/* ═══════════════════════════════════════════
   ENTEN AI — style.css
   Dark Amber + Codey Green
   ═══════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Geist+Mono:wght@300;400;500&family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  /* Base */
  --bg:        #080809;
  --surface:   #111114;
  --surface2:  #18181e;
  --surface3:  #222229;
  --border:    #2b2b34;
  --border2:   #38383f;
  --text:      #ededf2;
  --text2:     #9a9aae;
  --muted:     #56566a;

  /* Amber (normal chat) */
  --amber:     #f5c842;
  --amber2:    #e8a020;
  --amber3:    #b87010;
  --amber-dim: rgba(245,200,66,0.07);
  --amber-glow:rgba(245,200,66,0.14);

  /* Green (Codey) */
  --green:     #3ddc84;
  --green2:    #2ab86a;
  --green3:    #1a8a4a;
  --green-dim: rgba(61,220,132,0.07);
  --green-glow:rgba(61,220,132,0.14);

  /* Errors / OK */
  --err:       #ff5252;
  --err-bg:    rgba(255,82,82,0.08);
  --ok:        #4ade80;

  --r-sm: 8px;
  --r:    13px;
  --r-lg: 20px;
  --r-xl: 28px;

  --shadow:    0 4px 20px rgba(0,0,0,0.5);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.65);

  --serif: 'Instrument Serif', Georgia, serif;
  --body:  'Outfit', sans-serif;
  --mono:  'Geist Mono', 'Courier New', monospace;
  --ease:  cubic-bezier(0.4,0,0.2,1);
  --t:     0.18s;

  /* Active accent — switched by .codey-mode */
  --accent:     var(--amber);
  --accent2:    var(--amber2);
  --accent-dim: var(--amber-dim);
  --accent-glow:var(--amber-glow);
}

/* Codey mode swaps accent to green */
.codey-mode {
  --accent:     var(--green);
  --accent2:    var(--green2);
  --accent-dim: var(--green-dim);
  --accent-glow:var(--green-glow);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased}
body{font-family:var(--body);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.032'/%3E%3C/svg%3E");opacity:.4}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}

/* ── BG EFFECTS ── */
.page-bg{position:fixed;inset:0;background-image:linear-gradient(rgba(245,200,66,0.022) 1px,transparent 1px),linear-gradient(90deg,rgba(245,200,66,0.022) 1px,transparent 1px);background-size:52px 52px;pointer-events:none;z-index:0}
.codey-mode .page-bg{background-image:linear-gradient(rgba(61,220,132,0.018) 1px,transparent 1px),linear-gradient(90deg,rgba(61,220,132,0.018) 1px,transparent 1px)}
.page-glow{position:fixed;top:-280px;left:50%;transform:translateX(-50%);width:900px;height:700px;background:radial-gradient(ellipse,var(--accent-glow) 0%,transparent 68%);pointer-events:none;z-index:0;transition:background 0.5s}

/* ── APP SHELL ── */
.app-shell{display:flex;height:100vh;overflow:hidden;position:relative;z-index:1}

/* ── SIDEBAR ── */
.sidebar{width:265px;min-width:265px;height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:relative;overflow:hidden;transition:background var(--t)}
.sidebar::before{content:'';position:absolute;top:0;left:0;right:0;height:160px;background:linear-gradient(180deg,var(--accent-dim) 0%,transparent 100%);pointer-events:none;transition:background 0.5s}

.sb-header{padding:24px 18px 14px;border-bottom:1px solid var(--border)}
.logo{display:flex;align-items:center;gap:9px;text-decoration:none}
.logo-duck{font-size:1.45rem;display:inline-block;animation:duckBob 4s ease-in-out infinite}
@keyframes duckBob{0%,100%{transform:translateY(0) rotate(0deg)}30%{transform:translateY(-5px) rotate(-3deg)}60%{transform:translateY(-2px) rotate(2deg)}}
.logo-name{font-family:var(--serif);font-style:italic;font-size:1.28rem;color:var(--accent);line-height:1;transition:color 0.4s}
.logo-sub{font-family:var(--mono);font-size:.55rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase;margin-top:2px}

/* Mode switcher */
.mode-switcher{margin:11px 12px 0;display:flex;gap:6px}
.mode-btn{flex:1;padding:8px 10px;border-radius:var(--r-sm);border:1px solid var(--border);background:transparent;color:var(--muted);font-family:var(--body);font-size:.78rem;font-weight:500;cursor:pointer;transition:all var(--t);display:flex;align-items:center;justify-content:center;gap:6px}
.mode-btn:hover{border-color:var(--border2);color:var(--text2)}
.mode-btn.active-amber{background:var(--amber-dim);border-color:rgba(245,200,66,0.3);color:var(--amber)}
.mode-btn.active-green{background:var(--green-dim);border-color:rgba(61,220,132,0.3);color:var(--green)}

.new-chat-btn{margin:10px 12px 0;width:calc(100% - 24px);background:var(--accent);color:var(--bg);border:none;border-radius:var(--r);padding:9px 16px;font-family:var(--body);font-weight:600;font-size:.82rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:background var(--t),transform var(--t),box-shadow var(--t);position:relative;overflow:hidden}
.new-chat-btn::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 55%);pointer-events:none}
.new-chat-btn:hover{background:var(--accent2);transform:translateY(-1px);box-shadow:0 5px 18px var(--accent-glow)}
.new-chat-btn.locked{background:var(--surface2);color:var(--muted);border:1px solid var(--border);cursor:default}
.new-chat-btn.locked:hover{transform:none;box-shadow:none}

.sb-list{flex:1;overflow-y:auto;padding:8px 8px}
.sb-section-lbl{font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);padding:10px 10px 4px}
.chat-item{padding:8px 11px;border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;gap:8px;margin-bottom:2px;border:1px solid transparent;transition:all var(--t);color:var(--text2);font-size:.81rem;position:relative}
.chat-item:hover{background:var(--surface2);color:var(--text);border-color:var(--border)}
.chat-item.active{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.chat-item .ci-bar{width:3px;height:13px;border-radius:2px;flex-shrink:0;background:var(--accent)}
.ci-icon{font-size:.76rem;flex-shrink:0}
.ci-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ci-date{font-family:var(--mono);font-size:.59rem;color:var(--muted);flex-shrink:0}
/* Delete btn on chat item */
.ci-del{display:none;background:none;border:none;color:var(--muted);cursor:pointer;font-size:.8rem;padding:2px 4px;border-radius:4px;flex-shrink:0}
.chat-item:hover .ci-del{display:block}
.ci-del:hover{color:var(--err)}

.sb-empty{padding:24px 12px;text-align:center;color:var(--muted);font-size:.78rem;line-height:1.8}
.sb-empty-icon{font-size:1.4rem;display:block;margin-bottom:8px;opacity:.65}

/* Sidebar footer */
.sb-footer{padding:12px 12px 16px;border-top:1px solid var(--border)}
.user-row{display:flex;align-items:center;gap:9px;padding:8px 9px;border-radius:var(--r);cursor:pointer;border:1px solid transparent;margin-bottom:9px;transition:all var(--t)}
.user-row:hover{background:var(--surface2);border-color:var(--border)}
.avatar{width:33px;height:33px;border-radius:50%;background:linear-gradient(135deg,var(--amber),var(--amber3));color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.9rem;flex-shrink:0;overflow:hidden;border:1px solid rgba(245,200,66,.22)}
.avatar.guest{background:var(--surface3);color:var(--muted);border-color:var(--border)}
.avatar img{width:100%;height:100%;object-fit:cover}
.user-info{flex:1;min-width:0}
.ui-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ui-email{font-family:var(--mono);font-size:.61rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-badge{font-family:var(--mono);font-size:.54rem;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.1em;flex-shrink:0}
.user-badge.guest{background:var(--surface3);color:var(--muted);border:1px solid var(--border)}
.user-badge.member{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(245,200,66,.2)}
.user-badge.admin{background:rgba(255,82,82,.1);color:#ff5252;border:1px solid rgba(255,82,82,.25)}

.sb-actions{display:flex;gap:7px}
.icon-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text2);padding:7px 11px;border-radius:var(--r-sm);cursor:pointer;font-family:var(--body);font-size:.77rem;display:flex;align-items:center;justify-content:center;gap:5px;transition:all var(--t);white-space:nowrap}
.icon-btn:hover{background:var(--surface3);color:var(--text);border-color:var(--border2)}
.icon-btn.flex1{flex:1}

/* ── MAIN ── */
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}
.topbar{padding:13px 24px;border-bottom:1px solid var(--border);background:rgba(8,8,9,.88);backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:relative;z-index:10}
.topbar-title{font-family:var(--serif);font-style:italic;color:var(--text2);font-size:.92rem}
.topbar-badge{font-family:var(--mono);font-size:.58rem;padding:2px 9px;border-radius:20px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-glow);text-transform:uppercase;letter-spacing:.1em;margin-left:10px;transition:all 0.4s}
.topbar-right{display:flex;align-items:center;gap:8px}

/* ── MESSAGES ── */
.chat-window{flex:1;overflow-y:auto;padding:28px clamp(14px,7%,90px);display:flex;flex-direction:column;gap:14px}
.welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:40px 20px;animation:fadeUp .4s var(--ease)}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.welcome-icon{font-size:3.6rem;display:block;margin-bottom:6px;animation:duckBob 4s ease-in-out infinite}
.welcome-title{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2.1rem);font-weight:400}
.welcome-title .hi{font-style:italic}
.welcome-desc{color:var(--muted);font-size:.87rem;max-width:340px;line-height:1.75}
.chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:14px}
.chip{background:var(--surface2);border:1px solid var(--border);color:var(--text2);padding:7px 15px;border-radius:40px;font-size:.78rem;cursor:pointer;transition:all var(--t);font-family:var(--body)}
.chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:translateY(-1px)}

.message{display:flex;gap:10px;align-items:flex-start;max-width:84%;animation:msgIn .25s var(--ease)}
@keyframes msgIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:translateY(0)}}
.message.user{align-self:flex-end;flex-direction:row-reverse}
.msg-ava{width:27px;height:27px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.74rem;flex-shrink:0;margin-top:3px}
.message.ai .msg-ava{background:var(--accent);color:var(--bg);transition:background 0.4s}
.message.user .msg-ava{background:var(--surface3);border:1px solid var(--border2)}
.msg-bbl{padding:10px 14px;border-radius:14px;font-size:.88rem;line-height:1.72}
.message.ai .msg-bbl{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px;white-space:pre-wrap}
.message.user .msg-bbl{background:var(--surface2);border:1px solid var(--border2);border-bottom-right-radius:4px}

/* Codey mode message tweaks */
.codey-mode .message.ai .msg-bbl{border-color:rgba(61,220,132,.15)}
.codey-mode .message.ai .msg-ava{background:var(--green)}

.typing-dots{display:flex;gap:5px;padding:4px 2px;align-items:center}
.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--muted);animation:tdot 1.2s infinite}
.typing-dots span:nth-child(2){animation-delay:.15s}
.typing-dots span:nth-child(3){animation-delay:.3s}
@keyframes tdot{0%,60%,100%{transform:translateY(0);opacity:.3}30%{transform:translateY(-5px);opacity:1}}

/* ── CODE BLOCK ── */
.code-block{margin:8px 0;border-radius:10px;overflow:hidden;border:1px solid var(--border);font-family:var(--mono)}
.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:7px 14px;background:#0e0e10;border-bottom:1px solid var(--border)}
.code-lang{font-size:.66rem;color:var(--accent);letter-spacing:.12em;text-transform:uppercase;transition:color 0.4s}
.code-actions{display:flex;gap:6px}
.code-btn{background:var(--surface2);border:1px solid var(--border2);color:var(--text2);padding:3px 10px;border-radius:6px;font-size:.7rem;cursor:pointer;font-family:var(--body);transition:all var(--t)}
.code-btn:hover{background:var(--surface3);color:var(--text)}
.code-btn.preview-btn{background:var(--accent);border:none;color:var(--bg);font-weight:600}
.code-btn.preview-btn:hover{background:var(--accent2)}
pre.code-pre{margin:0;padding:13px 16px;background:#0a0a0c;overflow-x:auto;font-size:.81rem;line-height:1.65;color:#ededf2;white-space:pre-wrap;word-break:break-word}
pre.code-pre code{font-family:var(--mono)}

/* ── INPUT ── */
.input-wrap{padding:10px clamp(14px,7%,90px) 20px;flex-shrink:0}
.input-box{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:10px 13px;display:flex;align-items:flex-end;gap:9px;box-shadow:0 2px 12px rgba(0,0,0,.3);transition:border-color var(--t),box-shadow var(--t)}
.input-box:focus-within{border-color:rgba(245,200,66,.35);box-shadow:0 0 0 3px var(--amber-dim)}
.codey-mode .input-box:focus-within{border-color:rgba(61,220,132,.35);box-shadow:0 0 0 3px var(--green-dim)}
.input-box textarea{flex:1;background:transparent;border:none;color:var(--text);outline:none;resize:none;font-size:.88rem;font-family:var(--body);max-height:150px;line-height:1.6;padding-top:1px}
.input-box textarea::placeholder{color:var(--muted)}
.send-btn{background:var(--accent);border:none;width:33px;height:33px;border-radius:50%;cursor:pointer;color:var(--bg);font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--t)}
.send-btn:hover{background:var(--accent2);transform:scale(1.08);box-shadow:0 4px 14px var(--accent-glow)}
.send-btn:disabled{background:var(--surface3);color:var(--muted);cursor:not-allowed;transform:none;box-shadow:none}
.input-hint{text-align:center;font-family:var(--mono);font-size:.59rem;color:var(--muted);margin-top:7px;letter-spacing:.02em}

/* ── PREVIEW PANEL ── */
.preview-panel{width:48%;min-width:360px;background:#0a0a0c;border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;animation:panelIn .25s var(--ease)}
@keyframes panelIn{from{transform:translateX(36px);opacity:0}to{transform:translateX(0);opacity:1}}
.preview-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--surface);flex-shrink:0}
.preview-title{display:flex;align-items:center;gap:9px}
.preview-lang{font-family:var(--mono);font-size:.64rem;color:var(--accent);text-transform:uppercase;letter-spacing:.12em}
.preview-live{font-family:var(--mono);font-size:.58rem;color:var(--muted);background:var(--surface2);border:1px solid var(--border);padding:2px 8px;border-radius:20px}
.preview-actions{display:flex;gap:7px}
.preview-panel iframe{flex:1;border:none;background:#fff}

/* ── SETTINGS PANEL ── */
.panel-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.58);backdrop-filter:blur(10px);z-index:500;justify-content:flex-end}
.panel-overlay.open{display:flex}
.panel{width:350px;max-width:95vw;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;animation:panelIn .25s var(--ease)}
.panel-hdr{padding:18px 18px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.panel-title{font-family:var(--serif);font-style:italic;font-size:1.1rem}
.panel-close{width:26px;height:26px;background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-radius:var(--r-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all var(--t)}
.panel-close:hover{background:var(--surface3);color:var(--text)}
.panel-body{flex:1;overflow-y:auto;padding:16px 18px 28px}
.psection{margin-bottom:22px}
.psection-ttl{font-family:var(--mono);font-size:.6rem;text-transform:uppercase;letter-spacing:.18em;color:var(--muted);padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:13px}

.profile-row{display:flex;align-items:center;gap:13px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;margin-bottom:14px}
.avatar-lg{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--amber),var(--amber3));color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.3rem;overflow:hidden;flex-shrink:0;border:2px solid rgba(245,200,66,.25)}
.avatar-lg img{width:100%;height:100%;object-fit:cover}
.profile-meta .p-name{font-weight:600;font-size:.88rem;margin-bottom:2px}
.profile-meta .p-tag{font-family:var(--mono);font-size:.61rem;color:var(--accent);text-transform:uppercase;letter-spacing:.1em}

.fgroup{margin-bottom:11px}
.fgroup label{display:block;font-family:var(--mono);font-size:.61rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px}
.fgroup input,.fgroup select{width:100%;padding:9px 12px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);font-size:.86rem;font-family:var(--body);outline:none;transition:border-color var(--t),box-shadow var(--t);box-sizing:border-box}
.fgroup input:focus,.fgroup select:focus{border-color:rgba(245,200,66,.45);box-shadow:0 0 0 2px var(--amber-dim)}
.fgroup select option{background:var(--surface)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:9px}

.btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;border:none;cursor:pointer;font-family:var(--body);border-radius:var(--r-sm);font-size:.85rem;font-weight:500;padding:10px 16px;margin-top:7px;transition:all var(--t)}
.btn:active{transform:scale(.98)}
.btn-amber{background:var(--amber);color:var(--bg)}
.btn-amber:hover{background:var(--amber2);transform:translateY(-1px);box-shadow:0 5px 16px var(--amber-glow)}
.btn-outline{background:transparent;color:var(--text2);border:1px solid var(--border)}
.btn-outline:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.btn-red{background:transparent;color:var(--err);border:1px solid rgba(255,82,82,.28)}
.btn-red:hover{background:var(--err-bg);border-color:var(--err)}
.upload-lbl{display:inline-flex;align-items:center;gap:6px;background:var(--surface3);border:1px solid var(--border2);color:var(--text2);padding:6px 12px;border-radius:var(--r-sm);font-size:.75rem;cursor:pointer;margin-top:6px;transition:all var(--t)}
.upload-lbl:hover{background:var(--border);color:var(--text)}

.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.toggle-row:last-child{border:none}
.toggle-lbl{font-size:.84rem}
.tog{width:36px;height:20px;background:var(--surface3);border:1px solid var(--border2);border-radius:10px;cursor:pointer;position:relative;transition:background var(--t);flex-shrink:0}
.tog.on{background:var(--amber);border-color:var(--amber)}
.tog::after{content:'';position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:2px;left:2px;transition:left var(--t);box-shadow:0 1px 3px rgba(0,0,0,.3)}
.tog.on::after{left:18px}

.auth-cta{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:16px;text-align:center}
.auth-cta p{font-size:.82rem;color:var(--muted);margin-bottom:13px;line-height:1.65}
.auth-btns{display:flex;gap:8px}
.auth-btns a{flex:1;text-align:center;text-decoration:none;padding:9px;border-radius:var(--r-sm);font-size:.8rem;font-weight:500;transition:all var(--t)}
.ab-login{background:var(--surface3);color:var(--text2);border:1px solid var(--border2)}
.ab-login:hover{color:var(--text);border-color:var(--amber)}
.ab-reg{background:var(--amber);color:var(--bg)}
.ab-reg:hover{background:var(--amber2)}

/* ── AUTH PAGES ── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 20px;position:relative;z-index:1}
.auth-card{width:100%;max-width:430px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:38px 36px;position:relative;z-index:1;box-shadow:var(--shadow-lg);animation:cardUp .38s var(--ease)}
.auth-card.wide{max-width:465px}
@keyframes cardUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.auth-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:.68rem;color:var(--muted);text-decoration:none;letter-spacing:.06em;margin-bottom:26px;transition:color var(--t)}
.auth-back:hover{color:var(--amber)}
.auth-logo{margin-bottom:24px}
.auth-h1{font-family:var(--serif);font-size:1.65rem;font-weight:400;margin-bottom:5px}
.auth-desc{font-size:.84rem;color:var(--muted);margin-bottom:24px;line-height:1.6}
.af-group{margin-bottom:13px}
.af-group label{display:block;font-family:var(--mono);font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px}
.af-group input{width:100%;padding:11px 13px;background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);font-size:.88rem;font-family:var(--body);outline:none;transition:all var(--t);box-sizing:border-box}
.af-group input:focus{border-color:rgba(245,200,66,.45);box-shadow:0 0 0 3px var(--amber-dim)}
.af-group input.ferr{border-color:var(--err);box-shadow:0 0 0 2px rgba(255,82,82,.1)}
.af-group input.fok{border-color:rgba(74,222,128,.45)}
.ferrmsg{font-family:var(--mono);font-size:.68rem;color:var(--err);margin-top:4px;display:none}
.ferrmsg.show{display:block}
.galert{padding:10px 13px;border-radius:var(--r-sm);font-family:var(--mono);font-size:.78rem;margin-bottom:14px;display:none}
.galert.err{background:var(--err-bg);border:1px solid rgba(255,82,82,.22);color:var(--err)}
.galert.show{display:block}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:42px}
.pw-eye{position:absolute;right:11px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:.82rem;padding:4px;transition:color var(--t)}
.pw-eye:hover{color:var(--amber)}
.pw-strength{margin-top:6px}
.str-track{height:3px;background:var(--surface3);border-radius:2px;overflow:hidden}
.str-fill{height:100%;border-radius:2px;width:0;transition:width .35s,background .35s}
.str-lbl{font-family:var(--mono);font-size:.62rem;color:var(--muted);margin-top:3px}
.auth-submit{width:100%;background:var(--amber);color:var(--bg);border:none;padding:12px;border-radius:var(--r-sm);font-family:var(--body);font-weight:600;font-size:.92rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:12px;position:relative;overflow:hidden;transition:all var(--t)}
.auth-submit::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 55%);pointer-events:none}
.auth-submit:hover{background:var(--amber2);transform:translateY(-1px);box-shadow:0 6px 22px var(--amber-glow)}
.auth-submit:disabled{opacity:.48;cursor:not-allowed;transform:none;box-shadow:none}
.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0 14px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-divider span{font-family:var(--mono);font-size:.62rem;color:var(--muted)}
.auth-alt-btn{width:100%;background:transparent;color:var(--text2);border:1px solid var(--border);padding:11px;border-radius:var(--r-sm);font-family:var(--body);font-size:.84rem;cursor:pointer;transition:all var(--t)}
.auth-alt-btn:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.auth-footer{text-align:center;font-size:.8rem;color:var(--muted);margin-top:18px}
.auth-footer a{color:var(--amber);text-decoration:none}
.auth-footer a:hover{text-decoration:underline}
.af-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.age-hint{font-family:var(--mono);font-size:.6rem;color:var(--muted);margin-top:3px}
.check-row{display:flex;align-items:flex-start;gap:10px;margin:13px 0}
.check-row input[type=checkbox]{margin-top:3px;accent-color:var(--amber);flex-shrink:0}
.check-row label{font-size:.78rem;color:var(--muted);line-height:1.55;cursor:pointer}
.check-row label a{color:var(--amber);text-decoration:none}
.spinner{width:15px;height:15px;border:2px solid rgba(0,0,0,.2);border-top-color:var(--bg);border-radius:50%;animation:spin .6s linear infinite;display:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── ADMIN PAGE ── */
.admin-page{min-height:100vh;background:var(--bg);font-family:var(--body);color:var(--text);position:relative;z-index:1}
.admin-topbar{padding:16px 32px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.admin-topbar .admin-logo{display:flex;align-items:center;gap:12px}
.admin-badge{font-family:var(--mono);font-size:.6rem;padding:3px 10px;border-radius:20px;background:rgba(255,82,82,.1);color:#ff5252;border:1px solid rgba(255,82,82,.25);text-transform:uppercase;letter-spacing:.1em}
.admin-content{max-width:1100px;margin:0 auto;padding:32px 24px}
.admin-h1{font-family:var(--serif);font-size:1.8rem;font-weight:400;margin-bottom:4px}
.admin-sub{color:var(--muted);font-size:.85rem;margin-bottom:28px}
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:32px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px}
.stat-num{font-family:var(--serif);font-size:2rem;color:var(--amber);line-height:1}
.stat-lbl{font-family:var(--mono);font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-top:4px}
.admin-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.admin-table-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.admin-table-title{font-family:var(--serif);font-size:1.1rem;font-style:italic}
.admin-search{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:var(--r-sm);font-size:.85rem;font-family:var(--body);outline:none;width:220px;transition:border-color var(--t)}
.admin-search:focus{border-color:rgba(245,200,66,.4)}
table{width:100%;border-collapse:collapse}
th{padding:10px 16px;text-align:left;font-family:var(--mono);font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:.85rem;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--surface2)}
.td-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--amber),var(--amber3));color:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.85rem;overflow:hidden;flex-shrink:0}
.td-avatar img{width:100%;height:100%;object-fit:cover}
.role-badge{font-family:var(--mono);font-size:.6rem;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.08em}
.role-badge.admin{background:rgba(255,82,82,.1);color:#ff5252;border:1px solid rgba(255,82,82,.22)}
.role-badge.user{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(245,200,66,.2)}
.del-btn{background:transparent;border:1px solid rgba(255,82,82,.25);color:var(--err);padding:4px 12px;border-radius:6px;font-size:.78rem;cursor:pointer;font-family:var(--body);transition:all var(--t)}
.del-btn:hover{background:var(--err-bg);border-color:var(--err)}
.admin-empty{padding:40px;text-align:center;color:var(--muted);font-size:.85rem}

/* ── TOAST ── */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(8px);background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:8px 20px;border-radius:40px;font-family:var(--mono);font-size:.74rem;z-index:9000;box-shadow:var(--shadow);opacity:0;pointer-events:none;white-space:nowrap;transition:opacity .22s,transform .22s}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:768px){.sidebar{display:none}.chat-window{padding:18px 14px}.input-wrap{padding:8px 14px 18px}.topbar{padding:13px 14px}.auth-card{padding:28px 22px}.preview-panel{width:100%;min-width:unset}}
