/* ============================================================
   Onyou — shared design system
   Warm-neutral frame + one coral pop, so the user's own palette
   and face stay the brightest thing on screen. Tokens mirror
   branding/onyou-design-system.html :root.
   (WP-0.1 — re-tokenise only: structure/selectors unchanged.)
   ============================================================ */
:root{
  /* surfaces */
  --cream:#FDF6EF;        /* base — input + reading */
  --cream-2:#F6EDE2;      /* raised on cream / app backdrop */
  --bone:#FFFCF8;         /* inputs */
  --blush:#FCE8DF;        /* gentle "moment" surface (loader, reveal) */
  --coral:#FF6B6B;        /* THE pop — primary actions, energy grounds */
  --coral-d:#ED5757;      /* coral hover / depth */
  --coral-soft:#FF9A8B;
  --sun:#FFC15E;          /* rare micro-accent */
  /* ink + neutrals */
  --ink:#2A211E;          /* warm dark — type + structural bars */
  --ink-soft:#4A3F39;
  --muted:#9C8F84;
  --rule:#ECE2D7;
  /* verdicts (warmed) */
  --best:#3E7A5A; --good:#E0A43B; --avoid:#C2453B;
  /* type */
  --display:"Fraunces",Georgia,serif;
  --ui:"Hanken Grotesk",system-ui,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
  /* legacy aliases — mapped to the new system so any stray reference still
     resolves during the re-skin. Do NOT use these in new code. */
  --green:#2A211E; --green2:#4A3F39; --maroon:#C2453B; --board:#F6EDE2;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream-2);
  font-family:var(--ui);color:var(--ink);
  -webkit-font-smoothing:antialiased;
}
.display{font-family:var(--display)}

/* deliberate focus rings (coral, 2px offset) — not browser defaults */
:focus-visible{outline:2px solid var(--coral);outline-offset:2px;border-radius:2px}

/* ---------- intake / upload screen ---------- */
.intake-wrap{max-width:760px;margin:0 auto;padding:48px 24px 80px}
.brandmark{text-align:center;margin-bottom:8px}
.brandmark .logo{font-family:var(--display);font-size:44px;font-weight:600;letter-spacing:.5px}
.brandmark .brand-lockup{width:210px;max-width:72%;height:auto;margin:0 auto 4px;display:block}
.brandmark .tag{letter-spacing:4px;font-size:12px;text-transform:uppercase;color:var(--muted);margin-top:4px}
.intake-card{background:var(--cream);border:1px solid var(--rule);padding:40px 40px 44px;margin-top:28px;border-radius:14px}
.intake-card h2{font-family:var(--display);font-weight:600;font-size:34px;margin-bottom:6px}
.intake-card .lead{color:var(--ink-soft);font-weight:300;font-size:16px;line-height:1.55;margin-bottom:26px}
.field{margin-bottom:20px}
.field label{display:block;letter-spacing:2px;text-transform:uppercase;font-size:12px;color:var(--muted);margin-bottom:8px;font-weight:500}
.field input[type=text],.field select,.field textarea{
  width:100%;padding:12px 14px;border:1px solid var(--rule);background:var(--bone);
  font-family:var(--ui);font-size:15px;color:var(--ink);border-radius:9px;
}
.field textarea{min-height:72px;resize:vertical;line-height:1.5}
.field .hint{font-size:12px;color:var(--muted);margin-top:6px;font-weight:300}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}

.dropzone{border:1.5px dashed var(--coral-soft);background:var(--bone);border-radius:14px;
  padding:30px;text-align:center;cursor:pointer;transition:.15s;position:relative}
.dropzone:hover,.dropzone.drag{background:var(--blush);border-color:var(--coral)}
.dropzone p{color:var(--muted);font-size:14px;margin-top:8px}
.dropzone .big{font-family:var(--display);font-size:22px;color:var(--ink)}
.dropzone input{display:none}
.preview-thumb{width:118px;height:148px;object-fit:cover;border-radius:8px;margin:0 auto 4px;display:block;border:1px solid var(--rule)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--coral);color:#fff;border:none;padding:15px 30px;
  font-family:var(--ui);letter-spacing:.01em;font-weight:700;font-size:14px;
  cursor:pointer;border-radius:100px;transition:.15s}
.btn:hover{background:var(--coral-d)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn.ghost:hover{background:rgba(42,33,30,.06)}
.actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px;align-items:center}
.consent{display:flex;gap:10px;align-items:flex-start;margin-top:22px;font-size:13px;color:var(--ink-soft);font-weight:300;line-height:1.5}
.consent input{margin-top:3px;width:18px;height:18px;accent-color:var(--coral);flex:none}

.status{margin-top:22px;padding:14px 16px;border-radius:9px;font-size:14px;line-height:1.5;display:none}
.status.show{display:block}
.status.info{background:var(--blush);color:var(--ink-soft);border:1px solid var(--rule)}
.status.err{background:#FBE6E2;color:var(--avoid);border:1px solid #F0C9C2}
.spinner{width:16px;height:16px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;display:inline-block;animation:spin .7s linear infinite;vertical-align:-3px;margin-right:8px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- report ---------- */
#report{display:none;padding:24px 0 60px}
#report.show{display:block}
.report-bar{position:sticky;top:0;z-index:20;background:rgba(246,237,226,.92);backdrop-filter:blur(6px);
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;padding:14px;border-bottom:1px solid var(--rule)}

/* page card */
.page{width:1080px;max-width:calc(100vw - 32px);background:var(--cream);border-radius:14px;
  margin:24px auto;box-shadow:0 8px 40px rgba(42,33,30,.10);position:relative}
.page-inner{padding:64px 64px 56px}
@media(max-width:1140px){
  .page{transform-origin:top center}
}
h1.page-title{font-family:var(--display);font-weight:600;font-size:72px;text-align:center;letter-spacing:.5px;line-height:1.02}
.sub{text-align:center;letter-spacing:3px;font-size:15px;font-weight:400;color:var(--muted);text-transform:uppercase;margin:8px 0 34px}
.hr{height:1px;background:var(--rule);margin:0 120px 34px}
.top{display:grid;grid-template-columns:440px 1fr;gap:34px;align-items:start}
@media(max-width:720px){.top{grid-template-columns:1fr}}
.photo{width:100%;max-width:440px;aspect-ratio:440/560;object-fit:cover;border-radius:8px}
.seasonbar{background:var(--ink);color:var(--cream);padding:20px 26px;text-align:center;border-radius:10px}
.seasonbar .lab{letter-spacing:3px;font-size:13px;opacity:.85;text-transform:uppercase}
.seasonbar .name{font-family:var(--display);font-size:46px;font-weight:600;line-height:1.05;margin:6px 0 8px}
.seasonbar .kw{letter-spacing:2px;font-size:14px;opacity:.9}
.desc{font-size:18px;line-height:1.6;color:var(--ink-soft);margin:18px 4px 20px;font-weight:300}
.prow{display:flex;justify-content:space-between;padding:11px 4px;border-bottom:1px solid var(--rule);font-size:16px;gap:14px}
.pk{color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-size:13px;align-self:center}
.pv{font-weight:500;text-align:right}
.section-eyebrow{text-align:center;letter-spacing:3px;font-size:14px;color:var(--muted);text-transform:uppercase;margin:42px 0 22px}
.grids{display:grid;grid-template-columns:1fr 1fr;gap:30px 46px;margin-top:8px}
@media(max-width:720px){.grids{grid-template-columns:1fr}}
.gtitle{background:var(--ink);color:var(--cream);text-align:center;letter-spacing:2px;font-size:13px;text-transform:uppercase;padding:8px;border-radius:7px}
.gcap{text-align:center;font-size:13px;color:var(--muted);margin:6px 0 12px;font-weight:300}
.row{display:flex;gap:0;flex-wrap:wrap}
.sw{flex:1 0 12%;text-align:center}
.sw span{display:block;height:70px}
.sw label{display:block;font-size:11px;color:var(--muted);margin-top:6px;letter-spacing:.3px;line-height:1.25}
.avoid-h{text-align:center;letter-spacing:2px;font-size:13px;color:var(--avoid);text-transform:uppercase;margin:40px 0 12px;font-weight:600}
.avoid-row{display:flex;flex-wrap:wrap}
.avoid-row span{flex:1 0 10%;height:58px;min-width:9%}
.foot{text-align:center;font-size:11px;color:var(--muted);letter-spacing:2px;margin-top:36px;text-transform:uppercase;font-family:var(--mono)}

/* generic blocks reused across pages */
.lede{font-size:18px;line-height:1.62;color:var(--ink-soft);font-weight:300;text-align:center;max-width:760px;margin:0 auto 30px}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:28px 40px}
.cols3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px}
@media(max-width:720px){.cols2,.cols3{grid-template-columns:1fr}}
.block .bt{background:var(--ink-soft);color:var(--cream);text-align:center;letter-spacing:2px;font-size:12px;text-transform:uppercase;padding:8px;margin-bottom:14px;border-radius:7px}
.itemline{padding:10px 2px;border-bottom:1px solid var(--rule)}
.itemline .h{font-weight:500;font-size:16px}
.itemline .w{color:var(--muted);font-size:14px;font-weight:300;line-height:1.45;margin-top:2px}
.chip{display:inline-block;border:1px solid var(--rule);background:var(--bone);padding:7px 14px;border-radius:100px;font-size:13px;margin:0 8px 8px 0;letter-spacing:.4px}
.steps{counter-reset:s;list-style:none}
.steps li{counter-increment:s;position:relative;padding:11px 2px 11px 42px;border-bottom:1px solid var(--rule);font-size:16px;font-weight:300;line-height:1.45}
.steps li::before{content:counter(s);position:absolute;left:0;top:10px;width:28px;height:28px;border-radius:50%;background:var(--ink);color:var(--cream);font-size:13px;display:flex;align-items:center;justify-content:center;font-weight:500}

/* draping */
.drape3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px;margin-top:8px}
@media(max-width:720px){.drape3{grid-template-columns:1fr}}
.drapecard{text-align:center}
.drapecard .swatchphoto{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:3/4}
.drapecard .swatchphoto img{width:100%;height:62%;object-fit:cover;object-position:center top;display:block}
.drapecard .swatchphoto .drape-fill{height:38%;display:flex;align-items:center;justify-content:center}
.drapecard .verdict{letter-spacing:2px;font-size:12px;text-transform:uppercase;padding:9px;margin-top:0;display:flex;align-items:center;justify-content:center;gap:7px}
.verdict-best{background:var(--best);color:#fff}
.verdict-good{background:var(--good);color:var(--ink)}
.verdict-avoid{background:var(--avoid);color:#fff}
.vglyph{font-weight:700;font-size:13px}
.drapecard ul{list-style:none;text-align:left;margin-top:12px}
.drapecard ul li{font-size:13px;color:var(--ink-soft);font-weight:300;padding:5px 0 5px 18px;position:relative;line-height:1.4}
.drapecard ul li::before{content:"";position:absolute;left:0;top:11px;width:6px;height:6px;border-radius:50%;background:var(--ink-soft)}
.drapename{font-family:var(--display);font-size:24px;margin-top:10px}

/* hairstyles grid */
.hairgrid{display:grid;grid-template-columns:1fr 1fr;gap:24px 36px;margin-top:10px}
@media(max-width:720px){.hairgrid{grid-template-columns:1fr}}
.hairstyle .hs-name{font-family:var(--display);font-size:26px;margin-bottom:8px}
.hairstyle ul{list-style:none}
.hairstyle ul li{font-size:14px;color:var(--ink-soft);font-weight:300;padding:5px 0 5px 18px;position:relative;line-height:1.4}
.hairstyle ul li::before{content:"✓";position:absolute;left:0;color:var(--best);font-size:12px;top:6px}

.swatch-strip{display:flex;flex-wrap:wrap;gap:0;margin-top:8px}
.swatch-strip .sw{flex:1 0 16%}

.note-card{background:var(--blush);border-left:3px solid var(--coral);padding:16px 20px;font-size:15px;font-weight:300;line-height:1.55;color:var(--ink-soft);margin-top:24px;border-radius:0 8px 8px 0}

/* mood / cohesion */
.icons3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:22px;margin-top:10px}
@media(max-width:720px){.icons3{grid-template-columns:1fr}}
.iconcard{border:1px solid var(--rule);background:var(--bone);padding:20px;text-align:center;border-radius:10px}
.iconcard .nm{font-family:var(--display);font-size:23px}
.iconcard .wy{color:var(--muted);font-size:13px;font-weight:300;margin-top:6px;line-height:1.45}
.identity{font-family:var(--display);font-style:italic;font-size:30px;text-align:center;line-height:1.3;color:var(--ink);margin:30px auto 0;max-width:820px}

.disclaimer{max-width:1080px;margin:8px auto 0;text-align:center;font-size:12px;color:var(--muted);font-weight:300;line-height:1.5;padding:0 24px}

/* ---------- friendly AI features card ---------- */
.ai-card{border:1px solid var(--rule);border-radius:14px;background:var(--cream-2);margin-top:24px;padding:22px 22px 20px}
.ai-head{font-family:var(--display);font-size:26px;font-weight:600;display:flex;align-items:center;gap:10px}
.ai-head .opt{font-family:var(--ui);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);border:1px solid var(--rule);padding:3px 9px;border-radius:100px}
.ai-intro{color:var(--ink-soft);font-weight:300;font-size:15px;line-height:1.55;margin:8px 0 18px}
.ai-intro em{font-style:italic}
.ai-toggles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.ai-toggles{grid-template-columns:1fr}}
.ai-toggle{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--rule);background:var(--bone);border-radius:10px;padding:14px;cursor:pointer;transition:.12s}
.ai-toggle:hover{border-color:var(--coral);background:var(--cream)}
.ai-toggle input{margin-top:3px;width:18px;height:18px;accent-color:var(--coral);flex:none}
.ai-toggle b{display:block;font-weight:600;font-size:15px;letter-spacing:.2px}
.ai-toggle small{display:block;color:var(--muted);font-weight:300;font-size:13px;line-height:1.4;margin-top:2px}
.ai-foot{font-size:13px;color:var(--muted);font-weight:300;margin-top:16px}

/* ---------- preview-mode banner inside the report ---------- */
.report-notice{max-width:1080px;margin:14px auto 0;background:#FCEFD8;border:1px solid #F0D9A8;color:#7a5a1f;
  border-radius:9px;padding:13px 18px;font-size:14px;font-weight:300;line-height:1.5}
.report-notice b{font-weight:600}

/* ---------- generative settings panel (legacy, unused) ---------- */
.gen-settings{border:1px solid var(--rule);border-radius:9px;background:var(--bone);margin-top:24px;overflow:hidden}
.gen-settings summary{cursor:pointer;padding:16px 18px;font-weight:500;letter-spacing:.5px;list-style:none}
.gen-settings summary::-webkit-details-marker{display:none}
.gen-settings .muted-note{color:var(--muted);font-weight:300;font-size:13px;letter-spacing:0}
.gen-body{padding:6px 18px 20px;border-top:1px solid var(--rule)}
.toggles{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:560px){.toggles{grid-template-columns:1fr}}
.toggles label{display:flex;gap:9px;align-items:center;font-size:14px;color:var(--ink-soft);font-weight:300;text-transform:none;letter-spacing:0;border:1px solid var(--rule);padding:11px 13px;border-radius:9px;background:var(--bone);cursor:pointer}
.gen-settings input[type=range]{width:100%;accent-color:var(--coral)}
.gen-settings input[type=file]{font-size:13px}

/* generated images dropped into pages */
.gen-full{width:100%;height:auto;display:block;border-radius:8px}
.drapecard .swatchphoto .gen-full{height:100%;object-fit:cover;border-radius:0}
.hairstyle .hs-photo{margin-bottom:10px}
.hairstyle .hs-photo:empty{display:none}
.hairstyle .hs-photo .gen-full{aspect-ratio:3/4;object-fit:cover}

/* re-roll button on each generated image */
.gen-wrap{position:relative;display:block;width:100%}
.gen-wrap .gen-full{display:block;width:100%}
.drapecard .swatchphoto .gen-wrap{height:100%}
.drapecard .swatchphoto .gen-wrap .gen-full{height:100%;object-fit:cover}
.reroll{position:absolute;top:8px;right:8px;width:44px;height:44px;border-radius:50%;border:none;
  background:rgba(42,33,30,.72);color:var(--cream);font-size:18px;cursor:pointer;display:flex;align-items:center;
  justify-content:center;line-height:1;transition:.18s;z-index:2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.reroll:hover{background:rgba(42,33,30,.96);transform:rotate(90deg)}
@media print{.reroll,.no-export{display:none !important}}

/* shimmer placeholders while AI images generate (coral-tinted skeleton) */
.shimmer{width:100%;aspect-ratio:3/4;border-radius:8px;background:linear-gradient(100deg,#F6E2DA 30%,#FCE8DF 50%,#F6E2DA 70%);background-size:200% 100%;animation:shim 1.3s ease-in-out infinite}
.drapecard .swatchphoto .shimmer{height:100%;aspect-ratio:auto;border-radius:0}
@keyframes shim{0%{background-position:200% 0}100%{background-position:-200% 0}}
.gen-fail{width:100%;aspect-ratio:3/4;border-radius:8px;background:#F6E2DE;color:var(--avoid);display:flex;align-items:center;justify-content:center;font-size:13px;letter-spacing:.3px}
img.photo.gen-loading{animation:pulse 1.3s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}

/* branded analysis loader (full-screen while Sonnet writes) — blush moment surface */
.analyze-loader{position:fixed;inset:0;z-index:80;background:var(--blush);display:none;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px}
.analyze-loader.show{display:flex}
.al-logo{font-family:var(--display);font-size:40px;font-weight:600}
.al-wordmark{width:128px;height:auto;display:block;margin:0 auto}
.al-tag{letter-spacing:4px;font-size:11px;text-transform:uppercase;color:var(--muted);margin:4px 0 34px}
/* colour-wheel loader (screen 04) — a warm wheel that RESOLVES into the palette as
   real stream progress lands. Distinct object from the brand ring mark (never the mark
   as a spinner): the disc spins, a cover unveils it clockwise by % (set in setPhase),
   the hole keeps it a donut. */
.al-wheel{width:104px;height:104px;border-radius:50%;position:relative;margin:6px auto 2px}
.al-wheel-disc{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(var(--coral),var(--sun),#EBD3A6,var(--blush),var(--coral-soft),var(--coral));
  animation:wheelspin 8s linear infinite}
.al-wheel-cover{position:absolute;inset:0;border-radius:50%;
  background:conic-gradient(transparent 8%, var(--blush) 8%);transition:background .5s ease}
.al-wheel-hole{position:absolute;inset:13px;border-radius:50%;background:var(--blush)}
@keyframes wheelspin{to{transform:rotate(360deg)}}
.al-phase{font-family:var(--display);font-style:italic;font-size:26px;margin:28px 0 6px;min-height:34px;transition:opacity .3s}
.al-bar{width:min(340px,80vw);height:4px;background:var(--cream-2);border-radius:4px;overflow:hidden;margin:6px 0 28px}
.al-bar span{display:block;height:100%;width:0;background:var(--coral);transition:width .6s ease}
.al-tip{max-width:440px;color:var(--ink-soft);font-weight:300;font-size:15px;line-height:1.5;font-style:italic;min-height:46px;transition:opacity .4s}

/* makeup looks + styled looks slots */
.makeup-looks .ml-card{text-align:center}
.makeup-looks .hs-photo .gen-full{aspect-ratio:3/4;object-fit:cover;border-radius:8px}
.makeup-looks .gcap{margin-top:8px}
#outfitGallery .gen-full,#genGallery .gen-full{aspect-ratio:3/4;object-fit:cover}

/* progress toast */
.gen-progress{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:60;
  background:var(--ink);color:var(--cream);padding:13px 20px;border-radius:100px;font-size:14px;
  display:none;align-items:center;gap:10px;box-shadow:0 8px 30px rgba(42,33,30,.25);max-width:90vw}
.gen-progress.show{display:flex}
.gen-progress .gen-log{font-weight:300}
.gen-progress .gen-x{background:none;border:none;color:var(--cream);font-size:20px;line-height:1;cursor:pointer;opacity:.8;padding:0 2px}
.gen-progress .gen-x:hover{opacity:1}

/* print -> PDF */
@media print{
  body{background:#fff}
  .intake-wrap,.report-bar,.disclaimer-screen{display:none !important}
  #report{display:block !important;padding:0}
  .page{box-shadow:none;margin:0 auto;page-break-after:always;width:1080px;max-width:none;border-radius:0}
  .page:last-child{page-break-after:auto}
}

/* respect reduced-motion: degrade animation/transition to instant */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;
  }
}
