/* ============================================================
   Auth pages — v3 minimalist
   Shared by signin / signup / forgotten_password / password_recovery
   Pure focused auth — no marketing aside, no hero, no trust list.
   Just brand, centered form card, legal footer.
   Tokens mirror homepage-v3.css; keep in sync.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#ffffff; --bg-2:#fafafa; --bg-3:#f6f6f7; --surface:#ffffff;
  --line:#ededee; --line-2:#e3e3e5; --line-3:#c8c8cc;
  --ink:#0c0c0d; --ink-2:#1f1f22; --ink-3:#3f3f44;
  --muted:#3a3a40; --soft:#98989f; --faint:#d6d6d9;

  --accent:#007e42; --accent-2:#006336;
  --accent-soft:#f0f7f3; --accent-line:#d4e8de;
  --accent-glow:rgba(0,126,66,.15);

  --bad:#c0382b;

  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --display:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --serif:'New York','Iowan Old Style','Charter',Georgia,serif;

  --radius:14px; --radius-sm:10px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

html,body{height:100%}
body{
  font-family:var(--sans);
  background:var(--bg-2);
  color:var(--ink);
  font-size:15px;line-height:1.55;font-weight:450;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:'cv11','ss01','ss03','tnum';
  position:relative;
}
/* Ambient — a single soft green radial bleeds in from the top so
   the page isn't dead-flat. Quiet enough that it never reads as
   content. */
body::before{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(ellipse 720px 420px at 50% -20%, var(--accent-soft), transparent 60%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ============================================================
   Shell
   ============================================================ */
.auth-shell{
  min-height:100vh;
  display:flex;flex-direction:column;
  background:transparent;
}

/* ---- Topbar — brand only, centered ---- */
.auth-topbar{
  padding:28px 32px;
  display:flex;align-items:center;justify-content:center;
  max-width:1344px;width:100%;margin:0 auto;
  position:relative;
}
.auth-topbar .brand{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:-.015em;
  color:var(--ink);
}
.auth-topbar .brand img{height:26px;width:auto}

/* ---- Stage ---- */
.auth-main{
  flex:1;
  display:flex;align-items:flex-start;justify-content:center;
  padding:24px 24px 56px;
}

/* ---- Card ---- */
.auth-card{
  width:100%;max-width:400px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 1px 2px rgba(15,23,42,.04),0 12px 32px -18px rgba(15,23,42,.14);
  padding:36px 32px 28px;
}

/* The form wrapper sits inside the card with no extra padding. */
.auth-form{display:block}
.auth-card .auth-form{padding:0}

/* Legacy form-logo wrapper used by some templates; the new design
   keeps the brand in the top bar only, so hide it inside the card. */
.auth-form .form-logo,
.auth-card .form-logo{display:none}

/* ---- Heading ---- */
.auth-form h2{
  font-family:var(--display);font-weight:600;
  font-size:22px;letter-spacing:-.022em;line-height:1.18;color:var(--ink);
  text-align:center;
}
.auth-form .form-sub{
  margin-top:8px;color:var(--muted);font-size:14.5px;line-height:1.5;
  text-align:center;
}

/* ---- Field atoms ---- */
.auth-form .field-list,
.auth-form ul{
  list-style:none;padding:0;margin:22px 0 0;
  display:flex;flex-direction:column;gap:14px;
}
.auth-form .field-list li,
.auth-form ul li{display:block;position:relative}

.auth-form label.input,
.auth-form .field-label{
  display:block;font-size:12px;font-weight:600;
  letter-spacing:.04em;color:var(--ink-2);
  margin-bottom:6px;
}
.auth-form input[type="email"],
.auth-form input[type="text"],
.auth-form input[type="password"]{
  width:100%;
  height:44px;padding:0 14px;
  background:#fff;color:var(--ink);
  border:1px solid var(--line-2);border-radius:10px;
  font-family:inherit;font-size:14.5px;font-weight:450;
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease),background .15s var(--ease);
  -webkit-appearance:none;appearance:none;
}
.auth-form input::placeholder{color:var(--soft)}
.auth-form input:hover{border-color:var(--line-3)}
.auth-form input:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 4px var(--accent-glow);
}
.auth-form input.error{
  border-color:var(--bad);
  box-shadow:0 0 0 4px rgba(192,56,43,.08);
}

.auth-form .sml-txt{
  margin-top:6px;font-size:12px;color:var(--muted);
}

/* ---- Remember + forgot ---- */
.auth-form .remember-box{
  margin-top:14px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  font-size:13px;
}
.auth-form .remember-box .left{
  display:inline-flex;align-items:center;gap:8px;
}
.auth-form .remember-box input[type="checkbox"]{
  width:16px;height:16px;margin:0;
  accent-color:var(--accent);cursor:pointer;
}
.auth-form .remember-box label.remember{
  color:var(--ink-2);cursor:pointer;font-weight:500;
}
.auth-form .remember-box .right a{
  color:var(--accent-2);font-weight:500;
  border-bottom:1px solid transparent;transition:border-color .15s var(--ease);
}
.auth-form .remember-box .right a:hover{border-color:var(--accent-2)}

/* ---- Notice (error banner) ---- */
.auth-form .notice_text_signin{
  margin-top:14px;padding:10px 12px;
  background:rgba(192,56,43,.06);border:1px solid rgba(192,56,43,.18);
  color:var(--bad);font-size:13px;border-radius:10px;
  display:none;
}
.auth-form .notice_text_signin:empty{display:none}

/* ---- Primary CTA ---- */
.auth-form .btn-out{margin-top:18px}
.auth-form .btn.signup,
.auth-form button[type="submit"]{
  width:100%;height:46px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:var(--accent);color:#fff;
  border:1px solid var(--accent);border-radius:10px;
  font-family:inherit;font-size:14.5px;font-weight:600;letter-spacing:.005em;
  cursor:pointer;transition:all .18s var(--ease);
  -webkit-appearance:none;appearance:none;
  text-decoration:none;
}
.auth-form .btn.signup:hover,
.auth-form button[type="submit"]:hover{background:var(--accent-2);border-color:var(--accent-2)}
.auth-form .btn.signup:disabled,
.auth-form button[type="submit"]:disabled{opacity:.65;cursor:not-allowed}

/* ---- Divider ---- */
.auth-form .or-divider{
  margin:20px 0 16px;
  display:flex;align-items:center;gap:12px;
  font-size:11.5px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--soft);
}
.auth-form .or-divider::before,
.auth-form .or-divider::after{
  content:'';flex:1;height:1px;background:var(--line);
}

/* ---- Social ---- */
.auth-form .social-button{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
}
.auth-form .social-button .btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:42px;padding:0 12px;min-width:0;
  background:#fff;color:var(--ink);
  border:1px solid var(--line-2);border-radius:10px;
  font-family:inherit;font-size:14px;font-weight:500;
  white-space:nowrap;text-decoration:none;
  cursor:pointer;transition:all .18s var(--ease);
}
.auth-form .social-button .btn:hover,
.auth-form .social-button .btn:focus{text-decoration:none}
.auth-form .social-button .btn:hover{border-color:var(--ink-3);background:var(--bg-2)}
.auth-form .social-button .btn em{display:inline-flex;align-items:center;justify-content:center}
.auth-form .social-button .btn em img{width:16px;height:16px;display:block}

/* ---- Altcha widget ---- */
.auth-form altcha-widget{display:block;margin:14px 0 0}

/* ---- Switch / back lines ---- */
.auth-form .login-txt{
  margin-top:22px;padding-top:18px;
  border-top:1px solid var(--line);
  font-size:13.5px;color:var(--muted);text-align:center;
}
.auth-form .login-txt a{
  color:var(--ink);font-weight:600;
  border-bottom:1px solid var(--line-2);padding-bottom:1px;
  text-decoration:none;
  transition:border-color .15s var(--ease);
}
.auth-form .login-txt a:hover,
.auth-form .login-txt a:focus{text-decoration:none;border-bottom-color:var(--ink)}

.auth-form .back-to-login{
  margin-top:20px;text-align:center;font-size:13.5px;
}
.auth-form .back-to-login a{
  color:var(--muted);transition:color .15s var(--ease);
}
.auth-form .back-to-login a:hover{color:var(--ink)}

/* ============================================================
   Footer — legal only, centered
   ============================================================ */
.auth-footer{
  padding:18px 32px 28px;
  max-width:1344px;width:100%;margin:0 auto;
  display:flex;align-items:center;justify-content:center;gap:14px;
  font-size:12px;color:var(--soft);
  flex-wrap:wrap;
}
.auth-footer a{color:var(--muted);transition:color .15s var(--ease)}
.auth-footer a:hover{color:var(--ink)}
.auth-footer .sep{opacity:.5}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:520px){
  .auth-topbar{padding:22px 22px}
  .auth-main{padding:16px 18px 40px}
  .auth-card{padding:28px 22px 24px;border-radius:14px}
  .auth-form .social-button{grid-template-columns:1fr}
  .auth-footer{flex-wrap:wrap;gap:8px 14px;text-align:center;padding:14px 22px 24px}
}
