/* Minimal, clean mockup styling */
:root{
  --bg:#0f172a;          /* slate-900 */
  --panel:#111c33;       /* deep navy */
  --panel2:#0b1324;
  --text:#e5e7eb;        /* gray-200 */
  --muted:#9ca3af;       /* gray-400 */
  --line:#24324d;
  --accent:#22c55e;      /* green-500 */
  --accent2:#60a5fa;     /* blue-400 */
  --warn:#f59e0b;        /* amber-500 */
  --bad:#ef4444;         /* red-500 */
  --chip:#1f2a44;
  --shadow: 0 10px 24px rgba(0,0,0,.25);
  --radius:14px;
  --maxw:1200px;
  --maxw-wide:1540px;
  --logo-size: clamp(34px, 2.8vw, 56px);
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font);
  background: radial-gradient(1200px 700px at 20% -10%, #1d2a4a 0%, transparent 60%),
              radial-gradient(900px 600px at 90% 0%, #14203a 0%, transparent 55%),
              var(--bg);
  color:var(--text);
}
a{color:inherit; text-decoration:none}
small{color:var(--muted)}
code{background:var(--codebg, #0a1224); padding:2px 6px; border-radius:8px; border:1px solid var(--line)}

html[data-theme="light"]{
  --bg:#f3f6fb;
  --panel:#ffffff;
  --panel2:#f8fbff;
  --text:#0f172a;
  --muted:#475569;
  --line:#cbd5e1;
  --chip:#e2e8f0;
  --shadow: 0 10px 22px rgba(15,23,42,.10);
  --codebg:#eef2ff;
}

html[data-theme="light"] body{
  background: radial-gradient(1200px 700px at 20% -10%, #d7e3f7 0%, transparent 60%),
              radial-gradient(900px 600px at 90% 0%, #dceaf9 0%, transparent 55%),
              var(--bg);
}

html[data-theme="light"] .topbar{
  background:rgba(255,255,255,.88);
  border-bottom:1px solid rgba(148,163,184,.55);
}

html[data-theme="light"] .badge,
html[data-theme="light"] .btn,
html[data-theme="light"] .user-menu-trigger,
html[data-theme="light"] .select,
html[data-theme="light"] .input{
  border-color:rgba(148,163,184,.65);
  background:rgba(255,255,255,.88);
}

html[data-theme="light"] .card{
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,250,255,.95));
  border-color: rgba(148,163,184,.65);
}

html[data-theme="light"] .tablewrap{
  border-color: rgba(148,163,184,.65);
}

html[data-theme="light"] table{
  background: rgba(255,255,255,.6);
}

html[data-theme="light"] .nav a.active{
  background:rgba(226,232,240,.72);
  border-color:rgba(96,165,250,.35);
}

html[data-theme="light"] .nav a:hover{
  background:rgba(226,232,240,.5);
}

html[data-theme="light"] .user-menu-list{
  border-color:rgba(148,163,184,.65);
  background:rgba(255,255,255,.98);
}

html[data-theme="light"] .user-menu-item:hover{
  background:rgba(226,232,240,.6);
}

.container{
  max-width:var(--maxw);
  margin:0 auto;
  padding:24px;
}
body[data-page="queues"] .container.queue-wide{
  max-width: 1680px;
  padding: 16px 18px 24px;
}
@media (max-width: 1200px){
  body[data-page="queues"] .container.queue-wide{
    max-width: 100%;
    padding: 14px;
  }
}

/* Wider layout experiment (easy revert): remove this block to return to original width behavior. */
body[data-page="overview"] .container,
body[data-page="agents"] .container,
body[data-page="intervals"] .container,
body[data-page="explorer"] .container,
body[data-page="reports"] .container,
body[data-page="admin"] .container{
  max-width: var(--maxw-wide);
  padding: 18px 20px 24px;
}
body[data-page="overview"] .navwrap,
body[data-page="agents"] .navwrap,
body[data-page="intervals"] .navwrap,
body[data-page="explorer"] .navwrap,
body[data-page="reports"] .navwrap,
body[data-page="admin"] .navwrap{
  max-width: var(--maxw-wide);
}
@media (max-width: 1280px){
  body[data-page="overview"] .container,
  body[data-page="agents"] .container,
  body[data-page="intervals"] .container,
  body[data-page="explorer"] .container,
  body[data-page="reports"] .container,
  body[data-page="admin"] .container{
    max-width: 100%;
    padding: 14px;
  }
}

.topbar{
  position:sticky; top:0; z-index:10;
  background:rgba(15,23,42,.78);
  backdrop-filter: blur(10px);
  border-bottom:1px solid rgba(36,50,77,.7);
}
.navwrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:12px 24px;
  display:flex;
  align-items:center;
  gap:16px;
}
.brand{
  display:flex; align-items:center; gap:10px;
  font-weight:700;
  min-height: var(--logo-size);
}
.logo{
  width:var(--logo-size);
  height:var(--logo-size);
  border-radius:10px;
  background: linear-gradient(135deg, var(--accent2), var(--accent));
  box-shadow: var(--shadow);
  flex:0 0 auto;
}
.logo.logo-img{
  object-fit:contain;
  background: rgba(17,28,51,.65);
  padding:4px;
}
.nav{
  display:flex; flex-wrap:wrap;
  gap:10px;
  margin-left:12px;
}
.nav a{
  padding:8px 10px;
  border-radius:10px;
  color:var(--muted);
  border:1px solid transparent;
}
.nav a.active{
  color:var(--text);
  background:rgba(31,42,68,.55);
  border:1px solid rgba(96,165,250,.25);
}
.nav a:hover{
  color:var(--text);
  background:rgba(31,42,68,.35);
}

.right{
  margin-left:auto;
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
}
.badge{
  padding:6px 10px;
  border:1px solid rgba(36,50,77,.9);
  background:rgba(17,28,51,.65);
  border-radius:999px;
  color:var(--muted);
  font-size:12px;
}
.btn{
  padding:8px 12px;
  border-radius:12px;
  border:1px solid rgba(36,50,77,.9);
  background:rgba(17,28,51,.75);
  color:var(--text);
  cursor:default;
  font-size:13px;
}
.btn.primary{
  border-color: rgba(34,197,94,.35);
  background: rgba(34,197,94,.12);
}
.btn.blue{
  border-color: rgba(96,165,250,.35);
  background: rgba(96,165,250,.10);
}
.btn.warn{
  border-color: rgba(245,158,11,.35);
  background: rgba(245,158,11,.10);
}
.btn:active{transform: translateY(1px)}

.header{
  display:flex; gap:14px; align-items:flex-start; flex-wrap:wrap;
  margin: 18px 0 16px;
}
.hgroup{flex: 1 1 480px;}
.hgroup h1{
  margin:0;
  font-size:26px;
  letter-spacing:.2px;
}
.hgroup p{margin:6px 0 0; color:var(--muted); line-height:1.5}
.callout{
  flex: 0 0 auto;
  border:1px dashed rgba(96,165,250,.45);
  background: rgba(96,165,250,.08);
  padding:10px 12px;
  border-radius:12px;
  color: var(--muted);
  font-size:12px;
}

.grid{
  display:grid;
  gap:14px;
}
.grid.kpis{grid-template-columns: repeat(6, minmax(0, 1fr));}
@media (max-width: 1100px){ .grid.kpis{grid-template-columns: repeat(3, minmax(0,1fr));} }
@media (max-width: 650px){ .grid.kpis{grid-template-columns: repeat(2, minmax(0,1fr));} }

.card{
  background: linear-gradient(180deg, rgba(17,28,51,.85), rgba(11,19,36,.78));
  border:1px solid rgba(36,50,77,.95);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.card .pad{padding:14px}
.card h2{
  margin:0 0 10px;
  font-size:15px;
  color: var(--text);
  letter-spacing: .2px;
}
.kpi{
  padding:14px;
}
.kpi .label{color:var(--muted); font-size:12px}
.kpi .value{margin-top:8px; font-size:24px; font-weight:800}
.kpi .sub{margin-top:6px; color:var(--muted); font-size:12px}
.kpi .trend.up{color:var(--accent)}
.kpi .trend.down{color:var(--bad)}
.kpi .trend.flat{color:var(--accent2)}

.row{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:14px;
}
@media (max-width: 980px){ .row{grid-template-columns: 1fr;} }

.tablewrap{
  overflow:auto;
  border-radius: 12px;
  border:1px solid rgba(36,50,77,.95);
}
table{
  width:100%;
  border-collapse: collapse;
  min-width: 820px;
  background: rgba(15,23,42,.22);
}
.reports-schedules-wrap table{
  min-width: 0;
}
.reports-schedules-table th,
.reports-schedules-table td{
  white-space: normal;
}
.api-health{
  text-decoration:none;
}
.api-health.ok{
  color:#bbf7d0;
  border-color: rgba(34,197,94,.45);
  background: rgba(34,197,94,.14);
}
.api-health.bad{
  color:#fecaca;
  border-color: rgba(239,68,68,.45);
  background: rgba(239,68,68,.14);
}
.api-health.unknown{
  color:var(--muted);
}
.user-menu{
  position:relative;
}
.user-menu summary{
  list-style:none;
}
.user-menu summary::-webkit-details-marker{
  display:none;
}
.user-menu-trigger{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border:1px solid rgba(36,50,77,.9);
  background:rgba(17,28,51,.65);
  border-radius:999px;
  color:var(--text);
  font-size:12px;
  cursor:pointer;
  user-select:none;
}
.user-menu-caret{
  color:var(--muted);
  font-size:11px;
}
.user-menu-list{
  position:absolute;
  right:0;
  top:calc(100% + 6px);
  min-width:150px;
  border:1px solid rgba(36,50,77,.9);
  background:rgba(11,19,36,.98);
  border-radius:10px;
  box-shadow: var(--shadow);
  padding:6px;
  display:grid;
  gap:4px;
  z-index:20;
}
.user-menu-item{
  display:block;
  color:var(--text);
  padding:9px 10px;
  border-radius:8px;
  font-size:13px;
  line-height:1;
}
.user-menu-item:hover{
  background:rgba(31,42,68,.45);
}
.user-menu-form{
  margin:0;
}
.user-menu-button{
  width:100%;
  text-align:left;
  background:transparent;
  border:none;
  cursor:pointer;
  color:var(--text);
}
th, td{
  padding:10px 12px;
  border-bottom:1px solid rgba(36,50,77,.75);
  font-size:13px;
  white-space:nowrap;
}
th{
  text-align:left;
  color: var(--muted);
  font-weight:700;
  background: rgba(31,42,68,.25);
}
tr:hover td{
  background: rgba(31,42,68,.18);
}

.chips{display:flex; gap:8px; flex-wrap:wrap}
.chip{
  padding:6px 10px;
  border-radius: 999px;
  background: rgba(31,42,68,.55);
  border:1px solid rgba(36,50,77,.9);
  color:var(--muted);
  font-size:12px;
  cursor:pointer;
}
.dropzone{
  min-height:42px;
  border:1px dashed rgba(96,165,250,.35);
  border-radius:12px;
  padding:8px;
  align-content:flex-start;
}
.layout-canvas{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:10px;
}
.layout-section{
  border:1px solid rgba(36,50,77,.95);
  border-radius:12px;
  background: rgba(15,23,42,.35);
  padding:10px;
}
.layout-section-header{
  display:flex;
  align-items:center;
  gap:8px;
}
.layout-section-title{
  min-width: 120px;
  flex: 1 1 auto;
}
.layout-section-body{
  margin-top:8px;
  border:1px dashed rgba(96,165,250,.3);
  border-radius:10px;
  min-height:66px;
  padding:8px;
  display:grid;
  gap:6px;
}
.layout-column{
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(36,50,77,.9);
  border-radius:10px;
  padding:6px 8px;
  background: rgba(17,28,51,.82);
}
.layout-column.metric{
  border-color: rgba(34,197,94,.35);
}
.layout-column.dimension{
  border-color: rgba(96,165,250,.35);
}
.layout-column-label{
  flex: 1 1 auto;
  min-width: 0;
}
.layout-drag-handle{
  color:var(--muted);
  cursor:grab;
  user-select:none;
}

.trend-chart-host{
  min-height: 280px;
  border:1px solid rgba(36,50,77,.95);
  border-radius:12px;
  background: linear-gradient(180deg, rgba(17,28,51,.45), rgba(11,19,36,.35));
  padding:10px;
}
.line-swatch{
  display:inline-block;
  width:14px;
  height:0;
  border-top:2px solid transparent;
  vertical-align:middle;
  margin-right:6px;
}
.line-swatch.blue{ border-top-color: var(--accent2); }
.line-swatch.muted{ border-top-color: #94a3b8; border-top-style: dashed; }

.placeholderChart{
  height:260px;
  background:
    linear-gradient(180deg, rgba(96,165,250,.08), rgba(34,197,94,.05)),
    repeating-linear-gradient(90deg, rgba(36,50,77,.35) 0, rgba(36,50,77,.35) 1px, transparent 1px, transparent 45px),
    repeating-linear-gradient(0deg, rgba(36,50,77,.25) 0, rgba(36,50,77,.25) 1px, transparent 1px, transparent 45px);
  border:1px solid rgba(36,50,77,.95);
  border-radius: 12px;
  position: relative;
  overflow: hidden;
}
.placeholderChart:after{
  content:"";
  position:absolute; inset:auto 12px 12px auto;
  font-size:12px; color:var(--muted);
  background: rgba(15,23,42,.6);
  padding:6px 10px;
  border:1px solid rgba(36,50,77,.8);
  border-radius:999px;
}
.legend{
  display:flex; gap:10px; flex-wrap:wrap;
  margin-top:10px;
  color:var(--muted);
  font-size:12px;
}
.dot{
  width:10px; height:10px; border-radius:999px; display:inline-block; margin-right:6px;
}
.dot.blue{background: var(--accent2)}
.dot.green{background: var(--accent)}
.dot.amber{background: var(--warn)}
.dot.red{background: var(--bad)}

.footer{
  margin:24px 0 40px;
  color: var(--muted);
  font-size:12px;
  display:flex; justify-content:space-between; flex-wrap:wrap;
  gap:10px;
}
hr.sep{
  border:none;
  border-top:1px solid rgba(36,50,77,.75);
  margin:18px 0;
}

/* small form-like elements (non-functional) */
.filters{
  display:flex; flex-wrap:wrap; gap:10px; align-items:center;
}
.select{
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(36,50,77,.9);
  background: rgba(17,28,51,.65);
  color: var(--text);
  font-size:13px;
}
.input{
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(36,50,77,.9);
  background: rgba(17,28,51,.65);
  color: var(--text);
  font-size:13px;
  min-width: 220px;
}

.note{
  border-left: 3px solid rgba(96,165,250,.55);
  background: rgba(96,165,250,.08);
  padding:10px 12px;
  border-radius: 12px;
  color: var(--muted);
  font-size:12px;
}

.smallgrid{
  display:grid;
  gap:14px;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 980px){ .smallgrid{grid-template-columns: 1fr;} }

/* Queue wallboard density overrides */
.wallboard-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit,minmax(188px,1fr));
  gap:8px;
}
.wallboard-summary{
  font-size:12px;
  padding:7px 9px;
}
.wallboard-tablewrap{
  overflow-x: hidden;
}
.wallboard-table{
  min-width: 100%;
  table-layout: fixed;
}
.wallboard-table th,
.wallboard-table td{
  font-size:12px;
  padding:6px 7px;
}
.wallboard-table .col-ext{
  width:48px;
}
.wallboard-table .col-name{
  width:110px;
}
.wallboard-table .cell-name{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.queue-section-titlebar{
  padding:10px 12px;
}
.status-icon{
  width:12px;
  height:12px;
  border-radius:999px;
  display:inline-block;
  vertical-align:middle;
  border:1px solid rgba(255,255,255,.22);
}
.status-icon.queue-in{ background: var(--accent); }
.status-icon.queue-out{ background: var(--warn); }
.status-icon.queue-unknown{ background: #64748b; }
.status-icon.call-on{ background: var(--bad); }
.status-icon.call-idle{ background: #334155; }
.status-icon.call-other{ background: #a78bfa; }

.modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(2,6,23,.55);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:100;
}
.modal{
  width:min(420px,92vw);
  border:1px solid rgba(36,50,77,.95);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(17,28,51,.95), rgba(11,19,36,.95));
  box-shadow: var(--shadow);
}
.modal .pad{ padding:14px; }

/* Fullscreen board layouts */
#realtime-wallboard-section:fullscreen,
#realtime-wallboard-section:-webkit-full-screen{
  width:100vw;
  height:100vh;
  box-sizing:border-box;
  padding:10px;
  overflow:hidden;
  background:
    radial-gradient(900px 360px at 10% 10%, rgba(59,130,246,.16), transparent 60%),
    radial-gradient(1000px 420px at 90% 0%, rgba(16,185,129,.10), transparent 58%),
    var(--bg0);
  display:flex;
  flex-direction:column;
}

#realtime-wallboard-section:fullscreen > .card:first-child,
#realtime-wallboard-section:-webkit-full-screen > .card:first-child{
  flex:0 0 auto;
}

#realtime-wallboard-section:fullscreen #realtime-cards,
#realtime-wallboard-section:-webkit-full-screen #realtime-cards{
  flex:1 1 auto;
  min-height:0;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-rows: min-content;
  gap:10px;
  overflow:auto;
  align-content:start;
}

#realtime-wallboard-section:fullscreen #realtime-cards > .card,
#realtime-wallboard-section:-webkit-full-screen #realtime-cards > .card{
  min-height:unset;
  height:auto;
}

#realtime-wallboard-section:fullscreen #realtime-cards details.card,
#realtime-wallboard-section:-webkit-full-screen #realtime-cards details.card{
  height:auto;
  display:block;
}

#realtime-wallboard-section:fullscreen #realtime-cards details.card > .wallboard-tablewrap,
#realtime-wallboard-section:-webkit-full-screen #realtime-cards details.card > .wallboard-tablewrap{
  max-height:52vh;
  overflow:auto;
}

#realtime-wallboard-section:fullscreen .wallboard-table th,
#realtime-wallboard-section:fullscreen .wallboard-table td,
#realtime-wallboard-section:-webkit-full-screen .wallboard-table th,
#realtime-wallboard-section:-webkit-full-screen .wallboard-table td{
  font-size: clamp(14px, 1.5vh, 18px);
  padding: 7px 8px;
}

#realtime-wallboard-section:fullscreen .wallboard-summary,
#realtime-wallboard-section:-webkit-full-screen .wallboard-summary{
  font-size: clamp(14px, 1.6vh, 18px);
}

#queue-performance-summary:fullscreen,
#queue-performance-summary:-webkit-full-screen{
  width:100vw;
  height:100vh;
  box-sizing:border-box;
  padding:14px;
  overflow:hidden;
  background:
    radial-gradient(900px 360px at 10% 10%, rgba(59,130,246,.16), transparent 60%),
    radial-gradient(1000px 420px at 90% 0%, rgba(16,185,129,.10), transparent 58%),
    var(--bg0);
  display:flex;
  flex-direction:column;
  gap:10px;
}

#queue-performance-summary:fullscreen .tablewrap,
#queue-performance-summary:-webkit-full-screen .tablewrap{
  flex:1 1 auto;
  min-height:0;
  overflow:auto;
}

#queue-performance-summary:fullscreen table,
#queue-performance-summary:-webkit-full-screen table{
  min-width:100%;
  height:100%;
}

#queue-performance-summary:fullscreen tbody tr,
#queue-performance-summary:-webkit-full-screen tbody tr{
  height: clamp(64px, 9vh, 108px);
}

#queue-performance-summary:fullscreen th,
#queue-performance-summary:fullscreen td,
#queue-performance-summary:-webkit-full-screen th,
#queue-performance-summary:-webkit-full-screen td{
  font-size: clamp(18px, 2.1vh, 28px);
  padding: 16px 14px;
}

#queue-performance-summary:fullscreen .note,
#queue-performance-summary:-webkit-full-screen .note{
  font-size: clamp(14px, 1.35vh, 18px);
}

@media (max-width: 1800px){
  #realtime-wallboard-section:fullscreen #realtime-cards,
  #realtime-wallboard-section:-webkit-full-screen #realtime-cards{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1300px){
  #realtime-wallboard-section:fullscreen #realtime-cards,
  #realtime-wallboard-section:-webkit-full-screen #realtime-cards{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
