/* ===========================================================================
   AgentIL — bespoke dark editorial design system.
   Art direction: near-black canvas, warm-ivory serif display, a single
   signature emerald (no generic SaaS violet), glass surfaces, aurora glow,
   mono Latin labels, real motion. Built to read several levels above a store.
   =========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&display=swap');

:root {
  --bg: #07080d;
  --bg-2: #0c0e16;
  --ink: #f4f1e9;        /* warm ivory */
  --ink-2: #c4c4d2;
  --muted: #82869c;
  --line: rgba(255, 255, 255, .09);
  --line-2: rgba(255, 255, 255, .14);
  --glass: rgba(255, 255, 255, .035);
  --glass-2: rgba(255, 255, 255, .06);

  --emerald: #4ef0a8;     /* signature */
  --emerald-deep: #18c98a;
  --teal: #2fe6d0;
  --gold: #e7c074;        /* premium accent */
  --hot: #ff7a6b;

  --grad-text: linear-gradient(105deg, #f4f1e9 0%, #b9f5d8 45%, #4ef0a8 100%);
  --grad-cta: linear-gradient(120deg, #4ef0a8 0%, #2fe6d0 100%);
  --glow-emerald: 0 0 0 1px rgba(78, 240, 168, .35), 0 18px 50px -18px rgba(47, 230, 208, .5);

  --radius: 16px;
  --radius-lg: 26px;
  --container: 1200px;
  --ease: cubic-bezier(.21, .68, .35, 1);
  --shadow: 0 30px 80px -30px rgba(0, 0, 0, .8);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Heebo', system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  position: relative;
}
/* page-wide grain + top aurora */
body::before {
  content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(60% 40% at 78% -5%, rgba(78, 240, 168, .14), transparent 60%),
    radial-gradient(50% 35% at 10% 0%, rgba(47, 230, 208, .10), transparent 60%),
    radial-gradient(40% 30% at 50% 110%, rgba(231, 192, 116, .06), transparent 60%);
}
body::after {
  content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)'/%3E%3C/svg%3E");
}
main, header, footer { position: relative; z-index: 1; }
bdi, .ltr { unicode-bidi: isolate; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
::selection { background: rgba(78, 240, 168, .25); color: #fff; }
::-webkit-scrollbar { width: 11px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: #20232f; border-radius: 99px; border: 3px solid var(--bg); }

.container { max-width: var(--container); margin-inline: auto; padding-inline: 24px; }
.display { font-family: 'Frank Ruhl Libre', 'Heebo', serif; font-weight: 900; letter-spacing: -.5px; }
.label {
  font-family: 'Space Mono', monospace; font-size: 12.5px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--emerald); display: inline-flex; align-items: center; gap: 9px;
}
.label::before { content: ''; width: 22px; height: 1px; background: var(--emerald); opacity: .6; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: inherit; font-weight: 700; font-size: 15px; cursor: pointer;
  border: 0; border-radius: 999px; padding: 13px 24px; line-height: 1; white-space: nowrap;
  transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s, color .2s, border-color .2s;
}
.btn-cta { background: var(--grad-cta); color: #052016; box-shadow: 0 12px 34px -10px rgba(47, 230, 208, .6); }
.btn-cta:hover { transform: translateY(-2px); box-shadow: 0 18px 44px -10px rgba(78, 240, 168, .75); }
.btn-brand { background: var(--grad-cta); color: #052016; }
.btn-brand:hover { transform: translateY(-2px); }
.btn-ghost { background: transparent; color: var(--ink); border: 1.5px solid var(--line-2); }
.btn-ghost:hover { border-color: var(--emerald); color: var(--emerald); }
.btn-lg { padding: 16px 32px; font-size: 16.5px; }
.btn-block { width: 100%; }
.btn[disabled] { opacity: .5; cursor: not-allowed; }

/* ---------- nav ---------- */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(7, 8, 13, .72); backdrop-filter: saturate(150%) blur(16px); border-bottom: 1px solid var(--line); }
.nav-inner { display: flex; align-items: center; gap: 18px; height: 72px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: 'Space Mono', monospace; font-weight: 700; font-size: 21px; letter-spacing: -.5px; }
.brand .logo { width: 34px; height: 34px; border-radius: 9px; background: var(--grad-cta); color: #052016; display: grid; place-items: center; font-size: 18px; box-shadow: 0 0 22px -4px rgba(78, 240, 168, .7); }
.brand b { color: var(--emerald); }
.nav-links { display: flex; gap: 26px; margin-inline-start: 16px; color: var(--ink-2); font-weight: 500; font-size: 15px; }
.nav-links a { position: relative; }
.nav-links a:hover { color: var(--emerald); }
.nav-spacer { flex: 1; }
.cart-btn { position: relative; }
.cart-badge { position: absolute; inset-block-start: -7px; inset-inline-start: -7px; min-width: 20px; height: 20px; padding: 0 5px; border-radius: 999px; background: var(--emerald); color: #052016; font-size: 12px; font-weight: 800; display: grid; place-items: center; }
.cart-badge.hidden { display: none; }

/* ---------- marquee ticker ---------- */
.marquee { border-block: 1px solid var(--line); overflow: hidden; background: rgba(255, 255, 255, .015); }
.marquee-track { display: flex; gap: 42px; width: max-content; padding: 13px 0; animation: scroll 38s linear infinite; }
.marquee-track span { font-family: 'Space Mono', monospace; font-size: 13px; letter-spacing: 1px; color: var(--muted); display: inline-flex; align-items: center; gap: 42px; }
.marquee-track b { color: var(--emerald); font-weight: 400; }
@keyframes scroll { to { transform: translateX(50%); } }

/* ---------- hero ---------- */
.hero { padding: 86px 0 72px; position: relative; }
.hero > .container { position: relative; z-index: 1; }
.hero::after {
  content: ''; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: linear-gradient(180deg, rgba(7, 8, 13, .35), rgba(7, 8, 13, .72)), url('hero.jpg');
  background-size: cover; background-position: center;
  -webkit-mask-image: linear-gradient(180deg, #000 70%, transparent);
  mask-image: linear-gradient(180deg, #000 70%, transparent);
}
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 48px; align-items: center; }
.hero h1 { font-size: clamp(40px, 6.4vw, 76px); line-height: 1.03; margin: 22px 0 20px; }
.hero h1 .grad { background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero .sub { font-size: clamp(17px, 2.2vw, 20px); color: var(--ink-2); max-width: 560px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 30px; }
.trust-pills { display: flex; flex-wrap: wrap; gap: 10px 26px; margin-top: 34px; color: var(--muted); font-weight: 500; font-size: 14px; }
.trust-pills span { display: inline-flex; align-items: center; gap: 8px; }
.trust-pills .ic { color: var(--emerald); }

/* hero agent-chat visual */
.hero-visual { position: relative; }
.chat-card { background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02)); border: 1px solid var(--line-2); border-radius: var(--radius-lg); padding: 22px; box-shadow: var(--shadow); backdrop-filter: blur(6px); animation: floaty 6s ease-in-out infinite; }
.chat-card .ch-head { display: flex; align-items: center; gap: 11px; padding-bottom: 16px; border-bottom: 1px solid var(--line); margin-bottom: 16px; }
.chat-card .av { width: 38px; height: 38px; border-radius: 11px; background: var(--grad-cta); color: #052016; display: grid; place-items: center; font-size: 18px; }
.chat-card .ch-head .nm { font-weight: 700; }
.chat-card .ch-head .st { font-size: 12px; color: var(--emerald); font-family: 'Space Mono', monospace; }
.chat-card .ch-head .st::before { content: '●'; margin-inline-end: 5px; }
.bub { padding: 11px 15px; border-radius: 15px; max-width: 84%; margin-bottom: 11px; font-size: 14.5px; line-height: 1.5; opacity: 0; transform: translateY(8px); animation: pop .5s var(--ease) forwards; }
.bub.you { background: rgba(255,255,255,.07); border: 1px solid var(--line); margin-inline-start: auto; }
.bub.bot { background: rgba(78, 240, 168, .12); border: 1px solid rgba(78, 240, 168, .25); }
.bub.b2 { animation-delay: .5s; } .bub.b3 { animation-delay: 1s; } .bub.b4 { animation-delay: 1.5s; }
.chat-card .typing { font-family: 'Space Mono', monospace; font-size: 12px; color: var(--muted); }
@keyframes floaty { 50% { transform: translateY(-12px); } }
@keyframes pop { to { opacity: 1; transform: none; } }
.hero-visual .halo { position: absolute; inset: -40px; z-index: -1; background: radial-gradient(circle, rgba(78,240,168,.22), transparent 65%); filter: blur(20px); }

/* ---------- sections ---------- */
.section { padding: 64px 0; }
.sec-head { max-width: 720px; margin: 0 auto 44px; text-align: center; }
.sec-head h2 { font-size: clamp(28px, 4.4vw, 46px); line-height: 1.12; margin-top: 14px; }
.sec-head p { color: var(--muted); font-size: 17px; margin-top: 12px; }
.sec-head .label { justify-content: center; }
.sec-head .label::after { content: ''; width: 22px; height: 1px; background: var(--emerald); opacity: .6; }

.cat-head { display: flex; align-items: center; gap: 14px; margin: 52px 0 20px; }
.cat-head .ic { width: 46px; height: 46px; border-radius: 13px; background: var(--glass); border: 1px solid var(--line); display: grid; place-items: center; font-size: 23px; }
.cat-head h3 { font-family: 'Frank Ruhl Libre', serif; font-size: 25px; font-weight: 800; }
.cat-head p { color: var(--muted); font-size: 14px; }
.cat-head .ix { margin-inline-start: auto; font-family: 'Space Mono', monospace; color: var(--muted); font-size: 13px; }

/* ---------- agent cards ---------- */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(290px, 100%), 1fr)); gap: 18px; }
.card { position: relative; background: var(--glass); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; display: flex; flex-direction: column; overflow: hidden; transition: transform .25s var(--ease), border-color .25s, background .25s, box-shadow .25s; }
.card::before { content: ''; position: absolute; inset-block-start: 0; inset-inline: 0; height: 1px; background: linear-gradient(90deg, transparent, rgba(78,240,168,.5), transparent); opacity: 0; transition: opacity .25s; }
.card:hover { transform: translateY(-6px); border-color: var(--line-2); background: var(--glass-2); box-shadow: 0 26px 60px -28px rgba(0,0,0,.8); }
.card:hover::before { opacity: 1; }
.card-icon { width: 54px; height: 54px; border-radius: 14px; background: rgba(255,255,255,.05); border: 1px solid var(--line); display: grid; place-items: center; font-size: 27px; margin-bottom: 16px; transition: box-shadow .25s; }
.card:hover .card-icon { box-shadow: 0 0 26px -6px rgba(78,240,168,.6); border-color: rgba(78,240,168,.35); }
.card h4 { font-size: 19.5px; font-weight: 700; letter-spacing: -.2px; }
.card .tag { color: var(--ink-2); font-size: 14.5px; margin-top: 7px; flex: 1; }
.card-badge { position: absolute; inset-block-start: 18px; inset-inline-end: 18px; font-family: 'Space Mono', monospace; font-size: 11px; font-weight: 700; letter-spacing: .5px; padding: 5px 10px; border-radius: 999px; background: rgba(231,192,116,.14); color: var(--gold); border: 1px solid rgba(231,192,116,.3); }
.card-badge.hot { background: rgba(255,122,107,.14); color: var(--hot); border-color: rgba(255,122,107,.3); }
.card-badge.flag { background: rgba(78,240,168,.14); color: var(--emerald); border-color: rgba(78,240,168,.3); }
.card-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 20px; gap: 10px; }
.price { font-family: 'Space Mono', monospace; font-weight: 700; font-size: 21px; }
.price small { font-family: 'Heebo'; font-weight: 500; font-size: 12.5px; color: var(--muted); }
.card-foot .btn { padding: 10px 16px; font-size: 14px; }

/* ---------- value / 1:1 band ---------- */
.band { position: relative; border-radius: var(--radius-lg); padding: 56px; overflow: hidden; background: linear-gradient(135deg, #0d1520, #0a1a16); border: 1px solid rgba(78,240,168,.2); box-shadow: var(--shadow); }
.band::after { content: ''; position: absolute; inset: 0; background: radial-gradient(60% 90% at 88% 0%, rgba(78,240,168,.18), transparent 60%); pointer-events: none; }
.band-inner { position: relative; display: grid; grid-template-columns: 1.25fr 1fr; gap: 36px; align-items: center; }
.band h2 { font-family: 'Frank Ruhl Libre', serif; font-weight: 900; font-size: clamp(28px, 3.6vw, 42px); line-height: 1.12; }
.band p { color: var(--ink-2); margin-top: 14px; font-size: 17px; }
.band .mini { display: grid; gap: 12px; }
.band .mini div { background: var(--glass); border: 1px solid var(--line); border-radius: 13px; padding: 15px 17px; font-weight: 600; display: flex; gap: 11px; align-items: center; }

/* ---------- steps ---------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.step { position: relative; background: var(--glass); border: 1px solid var(--line); border-radius: var(--radius); padding: 30px; }
.step .n { font-family: 'Space Mono', monospace; font-size: 14px; color: var(--emerald); }
.step h4 { font-size: 19px; margin: 10px 0 7px; font-weight: 700; }
.step p { color: var(--muted); font-size: 15px; }

/* ---------- trust strip ---------- */
.trust-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.trust-card { background: var(--glass); border: 1px solid var(--line); border-radius: var(--radius); padding: 26px; text-align: center; }
.trust-card .big { font-family: 'Frank Ruhl Libre', serif; font-weight: 900; font-size: 34px; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.trust-card p { color: var(--muted); font-size: 14px; margin-top: 6px; }

/* ---------- FAQ ---------- */
.faq { max-width: 780px; margin: 0 auto; display: grid; gap: 12px; }
.faq details { background: var(--glass); border: 1px solid var(--line); border-radius: var(--radius); padding: 4px 20px; transition: border-color .2s; }
.faq details[open] { border-color: rgba(78,240,168,.3); }
.faq summary { list-style: none; cursor: pointer; font-weight: 600; font-size: 17px; padding: 16px 0; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: '+'; color: var(--emerald); font-weight: 700; font-size: 22px; }
.faq details[open] summary::after { content: '−'; }
.faq p { color: var(--muted); padding-bottom: 18px; }

/* ---------- footer ---------- */
.footer { border-top: 1px solid var(--line); margin-top: 56px; padding: 56px 0 34px; background: var(--bg-2); }
.footer .brand { color: var(--ink); }
.footer-grid { display: flex; flex-wrap: wrap; gap: 36px; justify-content: space-between; }
.footer p { color: var(--muted); font-size: 14px; max-width: 340px; margin-top: 14px; }
.footer-cols { display: flex; gap: 60px; flex-wrap: wrap; }
.footer-cols h5 { color: var(--ink); margin-bottom: 12px; font-size: 13px; font-family: 'Space Mono', monospace; letter-spacing: 1px; text-transform: uppercase; }
.footer-cols a { display: block; color: var(--muted); font-size: 14.5px; padding: 5px 0; }
.footer-cols a:hover { color: var(--emerald); }
.footer-bottom { border-top: 1px solid var(--line); margin-top: 34px; padding-top: 20px; font-size: 13px; color: var(--muted); font-family: 'Space Mono', monospace; }

/* ---------- agent detail ---------- */
.breadcrumb { color: var(--muted); font-size: 13px; padding: 26px 0 0; font-family: 'Space Mono', monospace; }
.breadcrumb a:hover { color: var(--emerald); }
.agent-wrap { display: grid; grid-template-columns: 1fr 370px; gap: 40px; align-items: start; padding: 28px 0 64px; }
.agent-main .a-icon { width: 80px; height: 80px; border-radius: 20px; background: var(--glass); border: 1px solid var(--line); display: grid; place-items: center; font-size: 42px; margin-bottom: 18px; box-shadow: 0 0 36px -10px rgba(78,240,168,.5); }
.agent-main h1 { font-family: 'Frank Ruhl Libre', serif; font-weight: 900; font-size: clamp(30px, 4.4vw, 48px); line-height: 1.08; letter-spacing: -.6px; }
.agent-main .lede { font-size: 19px; color: var(--ink-2); margin-top: 14px; }
.a-block { margin-top: 38px; }
.a-block h3 { font-size: 21px; font-weight: 700; margin-bottom: 14px; display: flex; align-items: center; gap: 9px; }
.a-block.problem { background: rgba(255,122,107,.06); border: 1px solid rgba(255,122,107,.2); border-radius: var(--radius); padding: 24px; }
.feature-list { display: grid; gap: 11px; }
.feature-list li { list-style: none; display: flex; gap: 12px; align-items: flex-start; background: var(--glass); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px 17px; }
.feature-list .ic { color: var(--emerald); font-weight: 800; flex: none; }
.how-row { display: flex; gap: 16px; margin-bottom: 14px; align-items: flex-start; }
.how-row .n { flex: none; width: 34px; height: 34px; border-radius: 10px; background: rgba(78,240,168,.12); border: 1px solid rgba(78,240,168,.3); color: var(--emerald); font-family: 'Space Mono', monospace; font-weight: 700; display: grid; place-items: center; }

.buy-box { position: sticky; top: 92px; background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); border: 1px solid var(--line-2); border-radius: var(--radius-lg); padding: 26px; box-shadow: var(--shadow); }
.buy-box .price { font-size: 38px; }
.buy-box .note { color: var(--muted); font-size: 13.5px; margin: 6px 0 20px; }
.buy-box .assure { display: grid; gap: 10px; margin-top: 20px; }
.buy-box .assure div { display: flex; gap: 10px; font-size: 14px; color: var(--ink-2); }
.buy-box .assure .ic { color: var(--emerald); font-weight: 800; }

/* ---------- cart ---------- */
.page-head { padding: 34px 0 10px; }
.page-head h1 { font-family: 'Frank Ruhl Libre', serif; font-weight: 900; font-size: clamp(28px, 4vw, 42px); }
.cart-layout { display: grid; grid-template-columns: 1fr 370px; gap: 30px; align-items: start; padding-bottom: 64px; }
.line { display: flex; gap: 16px; align-items: center; background: var(--glass); border: 1px solid var(--line); border-radius: var(--radius); padding: 17px; margin-bottom: 13px; }
.line .li-icon { width: 56px; height: 56px; border-radius: 14px; background: rgba(255,255,255,.05); border: 1px solid var(--line); display: grid; place-items: center; font-size: 27px; flex: none; }
.line .li-main { flex: 1; min-width: 0; }
.line .li-main h4 { font-size: 17px; font-weight: 700; }
.line .li-main p { color: var(--muted); font-size: 13.5px; }
.qty { display: inline-flex; align-items: center; border: 1px solid var(--line-2); border-radius: 999px; overflow: hidden; }
.qty button { width: 33px; height: 33px; border: 0; background: transparent; cursor: pointer; font-size: 18px; font-weight: 800; color: var(--ink); }
.qty button:hover { background: rgba(78,240,168,.15); color: var(--emerald); }
.qty span { width: 38px; text-align: center; font-weight: 800; font-family: 'Space Mono', monospace; }
.li-price { font-family: 'Space Mono', monospace; font-weight: 700; font-size: 18px; width: 96px; text-align: end; }
.li-remove { background: none; border: 0; color: var(--muted); cursor: pointer; font-size: 13px; padding: 0; }
.li-remove:hover { color: var(--hot); }
.summary { background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); border: 1px solid var(--line-2); border-radius: var(--radius-lg); padding: 26px; position: sticky; top: 92px; }
.summary h3 { font-size: 19px; margin-bottom: 18px; font-weight: 700; }
.sum-row { display: flex; justify-content: space-between; padding: 9px 0; color: var(--ink-2); }
.sum-row span:last-child { font-family: 'Space Mono', monospace; }
.sum-row.total { border-top: 1px solid var(--line); margin-top: 10px; padding-top: 17px; font-size: 21px; font-weight: 800; color: var(--ink); }
.empty { text-align: center; padding: 70px 0; color: var(--muted); }
.empty .big { font-size: 54px; }
.empty h2 { font-family: 'Frank Ruhl Libre', serif; color: var(--ink); margin: 10px 0; }

/* ---------- checkout ---------- */
.stepper { display: flex; gap: 10px; align-items: center; justify-content: center; margin: 10px 0 30px; color: var(--muted); font-family: 'Space Mono', monospace; font-size: 13px; }
.stepper .s { display: inline-flex; align-items: center; gap: 8px; }
.stepper .s .dot { width: 25px; height: 25px; border-radius: 999px; background: var(--glass); border: 1px solid var(--line); display: grid; place-items: center; font-size: 12px; }
.stepper .s.on { color: var(--emerald); }
.stepper .s.on .dot { background: var(--grad-cta); color: #052016; border-color: transparent; }
.stepper .bar { width: 32px; height: 1px; background: var(--line-2); }
.form { display: grid; gap: 15px; }
.field label { display: block; font-weight: 500; font-size: 14px; margin-bottom: 7px; color: var(--ink-2); }
.field input, .field textarea { width: 100%; padding: 14px 16px; border: 1.5px solid var(--line-2); border-radius: 13px; font: inherit; background: rgba(255,255,255,.03); color: var(--ink); transition: border-color .15s; }
.field input::placeholder, .field textarea::placeholder { color: #5d6072; }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--emerald); }
.row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }
.pay-box { background: rgba(78,240,168,.07); border: 1px solid rgba(78,240,168,.25); border-radius: var(--radius); padding: 18px; display: flex; gap: 13px; align-items: center; }
.pay-box .ic { font-size: 24px; }
.pay-box small { color: var(--emerald); }
.success { text-align: center; padding: 56px 20px; }
.success .check { width: 88px; height: 88px; border-radius: 999px; background: var(--grad-cta); color: #052016; font-size: 46px; display: grid; place-items: center; margin: 0 auto 22px; box-shadow: 0 0 50px -10px rgba(78,240,168,.7); }
.success h1 { font-family: 'Frank Ruhl Libre', serif; font-weight: 900; }

/* ---------- toast ---------- */
.toast { position: fixed; inset-block-end: 26px; inset-inline-start: 50%; transform: translate(50%, 150%); background: #11141d; border: 1px solid var(--line-2); color: var(--ink); padding: 13px 22px; border-radius: 999px; font-weight: 700; box-shadow: var(--shadow); z-index: 100; transition: transform .38s var(--ease); display: flex; gap: 9px; align-items: center; }
.toast.show { transform: translate(50%, 0); }
.toast .ic { color: var(--emerald); }

/* ---------- reveal ---------- */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- responsive ---------- */
@media (max-width: 940px) {
  .hero-grid { grid-template-columns: 1fr; gap: 36px; }
  .band-inner { grid-template-columns: 1fr; }
  .agent-wrap { grid-template-columns: 1fr; }
  .cart-layout { grid-template-columns: 1fr; }
  .buy-box, .summary { position: static; }
  .trust-strip { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .nav-links { display: none; }
  .hero { padding: 54px 0 44px; }
  .band { padding: 34px 24px; }
  .row-2 { grid-template-columns: 1fr; }
  .section { padding: 48px 0; }
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track, .chat-card, .bub { animation: none !important; }
  .bub { opacity: 1; transform: none; }
  * { scroll-behavior: auto !important; }
}
