/* ============================================================
   SIZELY — auth pages v2 (login · signup · password recovery · verify)
   Pre-login layout archetype: proof-first showcase (left) + form (right).
   Tokens + base reset come from /css/sz-app.css. This file holds only
   the auth-specific layout + components, ported from public/app-auth.html.
   ============================================================ */
:root{--warn:#e8730c;--amber:#b88500}
body{background:var(--paper);min-height:100vh;height:auto;overflow:hidden auto;overflow-x:hidden}

/* ---- layout: split panel ---- */
.auth{display:grid;grid-template-columns:1.04fr 1fr;min-height:100vh}

/* ---- LEFT: proof-first showcase (leads with a real composited chart) ---- */
.brand{position:relative;overflow:hidden;color:var(--ink);padding:40px 46px;display:flex;flex-direction:column;justify-content:space-between;border-right:1px solid var(--border);
  background:radial-gradient(760px 420px at 72% -12%,#fff,rgba(255,255,255,0) 60%),linear-gradient(165deg,var(--alice) 0%,#f3f7fe 56%,#e9f0fd 100%)}
.brand::before{content:"";position:absolute;width:380px;height:380px;border-radius:50%;top:-150px;right:-120px;background:radial-gradient(circle,rgba(38,95,247,.10),transparent 70%)}
.brand::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;bottom:-120px;left:-90px;background:radial-gradient(circle,rgba(38,95,247,.07),transparent 70%)}
.wordmark{display:flex;align-items:center;gap:10px;font-weight:800;font-size:21px;letter-spacing:-.03em;position:relative;z-index:1;color:var(--ink)}
.wordmark .s{width:30px;height:30px;border-radius:9px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800}

/* hero = the composited chart as a floating white card */
.show{position:relative;z-index:1;display:flex;flex-direction:column;align-items:flex-start;gap:18px;margin:6px 0}
.proofline{max-width:30ch;font-size:23px;font-weight:800;letter-spacing:-.025em;line-height:1.18;color:var(--ink);margin:0}
.chartcard{background:#fff;border-radius:20px;box-shadow:var(--sh-card);padding:16px 16px 18px;width:min(360px,92%);align-self:center}
.chead{font-size:13.5px;font-weight:600;color:var(--ink-2);margin:2px 6px 10px;letter-spacing:.01em}
.garment{position:relative;width:100%;aspect-ratio:1/1;margin:0 auto;user-select:none}
.garment canvas{position:absolute;inset:0;width:100%;height:100%;-webkit-user-drag:none}
.garment .skel{position:absolute;inset:8%;border-radius:16px;background:linear-gradient(90deg,#eef1f6 25%,#e3e8f1 37%,#eef1f6 63%);background-size:400% 100%;animation:sh 1.4s ease infinite}
@keyframes sh{0%{background-position:100% 0}100%{background-position:-100% 0}}
.vlab{position:absolute;transform:translate(-50%,-50%);background:#fff;border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-size:11.5px;font-weight:800;color:var(--ink);box-shadow:var(--sh-xs);white-space:nowrap;z-index:2}
.vlab i{font-style:normal;font-weight:600;font-size:8.5px;color:var(--ink-3);margin-left:2px}
.chartcap{font-size:12px;color:var(--ink-3);margin:13px 0 0;display:flex;align-items:center;justify-content:center;text-align:center;gap:6px}
.chartcap [data-icon]{font-size:13px;color:var(--line)}

.proofrow{position:relative;z-index:1;display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--border)}
.proofrow .big{font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.proofrow .lbl{font-size:13px;color:var(--ink-2);line-height:1.4}
.proofrow .stars{display:flex;gap:1px;color:#f5a623;margin-bottom:3px}
.proofrow .stars svg{width:14px;height:14px;fill:currentColor;stroke:none}
.proofrow .sep{width:1px;height:34px;background:var(--border)}

/* ---- RIGHT form panel ---- */
.panel{display:flex;align-items:center;justify-content:center;padding:48px 32px;min-width:0}
.card{width:100%;max-width:392px}
.m-brand{display:none;align-items:center;gap:9px;font-weight:800;font-size:20px;letter-spacing:-.03em;margin-bottom:20px;color:var(--ink)}
.m-brand .s{width:28px;height:28px;border-radius:8px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:800}

/* mobile-only proof hero (same composited chart, above the form) */
.m-hero{display:none}
.m-hero .chartcard{width:100%;max-width:300px;margin:0 auto 4px;padding:13px 13px 15px}
.m-hero .garment{max-height:230px}
.m-hero .vlab{font-size:10.5px;padding:1px 6px}

.back{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;font-weight:600;color:var(--ink-2);background:none;border:0;cursor:pointer;padding:6px 0;margin-bottom:8px;font-family:var(--font);text-decoration:none}
.back svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.back:hover{color:var(--ink)}

.head h1{font-size:clamp(1.5rem,2.6vw,1.9rem);font-weight:800}
.head p{margin:7px 0 0;font-size:14px;color:var(--ink-3);line-height:1.5}
.head p b{color:var(--ink-2);font-weight:700}
.head{margin-bottom:22px}

/* social */
.social{display:flex;flex-direction:column;gap:10px}
.sbtn{display:flex;align-items:center;justify-content:center;gap:10px;height:48px;border:1px solid var(--border-strong);border-radius:var(--r-btn);background:#fff;font-family:var(--font);font-weight:600;font-size:14.5px;color:var(--ink);cursor:pointer;text-decoration:none;transition:.14s}
.sbtn:hover{background:var(--surface)}
.sbtn svg{flex:none}

.divider{display:flex;align-items:center;gap:12px;color:var(--ink-3);font-size:12px;font-weight:600;margin:18px 0}
.divider::before,.divider::after{content:"";height:1px;background:var(--border);flex:1}

/* form */
.form{display:flex;flex-direction:column;gap:15px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12.5px;font-weight:700;color:var(--ink-2)}
.field-wrap{position:relative}
.inp{width:100%;height:48px;background:#fff;border:1px solid var(--border-strong);border-radius:var(--r-input);padding:0 14px;font-family:var(--font);font-size:16px;color:var(--ink);transition:.14s}
.inp:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
.inp::placeholder{color:#707a91}
.field-wrap.has-eye .inp{padding-right:46px}
.eye{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:0;background:transparent;color:var(--ink-3);cursor:pointer;border-radius:8px}
.eye:hover{color:var(--ink-2);background:var(--surface)}
.eye svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.eye .ico-off{display:none}
.eye.on .ico-on{display:none}.eye.on .ico-off{display:block}
.field .err{font-size:11.5px;color:var(--danger);font-weight:600;display:none}
.field.invalid .inp{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-bg)}
.field.invalid .err{display:block}

/* strength meter */
.meter{display:flex;flex-direction:column;gap:6px;margin-top:2px}
.meter .bars{display:flex;gap:5px}
.meter .bars i{flex:1;height:5px;border-radius:99px;background:var(--border);transition:.2s}
.meter.lv1 .bars i:nth-child(-n+1){background:var(--danger)}
.meter.lv2 .bars i:nth-child(-n+2){background:var(--warn)}
.meter.lv3 .bars i:nth-child(-n+3){background:var(--amber)}
.meter.lv4 .bars i:nth-child(-n+4){background:var(--good)}
.meter .hint{font-size:11.5px;color:var(--ink-3)}
.meter .hint b{font-weight:700}
.meter.lv1 .hint b{color:var(--danger)}.meter.lv2 .hint b{color:var(--warn)}
.meter.lv3 .hint b{color:var(--amber)}.meter.lv4 .hint b{color:var(--good)}

/* remember + forgot row */
.row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.check{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:13.5px;color:var(--ink-2);user-select:none}
.check input{position:absolute;opacity:0;width:0;height:0}
.check .box{width:18px;height:18px;border:1px solid var(--border-strong);border-radius:6px;background:#fff;display:inline-flex;align-items:center;justify-content:center;transition:.12s}
.check .box svg{width:12px;height:12px;fill:none;stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;opacity:0}
.check input:checked + .box{background:var(--brand);border-color:var(--brand)}
.check input:checked + .box svg{opacity:1}
.check input:focus-visible + .box{box-shadow:0 0 0 3px var(--brand-soft)}

.link{color:var(--brand);font-weight:600;font-size:13.5px;text-decoration:none;cursor:pointer;background:none;border:0;font-family:var(--font);padding:0}
.link:hover{text-decoration:underline}

/* primary cta */
.cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;height:50px;background:var(--brand);color:#fff;font-family:var(--font);font-weight:600;font-size:15.5px;letter-spacing:-.01em;border:0;border-radius:var(--r-btn);cursor:pointer;box-shadow:var(--sh-xs);transition:.15s;margin-top:2px}
.cta:hover{background:var(--brand-press)}
.cta .arr{transition:transform .15s}.cta:hover .arr{transform:translateX(3px)}
.cta.sec{background:#fff;color:var(--ink);border:1px solid var(--border-strong);box-shadow:none;height:48px;font-weight:600}
.cta.sec:hover{background:var(--surface)}
/* loading state (shown during submit) */
.cta.loading{color:transparent!important;pointer-events:none;position:relative}
.cta.loading .arr{opacity:0}
.cta.loading::after{content:"";position:absolute;top:50%;left:50%;width:18px;height:18px;margin:-9px 0 0 -9px;border:2.5px solid rgba(255,255,255,.5);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
.cta.sec.loading::after{border-color:rgba(38,95,247,.3);border-top-color:var(--brand)}
@keyframes spin{to{transform:rotate(360deg)}}

/* inline form alert (error / info) */
.form-alert{display:flex;gap:9px;align-items:flex-start;border-radius:12px;padding:11px 13px;font-size:13px;line-height:1.45;margin-bottom:16px}
.form-alert[hidden]{display:none}
.form-alert svg{width:17px;height:17px;flex:none;margin-top:1px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.form-alert.error{background:var(--danger-bg);border:1px solid #f4c7c2;color:var(--danger)}
.form-alert.good{background:var(--good-soft);border:1px solid #bfe8cd;color:#14794a}
.form-alert .link{color:inherit;font-weight:700;text-decoration:underline;text-underline-offset:2px}

.alt{margin-top:20px;text-align:center;font-size:13.5px;color:var(--ink-3)}
.legal{margin-top:18px;font-size:11.5px;color:var(--ink-3);text-align:center;line-height:1.55}
.legal a{color:var(--ink-2);text-decoration:underline;text-underline-offset:2px}

/* success states (sent / verify / expired) */
.success{text-align:center}
.success .ring{width:66px;height:66px;border-radius:50%;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;color:var(--brand);margin:0 auto 20px}
.success .ring svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.success .ring.good{background:var(--good-soft);color:var(--good)}
.success .ring.bad{background:var(--danger-bg);color:var(--danger)}
.success h1{font-size:clamp(1.4rem,2.4vw,1.8rem)}
.success .mailto{margin:7px 0 0;font-size:14px;color:var(--ink-3);line-height:1.5}
.success .mailto b{color:var(--ink);font-weight:700}
.success .actions{margin-top:24px;display:flex;flex-direction:column;gap:10px}
.note{margin-top:18px;display:flex;gap:9px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:11px 13px;font-size:12.5px;color:var(--ink-2);line-height:1.45;text-align:left}
.note svg{width:16px;height:16px;flex:none;margin-top:1px;fill:none;stroke:var(--ink-3);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

@media(max-width:900px){
  .auth{grid-template-columns:1fr}
  .brand{display:none}
  .m-brand{display:flex}
  .m-hero{display:block;margin:0 0 22px}
  .panel{padding:34px 22px 96px;align-items:flex-start}
  .card{margin-top:0;max-width:100%}
}
