/* ePower — Auth Styles */
:root{--pri:#5a7a2d;--pri-light:#eef4e5;--pri-dark:#3d5a1a;--bg:#fafbfc;--white:#fff;--border:#e8ecf1;--text:#1a1a2e;--text2:#4a5568;--text3:#8892a4;--red:#e74c3c;--green:#27ae60;--font:'Plus Jakarta Sans',sans-serif;--display:'Bricolage Grotesque',sans-serif;--mono:'JetBrains Mono',monospace;--r:12px;--shadow:0 1px 3px rgba(0,0,0,0.06)}
*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg);color:var(--text)}

.auth-page{display:flex;height:100vh;overflow:hidden}
.auth-brand{flex:0 0 42%;background:linear-gradient(135deg,#1a2e0a,#2d4a14,#1a2e0a);position:relative;display:flex;align-items:center;padding:60px;color:#fff;overflow:hidden}
.auth-brand-bg{position:absolute;inset:0;opacity:.06;background-image:radial-gradient(circle,rgba(255,255,255,.3) 1px,transparent 1px);background-size:20px 20px}
.auth-brand-content{position:relative;z-index:1}
.auth-logo{font-family:var(--display);font-size:24px;font-weight:800;margin-bottom:32px}
.auth-h1{font-family:var(--display);font-size:48px;font-weight:800;line-height:1.1;letter-spacing:-1.5px;margin-bottom:8px}
.auth-brand-line{width:60px;height:2px;background:#5a7a2d;margin:16px 0 20px}
.auth-desc{color:rgba(255,255,255,.65);font-size:15px;line-height:1.7;max-width:380px;margin-bottom:36px}
.auth-features{display:flex;flex-direction:column;gap:18px}
.auth-feat{display:flex;gap:12px;align-items:flex-start}
.auth-feat-ic{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.auth-feat strong{font-size:13px}.auth-feat span{font-size:12px;color:rgba(255,255,255,.5)}

.auth-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;overflow-y:auto}
.auth-form-wrap{width:100%;max-width:440px}
.af-title{font-family:var(--display);font-size:28px;font-weight:800;margin-bottom:4px}
.af-sub{color:var(--text3);font-size:14px;margin-bottom:24px}

.auth-tabs{display:flex;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-bottom:14px}
.atb{flex:1;padding:11px;background:none;border:none;font-family:var(--font);font-size:12px;color:var(--text3);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s;border-right:1px solid var(--border)}
.atb:last-child{border-right:none}.atb:hover{color:var(--text2);background:#fafafa}.atb.on{background:var(--pri-light);color:var(--pri);font-weight:600}

.auth-hint{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--pri-light);border-radius:8px;font-size:12px;color:var(--pri);margin-bottom:16px}
.auth-err{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#fef2f2;border-radius:8px;font-size:12px;color:var(--red);margin-bottom:16px;border:1px solid #fecaca}
.auth-msg{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:12px;margin-bottom:16px}
.auth-msg-success{background:#ecfdf5;color:var(--green);border:1px solid #a7f3d0}
.auth-msg-error{background:#fef2f2;color:var(--red);border:1px solid #fecaca}

.fg{margin-bottom:16px}
.fg label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:6px}
.inp{width:100%;padding:10px 14px;background:var(--white);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;font-family:var(--font);outline:none;transition:all .2s}
.inp:focus{border-color:var(--pri);box-shadow:0 0 0 3px rgba(90,122,45,.1)}
.inp::placeholder{color:var(--text3)}.inp.mono{font-family:var(--mono);font-size:12px}
.inp-wrap{position:relative}.ic-l{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text3);font-size:15px}.ic-pad{padding-left:38px!important}
.eye{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text3);cursor:pointer;font-size:16px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 22px;background:var(--pri);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .2s}
.btn-primary:hover{background:var(--pri-dark);transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;pointer-events:none}
.btn-primary.full{width:100%}

.auth-divider{text-align:center;margin:16px 0;position:relative}
.auth-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}
.auth-divider span{position:relative;background:var(--bg);padding:0 14px;font-size:12px;color:var(--text3)}

.btn-guest{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:var(--white);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;font-family:var(--font);transition:all .2s;text-decoration:none}
.btn-guest:hover{border-color:var(--pri);color:var(--pri);background:var(--pri-light)}

.af-sw{text-align:center;margin-top:20px;font-size:13px;color:var(--text3)}
.af-sw a{color:var(--pri);font-weight:600;text-decoration:none}

.bspin{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sp .6s linear infinite;display:inline-block}
@keyframes sp{to{transform:rotate(360deg)}}

@media(max-width:900px){.auth-brand{display:none}}
@media(max-width:600px){.fr{grid-template-columns:1fr}.auth-form-panel{padding:24px}}
