/* ═══════════════════════════════════════════════════════════
   BrainFlip — Stylesheet
   ═══════════════════════════════════════════════════════════ */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --accent:#6C63FF;--accent2:#FF6584;--accent3:#43D9AD;
  --bg:#0F0E17;--surface:#1A1830;--surface2:#231F3A;--surface3:#2D2850;
  --text:#FFFFFE;--text2:#A7A9BE;--text3:#6B6D8A;
  --green:#43D9AD;--red:#FF6584;--orange:#FF9B3E;
  --border:rgba(255,255,255,0.08);
  --radius:16px;--radius-sm:10px;--radius-xs:6px;
  --shadow:0 8px 32px rgba(0,0,0,0.4);
}
.theme-light{
  --bg:#F5F4FF;--surface:#FFF;--surface2:#EDECFA;--surface3:#E2E0F5;
  --text:#1A1830;--text2:#4A4870;--text3:#9B99BB;
  --border:rgba(108,99,255,0.12);--shadow:0 8px 32px rgba(108,99,255,0.1);
}
.theme-fun{
  --bg:#FFF5E6;--surface:#FFF;--surface2:#FFF0D6;--surface3:#FFE4B5;
  --text:#1A0A2E;--text2:#5C3A7E;--text3:#9B7DB5;
  --accent:#FF6B6B;--accent2:#FFB347;--accent3:#4ECDC4;
  --border:rgba(255,107,107,0.15);
}
body{font-family:'Nunito Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background .3s,color .3s;font-size:15px;line-height:1.6}
h1,h2,h3,h4{font-family:'Nunito',sans-serif}
button{cursor:pointer;font-family:'Nunito Sans',sans-serif;border:none;outline:none;transition:all .2s}
input,textarea,select{font-family:'Nunito Sans',sans-serif;outline:none}

/* ── Layout ── */
.app{max-width:940px;margin:0 auto;padding:20px 16px}

/* ── Loading ── */
.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}
.loading-logo{font-size:56px}
.loading-title{font-family:'Nunito',sans-serif;font-size:28px;font-weight:800;color:var(--text)}
.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Login ── */
.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;width:100%;max-width:420px;text-align:center;box-shadow:var(--shadow)}
.login-logo{font-size:52px;margin-bottom:16px}
.login-title{font-size:28px;font-weight:900;margin-bottom:6px;color:var(--text)}
.login-sub{font-size:14px;color:var(--text3);margin-bottom:28px}
.login-divider{display:flex;align-items:center;gap:12px;margin-bottom:20px;color:var(--text3);font-size:12px;font-weight:600}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.sso-list{display:flex;flex-direction:column;gap:10px}
.sso-btn{display:flex;align-items:center;gap:12px;padding:13px 18px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:14px;font-weight:700;transition:all .2s;text-align:left}
.sso-btn:hover{background:var(--surface3);border-color:var(--accent);transform:translateY(-1px)}
.sso-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.sso-icon{width:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.login-footer{font-size:11px;color:var(--text3);margin-top:20px;line-height:1.5}

/* ── Header ── */
.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;padding:14px 20px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);flex-wrap:wrap;gap:10px}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.logo-text{font-family:'Nunito',sans-serif;font-size:20px;font-weight:800;color:var(--text)}
.logo-sub{font-size:11px;color:var(--text3);display:block;font-weight:400;margin-top:-2px}
.header-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.conn-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;border:1px solid}
.conn-pill.ok{background:rgba(67,217,173,0.1);color:var(--green);border-color:rgba(67,217,173,0.3)}
.conn-pill.warn{background:rgba(255,155,62,0.1);color:var(--orange);border-color:rgba(255,155,62,0.3)}
.conn-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.theme-btn{padding:6px 11px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text2);font-size:12px;font-weight:700}
.theme-btn:hover{background:var(--surface3);color:var(--text)}
.theme-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.settings-btn{width:34px;height:34px;border-radius:var(--radius-xs);background:var(--surface2);border:1px solid var(--border);color:var(--text2);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.settings-btn:hover{background:var(--surface3)}
.settings-btn.has-warning{border-color:var(--orange)}
.user-pill{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;cursor:pointer;transition:all .2s}
.user-pill:hover{border-color:var(--accent)}
.user-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover}
.user-avatar-placeholder{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center}
.user-name{font-size:12px;font-weight:700;color:var(--text)}

/* ── Stats ── */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:22px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;text-align:center}
.stat-val{font-size:26px;font-weight:800;font-family:'Nunito',sans-serif;color:var(--accent)}
.stat-val.streak{color:var(--orange)}
.stat-val.green{color:var(--green)}
.stat-label{font-size:11px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}

/* ── Nav tabs ── */
.nav-tabs{display:flex;gap:6px;margin-bottom:22px;background:var(--surface);padding:6px;border-radius:var(--radius-sm);border:1px solid var(--border)}
.nav-tab{flex:1;padding:9px 8px;border-radius:var(--radius-xs);font-size:13px;font-weight:700;color:var(--text3);background:transparent;text-align:center;transition:all .2s;border:none;cursor:pointer}
.nav-tab:hover{color:var(--text);background:var(--surface2)}
.nav-tab.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px rgba(108,99,255,0.3)}

/* ── Deck grid ── */
.deck-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.deck-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:all .2s;position:relative;overflow:hidden}
.deck-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.deck-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--accent)}
.deck-icon{font-size:28px;margin-bottom:10px}
.deck-name{font-size:15px;font-weight:700;font-family:'Nunito',sans-serif;margin-bottom:5px;color:var(--text)}
.deck-meta{font-size:12px;color:var(--text3)}
.deck-progress{height:4px;background:var(--surface3);border-radius:2px;margin-top:10px;overflow:hidden}
.deck-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent3));border-radius:2px;transition:width .5s}
.deck-actions{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.deck-actions-row{display:flex;gap:6px}
.due-badge{position:absolute;top:10px;right:10px;background:var(--red);color:#fff;font-size:10px;font-weight:800;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.add-deck-card{border:2px dashed var(--border);background:transparent;border-radius:var(--radius);padding:18px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:150px;color:var(--text3)}
.add-deck-card:hover{border-color:var(--accent);color:var(--accent)}
.add-deck-card .plus{font-size:32px;margin-bottom:8px}
.add-deck-card span{font-size:13px;font-weight:700}

/* ── Buttons ── */
.btn-sm{padding:6px 12px;border-radius:var(--radius-xs);font-size:12px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.btn-study{width:100%;padding:9px 12px;border-radius:var(--radius-xs);font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .2s}
.btn-icon{width:34px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xs);font-size:14px;cursor:pointer;border:none;transition:all .2s;flex-shrink:0}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(1.1)}
.btn-ghost{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--surface3);color:var(--text)}
.btn-danger{background:rgba(255,101,132,0.12);color:var(--red);border:1px solid rgba(255,101,132,0.2)}
.btn-danger:hover{background:rgba(255,101,132,0.22)}
.btn-success{background:rgba(67,217,173,0.15);color:var(--green);border:1px solid rgba(67,217,173,0.3)}

/* ── Study ── */
.study-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.back-btn{padding:8px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text2);font-size:13px;font-weight:700;white-space:nowrap;cursor:pointer}
.back-btn:hover{color:var(--text);background:var(--surface2)}
.progress-track{flex:1;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent3));border-radius:4px;transition:width .4s}
.progress-text{font-size:13px;color:var(--text3);font-weight:700;white-space:nowrap}
.card-scene{perspective:1200px;margin:0 auto 20px;max-width:600px}
.card-3d{position:relative;width:100%;height:280px;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);cursor:pointer}
.card-3d.flipped{transform:rotateY(180deg)}
.card-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:var(--radius);padding:32px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border:1px solid var(--border)}
.card-front{background:var(--surface)}
.card-back{background:var(--surface);transform:rotateY(180deg)}
.card-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;padding:4px 12px;border-radius:20px}
.card-front .card-label{background:rgba(108,99,255,0.15);color:var(--accent)}
.card-back .card-label{background:rgba(67,217,173,0.15);color:var(--green)}
.card-text{font-size:20px;font-weight:600;font-family:'Nunito',sans-serif;color:var(--text);line-height:1.4}
.tap-hint{font-size:12px;color:var(--text3);margin-top:16px}
.rating-row{display:flex;gap:10px;max-width:600px;margin:0 auto 16px}
.rating-btn{flex:1;padding:14px 8px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer}
.rating-btn:hover{transform:translateY(-2px);filter:brightness(1.1)}
.rating-btn .days{font-size:10px;font-weight:600;opacity:.7}
.btn-again{background:rgba(255,101,132,0.15);color:var(--red);border:1px solid rgba(255,101,132,0.3)}
.btn-hard{background:rgba(255,155,62,0.15);color:var(--orange);border:1px solid rgba(255,155,62,0.3)}
.btn-good{background:rgba(108,99,255,0.15);color:var(--accent);border:1px solid rgba(108,99,255,0.3)}
.btn-easy{background:rgba(67,217,173,0.15);color:var(--green);border:1px solid rgba(67,217,173,0.3)}
.ai-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;max-width:600px;margin:0 auto 16px}
.ai-panel-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.ai-badge{font-size:11px;font-weight:700;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}
.ai-response{font-size:13px;color:var(--text2);line-height:1.6;white-space:pre-wrap}
.ai-btns{display:flex;gap:8px;max-width:600px;margin:0 auto 16px}
.ai-btn{flex:1;padding:10px;border-radius:var(--radius-xs);font-size:12px;font-weight:700;background:var(--surface);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .2s}
.ai-btn:hover{border-color:var(--accent);color:var(--accent);background:rgba(108,99,255,0.05)}
.ai-btn:disabled{opacity:.5;cursor:not-allowed}

/* ── Session complete ── */
.session-complete{text-align:center;padding:40px 20px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border)}
.complete-icon{font-size:64px;margin-bottom:16px}
.complete-title{font-size:28px;font-weight:800;font-family:'Nunito',sans-serif;margin-bottom:8px}
.complete-sub{color:var(--text2);margin-bottom:24px}
.complete-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;max-width:400px;margin-left:auto;margin-right:auto}
.complete-stat{background:var(--surface2);border-radius:var(--radius-xs);padding:12px}
.complete-stat-val{font-size:22px;font-weight:800;font-family:'Nunito',sans-serif}
.complete-stat-label{font-size:11px;color:var(--text3);font-weight:700}

/* ── Cards view ── */
.cards-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.search-input{flex:1;min-width:180px;max-width:300px;padding:9px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:13px;transition:border-color .2s}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:var(--text3)}
.card-list{display:flex;flex-direction:column;gap:8px}
.card-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;display:flex;align-items:center;gap:12px}
.card-item-content{flex:1;min-width:0}
.card-q{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-a{font-size:12px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-status{font-size:10px;font-weight:700;text-transform:uppercase;padding:3px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.status-new{background:rgba(108,99,255,0.15);color:var(--accent)}
.status-learning{background:rgba(255,155,62,0.15);color:var(--orange)}
.status-review{background:rgba(67,217,173,0.15);color:var(--green)}

/* ── AI Generator ── */
.ai-gen{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:22px}
.ai-gen-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.ai-gen-title{font-size:16px;font-weight:800;font-family:'Nunito',sans-serif}
.gen-tabs{display:flex;gap:4px;margin-bottom:14px;background:var(--surface2);padding:4px;border-radius:var(--radius-xs)}
.gen-tab{flex:1;padding:7px 8px;border-radius:4px;font-size:12px;font-weight:700;color:var(--text3);background:transparent;border:none;cursor:pointer;transition:all .2s;text-align:center}
.gen-tab:hover{color:var(--text)}
.gen-tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.2)}
.gen-row{display:flex;gap:8px}
.gen-input{flex:1;padding:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:13px;transition:border-color .2s}
.gen-input:focus{border-color:var(--accent)}
.gen-input::placeholder{color:var(--text3)}
.gen-btn{padding:10px 20px;background:var(--accent);color:#fff;border-radius:var(--radius-xs);font-size:13px;font-weight:700;white-space:nowrap;cursor:pointer;border:none;transition:all .2s}
.gen-btn:hover{filter:brightness(1.1)}
.gen-btn:disabled{opacity:.5;cursor:not-allowed}
.drop-zone{border:2px dashed var(--border);border-radius:var(--radius-sm);padding:28px 20px;text-align:center;cursor:pointer;transition:all .25s;position:relative;background:var(--surface2)}
.drop-zone:hover,.drop-zone.dragover{border-color:var(--accent);background:rgba(108,99,255,0.06)}
.drop-zone-icon{font-size:36px;margin-bottom:10px}
.drop-zone-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:4px}
.drop-zone-sub{font-size:12px;color:var(--text3)}
.drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.img-preview-wrap{position:relative;display:inline-block;margin-top:12px}
.img-preview{max-width:100%;max-height:180px;border-radius:var(--radius-xs);border:1px solid var(--border);display:block}
.img-preview-remove{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--red);color:#fff;font-size:12px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.gen-preview{display:flex;flex-direction:column;gap:8px}
.gen-card-preview{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);padding:12px 14px;display:flex;align-items:flex-start;gap:10px}
.gen-card-num{font-size:12px;font-weight:800;color:var(--accent);min-width:20px;flex-shrink:0;margin-top:1px}
.gen-card-q{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.gen-card-a{font-size:12px;color:var(--text3)}
.img-count-badge{display:inline-block;background:rgba(108,99,255,0.15);color:var(--accent);font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;margin-left:6px}
.loading-indicator{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2)}

/* ── Modal ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.72);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;backdrop-filter:blur(4px)}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;display:flex;flex-direction:column}
.modal-header{padding:20px 24px 0;display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-shrink:0}
.modal-header h3{font-size:18px;font-weight:800}
.modal-close{width:30px;height:30px;border-radius:var(--radius-xs);background:var(--surface2);border:1px solid var(--border);color:var(--text3);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.modal-close:hover{color:var(--text);background:var(--surface3)}
.modal-body{padding:0 24px;flex:1;overflow-y:auto}
.modal-footer{padding:16px 24px 20px;flex-shrink:0;display:flex;gap:10px;justify-content:flex-end;border-top:1px solid var(--border);margin-top:20px}
.form-group{margin-bottom:16px}
.form-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:6px;display:block}
.form-label-sub{font-size:11px;color:var(--text3);font-weight:400;text-transform:none;letter-spacing:0;margin-left:4px}
.form-input{width:100%;padding:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:14px;transition:border-color .2s}
.form-input:focus{border-color:var(--accent)}
.form-input::placeholder{color:var(--text3)}
.form-textarea{width:100%;padding:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:14px;resize:vertical;min-height:80px;transition:border-color .2s}
.form-textarea:focus{border-color:var(--accent)}
.icon-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:6px;margin-top:6px}
.icon-opt{padding:8px;border-radius:var(--radius-xs);background:var(--surface2);border:1px solid var(--border);font-size:18px;cursor:pointer;text-align:center;transition:all .2s}
.icon-opt:hover,.icon-opt.selected{border-color:var(--accent);background:rgba(108,99,255,0.15)}

/* ── Settings ── */
.settings-tabs{display:flex;gap:4px;margin-bottom:22px;background:var(--surface2);padding:4px;border-radius:var(--radius-xs);flex-wrap:wrap}
.stab{flex:1;min-width:80px;padding:8px 6px;border-radius:4px;font-size:12px;font-weight:700;border:none;cursor:pointer;transition:all .2s;color:var(--text3);background:transparent;text-align:center}
.stab:hover{color:var(--text)}
.stab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,.2)}
.settings-section{margin-bottom:22px}
.settings-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface2);border-radius:var(--radius-xs);margin-bottom:6px;gap:12px;border:1px solid transparent;transition:border-color .2s}
.settings-row-active{border-color:var(--accent) !important}
.settings-row-left{flex:1;min-width:0}
.settings-row-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.settings-row-sub{font-size:11px;color:var(--text3)}
.sb-status-banner{padding:12px 14px;border-radius:var(--radius-xs);margin-bottom:14px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}
.sb-status-banner.ok{background:rgba(67,217,173,0.1);color:var(--green);border:1px solid rgba(67,217,173,0.25)}
.provider-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:10px;transition:border-color .2s}
.provider-card.active-provider{border-color:var(--accent)}
.provider-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.provider-logo{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.provider-name{font-size:13px;font-weight:700;color:var(--text)}
.provider-desc{font-size:11px;color:var(--text3)}
.provider-status{margin-left:auto;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px}
.pstatus-active{background:rgba(67,217,173,0.15);color:var(--green)}
.pstatus-configured{background:rgba(108,99,255,0.15);color:var(--accent)}
.pstatus-none{background:var(--surface3);color:var(--text3)}
.key-input-row{display:flex;gap:8px}
.key-input{flex:1;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:12px;font-family:monospace;transition:border-color .2s}
.key-input:focus{border-color:var(--accent)}
.key-input::placeholder{color:var(--text3)}
.danger-zone{background:rgba(255,101,132,0.06);border:1px solid rgba(255,101,132,0.2);border-radius:var(--radius-sm);padding:14px 16px}
.danger-zone-title{font-size:12px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}

/* ── Empty / misc ── */
.empty{text-align:center;padding:40px 20px;color:var(--text3)}
.empty-icon{font-size:48px;margin-bottom:12px}
.empty-text{font-size:14px;font-weight:600}
.toast{position:fixed;bottom:24px;right:24px;padding:12px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:700;z-index:9999;animation:slideUp .3s ease;max-width:320px;display:flex;align-items:center;gap:8px;box-shadow:0 8px 24px rgba(0,0,0,0.3)}
.toast.success{background:var(--green);color:#0F0E17}
.toast.error{background:var(--red);color:#fff}
.toast.info{background:var(--accent);color:#fff}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* ── Responsive ── */
@media(max-width:600px){
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .rating-row{flex-wrap:wrap}
  .rating-btn{min-width:calc(50% - 5px)}
  .deck-grid{grid-template-columns:1fr 1fr}
  .login-card{padding:28px 20px}
  .settings-tabs{gap:2px}
  .stab{font-size:11px;padding:6px 4px}
}
