/* ============================================================
   T&W Coffee Co. — Franchise Navigator
   Design system — LIGHT theme (clean, white, trustworthy)
   Warm paper base + brand green accent + Onest.
   ============================================================ */

:root{
  /* base — warm clean paper, white cards */
  --ink:#F5F2EC;
  --ink-2:#ECE8DF;
  --panel:#FFFFFF;
  --panel-2:#F4F1EA;
  --panel-3:#EAE6DD;
  --line:rgba(24,22,16,.10);
  --line-strong:rgba(24,22,16,.20);

  /* text — dark on light (var name kept for compatibility) */
  --white:#1A1B14;
  --light:#34362C;
  --gray:#5E6056;
  --gray-2:#8B8D82;

  /* brand green */
  --green:#79C94E;
  --green-deep:#5DA539;
  --green-bright:#3C8B23;            /* readable green accent/text on light */
  --green-soft:rgba(121,201,78,.13);
  --green-line:rgba(93,165,57,.30);
  --grad-green:linear-gradient(180deg,#8FD957,#5DA539);
  --grad-green-135:linear-gradient(135deg,#8FD957,#5DA539);

  /* warm accent (sparingly) */
  --cream:#A9743D;

  /* service */
  --red:#D8434A;
  --red-soft:rgba(216,67,74,.10);

  /* layout */
  --maxw:1200px;
  --radius:24px;
  --radius-lg:30px;
  --radius-sm:16px;
  --header-h:80px;

  --ease:cubic-bezier(.22,.7,.2,1);
}

*{ box-sizing:border-box; }
*::selection{ background:rgba(121,201,78,.30); color:#0c1707; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--ink);
  background-image:
    radial-gradient(900px 600px at 88% -5%, rgba(121,201,78,.10), transparent 60%),
    radial-gradient(800px 700px at -8% 8%, rgba(121,201,78,.07), transparent 55%),
    radial-gradient(1000px 800px at 50% 120%, rgba(121,201,78,.06), transparent 60%);
  color:var(--white);
  font-family:'Onest',system-ui,sans-serif;
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; }
input{ font-family:inherit; }

/* ---------- typography ---------- */
h1,h2,h3,h4{ margin:0; font-weight:800; letter-spacing:-.02em; line-height:1.05; text-wrap:balance; }
h1{ font-size:clamp(40px,6.4vw,84px); }
h2{ font-size:clamp(30px,4.4vw,56px); }
h3{ font-size:clamp(22px,2.4vw,30px); letter-spacing:-.015em; }
p{ margin:0; text-wrap:pretty; }

.script{ font-family:'Caveat',cursive; font-weight:700; color:var(--green-bright); }
.gtext{ color:var(--green-bright); }
.chip{
  display:inline-block; background:var(--grad-green); color:#0c1707;
  padding:.02em .32em .12em; border-radius:14px; letter-spacing:-.01em;
  box-decoration-break:clone; -webkit-box-decoration-break:clone;
  box-shadow:0 10px 30px -12px rgba(121,201,78,.55);
}

/* eyebrow / kicker */
.eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-size:14px; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
  color:var(--green-bright);
}
.eyebrow::before{ content:""; width:34px; height:2px; background:var(--green); border-radius:2px; }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:34px; height:2px; background:var(--green); border-radius:2px; }

/* ---------- layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:24px; }
.wrap-narrow{ max-width:920px; }
.section{ padding:clamp(70px,9vw,128px) 0; position:relative; }
.section-tight{ padding:clamp(48px,6vw,80px) 0; }
.center{ text-align:center; }
.lead{ font-size:clamp(18px,1.7vw,21px); line-height:1.55; color:var(--gray); }
.section-head{ max-width:760px; margin:0 auto clamp(40px,5vw,64px); text-align:center; }
.section-head .lead{ margin-top:18px; }
.section-head h2 .gtext{ display:inline; }

/* decorative glow */
.glow{ position:absolute; border-radius:50%; filter:blur(20px); pointer-events:none; z-index:0; }
.glow-green{ background:radial-gradient(circle,rgba(121,201,78,.16),transparent 66%); }

/* alternating section bg — feathered top/bottom so transitions blend smoothly */
.bg-alt{ background:
  radial-gradient(120% 90% at 85% 0%, rgba(121,201,78,.10) 0%, rgba(245,242,236,0) 48%),
  linear-gradient(180deg, rgba(255,255,255,0) 0%, #FBF9F4 9%, #FBF9F4 91%, rgba(255,255,255,0) 100%); }
.bg-deep{ background:
  linear-gradient(180deg, rgba(236,232,223,0) 0%, #EFEBE2 9%, #EFEBE2 91%, rgba(236,232,223,0) 100%); }
/* soft hairline glow between consecutive sections */
.section, .section-tight{ position:relative; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:16px 28px; border-radius:16px; font-weight:700; font-size:16px;
  border:1px solid transparent; transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s, border-color .2s;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--grad-green); color:#0c1707; box-shadow:0 16px 40px -14px rgba(121,201,78,.6); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 22px 50px -14px rgba(121,201,78,.75); }
.btn-ghost{ background:rgba(24,22,16,.035); color:var(--white); border-color:var(--line-strong); }
.btn-ghost:hover{ background:rgba(24,22,16,.07); transform:translateY(-2px); }
.btn-lg{ padding:19px 36px; font-size:18px; border-radius:18px; }
.btn-sm{ padding:11px 18px; font-size:14px; border-radius:12px; }

/* ---------- cards ---------- */
.card{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  position:relative; box-shadow:0 1px 2px rgba(24,22,16,.04), 0 18px 40px -28px rgba(24,22,16,.22);
}
.card-soft{ background:linear-gradient(160deg,#FFFFFF,#FAF8F2); }
.card-green{ background:linear-gradient(160deg,rgba(121,201,78,.14),rgba(93,165,57,.04)); border-color:var(--green-line); }
.card-pad{ padding:clamp(24px,3vw,40px); }
.card-hover{ transition:transform .25s var(--ease), border-color .25s; }
.card-hover:hover{ transform:translateY(-4px); border-color:var(--green-line); }

/* numbered badge (brand motif) */
.nbadge{
  width:52px; height:52px; flex:none; border-radius:15px; display:grid; place-items:center;
  font-size:24px; font-weight:800; color:var(--green-bright);
  border:1.5px solid var(--green-line); background:var(--green-soft);
}
.nbadge.round{ border-radius:50%; }
.nbadge.solid{ background:var(--grad-green); color:#0c1707; border:none; }

/* pill */
.pill{
  display:inline-flex; align-items:center; gap:12px;
  background:var(--panel); border:1px solid var(--line); border-radius:14px;
  padding:14px 20px; font-weight:600; color:var(--white); font-size:15px;
}
.pill .dot{ width:11px; height:11px; border-radius:50%; background:var(--green); flex:none; box-shadow:0 0 14px rgba(121,201,78,.6); }

/* stat */
.stat .v{ font-weight:800; letter-spacing:-.03em; line-height:.9; color:var(--green-bright); font-size:clamp(48px,6vw,84px); }
.stat .l{ color:var(--gray); font-weight:600; margin-top:10px; font-size:16px; }

/* tag */
.tag{ display:inline-block; font-size:12px; font-weight:700; letter-spacing:.04em; padding:5px 11px; border-radius:999px;
  background:var(--green-soft); color:var(--green-bright); border:1px solid var(--green-line); }
.tag-amber{ background:rgba(201,160,122,.14); color:var(--cream); border-color:rgba(201,160,122,.3); }

/* leaf decor */
.leaf{ position:absolute; width:42px; height:18px; background:var(--grad-green-135);
  border-radius:0 100% 0 100%; transform:rotate(20deg); opacity:.7; pointer-events:none; z-index:1; }

/* ---------- header (floating rounded pill) ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:90;
  display:flex; align-items:center; padding:11px 16px;
  background:transparent; border:none;
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:14px; max-width:1340px;
  background:rgba(255,255,255,.86); -webkit-backdrop-filter:blur(18px) saturate(1.3); backdrop-filter:blur(18px) saturate(1.3);
  border:1px solid rgba(255,255,255,.7); border-radius:18px; padding:8px 8px 8px 18px;
  box-shadow:0 14px 38px -20px rgba(24,22,16,.45), 0 1px 0 rgba(255,255,255,.7) inset; }
.logo{ display:flex; align-items:center; gap:10px; flex:none; }
.logo .wordmark{ height:21px; width:auto; display:block; }
.logo .mono{ width:34px; height:34px; }
.nav{ display:flex; align-items:center; gap:1px; flex-wrap:nowrap; }
.nav a{
  display:flex; align-items:center; gap:6px; padding:8px 9px; border-radius:11px;
  font-size:13px; font-weight:600; color:var(--gray); transition:color .18s, background .18s;
  position:relative; white-space:nowrap;
}
.nav a .ic{ font-size:14px; line-height:1; }
.nav a:hover{ color:var(--white); background:rgba(24,22,16,.05); border-radius:999px; }
.nav a.active{ color:var(--green-bright); }
.nav a.active::after{ content:""; position:absolute; left:11px; right:11px; bottom:2px; height:2px; background:var(--green); border-radius:2px; }
.nav a .visited{ width:13px; height:13px; color:var(--green); opacity:.85; }
.header-actions{ display:flex; align-items:center; gap:10px; flex:none; }
.header-phone{ display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:999px; border:1px solid var(--line-strong); font-size:13px; font-weight:600; color:var(--white); transition:background .18s; white-space:nowrap; }
.header-phone:hover{ background:rgba(24,22,16,.06); }
.header-phone svg{ width:15px; height:15px; flex:none; }
.burger{ display:none; background:rgba(24,22,16,.05); border:none; color:var(--white); padding:9px; width:42px; height:42px; border-radius:999px; align-items:center; justify-content:center; }
.burger svg{ width:24px; height:24px; }

/* mobile menu (floating rounded panel) */
.mobile-menu{ display:none; position:fixed; top:calc(var(--header-h) - 2px); left:12px; right:12px; z-index:89;
  background:rgba(255,255,255,.98); -webkit-backdrop-filter:blur(18px); backdrop-filter:blur(18px);
  border:1px solid var(--line); border-radius:22px; padding:12px;
  box-shadow:0 34px 66px -26px rgba(24,22,16,.5); }
.mobile-menu.open{ display:block; }
.mobile-menu a{ display:flex; align-items:center; gap:14px; padding:15px 16px; border-radius:14px; font-weight:600; color:var(--light); font-size:16px; }
.mobile-menu a svg{ width:20px; height:20px; flex:none; }
.mobile-menu a.active{ color:var(--green-bright); background:rgba(121,201,78,.08); }
.mobile-menu a .visited{ margin-left:auto; width:18px; height:18px; color:var(--green); }

/* scroll progress */
.scroll-progress{ position:fixed; top:0; left:0; height:3px; width:0; z-index:100; background:var(--grad-green-135); box-shadow:0 0 12px rgba(121,201,78,.6); transition:width .1s linear; }

/* ---------- footer ---------- */
.site-footer{ background:var(--ink-2); border-top:1px solid var(--line); padding:72px 0 40px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.1fr; gap:40px; margin-bottom:48px; }
.footer-brand .logo{ font-size:24px; margin-bottom:14px; }
.footer-brand p{ color:var(--gray); font-size:15px; max-width:280px; }
.footer-col h4{ font-size:13px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gray-2); margin-bottom:18px; }
.footer-col a{ display:block; color:var(--gray); font-size:15px; padding:5px 0; transition:color .18s; }
.footer-col a:hover{ color:var(--white); }
.footer-social{ display:flex; flex-wrap:wrap; gap:10px; }
.footer-social a{ width:42px; height:42px; border-radius:50%; background:rgba(24,22,16,.05); display:grid; place-items:center; font-size:12px; font-weight:700; color:var(--light); transition:background .18s, transform .18s; }
.footer-social a:hover{ background:var(--green-soft); color:var(--green-bright); transform:translateY(-2px); }
.footer-bottom{ border-top:1px solid var(--line); padding-top:28px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; color:var(--gray-2); font-size:14px; }

/* ---------- floating CTA ---------- */
.fab-wrap{ position:fixed; bottom:24px; right:24px; z-index:80; display:flex; flex-direction:column; align-items:flex-end; gap:12px; }
.fab-panel{ background:var(--panel-2); border:1px solid var(--line-strong); border-radius:20px; padding:18px; width:248px; box-shadow:0 30px 60px -20px rgba(0,0,0,.7);
  opacity:0; transform:translateY(12px) scale(.97); pointer-events:none; transition:all .25s var(--ease); }
.fab-panel.open{ opacity:1; transform:none; pointer-events:auto; }
.fab-panel p{ font-weight:700; font-size:15px; margin-bottom:14px; }
.fab-panel a{ display:flex; align-items:center; gap:10px; padding:12px 16px; border-radius:13px; font-weight:600; font-size:14px; margin-bottom:8px; color:#fff; }
.fab-panel a:last-child{ margin-bottom:0; }
.fab-btn{ width:60px; height:60px; border-radius:50%; border:none; background:var(--grad-green); display:grid; place-items:center; color:#0c1707; box-shadow:0 18px 40px -12px rgba(121,201,78,.6); transition:transform .2s var(--ease); align-self:flex-end; }
.fab-btn:hover{ transform:scale(1.08); }
.fab-btn svg{ width:26px; height:26px; }

/* ---------- accordion ---------- */
.accordion{ display:flex; flex-direction:column; gap:12px; }
.acc-item{ border:1px solid var(--line); border-radius:20px; background:var(--panel); overflow:hidden; transition:border-color .2s, background .2s; }
.acc-item.open{ border-color:var(--green-line); background:rgba(121,201,78,.045); }
.acc-head{ width:100%; display:flex; align-items:center; gap:18px; padding:22px 24px; text-align:left; background:none; border:none; color:var(--white); }
.acc-head .ic{ font-size:24px; flex:none; }
.acc-head .num{ flex:none; }
.acc-title{ flex:1; font-weight:700; font-size:clamp(15px,1.7vw,18px); }
.acc-chev{ width:22px; height:22px; color:var(--gray); transition:transform .3s var(--ease); flex:none; }
.acc-item.open .acc-chev{ transform:rotate(180deg); }
.acc-body{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .35s var(--ease); }
.acc-item.open .acc-body{ grid-template-rows:1fr; }
.acc-body-inner{ overflow:hidden; }
.acc-body p{ padding:0 24px 24px 60px; color:var(--gray); font-size:15.5px; line-height:1.6; }

/* ---------- tabs ---------- */
.tabs{ display:flex; justify-content:center; gap:10px; flex-wrap:wrap; margin-bottom:40px; }
.tab-btn{ padding:13px 26px; border-radius:14px; font-weight:700; font-size:15px; color:var(--gray);
  background:rgba(24,22,16,.045); border:1px solid var(--line); transition:all .2s var(--ease); }
.tab-btn:hover{ color:var(--white); }
.tab-btn.active{ background:var(--grad-green); color:#0c1707; border-color:transparent; transform:translateY(-1px); box-shadow:0 12px 30px -12px rgba(121,201,78,.5); }

/* filter chips */
.filters{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:28px; }
.filter-chip{ padding:10px 18px; border-radius:12px; font-size:14px; font-weight:600; color:var(--gray);
  background:rgba(24,22,16,.045); border:1px solid var(--line); transition:all .18s; }
.filter-chip:hover{ color:var(--white); }
.filter-chip.active{ background:var(--grad-green); color:#0c1707; border-color:transparent; }

/* ---------- table ---------- */
.table-scroll{ overflow-x:auto; border-radius:var(--radius); border:1px solid var(--line); }
table.tw{ width:100%; border-collapse:collapse; min-width:680px; }
table.tw th{ text-align:left; font-size:12px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--gray-2); padding:18px 16px; background:var(--panel-2); }
table.tw td{ padding:16px; border-top:1px solid var(--line); font-size:15px; }
table.tw tbody tr:hover{ background:rgba(121,201,78,.04); }
.td-right{ text-align:right; }
.td-center{ text-align:center; }

/* number input row */
.num-row{ display:flex; align-items:flex-start; justify-content:space-between; gap:12px; padding:13px 0; border-bottom:1px solid var(--line); }
.num-row:last-child{ border-bottom:none; }
.num-row .lab{ font-size:15px; color:var(--light); }
.num-row .hint{ font-size:12.5px; color:var(--gray-2); margin-top:3px; }
.num-input{ width:120px; text-align:right; font-weight:700; font-size:15px; color:var(--green-bright);
  background:var(--panel-3); border:1px solid var(--line); border-radius:11px; padding:9px 12px; }
.num-input:focus{ outline:none; border-color:var(--green); }
.num-suffix{ width:22px; font-size:13px; color:var(--gray); }

/* toggle switch */
.switch{ width:46px; height:26px; border-radius:999px; background:var(--panel-3); border:1px solid var(--line-strong); position:relative; transition:background .2s; flex:none; }
.switch.on{ background:var(--green-deep); border-color:transparent; }
.switch::after{ content:""; position:absolute; top:2px; left:2px; width:20px; height:20px; border-radius:50%; background:#fff; transition:left .2s var(--ease); }
.switch.on::after{ left:22px; }

/* segment chips for points */
.seg{ display:flex; gap:8px; flex-wrap:wrap; }
.seg button{ padding:10px 18px; border-radius:12px; font-weight:700; font-size:15px; background:rgba(24,22,16,.045); border:1px solid var(--line); color:var(--gray); transition:all .18s; }
.seg button.active{ background:var(--grad-green); color:#0c1707; border-color:transparent; }

/* checkbox row */
.check-row{ display:flex; gap:16px; padding:20px 22px; border:1px solid var(--line); border-radius:18px; background:var(--panel); cursor:pointer; transition:border-color .2s, background .2s; }
.check-row.checked{ border-color:var(--green-line); background:rgba(121,201,78,.06); }
.check-box{ width:26px; height:26px; flex:none; border-radius:8px; border:2px solid var(--line-strong); display:grid; place-items:center; transition:all .2s; margin-top:2px; }
.check-row.checked .check-box{ background:var(--grad-green); border-color:transparent; }
.check-box svg{ width:16px; height:16px; color:#0c1707; opacity:0; transition:opacity .2s; }
.check-row.checked .check-box svg{ opacity:1; }

/* ---------- reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* insight banner */
.insight{ max-width:760px; margin:0 auto; display:flex; gap:16px; align-items:flex-start;
  background:var(--green-soft); border:1px solid var(--green-line); border-radius:20px; padding:22px 26px; }
.insight .em{ font-size:24px; flex:none; }
.insight p{ color:var(--light); font-size:16px; line-height:1.55; }

/* next chapter */
.next-chapter{ max-width:760px; margin:36px auto 0; display:flex; justify-content:center; }
.next-chapter a{ display:inline-flex; align-items:center; gap:12px; padding:18px 30px; border-radius:18px;
  background:var(--panel); border:1px solid var(--line-strong); font-weight:700; transition:all .2s var(--ease); }
.next-chapter a:hover{ border-color:var(--green-line); background:rgba(121,201,78,.06); transform:translateY(-2px); }
.next-chapter .sub{ color:var(--gray-2); font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.1em; display:block; }
.next-chapter .nm{ color:var(--green-bright); }

/* modal */
.modal-backdrop{ position:fixed; inset:0; z-index:120; background:rgba(0,0,0,.82); backdrop-filter:blur(6px); display:none; align-items:center; justify-content:center; padding:24px; }
.modal-backdrop.open{ display:flex; }
.modal-box{ width:100%; max-width:900px; position:relative; }
.modal-close{ position:absolute; top:-46px; right:0; background:none; border:none; color:#fff; }
.modal-close svg{ width:30px; height:30px; }
.modal-video{ aspect-ratio:16/9; border-radius:18px; overflow:hidden; background:#000; }
.modal-video iframe{ width:100%; height:100%; border:none; }

/* responsive */
/* hide nav text labels a bit earlier to keep one row; show icons only on mid screens */
@media (max-width:1280px){ .nav a span:not(.visited){ display:none; } .nav a{ padding:9px; } .nav a .ic{ font-size:17px; } }
@media (max-width:1080px){
  .nav{ display:none; }
  .burger{ display:inline-flex; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}
@media (max-width:640px){
  body{ font-size:16px; }
  .header-phone span{ display:none; }
  .footer-grid{ grid-template-columns:1fr; }
  .fab-wrap{ bottom:16px; right:16px; }
}

/* ---- comprehensive mobile pass ---- */
@media (max-width:768px){
  :root{ --header-h:68px; --radius:20px; --radius-lg:24px; }
  .wrap{ padding-inline:18px; }
  .header-phone{ padding:9px; width:42px; height:42px; justify-content:center; border-radius:999px; }
  .header-phone span{ display:none; }       /* icon-only round */
  .logo .wordmark{ height:18px; }
  .section-head{ margin-bottom:36px; }
  /* full-width stacked CTAs in button groups */
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ width:100%; }
  .btn-lg{ padding:16px 24px; font-size:16px; }
  /* tables: let inner scroll, lighter padding */
  table.tw th, table.tw td{ padding:13px 12px; font-size:14px; }
  /* accordion body left padding back to normal (no number gutter) */
  .acc-body p{ padding-left:24px; }
  .acc-head{ padding:18px 18px; gap:14px; }
  .acc-head .ic{ font-size:21px; }
  /* insight / next-chapter */
  .insight{ padding:18px 20px; }
  .next-chapter a{ padding:16px 22px; }
  /* tabs & filters wrap tighter */
  .tab-btn{ padding:11px 18px; font-size:14px; }
  .filter-chip{ padding:9px 14px; font-size:13px; }
  /* mobile menu scroll if tall */
  .mobile-menu{ max-height:calc(100vh - var(--header-h)); overflow-y:auto; }
}
@media (max-width:480px){
  .wrap{ padding-inline:15px; }
  .eyebrow{ font-size:12.5px; letter-spacing:.14em; }
  .lead{ font-size:16px; }
  .btn{ padding:14px 20px; font-size:15px; }
  .card-pad{ padding:22px 20px; }
  .icon-chip{ width:50px; height:50px; }
  .icon-chip svg{ width:25px; height:25px; }
  /* keep section rhythm tighter */
  .section{ padding:54px 0; }
  .section-tight{ padding:40px 0; }
}

/* ============================================================
   Design enhancement layer — icons, motifs, motion
   ============================================================ */

/* gradient icon chip holding an inline SVG */
.icon-chip{ width:56px; height:56px; border-radius:16px; display:grid; place-items:center; flex:none;
  background:linear-gradient(150deg, rgba(121,201,78,.20), rgba(93,165,57,.06));
  border:1px solid var(--green-line); color:var(--green-bright); position:relative; overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease); }
.icon-chip svg{ width:28px; height:28px; stroke:currentColor; fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; position:relative; z-index:1; }
.icon-chip.solid{ background:var(--grad-green-135); color:#0c1707; border:none; box-shadow:0 12px 30px -10px rgba(121,201,78,.5); }
.icon-chip.solid svg{ stroke:#0c1707; }
.icon-chip.lg{ width:68px; height:68px; border-radius:19px; }
.icon-chip.lg svg{ width:34px; height:34px; }
.card-hover:hover .icon-chip{ transform:scale(1.08) rotate(-3deg); box-shadow:0 14px 34px -12px rgba(121,201,78,.5); }

/* nav inline-svg icon */
.nav a .nic{ width:17px; height:17px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; display:block; }
.mobile-menu a .nic{ width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

/* coffee-bean / leaf floating motifs */
.motif{ position:absolute; pointer-events:none; z-index:1; opacity:.5; }
.bean{ width:34px; height:46px; border-radius:50%; background:linear-gradient(135deg,#3a2417,#1c1109);
  position:relative; transform:rotate(28deg); box-shadow:inset 0 0 0 1px rgba(255,255,255,.05); }
.bean::after{ content:""; position:absolute; left:50%; top:8%; bottom:8%; width:2px; transform:translateX(-50%) rotate(0deg);
  background:rgba(0,0,0,.5); border-radius:2px; }
@media (prefers-reduced-motion:no-preference){
  .float-a{ animation:floatA 9s ease-in-out infinite; }
  .float-b{ animation:floatB 11s ease-in-out infinite; }
  .float-c{ animation:floatC 13s ease-in-out infinite; }
  @keyframes floatA{ 0%,100%{ transform:translateY(0) rotate(20deg);} 50%{ transform:translateY(-22px) rotate(28deg);} }
  @keyframes floatB{ 0%,100%{ transform:translateY(0) rotate(-12deg);} 50%{ transform:translateY(-30px) rotate(-4deg);} }
  @keyframes floatC{ 0%,100%{ transform:translateY(0) rotate(40deg);} 50%{ transform:translateY(-16px) rotate(48deg);} }
}

/* steam wisps */
@media (prefers-reduced-motion:no-preference){
  .steam path{ animation:steam 3.4s ease-in-out infinite; transform-origin:center; }
  .steam path:nth-child(2){ animation-delay:.5s; }
  .steam path:nth-child(3){ animation-delay:1s; }
  @keyframes steam{ 0%{ opacity:0; transform:translateY(4px) scaleY(.9);} 40%{ opacity:.8;} 100%{ opacity:0; transform:translateY(-10px) scaleY(1.1);} }
}

/* CTA pulse ring */
@media (prefers-reduced-motion:no-preference){
  .pulse{ position:relative; }
  .pulse::after{ content:""; position:absolute; inset:0; border-radius:inherit; box-shadow:0 0 0 0 rgba(121,201,78,.5); animation:pulse 2.6s var(--ease) infinite; }
  @keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(121,201,78,.45);} 70%{ box-shadow:0 0 0 16px rgba(121,201,78,0);} 100%{ box-shadow:0 0 0 0 rgba(121,201,78,0);} }
}

/* gradient animated headline accent */
.flow-text{ background:linear-gradient(100deg,#8FD957,#cdeeae,#8FD957); background-size:200% auto; -webkit-background-clip:text; background-clip:text; color:transparent; }
@media (prefers-reduced-motion:no-preference){ .flow-text{ animation:flow 5s linear infinite; } @keyframes flow{ to{ background-position:200% center; } } }

/* card top sheen on hover */
.card-hover{ overflow:hidden; }
.card-hover::before{ content:""; position:absolute; inset:0; border-radius:inherit; opacity:0;
  background:radial-gradient(120% 80% at 50% -10%, rgba(121,201,78,.14), transparent 60%); transition:opacity .3s; pointer-events:none; }
.card-hover:hover::before{ opacity:1; }

/* staggered reveal helper */
.reveal.s1{ transition-delay:.06s; } .reveal.s2{ transition-delay:.12s; } .reveal.s3{ transition-delay:.18s; }
.reveal.s4{ transition-delay:.24s; } .reveal.s5{ transition-delay:.30s; } .reveal.s6{ transition-delay:.36s; }

/* ── Тикер городов ── */
.city-ticker{
  position:relative; width:100%; overflow:hidden;
  background:var(--green-bright,#3C8B23);
  padding:11px 0; z-index:80;
}
.city-ticker-inner{
  display:flex; width:max-content;
  animation:ticker-scroll 48s linear infinite;
}
.city-ticker:hover .city-ticker-inner{ animation-play-state:paused; }
@keyframes ticker-scroll{
  0%  { transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}
.tick-item{
  display:inline-flex; align-items:center; gap:10px;
  white-space:nowrap; padding:0 20px;
  font-family:var(--font-brand,'Onest',sans-serif);
  font-size:14px; font-weight:600; color:var(--ink,#F5F2EC);
}
.tick-city{ font-weight:700; }
.tick-rev{ opacity:.92; }
.tick-pct{ font-size:13px; font-weight:700; padding:2px 8px; border-radius:6px; }
.tick-pct--up  { background:rgba(255,255,255,.22); color:var(--ink,#F5F2EC); }
.tick-pct--down{ background:rgba(0,0,0,.18);       color:rgba(245,242,236,.85); }
.tick-sep{ opacity:.35; font-weight:400; margin-left:10px; }

/* ── Виджет годовой выручки ── */
.rev-widget{
  display:grid; grid-template-columns:1fr 1fr 1fr;
  gap:0; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--green-line);
}
.rev-widget-cell{
  padding:28px 32px;
  background:var(--panel); border-right:1px solid var(--line);
}
.rev-widget-cell:last-child{ border-right:none; }
.rev-widget-cell .rwl{ font-size:13px; font-weight:600; color:var(--gray-2);
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:10px; }
.rev-widget-cell .rwv{ font-size:clamp(22px,2.6vw,34px); font-weight:800;
  color:var(--white); line-height:1.1; }
.rev-widget-cell .rwv-small{ font-size:clamp(18px,2vw,26px); }
.tw-pct{ display:inline-block; margin-left:10px; font-size:16px;
  font-weight:700; padding:2px 10px; border-radius:8px; vertical-align:middle; }
.tw-pct--up  { background:rgba(121,201,78,.15); color:var(--green-deep); }
.tw-pct--down{ background:var(--red-soft);      color:var(--red); }
@media(max-width:768px){
  .rev-widget{ grid-template-columns:1fr; }
  .rev-widget-cell{ border-right:none; border-bottom:1px solid var(--line); }
  .rev-widget-cell:last-child{ border-bottom:none; }
}

/* ── Топ-10 партнёров ── */
#top-partners-list{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); }
.tp-row{
  display:grid; grid-template-columns:36px 1fr 140px 160px;
  align-items:center; gap:12px; padding:14px 20px;
  border-bottom:1px solid var(--line);
  font-size:15px; background:var(--panel);
  transition:background .18s;
}
.tp-row:last-child{ border-bottom:none; }
.tp-row:hover{ background:var(--green-soft); }
.tp-rank{ font-weight:800; color:var(--green-bright); font-size:17px; text-align:center; }
.tp-name{ font-weight:600; color:var(--white); }
.tp-city{ color:var(--gray); font-size:14px; }
.tp-rev{ font-weight:700; color:var(--white); text-align:right; }
.tp-skeleton .tp-name{ color:var(--gray-2); font-weight:400; }
@media(max-width:600px){
  .tp-row{ grid-template-columns:28px 1fr 100px; }
  .tp-city{ display:none; }
}

/* ── Три карточки в net-grid ── */
.net-cards{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
@media(max-width:960px){ .net-cards{ grid-template-columns:1fr 1fr; } }
@media(max-width:600px){ .net-cards{ grid-template-columns:1fr; } }

/* ── Секция наград ── */
.awards-row{
  display:flex; gap:20px; flex-wrap:wrap; justify-content:center;
}
.award-card{
  display:flex; flex-direction:column; align-items:center; gap:14px;
  padding:28px 24px; border-radius:var(--radius); background:var(--panel);
  border:1px solid var(--line); text-align:center; text-decoration:none;
  min-width:180px; flex:1; max-width:260px;
  box-shadow:0 1px 2px rgba(24,22,16,.04),0 18px 40px -28px rgba(24,22,16,.18);
  transition:transform .25s var(--ease),border-color .25s,box-shadow .25s;
}
.award-card:hover{ transform:translateY(-5px); border-color:var(--green-line);
  box-shadow:0 1px 2px rgba(24,22,16,.04),0 28px 50px -24px rgba(93,165,57,.3); }
.award-card img{ width:120px; height:120px; object-fit:contain; }
.award-badge-wrap{ width:120px; height:120px; display:grid; place-items:center; }
.award-tf-icon svg{ width:90px; height:90px; filter:drop-shadow(0 8px 20px rgba(240,165,0,.35)); }
.award-label{ display:flex; flex-direction:column; gap:4px; }
.award-name{ font-weight:800; font-size:16px; color:var(--white); }
.award-sub{ font-size:13px; color:var(--gray); font-weight:600; }
.award-tf-ranks{ display:grid; grid-template-columns:auto 1fr; gap:2px 8px;
  align-items:center; margin-top:6px; text-align:left; }
.award-tf-num{ font-size:20px; font-weight:800; color:var(--green-bright); line-height:1.1; }
.award-tf-desc{ font-size:13px; color:var(--gray); }
.award-verify{ margin-top:8px; font-size:12px; font-weight:700; color:var(--green-bright);
  letter-spacing:.04em; }
@media(max-width:600px){
  .awards-row{ gap:12px; }
  .award-card{ min-width:calc(50% - 6px); padding:20px 16px; }
  .award-card--text{ min-width:100%; max-width:100%; }
}
