﻿/* ============ RESET & BASE ============ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --ink:#17002B;
  --orange:#FE7C01;
  --purple:#71248A;
  --amber:#FDC834;
  --hot:#FF4F9A;
  --cyan:#25D5FF;
  --lime:#B7FF42;
  --white:#FFFFFF;
  --mist:#F6F1FB;
  --ink-soft:#5C4A70;
  --orange-tint:#FFE7CF;
  --purple-tint:#F0E1F6;
  --amber-tint:#FFF6D8;
  --font-display:'Baloo 2',sans-serif;
  --font-body:'Manrope',sans-serif;
  --font-mono:'Space Mono',monospace;
  --radius-lg:24px;
  --radius-md:18px;
  --radius-sm:12px;
  --border-size:2.5px;
  --border:var(--border-size) solid var(--ink);
  --shadow:6px 6px 0 var(--ink);
  --shadow-sm:4px 4px 0 var(--ink);
  --shadow-lg:10px 10px 0 var(--ink);
  --section-space:clamp(48px,6vw,76px);
  --grid-gap:20px;
}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-body);
  color:var(--ink-soft);
  background:var(--white);
  line-height:1.6;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
.product-img,
.shelf-product,
.slot-product,
.menu-product-img,
.mini-product-img{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  background:transparent;
  filter:drop-shadow(0 10px 12px rgba(23,0,43,.16));
}
a{color:inherit;text-decoration:none;}
button{font:inherit;cursor:pointer;background:none;border:none;}
ul{list-style:none;}
.container{max-width:1180px;margin:0 auto;padding:0 clamp(20px,4vw,32px);}
@media (max-width:640px){.container{padding:0 20px;}}

/* skip link */
.skip-link{position:absolute;left:-999px;top:0;background:var(--amber);color:var(--ink);padding:10px 18px;z-index:200;font-weight:700;}
.skip-link:focus{left:10px;top:10px;}
:focus-visible{outline:3px solid var(--purple);outline-offset:3px;}
@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}}

/* ============ TYPOGRAPHY ============ */
h1,h2,h3,h4{font-family:var(--font-display);color:var(--ink);line-height:1.08;font-weight:700;}
h1{font-size:clamp(2.6rem,6.2vw,5rem);}
h2{font-size:clamp(2rem,4.4vw,3.1rem);}
h3{font-size:clamp(1.25rem,2.2vw,1.55rem);}
.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--ink-soft);max-width:640px;}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--purple);margin-bottom:14px;}
.eyebrow.on-dark{color:var(--amber);}
.section-head{max-width:760px;margin-bottom:28px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}

/* ============ LAYOUT / SECTIONS ============ */
.section{padding:var(--section-space) 0;position:relative;overflow:hidden;}
.section-alt{background:var(--mist);}
.section-dark{background:var(--ink);color:#E7DBF2;}
.section-dark h2,.section-dark h3{color:var(--white);}
.section-dark .lead{color:#CDB9DE;}
.section-tight{padding:48px 0;}
@media (max-width:780px){.section{padding:48px 0;}}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--grid-gap);}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--grid-gap);}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--grid-gap);}
@media (max-width:900px){.grid-3{grid-template-columns:1fr 1fr;}.grid-4{grid-template-columns:1fr 1fr;}}
@media (max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}}

/* blobs */
.blob{position:absolute;border-radius:50%;filter:blur(50px);opacity:.4;z-index:0;pointer-events:none;}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:800;font-size:1rem;padding:14px 28px;border-radius:999px;border:var(--border);box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease,background .15s ease;white-space:nowrap;}
.btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.btn:active{transform:translate(1px,1px);box-shadow:1px 1px 0 var(--ink);}
.btn-primary{background:linear-gradient(135deg,var(--orange),var(--amber));color:var(--ink);}
.btn-secondary{background:var(--white);color:var(--ink);}
.btn-ghost{background:var(--amber);color:var(--ink);}
.btn-sm{padding:10px 20px;font-size:.85rem;box-shadow:var(--shadow-sm);}
.btn-sm:hover{box-shadow:var(--shadow);}
.btn-block{width:100%;justify-content:center;}

/* ============ BADGES (sticker style) ============ */
.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;background:var(--white);color:var(--ink);border:var(--border);border-radius:999px;padding:7px 14px;box-shadow:var(--shadow-sm);}
.badge--1{transform:rotate(-3deg);}
.badge--2{transform:rotate(2deg);}
.badge--3{transform:rotate(-1.5deg);}
.badge-row{display:flex;gap:14px;flex-wrap:wrap;}

/* ============ CARDS ============ */
.card{background:var(--white);border:var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow);padding:28px;transition:transform .2s ease,box-shadow .2s ease;}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.card-icon{font-size:2.1rem;display:inline-flex;align-items:center;justify-content:center;width:60px;height:60px;background:var(--amber-tint);border:var(--border-size) solid var(--ink);border-radius:16px;margin-bottom:18px;}
.card-title{font-size:1.25rem;margin-bottom:10px;}
.card-text{font-size:.97rem;color:var(--ink-soft);}

/* ============ NAV ============ */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);border-bottom:var(--border);backdrop-filter:blur(16px);}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px clamp(20px,4vw,32px);max-width:1180px;margin:0 auto;gap:20px;}
.brand{display:flex;align-items:center;}
.snapgo-logo{width:184px;height:auto;display:block;overflow:visible;}
.logo-chip{fill:var(--ink);transform:translate(4px,4px);}
.logo-machine{fill:var(--orange);stroke:var(--ink);stroke-width:4px;}
.logo-screen{fill:var(--ink);}
.logo-snack{stroke:var(--ink);stroke-width:2px;}
.logo-snack-1{fill:var(--amber);}
.logo-snack-2{fill:var(--white);}
.logo-snack-3{fill:var(--purple);}
.logo-bolt{fill:var(--amber);stroke:var(--ink);stroke-width:2px;stroke-linejoin:round;}
.logo-tray{fill:var(--purple);stroke:var(--ink);stroke-width:2px;}
.logo-word{font-family:var(--font-display);font-size:34px;font-weight:800;fill:var(--ink);letter-spacing:0;}
.logo-tag{font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:.16em;fill:var(--purple);}
.logo-swoosh{stroke:var(--orange);stroke-width:5px;}
.brand .snapgo-logo{transition:transform .2s ease,filter .2s ease;}
.brand:hover .snapgo-logo{transform:translateY(-2px) rotate(-1deg);filter:drop-shadow(3px 4px 0 rgba(23,0,43,.18));}
.nav-links{display:flex;align-items:center;gap:22px;}
.nav-link{font-weight:800;font-size:.95rem;color:var(--ink);position:relative;padding:8px 2px;letter-spacing:0;}
.nav-link::after{content:'';position:absolute;left:0;bottom:0;height:3px;width:0;background:linear-gradient(90deg,var(--orange),var(--hot),var(--cyan));transition:width .2s ease;border-radius:999px;}
.nav-link.active::after,.nav-link:hover::after{width:100%;}
.nav-link.active{color:var(--orange);}
.nav-cta{display:flex;align-items:center;gap:18px;}
.hamburger{display:none;font-size:1.6rem;line-height:1;background:var(--mist);border:var(--border);border-radius:10px;padding:6px 10px;}
.mobile-menu{display:none;}
@media (max-width:900px){
  .nav-links{display:none;}
  .nav-cta .btn{display:none;}
  .hamburger{display:block;}
  body.menu-open .mobile-menu{display:flex;}
  .mobile-menu{position:fixed;inset:0;top:75px;background:var(--mist);z-index:99;flex-direction:column;padding:30px 24px;gap:22px;overflow-y:auto;}
  .mobile-menu .nav-link{font-size:1.3rem;}
  .mobile-menu .btn{margin-top:10px;}
}

/* ============ HERO ============ */
.hero{padding:70px 0 60px;position:relative;}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center;position:relative;z-index:1;}
@media (max-width:900px){.hero-grid{grid-template-columns:1fr;}}
.hero-copy h1{margin-bottom:22px;}
.hero-copy h1 .accent{color:var(--orange);display:inline-block;transform:rotate(-2deg);}
.hero-copy .lead{margin-bottom:30px;}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:36px;}
.hero-visual{display:flex;justify-content:center;position:relative;}
.hero-fade-up{animation:fadeUp .7s ease both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:translateY(0);}}
.hero-copy>*:nth-child(1){animation-delay:0s;}
.hero-copy>*:nth-child(2){animation-delay:.08s;}
.hero-copy>*:nth-child(3){animation-delay:.16s;}
.hero-copy>*:nth-child(4){animation-delay:.24s;}
.hero-copy>*:nth-child(5){animation-delay:.32s;}

/* mock machine graphic for hero visual */
.mock-machine{width:260px;background:var(--purple);border:var(--border);border-radius:24px;padding:18px;box-shadow:var(--shadow-lg);position:relative;transform:rotate(-2deg);}
.mock-screen{background:var(--ink);color:var(--amber);font-family:var(--font-mono);font-size:.75rem;text-align:center;padding:10px;border-radius:8px;margin-bottom:14px;letter-spacing:.05em;}
.mock-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px;}
.mock-cell{background:rgba(255,255,255,.88);border:var(--border-size) solid var(--ink);border-radius:8px;font-size:1.4rem;display:flex;align-items:center;justify-content:center;aspect-ratio:1;padding:6px;}
.mock-tray{background:var(--orange);border:var(--border-size) solid var(--ink);border-radius:8px;height:34px;}
.mock-coin{position:absolute;top:-18px;right:-22px;background:var(--amber);border:var(--border);border-radius:50%;width:74px;height:74px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.68rem;font-weight:700;text-align:center;transform:rotate(8deg);box-shadow:var(--shadow-sm);}

/* ============ DEMO MACHINE (signature interactive) ============ */
.demo-wrap{display:grid;grid-template-columns:.95fr 1.05fr;gap:56px;align-items:center;position:relative;z-index:1;}
@media (max-width:900px){.demo-wrap{grid-template-columns:1fr;}}
.demo-counter{font-family:var(--font-mono);font-size:.95rem;background:var(--ink);color:var(--amber);display:inline-block;padding:10px 18px;border-radius:999px;margin-top:14px;}
.demo-counter span{color:var(--orange);font-weight:700;}
.demo-hint{font-size:.85rem;color:var(--ink-soft);margin-top:10px;font-style:italic;}
.machine{background:var(--purple);border:var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-lg);max-width:420px;margin:0 auto;position:relative;}
.machine-screen{background:var(--ink);color:var(--amber);font-family:var(--font-mono);font-size:.8rem;text-align:center;padding:12px;border-radius:10px;margin-bottom:16px;letter-spacing:.06em;}
.machine-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;}
.slot{position:relative;background:var(--white);border:var(--border-size) solid var(--ink);border-radius:14px;padding:10px 4px;display:flex;flex-direction:column;align-items:center;gap:4px;transition:transform .15s ease;overflow:visible;}
.slot:hover{transform:translateY(-3px);background:var(--amber-tint);}
.slot-emoji{font-size:1.6rem;width:100%;height:46px;display:grid;place-items:center;}
.slot-name{font-size:.62rem;font-weight:700;text-align:center;color:var(--ink);line-height:1.1;}
.slot-price{font-family:var(--font-mono);font-size:.62rem;color:var(--purple);}
.slot.pulse{animation:slotPulse .4s ease;}
@keyframes slotPulse{0%{transform:scale(1)}50%{transform:scale(.9)}100%{transform:scale(1)}}
.burst{position:absolute;top:-14px;right:-10px;font-size:1.6rem;pointer-events:none;animation:burstPop .7s ease forwards;}
@keyframes burstPop{0%{transform:scale(.2) rotate(0deg);opacity:0}30%{transform:scale(1.3) rotate(12deg);opacity:1}100%{transform:scale(1.6) rotate(20deg) translateY(-22px);opacity:0}}
.machine-tray{background:var(--orange);border:var(--border-size) solid var(--ink);border-radius:10px;min-height:42px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;padding:6px 10px;overflow:hidden;}
.dispensed-item{display:inline-flex;align-items:center;justify-content:center;gap:8px;max-width:100%;font-weight:900;font-size:.78rem;color:var(--ink);white-space:nowrap;}
.dispensed-item img{width:38px;height:30px;object-fit:contain;background:transparent;}
.machine-tray.is-dispensing .dispensed-item{animation:dispensePop .55s cubic-bezier(.2,.8,.2,1) both;}
@keyframes dispensePop{0%{opacity:0;transform:translateY(-18px) scale(.85);}70%{opacity:1;transform:translateY(2px) scale(1.08);}100%{opacity:1;transform:translateY(0) scale(1);}}
.machine-label{text-align:center;font-family:var(--font-mono);font-size:.62rem;color:var(--amber);letter-spacing:.08em;}
.toast{position:absolute;left:50%;bottom:-26px;transform:translate(-50%,10px);background:var(--ink);color:var(--amber);padding:10px 20px;border-radius:999px;font-family:var(--font-mono);font-size:.78rem;opacity:0;transition:opacity .25s ease,transform .25s ease;white-space:nowrap;border:var(--border-size) solid var(--amber);z-index:5;}
.toast.show{opacity:1;transform:translate(-50%,0);}

/* ============ FEATURE STRIP ============ */
.feature-card{background:var(--white);border:var(--border);border-radius:var(--radius-md);padding:28px;box-shadow:var(--shadow);}

/* ============ PROMISE BANNER ============ */
.promise-banner{background:var(--ink);padding:70px 0;text-align:center;position:relative;overflow:hidden;}
.promise-banner p{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem,3.6vw,2.6rem);color:var(--white);max-width:880px;margin:0 auto;line-height:1.3;position:relative;z-index:1;}
.promise-banner p .hi{color:var(--amber);}
.promise-banner p .hi2{color:var(--orange);}

/* ============ SPLIT PANEL (tech + payments) ============ */
.split-panel{display:grid;grid-template-columns:1fr 1fr;gap:0;background:var(--ink);border-radius:var(--radius-lg);overflow:hidden;border:var(--border);box-shadow:var(--shadow-lg);}
@media (max-width:780px){.split-panel{grid-template-columns:1fr;}}
.split-col{padding:44px 38px;}
.split-col + .split-col{border-left:3px solid rgba(255,255,255,.15);}
@media (max-width:780px){.split-col + .split-col{border-left:none;border-top:3px solid rgba(255,255,255,.15);}}
.split-col h3{color:var(--white);margin-bottom:22px;font-size:1.4rem;}
.feature-row{display:flex;gap:14px;margin-bottom:20px;}
.feature-row:last-child{margin-bottom:0;}
.feature-row-icon{font-size:1.4rem;flex-shrink:0;width:40px;height:40px;background:rgba(255,255,255,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;}
.feature-row-title{color:var(--amber);font-weight:700;font-size:.97rem;margin-bottom:3px;}
.feature-row-text{color:#CDB9DE;font-size:.88rem;}

/* ============ PREVIEW CARDS (who it's for, on home) ============ */
.preview-card{background:var(--mist);border:var(--border);border-radius:var(--radius-md);padding:30px;text-align:center;}
.preview-card .card-icon{margin:0 auto 16px;}

/* ============ FINAL CTA ============ */
.final-cta{background:var(--orange);border-radius:var(--radius-lg);border:var(--border);box-shadow:var(--shadow-lg);padding:60px 40px;text-align:center;position:relative;overflow:hidden;}
.final-cta h2{margin-bottom:18px;}
.final-cta .lead{margin:0 auto 28px;color:var(--ink);}

/* ============ PROCESS STEPS (about page) ============ */
.process-steps{display:flex;flex-direction:column;gap:0;max-width:760px;}
.step{display:flex;gap:24px;padding:24px 0;border-bottom:2.5px dashed rgba(23,0,43,.18);}
.step:last-child{border-bottom:none;}
.step-num{font-family:var(--font-display);font-size:1.8rem;font-weight:800;color:var(--orange);flex-shrink:0;width:56px;}
.step-title{font-size:1.15rem;margin-bottom:4px;color:var(--ink);font-family:var(--font-display);font-weight:700;}
.step-text{color:var(--ink-soft);font-size:.95rem;}

/* ============ VALUE CHIPS / STAT STRIP (about page) ============ */
.values-grid{display:flex;flex-wrap:wrap;gap:14px;}
.value-chip{background:var(--purple-tint);border:var(--border-size) solid var(--ink);border-radius:999px;padding:12px 22px;font-weight:700;font-size:.92rem;color:var(--ink);}
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media (max-width:780px){.stat-strip{grid-template-columns:1fr 1fr;}}
.stat{background:var(--ink);border-radius:var(--radius-md);padding:26px 18px;text-align:center;}
.stat-num{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--amber);font-weight:800;}
.stat-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.05em;color:#CDB9DE;text-transform:uppercase;margin-top:4px;}

/* ============ MENU PAGE ============ */
.menu-filters{display:flex;gap:12px;margin-bottom:36px;flex-wrap:wrap;}
.filter-btn{font-family:var(--font-body);font-weight:700;font-size:.9rem;padding:10px 22px;border-radius:999px;border:var(--border-size) solid var(--ink);background:var(--white);transition:.15s ease;}
.filter-btn.active{background:var(--ink);color:var(--amber);}
.menu-category-label{font-family:var(--font-display);font-size:1.4rem;color:var(--purple);margin:40px 0 20px;display:flex;align-items:center;gap:10px;}
.menu-category-label:first-of-type{margin-top:0;}
.menu-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;}
@media (max-width:980px){.menu-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:640px){.menu-grid{grid-template-columns:repeat(2,1fr);}}
.menu-item{background:var(--white);border:var(--border-size) solid var(--ink);border-radius:16px;padding:18px 12px;text-align:center;box-shadow:var(--shadow-sm);transition:transform .15s ease;}
.menu-item:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.menu-item-emoji{font-size:2rem;margin-bottom:8px;}
.menu-item-name{font-weight:800;font-size:.85rem;color:var(--ink);margin-bottom:3px;}
.menu-item-brand{font-size:.72rem;color:var(--ink-soft);margin-bottom:8px;}
.menu-item-price{font-family:var(--font-mono);font-size:.8rem;color:var(--orange);font-weight:700;background:var(--orange-tint);border-radius:999px;padding:3px 10px;display:inline-block;}
.menu-note{margin-top:40px;font-size:.88rem;color:var(--ink-soft);font-style:italic;}

/* ============ INDUSTRY CARDS (where page) ============ */
.industry-primary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-bottom:30px;}
@media (max-width:900px){.industry-primary-grid{grid-template-columns:1fr;}}
.industry-card--primary{background:var(--ink);border-radius:var(--radius-lg);border:var(--border);box-shadow:var(--shadow-lg);padding:34px;color:var(--white);position:relative;}
.industry-card--primary .badge{position:absolute;top:-14px;right:20px;}
.industry-card--primary .card-icon{background:var(--amber);}
.industry-card--primary h3{color:var(--white);}
.industry-card--primary p{color:#CDB9DE;font-size:.93rem;}
.industry-secondary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media (max-width:900px){.industry-secondary-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.industry-secondary-grid{grid-template-columns:1fr;}}
.industry-card--secondary{background:var(--white);border:var(--border-size) solid var(--ink);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm);}
.industry-card--secondary .card-icon{width:48px;height:48px;font-size:1.6rem;margin-bottom:12px;}
.industry-card--secondary h3{font-size:1.05rem;}
.industry-card--secondary p{font-size:.85rem;}

/* ============ CONTACT PAGE ============ */
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:start;}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.form-card{background:var(--white);border:var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:36px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:560px){.form-row{grid-template-columns:1fr;}}
.form-group{margin-bottom:18px;}
.form-group label{display:block;font-weight:700;font-size:.85rem;margin-bottom:7px;color:var(--ink);}
.form-group input,.form-group select,.form-group textarea{width:100%;font-family:var(--font-body);font-size:.95rem;padding:12px 14px;border:var(--border-size) solid var(--ink);border-radius:12px;background:var(--mist);color:var(--ink);}
.form-group textarea{resize:vertical;min-height:90px;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:3px solid var(--purple);outline-offset:1px;background:var(--white);}
.form-success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:50px 20px;}
.form-success .big-emoji{font-size:3rem;}
.contact-info-card{background:var(--purple);border:var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:32px;color:var(--white);margin-bottom:24px;}
.contact-info-card h3{color:var(--white);margin-bottom:18px;}
.contact-info-row{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px;}
.contact-info-row:last-child{margin-bottom:0;}
.contact-info-icon{font-size:1.3rem;flex-shrink:0;}
.contact-info-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;color:var(--amber);margin-bottom:2px;}
.contact-info-value{font-weight:700;font-size:.95rem;}

/* ============ FOOTER ============ */
.site-footer{background:var(--ink);color:#CDB9DE;padding:48px 0 24px;position:relative;overflow:hidden;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;position:relative;z-index:1;}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr;}}
.footer-logo .snapgo-logo{width:184px;margin-bottom:16px;filter:brightness(1.08);}
.site-footer .logo-chip{fill:#050008;}
.site-footer .logo-word{fill:var(--white);}
.site-footer .logo-tag{fill:var(--amber);}
.site-footer .logo-swoosh{stroke:var(--amber);}
.footer-tagline{font-size:.9rem;max-width:260px;}
.footer-col h4{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);margin-bottom:16px;}
.footer-col ul li{margin-bottom:10px;font-size:.92rem;}
.footer-col ul li a:hover{color:var(--white);}
.footer-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px;}
.footer-badges .badge{background:rgba(255,255,255,.06);color:var(--amber);border-color:rgba(255,255,255,.25);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);margin-top:32px;padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:.82rem;position:relative;z-index:1;}
.social-row{display:flex;gap:12px;}
.social-row a{width:36px;height:36px;border:2px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;}
.social-row a:hover{background:var(--orange);border-color:var(--orange);color:var(--ink);}

/* ============ PAGE SHELL ============ */
.page{display:block;}
.page.active{animation:pageIn .35s ease;}
@keyframes pageIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.page-hero-small{padding:56px 0 20px;}
.page-hero-small .lead{margin-top:14px;}

/* ============ COMPARE TABLE ============ */
.compare-table{border:var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow);}
.compare-header{display:grid;grid-template-columns:1.4fr 1fr 1fr;background:var(--ink);padding:14px 20px;}
.compare-col-label{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--amber);font-weight:700;}
.compare-col-new{color:var(--orange);}
.compare-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;padding:14px 20px;border-bottom:1.5px solid var(--mist);background:var(--white);transition:background .15s;}
.compare-row:last-child{border-bottom:none;}
.compare-row:hover{background:var(--mist);}
.compare-feature{font-weight:700;font-size:.9rem;color:var(--ink);}
.compare-old{font-size:.88rem;color:var(--ink-soft);}
.compare-new{font-size:.88rem;color:var(--purple);font-weight:700;}
@media (max-width:640px){.compare-header,.compare-row{grid-template-columns:1fr;gap:4px;}.compare-col-old,.compare-col-new{display:none;}.compare-old{color:var(--ink-soft);font-size:.8rem;}.compare-old::before{content:"Traditional: ";font-weight:700;color:var(--ink-soft);}.compare-new::before{content:"SnapGo: ";font-weight:700;color:var(--purple);}}

/* ============ PAGE HERO SMALL ============ */
.page-hero-small{padding:56px 0 40px;border-bottom:var(--border);margin-bottom:0;}
.page-hero-small .section-head{margin-bottom:0;}
