/* ════════════════════════════════════════════════════════════════════
   APTLY — EDITORIAL RESTYLE
   "resume being graded by a sharp editor" · marked-up paper, red-pen edits
   Type: Newsreader (serif) · Hanken Grotesk (sans) · JetBrains Mono · Caveat
   Theme: DARK ACADEMIA = default · EDITORIAL PAPER = light toggle
   ════════════════════════════════════════════════════════════════════ */

/* ── CSS VARIABLES — DARK ACADEMIA (default) ─────────────────────── */
:root {
  --bg:            #16130d;
  --surface:       #1e1a12;
  --surface-2:     #221d15;
  --border:        #322c20;
  --border-soft:   rgba(236,226,205,0.07);
  --text:          #ece2cd;
  --ink-2:         #c7bda4;
  --sub:           #8c8369;
  --muted:         #6b6450;
  --accent:        #e07158;   /* ember red — the red pen */
  --accent-strong: #c2583f;   /* deeper ember for solid fills */
  --accent-vivid:  #e07158;
  --accent-soft:   rgba(224,113,88,0.12);
  --good:          #9bb072;   /* sage — the good mark */
  --good-soft:     rgba(155,176,114,0.12);
  --shadow:        0 30px 70px -34px rgba(0,0,0,0.72);
  --shadow-sm:     0 2px 10px rgba(0,0,0,0.32);
  --radius-xl:     8px;
  --radius-lg:     6px;
  --radius-md:     5px;
  --serif:  'Newsreader', Georgia, 'Times New Roman', serif;
  --sans:   'Hanken Grotesk', system-ui, sans-serif;
  --mono:   'JetBrains Mono', ui-monospace, monospace;
  --hand:   'Caveat', cursive;
}

/* ── EDITORIAL PAPER (light toggle) ──────────────────────────────── */
body.theme-light {
  --bg:            #f4f0e7;
  --surface:       #fffdf8;
  --surface-2:     #fbf7ee;
  --border:        #ddd6c8;
  --border-soft:   #e4dccd;
  --text:          #1c1a16;
  --ink-2:         #48412f;
  --sub:           #6b6256;
  --muted:         #9a907d;
  --accent:        #b23a2e;
  --accent-strong: #9a2f25;
  --accent-vivid:  #b23a2e;
  --accent-soft:   rgba(178,58,46,0.08);
  --good:          #3f6b3a;
  --good-soft:     rgba(63,107,58,0.10);
  --shadow:        0 30px 70px -30px rgba(60,42,18,0.30);
  --shadow-sm:     0 2px 10px rgba(60,42,18,0.10);
}

/* ── RESETS ─────────────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100vh;font-family:var(--sans);font-size:14px;background:var(--bg);color:var(--ink-2);-webkit-font-smoothing:antialiased}
.serif{font-family:var(--serif)}
.mono{font-family:var(--mono)}
.hand{font-family:var(--hand);font-weight:600}

/* ── ANIMATIONS (slop removed: orbs, glow flash, pulse-glow) ────── */
@keyframes spin      {to{transform:rotate(360deg)}}
@keyframes fadein    {from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes rise-in   {from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
@keyframes appEntrance{0%{opacity:0.55;transform:translateY(8px)}100%{opacity:1;transform:none}}

/* Resume entry cards (Upload + Paste): on hover a soft highlight sweeps ONCE
/* Resume entry cards (Upload + Paste): on hover a soft light travels ONCE around
   the border, then fades out. No held ring — just the moving light. Overlay via a
   masked conic-gradient so it never disturbs layout or the card's own states. */
@property --ubd-angle{syntax:"<angle>";initial-value:0deg;inherits:false}
@keyframes ubd-spin{
  0%  {--ubd-angle:0deg;  opacity:0}
  12% {opacity:1}
  82% {opacity:1}
  100%{--ubd-angle:360deg;opacity:0}
}
.upload-shimmer{position:relative}
/* one-time travelling light — plays once on hover then fades (no held ring, no frozen dot) */
.upload-shimmer::after{
  content:"";position:absolute;inset:0;border-radius:inherit;padding:1.5px;
  background:conic-gradient(from var(--ubd-angle),transparent 0deg,transparent 250deg,#e07158 298deg,#ffd9cc 320deg,#e07158 342deg,transparent 360deg);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;
  mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;
  opacity:0;pointer-events:none;
}
.upload-shimmer:hover::after{animation:ubd-spin 1.2s ease-out}
@media (prefers-reduced-motion:reduce){
  .upload-shimmer:hover::after{animation:none}
  .upload-shimmer::after{display:none}
}

.app-flash{animation:appEntrance 0.4s cubic-bezier(0.2,0.8,0.3,1) forwards;}
.app-scroll-glow{animation:fadein 0.4s ease;}
.fadein{animation:fadein .18s ease}

/* ── SCROLLBAR ───────────────────────────────────────────────────── */
::-webkit-scrollbar{width:9px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:0}
::-webkit-scrollbar-track{background:transparent}

/* ── FORM FOCUS — hairline ember, no glow halo ──────────────────── */
textarea:focus,input:focus,select:focus{outline:none;border-color:var(--accent)!important;box-shadow:0 0 0 1px var(--accent)!important}
button:active{transform:translateY(1px)}
::selection{background:var(--accent-soft);color:var(--text)}

/* ── UTILITY ─────────────────────────────────────────────────────── */
.spin{display:inline-block;width:13px;height:13px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;vertical-align:middle;margin-right:6px;flex-shrink:0}
.no-print{display:block}
.ta-hidden{display:none!important}
.diff-highlight{background:var(--accent-soft);color:inherit;border-radius:0;padding:0 2px;font-weight:600;box-shadow:inset 0 -2px 0 var(--accent)}

/* ── EDITORIAL CARD (replaces glassmorphism gradient border) ─────── */
.ap-glass{position:relative;overflow:hidden;border:1px solid var(--border);}
.ap-glass::before{content:none;}

/* ── COVER LETTER PREVIEW (print-safe, editorial serif) ──────────── */
.cov-preview-wrap{background:#fffdf8;color:#1c1a16;font-family:var(--sans);font-size:10.5pt;padding:36px 44px;max-width:800px;margin:0 auto;line-height:1.75}
.cov-preview-name{font-family:var(--serif);font-size:22pt;font-weight:600;color:#1c1a16;letter-spacing:0;text-transform:none;text-align:center;margin-bottom:3px}
.cov-preview-contact{font-family:var(--mono);font-size:8.5pt;color:#6b6256;display:flex;justify-content:center;flex-wrap:wrap;gap:6px 10px;margin-bottom:6px;letter-spacing:.02em}
.cov-preview-sep{color:#cfc6b4;margin:0 2px}
.cov-preview-rule{border:none;border-top:1px solid #cfc6b4;margin:8px 0 48px}
.cov-preview-meta{margin-bottom:40px}
.cov-preview-date{font-family:var(--mono);font-size:9pt;color:#6b6256;margin-bottom:8px}
.cov-preview-re{font-size:10pt;font-weight:600;color:#1c1a16}
.cov-preview-body .cov-p{margin-bottom:14px;font-size:10.5pt;line-height:1.75;color:#1c1a16;text-align:justify}
.cov-preview-body .cov-p:last-child{margin-bottom:0}
.cov-preview-sig{margin-top:36px}
.cov-preview-closing{font-size:10.5pt;color:#1c1a16;margin-bottom:28px}
.cov-preview-signame{font-family:var(--hand);font-size:30pt;color:#b23a2e;font-weight:600;line-height:1}
@media print{.cov-preview-signame{font-family:var(--hand)}}

/* ── PDF / PRINT STYLES (its own light identity — editorial, readable) ─ */
.pdf-wrap{background:#fffdf8;color:#211d16;font-family:var(--sans);font-size:10pt;font-weight:400;padding:32px 40px;max-width:800px;margin:0 auto;line-height:1.6}
.pdf-wrap *{color:inherit}
.pdf-name{font-family:var(--serif);font-size:23pt;font-weight:600;color:#1c1a16;letter-spacing:0;text-transform:none;text-align:center;margin-bottom:3px}
.pdf-tagline{font-family:var(--mono);font-size:9.5pt;color:#b23a2e;font-weight:500;text-align:center;margin-bottom:6px;letter-spacing:.04em}
.pdf-contact{font-family:var(--mono);font-size:8.5pt;color:#6b6256;font-weight:400;display:flex;justify-content:center;flex-wrap:wrap;gap:6px 12px;margin-bottom:6px;letter-spacing:.02em}
.pdf-divider{border:none;border-top:1px solid #cfc6b4;margin:8px 0 10px}
.pdf-sec-title{font-family:var(--mono);font-size:9.5pt;font-weight:600;color:#1c1a16;text-transform:uppercase;letter-spacing:.12em;border-bottom:1px solid #cfc6b4;padding-bottom:3px;margin-top:14px;margin-bottom:6px;text-align:left}
.pdf-exp-block{margin-bottom:10px;padding-bottom:8px;font-weight:400}
.pdf-exp-block:last-child{margin-bottom:0;padding-bottom:0}
.pdf-exp-title{font-size:10.5pt;font-weight:700;color:#1c1a16;margin-bottom:1px}
.pdf-exp-meta-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:3px}
.pdf-exp-company{font-size:9pt;color:#6b6256;font-weight:500}
.pdf-exp-date{font-family:var(--mono);font-size:8.5pt;color:#b23a2e;font-weight:500;white-space:nowrap;flex-shrink:0;letter-spacing:.02em}
.pdf-bullet{display:flex;gap:6px;margin-bottom:1px;font-size:9.5pt;position:relative}
.pdf-bullet-dot{color:#b23a2e;flex-shrink:0;font-weight:400}
.pdf-bullet-text{color:#39342a;line-height:1.5;font-weight:400}
.pdf-text-line{font-size:10pt;margin-bottom:3px;color:#39342a;line-height:1.5;font-weight:400}
.pdf-bullet-text strong,.pdf-text-line strong{font-weight:700;color:#b23a2e}
/* ── Inline bullet feedback flags ── */
.ap-bullet-flag{display:inline-flex;align-items:center;justify-content:center;
  width:13px;height:13px;border-radius:50%;font-size:7.5pt;font-weight:700;
  flex-shrink:0;margin-left:4px;cursor:help;line-height:1;
  vertical-align:middle;position:relative;top:-1px;font-family:var(--mono)}
.ap-bullet-flag-warn{background:rgba(199,154,82,0.16);color:#a87f33;border:1px solid rgba(199,154,82,0.4)}
.ap-bullet-flag-error{background:rgba(178,58,46,0.12);color:#b23a2e;border:1px solid rgba(178,58,46,0.32)}
/* Tooltip for bullet flags */
.ap-bullet-flag[data-tip]:hover::after{
  content:attr(data-tip);
  position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  width:max-content;min-width:160px;max-width:260px;
  background:#221d15;color:#ece2cd;font-size:11px;font-weight:500;font-family:var(--sans);
  padding:6px 10px;border-radius:6px;
  white-space:normal;word-break:break-word;line-height:1.5;
  border:1px solid #41392a;
  box-shadow:0 4px 16px rgba(0,0,0,0.45);
  z-index:9999;pointer-events:none;}
@media print{.ap-bullet-flag{display:none!important}}
.pdf-grid-flex{display:flex;flex-wrap:wrap;width:100%;margin-top:2px;justify-content:center;text-align:center}
.pdf-grid-flex-item{font-size:9pt;color:#2b271f;font-weight:400;padding:1px 8px;line-height:1.6}
.pdf-grid-flex-item.full{flex:0 0 100%;text-align:center}
.pdf-grid-flex-item.half{flex:0 0 50%}
.pdf-compact .pdf-wrap{font-size:9.5pt;padding:24px 32px}
.pdf-compact .pdf-exp-block{margin-bottom:10px;padding-bottom:8px}
.pdf-compact .pdf-sec-title{margin-top:12px;margin-bottom:6px}
.pdf-modern .pdf-name{font-family:var(--sans);color:#1c1a16;font-weight:700}
.pdf-modern .pdf-sec-title{color:#48412f;border-bottom-color:#cfc6b4}
.pdf-classic .pdf-wrap{font-family:var(--serif)}
.pdf-classic .pdf-name{font-family:var(--serif)}
.pdf-classic .pdf-sec-title{border-bottom:1px solid #cfc6b4;letter-spacing:.08em}
#print-area{position:absolute;left:-9999px;top:0;width:800px}
@page{size:letter;margin:0}
@media print{
  html,body{min-height:0!important;height:auto!important;margin:0!important;padding:0!important;}
  body{background:white!important;color:black!important;
    -webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;}
  #print-area{padding:0.5in!important;}
  body>*:not(#print-area),.no-print,button,#app{display:none!important}
  #print-area{position:static!important;left:0!important;width:100%!important;}
  .pdf-wrap{padding:0;max-width:none;box-shadow:none;}
  *{overflow:visible!important;}
}

/* ── HEADER ─────────────────────────────────────────────────────── */
.ap-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: color-mix(in srgb, var(--bg) 90%, transparent);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  padding: 0 28px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background .2s, border-color .2s;
}
.ap-header-logo {
  display: flex; align-items: baseline; gap: 12px; text-decoration: none;
}
.ap-wordmark {
  font-family: var(--serif);
  font-size: 25px; font-weight: 600; letter-spacing: -0.02em;
  line-height: 1; user-select: none; display: flex; align-items: baseline;
}
.ap-logo-icon { display:none; }
.ap-logo-apt  { color: var(--text); font-weight: 600; }
.ap-logo-ly   { color: var(--accent); font-weight: 600; font-style: italic; }
.ap-tagline   { font-family: var(--mono); font-size: 10px; color: var(--sub); font-weight: 400; letter-spacing: 0.14em; text-transform: uppercase; }
.ap-wordmark-check,.ap-wordmark-apply,.ap-wordmark-ify{display:none}
.ap-header-actions { display: flex; align-items: center; gap: 10px; }

/* ── MORE DROPDOWN ───────────────────────────────────────────────── */
.ap-more-dropdown{position:relative;display:inline-block;}
.ap-more-btn{padding:7px 13px;border-radius:var(--radius-md);border:1px solid var(--border);background:transparent;color:var(--sub);font-size:11px;font-weight:500;cursor:pointer;font-family:var(--mono);white-space:nowrap;letter-spacing:.06em;text-transform:uppercase;transition:background .15s,border-color .15s,color .15s;}
.ap-more-btn:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);}
.ap-dropdown-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:200;min-width:190px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:4px;box-shadow:var(--shadow);}
.ap-dropdown-item{display:flex;align-items:center;gap:9px;width:100%;padding:8px 12px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--sub);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;text-align:left;white-space:nowrap;transition:background .12s,color .12s;}
.ap-dropdown-item:hover{background:var(--accent-soft);color:var(--accent);}

/* ── SCORE / KEYWORD CARDS ───────────────────────────────────────── */
.score-card{background:var(--surface);border-radius:var(--radius-lg);padding:22px;margin-bottom:24px;border:1px solid var(--border);box-shadow:none}

/* ── TOOL TAB BAR — hover affordance (inactive only) ─────────────── */
#ap-tab-bar button:not([data-active="1"]):hover{border-color:var(--accent)!important;color:var(--accent)!important;}
.buzzword-tag{background:var(--accent-soft);color:var(--accent);padding:4px 10px;border-radius:var(--radius-md);font-size:12px;margin-right:6px;display:inline-block;margin-bottom:6px;font-weight:500;border:1px solid var(--border)}
.btn-key-active{padding:8px 16px;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s;background:var(--accent-strong);color:#fffdf8;font-family:inherit;border:none}
.btn-key-active:hover{background:var(--accent)}
.btn-key-missing{padding:5px 12px;border-radius:var(--radius-md);font-size:11px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;background:rgba(199,154,82,0.1);border:1px solid rgba(199,154,82,0.4);color:#c79a52;font-family:inherit}
.key-dot{width:7px;height:7px;background:var(--accent);border-radius:50%;flex-shrink:0}
.key-dot-missing{width:6px;height:6px;background:#c79a52;border-radius:50%;flex-shrink:0}
.app-stale{border:1px solid var(--accent)!important;background:var(--accent-soft)!important;position:relative}
.app-stale::after{content:"Follow up?";position:absolute;top:-11px;right:12px;background:var(--accent);color:#fffdf8;font-size:10px;padding:3px 9px;border-radius:0;font-family:var(--mono);font-weight:500;letter-spacing:.06em;text-transform:uppercase}

/* ════════════════════════════════════════════════════════════════
   LANDING PAGE — editorial
   ════════════════════════════════════════════════════════════════ */
.ap-section-inner{max-width:920px;margin:0 auto;padding:0 24px;text-align:center}
.ap-section-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px;background:transparent;color:var(--accent);border:none;padding:0}
.ap-section-eyebrow::before{content:"";width:24px;height:1px;background:var(--accent)}
.ap-section-eyebrow::after{content:"";width:24px;height:1px;background:var(--accent)}
.ap-section-inner h2{font-family:var(--serif);font-size:clamp(28px,4vw,44px);font-weight:500;color:var(--text);letter-spacing:-0.02em;margin-bottom:16px;line-height:1.12}
.ap-section-inner p{font-size:15px;color:var(--sub);line-height:1.75;max-width:600px;margin:0 auto 32px}

/* Hero */
.ap-hero{position:relative;overflow:hidden;padding:92px 24px 72px;text-align:center;background:var(--bg);border-bottom:1px solid var(--border)}
.ap-hero-glow{display:none!important}
.ap-hero-inner{position:relative;max-width:800px;margin:0 auto}
.ap-hero-badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;font-weight:400;color:var(--sub);background:transparent;border:1px solid var(--border);padding:7px 16px;border-radius:0;margin-bottom:30px;letter-spacing:.08em;text-transform:uppercase}
.ap-hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--good)}
.ap-hero h1{font-family:var(--serif);font-size:clamp(40px,6.4vw,68px);font-weight:500;color:var(--text);letter-spacing:-0.025em;line-height:1.04;margin-bottom:22px}
.ap-hero-em{color:var(--accent);font-style:italic;font-weight:500}
.ap-hero-sub{font-size:16px;color:var(--sub);line-height:1.7;max-width:560px;margin:0 auto 36px}
.ap-hero-actions-top{display:flex;flex-direction:column;align-items:center;gap:8px;margin:22px 0 4px;}
.ap-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:52px}

/* Buttons — solid ember, hairline secondary, no glow */
.ap-btn-primary{padding:14px 28px;border-radius:var(--radius-md);background:var(--accent-strong);color:#fffdf8;font-size:15px;font-weight:600;border:none;cursor:pointer;font-family:var(--sans);letter-spacing:0;transition:background .15s,transform .15s}
.ap-btn-primary:hover{background:var(--accent);transform:translateY(-1px)}
.ap-btn-large{padding:16px 38px;font-size:16px}

/* Subtle sheen that sweeps across the primary CTA every few seconds, then rests */
.ap-btn-primary{position:relative;overflow:hidden}
.ap-btn-primary::after{content:"";position:absolute;top:0;bottom:0;left:-60%;width:35%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,0.28),transparent);
  transform:skewX(-18deg);pointer-events:none}
.ap-btn-primary:hover::after{animation:ap-shine 1s ease-out}
@keyframes ap-shine{0%{left:-60%}14%{left:150%}100%{left:150%}}
@media (prefers-reduced-motion:reduce){.ap-btn-primary::after{animation:none;display:none}}
.ap-btn-secondary{padding:14px 24px;border-radius:var(--radius-md);background:transparent;color:var(--ink-2);font-size:15px;font-weight:500;border:1px solid var(--border);cursor:pointer;font-family:var(--sans);transition:border-color .15s,color .15s}
.ap-btn-secondary:hover{border-color:var(--accent);color:var(--accent)}

.ap-hero-stats{display:flex;justify-content:center;align-items:stretch;gap:0;flex-wrap:wrap}
.ap-stat{text-align:center;padding:0 34px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.ap-stat-num{font-family:var(--serif);font-size:30px;font-weight:500;color:var(--accent);letter-spacing:-.02em;line-height:1.1;margin-bottom:8px}
.ap-stat-label{font-size:12px;color:var(--sub);font-weight:400;line-height:1.5;max-width:130px}
.ap-stat-div{width:1px;background:var(--border)}

/* ── Hero preview — editorial "graded page" mock (.hp-*) ─────────── */
.hp-stack{max-width:540px;margin:0 auto 40px;position:relative;text-align:left}
.hp-panel{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
  /* lifted "graded page" — deep drop shadow + faint top highlight so it floats off the dark page */
  box-shadow:
    0 1px 0 rgba(236,226,205,0.06) inset,
    0 2px 8px rgba(0,0,0,0.38),
    0 42px 84px -30px rgba(0,0,0,0.85);
}
/* Light (editorial paper): brightest sheet on the cream desk + warm layered shadow so it clearly stands out */
body.theme-light .hp-panel{
  background:var(--surface);
  border-color:#cdc2ab;
  box-shadow:
    0 0 0 1px rgba(60,42,18,0.06),
    0 2px 4px rgba(60,42,18,0.16),
    0 14px 28px -10px rgba(60,42,18,0.30),
    0 46px 84px -28px rgba(60,42,18,0.46);
}
.hp-bar{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--surface);border-bottom:1px solid var(--border)}
.hp-bar .wm{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--text);letter-spacing:-.02em}
.hp-bar .wm i{color:var(--accent);font-style:italic}
.hp-bar .tab{margin-left:auto;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--sub)}
.hp-body{padding:22px 22px 24px}
.hp-score-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding-bottom:18px;border-bottom:1px solid var(--border)}
.hp-score-label{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.hp-score-label::before{content:"";width:18px;height:1px;background:var(--accent)}
.hp-score-big{font-family:var(--serif);font-weight:500;color:var(--text);font-size:58px;line-height:.9;letter-spacing:-.03em}
.hp-score-big .of{font-size:20px;color:var(--sub)}
.hp-stamp{position:relative;flex-shrink:0;width:84px;height:84px;border-radius:50%;border:2.5px solid var(--accent);color:var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;transform:rotate(-8deg);background:var(--accent-soft)}
.hp-stamp .d{font-family:var(--serif);font-size:24px;font-weight:600;line-height:1}
.hp-stamp .l{font-family:var(--mono);font-size:7.5px;letter-spacing:.12em;margin-top:3px}
.hp-sech{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--sub);margin:22px 0 12px;padding-top:18px;border-top:1px solid var(--border)}
.hp-bullet{display:flex;gap:9px;font-size:13px;line-height:1.55;color:var(--ink-2)}
.hp-bullet .dot{color:var(--accent);flex-shrink:0}
.hp-strike{text-decoration:line-through;text-decoration-color:var(--accent);text-decoration-thickness:2px;color:var(--sub)}
.hp-note{display:flex;justify-content:flex-end;margin:-1px 0 14px}
.hp-note .hand{font-family:var(--hand);font-weight:600;color:var(--accent);font-size:19px;line-height:1;transform:rotate(-2.5deg)}
.hp-good b{color:var(--good);font-weight:700}
.hp-ats{margin-top:4px;display:grid;grid-template-columns:1fr 1fr;gap:7px 22px}
.hp-ats-item{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--ink-2)}
.hp-ats-item.miss{color:var(--sub)}
.hp-ck{width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0;font-family:var(--mono)}
.hp-ck.ok{border:1.5px solid var(--good);color:var(--good)}
.hp-ck.warn{border:1.5px solid var(--accent);color:var(--accent)}
.hp-fade{-webkit-mask-image:linear-gradient(to bottom,black 0%,black 62%,transparent 100%);mask-image:linear-gradient(to bottom,black 0%,black 62%,transparent 100%)}

.ap-hero-fineprint{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;text-align:center;margin:4px 0 0}
.ap-hero-aside{font-size:13px;color:var(--sub);margin:0 auto 8px;font-style:italic;max-width:520px}

/* How it works */
.ap-how{padding:84px 0;background:var(--surface);border-bottom:1px solid var(--border)}
.ap-how-steps{display:flex;align-items:flex-start;justify-content:center;gap:0;flex-wrap:wrap;margin-top:44px}
.ap-how-step{flex:1;min-width:220px;max-width:270px;text-align:center;padding:0 18px}
.ap-how-num{width:46px;height:46px;border-radius:50%;background:transparent;border:1.5px solid var(--accent);color:var(--accent);font-family:var(--serif);font-size:20px;font-weight:600;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.ap-how-content h3{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--text);margin-bottom:9px;letter-spacing:-.01em}
.ap-how-content p{font-size:13px;color:var(--sub);line-height:1.65}
.ap-how-arrow{font-family:var(--mono);font-size:18px;color:var(--border);padding:32px 4px 0;flex-shrink:0}
@media(max-width:600px){.ap-how-arrow{transform:rotate(90deg);padding:0 30px}}

/* Problem */
.ap-problem{padding:84px 0;border-bottom:1px solid var(--border)}
.ap-problem-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:0;margin-top:36px;text-align:left;border:1px solid var(--border)}
.ap-problem-item{display:flex;gap:16px;padding:24px;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.ap-problem-item:last-child{border-right:none}
.ap-problem-icon{font-family:var(--serif);font-size:26px;font-style:italic;color:var(--accent);flex-shrink:0;line-height:1;margin-top:-2px}
.ap-problem-item strong{display:block;font-family:var(--serif);font-size:16px;font-weight:600;color:var(--text);margin-bottom:7px;line-height:1.3}
.ap-problem-item p{font-size:12.5px;color:var(--sub);line-height:1.6;margin:0}

/* Features */
.ap-value{padding:84px 0;background:var(--surface);border-bottom:1px solid var(--border)}
.ap-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0;margin-top:44px;text-align:left;border-top:1px solid var(--border);border-left:1px solid var(--border)}
.ap-feature{padding:28px 26px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:background .2s}
.ap-feature:hover{background:var(--accent-soft)}
.ap-feature-icon{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--accent);display:block;margin-bottom:16px;letter-spacing:.1em}
.ap-feature h3{font-family:var(--serif);font-size:19px;font-weight:600;color:var(--text);margin-bottom:9px;letter-spacing:-.01em}
.ap-feature p{font-size:13px;color:var(--sub);line-height:1.65;margin:0}

/* Social proof */
.ap-proof{padding:84px 0;border-bottom:1px solid var(--border)}
.ap-proof-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:44px}
.ap-proof-card{padding:26px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:left}
.ap-proof-quote{font-family:var(--serif);font-size:17px;color:var(--ink-2);line-height:1.55;font-style:italic;margin-bottom:14px}
.ap-proof-attr{font-family:var(--mono);font-size:10px;color:var(--muted);font-weight:500;letter-spacing:.1em;text-transform:uppercase}
.ap-proof-feedback{display:flex;flex-direction:column;justify-content:space-between;text-align:center}
.ap-proof-feedback-title{font-family:var(--serif);font-size:18px;font-weight:600;color:var(--text);margin-bottom:7px}
.ap-proof-feedback-sub{font-size:12px;color:var(--sub);margin-bottom:18px}
.ap-proof-feedback-btns{display:flex;gap:10px;justify-content:center}
.ap-proof-btn{padding:9px 18px;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:all .15s;border:1px solid var(--border);background:transparent;color:var(--sub)}
.ap-proof-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.ap-proof-btn-yes:hover:not(:disabled){background:var(--accent-soft)}
.ap-proof-btn-no:hover:not(:disabled){background:var(--accent-soft)}

/* CTA */
.ap-cta{padding:88px 24px;text-align:center}
.ap-cta-inner{max-width:700px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.ap-cta h2{font-family:var(--serif);font-size:clamp(30px,4.4vw,46px);font-weight:500;color:var(--text);letter-spacing:-.02em;margin-bottom:14px;line-height:1.1}
.ap-cta p{font-size:15px;color:var(--sub);margin-bottom:30px}
.ap-coffee-divider{margin:48px auto 24px;font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.ap-coffee{display:inline-flex;align-items:center;gap:14px;padding:16px 24px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;white-space:nowrap;max-width:100%;transition:border-color .2s}
.ap-coffee:hover{border-color:var(--accent)}
@media(max-width:640px){.ap-coffee{white-space:normal;}}
.ap-coffee-emoji{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--accent);flex-shrink:0}
.ap-coffee span:last-child{font-size:13px;color:var(--sub);line-height:1.5}

/* ── FACTS BAR ───────────────────────────────────────────────────── */
.ap-facts-bar{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:center;gap:10px;padding:9px 24px;background:color-mix(in srgb, var(--bg) 94%, transparent);border-top:1px solid var(--border);backdrop-filter:blur(10px);font-size:12px;color:var(--sub);min-height:38px;box-sizing:border-box;}
.ap-facts-icon{font-family:var(--serif);font-style:italic;font-size:13px;color:var(--accent);flex-shrink:0;}
.ap-facts-text{max-width:780px;text-align:center;line-height:1.5;transition:opacity 0.5s ease;}
.ap-facts-text.fade{opacity:0;}
#app{padding-bottom:46px;}
@media(max-width:600px){.ap-facts-bar{padding:8px 14px;font-size:11px;}}

/* ── TOAST ───────────────────────────────────────────────────────── */
@keyframes toast-in{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes toast-out{from{transform:translateY(0);opacity:1}to{transform:translateY(10px);opacity:0}}

/* ── MOBILE ──────────────────────────────────────────────────────── */
@media(max-width:700px){
  .ap-header{padding:0 16px;height:54px;}
  .ap-tagline{display:none;}
  .ap-wordmark{font-size:21px;}
  .ap-facts-bar{padding:8px 12px;font-size:11px;}
  #app{padding-bottom:42px;}
  #ap-toast-el{bottom:54px!important;right:12px!important;left:12px!important;max-width:none!important;}
  #ap-tab-bar{
    flex-wrap:nowrap!important;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding-bottom:4px;
    gap:6px!important;
  }
  #ap-tab-bar::-webkit-scrollbar{display:none;}
  #ap-tab-bar button{flex-shrink:0;}
  #ap-workspace{padding:0 12px!important;}
  .ap-action-grid{grid-template-columns:repeat(2,1fr)!important;}
  .ap-mini-grid{grid-template-columns:repeat(2,1fr)!important;}
}

@media(max-width:480px){
  .ap-header{padding:0 12px;}
  .ap-action-grid{grid-template-columns:1fr!important;}
}

/* ── MATCH SCORE PILLS — flat editorial, no gradient/glow ────────── */
.match-score-high{background:var(--good-soft);color:var(--good)!important;padding:6px 14px;border-radius:var(--radius-md);font-weight:700;font-size:13px;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--good)}
.match-score-medium{background:rgba(199,154,82,0.12);color:#c79a52!important;padding:6px 14px;border-radius:var(--radius-md);font-weight:700;font-size:13px;display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(199,154,82,0.5)}
.match-score-low{background:var(--accent-soft);color:var(--accent)!important;padding:6px 14px;border-radius:var(--radius-md);font-weight:700;font-size:13px;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--accent)}

/* ── MATCH ANALYSIS ──────────────────────────────────────────────── */
.match-analysis-card{background:var(--surface);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px;border:1px solid var(--border);box-shadow:none}
.match-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.match-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.match-category{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--text);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.match-detail{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding:8px 12px;border-radius:var(--radius-md);background:var(--surface-2);border:1px solid var(--border)}
.match-detail-label{font-size:13px;color:var(--sub)}
.match-detail-value{font-size:13px;font-weight:600;color:var(--accent)}
.match-keywords{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.match-keyword{background:var(--accent-soft);color:var(--accent);padding:4px 12px;border-radius:var(--radius-md);font-size:12px;border:1px solid var(--border)}
.match-gap{background:rgba(199,154,82,0.12);color:#c79a52;padding:4px 12px;border-radius:var(--radius-md);font-size:12px;border:1px solid rgba(199,154,82,0.4)}
.match-strength{background:var(--good-soft);color:var(--good);padding:4px 12px;border-radius:var(--radius-md);font-size:12px;border:1px solid var(--good)}


/* ── COMPARISON (landing) ────────────────────────────────────────── */
.ap-compare{padding:84px 0;border-bottom:1px solid var(--border)}
.ap-compare-table{margin-top:8px;border:1px solid var(--border);text-align:left}
.ap-compare-row{display:grid;grid-template-columns:150px 1fr 1fr;border-bottom:1px solid var(--border)}
.ap-compare-row:last-child{border-bottom:none}
.ap-compare-row > div{padding:15px 20px;font-size:14px;line-height:1.55}
.ap-compare-label{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center}
.ap-compare-aptly{color:var(--text);background:var(--surface);border-left:1px solid var(--border)}
.ap-compare-them{color:var(--muted);border-left:1px solid var(--border)}
.ap-compare-head > div{padding-top:12px;padding-bottom:12px;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase}
.ap-compare-head .ap-compare-aptly{color:var(--accent)}
.ap-compare-head .ap-compare-them{color:var(--muted)}
.ap-ck-good{color:var(--good);font-weight:700;margin-right:7px}
@media (max-width:640px){
  .ap-compare-row{grid-template-columns:1fr}
  .ap-compare-row > div{border-left:none;padding:10px 16px}
  .ap-compare-label{padding-bottom:0;padding-top:14px}
  .ap-compare-them{padding-bottom:16px}
  .ap-compare-head{display:none}
  .ap-compare-them::before{content:"Others: ";font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
}

/* ── FAQ (landing) ───────────────────────────────────────────────── */
.ap-faq{padding:84px 0;background:var(--surface);border-bottom:1px solid var(--border)}
.ap-faq-list{margin-top:36px;text-align:left;border-top:1px solid var(--border)}
.ap-faq-item{border-bottom:1px solid var(--border)}
.ap-faq-item summary{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:19px 4px;cursor:pointer;font-family:var(--serif);font-size:18px;font-weight:500;color:var(--text);list-style:none}
.ap-faq-item summary::-webkit-details-marker{display:none}
.ap-faq-item summary:hover{color:var(--accent)}
.ap-faq-mark{font-family:var(--mono);color:var(--accent);font-size:16px;flex-shrink:0;transition:transform .2s}
.ap-faq-item[open] .ap-faq-mark{transform:rotate(45deg)}
.ap-faq-item p{font-size:14.5px;color:var(--sub);line-height:1.75;max-width:680px;margin:0;padding:0 4px 22px;text-align:left}


/* ── SPLIT: landing ↔ app ────────────────────────────────────────── */
a.ap-btn-primary,a.ap-btn-secondary,a.ap-price-btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box}
.ap-btn-header{padding:9px 18px;font-size:13px}

/* ── PRICING (landing) ───────────────────────────────────────────── */
.ap-pricing{padding:84px 0;border-bottom:1px solid var(--border)}
.ap-pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:40px;border:1px solid var(--border);text-align:left;align-items:stretch}
.ap-price-card{padding:32px 28px 28px;display:flex;flex-direction:column;gap:0;border-left:1px solid var(--border);position:relative}
.ap-price-card:first-child{border-left:none}
.ap-price-best{background:var(--surface);outline:1px solid var(--accent);outline-offset:-1px}
.ap-price-flag{position:absolute;top:-1px;right:-1px;font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--bg);background:var(--accent);padding:5px 12px}
.ap-price-tier{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.ap-price-amount{font-family:var(--serif);font-size:40px;font-weight:500;color:var(--text);line-height:1;margin-bottom:22px;display:flex;align-items:baseline;gap:10px}
.ap-price-period{font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.ap-price-list{list-style:none;margin:0 0 26px;padding:0;display:flex;flex-direction:column;gap:10px;flex:1}
.ap-price-list li{font-size:13.5px;line-height:1.5;color:var(--sub);padding-left:18px;position:relative}
.ap-price-list li::before{content:"—";position:absolute;left:0;color:var(--accent)}
.ap-price-list li strong{color:var(--text);font-weight:600}
.ap-price-btn{padding:11px 18px;font-size:13.5px;font-weight:600;border:1px solid var(--border);color:var(--text);background:transparent;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s}
.ap-price-btn:hover{border-color:var(--accent);color:var(--accent)}
.ap-price-btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.ap-price-btn-primary:hover{color:var(--bg);opacity:.9}
.ap-pricing-note{margin-top:22px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--muted)}
@media (max-width:760px){
  .ap-pricing-grid{grid-template-columns:1fr}
  .ap-price-card{border-left:none;border-top:1px solid var(--border)}
  .ap-price-card:first-child{border-top:none}
}


/* ── HERO VIGNETTE — the graded page, quietly coming alive ───────── */
/* Gated on .hv-anim (added by JS only when motion is OK) so no-JS,
   print, and reduced-motion all show the finished graded page. */
.hv-anim{transition:opacity .4s ease}
.hv-anim.hv-reset{opacity:0;transition:opacity .42s ease}
.hv-anim .hp-strike{text-decoration:none;color:var(--ink-2);background-image:linear-gradient(var(--accent),var(--accent));background-repeat:no-repeat;background-size:0 3px;background-position:0 60%;transition:background-size .4s cubic-bezier(.4,0,.2,1),color .4s ease}
.hv-anim.hv-s1 .hp-strike{background-size:100% 3px;color:var(--sub)}
.hv-anim .hp-note .hand{opacity:0;transform:rotate(-2.5deg) translateY(9px) scale(.92);transition:opacity .38s ease,transform .38s cubic-bezier(.3,1.3,.5,1)}
.hv-anim.hv-s2 .hp-note .hand{opacity:1;transform:rotate(-2.5deg) translateY(0) scale(1)}
.hv-anim .hp-bullet.hp-good{opacity:0;transform:translateY(12px);transition:opacity .45s ease,transform .45s cubic-bezier(.3,1.2,.5,1)}
.hv-anim.hv-s3 .hp-bullet.hp-good{opacity:1;transform:translateY(0)}
.hv-anim .hp-stamp{opacity:0;scale:2;transition:opacity .26s ease,scale .34s cubic-bezier(.25,1.5,.45,1)}
.hv-anim.hv-s4 .hp-stamp{opacity:1;scale:1}
