/* =====================================================================
   OE 324 — V1 Wizard (true single-question)
   One question per step. Dots indicator. Slide transitions.
   ===================================================================== */

:root {
  --c-navy-900:#07264D; --c-navy-800:#0B3A6F; --c-navy-700:#134B8A; --c-navy-600:#1E5BA8; --c-navy-50:#EEF4FB;
  --c-amber-500:#F7A800; --c-amber-50:#FFF6E0;
  --c-ink-900:#0F172A; --c-ink-700:#334155; --c-ink-500:#64748B; --c-ink-300:#94A3B8;
  --c-line:#E2E8F0; --c-line-2:#EEF1F6; --c-bg:#F6F8FB; --c-surface:#FFFFFF;
  --c-success:#16A34A; --c-success-50:#E8F8EE; --c-success-100:#D1FADF;
  --c-danger:#DC2626; --c-danger-50:#FEECEC;
  --ff-sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --ff-display:"Manrope","Inter",system-ui,sans-serif;
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:24px; --r-full:999px;
  --sh-1:0 1px 2px rgba(15,23,42,.04),0 1px 1px rgba(15,23,42,.04);
  --sh-2:0 6px 16px rgba(15,23,42,.06),0 2px 4px rgba(15,23,42,.04);
  --sh-3:0 30px 60px -16px rgba(11,58,111,.20),0 10px 20px -8px rgba(15,23,42,.10);
  --sh-focus:0 0 0 4px rgba(11,58,111,.18);
  --container:1200px; --gutter:clamp(16px,4vw,32px);
  --topbar-h:64px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--ff-sans);font-size:16px;line-height:1.55;color:var(--c-ink-900);background:var(--c-bg);-webkit-font-smoothing:antialiased;min-height:100vh;display:flex;flex-direction:column}
img,svg{display:block;max-width:100%}
a{color:var(--c-navy-700);text-decoration:none}
a:hover{text-decoration:underline}
button{font:inherit}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter);width:100%}

/* Topbar */
.topbar{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.85);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--c-line)}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;min-height:var(--topbar-h);gap:16px}
.brand{display:inline-flex;align-items:center;gap:12px;color:var(--c-ink-900);text-decoration:none}
.brand__logo{width:38px;height:38px;object-fit:contain}
.brand__wordmark{display:flex;flex-direction:column;line-height:1.15}
.brand__wordmark strong{font-family:var(--ff-display);font-weight:800;letter-spacing:-.01em;font-size:15px}
.brand__wordmark span{font-size:11.5px;color:var(--c-ink-500)}
.topbar__right{display:flex;align-items:center;gap:8px}
.cat-chip{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-navy-800);background:var(--c-navy-50);padding:5px 10px;border-radius:var(--r-full);border:1px solid #DCE7F3}
@media(max-width:680px){.brand__wordmark span{display:none}.cat-chip{display:none}#reqBtn span,#reqBtn{display:none}}

/* Buttons */
.btn{--btn-bg:var(--c-navy-800);--btn-fg:#fff;--btn-bd:var(--c-navy-800);display:inline-flex;align-items:center;gap:6px;padding:11px 18px;border-radius:var(--r-sm);border:1px solid var(--btn-bd);background:var(--btn-bg);color:var(--btn-fg);font-weight:600;font-size:14px;cursor:pointer;transition:transform .12s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);text-decoration:none;white-space:nowrap}
.btn:hover{transform:translateY(-1px);box-shadow:var(--sh-2);text-decoration:none}
.btn:focus-visible{outline:none;box-shadow:var(--sh-focus)}
.btn[disabled]{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.btn[hidden]{display:none}
.btn--primary:hover{--btn-bg:var(--c-navy-700);--btn-bd:var(--c-navy-700)}
.btn--ghost{--btn-bg:transparent;--btn-fg:var(--c-ink-700);--btn-bd:var(--c-line)}
.btn--ghost:hover{--btn-bg:var(--c-navy-50);--btn-fg:var(--c-navy-800);--btn-bd:#DCE7F3}
.btn--sm{padding:7px 11px;font-size:13px}

/* Resume bar */
.resume-bar{background:var(--c-amber-50);border-bottom:1px solid #f1d68a;animation:slideDown .3s var(--ease)}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.resume-bar__inner{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:13.5px;color:#6b4500}
.resume-bar__icon{flex:0 0 auto;display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:#fff;color:#8a5a00}
.resume-bar__msg{flex:1}
.resume-bar__close{padding:4px 8px!important}
@media(max-width:560px){.resume-bar__msg{font-size:12.5px}}

/* Work area — single-column centered */
.work{flex:1;padding:clamp(24px,4vw,44px) 0 clamp(40px,6vw,80px);background:radial-gradient(1100px 280px at 90% -20%,rgba(11,58,111,.06),transparent 60%),radial-gradient(700px 200px at -5% -10%,rgba(247,168,0,.06),transparent 60%),var(--c-bg);display:flex;align-items:flex-start}
.work__inner{display:flex;justify-content:center;width:100%}
.wizard{width:100%;max-width:680px}

/* Wizard card */
.wizard__card{position:relative;background:var(--c-surface);border:1px solid var(--c-line);border-radius:var(--r-xl);box-shadow:var(--sh-3)}
.wizard__card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--c-navy-800),var(--c-navy-600),var(--c-amber-500))}

.wizard__head{padding:24px 32px 18px;text-align:center;border-bottom:1px solid var(--c-line-2)}
.wizard__head-text{margin-bottom:18px}
.wizard__title{font-family:var(--ff-display);font-weight:800;font-size:clamp(20px,2.4vw,24px);margin:0 0 4px;letter-spacing:-.02em;color:var(--c-navy-900);line-height:1.15}
.wizard__lede{color:var(--c-ink-500);font-size:13.5px;margin:0;line-height:1.5;max-width:54ch;margin-inline:auto}

/* DOTS indicator */
.dots{list-style:none;padding:0;margin:0;display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}
.dot{appearance:none;background:transparent;border:0;padding:6px 2px;cursor:pointer;display:inline-flex;align-items:center;gap:0;position:relative}
.dot__inner{width:8px;height:8px;border-radius:50%;background:var(--c-line);display:block;transition:width .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),transform .15s var(--ease)}
.dot.is-done .dot__inner{background:var(--c-navy-700)}
.dot.is-active .dot__inner{background:var(--c-navy-800);width:28px;border-radius:999px;box-shadow:0 0 0 4px rgba(11,58,111,.14)}
.dot:hover:not(:disabled) .dot__inner{transform:scale(1.25);background:var(--c-navy-700)}
.dot.is-active:hover .dot__inner{transform:none}
.dot:disabled{cursor:not-allowed}
.dot:disabled .dot__inner{opacity:.55}
.dot:focus-visible{outline:none}
.dot:focus-visible .dot__inner{box-shadow:var(--sh-focus)}
.dot__tip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--c-ink-900);color:#fff;padding:5px 9px;border-radius:6px;font-size:11.5px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .15s var(--ease);z-index:5}
.dot:hover .dot__tip{opacity:1}

/* Form / stage */
.form{display:flex;flex-direction:column}
.stage{position:relative;padding:32px 32px 8px;min-height:280px}
@media(max-width:560px){.stage{padding:24px 20px 4px;min-height:240px}.wizard__head{padding:20px 20px 14px}}

.step{border:0;padding:0;margin:0;display:none;animation:none}
.step.is-active{display:block}
.step.enter-right{animation:slideInR .32s var(--ease)}
.step.enter-left{animation:slideInL .32s var(--ease)}
@keyframes slideInR{from{opacity:0;transform:translateX(24px)}to{opacity:1;transform:none}}
@keyframes slideInL{from{opacity:0;transform:translateX(-24px)}to{opacity:1;transform:none}}

.step__counter{display:inline-block;font-family:var(--ff-display);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--c-navy-700);background:var(--c-navy-50);padding:4px 10px;border-radius:var(--r-full);margin-bottom:14px}
.step__question{font-family:var(--ff-display);font-size:clamp(22px,2.8vw,28px);font-weight:800;letter-spacing:-.02em;line-height:1.2;color:var(--c-ink-900);margin:0 0 8px}
.step__hint{color:var(--c-ink-500);font-size:14.5px;margin:0 0 22px;line-height:1.5;max-width:60ch}
.step__link{appearance:none;background:transparent;border:0;padding:0;margin-top:14px;color:var(--c-navy-700);font-size:13.5px;font-weight:600;cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.step__link:hover{color:var(--c-navy-800)}
.step__link[hidden]{display:none}

/* Welcome step */
.welcome__intro{color:var(--c-ink-700);font-size:15px;line-height:1.6;margin:0 0 22px;max-width:62ch}
.welcome__reqs{list-style:none;padding:0;margin:0;counter-reset:w;display:grid;gap:6px}
.welcome__reqs > li{counter-increment:w;position:relative;padding:12px 14px 12px 48px;background:var(--c-bg);border:1px solid var(--c-line);border-radius:var(--r-md);font-size:14px;color:var(--c-ink-700);line-height:1.45}
.welcome__reqs > li::before{content:counter(w);position:absolute;left:12px;top:12px;width:24px;height:24px;border-radius:50%;background:var(--c-navy-50);color:var(--c-navy-800);font-weight:700;font-size:12px;display:grid;place-items:center}
.welcome__main{display:block;font-weight:600;color:var(--c-ink-900);margin-bottom:2px}
.welcome__sub{margin:4px 0 0;padding-left:14px;list-style:disc;font-size:12.5px;color:var(--c-ink-500)}
.welcome__sub li{padding:1px 0}
/* Standalone heading rendered above the accepted-programs grid when at
   least one type's codes are surfaced (intro / welcome step). */
.welcome__cte-title{margin:18px 0 8px;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-navy-800)}
.welcome__cte{margin-top:6px;display:grid;gap:10px;grid-template-columns:1fr 1fr}
@media(max-width:560px){.welcome__cte{grid-template-columns:1fr}}
.welcome__sect{padding:14px;background:var(--c-navy-50);border:1px solid #DCE7F3;border-radius:var(--r-md)}
.welcome__sect--amber{background:var(--c-amber-50);border-color:#f1d68a}
/* Span both columns of the grid. Used on the WorkKeys card so that when
   two type sections render side-by-side, the score-minimums sit cleanly
   underneath as a single full-width row instead of leaving an empty
   second column. Falls back to a single column at narrow widths via the
   media query above (the grid only has 1 column there anyway). */
.welcome__sect--span{grid-column:1 / -1}
.welcome__sect h3{margin:0 0 10px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-navy-800)}
.welcome__sect--amber h3{color:#6b4500}
.welcome__codes{list-style:none;padding:0;margin:0;display:grid;gap:4px}
.welcome__codes li{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;background:#fff;border:1px solid #DCE7F3;padding:6px 9px;border-radius:var(--r-sm);color:var(--c-ink-700)}
.welcome__bullets{list-style:disc;padding-left:18px;margin:0;color:#6b4500;font-size:13px}
.welcome__bullets li{padding:2px 0}

/* Field */
.field{display:flex;flex-direction:column;min-width:0;position:relative}
.field__error{display:none;font-size:13px;color:var(--c-danger);margin-top:8px;line-height:1.4}
.field.is-invalid .input,.field.is-invalid .input--xl{border-color:var(--c-danger);background:var(--c-danger-50)}
.field.is-invalid .field__error{display:block}

/* Inputs — large for one-question-at-a-time */
.input,.input--xl{width:100%;padding:14px 16px;background:#fff;border:1.5px solid var(--c-line);border-radius:var(--r-md);color:var(--c-ink-900);font-size:18px;line-height:1.4;font-family:inherit;transition:border-color .15s var(--ease),box-shadow .15s var(--ease)}
.input--xl{padding:16px 18px;font-size:20px;border-radius:14px}
.input::placeholder,.input--xl::placeholder{color:var(--c-ink-300)}
.input:hover,.input--xl:hover{border-color:#cdd6e2}
.input:focus,.input--xl:focus{outline:none;border-color:var(--c-navy-800);box-shadow:var(--sh-focus)}

.field__check{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:var(--c-success);display:none;place-items:center;pointer-events:none}
.field__check::after{content:"";width:12px;height:12px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.17 4.83 12 3.41 13.41 9 19l12-12-1.41-1.42z'/></svg>") center/contain no-repeat}
.field.is-valid .input--xl,.field.is-valid .input{padding-right:48px;border-color:var(--c-success)}
.field.is-valid .field__check{display:grid;animation:checkIn .25s var(--ease)}
@keyframes checkIn{from{opacity:0;transform:translateY(-50%) scale(.6)}to{opacity:1;transform:translateY(-50%) scale(1)}}

/* Custom checkbox */
.check{display:inline-flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;color:var(--c-ink-700);line-height:1.45}
.check input{position:absolute;opacity:0;pointer-events:none}
.check__box{width:20px;height:20px;flex:0 0 20px;border-radius:6px;border:1.5px solid var(--c-line);background:#fff;display:grid;place-items:center;margin-top:1px;transition:background .15s var(--ease),border-color .15s var(--ease)}
.check__box::after{content:"";width:11px;height:11px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.17 4.83 12 3.41 13.41 9 19l12-12-1.41-1.42z'/></svg>") center/contain no-repeat;opacity:0;transform:scale(.8);transition:opacity .12s var(--ease),transform .12s var(--ease)}
.check input:checked + .check__box{background:var(--c-navy-800);border-color:var(--c-navy-800)}
.check input:checked + .check__box::after{opacity:1;transform:scale(1)}
.check input:focus-visible + .check__box{box-shadow:var(--sh-focus)}
.check--inline{font-size:13px;color:var(--c-ink-500)}
.field--check{padding:14px 16px;margin-top:18px;background:var(--c-bg);border:1px solid var(--c-line);border-radius:var(--r-md)}

/* ===================== Choices.js — XL overrides ===================== */
.choices{margin-bottom:0!important;font-size:inherit;font-family:inherit}
.choices__inner{padding:16px 18px!important;min-height:auto!important;font-size:20px;border:1.5px solid var(--c-line)!important;border-radius:14px!important;background:#fff!important;font-family:inherit}
.choices.is-focused .choices__inner,.choices.is-open .choices__inner{border-color:var(--c-navy-800)!important;box-shadow:var(--sh-focus)!important}
.choices__list--single{padding:0 32px 0 0!important}
.choices__list--single .choices__item{color:var(--c-ink-900)}
.choices__placeholder{color:var(--c-ink-300)!important;opacity:1!important}
.choices[data-type*=select-one]::after{border:0!important;width:18px;height:18px;margin-top:-9px;right:16px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%2364748B' d='M7 10l5 5 5-5z'/></svg>") center/contain no-repeat;transition:transform .2s var(--ease)}
.choices[data-type*=select-one].is-open::after{transform:rotate(180deg);border:0!important;margin-top:-9px}
.choices[data-type*=select-one] .choices__button{display:none}
.choices__list--dropdown,.choices__list[aria-expanded]{border-radius:var(--r-md)!important;border:1px solid var(--c-line)!important;box-shadow:var(--sh-3)!important;margin-top:8px!important;z-index:30;padding:6px 0}
.choices__list--dropdown .choices__list,.choices__list[aria-expanded] .choices__list{padding:0 6px}
.choices__list--dropdown .choices__item--selectable,.choices__list[aria-expanded] .choices__item--selectable{padding:10px 12px;font-size:15px;color:var(--c-ink-700);border-radius:var(--r-sm);margin:1px 0}
.choices__list--dropdown .choices__item--selectable.is-highlighted,.choices__list[aria-expanded] .choices__item--selectable.is-highlighted{background:var(--c-navy-50);color:var(--c-navy-800)}
.choices__list--dropdown .choices__item--selectable.is-selected,.choices__list[aria-expanded] .choices__item--selectable.is-selected{background:var(--c-navy-800);color:#fff}
.choices__input{background:var(--c-bg)!important;border:1px solid var(--c-line);border-radius:var(--r-sm);padding:9px 11px!important;font-size:14px!important;margin:6px 8px 4px!important;width:calc(100% - 16px)!important}
.choices__input:focus{outline:none;border-color:var(--c-navy-800);box-shadow:var(--sh-focus)}
@media(max-width:560px){.choices__inner{padding:14px 16px!important;font-size:18px}}

/* ===================== Google Places dropdown ====================== */
.pac-container{border-radius:var(--r-md);border:1px solid var(--c-line);box-shadow:var(--sh-3);margin-top:8px;font-family:var(--ff-sans);background:#fff;z-index:1000;padding:6px 0}
.pac-container::after{margin:6px 12px;filter:grayscale(100%) opacity(.4)}
.pac-item{padding:10px 14px;font-size:14px;color:var(--c-ink-700);border-top:1px solid var(--c-line-2);cursor:pointer;line-height:1.4}
.pac-item:first-child{border-top:0}
.pac-item:hover,.pac-item-selected,.pac-item.pac-item-selected{background:var(--c-navy-50);color:var(--c-navy-800)}
.pac-item-query{font-size:14px;color:var(--c-ink-900);font-weight:600;padding-right:4px}
.pac-matched{font-weight:700;color:var(--c-navy-800)}
.pac-icon{margin-top:4px}

/* Custom select (legacy — kept for V2/V3/V4 variants) */
.cselect{position:relative;width:100%}
.cselect__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 16px;background:#fff;border:1.5px solid var(--c-line);border-radius:var(--r-md);color:var(--c-ink-300);font-size:18px;line-height:1.4;cursor:pointer;text-align:left;transition:border-color .15s var(--ease),box-shadow .15s var(--ease);font-family:inherit}
.cselect--xl .cselect__trigger{padding:16px 18px;font-size:20px;border-radius:14px}
.cselect.has-value .cselect__trigger{color:var(--c-ink-900)}
.cselect__trigger:hover{border-color:#cdd6e2}
.cselect.is-open .cselect__trigger,.cselect__trigger:focus-visible{outline:none;border-color:var(--c-navy-800);box-shadow:var(--sh-focus)}
.cselect__caret{transition:transform .2s var(--ease);color:var(--c-ink-500);flex:0 0 auto}
.cselect.is-open .cselect__caret{transform:rotate(180deg)}
.cselect__panel{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);box-shadow:var(--sh-3);padding:6px;z-index:20;max-height:340px;overflow:auto;animation:popIn .15s var(--ease)}
.cselect__panel[hidden]{display:none}
@keyframes popIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.cselect__search{width:100%;padding:9px 11px;border:1px solid var(--c-line);border-radius:var(--r-sm);font-size:14px;margin-bottom:6px;outline:none}
.cselect__search:focus{border-color:var(--c-navy-800);box-shadow:var(--sh-focus)}
.cselect__list{list-style:none;padding:0;margin:0}
.cselect__option{padding:10px 12px;border-radius:var(--r-sm);cursor:pointer;font-size:15px;color:var(--c-ink-700);display:flex;flex-direction:column;gap:2px}
.cselect__option:hover,.cselect__option.is-active{background:var(--c-navy-50);color:var(--c-navy-800)}
.cselect__option.is-selected{background:var(--c-navy-800);color:#fff}
.cselect__opt-hint{font-size:12px;color:var(--c-ink-500)}
.cselect__option.is-selected .cselect__opt-hint{color:rgba(255,255,255,.7)}

/* Dropzone — single, larger */
.dropzone{position:relative;border:1.5px dashed var(--c-line);background:#fff;border-radius:var(--r-md);padding:24px;min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;text-align:center;transition:border-color .15s var(--ease),background .15s var(--ease),box-shadow .15s var(--ease)}
.dropzone:hover{border-color:var(--c-navy-700);background:#fbfdff}
.dropzone.is-drag{border-color:var(--c-navy-800);background:var(--c-navy-50);box-shadow:var(--sh-focus)}
.dropzone.is-filled{border-style:solid;border-color:var(--c-success);background:var(--c-success-50);flex-direction:row;align-items:flex-start;text-align:left;justify-content:flex-start}
.dropzone.is-invalid{border-color:var(--c-danger);background:var(--c-danger-50)}
.dropzone .cdz__input,.dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer}
.dropzone__thumb{width:56px;height:56px;border-radius:14px;flex:0 0 56px;background:var(--c-navy-50) center/cover no-repeat;color:var(--c-navy-800);display:grid;place-items:center}
.dropzone__thumb.has-img{background-color:#000}
.dropzone__thumb.has-img svg{display:none}
.dropzone.is-filled .dropzone__thumb{background-color:#fff;color:var(--c-success)}
.dropzone__body{min-width:0;display:flex;flex-direction:column;align-items:center;text-align:center}
.dropzone.is-filled .dropzone__body{align-items:flex-start;text-align:left;flex:1}
.dropzone__label{display:block;font-weight:700;color:var(--c-ink-900);font-size:15px;margin:0 0 4px}
.dropzone__hint{display:block;font-size:13px;color:var(--c-ink-500);margin:0;line-height:1.4}
.dropzone__file{display:block;font-size:13.5px;color:#14532D;margin-top:6px;word-break:break-all;font-weight:600}
.dropzone__remove{position:absolute;top:12px;right:12px;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-sm);padding:5px 9px;font-size:12px;cursor:pointer;color:var(--c-ink-700);display:none;z-index:2}
.dropzone.is-filled .dropzone__remove{display:inline-flex;align-items:center;gap:4px}

/* Review */
.review{display:grid;gap:0;background:var(--c-bg);border:1px solid var(--c-line);border-radius:var(--r-md);padding:0 18px;margin-bottom:6px}
.review__row{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px dashed var(--c-line);font-size:14px}
.review__row:last-child{border-bottom:0}
.review__key{color:var(--c-ink-500);font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:.04em}
.review__val{color:var(--c-ink-900);word-break:break-word}
.review__val--empty{color:var(--c-ink-300);font-style:italic}
.review__edit{appearance:none;background:transparent;border:1px solid var(--c-line);border-radius:var(--r-sm);padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;color:var(--c-navy-700);transition:background .15s var(--ease),border-color .15s var(--ease)}
.review__edit:hover{background:var(--c-navy-50);border-color:#DCE7F3}
@media(max-width:560px){.review__row{flex-wrap:wrap;gap:8px}.review__body{flex:1 1 100%;order:1}.review__thumb{order:0}.review__edit{order:2;margin-left:auto}}

/* Wizard nav */
.wizard__nav{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px 32px 22px;border-top:1px solid var(--c-line);background:var(--c-bg)}
.wizard__nav[hidden]{display:none}
.wizard__step-indicator{color:var(--c-ink-500);font-size:13px;font-variant-numeric:tabular-nums}
.wizard__step-indicator strong{color:var(--c-navy-800);font-weight:800}
@media(max-width:560px){.wizard__step-indicator{display:none}.wizard__nav{padding:14px 18px}}

/* Success */
.step--success{padding:8px 4px}
.success{text-align:center;padding:12px 0}
.success__icon{width:72px;height:72px;border-radius:50%;background:var(--c-success-100);color:var(--c-success);display:grid;place-items:center;margin:0 auto 18px;animation:successIn .4s cubic-bezier(.2,1.5,.3,1)}
@keyframes successIn{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}
.success__title{font-family:var(--ff-display);font-size:24px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px;color:var(--c-ink-900)}
.success__lede{color:var(--c-ink-700);margin:0 0 18px;font-size:15px}
.success__ref{display:inline-flex;flex-direction:column;align-items:center;gap:4px;padding:12px 20px;background:var(--c-bg);border:1px dashed var(--c-line);border-radius:var(--r-md);margin-bottom:22px}
.success__ref span{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--c-ink-500)}
.success__ref code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:18px;color:var(--c-ink-900);font-weight:700;letter-spacing:.04em}
.success__next{list-style:none;padding:0;margin:0 auto 26px;text-align:left;max-width:420px;display:grid;gap:10px}
.success__next li{position:relative;padding:10px 14px 10px 38px;background:#fff;border:1px solid var(--c-line);border-radius:var(--r-md);font-size:13.5px;color:var(--c-ink-700)}
.success__next li::before{content:"";position:absolute;left:14px;top:14px;width:14px;height:14px;border-radius:50%;background:var(--c-navy-50);border:2px solid var(--c-navy-700)}
.success__next strong{color:var(--c-ink-900)}
.success__actions{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}

/* Footer */
.footer{background:#fff;border-top:1px solid var(--c-line);padding:16px 0}
.footer__inner{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;color:var(--c-ink-500);font-size:12.5px}
.footer__sep{color:var(--c-ink-300)}
.footer__inner a{color:var(--c-ink-700)}

/* Floating help */
.fab{position:fixed;right:20px;bottom:20px;display:inline-flex;align-items:center;gap:8px;padding:11px 16px;border-radius:var(--r-full);background:var(--c-navy-800);color:#fff;border:0;font-weight:600;font-size:13.5px;cursor:pointer;box-shadow:0 12px 28px rgba(11,58,111,.32);z-index:50;transition:transform .12s var(--ease),box-shadow .2s var(--ease)}
.fab:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(11,58,111,.42)}
.fab:focus-visible{outline:none;box-shadow:0 12px 28px rgba(11,58,111,.32),var(--sh-focus)}
@media(max-width:560px){.fab span{display:none}.fab{padding:12px;width:48px;height:48px;justify-content:center}}

/* Modals */
.modal{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:20px}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(7,38,77,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:fadeIn .2s var(--ease)}
.modal__panel{position:relative;max-width:460px;width:100%;background:#fff;border-radius:var(--r-lg);padding:28px;box-shadow:0 30px 60px rgba(7,38,77,.35);animation:panelIn .25s var(--ease)}
.modal__panel--lg{max-width:720px}
.modal__close{position:absolute;top:12px;right:12px;background:transparent;border:0;cursor:pointer;width:36px;height:36px;border-radius:50%;color:var(--c-ink-500);font-size:22px;line-height:1;display:grid;place-items:center}
.modal__close:hover{background:var(--c-line-2);color:var(--c-ink-900)}
.modal__icon{width:56px;height:56px;border-radius:16px;background:var(--c-amber-50);color:#8a5a00;display:grid;place-items:center;margin-bottom:14px}
.modal__title{font-family:var(--ff-display);font-weight:800;font-size:22px;margin:0 0 8px;letter-spacing:-.01em}
.modal__body{color:var(--c-ink-700);margin:0 0 18px}
.modal__scroll{max-height:50vh;overflow:auto;padding-right:4px;color:var(--c-ink-700);font-size:14.5px;line-height:1.6}
.modal__scroll h3{font-family:var(--ff-display);font-size:15px;margin:14px 0 6px;color:var(--c-ink-900)}
.modal__scroll ul{padding-left:20px;margin:6px 0}
.modal__scroll li{margin:3px 0}
.modal__scroll ol{padding-left:20px;margin:6px 0}
.modal__actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:6px}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes panelIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}

/* Toast */
.toast{position:fixed;left:50%;bottom:80px;transform:translateX(-50%);background:var(--c-ink-900);color:#fff;padding:11px 16px;border-radius:var(--r-md);display:inline-flex;align-items:center;gap:8px;font-size:14px;box-shadow:var(--sh-3);z-index:90;animation:toastIn .25s var(--ease)}
.toast[hidden]{display:none}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%,0)}}

@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}}

/* ----- Review-step thumbnails (added with the initial form) ----- */
.review__row{align-items:center;}
.review__row--upload{gap:12px;}
.review__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;}
.review__thumb{
  flex:0 0 56px; width:56px; height:56px; border-radius:10px;
  display:grid; place-items:center; overflow:hidden;
  background:#F1F5F9; border:1px solid #E2E8F0;
  color:#64748B;
}
.review__thumb--img img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.review__thumb--pdf{
  background:linear-gradient(180deg,#FEE2E2,#FECACA);
  border-color:#FCA5A5; color:#B91C1C;
}
.review__thumb-badge{
  font-family:var(--ff-mono,JetBrains Mono,monospace); font-weight:800;
  font-size:11px; letter-spacing:.06em;
}
.review__thumb--empty{ color:#CBD5E1; }
@media (max-width:560px){
  .review__thumb{ flex:0 0 44px; width:44px; height:44px; }
}
.review__edit{flex:0 0 auto}
/* defensive override: ensure non-thumb review rows lay out correctly */
.review #review .review__row { display: flex !important; align-items: center; gap: 12px; }
.review #review .review__row > .review__body { flex: 1 1 auto !important; min-width: 0; }
.review #review .review__row > .review__edit { flex: 0 0 auto !important; width: auto !important; }
/* ----- Off-window (closed / pending / full) full-page message ----- */
.off-window-page{
  min-height:100vh; display:flex; flex-direction:column;
  background:#F8FAFC;
}
.off-window__brand{ background:#fff; border-bottom:1px solid #E2E8F0; }
.off-window__brand-link{
  max-width:880px; margin:0 auto;
  display:flex; align-items:center; justify-content:center; gap:12px;
  padding:18px 20px; text-decoration:none; color:#0F172A;
}
.off-window__brand-logo{ height:40px; width:auto; }
.off-window__brand-text{ display:flex; flex-direction:column; line-height:1.15; }
.off-window__brand-text strong{
  font-family:"Manrope",sans-serif; font-weight:800;
  font-size:16px; color:#0B3A6F;
}
.off-window__brand-text span{ font-size:12px; color:#64748B; font-weight:600; }

.off-window__panel{
  max-width:600px; margin:48px auto 32px; padding:42px 32px;
  background:#fff; border:1px solid #E2E8F0; border-radius:18px;
  box-shadow:0 12px 40px rgba(15,23,42,.08);
  text-align:center;
}
.off-window__panel--pending{ border-top:4px solid #0B3A6F; }
.off-window__panel--closed { border-top:4px solid #64748B; }
.off-window__panel--full   { border-top:4px solid #B45309; }

.off-window__icon{
  width:72px; height:72px; margin:0 auto 18px;
  display:grid; place-items:center; border-radius:50%;
  background:#EEF4FB; color:#0B3A6F;
}
.off-window__panel--full .off-window__icon{ background:#FEF3C7; color:#B45309; }
.off-window__panel--closed .off-window__icon{ background:#F1F5F9; color:#475569; }

.off-window__title{
  font-family:"Manrope",sans-serif; font-weight:800;
  font-size:24px; color:#0B3A6F; margin:0 0 12px; letter-spacing:-.01em;
}
.off-window__body{
  font-size:15.5px; color:#475569; line-height:1.55; margin:0 0 18px;
}
.off-window__when{
  display:inline-block; padding:8px 14px; border-radius:999px;
  background:#EEF4FB; color:#0B3A6F; font-weight:700; font-size:13px; margin-bottom:18px;
}
.off-window__actions{ margin-top:18px; }

.off-window__footer{
  margin-top:auto; padding:18px 20px; text-align:center;
  color:#94A3B8; font-size:12.5px;
}

@media(max-width:560px){
  .off-window__panel{ margin:24px 16px; padding:32px 22px; border-radius:14px; }
  .off-window__title{ font-size:21px; }
}
/* Currently accepting … line on CTE welcome */
.welcome__open{
  margin:14px 0 4px; padding:10px 14px;
  background:#ECFDF5; border:1px solid #A7F3D0; color:#065F46;
  border-radius:10px; font-size:14px;
}
.welcome__open strong{ color:#064E3B; }
/* ----- Type picker (CTE step 2) ----- */
.type-picker{ display:flex; flex-direction:column; gap:10px; margin-top:12px; }
.type-card{
  position:relative; display:flex; align-items:center; gap:14px;
  padding:14px 18px; border:1.5px solid #E2E8F0; border-radius:14px;
  background:#fff; cursor:pointer; transition:all .15s ease;
}
.type-card:hover{ border-color:#93C5FD; background:#F8FAFC; }
.type-card input[type="radio"]{ position:absolute; opacity:0; pointer-events:none; }
.type-card.is-selected{ border-color:#0B3A6F; background:#EEF4FB; box-shadow:0 0 0 3px rgba(11,58,111,.10); }
.type-card__body{ display:flex; flex-direction:column; gap:4px; flex:1; min-width:0; }
.type-card__name{ font-weight:700; color:#0F172A; font-size:16px; line-height:1.25; }
.type-card__sub{ color:#64748B; font-size:13px; line-height:1.3; }
.type-card__check{
  width:28px; height:28px; border-radius:50%;
  display:grid; place-items:center;
  background:#F1F5F9; color:#94A3B8; flex:0 0 28px;
  transition:all .15s ease;
}
.type-card.is-selected .type-card__check{ background:#0B3A6F; color:#fff; }
@media(max-width:560px){
  .type-card{ padding:12px 14px; gap:10px; }
  .type-card__name{ font-size:15px; }
}

/* ---- Course dropdown — viewport-aware so it never gets clipped ---- */
.choices__list--dropdown,
.choices__list[aria-expanded]{
  max-height: min(340px, 50vh) !important;
  z-index: 60 !important;
}
.choices__list--dropdown .choices__list{
  max-height: min(280px, 42vh) !important;
  overflow-y: auto !important;
}
/* Open upward visually if Choices flips */
.choices.is-flipped .choices__list--dropdown{
  margin-top: 0 !important; margin-bottom: 8px !important;
}


/* ============================================================
   Slot-reservation countdown chip
   - Slim, sticky at top of viewport, mobile-first sizing.
   - Color shifts blue → amber when <= 60s, → red when 0.
   - Tap targets ≥ 40px to satisfy iOS/Android touch-area minimums.
   ============================================================ */
.res-chip {
  position: fixed;
  top: max(8px, env(safe-area-inset-top));
  left: 50%;
  transform: translateX(-50%);
  z-index: 50;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: #0B3A6F;
  color: #fff;
  font: 600 14px/1 "Inter", system-ui, sans-serif;
  box-shadow: 0 6px 18px rgba(11, 58, 111, 0.35);
  max-width: calc(100vw - 16px);
  white-space: nowrap;
  transition: background-color .2s ease;
}
.res-chip__icon {
  display: inline-flex;
  align-items: center;
  color: #cfe1ff;
}
.res-chip__label {
  opacity: 0.85;
  font-weight: 500;
}
.res-chip__time {
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.res-chip__btn {
  appearance: none;
  border: 0;
  margin-left: 4px;
  padding: 8px 12px;
  min-height: 40px;
  border-radius: 999px;
  background: #fff;
  color: #0B3A6F;
  font: 700 13px/1 "Inter", system-ui, sans-serif;
  cursor: pointer;
  white-space: nowrap;
}
.res-chip__btn:hover  { background: #f1f5fb; }
.res-chip__btn:active { transform: translateY(1px); }
.res-chip__btn:disabled { opacity: 0.6; cursor: progress; }

.res-chip--warn {
  background: #B45309;     /* amber-700 */
  box-shadow: 0 6px 18px rgba(180, 83, 9, 0.4);
}
.res-chip--warn .res-chip__icon { color: #fde68a; }
.res-chip--warn .res-chip__btn  { background: #fff; color: #B45309; }

.res-chip--expired {
  background: #991B1B;     /* red-800 */
}
.res-chip--expired .res-chip__btn { display: none; }

.res-chip--maxed .res-chip__btn { display: none; }

/* Unit label ("mins"). Sits between the timer and the extend button. */
.res-chip__unit {
  font-weight: 500;
  opacity: 0.85;
  margin-left: 2px;
}

@media (max-width: 480px) {
  /* Pin the chip to the top-right corner on mobile rather than centering
     it across the viewport — it reads as a header element rather than a
     full-width banner, which matches the visual weight the rest of the
     app uses on small screens. */
  .res-chip {
    left: auto;
    right: max(8px, env(safe-area-inset-right));
    transform: none;
    padding: 6px 10px;
    font-size: 13px;
    gap: 6px;
    max-width: calc(100vw - 16px);
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  /* Label stays visible on mobile (intentional change from the original
     pass — the standalone timer was ambiguous without context). */
  .res-chip__label { display: inline; }
  .res-chip__btn   { padding: 6px 10px; font-size: 12px; min-height: 36px; }
}

@media (max-width: 360px) {
  /* Very small viewports: drop the icon to claw back enough width that
     "Complete in 4:32 mins" + the extend button still fit on one line
     without wrapping into an awkward two-row chip. */
  .res-chip__icon { display: none; }
}

/* Push the top of the wizard down so the chip doesn't overlap the first
   line of the form. Only applies when the chip is in the DOM. */
body:has(.res-chip) .app__shell,
body:has(.res-chip) .step__inner,
body:has(.res-chip) main {
  scroll-margin-top: 64px;
}
