/* ============================================================
   MARKAIGE — site styles (marketing pages). Pairs with markaige.css tokens.
   Shared nav/footer chrome + section layouts used across all pages.
   ============================================================ */

:root { --font-scale: 1; }
body.site { overflow-x: hidden; }
.site { font-size: calc(17px * var(--font-scale)); }

/* ---------------- shared NAV ---------------- */
.snav { position: sticky; top: 0; z-index: 80; backdrop-filter: blur(18px);
  background: color-mix(in oklab, var(--bg) 78%, transparent);
  border-bottom: 1px solid transparent; transition: border-color .3s ease, background .3s ease; }
.snav.scrolled { border-color: var(--line); }
.snav-in { height: 72px; display: flex; align-items: center; gap: 30px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 600; font-size: 20px; letter-spacing: -0.02em; color: var(--ink); }
.logo-mark { width: 30px; height: 30px; flex: none; }
.snav-links { display: flex; gap: 2px; margin-left: 6px; }
.snav-links a { font-size: 15px; color: var(--ink-2); padding: 8px 13px; border-radius: 9px; font-weight: 500; transition: .15s; }
.snav-links a:hover { color: var(--ink); background: var(--panel-2); }
.snav-links a.on { color: var(--ink); }
.snav-cta { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.snav-cta .signin { font-size: 15px; font-weight: 600; color: var(--ink-2); padding: 8px 12px; }
.snav-cta .signin:hover { color: var(--ink); }
.snav-burger { display: none; }

/* ---------------- shared FOOTER ---------------- */
.sfoot { border-top: 1px solid var(--line); padding: 64px 0 40px; margin-top: 40px; }
.sfoot-grid { display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 32px; }
.sfoot h5 { font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 16px; }
.sfoot a { display: block; color: var(--ink-2); font-size: 14.5px; padding: 6px 0; }
.sfoot a:hover { color: var(--ink); }
.sfoot-bottom { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; color: var(--ink-3); font-size: 13.5px; flex-wrap: wrap; gap: 12px; }

/* ---------------- sections ---------------- */
section.block { padding: 92px 0; }
.sec-head { max-width: 660px; margin-bottom: 48px; }
.sec-head.center { margin-left: auto; margin-right: auto; text-align: center; }
.sec-head h2 { font-size: clamp(32px, 3.6vw, 50px); letter-spacing: -0.03em; margin-top: 16px; }
.sec-head p { margin-top: 18px; font-size: 18px; color: var(--ink-2); }

/* page hero band */
.page-hero { padding: 76px 0 30px; }
.page-hero h1 { font-size: clamp(40px, 5vw, 68px); letter-spacing: -0.035em; line-height: 0.98; }
.page-hero h1 .hl { color: var(--accent); }
.page-hero .lede { margin-top: 22px; font-size: clamp(17px, 1.4vw, 20px); color: var(--ink-2); max-width: 52ch; }
.page-hero .actions { margin-top: 30px; display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------------- home hero ---------------- */
.hero { position: relative; padding: 70px 0 40px; }
.hero-grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 56px; align-items: center; }
.hero h1 { font-size: clamp(44px, 5.6vw, 76px); line-height: 0.98; letter-spacing: -0.035em; font-weight: 600; }
.hero h1 .hl { color: var(--accent); }
.hero .lede { margin-top: 24px; font-size: clamp(17px, 1.4vw, 20px); color: var(--ink-2); max-width: 30ch; line-height: 1.5; }
.hero-actions { margin-top: 34px; display: flex; gap: 12px; flex-wrap: wrap; }
.hero-meta { margin-top: 30px; display: flex; gap: 26px; flex-wrap: wrap; }
.hero-meta .m { display: flex; flex-direction: column; gap: 2px; }
.hero-meta .m b { font-family: var(--font-display); font-size: 24px; font-weight: 600; }
.hero-meta .m span { font-size: 13px; color: var(--ink-3); }
.hero-orbit { position: absolute; inset: 0; z-index: -1; pointer-events: none; opacity: .55;
  background: radial-gradient(620px 420px at 78% 30%, var(--accent-soft), transparent 70%); }

/* app preview card */
.preview { position: relative; }
.preview-glow { position: absolute; inset: -8% -6% -14% -6%; z-index: 0; border-radius: 30px;
  background: radial-gradient(60% 60% at 70% 20%, var(--accent-soft), transparent 70%); filter: blur(8px); }
.win { position: relative; z-index: 1; border-radius: 18px; overflow: hidden; border: 1px solid var(--line-2);
  background: var(--elev); box-shadow: var(--shadow-pop); }
.win-bar { height: 42px; display: flex; align-items: center; gap: 8px; padding: 0 14px; border-bottom: 1px solid var(--line); background: var(--panel); }
.win-dots { display: flex; gap: 7px; }
.win-dots i { width: 11px; height: 11px; border-radius: 50%; background: var(--panel-3); }
.win-url { margin: 0 auto; font-family: var(--font-mono); font-size: 12px; color: var(--ink-3); display: flex; align-items: center; gap: 7px; }
.win-body { display: grid; grid-template-columns: 56px 1fr; height: 372px; }
.win-rail { border-right: 1px solid var(--line); padding: 12px 0; display: flex; flex-direction: column; align-items: center; gap: 14px; background: var(--panel); }
.win-rail .r { width: 32px; height: 32px; border-radius: 9px; display: grid; place-items: center; color: var(--ink-3); }
.win-rail .r.on { background: var(--accent-soft); color: var(--accent); }
.win-main { padding: 16px 18px; overflow: hidden; }
.win-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 13px; }
.win-head h4 { font-size: 15px; }
.win-search { height: 30px; border-radius: 8px; border: 1px solid var(--line); background: var(--panel); display: flex; align-items: center; gap: 7px; padding: 0 10px; color: var(--ink-3); font-size: 12.5px; width: 150px; }
.win-cats { display: flex; gap: 7px; margin-bottom: 14px; }
.win-cats .c { font-size: 11.5px; padding: 5px 10px; border-radius: 999px; border: 1px solid var(--line); color: var(--ink-3); background: var(--panel); }
.win-cats .c.on { color: var(--accent-ink); background: var(--accent); border-color: transparent; font-weight: 600; }
.win-tools { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.tcard { border: 1px solid var(--line); border-radius: 12px; padding: 12px; background: var(--panel); }
.tcard .nm { font-size: 13px; font-weight: 600; }
.tcard .ct { font-size: 11px; color: var(--ink-3); margin-top: 1px; }
.tcard .go { margin-top: 12px; font-size: 11px; color: var(--accent); display: flex; align-items: center; gap: 4px; font-weight: 600; }

/* marquee */
.marquee-sec { padding: 30px 0 8px; }
.marquee-label { text-align: center; color: var(--ink-3); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 22px; }
.marquee { overflow: hidden; mask: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.marquee-track { display: flex; gap: 14px; width: max-content; animation: slide 38s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes slide { to { transform: translateX(-50%); } }
.prov { display: flex; align-items: center; gap: 10px; height: 50px; padding: 0 18px; border: 1px solid var(--line); border-radius: 12px; background: var(--panel); white-space: nowrap; }
.prov .pn { font-weight: 600; font-size: 15px; }
.prov .pc { font-size: 11px; color: var(--ink-3); font-family: var(--font-mono); }

/* value props */
.values { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.vcard { padding: 30px; border-radius: var(--radius-lg); border: 1px solid var(--line); background: linear-gradient(180deg, var(--panel), var(--bg-grad)); position: relative; overflow: hidden; }
.vcard .vico { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: var(--accent-soft); color: var(--accent); border: 1px solid var(--accent-line); margin-bottom: 22px; }
.vcard h3 { font-size: 21px; letter-spacing: -0.02em; }
.vcard p { margin-top: 11px; color: var(--ink-2); font-size: 15.5px; }
.vcard.span2 { grid-column: span 2; display: grid; grid-template-columns: 1fr 1fr; gap: 30px; align-items: center; }
.vcard .stat-row { display: flex; gap: 28px; margin-top: 24px; }
.vcard .stat-row .s b { font-family: var(--font-display); font-size: 30px; display: block; }
.vcard .stat-row .s span { font-size: 13px; color: var(--ink-3); }

/* catalog */
.cat-tabs { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin-bottom: 34px; }
.cat-tabs .t { display: inline-flex; align-items: center; gap: 8px; height: 40px; padding: 0 16px; border-radius: 999px; border: 1px solid var(--line); background: var(--panel); color: var(--ink-2); font-size: 14px; font-weight: 600; transition: .15s; cursor: pointer; }
.cat-tabs .t:hover { color: var(--ink); border-color: var(--line-2); }
.cat-tabs .t.on { background: var(--accent); color: var(--accent-ink); border-color: transparent; }
.cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.gcard { padding: 20px; border-radius: var(--radius); border: 1px solid var(--line); background: var(--panel); transition: .18s; cursor: pointer; position: relative; display: block; }
.gcard:hover { transform: translateY(-3px); border-color: var(--line-2); box-shadow: var(--shadow-2); }
.gcard .top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 28px; }
.gcard .nm { font-size: 17px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink); }
.gcard .desc { font-size: 13.5px; color: var(--ink-3); margin-top: 4px; line-height: 1.45; min-height: 38px; }
.gcard .foot { margin-top: 16px; display: flex; align-items: center; justify-content: space-between; }
.gcard .catpill { font-size: 11px; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: .05em; color: var(--ink-3); }

/* how it works */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.step { padding: 28px; border-radius: var(--radius-lg); border: 1px solid var(--line); background: var(--panel); position: relative; }
.step .num { font-family: var(--font-mono); font-size: 13px; color: var(--accent); margin-bottom: 18px; }
.step h3 { font-size: 20px; }
.step p { margin-top: 10px; color: var(--ink-2); font-size: 15px; }
.step .ph { margin-top: 20px; height: 132px; border-radius: 12px; border: 1px solid var(--line); background:
  radial-gradient(120% 100% at 0 0, var(--accent-soft), transparent 60%), var(--bg-grad); overflow: hidden; position: relative; }

/* split feature */
.feat { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.feat + .feat { margin-top: 72px; }
.feat.alt { direction: rtl; }
.feat.alt > * { direction: ltr; }
.feat-list { margin-top: 26px; display: flex; flex-direction: column; gap: 16px; }
.feat-list .fi { display: flex; gap: 14px; }
.feat-list .fi .k { width: 28px; height: 28px; border-radius: 8px; flex: none; display: grid; place-items: center; background: var(--accent-soft); color: var(--accent); }
.feat-list .fi h4 { font-size: 16px; font-family: var(--font-body); font-weight: 600; }
.feat-list .fi p { font-size: 14.5px; color: var(--ink-2); margin-top: 3px; }
.feat-visual { border-radius: var(--radius-lg); border: 1px solid var(--line-2); background: var(--elev); box-shadow: var(--shadow-2); overflow: hidden; min-height: 360px; }

/* pricing */
.price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: start; }
.plan { padding: 30px; border-radius: var(--radius-lg); border: 1px solid var(--line); background: var(--panel); }
.plan.feat-plan { border-color: var(--accent-line); background: linear-gradient(180deg, var(--accent-soft), var(--panel) 40%); box-shadow: var(--shadow-2); }
.plan .pname { font-family: var(--font-mono); font-size: 13px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); }
.plan .pprice { font-family: var(--font-display); font-size: 44px; margin: 14px 0 2px; }
.plan .pprice small { font-size: 15px; color: var(--ink-3); font-family: var(--font-body); }
.plan .psub { font-size: 14px; color: var(--ink-2); min-height: 40px; }
.plan ul { list-style: none; margin: 22px 0 26px; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.plan li { display: flex; gap: 10px; font-size: 14.5px; color: var(--ink-2); }
.plan li i { color: var(--accent); flex: none; margin-top: 1px; }

/* faq */
.faq { max-width: 760px; margin: 0 auto; }
.faq details { border-bottom: 1px solid var(--line); padding: 22px 0; }
.faq summary { font-size: 18px; font-weight: 600; cursor: pointer; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px; color: var(--ink); }
.faq summary::-webkit-details-marker { display: none; }
.faq summary .pm { color: var(--accent); transition: transform .2s; flex: none; }
.faq details[open] summary .pm { transform: rotate(45deg); }
.faq p { margin-top: 14px; color: var(--ink-2); font-size: 15.5px; }

/* cta */
.cta { position: relative; border-radius: 28px; padding: 70px 56px; overflow: hidden; border: 1px solid var(--accent-line);
  background: radial-gradient(120% 160% at 0% 0%, var(--accent-soft), transparent 55%), var(--elev); }
.cta h2 { font-size: clamp(34px, 4vw, 56px); letter-spacing: -0.03em; max-width: 16ch; }
.cta p { margin-top: 18px; color: var(--ink-2); font-size: 18px; max-width: 46ch; }
.cta .actions { margin-top: 34px; display: flex; gap: 12px; flex-wrap: wrap; }

/* reveal */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }

/* ---- catalog page rail + controls ---- */
.cat-layout { display: grid; grid-template-columns: 220px 1fr; align-items: start; gap: 30px; }
.catrail { display: flex; flex-direction: column; gap: 3px; position: sticky; top: 92px; }
.catrail .cr { display: flex; align-items: center; gap: 11px; padding: 10px 13px; border-radius: 10px; color: var(--ink-2); font-size: 14.5px; font-weight: 500; cursor: pointer; transition: .13s; }
.catrail .cr:hover { background: var(--panel); color: var(--ink); }
.catrail .cr.on { background: var(--panel-2); color: var(--ink); }
.catrail .cr .crk { width: 10px; height: 10px; border-radius: 3px; flex: none; }
.catrail .cr .crn { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--ink-4); }
.cat-controls { display: flex; gap: 12px; margin-bottom: 22px; align-items: center; flex-wrap: wrap; }
.site-search { flex: 1; min-width: 220px; height: 44px; border-radius: 12px; border: 1px solid var(--line); background: var(--panel); display: flex; align-items: center; gap: 10px; padding: 0 14px; color: var(--ink-3); }
.site-search input { flex: 1; border: 0; background: transparent; color: var(--ink); outline: none; font-size: 15px; font-family: var(--font-body); }
.seg { display: inline-flex; padding: 4px; border-radius: 12px; background: var(--panel); border: 1px solid var(--line); gap: 3px; }
.seg button { height: 34px; padding: 0 14px; border: 0; background: transparent; color: var(--ink-2); font-size: 13.5px; font-weight: 600; border-radius: 9px; cursor: pointer; font-family: var(--font-body); }
.seg button.on { background: var(--accent); color: var(--accent-ink); }
.cat-grid.cols3 { grid-template-columns: repeat(3, 1fr); }

/* ---- marketing funnel ---- */
.funnel { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.fband { width: 100%; border-radius: 18px; border: 1px solid var(--line); padding: 22px 26px; display: flex; align-items: center; gap: 24px; transition: .18s; position: relative; overflow: hidden;
  background: linear-gradient(100deg, color-mix(in oklab, var(--fc) 12%, var(--panel)), var(--panel) 70%); }
.fband:hover { transform: translateY(-2px); border-color: var(--line-2); box-shadow: var(--shadow-2); }
.fband .fb-stage { flex: none; width: 200px; }
.fband .fb-num { font-family: var(--font-mono); font-size: 12px; color: var(--fc); letter-spacing: .06em; }
.fband .fb-name { font-family: var(--font-display); font-size: 22px; font-weight: 600; letter-spacing: -0.02em; margin-top: 4px; }
.fband .fb-desc { flex: 1; color: var(--ink-2); font-size: 15px; max-width: 42ch; }
.fband .fb-tools { flex: none; display: flex; flex-direction: column; gap: 8px; align-items: flex-end; }
.fband .fb-logos { display: flex; gap: 7px; }
.fband .fb-cats { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); }
@media (max-width: 820px) {
  .fband { flex-direction: column; align-items: flex-start; gap: 14px; }
  .fband .fb-stage { width: auto; }
  .fband .fb-tools { align-items: flex-start; }
}

@media (max-width: 960px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .values, .cat-grid, .steps, .price-grid, .feat, .sfoot-grid { grid-template-columns: 1fr; }
  .vcard.span2 { grid-template-columns: 1fr; }
  .cat-grid { grid-template-columns: 1fr 1fr; }
  .feat.alt { direction: ltr; }
  .snav-links { display: none; }
}
@media (max-width: 560px) { .cat-grid { grid-template-columns: 1fr; } .wrap { padding: 0 20px; } }
