/* ════════════════════════════════════════════════════════
   TADAKADO — Design System
   Organised as:
     1. Design Tokens  (:root)
     2. Reset & Base
     3. Layout Utilities
     4. Typography Utilities
     5. Button Components
     6. Navigation
     7. Hero
     8. Trusted By (logo marquee)
     9. One Tadakado Voucher
    10. Feature Sections
    11. Redeem Rewards
    12. Comparison Table
    13. Two Voucher Options
    14. Advantages
    15. Use Cases
    16. Security
    17. Trusted Brands
    18. Footer
    19. Responsive Overrides
════════════════════════════════════════════════════════ */


/* ────────────────────────────────────────────────────────
   1. DESIGN TOKENS
   Edit here to retheme the entire site.
──────────────────────────────────────────────────────── */
:root {
  /* — Brand colours — */
  --color-primary:        #103294;
  --color-primary-hover:  #0d2677;
  --color-gold:           #FFB100;
  --color-gold-light:     #FFD154;
  --color-sky:            #2694F5;
  --color-success:        #22C55E;
  --color-danger:         #F87171;
  --color-info:           #7ECFFF;

  /* — Neutral palette — */
  --color-dark:           #282E40;
  --color-muted:          #555D6E;
  --color-subtle:         #959DA3;
  --color-white:          #ffffff;
  --color-bg:             #F8F9FE;
  --color-bg-card:        #dde4f5;

  /* — Dark surface palette (dark sections / footer) — */
  --color-navy:           #0B1F5E;
  --color-navy-deep:      #080F2E;

  /* — Tinted backgrounds — */
  --color-primary-tint:   #EEF4FF;
  --color-sky-tint:       #EDF5FF;
  --color-gold-tint:      #FFF8E6;
  --color-warm-tint:      #FFFAEF;

  /* — Typography — */
  --font-family:          'Poppins', sans-serif;

  --font-size-2xs:        11px;
  --font-size-xs:         12px;
  --font-size-sm:         13px;
  --font-size-base:       14px;
  --font-size-md:         15px;
  --font-size-lg:         16px;
  --font-size-xl:         18px;
  --font-size-2xl:        20px;
  --font-size-3xl:        clamp(22px, 2.5vw, 36px);
  --font-size-4xl:        clamp(24px, 3vw, 40px);
  --font-size-5xl:        clamp(28px, 3.5vw, 48px);
  --font-size-6xl:        clamp(32px, 4vw, 56px);

  --font-weight-normal:   400;
  --font-weight-medium:   500;
  --font-weight-semibold: 600;
  --font-weight-bold:     700;

  --line-height-tight:    1.1;
  --line-height-snug:     1.3;
  --line-height-normal:   1.5;
  --line-height-relaxed:  1.65;
  --line-height-loose:    1.7;

  /* — Spacing scale (4-point grid) — */
  --space-1:   4px;
  --space-2:   8px;
  --space-3:   12px;
  --space-4:   16px;
  --space-5:   20px;
  --space-6:   24px;
  --space-7:   28px;
  --space-8:   32px;
  --space-10:  40px;
  --space-12:  48px;
  --space-14:  56px;
  --space-16:  64px;
  --space-18:  72px;
  --space-20:  80px;

  /* — Border radius — */
  --radius-sm:   8px;
  --radius-md:   12px;
  --radius-lg:   16px;
  --radius-xl:   20px;
  --radius-2xl:  24px;
  --radius-3xl:  32px;
  --radius-4xl:  40px;
  --radius-full: 100px;

  /* — Shadows — */
  --shadow-xs:   0 2px 10px rgba(27,37,68,.07);
  --shadow-sm:   0 2px 12px rgba(27,37,68,.08);
  --shadow-md:   0 2px 16px rgba(27,37,68,.10);
  --shadow-lg:   0 6px 28px rgba(27,37,68,.12);
  --shadow-card: 0 20px 60px rgba(16,50,148,.12);

  /* — Layout — */
  --nav-height:        72px;
  --max-width:         1280px;
  --section-padding-x: var(--space-20);
  --section-padding-y: var(--space-20);
}


/* ────────────────────────────────────────────────────────
   2. RESET & BASE
──────────────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  color: var(--color-dark);
  line-height: var(--line-height-normal);
  overflow-x: hidden;
}

a {
  text-decoration: none;
  color: inherit;
}

img {
  display: block;
  max-width: 100%;
}

button {
  font-family: inherit;
  cursor: pointer;
}


/* ────────────────────────────────────────────────────────
   3. LAYOUT UTILITIES
──────────────────────────────────────────────────────── */
.sec {
  padding: var(--section-padding-y) var(--section-padding-x);
}

.sec-inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.sec-center {
  text-align: center;
}


/* ────────────────────────────────────────────────────────
   4. TYPOGRAPHY UTILITIES
──────────────────────────────────────────────────────── */
.sec-eyebrow {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  text-align: center;
}

.sec-title {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  line-height: var(--line-height-snug);
}

.sec-subtitle {
  font-size: var(--font-size-md);
  color: var(--color-muted);
  line-height: var(--line-height-relaxed);
  margin-top: var(--space-3);
}

/* Inline tag / pill label */
.tag {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  color: var(--color-primary);
  background: var(--color-primary-tint);
  border-radius: var(--radius-full);
  padding: 5px 14px;
  margin-bottom: var(--space-4);
}

.tag--gold {
  color: #B45309;
  background: #FEF3C7;
}


/* ────────────────────────────────────────────────────────
   5. BUTTON COMPONENTS
──────────────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  height: 46px;
  padding: 0 var(--space-7);
  background: var(--color-primary);
  border-radius: var(--radius-full);
  border: none;
  color: var(--color-white);
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  transition: background .2s;
}

.btn-primary:hover {
  background: var(--color-primary-hover);
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  height: 46px;
  padding: 0 var(--space-7);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-full);
  color: var(--color-primary);
  background: transparent;
  font-family: var(--font-family);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  transition: all .2s;
}

.btn-outline:hover {
  background: var(--color-primary);
  color: var(--color-white);
}


/* ────────────────────────────────────────────────────────
   6. NAVIGATION
──────────────────────────────────────────────────────── */
#nav-toggle {
  display: none;
}

.nav {
  position: sticky;
  top: 0;
  z-index: 200;
  width: 100%;
  height: var(--nav-height);
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(40,46,64,0.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--section-padding-x);
}

.nav-logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
}

.nav-logo img {
  width: 120px;
  height: auto;
}

.nav-links {
  display: flex;
  gap: 36px;
  list-style: none;
}

.nav-links a {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-dark);
  transition: color .2s;
}

.nav-links a:hover {
  color: var(--color-primary);
}

.nav-cta {
  height: 40px;
  padding: 0 var(--space-6);
  background: var(--color-primary);
  border-radius: var(--radius-full);
  color: var(--color-white);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  display: inline-flex;
  align-items: center;
  transition: background .2s;
}

.nav-cta:hover {
  background: var(--color-primary-hover);
}

/* Hamburger */
.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: var(--space-1);
  cursor: pointer;
}

.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-dark);
  border-radius: 2px;
  transition: all .3s;
}

/* Mobile drawer */
.nav-drawer {
  display: none;
  position: fixed;
  inset: var(--nav-height) 0 0 0;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(8px);
  z-index: 199;
  flex-direction: column;
  padding: var(--space-8) var(--space-6);
  gap: var(--space-7);
}

.nav-drawer .nav-links {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.nav-drawer .nav-links a {
  font-size: var(--font-size-xl);
}

.nav-drawer .nav-cta {
  width: fit-content;
  height: 48px;
  padding: 0 var(--space-8);
  font-size: var(--font-size-lg);
}

/* Checkbox nav toggle */
#nav-toggle:checked ~ .nav-drawer {
  display: flex;
}

#nav-toggle:checked ~ .nav .nav-hamburger span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

#nav-toggle:checked ~ .nav .nav-hamburger span:nth-child(2) {
  opacity: 0;
}

#nav-toggle:checked ~ .nav .nav-hamburger span:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px);
}


/* ────────────────────────────────────────────────────────
   7. HERO
   Desktop stage uses aspect-ratio 1440/900 so all
   absolute % positions match Figma pixel coords exactly.
──────────────────────────────────────────────────────── */
.hero-outer {
  width: 100%;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(255,255,255,.20) 0%, rgba(255,187,24,.06) 100%),
    linear-gradient(225deg, rgba(255,255,255,.20) 0%, rgba(99,210,250,.20) 100%),
    var(--color-white);
}

/* Scales with viewport, locks 1440:900 ratio */
.hero-stage {
  position: relative;
  width: 100%;
  max-width: 1440px;
  aspect-ratio: 1440 / 900;
  margin: 0 auto;
}

/* Golden orb — Figma: 468, 389 / 534 × 534 */
.h-orb {
  position: absolute;
  left: 32.5%;
  top: 43.2%;
  width: 37.1%;
  padding-top: 37.1%;
  background: linear-gradient(127deg, rgba(255,255,255,0) 0%, #FEDD8B 100%);
  border-radius: 50%;
  pointer-events: none;
}

/* Centred text block — Figma: 255, 150 / 931w */
.h-text {
  position: absolute;
  left: 17.71%;
  top: 16.67%;
  width: 64.65%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2.08%;
  text-align: center;
}

.h-headline {
  width: 100%;
  font-size: min(2.78vw, 40px);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-snug);
  color: var(--color-dark);
}

.h-headline .brand {
  color: var(--color-primary);
}

.h-subtitle {
  width: min(44.7%, 644px);
  font-size: min(1.11vw, 16px);
  color: var(--color-dark);
}

.h-subtitle strong {
  font-weight: var(--font-weight-semibold);
}

.h-cta {
  height: min(3.47vw, 50px);
  padding: min(.83vw, 12px) min(2.22vw, 32px);
  background: var(--color-primary);
  border-radius: var(--radius-full);
  border: none;
  color: var(--color-white);
  font-family: var(--font-family);
  font-size: min(.97vw, 14px);
  font-weight: var(--font-weight-medium);
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  transition: background .2s;
}

.h-cta:hover {
  background: var(--color-primary-hover);
}

/* App card — Figma: 210.5, 486 / inner 352 × 312 */
.h-app-card {
  position: absolute;
  left: 14.62%;
  top: 54%;
  padding: min(.75vw, 10.73px);
  background: var(--color-warm-tint);
  box-shadow: 0 min(.15vw, 2.15px) min(1.19vw, 17.17px) rgba(27,37,68,.10);
  border-radius: min(2.24vw, 32.2px);
  outline: min(.6vw, 8.59px) solid var(--color-white);
  outline-offset: min(-.3vw, -4.29px);
}

.h-app-inner {
  width: min(24.44vw, 352px);
  height: min(21.67vw, 312px);
  background: var(--color-white);
  border-radius: min(1.53vw, 22px);
  overflow: hidden;
}

.h-app-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Main product image — Figma: 520, 456 / 400 × 444 */
.h-main-img {
  position: absolute;
  left: 36.11%;
  top: 50.67%;
  width: 27.78%;
  height: 49.33%;
  object-fit: cover;
}

/* Decorative gold squares */
.h-sq {
  position: absolute;
  background: linear-gradient(180deg, var(--color-gold) 0%, var(--color-gold-light) 100%);
  outline-style: solid;
  outline-color: var(--color-white);
}

.h-sq-lg {
  left: 38.13%;
  top: 51.61%;
  width: 3.71%;
  padding-top: 5.94%;
  outline-width: min(.42vw, 6px);
}

.h-sq-sm {
  left: 37.71%;
  top: 51.33%;
  width: 1.27%;
  padding-top: 2.04%;
  outline-width: min(.42vw, 6px);
}

.h-sq-xs {
  left: 41.02%;
  top: 52.05%;
  width: 0.83%;
  padding-top: 1.33%;
  outline-width: min(.42vw, 6px);
}

/* Voucher chat bubble — Figma: 830, 432 / 243.63w */
.h-bubble {
  position: absolute;
  left: 57.64%;
  top: 48%;
  width: 16.92%;
  padding: min(.77vw, 11.07px);
  background: var(--color-white);
  box-shadow: 0 min(.13vw, 1.85px) min(1.03vw, 14.77px) rgba(27,37,68,.10);
  border-radius: 0 min(1.03vw, 14.77px) min(1.03vw, 14.77px) min(1.03vw, 14.77px);
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: min(.77vw, 11.07px);
}

.h-bubble-corner {
  position: absolute;
  width: min(1.73vw, 24.92px);
  height: min(1.73vw, 24.92px);
  left: min(-1.22vw, -17.53px);
  top: 0;
  background: var(--color-white);
  border-radius: 1.85px;
}

.h-bubble-text {
  width: 100%;
  font-size: min(.9vw, 12.92px);
  line-height: var(--line-height-snug);
  color: #333;
}

.h-bubble-time {
  color: var(--color-subtle);
  font-size: min(.77vw, 11.07px);
}

/* Avatar — Figma: 1034, 399 / 54 × 54 */
.h-avatar {
  position: absolute;
  left: 71.81%;
  top: 44.33%;
  width: min(3.75vw, 54px);
  height: min(3.75vw, 54px);
  border-radius: 50%;
  object-fit: cover;
}

/* Action pills — Figma: 863, 541 / 863, 592 */
.h-pill {
  position: absolute;
  left: 59.93%;
  width: 16.92%;
  height: min(3.01vw, 43.37px);
  background: var(--color-white);
  box-shadow: 0 min(.13vw, 1.85px) min(1.03vw, 14.77px) rgba(27,37,68,.10);
  border-radius: min(.77vw, 11.07px);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-sky);
  font-size: min(1.01vw, 14.5px);
  font-weight: var(--font-weight-medium);
}

.h-pill-1 { top: 60.11%; }
.h-pill-2 { top: 65.78%; }

/* Merchant tile stack — Figma: 886, 654 */
.h-merchants {
  position: absolute;
  left: 61.53%;
  top: 72.67%;
  display: flex;
  flex-direction: column;
}

.h-tile {
  width: min(7.33vw, 105.5px);
  height: min(7.33vw, 105.5px);
  padding: min(.96vw, 13.85px) min(1.1vw, 15.83px);
  background: var(--color-white);
  box-shadow: 0 min(.18vw, 2.64px) min(1.47vw, 21.1px) rgba(27,37,68,.10);
  border-radius: min(1.47vw, 21.1px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.h-tile img {
  max-width: 100%;
  max-height: 60%;
  object-fit: contain;
}

/* Mobile hero — hidden on desktop, shown < 1024px */
.hero-mobile {
  display: none;
}


/* ────────────────────────────────────────────────────────
   8. TRUSTED BY (logo marquee)
──────────────────────────────────────────────────────── */
.trusted {
  padding: var(--space-16) var(--section-padding-x);
  background: var(--color-white);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-7);
  overflow: hidden;
}

.runway {
  width: 100%;
  overflow: hidden;
  position: relative;
}

.runway::before,
.runway::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  width: 80px;
  z-index: 2;
  pointer-events: none;
}

.runway::before {
  left: 0;
  background: linear-gradient(to right, var(--color-white), transparent);
}

.runway::after {
  right: 0;
  background: linear-gradient(to left, var(--color-white), transparent);
}

.runway-track {
  display: flex;
  width: max-content;
  animation: rl 36s linear infinite;
}

.runway-track-r {
  animation: rr 36s linear infinite;
}

@keyframes rl {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes rr {
  0%   { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}

.runway-track:hover,
.runway-track-r:hover {
  animation-play-state: paused;
}

.logo-slot {
  width: 156px;
  height: 112px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3);
}

.logo-slot img {
  max-width: 100%;
  max-height: 68px;
  object-fit: contain;
}


/* ────────────────────────────────────────────────────────
   9. ONE TADAKADO VOUCHER
──────────────────────────────────────────────────────── */
.one-voucher {
  background: var(--color-white);
}

.one-voucher .sec-inner {
  display: flex;
  gap: var(--space-20);
  align-items: center;
}

.ov-text {
  flex: 1;
}

.ov-headline {
  font-size: var(--font-size-6xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-dark);
  margin-bottom: var(--space-8);
}

.ov-headline span {
  color: var(--color-primary);
}

.ov-badge {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full);
  width: fit-content;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--space-3);
}

.ov-badge-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.ov-online {
  background: var(--color-sky-tint);
  color: var(--color-dark);
}

.ov-online .ov-badge-dot {
  background: var(--color-sky);
}

.ov-offline {
  background: var(--color-gold-tint);
  color: var(--color-dark);
}

.ov-offline .ov-badge-dot {
  background: var(--color-gold);
}

.ov-visual {
  flex: 1;
  display: flex;
  justify-content: center;
}

.ov-phone {
  width: clamp(200px, 19.4vw, 280px);
  height: clamp(380px, 38.9vw, 560px);
  background: #f0f4ff;
  border-radius: var(--radius-4xl);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}

.ov-phone img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ────────────────────────────────────────────────────────
   10. FEATURE SECTIONS (QRIS / Travel)
──────────────────────────────────────────────────────── */
.feature-sec {
  background: var(--color-bg);
}

.feature-sec--white {
  background: var(--color-white);
}

.feature-split {
  display: flex;
  gap: 60px;
  align-items: center;
}

.feature-split--rev {
  flex-direction: row-reverse;
}

.feature-copy {
  flex: 1;
}

.feature-copy .sec-title {
  margin-bottom: var(--space-4);
}

.feature-imgs {
  flex: 1;
  position: relative;
  height: 380px;
  min-width: 0;
}

.fi-main {
  position: absolute;
  left: 0;
  top: 0;
  width: 58%;
  height: 100%;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--color-bg-card);
}

.fi-main--full {
  width: 100%;
}

.fi-sec {
  position: absolute;
  right: 0;
  top: 8%;
  width: 40%;
  height: 84%;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: #d0dff5;
}

.fi-main img,
.fi-sec img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Floating info card */
.float-card {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 220px;
}

.float-card--inline {
  position: static;
  margin-top: var(--space-6);
  display: inline-flex;
}

.float-card-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--color-primary-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-2xl);
  flex-shrink: 0;
}

.float-card-text {
  font-size: var(--font-size-sm);
  color: var(--color-dark);
}

.float-card-text strong {
  display: block;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
}


/* ────────────────────────────────────────────────────────
   11. REDEEM REWARDS (tabbed)
──────────────────────────────────────────────────────── */
.redeem-sec {
  background: var(--color-bg);
}

.redeem-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.redeem-header .sec-title {
  margin-top: var(--space-3);
}

.redeem-layout {
  display: flex;
  gap: var(--space-8);
  align-items: flex-start;
}

.redeem-tabs {
  flex: 0 0 240px;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.rtab {
  padding: 13px 18px;
  border-radius: var(--radius-md);
  border: none;
  font-family: var(--font-family);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-muted);
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: all .2s;
}

.rtab.active {
  background: var(--color-white);
  color: var(--color-primary);
  font-weight: var(--font-weight-semibold);
  box-shadow: var(--shadow-sm);
}

.rtab:hover:not(.active) {
  background: rgba(255,255,255,.6);
}

.redeem-phone {
  flex: 0 0 200px;
}

.redeem-mockup {
  width: 200px;
  height: 400px;
  background: var(--color-bg-card);
  border-radius: var(--radius-3xl);
  overflow: hidden;
}

.redeem-mockup img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.redeem-logos {
  flex: 1;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-content: flex-start;
  padding-top: var(--space-1);
}

.r-logo {
  width: 76px;
  height: 76px;
  background: var(--color-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3);
}

.r-logo img {
  max-width: 100%;
  max-height: 44px;
  object-fit: contain;
}


/* ────────────────────────────────────────────────────────
   12. COMPARISON TABLE
──────────────────────────────────────────────────────── */
.compare-sec {
  background: var(--color-white);
}

.compare-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.compare-layout {
  display: flex;
  gap: var(--space-12);
  align-items: flex-start;
}

.compare-wrap {
  flex: 1;
  overflow-x: auto;
}

table.ctable {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-size-base);
}

.ctable thead th {
  padding: var(--space-4) var(--space-5);
  text-align: center;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  border-bottom: 2px solid #eef0f5;
}

.ctable thead th:first-child {
  text-align: left;
}

.ctable thead th.c-tada {
  color: var(--color-primary);
}

.ctable tbody tr {
  border-bottom: 1px solid #f0f2f7;
}

.ctable tbody tr:last-child {
  border-bottom: none;
}

.ctable tbody td {
  padding: 13px var(--space-5);
  color: var(--color-muted);
}

.ctable tbody td:not(:first-child) {
  text-align: center;
}

.ck {
  color: var(--color-success);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
}

.cx {
  color: var(--color-danger);
  font-size: var(--font-size-xl);
  font-weight: var(--font-weight-bold);
}

.compare-phone {
  flex: 0 0 180px;
}

.compare-mockup {
  width: 180px;
  height: 360px;
  background: var(--color-bg-card);
  border-radius: var(--radius-3xl);
  overflow: hidden;
}

.compare-mockup img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ────────────────────────────────────────────────────────
   13. TWO VOUCHER OPTIONS (dark section)
──────────────────────────────────────────────────────── */
.two-voucher {
  background: var(--color-navy);
  color: var(--color-white);
}

.two-voucher .sec-inner {
  text-align: center;
}

.tv-title {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-2);
}

.tv-sub {
  font-size: var(--font-size-md);
  color: rgba(255,255,255,.65);
  margin-bottom: var(--space-12);
}

.tv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  text-align: left;
}

.tv-card {
  background: rgba(255,255,255,.07);
  border-radius: var(--radius-2xl);
  padding: 36px;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.tv-badge {
  width: fit-content;
  padding: 5px 14px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
}

.tv-badge--digital {
  background: rgba(38,148,245,.2);
  color: var(--color-info);
}

.tv-badge--physical {
  background: rgba(255,177,0,.2);
  color: var(--color-gold-light);
}

.tv-card h3 {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
}

.tv-card p {
  font-size: var(--font-size-base);
  color: rgba(255,255,255,.7);
  line-height: var(--line-height-relaxed);
}

.tv-img {
  width: 100%;
  height: 220px;
  background: rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-top: var(--space-2);
}

.tv-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ────────────────────────────────────────────────────────
   14. ADVANTAGES GRID
──────────────────────────────────────────────────────── */
.adv-sec {
  background: var(--color-bg);
}

.adv-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.adv-header .sec-subtitle {
  max-width: 560px;
  margin: var(--space-3) auto 0;
}

.adv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.adv-card {
  background: var(--color-white);
  border-radius: var(--radius-xl);
  padding: var(--space-8);
  box-shadow: var(--shadow-md);
}

.adv-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-lg);
  background: var(--color-primary-tint);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--font-size-2xl);
  margin-bottom: var(--space-4);
}

.adv-card h3 {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  margin-bottom: var(--space-2);
}

.adv-card p {
  font-size: var(--font-size-base);
  color: var(--color-muted);
  line-height: var(--line-height-relaxed);
}


/* ────────────────────────────────────────────────────────
   15. FLEXIBLE USE CASES
──────────────────────────────────────────────────────── */
.uc-sec {
  background: var(--color-white);
}

.uc-header {
  text-align: center;
  margin-bottom: 60px;
}

.uc-item {
  display: flex;
  gap: 64px;
  align-items: center;
  margin-bottom: var(--space-18);
}

.uc-item:last-child {
  margin-bottom: 0;
}

.uc-item--rev {
  flex-direction: row-reverse;
}

.uc-img {
  flex: 0 0 480px;
  height: 360px;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  background: var(--color-bg-card);
}

.uc-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.uc-copy {
  flex: 1;
}

.uc-copy h3 {
  font-size: clamp(20px, 2vw, 28px);
  font-weight: var(--font-weight-bold);
  color: var(--color-dark);
  margin: var(--space-3) 0;
}

.uc-copy p {
  font-size: var(--font-size-base);
  color: var(--color-muted);
  line-height: var(--line-height-loose);
  margin-bottom: var(--space-6);
}

.uc-logos {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.uc-logo {
  width: 60px;
  height: 38px;
  border-radius: var(--radius-sm);
  background: #f5f6fa;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px;
}

.uc-logo img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}


/* ────────────────────────────────────────────────────────
   16. SECURITY (dark blue)
──────────────────────────────────────────────────────── */
.security-sec {
  background: var(--color-primary);
  color: var(--color-white);
}

.security-inner {
  display: flex;
  gap: var(--space-20);
  align-items: center;
}

.sec-copy {
  flex: 1;
}

.sec-copy h2 {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.35;
  margin-bottom: var(--space-7);
}

.sec-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.sec-list li {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  font-size: var(--font-size-md);
  color: rgba(255,255,255,.85);
  line-height: var(--line-height-normal);
}

.sec-list li::before {
  content: '✓';
  color: var(--color-info);
  font-weight: var(--font-weight-bold);
  flex-shrink: 0;
  margin-top: 1px;
}

.sec-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-7);
}

.sec-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.12);
  border-radius: var(--radius-full);
  padding: 7px var(--space-4);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.sec-visual {
  flex: 0 0 400px;
  height: 360px;
  border-radius: var(--radius-2xl);
  background: rgba(255,255,255,.08);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sec-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ────────────────────────────────────────────────────────
   17. TRUSTED BRANDS GRID
──────────────────────────────────────────────────────── */
.brands-sec {
  background: var(--color-bg);
}

.brands-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.brands-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--space-4);
}

.brand-tile {
  background: var(--color-white);
  border-radius: var(--radius-lg);
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3);
  box-shadow: var(--shadow-xs);
}

.brand-tile img {
  max-width: 100%;
  max-height: 44px;
  object-fit: contain;
}


/* ────────────────────────────────────────────────────────
   18. FOOTER
──────────────────────────────────────────────────────── */
footer {
  background: var(--color-navy-deep);
  color: rgba(255,255,255,.65);
  padding: var(--space-16) var(--section-padding-x) var(--space-10);
}

.ft-inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.ft-top {
  display: flex;
  gap: 64px;
  margin-bottom: var(--space-12);
}

.ft-brand {
  flex: 0 0 260px;
}

.ft-logo {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  margin-bottom: var(--space-3);
}

.ft-logo img {
  width: 120px;
  height: auto;
}

.ft-brand p {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
}

.ft-cols {
  flex: 1;
  display: flex;
  gap: var(--space-10);
}

.ft-col h4 {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  color: var(--color-white);
  margin-bottom: var(--space-4);
}

.ft-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.ft-col ul li a {
  font-size: var(--font-size-base);
  color: rgba(255,255,255,.55);
  transition: color .2s;
}

.ft-col ul li a:hover {
  color: var(--color-white);
}

.ft-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: var(--space-6);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-sm);
}

.social-row {
  display: flex;
  gap: var(--space-3);
}

.social-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  transition: background .2s;
}

.social-btn:hover {
  background: rgba(255,255,255,.18);
}


/* ────────────────────────────────────────────────────────
   19. RESPONSIVE OVERRIDES
──────────────────────────────────────────────────────── */

/* Tablet / small desktop: switch hero to mobile layout */
@media (max-width: 1024px) {
  .hero-stage {
    display: none;
  }

  .hero-mobile {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-7);
    padding: var(--space-16) var(--space-6) var(--space-12);
    background:
      linear-gradient(135deg, rgba(255,255,255,.20) 0%, rgba(255,187,24,.06) 100%),
      linear-gradient(225deg, rgba(255,255,255,.20) 0%, rgba(99,210,250,.20) 100%),
      var(--color-white);
    text-align: center;
  }

  .hm-headline {
    font-size: clamp(26px, 5vw, 40px);
    font-weight: var(--font-weight-bold);
    line-height: var(--line-height-snug);
    color: var(--color-dark);
  }

  .hm-headline span {
    color: var(--color-primary);
  }

  .hm-sub {
    font-size: var(--font-size-md);
    color: var(--color-dark);
    max-width: 520px;
  }

  .hm-sub strong {
    font-weight: var(--font-weight-semibold);
  }

  .hm-cta {
    height: 50px;
    padding: 0 var(--space-8);
    background: var(--color-primary);
    border-radius: var(--radius-full);
    border: none;
    color: var(--color-white);
    font-family: var(--font-family);
    font-size: var(--font-size-md);
    font-weight: var(--font-weight-medium);
    cursor: pointer;
  }

  .hm-img-wrap {
    width: 100%;
    max-width: 380px;
    height: 300px;
    background: linear-gradient(135deg, #dde8ff, #f0f4ff);
    border-radius: var(--radius-3xl);
    overflow: hidden;
  }

  .hm-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .hm-bubble {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--space-3) var(--space-4);
    box-shadow: var(--shadow-md);
    font-size: var(--font-size-sm);
    color: #333;
    line-height: var(--line-height-normal);
    max-width: 340px;
    width: 100%;
  }
}

/* Mobile */
@media (max-width: 900px) {
  .nav {
    padding: 0 var(--space-6);
  }

  .nav-links,
  .nav-cta {
    display: none;
  }

  .nav-hamburger {
    display: flex;
  }

  .sec {
    padding: var(--space-14) var(--space-6);
  }

  .trusted {
    padding: var(--space-14) var(--space-6);
  }

  /* One Voucher */
  .one-voucher .sec-inner {
    flex-direction: column;
    gap: var(--space-10);
  }

  .ov-text {
    text-align: center;
  }

  .ov-badge {
    margin: 0 auto;
  }

  /* Feature splits */
  .feature-split,
  .feature-split--rev {
    flex-direction: column;
    gap: var(--space-8);
  }

  .feature-imgs {
    width: 100%;
    height: 260px;
  }

  .fi-main {
    width: 60%;
    height: 100%;
  }

  .fi-sec {
    width: 37%;
  }

  /* Redeem */
  .redeem-layout {
    flex-direction: column;
  }

  .redeem-tabs {
    width: 100%;
    flex: none;
  }

  .redeem-phone {
    display: none;
  }

  /* Compare */
  .compare-layout {
    flex-direction: column;
  }

  .compare-phone {
    display: none;
  }

  /* Two voucher */
  .tv-grid {
    grid-template-columns: 1fr;
  }

  /* Advantages */
  .adv-grid {
    grid-template-columns: 1fr 1fr;
  }

  /* Use cases */
  .uc-item,
  .uc-item--rev {
    flex-direction: column;
    gap: var(--space-7);
  }

  .uc-img {
    flex: none;
    width: 100%;
    height: 220px;
  }

  /* Security */
  .security-inner {
    flex-direction: column;
  }

  .sec-visual {
    flex: none;
    width: 100%;
  }

  /* Footer */
  .ft-top {
    flex-direction: column;
    gap: var(--space-10);
  }

  .ft-cols {
    flex-wrap: wrap;
    gap: var(--space-7);
  }

  .ft-brand {
    flex: none;
  }

  .ft-bottom {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }

  footer {
    padding: var(--space-12) var(--space-6) var(--space-8);
  }
}

/* Small mobile */
@media (max-width: 560px) {
  .adv-grid {
    grid-template-columns: 1fr;
  }

  .tv-card {
    padding: var(--space-6);
  }
}
