/* ============================================================
   konuşadur - auth.css  (giriş / kayıt / şifre sıfırlama)
   Orijinal tasarımlardan birebir; kendi içinde tam.
   ============================================================ */
:root{
  --violet:#6938EF;--violet-700:#5326D6;--violet-50:#F6F3FE;
  --amber:#FF7A45;--teal:#12B5A4;--green:#16A34A;--red:#E5484D;--gold:#E8A317;
  --ink:#17131F;--body:#3C3850;--muted:#6E6A80;--faint:#9A96AC;
  --paper:#F4F3FA;--card:#FFFFFF;--card-2:#FAF9FE;
  --line:#EAE8F2;--line-2:#F1EFF8;
  --shadow:0 14px 40px -16px rgba(54,33,150,.22);
  --ring:0 0 0 3px rgba(105,56,239,.32);
  --grad:linear-gradient(135deg,#7B45FF 0%,#6938EF 44%,#5326D6 100%);
  --fd:'Sora',system-ui,sans-serif;--fb:'Inter',system-ui,sans-serif;
}
[data-theme="dark"]{
  --ink:#F4F2FB;--body:#CFCADF;--muted:#A29DBA;--faint:#7E7896;
  --paper:#0C0916;--card:#17122A;--card-2:#1F1838;--line:#2A2444;--line-2:#221C3A;--violet-50:#1B1535;
  --shadow:0 14px 40px -16px rgba(0,0,0,.6);--ring:0 0 0 3px rgba(140,98,255,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);background:var(--paper);color:var(--body);min-height:100dvh;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
svg{display:block}a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
h1,h2,h3{font-family:var(--fd);letter-spacing:-.02em;line-height:1.15}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:10px}

.wrap{display:grid;grid-template-columns:1fr;min-height:100dvh}
@media(min-width:980px){.wrap{grid-template-columns:1.05fr 1fr}}

/* LEFT VISUAL */
.visual{display:none;position:relative;overflow:hidden;background:#1B1136;color:#fff;padding:48px;flex-direction:column;justify-content:space-between}
@media(min-width:980px){.visual{display:flex}}
.visual .aurora{position:absolute;inset:0;z-index:0}
.visual .aurora i{position:absolute;border-radius:50%;filter:blur(60px);mix-blend-mode:screen}
.visual .aurora i:nth-child(1){width:46%;height:60%;left:-8%;top:-10%;background:#7B45FF;animation:d1 17s ease-in-out infinite}
.visual .aurora i:nth-child(2){width:44%;height:58%;right:-6%;top:20%;background:#FF7A45;opacity:.7;animation:d2 20s ease-in-out infinite}
.visual .aurora i:nth-child(3){width:50%;height:60%;left:20%;bottom:-18%;background:#12B5A4;opacity:.6;animation:d3 23s ease-in-out infinite}
@keyframes d1{0%,100%{transform:translate(0,0)}50%{transform:translate(14%,12%)}}
@keyframes d2{0%,100%{transform:translate(0,0)}50%{transform:translate(-12%,16%)}}
@keyframes d3{0%,100%{transform:translate(0,0)}50%{transform:translate(-14%,-10%)}}
.visual>*{position:relative;z-index:1}
.v-brand{display:flex;align-items:center;gap:11px}
.v-brand .lm{width:44px;height:44px;border-radius:13px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);display:grid;place-items:center}
.v-brand .lm svg{width:24px;height:24px}.v-brand b{font-family:var(--fd);font-weight:800;font-size:23px}
.v-mid{max-width:30ch}
.v-mid .icon-circle{width:64px;height:64px;border-radius:18px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;margin-bottom:24px}
.v-mid .icon-circle svg{width:30px;height:30px}
.v-mid h2{font-size:36px;font-weight:800;line-height:1.16;margin-bottom:16px}
.v-mid p{font-size:16px;color:rgba(255,255,255,.82);line-height:1.6}
/* vertical steps in visual */
.vsteps{display:flex;flex-direction:column;gap:4px;margin-top:32px}
.vstep{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:14px;transition:.25s;border:1px solid transparent}
.vstep.on{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18)}
.vstep .vn{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;font-family:var(--fd);font-weight:700;font-size:14px;background:rgba(255,255,255,.12);color:rgba(255,255,255,.65);flex-shrink:0;transition:.25s}
.vstep.on .vn{background:#fff;color:var(--violet)}
.vstep.done .vn{background:#7CF0E0;color:#0C3B36}
.vstep .vt{font-size:14.5px;font-weight:600;color:rgba(255,255,255,.6);transition:.25s}
.vstep.on .vt,.vstep.done .vt{color:#fff}
.vstep .vt small{display:block;font-weight:400;font-size:12px;color:rgba(255,255,255,.55)}

/* RIGHT FORM */
.form-side{display:flex;flex-direction:column;padding:24px}
.fs-top{display:flex;align-items:center;justify-content:space-between}
.fs-back{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--muted);padding:9px 13px;border-radius:11px;transition:.14s}
.fs-back:hover{background:var(--card-2);color:var(--violet)}.fs-back svg{width:17px;height:17px}
.mini-brand{display:none;align-items:center;gap:9px}
.mini-brand .lm{width:36px;height:36px;border-radius:11px;background:var(--grad);display:grid;place-items:center}
.mini-brand .lm svg{width:20px;height:20px}.mini-brand b{font-family:var(--fd);font-weight:800;font-size:18px;color:var(--ink)}
.mini-brand b span{color:var(--violet)}
@media(max-width:979px){.mini-brand{display:flex}}
.theme-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:var(--body);border:1px solid var(--line);transition:.14s}
.theme-btn:hover{background:var(--violet-50);color:var(--violet)}.theme-btn svg{width:20px;height:20px}

/* mobile progress bar */
.mprog{display:none;gap:6px;margin:18px 0 4px}
@media(max-width:979px){.mprog{display:flex}}
.mprog i{flex:1;height:5px;border-radius:999px;background:var(--line);transition:.3s}
.mprog i.on{background:var(--violet)}

.form-mid{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px 0}
.fcard{width:100%;max-width:412px}
.step{display:none;animation:fade .35s ease}
.step.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.step-eyebrow{font-size:13px;font-weight:700;color:var(--violet);letter-spacing:.03em;margin-bottom:10px}
.fcard h1{font-size:27px;font-weight:800;color:var(--ink);margin-bottom:9px}
.fcard .sub{font-size:15px;color:var(--muted);margin-bottom:26px;line-height:1.55}
.fcard .sub b{color:var(--ink);font-weight:600}
.field{margin-bottom:18px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:7px}
.input{position:relative}
.input>svg.lead{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:var(--faint)}
.input input{width:100%;height:52px;border-radius:13px;border:1px solid var(--line);background:var(--card-2);padding:0 15px 0 46px;font-size:15px;color:var(--ink);transition:.16s}
.input input::placeholder{color:var(--faint)}
.input input:focus{border-color:var(--violet);background:var(--card);box-shadow:var(--ring)}
.input .eye-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:var(--faint)}
.input .eye-btn:hover{color:var(--violet);background:var(--violet-50)}.input .eye-btn svg{width:19px;height:19px}
.submit{width:100%;height:52px;border-radius:13px;background:var(--violet);color:#fff;font-size:15.5px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 12px 26px -10px rgba(83,38,214,.65);transition:.18s}
.submit:hover{background:var(--violet-700);transform:translateY(-1px)}.submit svg{width:19px;height:19px}
.ghost-link{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--muted);margin-top:18px}
.ghost-link:hover{color:var(--violet)}.ghost-link svg{width:16px;height:16px}

/* OTP */
.otp{display:flex;gap:10px;justify-content:space-between;margin-bottom:18px}
.otp input{width:100%;aspect-ratio:1;max-width:58px;text-align:center;font-family:var(--fd);font-weight:700;font-size:24px;color:var(--ink);border:1.5px solid var(--line);background:var(--card-2);border-radius:14px;transition:.16s}
.otp input:focus{border-color:var(--violet);background:var(--card);box-shadow:var(--ring)}
.otp input.filled{border-color:var(--violet);background:var(--violet-50);color:var(--violet)}
.timer-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;font-size:14px}
.timer{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-weight:600}
.timer svg{width:16px;height:16px;color:var(--violet)}
.timer.expired{color:var(--red)}.timer.expired svg{color:var(--red)}
.timer b{font-variant-numeric:tabular-nums;color:var(--ink)}.timer.expired b{color:var(--red)}
.resend{font-weight:700;color:var(--violet)}
.resend:disabled{color:var(--faint);cursor:not-allowed}
.mail-hint{display:flex;align-items:center;gap:11px;background:var(--violet-50);border:1px solid color-mix(in srgb,var(--violet) 18%,var(--line));border-radius:14px;padding:13px 15px;margin-bottom:22px}
.mail-hint .mc{width:38px;height:38px;border-radius:11px;background:var(--card);border:1px solid var(--line);display:grid;place-items:center;flex-shrink:0;color:var(--violet)}
.mail-hint .mc svg{width:19px;height:19px}
.mail-hint .mt{font-size:13.5px;color:var(--body)}.mail-hint .mt b{color:var(--ink);font-weight:700}
/* strength */
.strength{margin:10px 0 22px}
.strbars{display:flex;gap:5px}
.strbars i{flex:1;height:5px;border-radius:999px;background:var(--line);transition:.2s}
.strength.s1 .strbars i:nth-child(1){background:var(--red)}
.strength.s2 .strbars i:nth-child(-n+2){background:var(--amber)}
.strength.s3 .strbars i:nth-child(-n+3){background:var(--gold)}
.strength.s4 .strbars i{background:var(--green)}
.str-label{font-size:12.5px;color:var(--muted);margin-top:7px;display:flex;justify-content:space-between}
.strength.s1 .str-label b{color:var(--red)}.strength.s2 .str-label b{color:var(--amber)}
.strength.s3 .str-label b{color:var(--gold)}.strength.s4 .str-label b{color:var(--green)}
/* success */
.success{text-align:center}
.success .sc{width:84px;height:84px;border-radius:50%;background:color-mix(in srgb,var(--green) 14%,var(--card));display:grid;place-items:center;margin:0 auto 22px;color:var(--green);animation:pop .5s cubic-bezier(.3,1.4,.5,1)}
@keyframes pop{0%{transform:scale(.5);opacity:0}100%{transform:scale(1);opacity:1}}
.success .sc svg{width:42px;height:42px}
.success h1{margin-bottom:10px}

.fs-foot{display:flex;align-items:center;justify-content:center;gap:16px;font-size:12.5px;color:var(--faint);flex-wrap:wrap}
.fs-foot a:hover{color:var(--violet)}

/* --- register ekleri --- */
:root{
  --violet:#6938EF;--violet-700:#5326D6;--violet-50:#F6F3FE;
  --amber:#FF7A45;--teal:#12B5A4;--green:#16A34A;--red:#E5484D;--gold:#E8A317;
  --ink:#17131F;--body:#3C3850;--muted:#6E6A80;--faint:#9A96AC;
  --paper:#F4F3FA;--card:#FFFFFF;--card-2:#FAF9FE;
  --line:#EAE8F2;--line-2:#F1EFF8;
  --shadow:0 14px 40px -16px rgba(54,33,150,.22);
  --ring:0 0 0 3px rgba(105,56,239,.32);
  --grad:linear-gradient(135deg,#7B45FF 0%,#6938EF 44%,#5326D6 100%);
  --fd:'Sora',system-ui,sans-serif;--fb:'Inter',system-ui,sans-serif;
}
[data-theme="dark"]{
  --ink:#F4F2FB;--body:#CFCADF;--muted:#A29DBA;--faint:#7E7896;
  --paper:#0C0916;--card:#17122A;--card-2:#1F1838;--line:#2A2444;--line-2:#221C3A;--violet-50:#1B1535;
  --shadow:0 14px 40px -16px rgba(0,0,0,.6);--ring:0 0 0 3px rgba(140,98,255,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);background:var(--paper);color:var(--body);min-height:100dvh;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
svg{display:block}a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
h1,h2,h3{font-family:var(--fd);letter-spacing:-.02em;line-height:1.15}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:10px}

.wrap{display:grid;grid-template-columns:1fr;min-height:100dvh}
@media(min-width:980px){.wrap{grid-template-columns:1fr 1.05fr}}

/* LEFT VISUAL */
.visual{display:none;position:relative;overflow:hidden;background:#1B1136;color:#fff;padding:48px;flex-direction:column;justify-content:space-between;order:-1}
@media(min-width:980px){.visual{display:flex}}
.visual .aurora{position:absolute;inset:0;z-index:0}
.visual .aurora i{position:absolute;border-radius:50%;filter:blur(60px);mix-blend-mode:screen}
.visual .aurora i:nth-child(1){width:46%;height:60%;left:-8%;top:-10%;background:#7B45FF;animation:d1 17s ease-in-out infinite}
.visual .aurora i:nth-child(2){width:44%;height:58%;right:-6%;top:20%;background:#12B5A4;opacity:.7;animation:d2 20s ease-in-out infinite}
.visual .aurora i:nth-child(3){width:50%;height:60%;left:20%;bottom:-18%;background:#FF7A45;opacity:.65;animation:d3 23s ease-in-out infinite}
@keyframes d1{0%,100%{transform:translate(0,0)}50%{transform:translate(14%,12%)}}
@keyframes d2{0%,100%{transform:translate(0,0)}50%{transform:translate(-12%,16%)}}
@keyframes d3{0%,100%{transform:translate(0,0)}50%{transform:translate(-14%,-10%)}}
.visual>*{position:relative;z-index:1}
.v-brand{display:flex;align-items:center;gap:11px}
.v-brand .lm{width:44px;height:44px;border-radius:13px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);display:grid;place-items:center}
.v-brand .lm svg{width:24px;height:24px}.v-brand b{font-family:var(--fd);font-weight:800;font-size:23px}
.v-mid{max-width:32ch}
.v-mid .eye{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);padding:7px 13px;border-radius:999px;margin-bottom:22px}
.v-mid .eye .dot{width:7px;height:7px;border-radius:50%;background:#7CF0E0}
.v-mid h2{font-size:38px;font-weight:800;line-height:1.16;margin-bottom:16px}
.v-mid p{font-size:16px;color:rgba(255,255,255,.82);line-height:1.6}
.perks{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.perk{display:flex;align-items:center;gap:13px;font-size:15px}
.perk .pc{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;flex-shrink:0}
.perk .pc svg{width:19px;height:19px}
.v-foot{display:flex;align-items:center;gap:12px}
.v-foot .stack{display:flex}
.v-foot .stack img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid #1B1136;margin-left:-10px}
.v-foot .stack img:first-child{margin-left:0}
.v-foot span{font-size:14px;color:rgba(255,255,255,.82)}.v-foot span b{color:#fff}

/* RIGHT FORM */
.form-side{display:flex;flex-direction:column;padding:24px;overflow-y:auto}
.fs-top{display:flex;align-items:center;justify-content:space-between}
.fs-back{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--muted);padding:9px 13px;border-radius:11px;transition:.14s}
.fs-back:hover{background:var(--card-2);color:var(--violet)}.fs-back svg{width:17px;height:17px}
.mini-brand{display:none;align-items:center;gap:9px}
.mini-brand .lm{width:36px;height:36px;border-radius:11px;background:var(--grad);display:grid;place-items:center}
.mini-brand .lm svg{width:20px;height:20px}.mini-brand b{font-family:var(--fd);font-weight:800;font-size:18px;color:var(--ink)}
.mini-brand b span{color:var(--violet)}
@media(max-width:979px){.mini-brand{display:flex}}
.theme-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:var(--body);border:1px solid var(--line);transition:.14s}
.theme-btn:hover{background:var(--violet-50);color:var(--violet)}.theme-btn svg{width:20px;height:20px}
.form-mid{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px 0}
.fcard{width:100%;max-width:424px}
.fcard h1{font-size:29px;font-weight:800;color:var(--ink);margin-bottom:8px}
.fcard .sub{font-size:15px;color:var(--muted);margin-bottom:24px}
.fcard .sub a{color:var(--violet);font-weight:600}
.sbtn{display:flex;align-items:center;justify-content:center;gap:10px;height:50px;width:100%;border-radius:13px;border:1px solid var(--line);background:var(--card);font-size:14.5px;font-weight:600;color:var(--ink);transition:.16s;margin-bottom:20px}
.sbtn:hover{background:var(--card-2);border-color:color-mix(in srgb,var(--violet) 25%,var(--line))}.sbtn svg{width:20px;height:20px}
.divider{display:flex;align-items:center;gap:14px;margin-bottom:20px;color:var(--faint);font-size:13px}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:440px){.grid2{grid-template-columns:1fr}}
.field{margin-bottom:15px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:7px}
.input{position:relative}
.input>svg.lead{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:var(--faint)}
.input .at{position:absolute;left:15px;top:50%;transform:translateY(-50%);font-size:15px;font-weight:600;color:var(--faint)}
.input input{width:100%;height:52px;border-radius:13px;border:1px solid var(--line);background:var(--card-2);padding:0 15px 0 46px;font-size:15px;color:var(--ink);transition:.16s}
.input.pad-at input{padding-left:34px}
.input input::placeholder{color:var(--faint)}
.input input:focus{border-color:var(--violet);background:var(--card);box-shadow:var(--ring)}
.input .eye-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:var(--faint)}
.input .eye-btn:hover{color:var(--violet);background:var(--violet-50)}.input .eye-btn svg{width:19px;height:19px}
.input .ok{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--green);opacity:0;transition:.16s}
.input.valid .ok{opacity:1}
/* strength */
.strength{margin-top:10px}
.strbars{display:flex;gap:5px}
.strbars i{flex:1;height:5px;border-radius:999px;background:var(--line);transition:.2s}
.strength.s1 .strbars i:nth-child(1){background:var(--red)}
.strength.s2 .strbars i:nth-child(-n+2){background:var(--amber)}
.strength.s3 .strbars i:nth-child(-n+3){background:var(--gold)}
.strength.s4 .strbars i{background:var(--green)}
.str-label{font-size:12.5px;color:var(--muted);margin-top:7px;display:flex;justify-content:space-between}
.str-label b{font-weight:700}
.strength.s1 .str-label b{color:var(--red)}.strength.s2 .str-label b{color:var(--amber)}
.strength.s3 .str-label b{color:var(--gold)}.strength.s4 .str-label b{color:var(--green)}
.terms{display:flex;align-items:flex-start;gap:11px;margin:20px 0;font-size:13.5px;color:var(--body);line-height:1.5;cursor:pointer;user-select:none}
.terms input{position:absolute;opacity:0}
.terms .box{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);background:var(--card-2);display:grid;place-items:center;flex-shrink:0;margin-top:1px;transition:.14s}
.terms .box svg{width:13px;height:13px;color:#fff;opacity:0;transition:.14s}
.terms input:checked+.box{background:var(--violet);border-color:var(--violet)}
.terms input:checked+.box svg{opacity:1}
.terms input:focus-visible+.box{box-shadow:var(--ring)}
.terms a{color:var(--violet);font-weight:600}
.submit{width:100%;height:52px;border-radius:13px;background:var(--violet);color:#fff;font-size:15.5px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 12px 26px -10px rgba(83,38,214,.65);transition:.18s}
.submit:hover{background:var(--violet-700);transform:translateY(-1px)}.submit svg{width:19px;height:19px}
.alt{text-align:center;margin-top:22px;font-size:14.5px;color:var(--muted)}.alt a{color:var(--violet);font-weight:700}
.fs-foot{display:flex;align-items:center;justify-content:center;gap:16px;font-size:12.5px;color:var(--faint);flex-wrap:wrap;padding-top:8px}
.fs-foot a:hover{color:var(--violet)}

/* --- login ekleri --- */
:root{
  --violet:#6938EF;--violet-700:#5326D6;--violet-50:#F6F3FE;
  --amber:#FF7A45;--teal:#12B5A4;
  --ink:#17131F;--body:#3C3850;--muted:#6E6A80;--faint:#9A96AC;
  --paper:#F4F3FA;--card:#FFFFFF;--card-2:#FAF9FE;
  --line:#EAE8F2;--line-2:#F1EFF8;
  --shadow-sm:0 1px 2px rgba(23,19,31,.05);
  --shadow:0 14px 40px -16px rgba(54,33,150,.22);
  --ring:0 0 0 3px rgba(105,56,239,.32);
  --grad:linear-gradient(135deg,#7B45FF 0%,#6938EF 44%,#5326D6 100%);
  --fd:'Sora',system-ui,sans-serif;--fb:'Inter',system-ui,sans-serif;
}
[data-theme="dark"]{
  --ink:#F4F2FB;--body:#CFCADF;--muted:#A29DBA;--faint:#7E7896;
  --paper:#0C0916;--card:#17122A;--card-2:#1F1838;--line:#2A2444;--line-2:#221C3A;--violet-50:#1B1535;
  --shadow:0 14px 40px -16px rgba(0,0,0,.6);--ring:0 0 0 3px rgba(140,98,255,.45);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);background:var(--paper);color:var(--body);min-height:100dvh;-webkit-font-smoothing:antialiased;transition:background .3s,color .3s}
svg{display:block}a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
h1,h2,h3{font-family:var(--fd);letter-spacing:-.02em;line-height:1.15}
:focus-visible{outline:none;box-shadow:var(--ring);border-radius:10px}

.wrap{display:grid;grid-template-columns:1fr;min-height:100dvh}
@media(min-width:980px){.wrap{grid-template-columns:1.05fr 1fr}}

/* LEFT VISUAL */
.visual{display:none;position:relative;overflow:hidden;background:#1B1136;color:#fff;padding:48px;flex-direction:column;justify-content:space-between}
@media(min-width:980px){.visual{display:flex}}
.visual .aurora{position:absolute;inset:0;z-index:0}
.visual .aurora i{position:absolute;border-radius:50%;filter:blur(60px);mix-blend-mode:screen}
.visual .aurora i:nth-child(1){width:46%;height:60%;left:-8%;top:-10%;background:#7B45FF;animation:d1 17s ease-in-out infinite}
.visual .aurora i:nth-child(2){width:44%;height:58%;right:-6%;top:20%;background:#FF7A45;opacity:.75;animation:d2 20s ease-in-out infinite}
.visual .aurora i:nth-child(3){width:50%;height:60%;left:20%;bottom:-18%;background:#12B5A4;opacity:.6;animation:d3 23s ease-in-out infinite}
@keyframes d1{0%,100%{transform:translate(0,0)}50%{transform:translate(14%,12%)}}
@keyframes d2{0%,100%{transform:translate(0,0)}50%{transform:translate(-12%,16%)}}
@keyframes d3{0%,100%{transform:translate(0,0)}50%{transform:translate(-14%,-10%)}}
.visual>*{position:relative;z-index:1}
.v-brand{display:flex;align-items:center;gap:11px}
.v-brand .lm{width:44px;height:44px;border-radius:13px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);display:grid;place-items:center}
.v-brand .lm svg{width:24px;height:24px}
.v-brand b{font-family:var(--fd);font-weight:800;font-size:23px}
.v-mid{max-width:30ch}
.v-mid .eye{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);padding:7px 13px;border-radius:999px;margin-bottom:22px}
.v-mid .eye .dot{width:7px;height:7px;border-radius:50%;background:#7CF0E0}
.v-mid h2{font-size:38px;font-weight:800;line-height:1.16;margin-bottom:16px}
.v-mid p{font-size:16px;color:rgba(255,255,255,.82);line-height:1.6}
.v-stats{display:flex;gap:28px;margin-top:30px}
.v-stats .s .n{font-family:var(--fd);font-weight:800;font-size:26px}
.v-stats .s .l{font-size:13px;color:rgba(255,255,255,.7);margin-top:2px}
.v-quote{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.16);border-radius:18px;padding:20px 22px;backdrop-filter:blur(6px)}
.v-quote p{font-size:15px;line-height:1.6;color:rgba(255,255,255,.92)}
.v-quote .by{display:flex;align-items:center;gap:11px;margin-top:14px}
.v-quote .by img{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.3)}
.v-quote .by b{font-size:14px;display:block}.v-quote .by span{font-size:12.5px;color:rgba(255,255,255,.7)}

/* RIGHT FORM */
.form-side{display:flex;flex-direction:column;padding:24px;position:relative}
.fs-top{display:flex;align-items:center;justify-content:space-between}
.fs-back{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--muted);padding:9px 13px;border-radius:11px;transition:.14s}
.fs-back:hover{background:var(--card-2);color:var(--violet)}.fs-back svg{width:17px;height:17px}
.mini-brand{display:none;align-items:center;gap:9px}
.mini-brand .lm{width:36px;height:36px;border-radius:11px;background:var(--grad);display:grid;place-items:center}
.mini-brand .lm svg{width:20px;height:20px}.mini-brand b{font-family:var(--fd);font-weight:800;font-size:18px;color:var(--ink)}
.mini-brand b span{color:var(--violet)}
@media(max-width:979px){.mini-brand{display:flex}}
.theme-btn{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:var(--body);border:1px solid var(--line);transition:.14s}
.theme-btn:hover{background:var(--violet-50);color:var(--violet)}.theme-btn svg{width:20px;height:20px}
.form-mid{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px 0}
.fcard{width:100%;max-width:404px}
.fcard h1{font-size:29px;font-weight:800;color:var(--ink);margin-bottom:8px}
.fcard .sub{font-size:15px;color:var(--muted);margin-bottom:26px}
.fcard .sub a{color:var(--violet);font-weight:600}
.social{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.sbtn{display:flex;align-items:center;justify-content:center;gap:10px;height:50px;border-radius:13px;border:1px solid var(--line);background:var(--card);font-size:14.5px;font-weight:600;color:var(--ink);transition:.16s}
.sbtn:hover{background:var(--card-2);border-color:color-mix(in srgb,var(--violet) 25%,var(--line))}
.sbtn svg{width:20px;height:20px}
.divider{display:flex;align-items:center;gap:14px;margin-bottom:22px;color:var(--faint);font-size:13px}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}
.field{margin-bottom:16px}
.field label{display:block;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:7px}
.input{position:relative}
.input>svg{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:19px;height:19px;color:var(--faint)}
.input input{width:100%;height:52px;border-radius:13px;border:1px solid var(--line);background:var(--card-2);padding:0 15px 0 46px;font-size:15px;color:var(--ink);transition:.16s}
.input input::placeholder{color:var(--faint)}
.input input:focus{border-color:var(--violet);background:var(--card);box-shadow:var(--ring)}
.input .eye-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:var(--faint)}
.input .eye-btn:hover{color:var(--violet);background:var(--violet-50)}.input .eye-btn svg{width:19px;height:19px}
.row-between{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.check{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--body);cursor:pointer;user-select:none}
.check input{position:absolute;opacity:0}
.check .box{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--line);background:var(--card-2);display:grid;place-items:center;transition:.14s}
.check .box svg{width:13px;height:13px;color:#fff;opacity:0;transition:.14s}
.check input:checked+.box{background:var(--violet);border-color:var(--violet)}
.check input:checked+.box svg{opacity:1}
.check input:focus-visible+.box{box-shadow:var(--ring)}
.forgot{font-size:14px;font-weight:600;color:var(--violet)}
.submit{width:100%;height:52px;border-radius:13px;background:var(--violet);color:#fff;font-size:15.5px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 12px 26px -10px rgba(83,38,214,.65);transition:.18s}
.submit:hover{background:var(--violet-700);transform:translateY(-1px)}.submit svg{width:19px;height:19px}
.alt{text-align:center;margin-top:24px;font-size:14.5px;color:var(--muted)}
.alt a{color:var(--violet);font-weight:700}
.fs-foot{display:flex;align-items:center;justify-content:center;gap:16px;font-size:12.5px;color:var(--faint);flex-wrap:wrap}
.fs-foot a:hover{color:var(--violet)}

/* --- flash mesajları (auth) --- */
.flash-wrap{display:flex;flex-direction:column;gap:9px;margin:0 0 18px}
.flash{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:13px;font-size:14px;font-weight:500;line-height:1.45;border:1px solid var(--line)}
.flash svg{width:18px;height:18px;flex-shrink:0;margin-top:1px}
.flash.success{background:color-mix(in srgb,var(--teal) 12%,var(--card));border-color:color-mix(in srgb,var(--teal) 30%,var(--line));color:#0E7D70}
.flash.error{background:color-mix(in srgb,var(--red) 11%,var(--card));border-color:color-mix(in srgb,var(--red) 30%,var(--line));color:#C13A3F}
.flash.info{background:var(--violet-50);border-color:color-mix(in srgb,var(--violet) 24%,var(--line));color:var(--violet-700)}
[data-theme="dark"] .flash.success{color:#7CF0E0}
[data-theme="dark"] .flash.error{color:#FF9B9E}
[data-theme="dark"] .flash.info{color:#C9B8FF}
