/* ============================================================
   Brown Bag Media — Design system
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Fraunces:ital,wght@0,500;0,600;0,700;1,500&display=swap');

:root{
  /* Brand */
  --primary:#e8862a;
  --primary-dark:#c46d18;
  --primary-soft:#fef1e0;
  --brown:#2a1608;
  --brown-mid:#6b3a1c;
  --ocean:#1a9dc4;
  --ocean-dark:#0f6a88;
  --gold:#f5c23e;
  --palm:#2d8a3e;

  /* Neutrals */
  --ink:#1a1309;
  --text:#3a2e22;
  --muted:#7a6b5a;
  --faint:#a89a88;
  --line:#ece3d4;
  --line-soft:#f4ecde;
  --bg:#fbf8f2;
  --surface:#ffffff;

  /* Effects */
  --shadow-xs:0 1px 2px rgba(42,22,8,0.04);
  --shadow-sm:0 2px 6px rgba(42,22,8,0.06);
  --shadow-md:0 8px 24px rgba(42,22,8,0.08);
  --shadow-lg:0 20px 50px rgba(42,22,8,0.12);
  --radius-sm:10px;
  --radius:16px;
  --radius-lg:22px;

  /* Type */
  --font-sans:"Plus Jakarta Sans",Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;
  --font-display:"Fraunces","Plus Jakarta Sans",Georgia,serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0;font-family:var(--font-sans);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s ease}

h1,h2,h3,h4,h5{font-family:var(--font-display);color:var(--ink);font-weight:600;letter-spacing:-0.02em;line-height:1.15;margin:0 0 .5em}
h1{font-size:clamp(2rem,4vw,3rem);letter-spacing:-0.03em}
h2{font-size:clamp(1.75rem,3vw,2.4rem)}
h3{font-size:1.35rem;letter-spacing:-0.015em}
h4{font-size:1.1rem;letter-spacing:-0.01em}
p{margin:0 0 1em}
p:last-child{margin-bottom:0}

.container{max-width:1160px;margin:0 auto;padding:0 24px}

/* Eyebrow label */
.eyebrow{display:inline-block;font-family:var(--font-sans);font-size:0.78rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--primary);margin-bottom:14px}

/* ============================================================
   Header
   ============================================================ */
.bbm-header{position:sticky;top:0;background:rgba(251,248,242,0.92);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--line);z-index:50}
.bbm-header .nav{display:flex;align-items:center;justify-content:space-between;padding:10px 0;min-height:76px}
.brand{display:flex;gap:14px;align-items:center;font-weight:700;color:var(--ink);font-family:var(--font-display);font-size:1.25rem;letter-spacing:-0.015em;transition:transform .2s ease}
.brand:hover{transform:translateY(-1px)}
.brand img{height:72px;width:auto;filter:drop-shadow(0 2px 6px rgba(42,22,8,0.18))}
@media (max-width:720px){.brand img{height:54px}.bbm-header .nav{min-height:68px}}
.bbm-header nav{display:flex;gap:4px;align-items:center}
.bbm-header nav a{font-weight:500;color:var(--text);padding:9px 14px;border-radius:8px;font-size:0.96rem;transition:all .18s ease}
.bbm-header nav a:hover{color:var(--ink);background:rgba(42,22,8,0.04)}
.bbm-header nav a.btn{padding:10px 20px;margin-left:8px}

/* Homepage header — transparent over banner */
.bbm-header--home{position:absolute;top:0;left:0;right:0;background:transparent;border-bottom:none;backdrop-filter:none;-webkit-backdrop-filter:none}
.bbm-header--home:before{content:"";position:absolute;top:0;left:0;right:0;height:180px;background:linear-gradient(180deg,rgba(0,0,0,0.5) 0%,rgba(0,0,0,0.2) 50%,transparent 100%);pointer-events:none}
.bbm-header--home .brand img{height:84px;filter:drop-shadow(0 3px 14px rgba(0,0,0,0.5))}
.brand--spacer{display:block;width:1px;height:44px}
.bbm-header--home .nav{position:relative}
.bbm-header--home nav a{color:#fff;font-weight:600;text-shadow:0 1px 10px rgba(0,0,0,0.35)}
.bbm-header--home nav a:hover{background:rgba(255,255,255,0.14);color:#fff}
.bbm-header--home nav a.btn{background:var(--gold);color:var(--brown);text-shadow:none;box-shadow:0 4px 14px rgba(245,194,62,0.45)}
.bbm-header--home nav a.btn:hover{background:#fff;color:var(--brown);transform:translateY(-1px)}

/* ============================================================
   Buttons
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--primary);color:#fff;padding:12px 22px;border-radius:999px;font-weight:600;font-size:0.96rem;letter-spacing:-0.005em;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px rgba(232,134,42,0.25);white-space:nowrap}
.btn:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 10px 24px rgba(232,134,42,0.35)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;border:1.5px solid var(--primary);color:var(--primary);box-shadow:none}
.btn.ghost:hover{background:var(--primary);color:#fff}
.btn.btn-lg{padding:14px 28px;font-size:1rem}

/* ============================================================
   Hero — homepage
   ============================================================ */
.hero--banner{display:block;width:100%;background:#0b4a6b url('../img/hero-banner.jpg') center/cover no-repeat;aspect-ratio:16/9;max-height:640px;min-height:420px;position:relative;overflow:hidden}

/* ============================================================
   Features (homepage)
   ============================================================ */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:88px auto 64px}
.feature{background:var(--surface);padding:32px 28px;border-radius:var(--radius);border:1px solid var(--line-soft);box-shadow:var(--shadow-sm);transition:transform .25s ease,box-shadow .25s ease}
.feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.feature .icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--primary-soft);color:var(--primary);margin-bottom:18px;font-size:1.3rem}
.feature h3{margin:0 0 10px;font-size:1.2rem}
.feature p{margin:0;color:var(--muted)}

/* ============================================================
   Section headings / products
   ============================================================ */
.section-head{display:flex;justify-content:space-between;align-items:flex-end;margin:0 0 28px;flex-wrap:wrap;gap:12px}
.section-head .eyebrow{margin-bottom:8px}
.section-head h2{margin:0}
.section-head a{color:var(--primary);font-weight:600;font-size:0.96rem}
.section-head a:hover{color:var(--primary-dark)}

.products{margin:64px auto}
.products .heading{display:flex;justify-content:space-between;align-items:flex-end;margin:0 0 28px;flex-wrap:wrap;gap:12px}
.products .heading h2{margin:0}
.products .heading a{color:var(--primary);font-weight:600}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cards-5{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:26px 24px;transition:all .25s ease;position:relative;overflow:hidden}
.card:before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--primary),var(--gold));transform:scaleX(0);transform-origin:left;transition:transform .3s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(232,134,42,0.3)}
.card:hover:before{transform:scaleX(1)}
.card h4{margin:0 0 8px;color:var(--ink);font-size:1.15rem}
.card p{margin:0;color:var(--muted);font-size:0.94rem;line-height:1.55}

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{background:linear-gradient(135deg,var(--brown) 0%,var(--brown-mid) 50%,var(--primary-dark) 100%);color:#fff;padding:72px 0;margin:88px 0 0;position:relative;overflow:hidden}
.cta-band:before{content:"";position:absolute;top:-40%;right:-10%;width:500px;height:500px;border-radius:50%;background:radial-gradient(closest-side,rgba(245,194,62,0.25),transparent);pointer-events:none}
.cta-band h2{color:#fff;margin:0}
.cta-band p{color:rgba(255,255,255,0.85);margin:8px 0 0}
.cta-band .container{display:flex;align-items:center;justify-content:space-between;gap:24px;position:relative;z-index:2;flex-wrap:wrap}
.cta-band .btn{background:var(--gold);color:var(--brown);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.cta-band .btn:hover{background:#fff;color:var(--brown)}

/* ============================================================
   Layout helpers
   ============================================================ */
.pad{padding:80px 0}
.pad-lg{padding:104px 0}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}

/* ============================================================
   Product page
   ============================================================ */
.product-banner{display:block;width:100%;height:auto;border-radius:var(--radius-lg);margin-bottom:36px;background-color:#0b4a6b;box-shadow:var(--shadow-md)}
img.product-banner{object-fit:cover}

.product-intro{margin-bottom:56px;padding-right:8%}
.product-intro .tag{display:inline-flex;align-items:center;background:var(--accent-a,var(--primary));color:#fff;padding:6px 14px;border-radius:999px;font-size:0.76rem;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
.product-intro h1{color:var(--ink);margin:0 0 16px;font-size:clamp(2.2rem,4vw,3.2rem)}
.product-intro .sub{color:var(--muted);font-size:1.2rem;max-width:640px;margin:0 0 28px;line-height:1.55}
.product-intro .cta{display:flex;gap:12px;flex-wrap:wrap}
.product-intro .btn{background:var(--accent-a,var(--primary));box-shadow:0 4px 14px rgba(0,0,0,0.08)}
.product-intro .btn:hover{background:var(--brown);color:#fff}
.product-intro .btn.ghost{background:transparent;border:1.5px solid var(--accent-a,var(--primary));color:var(--accent-a,var(--primary));box-shadow:none}
.product-intro .btn.ghost:hover{background:var(--accent-a,var(--primary));color:#fff}

/* ============================================================
   Pricing
   ============================================================ */
.pricing{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin:32px 0 0}
.price-card{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:32px 28px;transition:all .25s ease;position:relative}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.price-card.featured{border-color:var(--accent-a,var(--primary));box-shadow:var(--shadow-md);transform:translateY(-4px)}
.price-card.featured:before{content:"Most Popular";position:absolute;top:-12px;right:24px;background:var(--accent-a,var(--primary));color:#fff;padding:5px 12px;border-radius:999px;font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase}
.price-card h4{margin:0 0 6px;color:var(--accent-a,var(--primary));font-size:1rem;text-transform:uppercase;letter-spacing:0.08em;font-family:var(--font-sans);font-weight:700}
.price-card .amt{font-family:var(--font-display);font-size:2.1rem;font-weight:600;margin:12px 0;color:var(--ink);letter-spacing:-0.02em}
.price-card .amt small{font-family:var(--font-sans);font-size:0.88rem;color:var(--muted);font-weight:500;letter-spacing:0}
.price-card p{margin:12px 0 0;color:var(--muted);font-size:0.95rem;line-height:1.55}

/* ============================================================
   Audience chips
   ============================================================ */
.audience{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.audience span{background:var(--primary-soft);border:1px solid rgba(232,134,42,0.2);padding:7px 14px;border-radius:999px;font-size:0.88rem;color:var(--brown-mid);font-weight:500}

/* ============================================================
   Section title
   ============================================================ */
.section-title{margin-top:56px;color:var(--ink);font-size:1.6rem}
h1.sub,p.sub{color:var(--muted);font-family:var(--font-sans);font-weight:400}

/* ============================================================
   Checklist
   ============================================================ */
.check{padding:0;margin:14px 0 0}
.check li{margin:14px 0;list-style:none;position:relative;padding-left:32px;color:var(--text);line-height:1.55}
.check li:before{content:"";position:absolute;left:0;top:5px;width:20px;height:20px;border-radius:50%;background:var(--palm);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M3.5 8l3 3 6-6' stroke='white' stroke-width='2.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:14px;background-position:center;background-repeat:no-repeat}

/* ============================================================
   Contact form
   ============================================================ */
.contact-form{display:grid;gap:16px;max-width:560px}
.contact-form label{display:grid;gap:8px;font-weight:600;color:var(--ink);font-size:0.95rem}
.contact-form input,.contact-form textarea,.contact-form select{padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;font:inherit;background:var(--surface);color:var(--ink);font-weight:400;transition:border-color .18s,box-shadow .18s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px rgba(232,134,42,0.12)}
.notice{margin-top:18px;background:#eaf7ec;color:#1e7a2e;border:1px solid #bfe8c7;padding:14px 16px;border-radius:12px;font-size:0.95rem}

/* ============================================================
   Footer
   ============================================================ */
.bbm-footer{background:var(--brown);color:#d4c4b0;margin-top:0;padding:72px 0 32px;position:relative}
.bbm-footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(245,194,62,0.3),transparent)}
.bbm-footer h4{color:#fff;margin:0 0 14px;font-size:0.88rem;text-transform:uppercase;letter-spacing:0.12em;font-family:var(--font-sans);font-weight:700}
.bbm-footer ul{margin:0;padding:0;list-style:none}
.bbm-footer ul li{margin:8px 0}
.bbm-footer p{color:#b8a68c;font-size:0.94rem;margin:0}
.bbm-footer a{color:#d4c4b0;font-size:0.94rem}
.bbm-footer a:hover{color:var(--gold)}
.bbm-footer .grid{gap:40px}
.copy{border-top:1px solid rgba(255,255,255,0.08);margin-top:40px;padding-top:24px;text-align:center;color:#8b7a63;font-size:0.88rem}

/* ============================================================
   Accessibility
   ============================================================ */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:920px){
  .features{grid-template-columns:1fr;gap:16px;margin:56px auto 40px}
  .cards{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr;gap:32px}
  .cta-band{padding:52px 0;margin-top:64px}
  .cta-band .container{flex-direction:column;align-items:flex-start}
  .pad,.pad-lg{padding:56px 0}
  .product-intro{padding-right:0}
  .product-intro .sub{font-size:1.08rem}
  .bbm-header nav{gap:2px}
  .bbm-header nav a:not(.btn){padding:8px 10px;font-size:0.92rem}
  .brand span{display:none}
  .section-title{margin-top:40px}
}

@media (max-width:560px){
  .bbm-header nav a:not(.btn){display:none}
  .bbm-header nav a.btn{margin-left:0}
}

/* ============================================================
   Hero v2 — full-bleed banner image with left text overlay
   ============================================================ */
.hero-v2{padding:0;background:#1a1309 url('../img/hero-banner.jpg') center/cover no-repeat;border-bottom:none;position:relative;overflow:hidden;min-height:640px;display:flex;align-items:center}
.hero-v2:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(26,19,9,0.85) 0%,rgba(26,19,9,0.6) 35%,rgba(26,19,9,0.15) 60%,rgba(26,19,9,0) 100%);pointer-events:none}
.hero-v2__grid{display:grid;grid-template-columns:minmax(0,640px) 1fr;gap:0;align-items:center;position:relative;width:100%;padding:80px 0}
.hero-v2__content{position:relative;z-index:2;color:#fff}
.hero-v2__content .eyebrow{color:var(--gold)}
.hero-v2__content h1{font-size:clamp(2.2rem,4vw,3.1rem);margin:14px 0 20px;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,0.4);max-width:560px;line-height:1.1}
.hero-v2__sub{font-size:1.1rem;color:rgba(255,255,255,0.9);max-width:520px;margin:0 0 32px;line-height:1.55;text-shadow:0 1px 14px rgba(0,0,0,0.4)}
.hero-v2__cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}
.hero-v2__cta .btn{background:var(--gold);color:var(--brown);box-shadow:0 10px 28px rgba(0,0,0,0.25)}
.hero-v2__cta .btn:hover{background:#fff;color:var(--brown)}
.hero-v2__cta .btn.ghost{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.5);color:#fff;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.hero-v2__cta .btn.ghost:hover{background:rgba(255,255,255,0.95);border-color:#fff;color:var(--brown)}
.hero-v2__visual{display:none}

.trust-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;color:rgba(255,255,255,0.85);font-size:0.94rem;font-weight:500;text-shadow:0 1px 8px rgba(0,0,0,0.4)}
.trust-row__item{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.trust-row__item svg{color:var(--gold)}
.trust-row__divider{color:rgba(255,255,255,0.4);font-weight:700}

.hero-v2__visual{position:relative}
.hero-logos{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hero-logo{background:var(--surface);border:1px solid var(--line-soft);border-radius:14px;padding:18px 18px 16px;transition:all .22s ease;position:relative;overflow:hidden;display:block}
.hero-logo:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--c);transition:width .22s ease}
.hero-logo:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--c)}
.hero-logo:hover:before{width:6px}
.hero-logo__tag{font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--c);margin-bottom:6px}
.hero-logo__name{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--ink);letter-spacing:-0.01em;line-height:1.2;margin-bottom:4px}
.hero-logo__desc{font-size:0.88rem;color:var(--muted);line-height:1.4}

/* ============================================================
   Lanes — category-grouped product sections
   ============================================================ */
.lane{display:grid;grid-template-columns:260px 1fr;gap:40px;margin:48px 0 0;padding:36px 0;border-top:1px solid var(--line-soft)}
.lane:first-of-type{margin-top:28px}
.lane__label{position:sticky;top:96px;align-self:start}
.lane__chip{display:inline-block;background:var(--c,var(--primary));color:#fff;padding:7px 16px;border-radius:999px;font-size:0.78rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:14px}
.lane__desc{color:var(--muted);font-size:0.98rem;line-height:1.55;margin:0}
.lane__cards{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.card-lg{padding:32px 28px}
.card-lg h4{font-size:1.35rem;margin-bottom:12px}
.card-lg p{font-size:1rem;line-height:1.6;margin-bottom:16px}
.card__link{display:inline-block;color:var(--primary);font-weight:600;font-size:0.95rem;transition:transform .2s ease}
.card-lg:hover .card__link{transform:translateX(3px)}

/* 4-column features */
.features-4{grid-template-columns:repeat(4,1fr)}

/* Larger audience chips */
.audience-lg span{padding:10px 18px;font-size:0.98rem}

/* Services block */
.services{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:40px;display:flex;align-items:center;justify-content:space-between;gap:32px;box-shadow:var(--shadow-sm)}
.services h3{margin:8px 0 10px;font-size:1.5rem}
.services p{color:var(--muted);margin:0;max-width:540px}

@media (max-width:1024px){
  .features-4{grid-template-columns:repeat(2,1fr)}
  .lane{grid-template-columns:1fr;gap:24px}
  .lane__label{position:static}
  .lane__cards{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  .hero-v2{min-height:520px}
  .hero-v2:before{background:linear-gradient(180deg,rgba(26,19,9,0.35) 0%,rgba(26,19,9,0.7) 50%,rgba(26,19,9,0.9) 100%)}
  .hero-v2__grid{grid-template-columns:1fr;padding:48px 0;align-items:flex-end}
  .hero-v2__content h1{font-size:2.1rem}
  .hero-v2__sub{font-size:1.05rem}
  .lane__cards{grid-template-columns:1fr}
  .services{flex-direction:column;align-items:flex-start;padding:28px}
  .trust-row{font-size:0.86rem;gap:8px}
  .trust-row__divider{display:none}
}

/* ============================================================
   Status pills
   ============================================================ */
.status{display:inline-flex;align-items:center;gap:6px;font-size:0.72rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;padding:4px 10px;border-radius:999px;margin-bottom:12px}
.status:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.status--live{background:rgba(45,138,62,0.12);color:#1e5a2a}
.status--beta{background:rgba(26,157,196,0.12);color:#0f6a88}
.status--soon{background:rgba(232,134,42,0.14);color:#c46d18}
.status--waitlist{background:rgba(139,58,14,0.12);color:#8b3a0e}

.card .status,.hero-logo .status{margin-bottom:10px}
.hero-logo__tag-row{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}

/* ============================================================
   Comparison table
   ============================================================ */
.compare-wrap{overflow-x:auto;margin:24px 0 0;border-radius:var(--radius-lg);border:1px solid var(--line-soft);box-shadow:var(--shadow-sm);background:var(--surface)}
.compare{width:100%;border-collapse:collapse;font-size:0.96rem;min-width:700px}
.compare th,.compare td{padding:18px 20px;text-align:left;border-bottom:1px solid var(--line-soft);vertical-align:top}
.compare thead th{background:var(--primary-soft);color:var(--brown);font-family:var(--font-sans);font-weight:700;font-size:0.82rem;text-transform:uppercase;letter-spacing:0.08em;border-bottom:1px solid rgba(232,134,42,0.2)}
.compare tbody tr:last-child td{border-bottom:none}
.compare tbody tr:hover{background:var(--primary-soft)}
.compare .product-name{font-family:var(--font-display);font-weight:600;font-size:1.08rem;color:var(--ink);letter-spacing:-0.01em}
.compare .product-name a{color:var(--ink)}
.compare .product-name a:hover{color:var(--primary)}
.compare .price{font-weight:600;color:var(--ink);white-space:nowrap}
.compare .price small{font-weight:500;color:var(--muted);font-size:0.82rem}

/* ============================================================
   FAQ (native <details> accordion)
   ============================================================ */
.faq{display:grid;gap:12px;margin-top:28px;max-width:860px}
.faq details{background:var(--surface);border:1px solid var(--line-soft);border-radius:var(--radius);padding:0;transition:border-color .2s,box-shadow .2s}
.faq details[open]{border-color:rgba(232,134,42,0.3);box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;padding:22px 24px;font-weight:600;color:var(--ink);font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:var(--font-sans)}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"";width:10px;height:10px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .2s ease;flex-shrink:0}
.faq details[open] summary:after{transform:rotate(-135deg);border-color:var(--primary)}
.faq details > div{padding:0 24px 22px;color:var(--text);line-height:1.65;font-size:0.98rem}
.faq details > div p:last-child{margin-bottom:0}

/* ============================================================
   Product preview mockups (placeholders)
   ============================================================ */
.preview-section{margin-top:64px;padding:48px 0;background:linear-gradient(180deg,var(--surface) 0%,var(--bg) 100%);border-radius:var(--radius-lg);border:1px solid var(--line-soft)}
.preview-section > .container{max-width:100%;padding:0 40px}
.preview-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;flex-wrap:wrap;gap:12px}
.preview-header h3{margin:6px 0 0;font-size:1.6rem}
.preview-note{font-size:0.85rem;color:var(--faint);font-style:italic}

.mockup-grid{display:grid;grid-template-columns:1.8fr 1fr;gap:32px;align-items:center}
@media (max-width:720px){.mockup-grid{grid-template-columns:1fr;gap:24px} .preview-section > .container{padding:0 20px}}

/* Browser / desktop mockup */
.mockup-browser{background:#fff;border-radius:14px;overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--line);aspect-ratio:16/10}
.mockup-browser__chrome{background:#f4ede1;padding:12px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--line-soft)}
.mockup-browser__dots{display:flex;gap:6px}
.mockup-browser__dot{width:10px;height:10px;border-radius:50%;background:#d9cfbe}
.mockup-browser__url{flex:1;background:#fff;height:22px;border-radius:6px;margin-left:10px;padding:0 10px;display:flex;align-items:center;font-size:0.72rem;color:var(--faint);font-family:ui-monospace,monospace}
.mockup-browser__body{padding:0;position:relative;background:var(--bg);height:calc(100% - 46px);overflow:hidden}

/* Phone mockup */
.mockup-phone{background:#1a1309;border-radius:32px;padding:10px;box-shadow:var(--shadow-lg);aspect-ratio:9/18;max-width:240px;justify-self:center;position:relative}
.mockup-phone:before{content:"";position:absolute;top:18px;left:50%;transform:translateX(-50%);width:60px;height:18px;background:#1a1309;border-radius:10px;z-index:3}
.mockup-phone__screen{background:var(--bg);border-radius:24px;overflow:hidden;height:100%;position:relative}

/* Mock UI content (shared) */
.mock-ui{padding:20px;display:flex;flex-direction:column;gap:10px;height:100%}
.mockup-phone .mock-ui{padding:40px 16px 20px}
.mock-ui__header{background:var(--c,var(--primary));height:44px;border-radius:10px;display:flex;align-items:center;padding:0 14px;color:#fff;font-size:0.82rem;font-weight:600;letter-spacing:-0.01em;gap:8px}
.mockup-phone .mock-ui__header{height:36px;font-size:0.72rem;padding:0 10px}
.mock-ui__header:before{content:"";width:18px;height:18px;border-radius:6px;background:rgba(255,255,255,0.25);flex-shrink:0}
.mock-ui__row{display:flex;gap:8px;align-items:stretch}
.mock-ui__card{background:var(--surface);border:1px solid var(--line-soft);border-radius:10px;padding:14px;flex:1;display:flex;flex-direction:column;gap:8px;min-height:0}
.mockup-phone .mock-ui__card{padding:10px;border-radius:8px}
.mock-ui__label{font-size:0.64rem;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--c,var(--primary))}
.mockup-phone .mock-ui__label{font-size:0.58rem}
.mock-ui__amount{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--ink);letter-spacing:-0.01em}
.mockup-phone .mock-ui__amount{font-size:1rem}
.mock-ui__line{background:var(--line);height:8px;border-radius:4px;width:100%}
.mock-ui__line--short{width:60%}
.mock-ui__line--mid{width:78%}
.mock-ui__pill{display:inline-flex;background:rgba(45,138,62,0.15);color:#1e5a2a;padding:3px 8px;border-radius:999px;font-size:0.62rem;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;width:fit-content}
.mockup-phone .mock-ui__pill{font-size:0.54rem;padding:2px 6px}
.mock-ui__footer{margin-top:auto;display:flex;gap:8px;align-items:center}
.mock-ui__btn{background:var(--c,var(--primary));color:#fff;padding:8px 14px;border-radius:999px;font-size:0.74rem;font-weight:600}
.mockup-phone .mock-ui__btn{padding:6px 10px;font-size:0.64rem}
.mock-ui__stat{flex:1;background:var(--surface);border:1px solid var(--line-soft);border-radius:10px;padding:10px 12px}
.mockup-phone .mock-ui__stat{padding:8px 10px}

/* ============================================================
   Banner fallback (CSS-only placeholder for missing images)
   ============================================================ */
.banner-placeholder{display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:16/7;min-height:280px;max-height:460px;border-radius:var(--radius-lg);margin-bottom:36px;box-shadow:var(--shadow-md);position:relative;overflow:hidden;color:#fff;background:linear-gradient(135deg,var(--c-start,var(--brown)) 0%,var(--c-end,var(--primary)) 100%)}
.banner-placeholder:before{content:"";position:absolute;top:-30%;right:-10%;width:60%;height:160%;background:radial-gradient(closest-side,rgba(245,194,62,0.35),transparent 70%);pointer-events:none}
.banner-placeholder:after{content:"";position:absolute;bottom:-20px;left:-20px;right:-20px;height:60px;background:linear-gradient(90deg,rgba(26,157,196,0.4),rgba(26,157,196,0))}
.banner-placeholder__content{position:relative;text-align:center;padding:40px}
.banner-placeholder__name{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);font-weight:600;letter-spacing:-0.02em;margin:0 0 10px;text-shadow:0 2px 16px rgba(0,0,0,0.25)}
.banner-placeholder__tag{display:inline-block;background:rgba(255,255,255,0.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:7px 18px;border-radius:999px;font-size:0.82rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;border:1px solid rgba(255,255,255,0.3)}

/* Inline hero logo mark (above the H1) */
.hero-logo-mark{display:block;width:auto;height:auto;max-width:min(440px,60%);margin:0 0 28px;filter:drop-shadow(0 0 12px rgba(255,255,255,0.55)) drop-shadow(0 0 28px rgba(255,255,255,0.35)) drop-shadow(0 6px 24px rgba(0,0,0,0.45))}
@media (max-width:720px){.hero-logo-mark{max-width:280px;margin-bottom:20px}}
