:root{
  --bg:#09090B;--bg2:#18181B;--bg3:#27272A;
  --surf:#18181B;--surf2:#27272A;
  --b:rgba(255,255,255,.08);--b2:rgba(255,255,255,.15);--b3:rgba(255,255,255,.25);
  --tx:#FAFAFA;--tx2:#A1A1AA;--tx3:#71717A;
  --green:#10B981;--amber:#F59E0B;--red:#EF4444;--blue:#3B82F6;--purple:#8B5CF6;
  --r:16px;--rs:10px;
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --glow: 0 0 12px rgba(16, 185, 129, 0.25);
}
[data-theme="light"] {
  --bg:#FAFAFA;--bg2:#FFFFFF;--bg3:#F4F4F5;
  --surf:#FFFFFF;--surf2:#F4F4F5;
  --b:rgba(0,0,0,.08);--b2:rgba(0,0,0,.15);--b3:rgba(0,0,0,.25);
  --tx:#09090B;--tx2:#52525B;--tx3:#A1A1AA;
  /* Adjusting input placeholders and inputs stringency */
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--tx);height:100vh;overflow:hidden;transition:background-color 0.3s, color 0.3s;}
.theme-toggle-btn{position:fixed;top:16px;right:16px;z-index:9999;background:var(--bg2);border:1px solid var(--b2);border-radius:50%;width:42px;height:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md);transition:all .2s cubic-bezier(0.4,0,0.2,1);color:var(--tx);}
.theme-toggle-btn:hover{transform:scale(1.05);box-shadow:var(--shadow-lg);}
.theme-toggle-btn:active{transform:scale(0.95);}

/* ── SHARED UTILS ── */
.hidden{display:none!important;}
.btn{padding:8px 16px;border-radius:var(--rs);font-family:inherit;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(0.4, 0, 0.2, 1);border:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;box-shadow:var(--shadow-sm);}
.btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-md);}
.btn:active{transform:scale(0.97);}
.btn-p{background:var(--green);color:#09090B;}
.btn-p:hover{background:#059669;box-shadow:var(--glow);}
.btn-o{background:rgba(255,255,255,0.03);border:1px solid var(--b2);color:var(--tx);}
.btn-o:hover{background:var(--surf);border-color:var(--b3);}
.btn-warn{background:rgba(245,158,11,.15);border:1px solid rgba(245,158,11,.3);color:#FCD34D;}
.btn-warn:hover{background:rgba(245,158,11,.25);}
.btn-danger{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.3);color:#FCA5A5;}
.btn-danger:hover{background:rgba(239,68,68,.25);}
.btn-sm{padding:6px 12px;font-size:11px;}
.tag{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:600;display:inline-flex;align-items:center;gap:3px;}
.tg{background:rgba(37,211,102,.12);color:var(--green);}
.ta{background:rgba(245,158,11,.12);color:#FCD34D;}
.tb{background:rgba(59,130,246,.12);color:#93C5FD;}
.tp{background:rgba(139,92,246,.12);color:#A78BFA;}
.tr{background:rgba(239,68,68,.12);color:#FCA5A5;}
.form-group{margin-bottom:12px;}
.lbl{font-size:12px;color:var(--tx2);margin-bottom:5px;display:block;font-weight:500;}
.inp,.sel,.txa{width:100%;background:rgba(255,255,255,0.03);border:1px solid var(--b2);border-radius:var(--rs);padding:10px 14px;color:var(--tx);font-family:inherit;font-size:13px;outline:none;transition:all .2s;resize:vertical;box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);}
.inp:focus,.sel:focus,.txa:focus{border-color:var(--green);background:rgba(255,255,255,0.05);box-shadow:0 0 0 3px rgba(16,185,129,0.15);}
.inp::placeholder,.txa::placeholder{color:var(--tx3);}
.sel{cursor:pointer;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.scr{overflow-y:auto;flex:1;padding:20px;}
.scr::-webkit-scrollbar{width:4px;}
.scr::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}
.card{background:var(--surf);border:1px solid var(--b);border-radius:var(--r);padding:16px;margin-bottom:12px;}

/* ── MODALS ── */
.overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(0.4, 0, 0.2, 1);}
.overlay.open{opacity:1;pointer-events:all;}
.modal{background:var(--bg2);border:1px solid var(--b2);border-radius:var(--r);padding:28px;width:480px;max-width:95vw;transform:scale(0.95) translateY(10px);opacity:0;transition:all .3s cubic-bezier(0.4, 0, 0.2, 1);max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);}
.overlay.open .modal{transform:scale(1) translateY(0);opacity:1;}
.modal h3{font-size:18px;font-weight:600;margin-bottom:20px;letter-spacing:-0.3px;}
.modal-actions{display:flex;gap:10px;margin-top:24px;justify-content:flex-end;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.pulse{animation:pulse 1.8s infinite;}

/* ═══════════════════════════════════════
   SCREEN: LOGIN
═══════════════════════════════════════ */
#screen-login{
  display:flex;align-items:center;justify-content:center;
  height:100vh;background:var(--bg);
}
.login-box{
  background:var(--bg2);border:1px solid var(--b2);
  border-radius:20px;padding:36px;width:380px;
}
.login-logo{
  width:46px;height:46px;background:var(--green);border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:22px;
  margin:0 auto 8px;
}
.login-box h1{font-size:20px;font-weight:600;text-align:center;margin-bottom:4px;}
.login-box p{font-size:13px;color:var(--tx2);text-align:center;margin-bottom:24px;}
.login-role{
  background:var(--bg3);border:1.5px solid var(--b2);border-radius:10px;
  padding:12px 14px;cursor:pointer;transition:all .15s;margin-bottom:10px;
  display:flex;align-items:center;gap:12px;
}
.login-role:hover{border-color:rgba(37,211,102,.3);background:rgba(37,211,102,.04);}
.login-role.selected{border-color:var(--green);background:rgba(37,211,102,.07);}
.role-icon{font-size:22px;width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;}
.role-info h4{font-size:13px;font-weight:600;}
.role-info p{font-size:11px;color:var(--tx2);}
.divider{display:flex;align-items:center;gap:10px;margin:16px 0;font-size:11px;color:var(--tx3);}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--b2);}

/* ═══════════════════════════════════════
   SCREEN: AGENCY ADMIN
═══════════════════════════════════════ */
#screen-agency{display:none;height:100vh;flex-direction:column;}
.agency-header{
  background:var(--bg2);border-bottom:1px solid var(--b);
  display:flex;align-items:center;gap:12px;padding:0 20px;height:56px;flex-shrink:0;
}
.agency-header h1{font-size:15px;font-weight:600;}
.ah-right{margin-left:auto;display:flex;gap:8px;align-items:center;}
.back-btn{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--tx2);cursor:pointer;padding:6px 10px;border-radius:var(--rs);border:1px solid var(--b2);transition:all .15s;}
.back-btn:hover{background:var(--surf);color:var(--tx);}

/* Agency tabs */
.agency-tabs{display:flex;border-bottom:1px solid var(--b);padding:0 20px;background:var(--bg2);flex-shrink:0;}
.atab{padding:12px 16px;font-size:13px;font-weight:500;cursor:pointer;color:var(--tx3);border-bottom:2px solid transparent;transition:all .15s;}
.atab:hover{color:var(--tx2);}
.atab.active{color:var(--green);border-bottom-color:var(--green);}

/* Company grid */
.company-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:14px;}
.cc{
  background:var(--surf);border:1px solid var(--b);border-radius:var(--r);
  padding:18px;cursor:pointer;transition:all .15s;
}
.cc:hover{border-color:var(--b2);background:var(--surf2);}
.cc-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.cc-avatar{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.cc-name{font-size:14px;font-weight:600;}
.cc-sub{font-size:12px;color:var(--tx2);}
.cc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:12px;border-top:1px solid var(--b);}
.cc-stat label{font-size:10px;color:var(--tx3);display:block;text-transform:uppercase;letter-spacing:.4px;}
.cc-stat span{font-size:17px;font-weight:600;font-family:'DM Mono',monospace;}
.cc-actions{display:flex;gap:6px;margin-top:12px;}

/* Access sharing panel */
.access-list-item{
  display:flex;align-items:center;gap:12px;padding:11px 14px;
  background:var(--bg3);border-radius:var(--rs);border:1px solid var(--b);margin-bottom:7px;
}
.ali-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff;flex-shrink:0;}
.ali-info{flex:1;}
.ali-name{font-size:13px;font-weight:500;}
.ali-email{font-size:11px;color:var(--tx2);}
.link-box{
  display:flex;align-items:center;gap:8px;
  background:var(--bg3);border:1px solid var(--b2);border-radius:var(--rs);
  padding:10px 12px;margin-top:12px;
}
.link-url{font-size:11px;color:var(--tx2);font-family:'DM Mono',monospace;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}

/* ═══════════════════════════════════════
   SCREEN: COMPANY WORKSPACE
   (like app #1 — full WhatsApp CRM)
═══════════════════════════════════════ */
#screen-company{display:none;height:100vh;}
.ws{display:flex;flex-direction:row;height:100vh;overflow:hidden;}

/* Icon rail */
.rail{
  background:var(--bg2);border-right:1px solid var(--b);
  display:flex;flex-direction:column;align-items:center;padding:16px 0;gap:4px;
  width:62px;flex-shrink:0;
}
.rail-logo{
  width:38px;height:38px;background:var(--green);border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:17px;
  margin-bottom:14px;cursor:pointer;
}
.ri{
  width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .15s;color:var(--tx3);font-size:18px;position:relative;
}
.ri:hover{background:var(--surf);color:var(--tx2);}
.ri.active{background:rgba(37,211,102,.13);color:var(--green);}
.ri .badge{
  position:absolute;top:5px;right:5px;background:var(--red);color:#fff;
  font-size:9px;font-weight:700;width:15px;height:15px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.rail-bot{margin-top:auto;display:flex;flex-direction:column;gap:6px;align-items:center;}
.rav{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff;cursor:pointer;}

/* Sidebar panel */
.sidebar{
  background:var(--bg2);border-right:1px solid var(--b);
  display:flex;flex-direction:column;overflow:hidden;
  width:260px;flex-shrink:0;transition:width .15s;
}
.sidebar.sb-hidden{width:0;border-right:none;}
.sb-header{padding:16px 14px 12px;border-bottom:1px solid var(--b);flex-shrink:0;}
.sb-header h2{font-size:15px;font-weight:600;margin-bottom:10px;}
.search{
  background:var(--bg3);border:1px solid var(--b);border-radius:var(--rs);
  display:flex;align-items:center;gap:7px;padding:7px 11px;
}
.search input{background:none;border:none;outline:none;color:var(--tx);font-family:inherit;font-size:12px;width:100%;}
.search input::placeholder{color:var(--tx3);}
.filter-row{display:flex;gap:5px;padding:9px 14px;border-bottom:1px solid var(--b);flex-shrink:0;overflow-x:auto;}
.filter-row::-webkit-scrollbar{display:none;}
.ftab{font-size:11px;font-weight:500;padding:3px 9px;border-radius:12px;cursor:pointer;border:1px solid var(--b);color:var(--tx2);white-space:nowrap;transition:all .15s;flex-shrink:0;}
.ftab.active{background:rgba(37,211,102,.13);border-color:rgba(37,211,102,.3);color:var(--green);}
.conv-list{flex:1;overflow-y:auto;}
.conv-list::-webkit-scrollbar{width:3px;}
.conv-list::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}
.ci{
  padding:11px 14px;cursor:pointer;
  border-bottom:1px solid var(--b);transition:background .12s;
}
.ci:hover{background:var(--bg3);}
.ci.active{background:rgba(37,211,102,.07);border-left:2px solid var(--green);}
.ci-row{display:flex;align-items:center;gap:9px;margin-bottom:4px;}
.ci-av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;flex-shrink:0;}
.ci-meta{flex:1;min-width:0;}
.ci-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ci-prev{font-size:11px;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ci-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;}
.ci-time{font-size:10px;color:var(--tx3);}
.ci-unread{background:var(--green);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;}

/* MAIN area */
.main-area{display:flex;flex-direction:column;overflow:hidden;min-height:0;flex:1;}

/* Stats bar */
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--b);flex-shrink:0;}
.stat-cell{padding:12px 16px;border-right:1px solid var(--b);}
.stat-cell:last-child{border-right:none;}
.stat-lbl{font-size:10px;color:var(--tx3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px;}
.stat-val{font-size:20px;font-weight:600;font-family:'DM Mono',monospace;}
.stat-sub{font-size:10px;color:var(--tx3);margin-top:1px;}

/* Chat header */
.chat-header{
  background:var(--bg2);border-bottom:1px solid var(--b);
  display:flex;align-items:center;gap:10px;padding:0 16px;height:54px;flex-shrink:0;
}
.ch-av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;}
.ch-info h3{font-size:13px;font-weight:600;}
.ch-info p{font-size:11px;color:var(--tx2);}
.ch-right{margin-left:auto;display:flex;gap:6px;align-items:center;}
.pill{padding:3px 9px;border-radius:14px;font-size:11px;font-weight:600;display:flex;align-items:center;gap:4px;}
.pill-ia{background:rgba(37,211,102,.1);color:var(--green);border:1px solid rgba(37,211,102,.2);}
.pill-hum{background:rgba(249,115,22,.1);color:#FDBA74;border:1px solid rgba(249,115,22,.2);}

/* Chat body */
.chat-body{overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:9px;flex:1;}
.chat-body::-webkit-scrollbar{width:3px;}
.chat-body::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}
.msg{max-width:68%;display:flex;flex-direction:column;gap:2px;}
.msg-in{align-self:flex-start;}
.msg-out{align-self:flex-end;}
.bubble{padding:9px 13px;border-radius:12px;font-size:13px;line-height:1.5;}
.msg-in .bubble{background:var(--surf);border-bottom-left-radius:3px;}
.msg-out .bubble{background:rgba(37,211,102,.13);border:1px solid rgba(37,211,102,.18);border-bottom-right-radius:3px;}
.msg-meta{font-size:10px;color:var(--tx3);display:flex;align-items:center;gap:4px;}
.msg-in .msg-meta{padding-left:3px;}
.msg-out .msg-meta{padding-right:3px;justify-content:flex-end;}
.ai-lbl{font-size:10px;color:var(--green);font-weight:600;}
.date-sep{text-align:center;color:var(--tx3);font-size:11px;display:flex;align-items:center;gap:8px;margin:4px 0;}
.date-sep::before,.date-sep::after{content:'';flex:1;height:1px;background:var(--b);}

/* Appt card in chat */
.appt-bubble{background:var(--bg3);border:1px solid rgba(139,92,246,.25);border-radius:10px;padding:12px;margin-top:4px;}
.appt-bh{display:flex;align-items:center;gap:6px;color:#A78BFA;font-size:11px;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.4px;}
.appt-row{display:flex;justify-content:space-between;font-size:11px;padding:4px 0;border-bottom:1px solid var(--b);color:var(--tx2);}
.appt-row:last-child{border-bottom:none;}
.appt-row span:last-child{color:var(--tx);font-weight:500;}

/* Chat input */
.chat-input-wrap{background:var(--bg2);border-top:1px solid var(--b);padding:12px 16px;flex-shrink:0;}
.ai-suggest{
  background:rgba(37,211,102,.05);border:1px solid rgba(37,211,102,.15);
  border-radius:var(--rs);padding:9px 12px;margin-bottom:9px;
  font-size:12px;display:flex;gap:8px;align-items:flex-start;
}
.ai-slbl{color:var(--green);font-weight:600;font-size:11px;flex-shrink:0;}
.ai-sbtns{display:flex;gap:5px;margin-top:5px;}
.sg-btn{background:transparent;border:1px solid var(--b2);color:var(--tx2);font-size:11px;padding:3px 9px;border-radius:6px;cursor:pointer;font-family:inherit;transition:all .12s;}
.sg-btn:hover{background:var(--surf);color:var(--tx);}
.sg-accept{background:rgba(37,211,102,.1);border-color:rgba(37,211,102,.25);color:var(--green);}
.esc-banner{
  background:rgba(249,115,22,.07);border:1px solid rgba(249,115,22,.2);
  border-radius:var(--rs);padding:8px 12px;margin-bottom:9px;
  font-size:12px;color:#FDBA74;display:flex;align-items:center;gap:8px;
}
.input-row{display:flex;gap:8px;align-items:center;}
.msg-inp{
  flex:1;background:var(--bg3);border:1px solid var(--b);border-radius:var(--rs);
  padding:9px 13px;color:var(--tx);font-family:inherit;font-size:13px;outline:none;
  transition:border-color .15s;
}
.msg-inp:focus{border-color:rgba(37,211,102,.3);}
.msg-inp::placeholder{color:var(--tx3);}
.send-btn{
  width:38px;height:38px;border-radius:9px;background:var(--green);border:none;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:all .15s;font-size:15px;flex-shrink:0;
}
.send-btn:hover{background:#1fb855;transform:scale(1.05);}

/* APPOINTMENTS panel */
.appt-list-item{
  display:flex;align-items:center;gap:12px;padding:12px 14px;
  background:var(--surf);border:1px solid var(--b);border-radius:var(--r);
  margin-bottom:7px;cursor:pointer;transition:all .15s;
}
.appt-list-item:hover{border-color:var(--b2);background:var(--surf2);}
.appt-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;}
.dot-ok{background:var(--green);}
.dot-pend{background:var(--amber);}
.dot-cancel{background:var(--red);}
.appt-info{flex:1;}
.appt-name{font-size:13px;font-weight:500;margin-bottom:2px;}
.appt-detail{font-size:11px;color:var(--tx2);}
.appt-time{font-size:12px;color:var(--tx2);text-align:right;font-family:'DM Mono',monospace;}

/* FAQ */
.faq-item{background:var(--surf);border:1px solid var(--b);border-radius:var(--rs);margin-bottom:7px;overflow:hidden;cursor:pointer;transition:border-color .15s;}
.faq-item:hover{border-color:var(--b2);}
.faq-q{padding:11px 14px;font-size:13px;font-weight:500;display:flex;justify-content:space-between;align-items:center;}
.faq-a{padding:0 14px 11px;font-size:12px;color:var(--tx2);line-height:1.6;border-top:1px solid var(--b);display:none;}
.faq-a.open{display:block;}

/* SETTINGS panel */
.set-section{background:var(--surf);border:1px solid var(--b);border-radius:var(--r);padding:16px;margin-bottom:12px;}
.set-title{font-size:12px;font-weight:600;color:var(--tx2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;}

/* TOP bar for non-chat panels */
.panel-topbar{
  background:var(--bg2);border-bottom:1px solid var(--b);
  display:flex;align-items:center;gap:10px;padding:0 16px;height:54px;flex-shrink:0;
}
.panel-topbar h3{font-size:14px;font-weight:600;}
.pt-right{margin-left:auto;display:flex;gap:8px;}

/* Workspace panels */
.ws-panel{display:none;flex-direction:column;flex:1;min-height:0;overflow:hidden;}
.ws-panel.active{display:flex;}

/* Access granted banner for company users */
.company-banner{
  display:flex;align-items:center;gap:10px;padding:8px 16px;
  background:rgba(37,211,102,.07);border-bottom:1px solid rgba(37,211,102,.15);
  font-size:12px;color:var(--tx2);flex-shrink:0;
}
.company-banner strong{color:var(--tx);font-weight:600;}

/* ── CALENDAR ── */
.citas-layout{display:grid;grid-template-columns:320px 1fr;height:100%;overflow:hidden;}
.cal-col{display:flex;flex-direction:column;border-right:1px solid var(--b);overflow:hidden;background:var(--bg2);}
.cal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;flex-shrink:0;}
.cal-month{font-size:14px;font-weight:600;}
.cal-nav{display:flex;gap:4px;}
.cal-nav-btn{width:28px;height:28px;border-radius:7px;border:1px solid var(--b2);background:transparent;color:var(--tx2);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .12s;}
.cal-nav-btn:hover{background:var(--surf);color:var(--tx);}
.cal-grid{padding:0 12px 12px;flex-shrink:0;}
.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px;}
.cal-dow span{text-align:center;font-size:10px;font-weight:600;color:var(--tx3);padding:4px 0;text-transform:uppercase;letter-spacing:.4px;}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.cal-day{
  aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  border-radius:8px;cursor:pointer;position:relative;font-size:12px;font-weight:500;
  color:var(--tx2);transition:all .12s;
}
.cal-day:hover{background:var(--surf);}
.cal-day.today{background:rgba(37,211,102,.12);color:var(--green);font-weight:700;}
.cal-day.selected{background:var(--green);color:#0F1117;font-weight:700;}
.cal-day.has-appts::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--amber);}
.cal-day.selected.has-appts::after{background:rgba(15,17,23,.5);}
.cal-day.other-month{color:var(--tx3);opacity:.4;}
.cal-day.disabled{pointer-events:none;opacity:.25;}
/* Google Calendar connect */
.gcal-connect{margin:0 12px 12px;padding:10px 12px;border-radius:var(--rs);border:1px solid var(--b2);display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .15s;background:var(--bg3);}
.gcal-connect:hover{border-color:rgba(66,133,244,.4);background:rgba(66,133,244,.05);}
.gcal-connect.connected{border-color:rgba(37,211,102,.3);background:rgba(37,211,102,.05);}
.gcal-icon{width:28px;height:28px;border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.gcal-info{flex:1;min-width:0;}
.gcal-title{font-size:12px;font-weight:600;}
.gcal-sub{font-size:10px;color:var(--tx2);}
/* Day agenda */
.day-agenda{flex:1;overflow-y:auto;padding:0 12px 12px;}
.day-agenda::-webkit-scrollbar{width:3px;}
.day-agenda::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}
.day-label{font-size:11px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:.5px;padding:10px 0 6px;}
.agenda-empty{text-align:center;color:var(--tx3);font-size:12px;padding:20px 0;}
.agenda-item{
  background:var(--surf);border:1px solid var(--b);border-radius:var(--r);
  padding:11px 13px;margin-bottom:6px;cursor:pointer;transition:all .15s;
  border-left:3px solid var(--green);
}
.agenda-item.online{border-left-color:var(--blue);}
.agenda-item.pendiente{border-left-color:var(--amber);}
.agenda-item.cancelada{border-left-color:var(--red);opacity:.6;}
.agenda-item:hover{background:var(--surf2);}
.ai-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;}
.ai-name{font-size:13px;font-weight:600;}
.ai-time{font-size:11px;font-family:'DM Mono',monospace;color:var(--tx2);}
.ai-service{font-size:11px;color:var(--tx2);margin-bottom:6px;}
.ai-badges{display:flex;gap:5px;align-items:center;flex-wrap:wrap;}
.ai-actions{display:flex;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid var(--b);}
.ai-act-btn{
  flex:1;padding:5px 8px;border-radius:6px;border:1px solid var(--b2);
  background:transparent;color:var(--tx2);font-size:11px;cursor:pointer;
  font-family:inherit;transition:all .12s;display:flex;align-items:center;justify-content:center;gap:4px;
}
.ai-act-btn:hover{background:var(--surf2);color:var(--tx);}
.ai-act-btn.danger:hover{background:rgba(239,68,68,.1);color:#FCA5A5;border-color:rgba(239,68,68,.2);}
.ai-act-btn.primary{background:rgba(37,211,102,.1);border-color:rgba(37,211,102,.2);color:var(--green);}
.ai-act-btn.blue{background:rgba(59,130,246,.1);border-color:rgba(59,130,246,.2);color:#93C5FD;}
.meet-link{
  display:flex;align-items:center;gap:6px;padding:6px 9px;
  background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.18);
  border-radius:6px;font-size:11px;color:#93C5FD;cursor:pointer;
  transition:all .12s;margin-top:6px;
}
.meet-link:hover{background:rgba(59,130,246,.13);}
.meet-link-url{flex:1;font-family:'DM Mono',monospace;font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
/* Right col */
.appts-right{display:flex;flex-direction:column;overflow:hidden;}
.appts-right-header{padding:16px 18px 10px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.appts-right-header h3{font-size:14px;font-weight:600;}
.appts-filters{display:flex;gap:5px;padding:10px 16px;border-bottom:1px solid var(--b);flex-shrink:0;overflow-x:auto;}
.appts-filters::-webkit-scrollbar{display:none;}
.appts-list{flex:1;overflow-y:auto;padding:14px 16px;}
.appts-list::-webkit-scrollbar{width:3px;}
.appts-list::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px;}
/* Full appt card */
.appt-card{
  background:var(--surf);border:1px solid var(--b);border-radius:var(--r);
  padding:14px 16px;margin-bottom:8px;transition:all .15s;
  border-left:3px solid var(--green);
}
.appt-card.online{border-left-color:var(--blue);}
.appt-card.pendiente{border-left-color:var(--amber);}
.appt-card.cancelada{border-left-color:var(--red);opacity:.55;}
.appt-card:hover{border-color:var(--b2);background:var(--surf2);}
.ac-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;}
.ac-name{font-size:13px;font-weight:600;margin-bottom:2px;}
.ac-sub{font-size:11px;color:var(--tx2);}
.ac-date{text-align:right;font-size:12px;font-family:'DM Mono',monospace;color:var(--tx2);}
.ac-date span{display:block;font-size:11px;color:var(--tx3);}
.ac-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:8px;}
.ac-actions{display:flex;gap:5px;flex-wrap:wrap;}
.ico-btn{
  padding:5px 10px;border-radius:6px;border:1px solid var(--b2);
  background:transparent;color:var(--tx2);font-size:11px;cursor:pointer;
  font-family:inherit;transition:all .12s;display:inline-flex;align-items:center;gap:4px;
}
.ico-btn:hover{background:var(--surf2);color:var(--tx);}
.ico-btn.green:hover{background:rgba(37,211,102,.1);color:var(--green);border-color:rgba(37,211,102,.25);}
.ico-btn.blue:hover{background:rgba(59,130,246,.1);color:#93C5FD;border-color:rgba(59,130,246,.25);}
.ico-btn.red:hover{background:rgba(239,68,68,.1);color:#FCA5A5;border-color:rgba(239,68,68,.2);}
/* Modal type selector */
.type-selector{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px;}
.type-opt{
  padding:12px;border-radius:var(--r);border:1.5px solid var(--b2);
  cursor:pointer;transition:all .15s;text-align:center;
}
.type-opt:hover{border-color:var(--b3);}
.type-opt.selected{border-color:var(--green);background:rgba(37,211,102,.07);}
.type-opt.selected.online-opt{border-color:var(--blue);background:rgba(59,130,246,.07);}
.type-icon{font-size:22px;margin-bottom:4px;}
.type-label{font-size:12px;font-weight:600;}
.type-sub{font-size:10px;color:var(--tx2);margin-top:2px;}
/* Toggle switch */
.toggle{position:relative;display:inline-block;width:34px;height:18px;}
.toggle input{opacity:0;width:0;height:0;}
.toggle-slider{position:absolute;inset:0;background:var(--surf2);border-radius:9px;cursor:pointer;transition:.2s;}
.toggle input:checked~.toggle-slider{background:var(--green);}
.toggle-slider:before{content:'';position:absolute;height:14px;width:14px;left:2px;top:2px;background:white;border-radius:50%;transition:.2s;}
.toggle input:checked~.toggle-slider:before{transform:translateX(16px);}
/* Meet preview */
.meet-preview{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  background:rgba(59,130,246,.07);border:1px solid rgba(59,130,246,.2);
  border-radius:var(--rs);margin-top:4px;
}
.meet-preview-icon{font-size:18px;}
.meet-preview-info{flex:1;}
.meet-preview-label{font-size:11px;font-weight:600;color:#93C5FD;}
.meet-preview-url{font-size:10px;color:var(--tx2);font-family:'DM Mono',monospace;}

/* ── CONTACTS ── */
.ct-item{
  display:flex;align-items:center;gap:10px;padding:11px 14px;
  border-bottom:1px solid var(--b);cursor:pointer;transition:background .12s;
}
.ct-item:hover{background:var(--bg3);}
.ct-item.active{background:rgba(37,211,102,.07);border-left:2px solid var(--green);}
.ct-av{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;color:#fff;
}
.ct-meta{flex:1;min-width:0;}
.ct-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ct-phone{font-size:11px;color:var(--tx2);font-family:'DM Mono',monospace;}
.ct-badges{display:flex;gap:4px;margin-top:3px;flex-wrap:wrap;}
/* Detail panel */
.ct-detail-header{
  background:var(--bg2);border-bottom:1px solid var(--b);
  padding:20px;display:flex;align-items:center;gap:14px;
}
.ct-detail-av{
  width:54px;height:54px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:#fff;flex-shrink:0;
}
.ct-detail-name{font-size:16px;font-weight:600;}
.ct-detail-phone{font-size:12px;color:var(--tx2);font-family:'DM Mono',monospace;}
.ct-detail-body{padding:16px;}
.ct-info-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--b);font-size:12px;}
.ct-info-row:last-child{border-bottom:none;}
.ct-info-label{color:var(--tx2);}
.ct-info-val{color:var(--tx);font-weight:500;text-align:right;}
.ct-actions-row{display:flex;gap:7px;flex-wrap:wrap;padding:12px 0;}
.ct-hist-item{background:var(--bg3);border-radius:var(--rs);padding:10px 12px;margin-bottom:7px;border:1px solid var(--b);}
.ct-hist-q{font-size:12px;color:var(--tx2);margin-bottom:3px;}
.ct-hist-a{font-size:12px;}
.ct-hist-date{font-size:10px;color:var(--tx3);margin-top:4px;}
/* Import preview row states */
.prev-ok td{color:var(--tx);}
.prev-dup td{color:var(--amber);}
.prev-err td{color:#FCA5A5;}

/* ── RESPONSIVE COMPATIBILITY ── */
@media (max-width: 768px) {
  /* Layout main */
  .ws { flex-direction: column-reverse; }
  .rail { flex-direction: row; width: 100%; height: 60px; padding: 0 12px; justify-content: space-between; align-items:center; border-right: none; border-top: 1px solid var(--b); z-index: 100;flex-direction:row;padding-top:0;}
  .ri { width: 44px; height: 44px; font-size:22px;}
  .rail-logo, .rail-bot { display: none; }
  .modal{max-height:80vh;}
  .citas-layout{flex-direction:column;overflow-y:auto;}
  .appts-right{border-left:none;border-top:1px solid var(--b);overflow:visible;}
  .cal-col{border-right:none;}
  .stats-bar{grid-template-columns:1fr 1fr;border-bottom:none;}
  .stat-cell{border-bottom:1px solid var(--b);}
  
  /* Sidebar overlap logic */
  .sidebar { width: 100% !important; position: absolute; z-index: 50; height: calc(100% - 60px); top: 0; left: 0; background: var(--bg2); transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); border-right: none; }
  .sidebar.sb-hidden { width: 100%; transform: translateX(-100%); }
  .sidebar.mobile-hide { transform: translateX(-100%); }
  
  .main-area { flex: 1; min-width: 100%; height: calc(100% - 60px); position: relative; z-index: 10; }
  .login-box { width: 90%; padding: 28px 20px; }
  
  /* Agency Header */
  .agency-header{flex-direction:column;height:auto;padding:16px;align-items:flex-start;gap:12px;}
  .ah-right{width:100%;justify-content:space-between;margin-top:8px;}
  #agencyStatsGrid{grid-template-columns:1fr;}
  #wsStatsGrid{grid-template-columns:1fr;}
  
  .ch-right{display:none;} /* hide heavy pills on very small mobile chat */
  .mobile-back{display:flex !important;}
  .chat-header{padding:0 10px;}
}
@media (min-width: 769px) {
  .mobile-back { display: none !important; }
}

/* Toast Notifications */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none;}
.toast{background:var(--bg2);border:1px solid var(--b2);border-left:4px solid var(--green);border-radius:8px;padding:12px 16px;color:var(--tx);font-size:13px;box-shadow:var(--shadow-lg);display:flex;align-items:flex-start;gap:10px;min-width:280px;max-width:350px;animation:toast-in 0.3s cubic-bezier(0.4, 0, 0.2, 1) forwards;pointer-events:all;transition:all 0.2s;}
.toast.hide{animation:toast-out 0.3s cubic-bezier(0.4, 0, 0.2, 1) forwards;}
.toast-icon{font-size:18px;line-height:1;}
.toast-content{flex:1;display:flex;flex-direction:column;justify-content:center;}
.toast-title{font-weight:600;margin-bottom:2px;font-size:13px;}
.toast-msg{font-size:12px;color:var(--tx2);line-height:1.4;}
.toast-close{background:none;border:none;color:var(--tx3);cursor:pointer;font-size:16px;padding:0;transition:color 0.2s;line-height:1;width:16px;height:16px;display:flex;align-items:center;justify-content:center;}
.toast-close:hover{color:var(--tx);}
.toast.error{border-left-color:var(--red);}
.toast.warning{border-left-color:var(--amber);}
.toast.info{border-left-color:var(--blue);}
@keyframes toast-in{from{transform:translateX(100%);opacity:0;}to{transform:translateX(0);opacity:1;}}
@keyframes toast-out{from{transform:translateX(0);opacity:1;}to{transform:translateX(100%);opacity:0;}}
