/* APEX CLIPS — component & page styles */

.section-h2 { font-size: clamp(32px, 4.4vw, 58px); }
.section-lead { color: var(--ink-2); font-size: clamp(17px, 1.4vw, 20px); max-width: 640px; margin-top: 18px; line-height: 1.5; }

/* ============ HERO ============ */
.hero { position: relative; min-height: 92vh; display: flex; align-items: center; overflow: hidden; }
.hero-mosaic { position: absolute; inset: -8% -2%; display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; transform: rotate(-4deg) scale(1.12); z-index: 0; }
.hero-col { overflow: hidden; }
.hero-track { display: flex; flex-direction: column; gap: 14px; animation-name: marquee; animation-timing-function: linear; animation-iteration-count: infinite; will-change: transform; }
@keyframes marquee { from { transform: translateY(0); } to { transform: translateY(-50%); } }
.hero-tile { aspect-ratio: 9/14; width: 100%; }
.hero-veil { position: absolute; inset: 0; z-index: 1;
  background:
    linear-gradient(180deg, color-mix(in oklch,var(--bg) 55%,transparent) 0%, color-mix(in oklch,var(--bg) 30%,transparent) 35%, var(--bg) 96%),
    linear-gradient(90deg, var(--bg) 0%, color-mix(in oklch,var(--bg) 50%,transparent) 42%, transparent 75%);
}
.hero-inner { position: relative; z-index: 2; padding: 60px 0; }
.hero-h1 { font-size: clamp(44px, 7.6vw, 116px); max-width: 16ch; text-wrap: balance; }
.hero-em { color: var(--accent); }
.hero-sub { color: var(--ink-2); font-size: clamp(17px, 1.5vw, 22px); max-width: 620px; margin-top: 24px; line-height: 1.5; }
.hero-cta { display: flex; gap: 14px; margin-top: 34px; flex-wrap: wrap; }
.hero-stats { display: flex; align-items: center; gap: 30px; margin-top: 52px; flex-wrap: wrap; }
.hero-stat-div { width: 1px; height: 46px; background: var(--line); }
.hero-scroll { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 2; font-size: 11px; letter-spacing: .24em; color: var(--ink-4); }

/* ============ TRUST STRIP ============ */
.trust-strip { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--bg-2); }
.trust-strip__inner { display: flex; justify-content: space-between; gap: 18px; padding: 22px 28px; flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: 11px; font-weight: 600; font-size: 15px; color: var(--ink); }
.trust-check { width: 22px; height: 22px; border-radius: 50%; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; font-size: 12px; }

/* ============ AUDIENCE SPLIT ============ */
.aud-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.aud-card { display: flex; flex-direction: column; overflow: hidden; }
.aud-thumb { aspect-ratio: 16/10; }
.aud-body { padding: 26px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.aud-tag { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }
.aud-title { font-size: 30px; line-height: 1; }
.aud-text { color: var(--ink-3); font-size: 15.5px; flex: 1; }

/* ============ CATEGORIES ============ */
.cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.cat-card { position: relative; aspect-ratio: 3/4; border-radius: var(--radius-sm); overflow: hidden; display: block; }
.cat-thumb { position: absolute; inset: 0; transition: transform .5s cubic-bezier(.2,.7,.2,1); }
.cat-card:hover .cat-thumb { transform: scale(1.06); }
.cat-overlay { position: absolute; inset: 0; z-index: 2; padding: 16px; display: flex; flex-direction: column; justify-content: space-between; background: linear-gradient(180deg, rgba(0,0,0,.1) 0%, transparent 30%, rgba(0,0,0,.78) 100%); }
.cat-title { font-size: 25px; line-height: .96; }
.cat-blurb { color: var(--ink-2); font-size: 13px; margin-top: 5px; opacity: 0; max-height: 0; transition: opacity .3s, max-height .3s; }
.cat-card:hover .cat-blurb { opacity: 1; max-height: 40px; }

/* ============ HOW IT WORKS ============ */
.how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.how-step { position: relative; padding-top: 22px; border-top: 2px solid var(--line); }
.how-num { font-size: 46px; color: var(--accent); line-height: 1; }
.how-title { font-size: 21px; margin: 14px 0 8px; font-weight: 700; }
.how-text { color: var(--ink-3); font-size: 15px; }

/* ============ RIGHTS BAND ============ */
.rights-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 42px; }
.rights-card { padding: 26px; }
.rights-check { width: 34px; height: 34px; border-radius: 9px; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; font-size: 16px; margin-bottom: 16px; }
.rights-title { font-size: 19px; font-weight: 700; }
.rights-text { color: var(--ink-3); font-size: 14.5px; margin-top: 6px; }

/* ============ CLIP CARD / GRID ============ */
.clip-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.clip-card { display: flex; flex-direction: column; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius-sm); overflow: hidden; transition: border-color .2s, transform .2s; }
.clip-card:hover { border-color: color-mix(in oklch,#fff 18%,transparent); transform: translateY(-3px); }
.clip-thumb { aspect-ratio: 16/10; }
.clip-thumb--v { aspect-ratio: 16/10; }
.clip-dur { position: absolute; left: 10px; bottom: 10px; z-index: 3; }
.clip-or { position: absolute; right: 10px; bottom: 10px; z-index: 3; }
.clip-rights { position: absolute; left: 10px; top: 10px; z-index: 3; }
.clip-meta { padding: 14px 15px 15px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.clip-title { font-size: 15.5px; font-weight: 600; line-height: 1.25; }
.clip-sub { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--ink-3); flex-wrap: wrap; }
.clip-sub .mono { font-size: 11.5px; }
.clip-dot { color: var(--ink-4); }
.clip-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 6px; }
.clip-id { font-size: 11px; color: var(--ink-4); letter-spacing: .06em; }
.clip-req { font-size: 13px; font-weight: 600; color: var(--accent); }

/* ============ FILTER BAR ============ */
.filter-bar { display: flex; gap: 14px; align-items: flex-end; flex-wrap: wrap; }
.filter-search { position: relative; flex: 1 1 260px; min-width: 220px; }
.filter-search-ic { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--ink-3); font-size: 17px; }
.filter-search .input { padding-left: 38px; }
.filter-fields { display: flex; gap: 10px; flex-wrap: wrap; }
.filter-field { display: flex; flex-direction: column; gap: 5px; }
.filter-label { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-4); padding-left: 2px; }
.filter-select { min-width: 150px; }
.filter-bar--compact .filter-label { display: none; }
.filter-bar--compact .filter-field { flex-direction: row; }

/* ============ BESPOKE ============ */
.bespoke { position: relative; overflow: hidden; border-top: 1px solid var(--line); }
.bespoke-bg { position: absolute; inset: 0; border-radius: 0; }
.bespoke-veil { position: absolute; inset: 0; background: linear-gradient(90deg, var(--bg) 8%, color-mix(in oklch,var(--bg) 72%,transparent) 55%, color-mix(in oklch,var(--bg) 40%,transparent) 100%); }
.bespoke-mini { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 32px 36px; flex-wrap: wrap; }

/* ============ TRUST COLUMNS ============ */
.trust-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.trust-col { padding: 38px; }
.trust-col-title { font-size: 30px; max-width: 18ch; }
.trust-list { list-style: none; padding: 0; margin: 26px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.trust-list li { display: flex; align-items: center; gap: 11px; font-size: 15px; color: var(--ink-2); }
.trust-list-mark { width: 22px; height: 22px; min-width: 22px; border-radius: 6px; border: 1px solid var(--line); display: grid; place-items: center; font-size: 11px; color: var(--ink-3); }

/* ============ FINAL CTA ============ */
.final-cta { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.final-card { position: relative; aspect-ratio: 16/9; border-radius: var(--radius); overflow: hidden; display: flex; align-items: flex-end; }
.final-bg { position: absolute; inset: 0; transition: transform .5s; }
.final-card:hover .final-bg { transform: scale(1.05); }
.final-veil { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 20%, rgba(0,0,0,.82) 100%); }
.final-inner { position: relative; z-index: 2; padding: 36px; display: flex; flex-direction: column; gap: 10px; align-items: flex-start; }
.final-tag { font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--accent); }
.final-h { font-size: clamp(34px,4vw,52px); }
.final-text { color: var(--ink-2); font-size: 16px; margin-bottom: 6px; }

/* ============ LIBRARY ============ */
.lib-head-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 32px; flex-wrap: wrap; }
.lib-head-sub { color: var(--ink-3); max-width: 360px; font-size: 15.5px; }
.lib-sticky { position: sticky; top: 71px; z-index: 40; background: color-mix(in oklch,var(--bg) 86%,transparent); backdrop-filter: blur(14px); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 18px 0; }
.lib-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 22px; }
.lib-count { font-size: 13px; color: var(--ink-2); }
.lib-empty { text-align: center; padding: 80px 0; }

/* ============ GATED LIBRARY ============ */
.filter-bar--locked { position: relative; cursor: pointer; }
.filter-bar--locked .input, .filter-bar--locked .select { pointer-events: none; }
.filter-lock { position: absolute; right: 0; top: -4px; font-size: 11px; letter-spacing: .08em; color: var(--accent); display: inline-flex; align-items: center; gap: 6px; }
@media (max-width: 760px) { .filter-lock { position: static; margin-top: 8px; } }

.library-wall { position: relative; }
.library-wall-fade { position: absolute; left: 0; right: 0; bottom: -1px; height: 200px; pointer-events: none; background: linear-gradient(180deg, transparent, var(--bg) 90%); }

.locked-tile { position: relative; display: block; padding: 0; border: 1px solid var(--line); border-radius: var(--radius-sm); overflow: hidden; background: var(--panel); cursor: pointer; transition: border-color .2s, transform .2s; }
.locked-tile:hover { border-color: color-mix(in oklch,#fff 18%,transparent); transform: translateY(-3px); }
.locked-tile-thumb { aspect-ratio: 16/10; width: 100%; }
.locked-tile-cat { position: absolute; left: 10px; top: 10px; z-index: 3; }
.locked-tile-lock { position: absolute; right: 10px; bottom: 10px; z-index: 3; width: 30px; height: 30px; display: grid; place-items: center; border-radius: 8px; font-size: 13px; background: rgba(0,0,0,.55); border: 1px solid var(--line); backdrop-filter: blur(6px); }

.library-gate { position: relative; z-index: 2; margin-top: -36px; text-align: center; padding: 40px 32px; display: flex; flex-direction: column; align-items: center; background: linear-gradient(180deg, var(--accent-soft), transparent 60%), var(--panel); border-color: color-mix(in oklch,var(--accent) 30%,transparent); }
.library-gate-tag { display: inline-flex; align-items: center; gap: 7px; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }
.library-gate-tag .dot { width: 6px; height: 6px; border-radius: 50%; }
.library-gate-h { font-size: clamp(28px,3.4vw,42px); margin-top: 12px; }
.library-gate-p { color: var(--ink-2); max-width: 560px; margin: 12px auto 0; font-size: 15.5px; }
.library-gate-cta { display: flex; gap: 12px; margin-top: 24px; flex-wrap: wrap; justify-content: center; }
.library-gate--compact { margin-top: 18px; padding: 30px 24px; }

/* ============ NEWSLETTER ============ */
.newsletter { margin-top: 26px; max-width: 320px; }
.newsletter-tag { display: inline-flex; align-items: center; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--accent); }
.newsletter-copy { color: var(--ink-3); font-size: 13.5px; line-height: 1.5; margin: 8px 0 12px; }
.newsletter-form { display: flex; gap: 8px; }
.newsletter-form .input { padding: 10px 12px; font-size: 14px; }
.newsletter-form .btn { white-space: nowrap; }
.newsletter-done { color: var(--ok); font-size: 13px; padding: 10px 0; }

/* ============ CLIP DETAIL ============ */
.detail-crumb { font-size: 12px; color: var(--ink-4); margin-bottom: 22px; letter-spacing: .04em; }
.detail-grid { display: grid; grid-template-columns: 1fr 380px; gap: 38px; align-items: start; }
.detail-player { position: relative; }
.detail-thumb { aspect-ratio: 16/9; border-radius: var(--radius); }
.detail-wm { position: absolute; inset: 0; z-index: 4; display: grid; place-items: center; font-family: var(--mono); font-size: 13px; letter-spacing: .3em; color: rgba(255,255,255,.16); white-space: nowrap; overflow: hidden; transform: rotate(-8deg); pointer-events: none; }
.detail-play { position: absolute; inset: 0; z-index: 5; display: grid; place-items: center; }
.detail-play span { width: 78px; height: 78px; border-radius: 50%; background: rgba(0,0,0,.4); border: 1px solid rgba(255,255,255,.55); backdrop-filter: blur(8px); display: grid; place-items: center; transition: transform .2s, background .2s; }
.detail-play span::after { content: ""; width: 0; height: 0; margin-left: 5px; border-left: 20px solid #fff; border-top: 12px solid transparent; border-bottom: 12px solid transparent; }
.detail-player:hover .detail-play span { transform: scale(1.08); background: var(--accent); }
.detail-scrub { position: absolute; left: 18px; right: 18px; bottom: 16px; z-index: 5; height: 4px; border-radius: 4px; background: rgba(255,255,255,.25); }
.detail-scrub-fill { width: 34%; height: 100%; border-radius: 4px; background: var(--accent); }
.detail-player-bar { display: flex; gap: 8px; align-items: center; margin-top: 14px; flex-wrap: wrap; }
.detail-wm-note { font-size: 11px; color: var(--ink-4); }
.detail-section { margin-top: 38px; }
.detail-h { font-size: 13px; text-transform: uppercase; letter-spacing: .12em; color: var(--ink-4); font-family: var(--mono); margin: 0 0 14px; }
.detail-desc { color: var(--ink-2); font-size: 16.5px; line-height: 1.6; max-width: 640px; }
.detail-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.detail-formats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.detail-format { padding: 16px; display: flex; flex-direction: column; gap: 5px; }
.detail-format-f { font-weight: 700; font-size: 15px; }
.detail-format-r { font-size: 12px; color: var(--ink-3); }
.detail-aside { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 92px; }
.detail-buy { padding: 26px; }
.detail-id { font-size: 11px; color: var(--ink-4); letter-spacing: .1em; }
.detail-title { font-size: 30px; line-height: 1.02; margin: 8px 0 10px; }
.detail-locline { display: flex; gap: 9px; align-items: center; font-size: 12.5px; color: var(--ink-3); margin-bottom: 20px; }
.detail-status { display: flex; flex-direction: column; gap: 14px; padding: 18px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.detail-status-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.detail-status-k { font-size: 11px; text-transform: uppercase; letter-spacing: .1em; color: var(--ink-4); }
.detail-buy-note { font-size: 11px; color: var(--ink-4); margin-top: 14px; line-height: 1.5; }
.detail-credit { padding: 18px; display: flex; gap: 14px; align-items: center; }
.detail-credit-av { width: 52px; height: 52px; min-width: 52px; border-radius: 50%; }
.detail-carousel { display: grid; grid-auto-flow: column; grid-auto-columns: minmax(260px, 1fr); gap: 16px; overflow-x: auto; padding-bottom: 14px; scroll-snap-type: x mandatory; }
.detail-carousel-item { scroll-snap-align: start; }

/* ============ FORM HERO ============ */
.form-hero { position: relative; min-height: 56vh; display: flex; align-items: center; overflow: hidden; padding: 70px 0; }
.form-hero-bg { position: absolute; inset: 0; border-radius: 0; }
.form-hero-veil { position: absolute; inset: 0; background: linear-gradient(180deg, color-mix(in oklch,var(--bg) 55%,transparent), color-mix(in oklch,var(--bg) 80%,transparent) 60%, var(--bg) 100%); }
.form-hero-h { font-size: clamp(40px, 6vw, 86px); margin-top: 16px; }
.form-hero-sub { color: var(--ink-2); font-size: clamp(17px,1.5vw,21px); max-width: 620px; margin-top: 20px; line-height: 1.5; }
.form-hero-trust { display: flex; gap: 18px; margin-top: 28px; flex-wrap: wrap; }
.form-hero-trust-i { font-size: 12.5px; color: var(--ok); letter-spacing: .02em; }

/* ============ FORMS / WIZARD ============ */
.form-wrap { max-width: 860px; }
.form-card { padding: 36px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.field--full { grid-column: 1 / -1; }
.field-hint { font-size: 12px; color: var(--ink-4); }
.form-section-h { font-size: 14px; text-transform: uppercase; letter-spacing: .1em; font-family: var(--mono); color: var(--ink-3); margin: 0 0 20px; padding-bottom: 12px; border-bottom: 1px solid var(--line); }
.form-nav { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-top: 30px; padding-top: 24px; border-top: 1px solid var(--line); }
.form-nav-step { font-size: 12px; color: var(--ink-4); }
.form-foot-note { text-align: center; font-size: 12px; color: var(--ink-4); margin-top: 22px; }

.wizard-steps { display: flex; justify-content: space-between; margin-bottom: 26px; gap: 8px; }
.wizard-step { display: flex; align-items: center; gap: 11px; flex: 1; }
.wizard-dot { width: 30px; height: 30px; min-width: 30px; border-radius: 50%; display: grid; place-items: center; font-weight: 700; font-size: 14px; border: 1px solid var(--line); color: var(--ink-3); background: var(--bg-2); transition: .25s; }
.wizard-label { font-weight: 600; font-size: 14px; color: var(--ink-3); white-space: nowrap; }
.wizard-line { flex: 1; height: 1px; background: var(--line); margin: 0 4px; }
.wizard-step[data-state="on"] .wizard-dot { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }
.wizard-step[data-state="on"] .wizard-label { color: var(--ink); }
.wizard-step[data-state="done"] .wizard-dot { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }

.dropzone { border: 1.5px dashed var(--line); border-radius: 12px; padding: 30px; text-align: center; background: var(--bg-2); cursor: pointer; transition: border-color .2s, background .2s; display: flex; flex-direction: column; gap: 8px; align-items: center; }
.dropzone:hover { border-color: var(--accent); background: var(--panel); }
.dropzone-ic { width: 46px; height: 46px; border-radius: 12px; background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; font-size: 22px; }
.dropzone-note { font-size: 11.5px; color: var(--ink-4); }

.form-flag { display: flex; gap: 12px; align-items: flex-start; background: color-mix(in oklch,var(--warn) 10%,transparent); border: 1px solid color-mix(in oklch,var(--warn) 32%,transparent); border-radius: 10px; padding: 14px 16px; font-size: 14px; color: var(--ink-2); }
.form-flag-ic { width: 22px; height: 22px; min-width: 22px; border-radius: 50%; background: var(--warn); color: #000; display: grid; place-items: center; font-weight: 800; font-size: 13px; }

.chip-pick { display: flex; gap: 9px; flex-wrap: wrap; }
.chip { display: inline-flex; align-items: center; gap: 8px; background: var(--bg-2); border: 1px solid var(--line); color: var(--ink-2); padding: 9px 14px; border-radius: 100px; font-size: 14px; font-weight: 600; transition: .15s; }
.chip[data-on="true"] { border-color: var(--accent); color: var(--ink); background: var(--accent-soft); }
.chip-box { width: 16px; height: 16px; border-radius: 4px; background: color-mix(in oklch,#fff 8%,transparent); display: grid; place-items: center; font-size: 10px; }
.chip[data-on="true"] .chip-box { background: var(--accent); color: var(--accent-ink); }

.submit-done { text-align: center; max-width: 640px; padding: 0 20px; }
.submit-done-mark { width: 72px; height: 72px; border-radius: 50%; background: var(--accent-soft); color: var(--accent); border: 1px solid color-mix(in oklch,var(--accent) 45%,transparent); display: grid; place-items: center; font-size: 32px; margin: 0 auto 22px; }

/* ============ LICENSE ============ */
.license-layout { display: grid; grid-template-columns: 1fr 360px; gap: 22px; align-items: start; }
.license-summary { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 92px; }
.license-summary-card { padding: 26px; }
.summary-rows { display: flex; flex-direction: column; margin-top: 18px; }
.summary-row { display: flex; justify-content: space-between; gap: 14px; padding: 11px 0; border-bottom: 1px solid var(--line-soft); }
.summary-k { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-4); }
.summary-v { font-size: 14px; font-weight: 600; text-align: right; color: var(--ink); }
.license-help { padding: 22px; }

/* ============ AUDIENCE PAGES ============ */
.aud-hero { position: relative; min-height: 66vh; display: flex; align-items: center; overflow: hidden; padding: 80px 0; }
.aud-hero-bg { position: absolute; inset: 0; border-radius: 0; }
.aud-hero-veil { position: absolute; inset: 0; background: linear-gradient(120deg, var(--bg) 18%, color-mix(in oklch,var(--bg) 70%,transparent) 60%, color-mix(in oklch,var(--bg) 35%,transparent) 100%); }
.aud-hero-h { font-size: clamp(40px, 6vw, 88px); margin-top: 16px; }
.aud-hero-sub { color: var(--ink-2); font-size: clamp(17px,1.5vw,21px); max-width: 640px; margin-top: 20px; line-height: 1.5; }
.stat-band { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 42px; }
.feature-card { padding: 28px; }
.feature-num { font-size: 13px; color: var(--accent); letter-spacing: .1em; }
.feature-title { font-size: 20px; font-weight: 700; margin: 12px 0 8px; }
.feature-text { color: var(--ink-3); font-size: 15px; }

/* ============ FAQ ============ */
.faq { display: flex; flex-direction: column; }
.faq-item { border-top: 1px solid var(--line); padding: 22px 0; }
.faq-item:last-child { border-bottom: 1px solid var(--line); }
.faq-q { display: flex; align-items: center; justify-content: space-between; gap: 18px; font-size: 19px; font-weight: 600; width: 100%; padding: 0; background: transparent; border: 0; color: inherit; font-family: inherit; text-align: left; cursor: pointer; }
.faq-mark { color: var(--accent); font-size: 24px; line-height: 1; }
.faq-a-wrap { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .3s ease; }
.faq-item[data-open="true"] .faq-a-wrap { grid-template-rows: 1fr; }
.faq-a { overflow: hidden; color: var(--ink-3); font-size: 16px; line-height: 1.6; max-width: 720px; }
.faq-item[data-open="true"] .faq-a { padding-top: 14px; }

/* ============ CHAIN (rights) ============ */
.chain { margin-top: 44px; max-width: 760px; }
.chain-step { display: flex; gap: 24px; }
.chain-rail { display: flex; flex-direction: column; align-items: center; }
.chain-node { width: 52px; height: 52px; min-width: 52px; border-radius: 50%; border: 1px solid var(--accent); background: var(--accent-soft); color: var(--accent); display: grid; place-items: center; font-family: var(--display); font-size: 20px; font-weight: 800; }
.chain-line { width: 1px; flex: 1; background: var(--line); min-height: 28px; }
.chain-body { padding-bottom: 34px; padding-top: 8px; }
.chain-title { font-size: 22px; font-weight: 700; }
.chain-text { color: var(--ink-3); font-size: 15.5px; margin-top: 6px; max-width: 520px; }

/* ============ LEGEND ============ */
.legend-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-top: 42px; }
.legend-card { padding: 24px; display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.legend-text { color: var(--ink-3); font-size: 15.5px; }

/* ============ PRICING ============ */
.price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: stretch; }
.price-card { padding: 32px; display: flex; flex-direction: column; position: relative; }
.price-card--hi { border-color: var(--accent); background: linear-gradient(180deg, var(--accent-soft), transparent 40%), var(--panel); }
.price-flag { position: absolute; top: -10px; left: 32px; background: var(--accent); color: var(--accent-ink); font-size: 10px; letter-spacing: .12em; padding: 4px 10px; border-radius: 100px; }
.price-name { font-size: 24px; }
.price-amount { font-size: 48px; margin-top: 10px; line-height: 1; }
.price-unit { font-size: 12px; color: var(--ink-4); margin-top: 6px; letter-spacing: .04em; }
.price-feat { list-style: none; padding: 0; margin: 26px 0; display: flex; flex-direction: column; gap: 12px; }
.price-feat li { display: flex; gap: 10px; align-items: flex-start; font-size: 14.5px; color: var(--ink-2); }
.price-check { color: var(--accent); font-weight: 800; }

/* ============ ABOUT ============ */
.about-mosaic { opacity: .5; }
.about-mission { display: grid; grid-template-columns: 1fr 1.3fr; gap: 48px; align-items: start; }
.about-mission-text { display: flex; flex-direction: column; gap: 18px; }
.about-mission-text p { color: var(--ink-2); font-size: 17.5px; line-height: 1.6; margin: 0; }

/* ============ CONTACT ============ */
.contact-layout { display: grid; grid-template-columns: 1.4fr 1fr; gap: 22px; align-items: start; }
.contact-card { padding: 24px; }
.contact-card-h { font-size: 18px; font-weight: 700; margin: 0 0 6px; }
.contact-card-b { color: var(--ink-3); font-size: 14.5px; margin: 0 0 14px; }

/* ============ RESPONSIVE ============ */
@media (max-width: 1080px) {
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .clip-grid { grid-template-columns: repeat(3, 1fr); }
  .how-grid { grid-template-columns: repeat(2, 1fr); }
  .rights-grid, .feature-grid, .price-grid { grid-template-columns: repeat(2, 1fr); }
  .aud-grid { grid-template-columns: 1fr; }
  .detail-grid { grid-template-columns: 1fr; }
  .detail-aside { position: static; flex-direction: row; flex-wrap: wrap; }
  .detail-buy, .detail-credit { flex: 1 1 300px; }
  .license-layout { grid-template-columns: 1fr; }
  .license-summary { position: static; }
  .about-mission { grid-template-columns: 1fr; gap: 22px; }
  .contact-layout { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .nav-desktop { display: none !important; }
  .nav-burger { display: block !important; }
  .nav-cta { display: none !important; }
  .hero-mosaic { grid-template-columns: repeat(3, 1fr); }
  .clip-grid { grid-template-columns: repeat(2, 1fr); }
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .how-grid, .rights-grid, .feature-grid, .price-grid, .legend-grid { grid-template-columns: 1fr; }
  .trust-cols, .final-cta { grid-template-columns: 1fr; }
  .trust-list { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr !important; }
  .detail-formats { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .wizard-label { display: none; }
  .form-card { padding: 22px; }
  .hero-stats { gap: 18px; }
  .hero-stat-div { display: none; }
}
@media (max-width: 480px) {
  .clip-grid, .cat-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr !important; }
}
