/* ========================================================================
   Juxta Asset Tag — site styles
   Brand: cream #f2eee4 · navy #26416c · red #a52626 · Inter
   ======================================================================== */

:root {
  --paper:#f2eee4;
  --paper-2:#ebe5d7;
  --card:#f7f4ec;
  --line:#e0d9c8;
  --line-2:#d4cbb6;

  --ink:#16181c;
  --ink-2:#3c3f46;
  --muted:#6d685c;

  --navy:#26416c;
  --navy-2:#1c3050;
  --navy-soft:#eaeef5;

  --red:#a52626;
  --red-2:#8e1f1f;
  --red-soft:#f6e7e3;

  --green:#2c6e49;

  --dark:#0d0e11;
  --dark-2:#15171b;
  --dark-3:#1f232a;
  --cream-muted:#b9b4a6;

  --display:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --wrap:1180px;
  --radius:16px;
  --radius-sm:11px;
  --shadow:0 1px 2px rgba(20,22,28,.04), 0 8px 30px rgba(20,22,28,.06);
  --shadow-lg:0 30px 60px -20px rgba(20,22,28,.28);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  font-size:17px;
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

h1,h2,h3,h4{font-family:var(--display);font-weight:700;letter-spacing:-0.022em;line-height:1.08;margin:0;}
h1{font-size:clamp(40px,6vw,72px);}
h2{font-size:clamp(29px,3.6vw,46px);}
h3{font-size:20px;letter-spacing:-0.01em;}
p{margin:0;}
em{font-style:normal;color:var(--navy);}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 28px;}
.block{padding:88px 0;}
.block.tight{padding:60px 0;}
.alt{background:var(--paper-2);}
.dark{background:var(--dark);color:#ece8de;}
.navy{background:var(--navy);color:#eef2f8;}

.eyebrow{
  display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--red);
}
.dark .eyebrow,.navy .eyebrow{color:#e7b9b0;}
.lead{font-size:clamp(17px,1.9vw,20px);color:var(--ink-2);line-height:1.62;}
.muted{color:var(--muted);}
.center{text-align:center;}

.section-head{max-width:680px;margin:0 auto 52px;text-align:center;}
.section-head.left{margin-left:0;text-align:left;}
.section-head h2{margin-top:14px;}
.section-head p{margin-top:16px;font-size:18px;color:var(--ink-2);}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--display);font-weight:600;font-size:15.5px;
  padding:13px 22px;border-radius:11px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .14s ease,box-shadow .18s ease,background .18s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--navy);color:#fff;}
.btn-primary:hover{background:var(--navy-2);box-shadow:0 8px 22px -8px rgba(38,65,108,.6);}
.btn-accent{background:var(--red);color:#fff;}
.btn-accent:hover{background:var(--red-2);box-shadow:0 8px 22px -8px rgba(165,38,38,.55);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-2);}
.btn-ghost:hover{border-color:var(--ink);background:rgba(0,0,0,.02);}
.dark .btn-ghost,.navy .btn-ghost,.cta-band .btn-ghost,.capture .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4);}
.dark .btn-ghost:hover,.navy .btn-ghost:hover,.cta-band .btn-ghost:hover,.capture .btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1);}
.btn-lg{font-size:16.5px;padding:16px 28px;border-radius:12px;}
.btn-wide{width:100%;}

/* ---------- announcement bar ---------- */
.annc{
  background:var(--red);color:#fff;font-size:14px;font-weight:500;
  text-align:center;position:relative;
}
.annc-in{
  max-width:var(--wrap);margin:0 auto;padding:9px 44px;
  display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;
}
.annc strong{font-weight:800;}
.annc .code{
  font-weight:800;letter-spacing:.05em;background:rgba(255,255,255,.16);
  padding:2px 9px;border-radius:6px;border:1px dashed rgba(255,255,255,.5);
}
.annc .cd{font-variant-numeric:tabular-nums;font-weight:700;}
.annc a{text-decoration:underline;text-underline-offset:2px;font-weight:700;}
.annc-close{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  background:none;border:none;color:#fff;font-size:18px;cursor:pointer;opacity:.8;line-height:1;
}
.annc-close:hover{opacity:1;}

/* ---------- header ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(242,238,228,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.nav-in{max-width:var(--wrap);margin:0 auto;padding:0 28px;height:66px;display:flex;align-items:center;justify-content:space-between;gap:22px;}
.brand img{height:28px;width:auto;}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a.link{font-size:15px;font-weight:500;color:var(--ink-2);transition:color .15s;}
.nav-links a.link:hover{color:var(--navy);}
.nav-links a.link.active{color:var(--navy);font-weight:600;}
.nav-cta{display:flex;align-items:center;gap:12px;}
.nav-price{font-size:13.5px;color:var(--muted);font-weight:500;}
.nav-price b{color:var(--ink);font-weight:700;}
.burger{display:none;background:none;border:none;cursor:pointer;padding:6px;}
.burger span{display:block;width:22px;height:2px;background:var(--ink);margin:5px 0;border-radius:2px;transition:.2s;}
.mobile-menu{display:none;flex-direction:column;gap:4px;padding:12px 28px 22px;border-bottom:1px solid var(--line);background:var(--paper);}
.mobile-menu a{padding:11px 0;font-size:17px;font-weight:500;border-bottom:1px solid var(--line);}
.mobile-menu a:last-of-type{border:none;}
.mobile-menu.open{display:flex;}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:64px 0 72px;}
.hero h1{margin-top:18px;}
.hero .lead{margin-top:20px;max-width:33ch;}
.hero-price{margin-top:24px;font-size:18px;color:var(--ink-2);}
.hero-price strong{font-size:30px;font-weight:800;color:var(--ink);letter-spacing:-.02em;}
.hero-price .sm{font-size:15px;}
.hero-cta{display:flex;gap:13px;margin-top:28px;flex-wrap:wrap;}
.hero-meta{margin-top:24px;font-size:13.5px;color:var(--muted);letter-spacing:.01em;}
.trust-row{margin-top:30px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-size:13.5px;color:var(--muted);}
.trust-row .stars{color:#d98324;letter-spacing:2px;font-size:15px;}

.media-tile{
  background:linear-gradient(150deg,#15171b,#0d0e11);border-radius:var(--radius);
  overflow:hidden;position:relative;box-shadow:var(--shadow-lg);
}
.media-tile img{width:100%;height:100%;object-fit:cover;}
.hero-visual{aspect-ratio:4/3;}
.hero-badge{
  position:absolute;left:18px;bottom:18px;background:rgba(13,14,17,.78);
  color:#fff;font-size:12.5px;font-weight:600;padding:8px 13px;border-radius:9px;
  backdrop-filter:blur(6px);display:flex;align-items:center;gap:8px;
}
.hero-badge .pulse{width:8px;height:8px;border-radius:50%;background:#4ad07d;box-shadow:0 0 0 0 rgba(74,208,125,.6);animation:pulse 2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(74,208,125,.55);}70%{box-shadow:0 0 0 8px rgba(74,208,125,0);}100%{box-shadow:0 0 0 0 rgba(74,208,125,0);}}

/* ---------- value band ---------- */
.value{background:var(--navy);color:#fff;}
.value-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.vcell{padding:30px 26px;border-right:1px solid rgba(255,255,255,.12);}
.vcell:last-child{border-right:none;}
.vtop{font-size:24px;font-weight:800;letter-spacing:-.02em;display:flex;align-items:baseline;gap:7px;}
.vtop span{font-size:14px;font-weight:500;opacity:.8;}
.vsub{margin-top:7px;font-size:13.5px;color:#c7d2e4;line-height:1.5;}

/* ---------- connectivity band ---------- */
.conn{background:var(--dark);color:#ece8de;}
.conn-in{max-width:var(--wrap);margin:0 auto;padding:24px 28px;display:flex;align-items:center;justify-content:center;gap:13px;flex-wrap:wrap;text-align:center;}
.conn .label{font-size:14.5px;color:var(--cream-muted);}
.pill{display:inline-flex;align-items:center;gap:7px;background:var(--dark-3);border:1px solid #2c313a;border-radius:999px;padding:6px 14px;font-size:13.5px;font-weight:600;}
.pill .dot{width:7px;height:7px;border-radius:50%;background:#4ad07d;}

/* ---------- feature grid ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--card);}
.cell{padding:34px 30px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);}
.features .cell:nth-child(3n){border-right:none;}
.features .cell:nth-last-child(-n+3){border-bottom:none;}
.cell .ic{width:30px;height:30px;color:var(--navy);margin-bottom:16px;}
.cell h3{margin-bottom:9px;}
.cell p{font-size:14.5px;color:var(--ink-2);line-height:1.58;}

/* simpler 3-up / 4-up card row (no shared border) */
.cards{display:grid;gap:22px;}
.cards.c3{grid-template-columns:repeat(3,1fr);}
.cards.c4{grid-template-columns:repeat(4,1fr);}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;}
.card .ic{width:28px;height:28px;color:var(--navy);margin-bottom:15px;}
.card h3{margin-bottom:9px;}
.card p{font-size:14.5px;color:var(--ink-2);line-height:1.58;}
.card .num{font-size:13px;font-weight:800;color:var(--red);letter-spacing:.04em;margin-bottom:12px;}

/* ---------- showcase rows ---------- */
.showcase{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;}
.showcase + .showcase{margin-top:80px;}
.showcase.reverse .sc-media{order:2;}
.sc-media{aspect-ratio:4/3;}
.sc-body h2{margin-top:14px;}
.sc-body p{margin-top:15px;color:var(--ink-2);}
.sc-list{margin-top:22px;display:flex;flex-direction:column;gap:13px;}
.sc-list .row{display:flex;gap:11px;align-items:flex-start;font-size:15px;color:var(--ink-2);}
.sc-list .row svg{color:var(--green);flex:none;margin-top:3px;}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:26px;}
.gtile .media-tile{aspect-ratio:16/10;}
.gtile .cap{margin-top:14px;font-size:14.5px;color:var(--ink-2);}
.gtile .cap strong{color:var(--ink);font-weight:700;}

/* ---------- trades chips ---------- */
.trades{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;justify-content:center;}
.section-head.left .trades{justify-content:flex-start;}
.trade{background:var(--card);border:1px solid var(--line-2);border-radius:999px;padding:8px 17px;font-size:14px;font-weight:600;color:var(--navy);}

/* ---------- steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;counter-reset:step;}
.step{position:relative;padding:30px 26px 28px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);}
.step .badge{width:38px;height:38px;border-radius:10px;background:var(--navy);color:#fff;font-weight:800;font-size:17px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.step h3{margin-bottom:9px;}
.step p{font-size:14.5px;color:var(--ink-2);}

/* ---------- pricing ---------- */
.price-wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:start;}
.price-card{background:var(--card);border:1.5px solid var(--line-2);border-radius:var(--radius);padding:38px 34px;position:relative;}
.price-card.feature{border-color:var(--navy);box-shadow:var(--shadow-lg);}
.price-tag{display:flex;align-items:baseline;gap:8px;margin:14px 0 4px;}
.price-tag .amt{font-size:56px;font-weight:800;letter-spacing:-.03em;}
.price-tag .per{font-size:16px;color:var(--muted);}
.price-was{font-size:15px;color:var(--muted);}
.price-was s{color:var(--red);}
.price-list{margin:24px 0;display:flex;flex-direction:column;gap:13px;}
.price-list .row{display:flex;gap:11px;align-items:flex-start;font-size:15px;}
.price-list .row svg{color:var(--green);flex:none;margin-top:3px;}
.ribbon{position:absolute;top:-13px;right:26px;background:var(--red);color:#fff;font-size:12px;font-weight:800;letter-spacing:.04em;padding:6px 14px;border-radius:8px;text-transform:uppercase;}

/* ---------- comparison table ---------- */
.compare{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-size:15px;}
.compare th,.compare td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--line);}
.compare thead th{background:var(--navy);color:#fff;font-weight:600;font-size:14.5px;}
.compare thead th.us{background:var(--navy-2);}
.compare tbody tr:last-child td{border-bottom:none;}
.compare td.feat{font-weight:600;color:var(--ink);}
.compare .yes{color:var(--green);font-weight:700;}
.compare .no{color:var(--muted);}
.compare td.col-us{background:rgba(38,65,108,.05);font-weight:600;}

/* ---------- testimonial ---------- */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.quote{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px 26px;display:flex;flex-direction:column;gap:16px;}
.quote .stars{color:#d98324;letter-spacing:2px;}
.quote p{font-size:15.5px;line-height:1.6;color:var(--ink-2);}
.quote .who{display:flex;align-items:center;gap:12px;margin-top:auto;}
.quote .who .av{width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;}
.quote .who b{display:block;font-size:14.5px;}
.quote .who span{font-size:13px;color:var(--muted);}

/* ---------- stat strip ---------- */
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:center;}
.stat .big{font-size:clamp(34px,4vw,46px);font-weight:800;letter-spacing:-.03em;color:var(--navy);}
.dark .stat .big,.navy .stat .big{color:#fff;}
.stat .lbl{font-size:14px;color:var(--muted);margin-top:6px;}
.dark .stat .lbl,.navy .stat .lbl{color:var(--cream-muted);}

/* ---------- email capture ---------- */
.capture{background:linear-gradient(160deg,var(--navy),var(--navy-2));color:#fff;border-radius:var(--radius);padding:48px 44px;text-align:center;}
.capture h2{color:#fff;}
.capture p{margin-top:12px;color:#cdd8ea;font-size:17px;}
.cap-form{display:flex;gap:10px;max-width:480px;margin:26px auto 0;}
.cap-form input{flex:1;padding:14px 18px;border-radius:11px;border:1.5px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff;font-size:15px;font-family:var(--body);}
.cap-form input::placeholder{color:#b7c3d8;}
.cap-form input:focus{outline:none;border-color:#fff;background:rgba(255,255,255,.14);}
.cap-note{margin-top:13px;font-size:12.5px;color:#aebbd2;}
.cap-ok{margin-top:18px;font-size:16px;font-weight:600;color:#9be7b9;display:none;}

/* ---------- FAQ ---------- */
.faq-list{max-width:780px;margin:0 auto;border-top:1px solid var(--line);}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;padding:22px 40px 22px 0;font-family:var(--display);font-weight:600;font-size:18px;color:var(--ink);position:relative;}
.faq-q::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:24px;font-weight:400;color:var(--navy);transition:transform .2s;}
.faq-item.open .faq-q::after{content:"−";}
.faq-a{max-height:0;overflow:hidden;transition:max-height .28s ease;}
.faq-a p{padding:0 40px 22px 0;color:var(--ink-2);font-size:15.5px;}

/* ---------- CTA band ---------- */
.cta-band{background:linear-gradient(160deg,var(--dark-2),var(--dark));color:#fff;border-radius:22px;padding:60px 50px;text-align:center;}
.cta-band h2{color:#fff;}
.cta-band p{margin:16px auto 0;max-width:560px;color:var(--cream-muted);font-size:18px;}
.cta-band .hero-cta{justify-content:center;margin-top:30px;}
.cta-band .fineprint{margin-top:18px;font-size:13px;color:var(--cream-muted);}

/* ---------- floating buy button ---------- */
.float-buy{
  position:fixed;right:22px;bottom:22px;z-index:60;
  background:var(--red);color:#fff;font-family:var(--display);font-weight:700;font-size:15px;
  padding:14px 20px;border-radius:999px;box-shadow:0 12px 30px -8px rgba(165,38,38,.6);
  display:inline-flex;align-items:center;gap:9px;transition:transform .15s,box-shadow .2s;
}
.float-buy:hover{transform:translateY(-2px);box-shadow:0 16px 36px -8px rgba(165,38,38,.7);}
.float-buy strong{font-weight:800;}

/* ---------- footer ---------- */
footer{background:var(--dark);color:var(--cream-muted);padding:64px 0 30px;}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;}
.foot-brand img{height:26px;margin-bottom:16px;}
.foot-brand p{font-size:14px;color:var(--cream-muted);max-width:30ch;line-height:1.6;}
.foot-col h4{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin-bottom:16px;font-weight:700;}
.foot-col a{display:block;font-size:14.5px;color:var(--cream-muted);padding:6px 0;transition:color .15s;}
.foot-col a:hover{color:#fff;}
.foot-bottom{margin-top:48px;padding-top:24px;border-top:1px solid #23262d;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:13px;}

/* ---------- placeholder fallback ---------- */
.ph-note{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#777;font-size:13px;background:#15171b;}

/* ========================================================================
   Responsive
   ======================================================================== */
@media (max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:36px;padding:44px 0 52px;}
  .hero .lead{max-width:none;}
  .features{grid-template-columns:repeat(2,1fr);}
  .features .cell:nth-child(3n){border-right:1px solid var(--line);}
  .features .cell:nth-child(2n){border-right:none;}
  .features .cell:nth-last-child(-n+3){border-bottom:1px solid var(--line);}
  .features .cell:nth-last-child(-n+2){border-bottom:none;}
  .cards.c3,.cards.c4,.quotes,.steps{grid-template-columns:repeat(2,1fr);}
  .price-wrap{grid-template-columns:1fr;}
  .stat-strip{grid-template-columns:repeat(2,1fr);gap:30px 22px;}
}
@media (max-width:760px){
  .nav-links,.nav-price{display:none;}
  .burger{display:block;}
  .showcase{grid-template-columns:1fr;gap:28px;}
  .showcase.reverse .sc-media{order:0;}
  .showcase + .showcase{margin-top:54px;}
  .value-grid{grid-template-columns:repeat(2,1fr);}
  .vcell:nth-child(2n){border-right:none;}
  .vcell{border-bottom:1px solid rgba(255,255,255,.12);}
  .vcell:nth-last-child(-n+2){border-bottom:none;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px 24px;}
}
@media (max-width:560px){
  body{font-size:16px;}
  .block{padding:60px 0;}
  .wrap{padding:0 20px;}
  .features,.cards.c3,.cards.c4,.quotes,.steps,.gallery{grid-template-columns:1fr;}
  .features .cell{border-right:none !important;border-bottom:1px solid var(--line) !important;}
  .features .cell:last-child{border-bottom:none !important;}
  .stat-strip{grid-template-columns:repeat(2,1fr);}
  .capture,.cta-band{padding:36px 24px;}
  .cap-form{flex-direction:column;}
  .hero-cta .btn{flex:1;}
  .foot-grid{grid-template-columns:1fr;}
  .float-buy .fb-long{display:none;}
  footer{padding-bottom:90px;}
  .annc-in{padding:9px 30px;font-size:13px;}
}

/* ========================================================================
   Added: competitor/AirTag versus, data-insights mock, scale & coverage viz
   ======================================================================== */

/* --- 3-way versus cards (AirTag / Juxta / Enterprise) --- */
.versus{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch;}
.vs-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;display:flex;flex-direction:column;}
.vs-card.feature{border:1.5px solid var(--navy);box-shadow:var(--shadow-lg);position:relative;}
.vs-tag{position:absolute;top:-13px;left:26px;background:var(--navy);color:#fff;font-size:11.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:6px 13px;border-radius:8px;}
.vs-head{display:flex;align-items:center;gap:11px;margin-bottom:6px;}
.vs-name{font-family:var(--display);font-weight:700;font-size:19px;}
.vs-sub{font-size:13px;color:var(--muted);margin-bottom:18px;}
.vs-list{display:flex;flex-direction:column;gap:12px;}
.vs-list .row{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:var(--ink-2);line-height:1.45;}
.vs-list .row svg{flex:none;margin-top:2px;}
.vs-list .row.no{color:var(--muted);}
.ic-yes{color:var(--green);}
.ic-no{color:var(--red);}
.ic-mid{color:#a9791b;}

/* --- data insights mock --- */
.insights-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;}
.insights-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);background:var(--paper-2);}
.insights-head b{font-size:14px;}
.insights-head span{font-size:12px;color:var(--muted);}
.insights-body{padding:22px 22px 24px;}
.insights-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:22px;}
.itile{background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:13px 14px;}
.itile .v{font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--navy);}
.itile .l{font-size:11.5px;color:var(--muted);margin-top:2px;line-height:1.3;}
.bars{display:flex;align-items:flex-end;gap:10px;height:120px;padding-top:6px;}
.bar{flex:1;border-radius:6px 6px 0 0;position:relative;background:var(--navy);opacity:.85;}
.bar.lo{opacity:.32;}
.bar.hi{background:var(--red);opacity:.9;}
.bars-x{display:flex;gap:10px;margin-top:8px;}
.bars-x span{flex:1;text-align:center;font-size:10.5px;color:var(--muted);}

/* --- scale viz --- */
.scale-row{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--card);}
.scale-node{padding:30px 24px;text-align:center;border-right:1px solid var(--line);position:relative;}
.scale-node:last-child{border-right:none;}
.scale-node .big{font-size:34px;font-weight:800;letter-spacing:-.02em;color:var(--navy);}
.scale-node .lbl{font-size:14px;font-weight:600;margin-top:4px;}
.scale-node .sub{font-size:13px;color:var(--muted);margin-top:6px;}
.scale-node .arrow{position:absolute;right:-11px;top:50%;transform:translateY(-50%);z-index:2;width:22px;height:22px;background:var(--red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;}

/* --- coverage viz (how it finds your stuff) --- */
.coverage{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.cov-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;}
.cov-card.win{border:1.5px solid var(--navy);}
.cov-card h4{font-size:16px;margin-bottom:14px;display:flex;align-items:center;gap:9px;}
.cov-net{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;}
.net{font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:999px;border:1px solid var(--line-2);color:var(--muted);background:var(--paper);}
.net.on{background:var(--navy-soft);border-color:var(--navy);color:var(--navy);}
.cov-card p{font-size:14px;color:var(--ink-2);line-height:1.55;}

@media (max-width:880px){
  .versus,.scale-row{grid-template-columns:1fr;}
  .scale-node{border-right:none;border-bottom:1px solid var(--line);}
  .scale-node:last-child{border-bottom:none;}
  .scale-node .arrow{right:50%;top:auto;bottom:-11px;transform:translateX(50%) rotate(90deg);}
  .coverage{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .insights-tiles{grid-template-columns:1fr;}
  /* breathing room between the sticky nav and the first content on mobile,
     and a clear gap below the hero image (.wrap padding would otherwise zero it) */
  .hero .hero-grid{padding-top:40px;padding-bottom:48px;}
  .block.pagehead{padding-top:42px;}
  /* tidy up the value band: even cells, smaller numerals */
  .vcell{padding:22px 18px;}
  .vtop{font-size:20px;}
  .vsub{font-size:12.5px;line-height:1.45;}
  /* connectivity band: labels on their own lines, pills centered between */
  .conn-in{gap:10px 12px;padding:24px 0;}
  .conn .label{flex-basis:100%;font-size:14px;}
}

/* ========================================================================
   Quick fade-in on page load — signals a fresh page on navigation.
   ======================================================================== */
/* opacity-only (a transform on <body> would break position:fixed children) */
@keyframes pageFade{from{opacity:0;}to{opacity:1;}}
body{animation:pageFade .3s ease both;}
@media (prefers-reduced-motion:reduce){body{animation:none;}}

/* ========================================================================
   "How many tags?" quantity modal (opened by every buy button)
   ======================================================================== */
.qmodal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;}
.qmodal[hidden]{display:none;}
.qmodal-backdrop{position:absolute;inset:0;background:rgba(13,14,17,.55);animation:qmFade .2s ease;}
.qmodal-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow-lg);width:min(440px,100%);padding:34px 32px 26px;text-align:center;animation:qmPop .22s cubic-bezier(.2,.8,.2,1);}
@keyframes qmFade{from{opacity:0}to{opacity:1}}
@keyframes qmPop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.qmodal-x{position:absolute;top:12px;right:15px;background:none;border:none;font-size:26px;line-height:1;color:var(--muted);cursor:pointer;}
.qmodal-x:hover{color:var(--ink);}
.qmodal-card h3{font-size:23px;margin:10px 0 8px;}
.qmodal-sub{font-size:14.5px;color:var(--ink-2);margin-bottom:22px;}

.qbtn{border:none;background:transparent;font-weight:600;cursor:pointer;color:var(--navy);line-height:1;}
.qbtn:hover{background:rgba(38,65,108,.08);}
.qty-ctrl.big{display:inline-flex;align-items:center;border:1.5px solid var(--line-2);border-radius:13px;overflow:hidden;background:var(--card);}
.qty-ctrl.big .qbtn{width:54px;height:56px;font-size:26px;}
.qty-ctrl.big input{width:104px;height:56px;border:none;border-left:1.5px solid var(--line-2);border-right:1.5px solid var(--line-2);text-align:center;font-size:23px;font-weight:800;font-family:var(--display);background:var(--card);color:var(--ink);-moz-appearance:textfield;}
.qty-ctrl.big input::-webkit-outer-spin-button,.qty-ctrl.big input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.qmodal-hint{font-size:12.5px;color:var(--muted);margin-top:11px;}
.qmodal-total{margin:20px 0;padding:16px;background:var(--card);border:1px solid var(--line);border-radius:13px;}
.qmodal-total .big{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--ink);}
.qmodal-total .big .lbl{font-size:15px;font-weight:600;color:var(--ink-2);}
.qmodal-total .sub{font-size:13.5px;color:var(--muted);margin-top:4px;}
.qmodal-total .sub b{color:var(--ink);}
.qmodal-card #qmGo{margin-top:2px;}
.qmodal-fine{font-size:12px;color:var(--muted);margin-top:13px;}
