/* ═══════════════════════════════════════════════
   THEME VARIABLES
═══════════════════════════════════════════════ */
[data-theme="dark"]{
  --green:#25D366;--green-dark:#128C7E;--accent:#00e676;
  --bg:#0a0f0a;--surface:#111811;--surface2:#182018;--surface3:#1e281e;
  --border:#25D36622;--border2:#25D36640;--text:#e8f5e9;--muted:#5a7a5a;
  --danger:#ff5252;--warn:#ffab40;--info:#64b5f6;
  --modal-bg:rgba(0,0,0,0.88);--input-bg:#182018;--shadow:rgba(0,0,0,0.5);
  --purple:#a855f7;--purple2:#6c3de0;
}
[data-theme="light"]{
  --green:#128C7E;--green-dark:#075E54;--accent:#00897b;
  --bg:#f0f7f4;--surface:#ffffff;--surface2:#e8f5e9;--surface3:#d4edda;
  --border:#25D36628;--border2:#25D36650;--text:#1a2e1a;--muted:#5a8a6a;
  --danger:#d32f2f;--warn:#f57c00;--info:#1976d2;
  --modal-bg:rgba(0,0,0,0.55);--input-bg:#f5faf5;--shadow:rgba(0,0,0,0.13);
  --purple:#7c3aed;--purple2:#5b21b6;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;transition:background .3s,color .3s}
body::before{content:'';position:fixed;inset:0;background-image:linear-gradient(rgba(37,211,102,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(37,211,102,.025) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}

/* ═══════════════════════════════════════════════
   LANDING / ROLE PICKER
═══════════════════════════════════════════════ */
#landingScreen{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}
.landing-wrap{width:100%;max-width:480px;text-align:center;animation:fadeUp .6s ease}
.landing-logo{font-size:60px;margin-bottom:20px;filter:drop-shadow(0 0 20px rgba(37,211,102,.4))}
.landing-wrap h1{font-family:'Inter',sans-serif;font-size:26px;font-weight:800;color:var(--accent);margin-bottom:8px}
.landing-wrap p{font-size:12px;color:var(--muted);margin-bottom:40px;letter-spacing:.5px}
.role-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.role-card{background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:32px 20px;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.role-card::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .3s}
.role-card.user-card::before{background:radial-gradient(ellipse at top,rgba(37,211,102,.08),transparent 70%)}
.role-card.admin-card::before{background:radial-gradient(ellipse at top,rgba(168,85,247,.08),transparent 70%)}
.role-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px var(--shadow)}
.role-card:hover::before{opacity:1}
.role-card.user-card:hover{border-color:var(--green)}
.role-card.admin-card:hover{border-color:var(--purple)}
.role-icon{font-size:40px;margin-bottom:14px}
.role-card h3{font-family:'Inter',sans-serif;font-size:16px;font-weight:800;margin-bottom:6px}
.role-card.user-card h3{color:var(--green)}
.role-card.admin-card h3{color:var(--purple)}
.role-card p{font-size:11px;color:var(--muted);line-height:1.6}
.role-badge{position:absolute;top:12px;right:12px;font-size:9px;padding:3px 8px;border-radius:99px;font-weight:700;letter-spacing:.5px}
.role-card.user-card .role-badge{background:rgba(37,211,102,.15);color:var(--green);border:1px solid rgba(37,211,102,.3)}
.role-card.admin-card .role-badge{background:rgba(168,85,247,.15);color:var(--purple);border:1px solid rgba(168,85,247,.3)}

/* ═══════════════════════════════════════════════
   AUTH SCREENS (shared base)
═══════════════════════════════════════════════ */
.auth-screen{position:fixed;inset:0;background:var(--bg);display:none;align-items:center;justify-content:center;z-index:9998;padding:20px;overflow-y:auto}
.auth-screen.visible{display:flex}
.auth-card{background:var(--surface);border:1px solid var(--border2);border-radius:24px;padding:40px 36px;width:100%;max-width:420px;animation:fadeUp .5s ease;box-shadow:0 24px 80px var(--shadow)}
.auth-back{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);cursor:pointer;margin-bottom:24px;width:fit-content;transition:color .2s}
.auth-back:hover{color:var(--text)}
.auth-logo-wrap{text-align:center;margin-bottom:20px}
.auth-logo-wrap .icon{font-size:46px;display:block;margin-bottom:10px}
.auth-logo-wrap h2{font-family:'Inter',sans-serif;font-size:22px;font-weight:800;margin-bottom:4px}
.auth-logo-wrap p{font-size:12px;color:var(--muted)}
.auth-logo-wrap.user h2{color:var(--green)}
.auth-logo-wrap.admin h2{color:var(--purple)}
.auth-tabs{display:grid;grid-template-columns:1fr 1fr;background:var(--surface2);border-radius:12px;padding:4px;margin-bottom:24px;gap:4px}
.auth-tab{padding:9px;text-align:center;border-radius:9px;font-family:'Inter',sans-serif;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;color:var(--muted)}
.auth-tab.active{background:var(--surface);color:var(--green);box-shadow:0 2px 8px var(--shadow)}
.field-group{margin-bottom:16px}
.field-group label{display:block;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.field-input{width:100%;padding:12px 14px;background:var(--input-bg);border:1px solid var(--border2);border-radius:11px;color:var(--text);font-family:'Inter',sans-serif;font-size:14px;outline:none;transition:border .2s}
.field-input:focus{border-color:var(--green)}
.field-input.admin-focus:focus{border-color:var(--purple)}
.field-input.error{border-color:var(--danger)}
.otp-group{display:flex;gap:8px;justify-content:center;margin-bottom:16px}
.otp-input{width:48px;height:52px;text-align:center;font-size:20px;font-weight:700;letter-spacing:0;background:var(--input-bg);border:1px solid var(--border2);border-radius:11px;color:var(--text);outline:none;transition:border .2s;font-family:'Inter',sans-serif}
.otp-input:focus{border-color:var(--green)}
.auth-btn{width:100%;padding:13px;border:none;border-radius:12px;font-family:'Inter',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px}
.auth-btn.green{background:var(--green);color:#fff}
.auth-btn.green:hover{background:var(--accent);transform:translateY(-1px)}
.auth-btn.purple{background:linear-gradient(135deg,var(--purple2),var(--purple));color:#fff}
.auth-btn.purple:hover{opacity:.9;transform:translateY(-1px)}
.auth-btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}
.auth-msg{font-size:11px;text-align:center;margin-top:10px;min-height:16px;transition:all .2s}
.auth-msg.error{color:var(--danger)}
.auth-msg.success{color:var(--accent)}
.auth-msg.info{color:var(--info)}
.auth-divider{text-align:center;font-size:10px;color:var(--muted);margin:14px 0;position:relative}
.auth-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border2)}
.auth-divider span{background:var(--surface);padding:0 10px;position:relative}
.resend-row{display:flex;justify-content:space-between;align-items:center;margin-top:10px}
.resend-btn{font-size:11px;color:var(--green);cursor:pointer;background:none;border:none;font-family:'Inter',sans-serif}
.resend-btn:disabled{color:var(--muted);cursor:not-allowed}
.timer{font-size:11px;color:var(--muted)}
.pw-toggle{position:relative}
.pw-toggle .field-input{padding-right:42px}
.pw-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;font-size:16px;color:var(--muted);user-select:none}
.strength-bar{height:3px;border-radius:99px;margin-top:6px;background:var(--surface2);overflow:hidden}
.strength-fill{height:100%;border-radius:99px;transition:all .3s}
.terms{font-size:10px;color:var(--muted);text-align:center;margin-top:12px;line-height:1.6}

/* ═══════════════════════════════════════════════
   ADMIN PANEL
═══════════════════════════════════════════════ */
#adminPanel{display:none;position:fixed;inset:0;background:var(--bg);z-index:9990;overflow-y:auto}
.admin-container{max-width:900px;margin:0 auto;padding:28px 20px;position:relative;z-index:1}
.admin-header{display:flex;align-items:center;gap:14px;margin-bottom:28px;animation:slideDown .5s ease}
.admin-logo{width:46px;height:46px;background:linear-gradient(135deg,var(--purple2),var(--purple));border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 0 24px rgba(168,85,247,.35)}
.admin-header h1{font-family:'Inter',sans-serif;font-size:20px;font-weight:800;color:var(--purple)}
.admin-header p{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
@media(max-width:600px){.admin-stats{grid-template-columns:repeat(2,1fr)}}
.astat{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:16px;text-align:center}
.astat .val{font-family:'Inter',sans-serif;font-size:28px;font-weight:800;color:var(--purple);font-variant-numeric:tabular-nums}
.astat .lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}
.admin-panel-card{background:var(--surface);border:1px solid var(--border2);border-radius:18px;overflow:hidden;margin-bottom:20px}
.table-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.acard-header{background:var(--surface2);padding:14px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border2)}
.acard-header h3{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;color:var(--purple);flex:1}
.users-table{width:100%;border-collapse:collapse}
.users-table th{background:var(--surface2);padding:10px 16px;text-align:left;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:400}
.users-table td{padding:11px 16px;font-size:12px;border-top:1px solid rgba(168,85,247,.07);vertical-align:middle}
.users-table tr:hover td{background:rgba(168,85,247,.03)}
.user-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;padding:3px 9px;border-radius:99px}
.user-badge.active{background:rgba(37,211,102,.15);color:var(--green);border:1px solid rgba(37,211,102,.3)}
.user-badge.suspended{background:rgba(255,82,82,.15);color:var(--danger);border:1px solid rgba(255,82,82,.3)}
.user-badge.pending{background:rgba(255,171,64,.15);color:var(--warn);border:1px solid rgba(255,171,64,.3)}
.action-btn{padding:4px 11px;border-radius:7px;font-size:10px;font-family:'Inter',sans-serif;font-weight:700;border:none;cursor:pointer;transition:all .2s;margin:0 2px}
.action-btn.reset{background:rgba(100,181,246,.15);color:var(--info);border:1px solid rgba(100,181,246,.3)}
.action-btn.reset:hover{background:rgba(100,181,246,.3)}
.action-btn.suspend{background:rgba(255,82,82,.1);color:var(--danger);border:1px solid rgba(255,82,82,.25)}
.action-btn.suspend:hover{background:rgba(255,82,82,.2)}
.action-btn.activate{background:rgba(37,211,102,.1);color:var(--green);border:1px solid rgba(37,211,102,.25)}
.action-btn.activate:hover{background:rgba(37,211,102,.2)}
.admin-empty{text-align:center;padding:40px;color:var(--muted);font-size:12px}
.admin-loading{text-align:center;padding:30px;color:var(--muted);font-size:12px;display:flex;align-items:center;justify-content:center;gap:10px}

/* ═══════════════════════════════════════════════
   MAIN APP
═══════════════════════════════════════════════ */
#appContainer{display:none;position:relative;z-index:1}
.container{max-width:980px;margin:0 auto;padding:28px 20px}
@media(max-width:480px){.container{padding:16px 12px}}
.header{display:flex;align-items:center;gap:14px;margin-bottom:28px;animation:slideDown .6s ease;flex-wrap:wrap}
.logo{width:48px;height:48px;background:var(--green);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 0 24px rgba(37,211,102,.35);flex-shrink:0}
.header-text h1{font-family:'Inter',sans-serif;font-size:20px;font-weight:800;color:var(--accent);letter-spacing:-.5px}
.header-text p{font-size:10px;color:var(--muted);margin-top:2px;letter-spacing:1px;text-transform:uppercase}
.header-right{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.user-chip{display:flex;align-items:center;gap:7px;background:var(--surface2);border:1px solid var(--border2);border-radius:99px;padding:5px 12px 5px 8px;font-size:11px;color:var(--muted)}
.user-chip .avatar-sm{width:22px;height:22px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;font-weight:700}
.status-pill{padding:5px 12px;border-radius:99px;font-size:11px;display:flex;align-items:center;gap:6px;transition:all .3s}
.status-pill.idle{background:rgba(90,122,90,.2);color:var(--muted);border:1px solid var(--muted)}
.status-pill.active{background:rgba(37,211,102,.15);color:var(--green);border:1px solid var(--green)}
.status-pill.calling{background:rgba(0,230,118,.15);color:var(--accent);border:1px solid var(--accent);animation:pulse-border 1.5s infinite}
/* Subscription badge */
.sub-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:99px;font-size:11px;font-family:'Inter',sans-serif;font-weight:700;letter-spacing:.3px;border:1px solid transparent;transition:all .3s;cursor:default}
.sub-badge.safe{background:rgba(37,211,102,.12);color:var(--green);border-color:rgba(37,211,102,.3)}
.sub-badge.warn{background:rgba(255,171,64,.12);color:var(--warn);border-color:rgba(255,171,64,.35);animation:pulse-border 2s infinite}
.sub-badge.critical{background:rgba(255,82,82,.15);color:var(--danger);border-color:rgba(255,82,82,.4);animation:pulse-border 1s infinite}
.sub-badge.expired{background:rgba(255,82,82,.2);color:var(--danger);border-color:var(--danger)}
/* Expired overlay */
#expiredOverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:99999;align-items:center;justify-content:center;padding:20px}
#expiredOverlay.show{display:flex}
.expired-card{background:var(--surface);border:1px solid var(--danger);border-radius:24px;padding:44px 36px;max-width:420px;width:100%;text-align:center;animation:fadeUp .5s ease;box-shadow:0 0 60px rgba(255,82,82,.25)}
.expired-icon{font-size:60px;margin-bottom:18px}
.expired-card h2{font-family:'Inter',sans-serif;font-size:22px;font-weight:800;color:var(--danger);margin-bottom:10px}
.expired-card p{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:6px}
.expired-card .admin-contact{margin-top:18px;background:rgba(255,82,82,.07);border:1px solid rgba(255,82,82,.2);border-radius:12px;padding:14px;font-size:12px;color:var(--text)}
/* Admin subscription input */
.sub-input{background:var(--input-bg);border:1px solid var(--border2);color:var(--text);padding:5px 9px;border-radius:7px;font-family:'Inter',sans-serif;font-size:11px;outline:none;width:130px}
.sub-input:focus{border-color:var(--purple)}
.sub-days-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:99px;font-size:10px;font-weight:700;font-family:'Inter',sans-serif}
.sub-days-badge.safe{background:rgba(37,211,102,.15);color:var(--green)}
.sub-days-badge.warn{background:rgba(255,171,64,.15);color:var(--warn)}
.sub-days-badge.critical{background:rgba(255,82,82,.15);color:var(--danger)}
.sub-days-badge.expired{background:rgba(255,82,82,.2);color:var(--danger)}
.sub-days-badge.none{background:var(--surface2);color:var(--muted)}
.icon-btn{width:36px;height:36px;border-radius:10px;background:var(--surface2);border:1px solid var(--border2);cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.icon-btn:hover{border-color:var(--green);transform:scale(1.05)}
.dot{width:7px;height:7px;border-radius:50%;background:currentColor}
.dot.blink{animation:blink 1s infinite}

/* UPLOAD */
#uploadZone{border:2px dashed var(--border2);border-radius:20px;padding:52px 32px;text-align:center;cursor:pointer;transition:all .3s;background:var(--surface);margin-bottom:24px;position:relative;overflow:hidden;animation:fadeUp .7s ease}
#uploadZone::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(37,211,102,.05) 0%,transparent 70%);pointer-events:none}
#uploadZone:hover,#uploadZone.drag-over{border-color:var(--green);background:rgba(37,211,102,.04);transform:translateY(-2px);box-shadow:0 12px 40px rgba(37,211,102,.1)}
#uploadZone .upload-icon{font-size:44px;margin-bottom:14px}
#uploadZone h2{font-family:'Inter',sans-serif;font-size:17px;font-weight:700;margin-bottom:6px}
#uploadZone p{font-size:12px;color:var(--muted)}
#uploadZone .supported{margin-top:14px;font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase}
#fileInput{display:none}
.btn-upload{display:inline-flex;align-items:center;gap:8px;margin-top:18px;padding:10px 22px;background:var(--green);color:#fff;border:none;border-radius:10px;font-family:'Inter',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s}
.btn-upload:hover{background:var(--accent);transform:scale(1.03)}

/* CONFIG */
.config-bar{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:18px 20px;margin-bottom:20px;display:none;animation:fadeUp .4s ease}
.config-bar h4{font-family:'Inter',sans-serif;font-size:12px;color:var(--green);margin-bottom:14px}
.config-fields{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
@media(max-width:480px){.config-fields{flex-direction:column}.config-field{width:100%}}
.config-field{display:flex;flex-direction:column;gap:4px}
.config-field label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.config-field select,.config-field input[type=text]{background:var(--input-bg);border:1px solid var(--border2);color:var(--text);padding:8px 12px;border-radius:8px;font-family:'Inter',sans-serif;font-size:12px;outline:none}
.config-field select:focus,.config-field input[type=text]:focus{border-color:var(--green)}

/* STATS */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;animation:fadeUp .5s ease}
.stat-card{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:16px;text-align:center;transition:all .3s}
.stat-card:hover{border-color:var(--green);transform:translateY(-1px)}
.stat-card .val{font-family:'Inter',sans-serif;font-size:26px;font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums}
.stat-card .lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}

/* DIALER */
.dialer-panel{background:var(--surface);border:1px solid var(--border2);border-radius:20px;overflow:hidden;margin-bottom:20px;animation:fadeUp .6s ease}
.panel-header{background:var(--surface2);padding:14px 20px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border2);flex-wrap:wrap}
.panel-header h3{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;color:var(--green);flex:1}
.current-call{padding:22px 20px;display:flex;align-items:center;gap:18px;border-bottom:1px solid var(--border2)}
.av{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--green-dark),var(--green));display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;position:relative}
.av.calling::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--green);animation:ring 1.5s infinite}
.call-info{flex:1}
.call-info .lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.call-info .num{font-family:'Inter',sans-serif;font-size:24px;font-weight:800;letter-spacing:2px;color:var(--text);margin:4px 0;font-variant-numeric:tabular-nums}
.call-info .cname{font-size:13px;color:var(--green)}
.call-info .cnote{font-size:11px;color:var(--muted);margin-top:2px}
.call-actions{display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.call-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.outcome-row,.templates-row{padding:11px 20px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.section-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;white-space:nowrap;margin-right:2px}
.outcome-btn{padding:5px 11px;border-radius:99px;font-size:11px;font-family:'Inter',sans-serif;font-weight:700;border:1px solid transparent;cursor:pointer;transition:all .2s;background:var(--surface2);color:var(--muted)}
.outcome-btn:hover{transform:scale(1.04)}
.outcome-btn.sel-interested{background:rgba(37,211,102,.2);color:var(--green);border-color:var(--green)}
.outcome-btn.sel-callback{background:rgba(255,171,64,.2);color:var(--warn);border-color:var(--warn)}
.outcome-btn.sel-noanswer{background:rgba(90,122,90,.2);color:var(--muted);border-color:var(--muted)}
.outcome-btn.sel-notinterested{background:rgba(255,82,82,.2);color:var(--danger);border-color:var(--danger)}
.tpl-chip{padding:5px 12px;border-radius:8px;font-size:11px;font-family:'Inter',sans-serif;cursor:pointer;transition:all .2s;background:rgba(37,211,102,.07);color:var(--green);border:1px solid rgba(37,211,102,.2);display:inline-flex;align-items:center;gap:4px}
.tpl-chip:hover{background:rgba(37,211,102,.18);transform:translateY(-1px)}
.progress-wrap{padding:12px 20px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:12px}
.progress-bar{flex:1;height:5px;background:var(--surface2);border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--green-dark),var(--accent));border-radius:99px;transition:width .5s ease}
.progress-text{font-size:11px;color:var(--muted);white-space:nowrap}
.queue-scroll{max-height:280px;overflow-y:auto}
.queue-scroll::-webkit-scrollbar{width:4px}
.queue-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}
.queue-table{width:100%;border-collapse:collapse}
.queue-table th{background:var(--surface2);padding:9px 14px;text-align:left;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:400}
.queue-table td{padding:9px 14px;font-size:12px;border-top:1px solid rgba(37,211,102,.06);transition:all .2s}
.queue-table tr:hover td{background:rgba(37,211,102,.03)}
.queue-table tr.current td{background:rgba(37,211,102,.07)}
.queue-table tr.done td{opacity:.45}
.queue-table tr.skipped td{opacity:.3;text-decoration:line-through}
.row-status{display:inline-flex;align-items:center;gap:5px;font-size:10px;padding:3px 9px;border-radius:99px}
.jump-btn{background:rgba(37,211,102,.06);border:1px solid rgba(37,211,102,.2);color:var(--green);border-radius:6px;padding:3px 8px;font-size:11px;font-weight:700;cursor:pointer;transition:all .2s;font-family:'Inter',sans-serif}
.jump-btn:hover{background:rgba(37,211,102,.18);transform:scale(1.08)}
tr.done .jump-btn{opacity:.45}
tr.current .jump-btn{display:none}
.row-status.pending{background:rgba(90,122,90,.2);color:var(--muted)}
.row-status.current{background:rgba(37,211,102,.15);color:var(--green)}
.row-status.done{background:rgba(0,230,118,.1);color:var(--accent)}
.row-status.skipped{background:rgba(255,82,82,.1);color:var(--danger)}
.mono{font-family:'Inter',sans-serif;letter-spacing:1px}
.done-banner{display:none;background:linear-gradient(135deg,rgba(37,211,102,.1),rgba(0,230,118,.05));border:1px solid var(--green);border-radius:16px;padding:28px;text-align:center;margin-bottom:20px;animation:fadeUp .5s ease}
.done-banner .icon{font-size:44px;margin-bottom:10px}
.done-banner h2{font-family:'Inter',sans-serif;font-size:20px;font-weight:800;color:var(--accent)}
.done-banner p{color:var(--muted);font-size:12px;margin-top:6px}
.done-actions{display:flex;gap:10px;justify-content:center;margin-top:18px;flex-wrap:wrap}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;border:none;border-radius:10px;font-family:'Inter',sans-serif;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;text-decoration:none;letter-spacing:.3px}
.btn:disabled{opacity:.35;cursor:not-allowed;pointer-events:none}
.btn-call{background:var(--green);color:#fff;padding:11px 18px}
.btn-call:hover{background:var(--accent);box-shadow:0 0 18px rgba(37,211,102,.3)}
.btn-phone{background:rgba(33,150,243,.15);color:#64b5f6;border:1px solid rgba(33,150,243,.3);padding:11px 18px}
.btn-phone:hover{background:rgba(33,150,243,.28)}
.btn-next{background:rgba(37,211,102,.1);color:var(--green);border:1px solid var(--border2)}
.btn-next:hover:not(:disabled){background:rgba(37,211,102,.2)}
.btn-skip{background:rgba(255,82,82,.08);color:var(--danger);border:1px solid rgba(255,82,82,.2)}
.btn-skip:hover{background:rgba(255,82,82,.15)}
.btn-ai{background:linear-gradient(135deg,var(--purple2),var(--purple));color:#fff}
.btn-ai:hover{opacity:.9;box-shadow:0 0 18px rgba(168,85,247,.35)}
.btn-ghost{background:var(--surface2);color:var(--muted);border:1px solid var(--border2)}
.btn-ghost:hover{color:var(--text)}
.btn-confirm{background:var(--green);color:#fff}
.btn-confirm:hover{background:var(--accent)}

/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:var(--modal-bg);z-index:1000;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:20px;width:100%;max-width:620px;max-height:88vh;overflow-y:auto;animation:fadeUp .3s ease;box-shadow:0 32px 100px var(--shadow)}
.modal-header{padding:18px 22px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:10px;position:sticky;top:0;background:var(--surface);z-index:1}
.modal-header h3{font-family:'Inter',sans-serif;font-size:15px;font-weight:800;color:var(--accent);flex:1}
.modal-close{background:none;border:none;color:var(--muted);font-size:24px;cursor:pointer;line-height:1}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px 22px}
.modal-footer{padding:14px 22px;border-top:1px solid var(--border2);display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.ai-output{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:18px;font-size:13px;line-height:1.8;color:var(--text);white-space:pre-wrap;min-height:120px}
.ai-loading{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;padding:24px 0}
.ai-spinner{width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
.tpl-modal-list{display:flex;flex-direction:column;gap:10px}
.tpl-item{background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .2s}
.tpl-item:hover{border-color:var(--green);background:rgba(37,211,102,.05);transform:translateY(-1px)}
.tpl-item .tpl-name{font-family:'Inter',sans-serif;font-size:12px;font-weight:700;color:var(--green);margin-bottom:5px}
.tpl-item .tpl-preview{font-size:11px;color:var(--muted);line-height:1.5}
.tpl-item .tpl-send{font-size:10px;color:var(--accent);margin-top:8px;letter-spacing:.5px;text-transform:uppercase}

.note{font-size:10px;color:var(--muted);text-align:center;margin-top:16px;line-height:1.8;padding:0 20px}

/* ═══════════════════════════════════════════════
   CUSTOM CONFIRM / ALERT MODAL
═══════════════════════════════════════════════ */
#appConfirmOverlay{display:none;position:fixed;inset:0;background:var(--modal-bg);z-index:99990;align-items:center;justify-content:center;padding:20px}
#appConfirmOverlay.open{display:flex}
.confirm-card{background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:32px 28px;max-width:400px;width:100%;text-align:center;animation:fadeUp .25s ease;box-shadow:0 24px 80px var(--shadow)}
.confirm-icon{font-size:40px;margin-bottom:14px}
.confirm-title{font-family:'Inter',sans-serif;font-size:16px;font-weight:800;color:var(--text);margin-bottom:8px}
.confirm-msg{font-size:13px;color:var(--muted);line-height:1.7;margin-bottom:22px;word-break:break-word}
.confirm-actions{display:flex;gap:10px;justify-content:center}
.confirm-actions .btn{min-width:100px;justify-content:center}

/* ═══════════════════════════════════════════════
   SKELETON LOADING
═══════════════════════════════════════════════ */
.skeleton{background:var(--surface2);border-radius:10px;position:relative;overflow:hidden}
.skeleton::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);animation:shimmer 1.5s infinite}
@keyframes shimmer{to{transform:translateX(100%)}}
.skeleton-stat{height:70px;border-radius:12px;border:1px solid var(--border2)}
.skeleton-text{height:14px;margin-bottom:8px;width:80%}
.skeleton-text.short{width:50%}

/* ═══════════════════════════════════════════════
   KEYBOARD SHORTCUT HINTS
═══════════════════════════════════════════════ */
.kbd-hint{display:inline-flex;align-items:center;gap:4px;font-size:9px;color:var(--muted);margin-left:4px;opacity:.7}
.kbd{display:inline-block;background:var(--surface2);border:1px solid var(--border2);border-radius:4px;padding:1px 5px;font-family:'Inter',sans-serif;font-size:9px;line-height:1.4}

/* ═══════════════════════════════════════════════
   F4 — SEARCH BAR
═══════════════════════════════════════════════ */
.search-bar{display:flex;gap:8px;padding:10px 20px;border-bottom:1px solid var(--border2);align-items:center}
.search-bar input{flex:1;background:var(--input-bg);border:1px solid var(--border2);border-radius:8px;padding:7px 12px;color:var(--text);font-family:'Inter',sans-serif;font-size:12px;outline:none;transition:border .2s}
.search-bar input:focus{border-color:var(--green)}
.search-bar select{background:var(--input-bg);border:1px solid var(--border2);border-radius:8px;padding:7px 10px;color:var(--text);font-family:'Inter',sans-serif;font-size:11px;outline:none;cursor:pointer}
.search-bar select:focus{border-color:var(--green)}
.search-bar .search-count{font-size:10px;color:var(--muted);white-space:nowrap}

/* ═══════════════════════════════════════════════
   F6 — DND TIME GUARD
═══════════════════════════════════════════════ */
.dnd-banner{background:rgba(255,171,64,.12);border:1px solid rgba(255,171,64,.3);border-radius:10px;padding:10px 16px;margin-bottom:16px;display:flex;align-items:center;gap:10px;animation:fadeUp .4s ease}
.dnd-banner .dnd-icon{font-size:20px;flex-shrink:0}
.dnd-banner .dnd-text{font-size:11px;color:var(--warn);flex:1;line-height:1.5}
.dnd-banner .dnd-text strong{color:var(--text)}
.dnd-banner .dnd-dismiss{background:none;border:none;color:var(--muted);cursor:pointer;font-size:16px;padding:4px}

/* ═══════════════════════════════════════════════
   F7 — CALL DURATION TIMER
═══════════════════════════════════════════════ */
.call-timer{display:inline-flex;align-items:center;gap:6px;background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.25);border-radius:8px;padding:4px 10px;font-family:'Inter',sans-serif;font-size:13px;font-weight:600;color:var(--green);letter-spacing:1px;font-variant-numeric:tabular-nums}
.call-timer.active{animation:pulse-border 2s infinite}
.call-timer .timer-icon{font-size:12px}
.call-bottom-row{display:flex;align-items:center;gap:10px;margin-top:8px;width:100%}
.call-bottom-row .call-timer{flex-shrink:0}
.call-bottom-row .btn-next{flex:1}
/* Duration cell in queue table */
.dur-cell{font-family:'Inter',sans-serif;font-size:10px;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}
.dur-cell.has-dur{color:var(--green);font-weight:600}

/* ═══════════════════════════════════════════════
   F2 — CALL NOTES
═══════════════════════════════════════════════ */
.notes-row{padding:10px 20px;border-bottom:1px solid var(--border2);display:flex;align-items:center;gap:8px}
.notes-row input{flex:1;background:var(--input-bg);border:1px solid var(--border2);border-radius:8px;padding:8px 12px;color:var(--text);font-family:'Inter',sans-serif;font-size:12px;outline:none;transition:border .2s}
.notes-row input:focus{border-color:var(--green)}
.notes-row input::placeholder{color:var(--muted);font-style:italic}

/* ═══════════════════════════════════════════════
   F9 — DUPLICATE BADGE
═══════════════════════════════════════════════ */
.dup-badge{display:inline-flex;align-items:center;gap:4px;background:rgba(255,171,64,.15);color:var(--warn);border:1px solid rgba(255,171,64,.3);border-radius:6px;padding:2px 7px;font-size:9px;font-weight:700}

/* ═══════════════════════════════════════════════
   F10 — TEMPLATE LANGUAGE SELECTOR
═══════════════════════════════════════════════ */
.tpl-lang-select{background:var(--input-bg);border:1px solid var(--border2);border-radius:8px;padding:5px 10px;color:var(--text);font-family:'Inter',sans-serif;font-size:11px;outline:none;cursor:pointer}
.tpl-lang-select:focus{border-color:var(--green)}
.tpl-lang-badge{font-size:9px;padding:2px 7px;border-radius:6px;background:rgba(37,211,102,.1);color:var(--green);border:1px solid rgba(37,211,102,.2)}

/* ═══════════════════════════════════════════════
   F5 — EXPORT BUTTONS
═══════════════════════════════════════════════ */
.btn-export{background:rgba(100,181,246,.1);color:#64b5f6;border:1px solid rgba(100,181,246,.25)}
.btn-export:hover{background:rgba(100,181,246,.2)}
.btn-export-excel{background:rgba(76,175,80,.1);color:#66bb6a;border:1px solid rgba(76,175,80,.25)}
.btn-export-excel:hover{background:rgba(76,175,80,.2)}

/* ═══════════════════════════════════════════════
   F8 — CALLBACK BANNER & SCHEDULER
═══════════════════════════════════════════════ */
.callback-banner{background:rgba(255,171,64,.08);border:1px solid rgba(255,171,64,.25);border-radius:14px;padding:14px 18px;margin-bottom:16px;animation:fadeUp .4s ease;cursor:pointer;transition:all .2s}
.callback-banner:hover{border-color:var(--warn);transform:translateY(-1px)}
.callback-banner .cb-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.callback-banner .cb-header .cb-icon{font-size:20px}
.callback-banner .cb-header .cb-title{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;color:var(--warn);flex:1}
.callback-banner .cb-header .cb-count{background:var(--warn);color:#000;font-size:11px;font-weight:700;padding:2px 8px;border-radius:99px}
.callback-banner .cb-list{display:flex;flex-direction:column;gap:6px}
.callback-banner .cb-item{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border2);border-radius:8px;padding:8px 12px;font-size:11px;color:var(--text)}
.callback-banner .cb-item .cb-name{font-weight:600;flex:1}
.callback-banner .cb-item .cb-time{color:var(--muted);font-size:10px}
.callback-banner .cb-item .cb-done-btn{background:rgba(37,211,102,.1);color:var(--green);border:1px solid rgba(37,211,102,.2);border-radius:6px;padding:3px 8px;font-size:10px;cursor:pointer;font-family:'Inter',sans-serif;font-weight:700}
.callback-sched{display:flex;gap:8px;align-items:center;margin-top:6px;padding-top:8px;border-top:1px solid var(--border2)}
.callback-sched input[type=date],.callback-sched input[type=time]{background:var(--input-bg);border:1px solid var(--border2);border-radius:7px;padding:5px 8px;color:var(--text);font-family:'Inter',sans-serif;font-size:11px;outline:none}
.callback-sched input:focus{border-color:var(--warn)}
/* Callback banner — action buttons */
.callback-banner .cb-item{flex-wrap:wrap}
.callback-banner .cb-note{font-size:10px;color:var(--muted);font-style:italic;width:100%;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.callback-banner .cb-actions{display:flex;gap:5px;align-items:center;margin-left:auto;flex-shrink:0}
.cb-call-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:7px;font-size:14px;text-decoration:none;transition:all .2s;cursor:pointer;border:none}
.cb-call-btn.wa{background:rgba(37,211,102,.12);border:1px solid rgba(37,211,102,.25)}
.cb-call-btn.wa:hover{background:rgba(37,211,102,.25);transform:scale(1.1)}
.cb-call-btn.phone{background:rgba(100,181,246,.12);border:1px solid rgba(100,181,246,.25)}
.cb-call-btn.phone:hover{background:rgba(100,181,246,.25);transform:scale(1.1)}
.cb-done-btn{background:rgba(37,211,102,.1);color:var(--green);border:1px solid rgba(37,211,102,.2);border-radius:7px;width:28px;height:28px;font-size:12px;cursor:pointer;font-family:'Inter',sans-serif;font-weight:700;display:inline-flex;align-items:center;justify-content:center;transition:all .2s}
.cb-done-btn:hover{background:rgba(37,211,102,.25);transform:scale(1.1)}
/* Callback banner — layout */
.callback-banner .cb-item{flex-direction:column;gap:0;padding:0;overflow:hidden}
.callback-banner .cb-top-row{display:flex;align-items:center;gap:8px;padding:8px 12px;width:100%}
.callback-banner .cb-note-row{display:flex;align-items:center;gap:8px;padding:6px 12px;background:rgba(255,171,64,.05);border-top:1px solid rgba(255,171,64,.12);width:100%}
.callback-banner .cb-note-icon{font-size:12px;flex-shrink:0}
.callback-banner .cb-note-input{flex:1;background:var(--input-bg);border:1px solid var(--border2);border-radius:7px;padding:5px 10px;color:var(--text);font-family:'Inter',sans-serif;font-size:11px;outline:none;transition:border .2s}
.callback-banner .cb-note-input:focus{border-color:var(--warn)}
.callback-banner .cb-note-input::placeholder{color:var(--muted);font-style:italic}
.cb-call-btn.note-toggle{background:rgba(255,171,64,.12);border:1px solid rgba(255,171,64,.25)}
.cb-call-btn.note-toggle:hover{background:rgba(255,171,64,.25);transform:scale(1.1)}

/* ═══════════════════════════════════════════════
   F1 — ANALYTICS DASHBOARD
═══════════════════════════════════════════════ */
.analytics-wrap{margin-top:20px}
.analytics-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.analytics-header h3{font-family:'Inter',sans-serif;font-size:14px;font-weight:800;color:var(--purple);flex:1}
.period-select{background:var(--input-bg);border:1px solid var(--border2);border-radius:8px;padding:5px 10px;color:var(--text);font-family:'Inter',sans-serif;font-size:11px;outline:none;cursor:pointer}
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
@media(max-width:600px){.chart-grid{grid-template-columns:1fr}}
.chart-card{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:16px;position:relative}
.chart-card h4{font-family:'Inter',sans-serif;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.chart-card canvas{width:100%!important;max-height:220px}

/* ═══════════════════════════════════════════════
   F3 — TEAM LEADERBOARD
═══════════════════════════════════════════════ */
.leaderboard-card{background:var(--surface);border:1px solid var(--border2);border-radius:14px;overflow:hidden;margin-top:16px}
.leaderboard-header{background:var(--surface2);padding:12px 18px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--border2)}
.leaderboard-header h3{font-family:'Inter',sans-serif;font-size:13px;font-weight:700;color:var(--purple);flex:1}
.leaderboard-table{width:100%;border-collapse:collapse}
.leaderboard-table th{background:var(--surface2);padding:8px 14px;text-align:left;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:400}
.leaderboard-table td{padding:10px 14px;font-size:12px;border-top:1px solid rgba(168,85,247,.06)}
.leaderboard-table tr:hover td{background:rgba(168,85,247,.03)}
.lb-rank{font-family:'Inter',sans-serif;font-weight:800;font-size:16px}
.lb-rank.gold{color:#ffd700}
.lb-rank.silver{color:#c0c0c0}
.lb-rank.bronze{color:#cd7f32}
.lb-bar{height:6px;border-radius:3px;background:var(--surface2);overflow:hidden;margin-top:4px}
.lb-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--purple2),var(--purple));transition:width .5s}

/* ═══════════════════════════════════════════════
   ADMIN TABS
═══════════════════════════════════════════════ */
.admin-tabs{display:flex;gap:4px;background:var(--surface2);border-radius:10px;padding:3px;margin-bottom:20px}
.admin-tab{padding:8px 16px;border-radius:8px;font-family:'Inter',sans-serif;font-size:11px;font-weight:700;cursor:pointer;transition:all .2s;color:var(--muted);border:none;background:none}
.admin-tab.active{background:var(--surface);color:var(--purple);box-shadow:0 2px 8px var(--shadow)}
.admin-tab:hover:not(.active){color:var(--text)}

/* ANIMATIONS */
@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse-border{0%,100%{box-shadow:0 0 0 0 rgba(37,211,102,.3)}50%{box-shadow:0 0 0 6px rgba(37,211,102,0)}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes ring{0%{transform:scale(1);opacity:1}100%{transform:scale(1.45);opacity:0}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ═══════════════════════════════════════════════
   RESPONSIVE — TABLET (max 768px)
═══════════════════════════════════════════════ */
@media(max-width:768px){
  .landing-wrap{max-width:100%;padding:0 8px}
  .landing-wrap h1{font-size:22px}
  .landing-logo{font-size:48px;margin-bottom:14px}
  .auth-card{padding:28px 20px;border-radius:18px;max-width:100%}
  .auth-logo-wrap h2{font-size:19px}
  #appScreen{padding:10px}
  .app-card{border-radius:16px}
  .app-header{padding:12px 16px;flex-wrap:wrap;gap:8px}
  .app-header .rep-info{font-size:11px}
  .header-actions{gap:6px}
  .stats-bar,.admin-stats{grid-template-columns:repeat(2,1fr);gap:8px;padding:12px}
  .stat-val{font-size:22px}
  .current-call{flex-direction:column;align-items:stretch;gap:12px;padding:14px 16px}
  .call-info .num{font-size:22px;letter-spacing:1px}
  .call-actions{flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:8px}
  .call-buttons{justify-content:flex-start;flex-wrap:wrap;gap:8px}
  .outcome-row,.templates-row{padding:10px 14px;gap:6px}
  .outcome-btn{padding:5px 10px;font-size:10px}
  .tpl-chip{font-size:10px;padding:4px 10px}
  .queue-table th,.queue-table td{padding:8px 10px;font-size:11px}
  .modal{border-radius:16px;max-height:92vh}
  .modal-footer{flex-direction:column}
  .modal-footer .btn{width:100%;justify-content:center}
}

/* ═══════════════════════════════════════════════
   RESPONSIVE — MOBILE (max 480px)
═══════════════════════════════════════════════ */
@media(max-width:480px){
  .role-cards{grid-template-columns:1fr;gap:12px}
  .landing-wrap h1{font-size:20px}
  .landing-logo{font-size:42px}
  .landing-wrap>p{margin-bottom:24px}
  .role-card{padding:22px 18px}
  .role-icon{font-size:32px;margin-bottom:10px}
  .auth-screen{padding:12px;align-items:flex-start;padding-top:40px}
  .auth-card{padding:24px 16px;border-radius:16px}
  .auth-logo-wrap .icon{font-size:36px}
  .auth-logo-wrap h2{font-size:17px}
  .otp-group{gap:5px}
  .otp-input{width:42px;height:46px;font-size:18px}
  .field-input{font-size:13px;padding:11px 12px}
  .auth-btn{padding:12px;font-size:13px}
  .app-header{padding:10px 12px}
  .app-header h1{font-size:13px}
  .btn{font-size:11px;padding:7px 12px;gap:5px}
  .stats-bar,.admin-stats{grid-template-columns:repeat(2,1fr);gap:6px;padding:10px 12px}
  .stat-card{padding:12px 10px;border-radius:12px}
  .stat-val{font-size:20px}
  .stat-lbl{font-size:9px}
  .upload-zone{padding:24px 16px;margin:12px}
  .upload-zone .upload-icon{font-size:36px}
  .upload-zone h3{font-size:14px}
  .upload-zone p{font-size:11px}
  .current-call{padding:12px 12px;gap:10px}
  .call-info .lbl{font-size:9px}
  .call-info .num{font-size:19px;letter-spacing:0}
  .call-info .cname{font-size:12px}
  .call-buttons{width:100%;gap:7px}
  .btn-call,.btn-phone{flex:1;justify-content:center;padding:11px 8px;font-size:12px}
  .btn-next,.btn-skip{padding:9px 12px;font-size:11px}
  .outcome-row,.templates-row{padding:8px 12px;gap:5px}
  .section-lbl{display:none}
  .outcome-btn{padding:5px 9px;font-size:10px;flex:1;text-align:center}
  .tpl-chip{font-size:10px;padding:4px 8px}
  .templates-row{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}
  .templates-row::-webkit-scrollbar{display:none}
  .progress-wrap{padding:9px 12px}
  .progress-text{font-size:10px}
  .queue-table .col-idx{display:none}
  .queue-table th,.queue-table td{padding:7px 8px;font-size:11px}
  .done-banner{padding:20px 14px}
  .done-banner h2{font-size:17px}
  .done-actions{flex-direction:column;align-items:stretch}
  .done-actions .btn{justify-content:center}
  .modal-overlay{align-items:flex-end;padding:0}
  .modal{border-radius:20px 20px 0 0;max-height:90vh;width:100%}
  .modal-footer{flex-direction:column;padding:12px 16px 24px}
  .modal-footer .btn{width:100%;justify-content:center;padding:12px}
  .ai-output{font-size:12px;padding:14px}
  .admin-header{flex-direction:column;align-items:flex-start;gap:8px}
  .users-table th,.users-table td{padding:7px 8px;font-size:11px}
  .users-table .col-email{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .note{font-size:9px;padding:0 12px}
}

/* ═══════════════════════════════════════════════
   RESPONSIVE — TINY PHONES (max 360px)
═══════════════════════════════════════════════ */
@media(max-width:360px){
  .otp-input{width:38px;height:42px;font-size:16px}
  .otp-group{gap:4px}
  .call-info .num{font-size:17px}
  .stats-bar,.admin-stats{grid-template-columns:repeat(2,1fr)}
  .stat-val{font-size:18px}
  .btn-call,.btn-phone{font-size:11px;padding:10px 6px}
}
