:root {
  --ink: oklch(27% 0.045 267);
  --muted: oklch(50% 0.035 267);
  --paper: oklch(97% 0.012 250);
  --panel: oklch(99% 0.006 250);
  --mist: oklch(94% 0.024 248);
  --line: oklch(86% 0.028 260);
  --blue: oklch(62% 0.15 254);
  --violet: oklch(62% 0.14 298);
  --coral: oklch(69% 0.14 35);
  --success: oklch(66% 0.12 160);
  --shadow: 0 18px 42px rgb(43 61 130 / 11%);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif; }
button, input, select { font: inherit; }
button { color: inherit; }
header, main, footer { max-width: 1180px; margin-inline: auto; }

header { display: flex; align-items: center; gap: 38px; min-height: 76px; padding: 0 4px; }
.brand { display: inline-flex; align-items: center; gap: 7px; color: var(--ink); font-size: 20px; font-weight: 850; letter-spacing: -1px; text-decoration: none; }
.brand img { width: 30px; height: 30px; object-fit: contain; }
.brand span { color: var(--ink); }
.brand em { color: var(--violet); font-style: normal; font-weight: 650; }
nav { display: flex; gap: 22px; }
nav a { color: var(--muted); font-size: 13px; font-weight: 700; text-decoration: none; }
nav a:hover { color: var(--blue); }
.privacy { display: flex; align-items: center; gap: 8px; margin-left: auto; color: var(--muted); font-size: 12px; font-weight: 650; }
.privacy b { width: 8px; height: 8px; border-radius: 50%; background: var(--success); }

.hero { display: none; }
.dashboard-hero { position: relative; display: grid; grid-template-columns: minmax(0, .88fr) minmax(460px, 1.12fr); gap: 48px; align-items: center; min-height: 510px; padding: 64px 62px 64px 70px; overflow: hidden; border: 1px solid var(--line); border-radius: 30px; background: radial-gradient(circle at 4% 10%, oklch(92% .055 250), transparent 28%), radial-gradient(circle at 98% 98%, oklch(92% .055 310), transparent 34%), var(--panel); }
.dashboard-copy { position: relative; z-index: 1; max-width: 460px; }
.eyebrow, .section-label p { margin: 0 0 12px; color: var(--violet); font-size: 11px; font-weight: 850; letter-spacing: .13em; text-transform: uppercase; }
.dashboard-copy h1 { max-width: 420px; margin: 0; font-size: 54px; font-weight: 850; letter-spacing: -3.1px; line-height: .98; }
.dashboard-copy > p:not(.eyebrow) { margin: 23px 0 0; color: var(--muted); font-size: 16px; line-height: 1.65; }
.trust-notes { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 30px; }
.trust-notes span { padding: 7px 10px; border-radius: 999px; background: oklch(95% .03 250); color: oklch(42% .07 255); font-size: 11px; font-weight: 750; }
.tool-dashboard { position: relative; z-index: 1; padding: 18px; border: 1px solid oklch(83% .035 260); border-radius: 22px; background: oklch(99% .008 250 / 94%); box-shadow: var(--shadow); }
.dashboard-top { display: flex; align-items: center; justify-content: space-between; padding: 5px 5px 16px; }
.dashboard-top p { margin: 0 0 4px; color: var(--muted); font-size: 11px; font-weight: 750; text-transform: uppercase; letter-spacing: .09em; }
.dashboard-top strong { font-size: 16px; letter-spacing: -.35px; }
.ready-dot { display: inline-flex; align-items: center; gap: 6px; color: oklch(45% .09 160); font-size: 11px; font-weight: 750; }
.ready-dot::before { width: 7px; height: 7px; border-radius: 50%; background: var(--success); content: ""; }
.hero-search { display: flex; align-items: center; gap: 8px; padding: 7px 8px 7px 14px; border: 1px solid var(--line); border-radius: 13px; background: var(--panel); }
.hero-search > span { color: var(--blue); font-size: 23px; line-height: 1; }
.hero-search input { min-width: 0; flex: 1; height: 39px; border: 0; outline: 0; background: transparent; color: var(--ink); font-size: 13px; }
.hero-search button { min-height: 39px; padding: 0 14px; border: 0; border-radius: 9px; background: var(--blue); color: oklch(99% .005 250); cursor: pointer; font-size: 12px; font-weight: 800; }
.hero-search button:hover { background: oklch(52% .15 254); }
.launch-list { display: grid; gap: 7px; margin-top: 12px; }
.launch-list a { display: grid; grid-template-columns: 35px 1fr 20px; gap: 12px; align-items: center; min-height: 59px; padding: 8px; border-radius: 12px; color: var(--ink); text-decoration: none; transition: background 170ms ease-out, transform 170ms ease-out; }
.launch-list a:hover { background: var(--mist); transform: translateX(3px); }
.launch-icon { display: grid; width: 35px; height: 35px; place-items: center; border-radius: 10px; font-size: 10px; font-weight: 850; }
.image-icon { background: oklch(91% .07 250); color: oklch(42% .13 254); }.pdf-icon { background: oklch(93% .07 300); color: oklch(43% .12 300); }.file-icon { background: oklch(94% .06 40); color: oklch(50% .13 35); }.video-icon { background: oklch(92% .05 165); color: oklch(43% .1 160); }
.launch-list b, .launch-list small { display: block; }.launch-list b { font-size: 13px; }.launch-list small { margin-top: 3px; color: var(--muted); font-size: 11px; }.launch-list i { color: var(--blue); font-size: 18px; font-style: normal; }
.kite-thread, .kite-dot { position: absolute; pointer-events: none; }.kite-thread { width: 210px; height: 210px; border: 1px solid oklch(79% .06 300); border-radius: 45% 55% 55% 45%; }.thread-one { top: -116px; right: 400px; transform: rotate(24deg); }.thread-two { bottom: -145px; left: 24px; border-color: oklch(82% .06 35); transform: rotate(-25deg); }.kite-dot { width: 12px; height: 12px; border-radius: 2px 12px 2px 12px; }.dot-one { top: 69px; right: 38px; background: var(--coral); transform: rotate(25deg); }.dot-two { bottom: 58px; left: 44%; background: var(--violet); transform: rotate(27deg); }

.catalogue { display: grid; grid-template-columns: 220px 1fr; gap: 42px; padding: 78px 0 22px; }
.section-label h2 { max-width: 200px; margin: 0; font-size: 28px; letter-spacing: -1.45px; line-height: 1.04; }
.tool-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 11px; }
.tool-card { min-height: 142px; padding: 19px; border: 1px solid var(--line); border-radius: 15px; background: var(--panel); cursor: pointer; text-align: left; transition: border-color 170ms ease-out, transform 170ms ease-out, box-shadow 170ms ease-out; }
.tool-card:hover { border-color: oklch(70% .09 260); transform: translateY(-2px); box-shadow: 0 11px 23px rgb(43 61 130 / 9%); }
.tool-card.selected { border-color: var(--blue); background: oklch(96% .025 250); box-shadow: 0 10px 20px rgb(43 91 185 / 13%); }
.glyph { display: grid; width: 39px; height: 39px; place-items: center; margin-bottom: 24px; border-radius: 11px; background: oklch(94% .045 250); color: var(--blue); font-size: 20px; }
.tool-card strong, .tool-card small { display: block; }.tool-card strong { font-size: 13px; letter-spacing: -.15px; }.tool-card small { margin-top: 4px; color: var(--muted); font-size: 11px; }

.workbench, .pdf-work { border: 1px solid var(--line); border-radius: 20px; background: var(--panel); box-shadow: var(--shadow); }
.panel { display: none; grid-template-columns: .87fr 1.13fr; gap: 60px; padding: 44px; }.panel.active { display: grid; }.panel-copy { max-width: 345px; }
.panel h2, .pdf-work h2 { margin: 0; font-size: 35px; letter-spacing: -1.8px; line-height: 1.04; }.panel-copy > p:last-child, .pdf-work > div > p:last-child { color: var(--muted); font-size: 14px; line-height: 1.6; }
.tool-form { max-width: 460px; }.file-drop { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 116px; border: 1.5px dashed oklch(70% .085 260); border-radius: 14px; background: oklch(98% .012 250); cursor: pointer; text-align: center; transition: background 170ms ease-out, border-color 170ms ease-out; }.file-drop:hover, .file-drop:focus-within { border-color: var(--blue); background: var(--mist); }.file-drop input { display: none; }.file-drop b { font-size: 14px; }.file-drop span, .status, small { margin-top: 4px; color: var(--muted); font-size: 12px; }
label { display: grid; gap: 7px; margin-top: 17px; color: var(--muted); font-size: 12px; font-weight: 650; }.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 11px; margin-top: 17px; }input, select { width: 100%; height: 40px; padding: 7px 9px; border: 1px solid var(--line); border-radius: 8px; background: var(--panel); color: var(--ink); }.check { display: flex; align-items: center; gap: 8px; }.check input { width: auto; height: auto; }
.primary { display: flex; align-items: center; justify-content: space-between; width: 100%; min-height: 47px; margin-top: 21px; padding: 0 15px; border: 0; border-radius: 10px; background: var(--blue); color: oklch(99% .006 250); cursor: pointer; font-size: 13px; font-weight: 800; text-align: left; }.primary:hover:not(:disabled) { background: oklch(52% .15 254); }.primary:disabled { cursor: not-allowed; opacity: .48; }
.status { min-height: 20px; margin: 14px 0 0; color: var(--muted); }.status a { color: var(--blue); font-weight: 800; }.mini-list { display: grid; gap: 5px; padding: 0; margin: 12px 0 0; list-style: none; }.mini-list li { display: flex; align-items: center; justify-content: space-between; padding: 9px 10px; border-radius: 8px; background: var(--mist); font-size: 12px; }.mini-list li.dragging { opacity: .55; }.mini-list li[draggable="true"] { cursor: grab; }.mini-list button { border: 0; background: transparent; color: var(--violet); cursor: pointer; font-size: 17px; }

.pdf-section { margin-top: 100px; }.pdf-grid .tool-card { min-height: 132px; }.pdf-work { display: grid; grid-template-columns: .87fr 1.13fr; gap: 60px; padding: 44px; }.file-work { margin-top: 40px; }.ad-space { display: none; }
.documents { display: grid; grid-template-columns: .8fr 1.2fr; gap: 56px; margin-top: 48px; padding: 52px; border-radius: 24px; background: oklch(30% .06 270); color: oklch(97% .012 250); }.documents .eyebrow { color: oklch(82% .08 290); }.documents h2, .faq h2, .video-preview h2 { margin: 0; font-size: 38px; letter-spacing: -2px; line-height: 1.04; }.document-list { display: grid; gap: 10px; }.document-list article { padding: 18px; border: 1px solid rgb(220 229 255 / 18%); border-radius: 12px; background: rgb(255 255 255 / 6%); }.document-list b { font-size: 14px; }.document-list p, .roadmap { margin: 6px 0 0; color: oklch(79% .025 270); font-size: 13px; line-height: 1.5; }.roadmap { grid-column: 2; }
.video-preview { display: grid; grid-template-columns: 1fr .9fr; gap: 54px; align-items: center; margin: 40px 0 0; padding: 44px 52px; border: 1px solid var(--line); border-radius: 24px; background: oklch(96% .023 285); }.video-preview > div > p:last-child { max-width: 550px; color: var(--muted); line-height: 1.6; }.video-preview ul { display: grid; gap: 10px; padding: 0; margin: 0; list-style: none; }.video-preview li { padding: 12px 0; border-bottom: 1px solid oklch(84% .04 285); font-size: 14px; font-weight: 750; }.video-preview li:last-child { border-bottom: 0; }.video-preview li span { display: inline-block; min-width: 34px; color: var(--violet); font-size: 11px; letter-spacing: .08em; }
.faq { max-width: 760px; padding: 80px 0; }.faq h2 { margin-bottom: 25px; }.faq details { padding: 18px 0; border-top: 1px solid var(--line); }.faq details:last-child { border-bottom: 1px solid var(--line); }.faq summary { cursor: pointer; font-size: 14px; font-weight: 800; }.faq details p { margin: 12px 0 0; color: var(--muted); font-size: 14px; line-height: 1.55; }
footer { display: flex; justify-content: space-between; padding: 24px 4px; border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; }

.sticky-ad { position: fixed; bottom: 18px; left: 50%; z-index: 20; width: min(520px, calc(100vw - 32px)); padding: 9px 12px 10px; transform: translateX(-50%); border: 1px solid var(--line); border-radius: 13px; background: var(--panel); box-shadow: 0 18px 45px rgb(43 61 130 / 18%); }.sticky-ad[hidden] { display: none; }.sticky-ad > span { display: block; margin: 0 0 6px 3px; color: var(--muted); font-size: 9px; font-weight: 750; letter-spacing: .11em; text-transform: uppercase; }.ad-placeholder { display: grid; min-height: 38px; place-items: center; border-radius: 8px; background: var(--mist); color: var(--muted); font-size: 11px; }.sticky-ad button { position: absolute; top: 2px; right: 7px; border: 0; background: transparent; color: var(--muted); cursor: pointer; font-size: 19px; }
.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; }
button:focus-visible, input:focus-visible, select:focus-visible, summary:focus-visible, a:focus-visible { outline: 3px solid oklch(70% .12 250); outline-offset: 3px; }

@media (max-width: 840px) { header, main, footer { margin-inline: 18px; } .dashboard-hero { grid-template-columns: 1fr; gap: 34px; min-height: 0; padding: 52px 34px; } .dashboard-copy { max-width: 580px; }.catalogue { grid-template-columns: 1fr; gap: 24px; }.section-label h2 { max-width: none; }.panel.active, .pdf-work, .documents, .video-preview { grid-template-columns: 1fr; gap: 32px; }.roadmap { grid-column: auto; } }
@media (max-width: 600px) { header { min-height: 65px; gap: 13px; }.brand { font-size: 17px; }.brand img { width: 26px; height: 26px; }nav { margin-left: auto; gap: 12px; }nav a { font-size: 11px; }.privacy { display: none; }.dashboard-hero { margin-inline: -18px; padding: 38px 20px; border-inline: 0; border-radius: 0; }.dashboard-copy h1 { font-size: 42px; letter-spacing: -2.3px; }.tool-dashboard { padding: 13px; border-radius: 16px; }.hero-search button { padding-inline: 11px; }.launch-list a { grid-template-columns: 34px 1fr 17px; gap: 10px; }.launch-list small { line-height: 1.35; }.catalogue { padding-top: 58px; }.tool-grid { grid-template-columns: 1fr 1fr; gap: 8px; }.tool-card { min-height: 122px; padding: 14px; }.glyph { margin-bottom: 18px; }.panel, .pdf-work, .documents, .video-preview { padding: 25px; border-radius: 18px; }.panel h2, .pdf-work h2, .documents h2, .faq h2, .video-preview h2 { font-size: 31px; letter-spacing: -1.5px; }.pdf-section { margin-top: 68px; }.pdf-grid .tool-card { min-height: 118px; }.form-row { grid-template-columns: 1fr; }.faq { padding: 58px 0; }footer { gap: 8px; font-size: 10px; }.sticky-ad { bottom: 12px; } }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; } }
