/* ═══════════════════════════════════════════
   Kiro ⚡ — Premium Dashboard v4 (Apple Polish)
   ═══════════════════════════════════════════ */

/* ---------- Fonts ---------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&family=JetBrains+Mono:wght@500;600;700&display=swap');

/* Try to load SF Pro if available (macOS/iOS) */
@supports (font-family: -apple-system) {
  :root { --font-primary: -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Inter', sans-serif; }
}

/* ---------- Reset ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ---------- Custom Properties ---------- */
:root{
  /* core palette — deep black dark mode */
  --bg:        #000000;
  --bg2:       #0a0a0a;
  --bg3:       #121212;
  --surface:   rgba(255,255,255,.04);
  --surface2:  rgba(255,255,255,.07);
  --glass:     rgba(255,255,255,.05);
  --glass-h:   rgba(255,255,255,.09);
  --border:    rgba(255,255,255,.08);
  --border-h:  rgba(255,255,255,.15);
  --glow:      rgba(99,102,241,.12);

  /* text */
  --text:      #ffffff;
  --text2:     #b4b4b8;
  --text3:     #6e6e73;
  --text4:     #3a3a3c;

  /* primary */
  --primary:     #818cf8;
  --primary-dim: #6366f1;
  --primary-bg:  rgba(99,102,241,.12);
  --primary-glow:rgba(99,102,241,.3);

  /* semantic */
  --green:     #34d399;
  --green-dim: #059669;
  --green-bg:  rgba(52,211,153,.12);
  --red:       #fb7185;
  --red-dim:   #e11d48;
  --red-bg:    rgba(251,113,133,.12);
  --amber:     #fbbf24;
  --amber-bg:  rgba(251,191,36,.12);
  --blue:      #60a5fa;
  --blue-bg:   rgba(96,165,250,.12);
  --cyan:      #22d3ee;
  --cyan-bg:   rgba(34,211,238,.12);
  --orange:    #fb923c;
  --orange-bg: rgba(251,146,60,.12);
  --purple:    #a78bfa;
  --purple-bg: rgba(167,139,250,.12);

  /* layout */
  --safe-t:    env(safe-area-inset-top, 0px);
  --safe-b:    env(safe-area-inset-bottom, 0px);
  --safe-l:    env(safe-area-inset-left, 0px);
  --safe-r:    env(safe-area-inset-right, 0px);
  --header-h:  64px;
  --tabs-h:    52px;
  --max-w:     1080px;
  --r:         18px;
  --r-sm:      14px;
  --r-xs:      10px;

  /* fonts */
  --font:      'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', 'Segoe UI', sans-serif;
  --mono:      'JetBrains Mono', 'SF Mono', 'Menlo', 'Consolas', monospace;

  /* transitions */
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-snap:   cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* ---------- Base ---------- */
html{
  -webkit-text-size-adjust:100%;
  -webkit-tap-highlight-color:transparent;
  scroll-behavior:smooth;
}
body{
  font-family:var(--font);
  font-size:14px;
  line-height:1.6;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  min-height:100dvh;
  padding-top:var(--safe-t);
  padding-bottom:var(--safe-b);
  padding-left:var(--safe-l);
  padding-right:var(--safe-r);
  overscroll-behavior-y:none;
  overflow-x:hidden;
  font-feature-settings:"liga" 1,"kern" 1;
}

/* ambient background glow with parallax */
body::before{
  content:'';
  position:fixed;
  top:-50%;left:-30%;
  width:160%;height:160%;
  background:
    radial-gradient(ellipse 700px 500px at 25% 25%, rgba(99,102,241,.08), transparent 65%),
    radial-gradient(ellipse 600px 450px at 75% 75%, rgba(139,92,246,.06), transparent 65%),
    radial-gradient(ellipse 500px 400px at 50% 50%, rgba(34,211,238,.04), transparent 65%);
  pointer-events:none;
  z-index:0;
  animation:float 30s ease-in-out infinite;
  will-change:transform;
}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(2%,-3%) scale(1.02)}
  66%{transform:translate(-3%,2%) scale(0.98)}
}

/* ---------- Header ---------- */
.header{
  position:sticky;
  top:0;
  z-index:100;
  backdrop-filter:blur(32px) saturate(1.8);
  -webkit-backdrop-filter:blur(32px) saturate(1.8);
  background:rgba(0,0,0,.75);
  border-bottom:0.5px solid var(--border);
  height:var(--header-h);
  transition:all .3s var(--ease-smooth);
}
.header-inner{
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 24px;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand{display:flex;align-items:center;gap:12px}
.brand-icon{
  color:var(--primary);
  filter:drop-shadow(0 0 10px var(--primary-glow));
  transition:filter .4s var(--ease-smooth),transform .3s var(--ease-spring);
}
.brand:hover .brand-icon{
  filter:drop-shadow(0 0 16px var(--primary-glow));
  transform:rotate(15deg) scale(1.05);
}
.brand-name{
  font-size:22px;
  font-weight:900;
  letter-spacing:-0.8px;
  background:linear-gradient(135deg,#818cf8,#c084fc,#818cf8);
  background-size:200% 200%;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:shimmer 8s ease infinite;
}
@keyframes shimmer{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}

.header-status{display:flex;align-items:center;gap:14px}
.status-pill{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;
  padding:6px 16px;
  border-radius:24px;
  background:var(--surface);
  border:0.5px solid var(--border);
  color:var(--text2);
  transition:all .3s var(--ease-smooth);
}
.status-dot{
  width:9px;height:9px;border-radius:50%;
  background:var(--text4);
  transition:all .5s var(--ease-smooth);
  position:relative;
}
.status-dot.online{
  background:var(--green);
  box-shadow:0 0 10px var(--green);
  animation:pulse-green 2.5s ease-in-out infinite;
}
.status-dot.offline{
  background:var(--red);
  box-shadow:0 0 10px var(--red);
  animation:pulse-red 2.5s ease-in-out infinite;
}
@keyframes pulse-green{
  0%,100%{box-shadow:0 0 6px var(--green),0 0 12px rgba(52,211,153,.3)}
  50%{box-shadow:0 0 14px var(--green),0 0 24px rgba(52,211,153,.5)}
}
@keyframes pulse-red{
  0%,100%{box-shadow:0 0 6px var(--red),0 0 12px rgba(251,113,133,.3)}
  50%{box-shadow:0 0 14px var(--red),0 0 24px rgba(251,113,133,.5)}
}

/* ---------- Tabs ---------- */
.tabs{
  position:sticky;
  top:var(--header-h);
  z-index:90;
  backdrop-filter:blur(32px) saturate(1.8);
  -webkit-backdrop-filter:blur(32px) saturate(1.8);
  background:rgba(0,0,0,.75);
  border-bottom:0.5px solid var(--border);
  height:var(--tabs-h);
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.tabs::-webkit-scrollbar{display:none}
.tabs-inner{
  max-width:var(--max-w);
  margin:0 auto;
  padding:0 24px;
  height:100%;
  display:flex;
  gap:4px;
  align-items:center;
  position:relative;
}
/* iOS-style sliding indicator */
.tab-indicator{
  position:absolute;
  bottom:0;
  left:0;
  height:3px;
  background:linear-gradient(90deg,var(--primary-dim),var(--primary));
  border-radius:2px 2px 0 0;
  box-shadow:0 -2px 12px var(--primary-glow);
  transition:all .4s var(--ease-spring);
  pointer-events:none;
  z-index:2;
}
.tab{
  flex-shrink:0;
  padding:11px 20px;
  border:none;
  background:transparent;
  color:var(--text3);
  font-family:var(--font);
  font-size:13.5px;
  font-weight:700;
  border-radius:var(--r-xs);
  cursor:pointer;
  transition:all .3s var(--ease-smooth);
  -webkit-tap-highlight-color:transparent;
  white-space:nowrap;
  position:relative;
  letter-spacing:-0.2px;
}
.tab:hover{color:var(--text2);background:var(--surface)}
.tab.active{
  color:var(--primary);
  background:var(--primary-bg);
}
.tab:active{transform:scale(0.96)}

/* ---------- Content ---------- */
.content{
  max-width:var(--max-w);
  margin:0 auto;
  padding:24px 24px 120px;
  position:relative;
  z-index:1;
}

.tab-panel{
  display:none;
  animation:fadeSlideUp .45s var(--ease-smooth);
}
.tab-panel.active{display:block}
@keyframes fadeSlideUp{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

/* ---------- Card ---------- */
.card{
  border-radius:var(--r);
  padding:24px;
  margin-bottom:18px;
  position:relative;
  transition:all .4s var(--ease-smooth);
  transform-origin:center;
}
.glass{
  background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.03));
  border:0.5px solid var(--border);
  backdrop-filter:blur(20px) saturate(1.5);
  -webkit-backdrop-filter:blur(20px) saturate(1.5);
}
.glass:hover{
  border-color:var(--border-h);
  background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.04));
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(0,0,0,.4),0 0 0 0.5px rgba(255,255,255,.08);
}
/* gradient border glow on hover */
.glass::before{
  content:'';
  position:absolute;
  inset:-1px;
  border-radius:calc(var(--r) + 1px);
  background:linear-gradient(135deg,rgba(99,102,241,.2),transparent 35%,transparent 65%,rgba(139,92,246,.15));
  opacity:0;
  transition:opacity .5s var(--ease-smooth);
  z-index:-1;
  pointer-events:none;
}
.glass:hover::before{opacity:1}

.board-title{
  font-size:11px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1.4px;
  color:var(--text3);
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:10px;
}
.board-title::before{
  content:'';
  width:3px;
  height:14px;
  border-radius:2px;
  background:linear-gradient(180deg,var(--primary),var(--primary-dim));
  box-shadow:0 0 8px var(--primary-glow);
}

/* ---------- Dashboard: Status Board ---------- */
.status-board{padding:28px}
.status-row{display:flex;gap:36px;flex-wrap:wrap}
.status-item{
  display:flex;align-items:center;gap:16px;
  transition:transform .3s var(--ease-smooth);
}
.status-item:hover{transform:scale(1.03)}
.status-icon{
  font-size:30px;
  width:56px;height:56px;
  display:flex;align-items:center;justify-content:center;
  border-radius:16px;
  background:linear-gradient(135deg,var(--surface2),var(--surface));
  border:0.5px solid var(--border);
  transition:all .3s var(--ease-smooth);
}
.status-item:hover .status-icon{
  background:linear-gradient(135deg,var(--glass-h),var(--surface2));
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.status-info{display:flex;flex-direction:column;gap:3px}
.status-value{
  font-family:var(--mono);
  font-size:22px;
  font-weight:800;
  color:var(--text);
  letter-spacing:-0.5px;
}
.status-label{
  font-size:11px;
  font-weight:700;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:1px;
}

/* ---------- Dashboard: Grid ---------- */
.dashboard-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:18px;
  margin-bottom:18px;
}

.dash-card-content{padding:6px 0}
.dash-big{
  font-family:var(--mono);
  font-size:40px;
  font-weight:900;
  margin-bottom:8px;
  letter-spacing:-1.2px;
  background:linear-gradient(135deg,var(--text),var(--text2));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}
.dash-label{font-size:14.5px;color:var(--text2);margin-bottom:5px;font-weight:600}
.dash-meta{font-size:12px;color:var(--text3)}

/* ---------- Dashboard: Markets ---------- */
.market-item{
  padding:14px 0;
  border-bottom:0.5px solid var(--border);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  transition:background .2s var(--ease-smooth),padding .2s;
}
.market-item:last-child{border-bottom:none}
.market-item:hover{
  background:var(--surface);
  margin:0 -12px;
  padding:14px 12px;
  border-radius:var(--r-xs);
}
.market-left{display:flex;flex-direction:column;gap:3px}
.market-name{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.6px}
.market-price{
  font-family:var(--mono);
  font-size:19px;
  font-weight:800;
  letter-spacing:-0.4px;
}
.market-change{
  font-family:var(--mono);
  font-size:12px;
  font-weight:700;
  padding:5px 12px;
  border-radius:7px;
  letter-spacing:-0.2px;
  animation:pulse-badge 3s ease-in-out infinite;
}
.market-change.up{background:var(--green-bg);color:var(--green)}
.market-change.down{background:var(--red-bg);color:var(--red)}
@keyframes pulse-badge{
  0%,100%{opacity:1}
  50%{opacity:0.85}
}

/* ---------- Dashboard: System Mini ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.stat-card-mini{
  padding:18px;
  border-radius:var(--r-sm);
  background:linear-gradient(135deg,var(--surface2),var(--surface));
  border:0.5px solid var(--border);
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:center;
  transition:all .3s var(--ease-smooth);
}
.stat-card-mini:hover{
  border-color:var(--border-h);
  transform:translateY(-3px) scale(1.02);
  box-shadow:0 6px 24px rgba(0,0,0,.35);
}
.stat-mini-icon{
  font-size:10px;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1px;
  padding:5px 12px;
  border-radius:7px;
}
.stat-mini-icon.blue{background:var(--blue-bg);color:var(--blue)}
.stat-mini-icon.green{background:var(--green-bg);color:var(--green)}
.stat-mini-icon.orange{background:var(--orange-bg);color:var(--orange)}
.stat-mini-icon.purple{background:var(--purple-bg);color:var(--purple)}
.stat-mini-val{
  font-family:var(--mono);
  font-size:22px;
  font-weight:800;
  letter-spacing:-0.5px;
}

/* ---------- Dashboard: Upcoming Crons ---------- */
.cron-mini{
  padding:11px 0;
  border-bottom:0.5px solid var(--border);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:14px;
  transition:background .2s,padding .2s;
}
.cron-mini:last-child{border-bottom:none}
.cron-mini:hover{background:var(--surface);margin:0 -12px;padding:11px 12px;border-radius:var(--r-xs)}
.cron-mini-name{font-size:13.5px;font-weight:700;color:var(--text)}
.cron-mini-time{
  font-family:var(--mono);
  font-size:11px;
  color:var(--text3);
  padding:4px 10px;
  border-radius:6px;
  background:var(--surface);
}

/* ---------- Controls: Gateway Buttons ---------- */
.gateway-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:56px;
  border:none;border-radius:var(--r-sm);
  font-family:var(--font);
  font-size:14px;font-weight:700;
  cursor:pointer;
  transition:all .25s var(--ease-smooth);
  -webkit-tap-highlight-color:transparent;
  color:#fff;
  position:relative;
  overflow:hidden;
}
.btn::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(255,255,255,.15),transparent 60%);
  pointer-events:none;
}
.btn:active{transform:scale(0.94)}
.btn:disabled{opacity:.45;pointer-events:none}
.btn:hover{
  transform:translateY(-2px) scale(1.01);
  box-shadow:0 6px 28px rgba(0,0,0,.4);
}
.btn-green{background:linear-gradient(135deg,#059669,#34d399);box-shadow:0 3px 16px rgba(52,211,153,.25)}
.btn-red{background:linear-gradient(135deg,#be123c,#fb7185);box-shadow:0 3px 16px rgba(251,113,133,.25)}
.btn-amber{background:linear-gradient(135deg,#b45309,#fbbf24);color:#0a0a0a;box-shadow:0 3px 16px rgba(251,191,36,.25)}

/* ---------- Controls: Power Toggle ---------- */
.power-toggle{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding-top:6px}
.power-opt{
  display:flex;align-items:center;justify-content:center;gap:10px;
  min-height:56px;
  border:0.5px solid var(--border);border-radius:var(--r-sm);
  background:var(--surface);color:var(--text2);
  font-family:var(--font);
  font-size:13.5px;font-weight:700;
  cursor:pointer;transition:all .3s var(--ease-smooth);
  -webkit-tap-highlight-color:transparent;
  position:relative;
  overflow:hidden;
}
.power-opt:active{transform:scale(0.96)}
.power-opt:hover{border-color:var(--border-h);color:var(--text)}
.power-opt.active{
  background:linear-gradient(135deg,var(--primary-dim),var(--primary));
  border-color:transparent;
  color:#fff;
  box-shadow:0 0 24px var(--primary-glow),inset 0 1px 0 rgba(255,255,255,.2);
}

/* ---------- System: Stat Cards ---------- */
.stat-card{
  padding:20px;
  display:flex;flex-direction:column;gap:12px;
  border-radius:var(--r-sm);
  position:relative;
}
.stat-top{display:flex;align-items:center;justify-content:space-between}
.stat-icon{
  width:40px;height:40px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
  transition:transform .35s var(--ease-spring);
}
.stat-card:hover .stat-icon{transform:scale(1.12) rotate(5deg)}
.stat-icon.blue{background:var(--blue-bg);color:var(--blue)}
.stat-icon.green{background:var(--green-bg);color:var(--green)}
.stat-icon.orange{background:var(--orange-bg);color:var(--orange)}
.stat-icon.purple{background:var(--purple-bg);color:var(--purple)}
.stat-val{
  font-family:var(--mono);
  font-size:24px;
  font-weight:800;
  letter-spacing:-0.6px;
}
.stat-bar{
  height:7px;
  border-radius:4px;
  background:rgba(255,255,255,.08);
  overflow:hidden;
  position:relative;
}
.stat-fill{
  height:100%;
  border-radius:4px;
  transition:width .9s var(--ease-smooth);
  position:relative;
}
.stat-fill::after{
  content:'';
  position:absolute;
  right:0;top:0;bottom:0;
  width:28px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.25));
  border-radius:0 4px 4px 0;
}
.stat-fill.blue{background:linear-gradient(90deg,rgba(96,165,250,.65),var(--blue))}
.stat-fill.green{background:linear-gradient(90deg,rgba(52,211,153,.65),var(--green))}
.stat-fill.orange{background:linear-gradient(90deg,rgba(251,146,60,.65),var(--orange))}
.stat-fill.purple{background:linear-gradient(90deg,rgba(167,139,250,.65),var(--purple))}
.stat-label{
  font-size:11px;
  font-weight:700;
  color:var(--text3);
  text-transform:uppercase;
  letter-spacing:.8px;
}
.stat-sub{
  font-weight:600;text-transform:none;letter-spacing:0;
  color:var(--text3);font-size:10px;margin-left:5px;
}

/* ---------- Storage ---------- */
.disk-row{
  display:flex;align-items:center;gap:16px;
  padding:14px 0;
  border-bottom:0.5px solid var(--border);
  transition:background .25s,padding .25s;
}
.disk-row:last-child{border-bottom:none}
.disk-row:hover{background:var(--surface);margin:0 -10px;padding:14px 10px;border-radius:var(--r-xs)}
.disk-letter{
  font-family:var(--mono);
  font-size:14px;font-weight:800;color:var(--text);
  width:40px;height:40px;border-radius:11px;
  background:linear-gradient(135deg,var(--surface2),var(--surface));
  border:0.5px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.disk-info{flex:1;min-width:0}
.disk-name{font-size:13.5px;font-weight:700;color:var(--text)}
.disk-meta{font-size:11px;color:var(--text3);margin-top:4px}
.disk-bar{height:6px;border-radius:3px;background:rgba(255,255,255,.08);margin-top:7px;overflow:hidden}
.disk-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--primary-dim),var(--primary));transition:width .9s var(--ease-smooth)}
.disk-fill.warn{background:linear-gradient(90deg,#92400e,var(--amber))}
.disk-fill.crit{background:linear-gradient(90deg,var(--red-dim),var(--red))}
.disk-pct{
  font-family:var(--mono);
  font-size:13.5px;font-weight:800;
  color:var(--text2);min-width:48px;text-align:right;
}

/* ---------- Network ---------- */
.net-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 0;
  border-bottom:0.5px solid var(--border);
  font-size:13px;
}
.net-row:last-child{border-bottom:none}
.net-key{color:var(--text3);font-weight:600}
.net-val{
  font-family:var(--mono);
  color:var(--text);font-weight:700;
  text-align:right;word-break:break-all;
  font-size:12px;
}

/* ---------- Processes ---------- */
.proc-row{
  padding:11px 0;
  border-bottom:0.5px solid var(--border);
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:background .2s,padding .2s;
}
.proc-row:last-child{border-bottom:none}
.proc-row:hover{background:var(--surface);margin:0 -10px;padding:11px 10px;border-radius:var(--r-xs)}
.proc-name{font-size:13.5px;font-weight:700;color:var(--text)}
.proc-stats{
  font-family:var(--mono);
  font-size:11px;
  color:var(--text3);
  display:flex;gap:16px;
}

/* ---------- Sessions ---------- */
.sess-item{
  padding:16px;
  border-radius:var(--r-sm);
  background:var(--surface);
  border:0.5px solid var(--border);
  margin-bottom:12px;
  transition:all .3s var(--ease-smooth);
}
.sess-item:hover{
  border-color:var(--border-h);
  transform:translateY(-2px);
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.sess-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.sess-key{
  font-family:var(--mono);
  font-size:11px;
  color:var(--text2);
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  max-width:65%;
}
.sess-kind{
  font-family:var(--mono);
  font-size:10px;font-weight:800;text-transform:uppercase;
  padding:4px 10px;border-radius:6px;
  background:var(--primary-bg);color:var(--primary);
  letter-spacing:.4px;
}
.sess-meta{
  font-size:11px;color:var(--text3);
  display:flex;gap:14px;margin-bottom:9px;
}
.sess-bar{height:5px;border-radius:3px;background:rgba(255,255,255,.08);overflow:hidden}
.sess-fill{height:100%;border-radius:3px;background:var(--primary);transition:width .9s var(--ease-smooth)}
.sess-fill.warn{background:var(--amber)}
.sess-fill.crit{background:var(--red)}
.sess-tokens{
  font-family:var(--mono);
  font-size:11px;color:var(--text3);
  margin-top:7px;text-align:right;
}

/* ---------- Cron Jobs ---------- */
.cron-summary{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;
  margin-bottom:24px;
}
.cron-stat{
  padding:16px;border-radius:var(--r-sm);text-align:center;
  background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:0.5px solid var(--border);
}
.cron-stat-val{font-family:var(--mono);font-size:28px;font-weight:800;letter-spacing:-1px}
.cron-stat-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);margin-top:4px}
.cron-stat.active .cron-stat-val{color:var(--green)}
.cron-stat.errors .cron-stat-val{color:var(--red)}
.cron-stat.pending .cron-stat-val{color:var(--primary)}
.cron-stat.disabled .cron-stat-val{color:var(--text4)}

.cron-category{margin-bottom:28px}
.cron-cat-header{
  display:flex;align-items:center;gap:12px;
  margin-bottom:14px;padding-bottom:10px;
  border-bottom:0.5px solid var(--border);
}
.cron-cat-icon{
  width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.cron-cat-icon.briefs{background:var(--amber-bg)}
.cron-cat-icon.scans{background:var(--cyan-bg)}
.cron-cat-icon.email{background:var(--blue-bg)}
.cron-cat-icon.dashboard{background:var(--green-bg)}
.cron-cat-icon.think{background:var(--purple-bg)}
.cron-cat-icon.reminders{background:var(--orange-bg)}
.cron-cat-icon.other{background:var(--surface2)}
.cron-cat-title{
  font-size:14px;font-weight:800;color:var(--text);
  flex:1;display:flex;align-items:center;gap:8px;
}
.cron-cat-count{
  font-family:var(--mono);font-size:11px;font-weight:700;
  color:var(--text3);padding:3px 9px;border-radius:6px;
  background:var(--surface);
}

.cron-list{display:grid;gap:10px}
.cron-card{
  padding:16px 18px;border-radius:var(--r-sm);
  display:flex;align-items:center;gap:14px;
  transition:all .3s var(--ease-smooth);
  position:relative;overflow:hidden;
}
.cron-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  border-radius:0 2px 2px 0;
  background:var(--primary);opacity:.4;transition:opacity .3s;
}
.cron-card:hover{transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,0,0,.25)}
.cron-card:hover::before{opacity:1}
.cron-card.status-ok::before{background:var(--green)}
.cron-card.status-error::before{background:var(--red)}
.cron-card.disabled{opacity:.45}

.cron-card-dot{
  width:8px;height:8px;border-radius:50%;flex-shrink:0;
  background:var(--text4);
}
.cron-card-dot.ok{background:var(--green);box-shadow:0 0 6px rgba(52,211,153,.4)}
.cron-card-dot.error{background:var(--red);box-shadow:0 0 6px rgba(251,113,133,.4);animation:pulse-red 2s ease infinite}
.cron-card-dot.pending{background:var(--primary);box-shadow:0 0 6px var(--primary-glow)}

.cron-card-left{flex:1;min-width:0}
.cron-name{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:3px;display:flex;align-items:center;gap:8px}
.cron-model-badge{
  font-family:var(--mono);font-size:9px;font-weight:700;
  padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px;
}
.cron-model-badge.gemini{background:rgba(66,133,244,.15);color:#4285f4}
.cron-model-badge.sonnet{background:rgba(167,139,250,.15);color:var(--purple)}
.cron-model-badge.opus{background:rgba(251,191,36,.15);color:var(--amber)}
.cron-model-badge.free{background:var(--green-bg);color:var(--green)}
.cron-schedule{font-family:var(--mono);font-size:11px;color:var(--text3)}

.cron-card-right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.cron-next{font-family:var(--mono);font-size:11px;color:var(--primary);font-weight:600}
.cron-countdown{font-family:var(--mono);font-size:10px;color:var(--text3)}
.cron-status-badge{
  font-size:9px;font-weight:800;text-transform:uppercase;
  padding:3px 8px;border-radius:5px;display:inline-block;letter-spacing:.4px;
}
.cron-status-badge.ok{background:var(--green-bg);color:var(--green)}
.cron-status-badge.error{background:var(--red-bg);color:var(--red)}

/* ---------- Chat ---------- */
.chat-card{
  display:flex;flex-direction:column;
  padding:0;overflow:hidden;
  min-height:480px;
  border-radius:var(--r);
}
.chat-messages{
  flex:1;min-height:300px;max-height:540px;
  overflow-y:auto;padding:20px 24px;
  -webkit-overflow-scrolling:touch;
}
.chat-empty{
  color:var(--text3);font-size:13.5px;text-align:center;
  padding:48px 0;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.chat-empty::before{
  content:'⚡';
  font-size:36px;
  opacity:.6;
}
.chat-msg{
  font-size:13.5px;padding:9px 0;
  border-bottom:0.5px solid rgba(255,255,255,.04);
  word-break:break-word;
  display:flex;
  align-items:flex-start;
  gap:10px;
  animation:chatFadeIn .35s var(--ease-smooth);
}
@keyframes chatFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.chat-msg:last-child{border-bottom:none}
.chat-ts{
  font-family:var(--mono);
  font-size:10px;
  color:var(--text4);
  flex-shrink:0;
  padding-top:2px;
}
.chat-arrow{color:var(--primary);flex-shrink:0;font-size:12px;padding-top:1px}
.chat-text{color:var(--text);flex:1}
.chat-form{
  display:flex;gap:12px;
  padding:16px 20px;
  border-top:0.5px solid var(--border);
  background:rgba(255,255,255,.03);
}
.chat-input{
  flex:1;min-height:48px;
  border:0.5px solid var(--border);border-radius:var(--r-sm);
  background:var(--surface);color:var(--text);
  padding:0 18px;
  font-family:var(--font);
  font-size:14px;
  outline:none;transition:all .3s var(--ease-smooth);
  -webkit-appearance:none;
}
.chat-input::placeholder{color:var(--text3)}
.chat-input:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-bg);
}
.chat-send{
  width:48px;height:48px;flex-shrink:0;
  border:none;border-radius:var(--r-sm);
  background:linear-gradient(135deg,var(--primary-dim),var(--primary));
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .25s var(--ease-smooth);
  box-shadow:0 3px 16px rgba(99,102,241,.25);
}
.chat-send:hover{transform:translateY(-2px);box-shadow:0 5px 20px rgba(99,102,241,.35)}
.chat-send:active{transform:scale(0.95)}

/* ---------- Toast ---------- */
.toast{
  position:fixed;
  bottom:calc(28px + var(--safe-b));
  left:24px;right:24px;
  max-width:500px;
  margin:0 auto;
  padding:16px 24px;
  border-radius:var(--r-sm);
  font-family:var(--font);
  font-size:13.5px;font-weight:700;
  text-align:center;
  z-index:999;
  transform:translateY(140%);
  opacity:0;
  transition:transform .5s var(--ease-spring),opacity .5s var(--ease-smooth);
  pointer-events:none;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  box-shadow:0 8px 32px rgba(0,0,0,.5);
}
.toast.show{transform:translateY(0);opacity:1;pointer-events:auto}
.toast.success{background:rgba(5,150,105,.18);color:var(--green);border:0.5px solid rgba(52,211,153,.2)}
.toast.error{background:rgba(190,18,60,.18);color:var(--red);border:0.5px solid rgba(251,113,133,.2)}
.toast.warn{background:rgba(180,83,9,.18);color:var(--amber);border:0.5px solid rgba(251,191,36,.2)}
.toast.info{background:rgba(99,102,241,.15);color:var(--primary);border:0.5px solid rgba(129,140,248,.2)}

/* ---------- Placeholder / Skeleton ---------- */
.placeholder{
  text-align:center;padding:28px 0;
  color:var(--text4);font-size:13.5px;
  font-weight:600;
}
.skeleton{
  background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);
  background-size:200% 100%;
  animation:skeleton-shimmer 1.8s ease-in-out infinite;
  border-radius:var(--r-xs);
}
@keyframes skeleton-shimmer{
  0%{background-position:200% 0}
  100%{background-position:-200% 0}
}
.skeleton-line{height:15px;margin-bottom:9px;border-radius:5px}
.skeleton-line:last-child{width:65%}

/* ---------- Utility ---------- */
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.text-amber{color:var(--amber)}
.text-primary{color:var(--primary)}
.text-mono{font-family:var(--mono)}

/* ---------- Loading Spinner ---------- */
.spinner{
  width:32px;height:32px;
  border:3px solid var(--surface2);
  border-top-color:var(--primary);
  border-radius:50%;
  animation:spin 0.8s linear infinite;
  margin:24px auto;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Responsive: Tablet+ ---------- */
@media(min-width:600px){
  .content{padding:28px 32px 120px}
  .stats-grid{grid-template-columns:repeat(4,1fr)}
  .dashboard-grid{grid-template-columns:repeat(2,1fr)}
  .chat-messages{max-height:580px}
}

/* ---------- Responsive: Desktop ---------- */
@media(min-width:900px){
  :root{--max-w:1080px}
  .header-inner,.tabs-inner{padding:0 32px}
  .content{padding:32px 40px 120px}
  .card{margin-bottom:22px;padding:28px}
  .gateway-row{gap:18px}
  .stats-grid{gap:18px}
  .status-board{padding:32px}
  .stat-card-mini:hover{transform:translateY(-4px) scale(1.03)}
}

/* ---------- Responsive: Large Desktop ---------- */
@media(min-width:1200px){
  :root{--max-w:1160px}
}

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.16)}

/* ---------- Accessibility ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    transition-duration:0.01ms!important;
  }
}

/* ---------- Focus ---------- */
button:focus-visible,input:focus-visible{
  outline:2px solid var(--primary);
  outline-offset:3px;
}

/* ---------- Email Badge (header) ---------- */
.email-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;
  padding:5px 12px;
  border-radius:22px;
  background:var(--red-bg);
  color:var(--red);
  cursor:pointer;
  transition:all .25s var(--ease-smooth);
  border:0.5px solid rgba(251,113,133,.18);
}
.email-badge:hover{background:rgba(251,113,133,.18);transform:scale(1.05)}

/* ---------- Weather Details ---------- */
.weather-details{
  display:flex;flex-wrap:wrap;gap:14px;
  font-size:12px;color:var(--text3);
  margin-top:10px;padding-top:10px;
  border-top:0.5px solid var(--border);
}

/* ---------- Forecast ---------- */
.forecast-row{
  display:flex;gap:10px;
  margin-top:16px;padding-top:16px;
  border-top:0.5px solid var(--border);
  overflow-x:auto;
}
.forecast-day{
  flex:1;min-width:76px;
  text-align:center;
  padding:12px 7px;
  border-radius:var(--r-xs);
  background:var(--surface);
  border:0.5px solid var(--border);
  transition:all .3s var(--ease-smooth);
}
.forecast-day:hover{
  border-color:var(--border-h);
  transform:translateY(-2px);
}
.forecast-name{font-size:11px;font-weight:800;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px}
.forecast-icon{font-size:24px;margin:5px 0}
.forecast-temps{display:flex;justify-content:center;gap:7px;font-family:var(--mono);font-size:12px;margin-top:5px}
.forecast-high{color:var(--text);font-weight:800}
.forecast-low{color:var(--text3)}
.forecast-rain{font-size:10px;color:var(--text3);margin-top:5px}

/* ---------- Markets Tab ---------- */
.market-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.market-card-full{padding:20px;border-radius:var(--r-sm)}
.mcf-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.mcf-icon{font-size:22px}
.mcf-name{font-size:14.5px;font-weight:800;flex:1}
.mcf-price{font-family:var(--mono);font-size:28px;font-weight:900;letter-spacing:-0.7px;margin-bottom:7px}
.mcf-details{display:flex;gap:16px;font-size:11px;color:var(--text3)}
.market-updated{text-align:center;font-size:11px;color:var(--text4);margin-top:14px}
.market-error{
  text-align:center;
  padding:32px;
  color:var(--text4);
  font-size:13px;
  font-weight:600;
}
.market-error::before{
  content:'⚠️';
  display:block;
  font-size:32px;
  margin-bottom:12px;
  opacity:.5;
}

/* ---------- Email — Preview (dashboard) ---------- */
.email-row{
  padding:9px 0;
  border-bottom:0.5px solid var(--border);
  cursor:pointer;
  transition:background .2s,padding .2s;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
}
.email-row:last-child{border-bottom:none}
.email-row:hover{background:var(--surface);margin:0 -10px;padding:9px 10px;border-radius:var(--r-xs)}
.email-row.unread .email-from,.email-row.unread .email-subject-line{font-weight:800;color:var(--text)}
.email-from{font-size:12px;color:var(--text2);min-width:110px;flex-shrink:0}
.email-subject-line{font-size:12px;color:var(--text3);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.email-date{font-family:var(--mono);font-size:10px;color:var(--text4);flex-shrink:0}
.email-more{
  text-align:center;padding:9px;margin-top:5px;
  font-size:12px;font-weight:700;color:var(--primary);
  cursor:pointer;border-radius:var(--r-xs);transition:background .2s;
}
.email-more:hover{background:var(--primary-bg)}

/* ---------- Email — Full List ---------- */
.email-item{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 14px;gap:14px;
  border-bottom:0.5px solid var(--border);
  cursor:pointer;transition:all .2s var(--ease-smooth);
  border-radius:0;
}
.email-item:hover{background:var(--surface);border-radius:var(--r-xs);transform:translateX(2px)}
.email-item.unread{background:rgba(99,102,241,.06)}
.email-item.unread .email-item-from,.email-item.unread .email-item-subject{font-weight:800;color:var(--text)}
.email-item-left{display:flex;align-items:center;gap:14px;flex:1;min-width:0}
.email-avatar{
  width:38px;height:38px;border-radius:11px;
  background:linear-gradient(135deg,var(--primary-bg),var(--purple-bg));
  color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;flex-shrink:0;
}
.email-item-info{flex:1;min-width:0}
.email-item-from{font-size:13.5px;color:var(--text2);margin-bottom:3px}
.email-item-subject{font-size:13.5px;color:var(--text3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.email-item-addr{font-size:10px;color:var(--text4);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.email-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}
.email-item-date{font-family:var(--mono);font-size:11px;color:var(--text3)}
.email-attach{font-size:12px}
.email-unread-dot{
  width:9px;height:9px;border-radius:50%;
  background:var(--primary);
  box-shadow:0 0 8px var(--primary-glow);
  animation:pulse-green 2.5s ease-in-out infinite;
}

/* ---------- Email — Reader ---------- */
.email-reader{margin-top:18px}
.email-reader-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.email-back{
  background:var(--surface);border:0.5px solid var(--border);
  color:var(--text2);padding:7px 16px;border-radius:var(--r-xs);
  font-family:var(--font);font-size:13px;font-weight:700;
  cursor:pointer;transition:all .2s var(--ease-smooth);
}
.email-back:hover{border-color:var(--border-h);color:var(--text);transform:translateX(-2px)}
.email-back:active{transform:scale(0.96)}
.email-subject{font-size:17px;font-weight:800;color:var(--text)}
.email-reader-meta{font-size:12px;color:var(--text3);margin-bottom:18px;padding-bottom:14px;border-bottom:0.5px solid var(--border)}
.email-reader-body{overflow-x:auto}
.email-content{
  font-family:var(--font);font-size:13.5px;line-height:1.75;
  color:var(--text2);white-space:pre-wrap;word-break:break-word;
}

/* ---------- Refresh Button ---------- */
.refresh-btn{
  background:var(--surface);border:0.5px solid var(--border);
  color:var(--text2);padding:3px 10px;border-radius:6px;
  font-size:14px;cursor:pointer;transition:all .3s var(--ease-smooth);
  margin-left:auto;
}
.refresh-btn:hover{
  border-color:var(--border-h);
  color:var(--text);
  transform:rotate(180deg);
}

/* ---------- Selection ---------- */
::selection{
  background:rgba(99,102,241,.35);
  color:var(--text);
}

/* ---------- Pull-to-refresh feel (visual only) ---------- */
@media(max-width:900px){
  body{overscroll-behavior-y:contain}
}
