/* ============================================================
   XpressCoupon — landing pages (SEO) shared styles
   ============================================================ */
:root{
  --accent:oklch(0.63 0.21 28); --accent-hover:oklch(0.57 0.21 28); --accent-2:oklch(0.74 0.16 58);
  --accent-soft:oklch(0.95 0.05 40); --accent-glow:oklch(0.63 0.21 28 / .32);
  --bg:oklch(0.985 0.006 60); --surface:oklch(1 0 0); --tint:oklch(0.975 0.008 50);
  --ink:oklch(0.24 0.02 45); --ink-soft:oklch(0.46 0.02 45); --ink-faint:oklch(0.62 0.015 45);
  --line:oklch(0.90 0.01 50); --line-soft:oklch(0.94 0.008 50);
  --green:oklch(0.55 0.13 150); --green-soft:oklch(0.95 0.05 150);
  --usa:oklch(0.55 0.16 255); --usa-soft:oklch(0.95 0.04 255);
  --sale:oklch(0.64 0.18 35); --sale-soft:oklch(0.95 0.05 40);
  --fd:"Space Grotesk",ui-sans-serif,system-ui,sans-serif;
  --fb:"Plus Jakarta Sans",ui-sans-serif,system-ui,sans-serif;
  --r-sm:10px; --r-md:16px; --r-lg:22px; --r-xl:30px;
  --sh-sm:0 1px 2px oklch(0.4 .02 45/.06),0 2px 8px oklch(0.4 .02 45/.05);
  --sh-md:0 8px 24px oklch(0.4 .04 45/.10),0 2px 6px oklch(0.4 .04 45/.06);
  --sh-lg:0 24px 60px oklch(0.4 .06 45/.16),0 8px 20px oklch(0.4 .04 45/.08);
}
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{ margin:0; font-family:var(--fb); color:var(--ink); background:var(--bg); line-height:1.7; font-size:17px; -webkit-font-smoothing:antialiased; }
h1,h2,h3,h4{ font-family:var(--fd); font-weight:700; line-height:1.12; letter-spacing:-.02em; margin:0; text-wrap:balance; }
p,li{ text-wrap:pretty; }
a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; }
img{ max-width:100%; display:block; }
:focus-visible{ outline:3px solid var(--accent); outline-offset:2px; border-radius:6px; }
.wrap{ max-width:880px; margin-inline:auto; padding-inline:clamp(18px,4vw,28px); }

/* ---- buttons ---- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:var(--fd); font-weight:600; font-size:15px; padding:13px 24px; border-radius:999px; min-height:48px; transition:transform .18s,box-shadow .25s,background .2s; white-space:nowrap; cursor:pointer; border:0; }
.btn svg{ width:18px; height:18px; }
.btn--primary{ background:var(--accent); color:#fff; box-shadow:0 10px 24px var(--accent-glow); }
.btn--primary:hover{ background:var(--accent-hover); transform:translateY(-2px); text-decoration:none; }
.btn--ghost{ background:var(--surface); color:var(--ink); border:1.5px solid var(--line); }
.btn--ghost:hover{ border-color:var(--accent); color:var(--accent); transform:translateY(-2px); text-decoration:none; }

/* ---- header ---- */
.lp-header{ position:sticky; top:0; z-index:40; background:oklch(1 0 0/.86); backdrop-filter:blur(12px); border-bottom:1px solid var(--line-soft); }
.lp-header__in{ max-width:1100px; margin-inline:auto; padding:12px clamp(18px,4vw,28px); display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand{ display:inline-flex; align-items:center; gap:9px; font-family:var(--fd); font-weight:700; font-size:20px; color:var(--ink); }
.brand:hover{ text-decoration:none; }
.brand .mk{ display:inline-flex; width:34px; height:34px; align-items:center; justify-content:center; border-radius:9px; background:var(--accent); color:#fff; }
.brand .mk svg{ width:20px; height:20px; }
.brand b{ color:var(--accent); }
.lp-nav{ display:flex; gap:4px; align-items:center; }
.lp-nav a{ font-family:var(--fd); font-weight:600; font-size:14px; color:var(--ink-soft); padding:8px 13px; border-radius:999px; }
.lp-nav a:hover{ color:var(--accent); background:var(--accent-soft); text-decoration:none; }
.lp-nav .btn{ min-height:40px; padding:9px 18px; font-size:14px; }
@media(max-width:760px){ .lp-nav a:not(.btn){ display:none; } }

/* ---- breadcrumb ---- */
.crumb{ max-width:880px; margin:18px auto 0; padding-inline:clamp(18px,4vw,28px); font-size:13.5px; color:var(--ink-faint); }
.crumb a{ color:var(--ink-faint); }
.crumb a:hover{ color:var(--accent); }
.crumb span{ margin:0 6px; opacity:.6; }

/* ---- hero ---- */
.lp-hero{ padding:clamp(26px,5vw,46px) 0 8px; }
.lp-hero .eyebrow{ display:inline-flex; align-items:center; gap:7px; font-family:var(--fd); font-weight:600; font-size:12.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); background:var(--accent-soft); padding:6px 13px; border-radius:999px; }
.lp-hero h1{ font-size:clamp(30px,5.4vw,46px); margin:16px 0 0; }
.lp-hero .lead{ font-size:clamp(17px,2.2vw,20px); color:var(--ink-soft); margin-top:16px; max-width:62ch; }
.lp-meta{ display:flex; flex-wrap:wrap; gap:10px 18px; margin-top:20px; font-size:14px; color:var(--ink-faint); align-items:center; }
.lp-meta .dot{ width:8px; height:8px; border-radius:50%; background:var(--green); display:inline-block; margin-right:7px; box-shadow:0 0 0 4px var(--green-soft); }
.lp-hero__cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }

/* ---- article body ---- */
.article{ padding:clamp(20px,4vw,36px) 0 8px; }
.article h2{ font-size:clamp(23px,3.4vw,32px); margin:44px 0 14px; scroll-margin-top:90px; }
.article h3{ font-size:clamp(19px,2.4vw,23px); margin:30px 0 10px; }
.article p{ margin:0 0 16px; color:oklch(0.32 0.02 45); }
.article ul,.article ol{ margin:0 0 18px; padding-left:22px; color:oklch(0.32 0.02 45); }
.article li{ margin-bottom:8px; }
.article strong{ color:var(--ink); }
.article a{ text-decoration:underline; text-underline-offset:2px; }
.lead-in::first-letter{ font-family:var(--fd); font-weight:700; font-size:3.1em; float:left; line-height:.82; padding:6px 12px 0 0; color:var(--accent); }

/* ---- TOC ---- */
.toc{ background:var(--tint); border:1px solid var(--line-soft); border-radius:var(--r-lg); padding:20px 24px; margin:8px 0 8px; }
.toc h2{ font-size:14px !important; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-faint); margin:0 0 12px !important; }
.toc ol{ margin:0; padding-left:20px; columns:2; column-gap:30px; }
.toc li{ margin-bottom:7px; }
.toc a{ color:var(--ink-soft); text-decoration:none; font-weight:500; font-size:15px; }
.toc a:hover{ color:var(--accent); }
@media(max-width:620px){ .toc ol{ columns:1; } }

/* ---- callout note ---- */
.note{ display:flex; gap:13px; background:var(--accent-soft); border:1px solid oklch(0.85 0.06 40); border-radius:var(--r-md); padding:16px 18px; margin:22px 0; font-size:15.5px; color:oklch(0.36 0.06 35); }
.note svg{ width:22px; height:22px; flex:0 0 auto; color:var(--accent); margin-top:2px; }
.note--green{ background:var(--green-soft); border-color:oklch(0.82 0.07 150); color:oklch(0.34 0.08 150); }
.note--green svg{ color:var(--green); }

/* ---- key facts strip ---- */
.facts{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:24px 0; }
@media(max-width:620px){ .facts{ grid-template-columns:1fr; } }
.fact{ background:var(--surface); border:1px solid var(--line-soft); border-radius:var(--r-md); padding:18px 20px; box-shadow:var(--sh-sm); }
.fact b{ font-family:var(--fd); font-size:26px; color:var(--accent); display:block; }
.fact span{ font-size:13.5px; color:var(--ink-soft); }

/* ---- coupon table ---- */
.codes{ margin:24px 0; border:1px solid var(--line-soft); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--sh-sm); background:var(--surface); }
.code-row{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:16px; padding:16px 20px; border-top:1px solid var(--line-soft); }
.code-row:first-child{ border-top:0; }
.code-amt{ font-family:var(--fd); font-weight:700; font-size:26px; color:var(--ink); min-width:74px; }
.code-amt small{ display:block; font-size:11px; letter-spacing:.08em; color:var(--ink-faint); font-weight:600; }
.code-info{ min-width:0; }
.code-info .ty{ display:inline-block; font-family:var(--fd); font-weight:600; font-size:11px; letter-spacing:.04em; text-transform:uppercase; padding:3px 9px; border-radius:999px; margin-bottom:5px; }
.ty.t-global{ background:var(--green-soft); color:var(--green); }
.ty.t-usa{ background:var(--usa-soft); color:var(--usa); }
.ty.t-sale{ background:var(--sale-soft); color:var(--sale); }
.code-info p{ margin:0; font-size:14.5px; color:var(--ink-soft); }
.code-act{ display:flex; align-items:center; gap:10px; }
.reveal-btn{ font-family:var(--fd); font-weight:600; font-size:14px; background:var(--ink); color:#fff; border:0; border-radius:999px; padding:10px 18px; min-height:42px; cursor:pointer; transition:background .2s,transform .15s; white-space:nowrap; }
.reveal-btn:hover{ background:var(--accent); transform:translateY(-1px); }
.code-shown{ display:none; align-items:center; gap:8px; }
.code-row.on .reveal-btn{ display:none; }
.code-row.on .code-shown{ display:flex; }
.codepill{ display:inline-flex; align-items:center; gap:8px; border:1.5px dashed var(--accent); border-radius:999px; padding:6px 6px 6px 14px; background:var(--accent-soft); }
.codepill .code{ font-family:var(--fd); font-weight:700; letter-spacing:.06em; color:var(--accent); }
.codepill .cp{ font-family:var(--fd); font-weight:600; font-size:13px; background:var(--accent); color:#fff; border:0; border-radius:999px; padding:7px 12px; cursor:pointer; }
@media(max-width:600px){ .code-row{ grid-template-columns:auto 1fr; } .code-act{ grid-column:1/-1; justify-content:flex-start; } }

/* ---- comparison table ---- */
.dtable{ width:100%; border-collapse:collapse; margin:20px 0; font-size:15.5px; background:var(--surface); border:1px solid var(--line-soft); border-radius:var(--r-md); overflow:hidden; }
.dtable th,.dtable td{ padding:13px 16px; text-align:left; border-top:1px solid var(--line-soft); }
.dtable thead th{ background:var(--tint); font-family:var(--fd); font-size:13px; letter-spacing:.03em; text-transform:uppercase; color:var(--ink-faint); border-top:0; }
.dtable td.num{ text-align:right; font-variant-numeric:tabular-nums; }
.dtable .hi{ color:var(--green); font-weight:600; }
.dtable tr.total td{ background:var(--tint); font-weight:700; font-family:var(--fd); }

/* ---- CTA band ---- */
.cta{ margin:34px 0; border-radius:var(--r-xl); color:#fff; padding:clamp(26px,4vw,40px); text-align:center;
  background:linear-gradient(125deg,oklch(0.42 0.16 28),oklch(0.54 0.18 38) 60%,oklch(0.66 0.16 58)); box-shadow:var(--sh-lg); position:relative; overflow:hidden; }
.cta .spark{ position:absolute; inset:0; background-image:radial-gradient(2px 2px at 20% 30%,oklch(1 0 0/.5),transparent),radial-gradient(2px 2px at 75% 60%,oklch(1 0 0/.4),transparent); opacity:.7; }
.cta h2{ color:#fff; font-size:clamp(22px,3.4vw,30px); position:relative; }
.cta p{ color:oklch(1 0 0/.92); margin:12px auto 0; max-width:52ch; position:relative; }
.cta .btn{ margin-top:22px; position:relative; }
.cta .btn--primary{ background:#fff; color:var(--accent); }

/* ---- FAQ ---- */
.faq{ margin:24px 0; }
.faq-item{ border:1px solid var(--line-soft); border-radius:var(--r-md); margin-bottom:12px; background:var(--surface); overflow:hidden; }
.faq-q{ width:100%; display:flex; align-items:center; justify-content:space-between; gap:14px; text-align:left; font-family:var(--fd); font-weight:600; font-size:17px; color:var(--ink); padding:18px 20px; background:none; border:0; cursor:pointer; }
.faq-q .pm{ flex:0 0 auto; width:22px; height:22px; color:var(--accent); transition:transform .25s; }
.faq-item.open .faq-q .pm{ transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-item.open .faq-a{ max-height:400px; }
.faq-a .inner{ padding:0 20px 18px; color:var(--ink-soft); font-size:15.5px; }

/* ---- related links ---- */
.related{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin:24px 0; }
@media(max-width:620px){ .related{ grid-template-columns:1fr; } }
.related a{ display:block; background:var(--surface); border:1px solid var(--line-soft); border-radius:var(--r-md); padding:18px 20px; box-shadow:var(--sh-sm); transition:transform .15s,border-color .15s; }
.related a:hover{ transform:translateY(-2px); border-color:var(--accent); text-decoration:none; }
.related b{ font-family:var(--fd); color:var(--ink); display:block; }
.related span{ font-size:14px; color:var(--ink-soft); }

/* ---- disclosure + footer ---- */
.disclosure{ display:flex; gap:12px; background:var(--tint); border:1px solid var(--line-soft); border-radius:var(--r-md); padding:16px 18px; margin:28px 0; font-size:14px; color:var(--ink-soft); }
.disclosure svg{ width:20px; height:20px; flex:0 0 auto; color:var(--ink-faint); margin-top:1px; }
.lp-footer{ margin-top:40px; border-top:1px solid var(--line); background:var(--tint); }
.lp-footer__in{ max-width:1100px; margin-inline:auto; padding:36px clamp(18px,4vw,28px) 28px; }
.lp-footer__grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:24px; }
@media(max-width:760px){ .lp-footer__grid{ grid-template-columns:1fr 1fr; } }
.lp-footer h4{ font-family:var(--fd); font-size:13px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:12px; }
.lp-footer a{ display:block; color:var(--ink-soft); font-size:15px; padding:4px 0; }
.lp-footer a:hover{ color:var(--accent); text-decoration:none; }
.lp-footer__about{ color:var(--ink-soft); font-size:14.5px; max-width:38ch; margin:10px 0 0; }
.lp-footer__legal{ max-width:1100px; margin-inline:auto; padding:18px clamp(18px,4vw,28px); border-top:1px solid var(--line-soft); display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; font-size:13px; color:var(--ink-faint); }
.lp-footer__legal nav{ display:flex; gap:16px; }
.lp-footer__legal a{ color:var(--ink-faint); }
.toast{ position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(20px); background:var(--ink); color:#fff; font-family:var(--fd); font-weight:600; font-size:14px; padding:12px 18px; border-radius:999px; display:flex; align-items:center; gap:8px; box-shadow:var(--sh-lg); opacity:0; pointer-events:none; transition:opacity .25s,transform .25s; z-index:80; }
.toast svg{ width:16px; height:16px; }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }
@media (prefers-reduced-motion:reduce){ *{ animation-duration:.001ms!important; transition-duration:.001ms!important; } html{ scroll-behavior:auto; } }
