:root{--bg: #0b0f16;--panel: #161d2b;--panel-2: #1f2839;--text: #eef1f7;--muted: #94a0b4;--accent: #e4231f;--accent-2: #b81419;--danger: #f04455;--green: #2ecc71;--radius: 16px;--radius-sm: 10px;--border: rgba(255, 255, 255, .07);--shadow: 0 8px 24px rgba(0, 0, 0, .35);--shadow-lg: 0 24px 60px rgba(0, 0, 0, .5)}*{box-sizing:border-box}body{margin:0;font-family:Noto Sans Thai,Inter,system-ui,-apple-system,sans-serif;background:radial-gradient(1100px 620px at 50% -12%,#1a2842,#0b0f16 58%) no-repeat fixed,#0b0f16;color:var(--text);-webkit-font-smoothing:antialiased;letter-spacing:.1px}h1,h2,h3{letter-spacing:-.2px}button{cursor:pointer;border:none;border-radius:var(--radius-sm);padding:11px 16px;background:var(--panel-2);color:var(--text);font-family:inherit;font-size:14px;font-weight:600;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease,background .12s ease}button:hover{filter:brightness(1.12);transform:translateY(-1px)}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:default;transform:none}button.primary,button .primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 6px 18px #e4231f52}button.primary:hover{box-shadow:0 10px 26px #e4231f73}button.danger{background:linear-gradient(135deg,#ff5a68,var(--danger));box-shadow:0 6px 18px #f044554d}button.active{background:linear-gradient(135deg,var(--accent),var(--accent-2))}button.ghost{background:transparent;color:var(--muted)}button.small{padding:6px 11px;font-size:12px;border-radius:8px}button.big{padding:15px;font-size:16px;width:100%;border-radius:12px}input,select,textarea{padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff0a;color:var(--text);font-family:inherit;font-size:15px;outline:none;width:100%;transition:border-color .12s,box-shadow .12s,background .12s}input::placeholder,textarea::placeholder{color:#6b7688}input:focus,select:focus,textarea:focus{border-color:var(--accent);background:#ffffff0f;box-shadow:0 0 0 3px #e4231f38}select option{background:var(--panel);color:var(--text)}.muted{color:var(--muted)}.small-link{font-size:13px;text-decoration:none;transition:color .12s}.small-link:hover{color:var(--accent)}.error{color:#ff9aa2;font-size:14px;background:#f044551f;border:1px solid rgba(240,68,85,.3);border-radius:var(--radius-sm);padding:9px 12px}.error.banner{padding:8px 16px}.center-screen{min-height:100vh;display:grid;place-items:center;padding:22px}.card{background:linear-gradient(180deg,#222c40b8,#161d2bb8);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--border);padding:30px;border-radius:20px;width:380px;max-width:94vw;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-lg)}.card.wide{width:460px}.card h1,.card h2{margin:0}.center-text{text-align:center}.row{display:flex;gap:10px;align-items:center}.row.between{justify-content:space-between}.primary.big{background:linear-gradient(135deg,var(--accent),var(--accent-2))}.room-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.room-list li{display:flex;justify-content:space-between;align-items:center;background:var(--panel-2);padding:10px 12px;border-radius:8px}.room-list li span{display:flex;align-items:center;gap:8px}.badge{background:var(--bg);padding:3px 8px;border-radius:20px;font-size:12px}.room{display:flex;flex-direction:column;height:100vh}.room-header{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;background:var(--panel);border-bottom:1px solid #232d3f}.status.on{color:var(--green)}.status.off{color:var(--muted)}.room-body{flex:1;display:flex;overflow:hidden}.grid{flex:1;display:grid;gap:10px;padding:14px;align-content:center;justify-content:center}.tile{position:relative;background:#000;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;min-width:220px}.tile video{width:100%;height:100%;object-fit:cover}.tile .avatar{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-size:48px;font-weight:700;background:var(--panel-2);color:var(--accent)}.tile-label{position:absolute;bottom:8px;left:8px;background:#0009;padding:4px 10px;border-radius:20px;font-size:13px}.chat{width:320px;border-left:1px solid #232d3f;background:var(--panel);display:flex;flex-direction:column}.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:8px}.msg{max-width:85%}.msg.self{align-self:flex-end;text-align:right}.msg-name{font-size:11px;color:var(--muted);margin-bottom:2px}.msg-bubble{display:inline-block;background:var(--panel-2);padding:8px 12px;border-radius:12px;font-size:14px;word-break:break-word}.msg.self .msg-bubble{background:var(--accent)}.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid #232d3f}.controls{display:flex;gap:10px;justify-content:center;padding:14px;background:var(--panel);border-top:1px solid #232d3f}.center-text{text-align:center;align-items:center}.small-link{display:block;margin-top:8px;font-size:13px;text-decoration:none}.muted.small{font-size:12px}.row.center{justify-content:center}.ivr{display:flex;flex-direction:column;gap:10px}.ivr-btn{display:flex;align-items:center;gap:14px;padding:16px;text-align:left;background:var(--panel-2);border-radius:10px;font-size:16px}.ivr-key{width:38px;height:38px;display:grid;place-items:center;flex:none;background:var(--accent);border-radius:50%;font-weight:700;font-size:18px}.pulse{font-size:56px;animation:pulse 1.2s infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.6}}.agent,.dash{min-height:100vh;display:flex;flex-direction:column}.panel{background:var(--panel);margin:14px;padding:18px;border-radius:var(--radius)}.panel h3{margin-top:0}.callbar{background:#e5484d26;color:#ffb4b6;padding:10px 16px;text-align:center}.incoming{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:grid;place-items:center;z-index:50}.incoming .card{width:380px}.badge{background:var(--panel-2);padding:4px 12px;border-radius:20px;font-size:13px}.status-available{background:#2ecc7138;color:#74e8a3}.status-oncall,.status-ringing{background:#e4231f38;color:#8cb8ff}.status-break,.status-wrapup{background:#e5484d33;color:#ff9b9d}.list-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #232d3f}.stats{display:flex;gap:12px;flex-wrap:wrap;padding:14px}.stat{flex:1;min-width:120px;background:var(--panel);border-radius:var(--radius);padding:16px;text-align:center}.stat-value{font-size:28px;font-weight:700;color:var(--accent)}.stat-label{font-size:13px;color:var(--muted);margin-top:4px}.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:0}.table-wrap{overflow-x:auto}table.cdr{width:100%;border-collapse:collapse;font-size:14px}table.cdr th,table.cdr td{padding:8px 10px;text-align:left;border-bottom:1px solid #232d3f;white-space:nowrap}table.cdr th{color:var(--muted);font-weight:600}.phone-panel{max-width:460px}.dial-input{text-align:center;font-size:18px;letter-spacing:1px;margin:10px 0}.dialpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.dial-key{padding:16px;font-size:20px;background:var(--panel-2);border-radius:10px}.dial-key:hover{background:var(--accent)}.captions{position:relative;margin:0 auto 4px;max-width:760px;width:100%;display:flex;flex-direction:column;gap:6px;padding:0 12px;box-sizing:border-box}.caption-line{align-self:flex-start;max-width:100%;background:#000000b8;color:#fff;font-size:17px;line-height:1.4;padding:8px 14px;border-radius:10px}.caption-line.caption-mine{align-self:flex-end;background:#e4231fd1}.caption-who{font-weight:700;opacity:.85;margin-right:6px;font-size:13px}.ai-detail{background:var(--panel-2);border-radius:10px;padding:12px 14px;margin:4px 0}.ai-summary pre{white-space:pre-wrap;font-family:inherit;margin:6px 0 0;line-height:1.5}.ai-transcript{margin-top:10px}.ai-transcript summary{cursor:pointer;color:var(--muted)}.ai-transcript pre{white-space:pre-wrap;font-family:inherit;margin:6px 0 0;color:var(--muted);line-height:1.5}.tabs{display:flex;gap:6px;padding:10px 14px 0;flex-wrap:wrap}.tab{background:var(--panel-2);border-radius:8px 8px 0 0;padding:10px 16px;color:var(--muted);border:none;cursor:pointer}.tab.active{background:var(--panel);color:var(--text, #e6eaf0);font-weight:600}.fld{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--muted)}.nowrap{white-space:nowrap}table.cdr input,table.cdr select{width:100%;box-sizing:border-box}.admin-shell{display:flex;min-height:100vh}.admin-side{width:220px;background:var(--panel);display:flex;flex-direction:column;gap:14px;padding:16px 12px;border-right:1px solid #232d3f}.admin-brand{padding:4px 6px 8px}.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1}.side-link{text-align:left;background:transparent;border:none;color:var(--muted);padding:11px 14px;border-radius:8px;cursor:pointer;font-size:15px}.side-link:hover{background:var(--panel-2);color:#e6eaf0}.side-link.active{background:var(--accent);color:#fff;font-weight:600}.side-link.logout{color:#e5484d}.admin-side-foot{display:flex;flex-direction:column;gap:8px;border-top:1px solid #232d3f;padding-top:12px}.admin-main{flex:1;min-width:0;padding:8px 4px 0;overflow-x:hidden}.app-footer{text-align:center;color:var(--muted);font-size:12px;padding:14px}.app-footer b{color:var(--accent)}@media (max-width: 700px){.admin-shell{flex-direction:column}.admin-side{width:auto;border-right:none;border-bottom:1px solid #232d3f}.admin-nav{flex-direction:row;flex-wrap:wrap}.admin-side-foot{border-top:none;padding-top:0}}.login-card{max-width:380px}.login-brand{display:flex;justify-content:center;margin-bottom:6px}.login-title{text-align:center;margin:4px 0 2px}.login-sub{text-align:center;margin-top:0}.sso-btn{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:8px;padding:15px 18px;border-radius:12px;background:linear-gradient(135deg,#e4231f,#b81419);color:#fff;font-size:16px;font-weight:600;text-decoration:none;box-shadow:0 6px 18px #e4231f59;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.sso-btn:hover{transform:translateY(-1px);box-shadow:0 9px 26px #e4231f80;filter:brightness(1.05)}.sso-btn:active{transform:translateY(0)}.sso-btn b{font-weight:800;letter-spacing:.3px}.sso-ic{flex:0 0 auto}.login-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}.login-wrap .app-footer{padding:4px}.chat-card{max-width:440px;width:100%;display:flex;flex-direction:column;gap:10px}.chat-head{display:flex;align-items:center;gap:10px}.chat-log{display:flex;flex-direction:column;gap:8px;height:46vh;min-height:260px;overflow-y:auto;padding:6px 2px}.chat-msg{max-width:82%;padding:9px 13px;border-radius:14px;line-height:1.45;white-space:pre-wrap;word-break:break-word}.chat-msg.bot{align-self:flex-start;background:var(--panel-2);border-bottom-left-radius:4px}.chat-msg.me{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}.chat-input{display:flex;gap:8px}.chat-input input{flex:1}.ai-context{background:#e4231f1f;border:1px solid rgba(228,35,31,.35);border-radius:10px;padding:8px 12px;margin-top:8px;font-size:14px;text-align:left}.ai-context-bar{background:#e4231f1a;border-bottom:1px solid rgba(228,35,31,.25);padding:10px 14px;font-size:14px}.ai-context-bar details{margin-top:6px}.ai-context-bar summary{cursor:pointer;color:var(--accent)}.ai-context-log{margin-top:8px;display:flex;flex-direction:column;gap:5px;color:var(--muted);max-height:180px;overflow-y:auto}.ai-context-log b{color:#e6eaf0}.voice-status{text-align:center;font-size:14px;color:var(--muted);padding:4px}button.big{width:100%;padding:14px;border-radius:10px;font-size:15px}.points-grid{display:flex;flex-wrap:wrap;gap:14px;margin-top:10px}.point-card{background:var(--panel-2);border-radius:12px;padding:12px;width:200px;text-align:center;display:flex;flex-direction:column;gap:6px;align-items:center}.point-card img{background:#fff;border-radius:8px;padding:6px}.point-name{font-weight:600}.voice-card{max-width:400px;width:100%;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.voice-orb{position:relative;width:170px;height:170px;display:flex;align-items:center;justify-content:center;margin:6px 0;--oc: #e4231f}.voice-orb.listening{--oc: #2ecc71}.voice-orb.user{--oc: #27c07a}.voice-orb.thinking{--oc: #e6a23c}.voice-orb.speaking{--oc: #e4231f}.voice-orb.connecting{--oc: #8a94a6}.voice-orb.error{--oc: #e5484d}.orb-core{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;background:var(--oc);box-shadow:0 0 28px var(--oc);z-index:2;transition:background .2s}.orb-ring{position:absolute;width:96px;height:96px;border-radius:50%;border:2px solid var(--oc);opacity:0}.voice-orb.listening .orb-ring,.voice-orb.user .orb-ring,.voice-orb.speaking .orb-ring{animation:orbpulse 2s ease-out infinite}.voice-orb.speaking .orb-ring{animation-duration:1.1s}.voice-orb.user .orb-ring{animation-duration:.9s}.orb-ring.r2{animation-delay:.55s!important}@keyframes orbpulse{0%{transform:scale(1);opacity:.55}to{transform:scale(1.95);opacity:0}}.voice-orb.thinking .orb-core,.voice-orb.connecting .orb-core{animation:orbglow 1.3s ease-in-out infinite}@keyframes orbglow{0%,to{box-shadow:0 0 10px var(--oc)}50%{box-shadow:0 0 36px var(--oc)}}.voice-state-txt{font-size:16px;font-weight:600}.voice-last{max-width:100%;background:var(--panel-2);border-radius:12px;padding:8px 12px;font-size:14px;color:var(--muted);line-height:1.4}.voice-last.me{color:#e6eaf0}.panel{background:linear-gradient(180deg,#1f283999,#161d2b99);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin:14px;box-shadow:var(--shadow)}.panel h3{margin:0 0 12px;font-size:16px}.room-header{background:#0e131eb8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:14px 20px}.badge{background:#ffffff0f;border:1px solid var(--border);padding:4px 11px;border-radius:999px;font-size:12px;font-weight:600}.badge.status-available,.status.on{color:#7ee2a8}.badge.status-available{background:#2ecc7129;border-color:#2ecc7159}.badge.status-break,.badge.status-wrapup{background:#f0445526;color:#ff9aa2;border-color:#f044554d}.badge.status-oncall,.badge.status-answered{background:#40bed62e;color:#86dcec;border-color:#40bed659}.badge.status-ringing{background:#e6a23c2e;color:#f0c479;border-color:#e6a23c59}.stats{gap:14px;padding:14px}.stat{background:linear-gradient(180deg,#1f2839a6,#161d2ba6);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s}.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-value{background:linear-gradient(135deg,#ff6a5f,#e4231f);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}table.cdr th{font-weight:600;color:var(--muted);border-bottom:1px solid var(--border)}table.cdr td{border-bottom:1px solid rgba(255,255,255,.04)}table.cdr tbody tr:hover td{background:#ffffff08}.list-row{padding:11px 4px;border-bottom:1px solid rgba(255,255,255,.05)}.list-row:last-child{border-bottom:none}.tab{background:transparent;border-radius:10px 10px 0 0;font-weight:600}.tab.active{background:var(--panel)}.admin-side{background:#0e131ec7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-right:1px solid var(--border)}.side-link.active{background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:0 6px 16px #e4231f4d}.controls,.callbar{background:#0e131eb8;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.controls{border-top:1px solid var(--border)}.ivr-btn{border:1px solid var(--border);background:#ffffff08;border-radius:var(--radius-sm);transition:transform .12s,border-color .12s,background .12s}.ivr-btn:hover{transform:translateY(-2px);border-color:#e4231f80;background:#e4231f14}.pulse{animation:softpulse 1.6s ease-in-out infinite}@keyframes softpulse{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.12);opacity:1}}.theme-toggle{position:fixed;top:14px;right:14px;z-index:200;width:42px;height:42px;padding:0;border-radius:50%;display:grid;place-items:center;font-size:18px;background:var(--panel-2);border:1px solid var(--border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.room-header,.admin-shell .admin-side{padding-right:64px}.admin-shell .admin-side{padding-right:12px}@media (max-width: 700px){.room-header{padding-right:64px}}html.light{--bg: #eef2f9;--panel: #ffffff;--panel-2: #eef2f8;--text: #16202f;--muted: #5a6678;--border: rgba(20, 30, 55, .11);--shadow: 0 8px 24px rgba(30, 50, 90, .1);--shadow-lg: 0 22px 55px rgba(30, 50, 90, .16)}html.light body{background:radial-gradient(1100px 620px at 50% -12%,#dce7ff,#eef2f9 55%) no-repeat fixed,#eef2f9}html.light .card{background:#ffffffe6;border:1px solid var(--border)}html.light .panel,html.light .stat{background:#fff}html.light input,html.light select,html.light textarea{background:#fff;border-color:#141e3729;color:var(--text)}html.light input::placeholder,html.light textarea::placeholder{color:#9aa4b4}html.light input:focus,html.light select:focus,html.light textarea:focus{background:#fff}html.light .room-header,html.light .admin-side,html.light .controls,html.light .tabs{background:#ffffffd1}html.light .callbar{background:#f0445514;color:#c0392b}html.light .badge{background:#141e370d}html.light .theme-toggle{background:#fff}html.light .chat-msg.bot,html.light .voice-last,html.light .msg-bubble,html.light .point-card,html.light .ai-detail,html.light .ai-context,html.light .ai-context-bar,html.light .ivr-btn{background:#eef2f8}html.light .ai-context,html.light .ai-context-bar{background:#e4231f17}html.light .chat-msg.me,html.light .msg.self .msg-bubble{color:#fff}html.light table.cdr th{color:#5a6678}html.light table.cdr td{border-bottom:1px solid rgba(20,30,55,.07)}html.light table.cdr tbody tr:hover td{background:#141e3708}html.light .tab.active{background:#fff}html.light .side-link:hover{background:#eef2f8}html.light .orb-core{color:#fff}button.ok,button.ok.big{background:linear-gradient(135deg,#34d67f,#21a55a);box-shadow:0 6px 18px #2ecc714d;color:#fff}
