/* ═══════════════════════════════════════════════════════════════════════════
   ArtAV Monitor — Material You Design System
   Based on Google Material Design 3 principles
   ═══════════════════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* ── Material You Design Tokens (Light) ─────────────────────────────────── */
  --m3-primary: #6366F1;
  --m3-primary-hover: #4F46E5;
  --m3-primary-container: #EEF2FF;
  --m3-secondary: #818CF8;
  --m3-secondary-container: #E8EAFC;
  --m3-tertiary: #0EA5E9;
  --m3-tertiary-container: #E0F2FE;
  --m3-surface: #FFFFFF;
  --m3-surface-variant: #F5F5F7;
  --m3-surface-container: #FAFAFA;
  --m3-surface-container-high: #F0F0F2;
  --m3-surface-bright: #FFFFFF;
  --m3-outline: #CAC4D0;
  --m3-outline-variant: #E7E0EC;
  --m3-shadow: rgba(0,0,0,0.08);
  --m3-shadow-raised: 0 2px 8px rgba(0,0,0,0.08), 0 4px 16px rgba(0,0,0,0.04);
  --m3-radius-xl: 28px;
  --m3-radius-lg: 20px;
  --m3-radius-md: 12px;
  --m3-radius-sm: 8px;
  --m3-radius-full: 9999px;
  --m3-transition: 150ms ease;
  --m3-elevation-1: 0 1px 2px rgba(0,0,0,0.05), 0 1px 4px rgba(0,0,0,0.04);
  --m3-elevation-2: 0 2px 4px rgba(0,0,0,0.06), 0 4px 8px rgba(0,0,0,0.04);
  --m3-elevation-3: 0 4px 8px rgba(0,0,0,0.08), 0 8px 16px rgba(0,0,0,0.04);
  --m3-elevation-4: 0 8px 16px rgba(0,0,0,0.10), 0 16px 32px rgba(0,0,0,0.06);

  /* ── Legacy Tokens (mapped to M3 for compatibility) ─────────────────────── */
  --bg:#F5F5F7;
  --sur:#FFFFFF;
  --sur2:#F3F4F6;
  --bdr:#E0E0E0;
  --bdr2:#BDBDBD;
  --blue:#6366F1;
  --blue-h:#4F46E5;
  --blue-d:#EEF2FF;
  --green:#16A34A;
  --green-d:#DCFCE7;
  --red:#DC2626;
  --red-d:#FEE2E2;
  --amber:#D97706;
  --amber-d:#FEF3C7;
  --orange:#EA580C;
  --orange-d:#FFEDD5;
  --text:#1F2937;
  --text2:#4B5563;
  --text3:#9CA3AF;
  --sh:var(--m3-elevation-1);
  --sh2:var(--m3-elevation-2);
  --sh3:var(--m3-elevation-3);
  --r:var(--m3-radius-sm);
  --rl:var(--m3-radius-md);
  --rxl:var(--m3-radius-lg);
  --sans:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono','Courier New',monospace;
  --hh:60px;
  --sw:240px;
}
[data-theme=dark]{
  --m3-primary: #818CF8;
  --m3-primary-hover: #A5B4FC;
  --m3-primary-container: #312E81;
  --m3-secondary: #A5B4FC;
  --m3-secondary-container: #3730A3;
  --m3-tertiary: #38BDF8;
  --m3-tertiary-container: #0C4A6E;
  --m3-surface: #1C1B1F;
  --m3-surface-variant: #2B2930;
  --m3-surface-container: #211F26;
  --m3-surface-container-high: #2A2730;
  --m3-surface-bright: #2B2930;
  --m3-outline: #938F99;
  --m3-outline-variant: #49454F;
  --m3-shadow: rgba(0,0,0,0.30);
  --m3-shadow-raised: 0 2px 8px rgba(0,0,0,0.30), 0 4px 16px rgba(0,0,0,0.20);

  --bg:#121212;
  --sur:#1C1B1F;
  --sur2:#2B2930;
  --bdr:#49454F;
  --bdr2:#625D67;
  --blue:#818CF8;
  --blue-h:#A5B4FC;
  --blue-d:#312E81;
  --green:#4ADE80;
  --green-d:#166534;
  --red:#F87171;
  --red-d:#7F1D1D;
  --amber:#FBBF24;
  --amber-d:#78350F;
  --text:#F9FAFB;
  --text2:#D1D5DB;
  --text3:#9CA3AF;
  --sh:0 1px 3px rgba(0,0,0,0.4);
  --sh2:0 4px 8px rgba(0,0,0,0.3);
  --sh3:0 10px 25px rgba(0,0,0,0.5);
}

body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh;transition:background .2s,color .2s}
a{color:var(--m3-primary);text-decoration:none}a:hover{text-decoration:underline}

/* ── HEADER ──────────────────────────────────────────────────────────────── */
.topbar{height:var(--hh);background:var(--m3-surface);border-bottom:1px solid var(--m3-outline-variant);display:flex;align-items:center;padding:0 20px;gap:12px;position:sticky;top:0;z-index:100;box-shadow:var(--m3-elevation-1)}
.topbar-logo img{height:30px;width:auto;display:block}
[data-theme=dark] .topbar-logo img:not([src*="ArtAV_OOB"]){filter:brightness(0) invert(1)}
.topbar-logo-text{font-size:.95rem;font-weight:700;color:var(--text)}
.topbar-sep{width:1px;height:20px;background:var(--m3-outline-variant)}
.live-pill{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:.7rem;color:var(--text2);background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant);border-radius:20px;padding:4px 12px}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--text3);flex-shrink:0;transition:all .4s}
.live-dot.on{background:var(--green);box-shadow:0 0 0 3px var(--green-d)}
.topbar-r{margin-left:auto;display:flex;align-items:center;gap:8px}
.role-badge{font-size:.7rem;font-weight:500;padding:3px 10px;border-radius:var(--m3-radius-full);font-family:var(--mono)}
.role-badge.admin{background:var(--m3-primary-container);color:var(--m3-primary)}
.role-badge.technician{background:var(--amber-d);color:var(--amber)}
.role-badge.client{background:var(--green-d);color:var(--green)}

/* ── LAYOUT ─────────────────────────────────────────────────────────────── */
.app-layout{display:flex;height:calc(100vh - var(--hh))}

/* ── SIDEBAR ────────────────────────────────────────────────────────────── */
.sidebar{width:var(--sw);background:var(--m3-surface);border-right:1px solid var(--m3-outline-variant);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}
.nav-group{font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text3);padding:16px 14px 6px}
.nav-link{display:flex;align-items:center;gap:9px;margin:2px 8px;padding:10px 12px;border-radius:var(--m3-radius-md);color:var(--text2);font-size:.84rem;font-weight:500;width:calc(100% - 16px);text-decoration:none;transition:all var(--m3-transition)}
.nav-link:hover{background:var(--m3-surface-variant);color:var(--text);text-decoration:none}
.nav-link.active{background:var(--m3-primary-container);color:var(--m3-primary)}
.nav-link .ni{font-size:18px;width:20px;text-align:center;flex-shrink:0}
.nav-link.active .ni{opacity:1}
.nav-badge{margin-left:auto;font-family:var(--mono);font-size:.65rem;padding:2px 8px;border-radius:var(--m3-radius-full);background:var(--m3-surface-variant);color:var(--text3)}
.nav-link.active .nav-badge{background:var(--m3-primary);color:white}
.sidebar-stats{padding:10px 16px;margin-top:4px}
.sstat{display:flex;justify-content:space-between;padding:4px 0;font-size:.75rem}
.sstat span:first-child{color:var(--text3)}.sstat .sv{font-family:var(--mono);font-weight:600}
.sv.on{color:var(--green)}.sv.off{color:var(--red)}
.sidebar-foot{margin-top:auto;padding:12px 16px;border-top:1px solid var(--m3-outline-variant);font-size:.72rem;color:var(--text3)}

/* ── MAIN ───────────────────────────────────────────────────────────────── */
.main-content{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px}

/* ── PAGE HEADER ───────────────────────────────────────────────────────── */
.page-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.page-hd h1{font-size:1.35rem;font-weight:700;letter-spacing:-.02em}
.page-hd .sub{font-size:.82rem;color:var(--text2);margin-top:4px}
.page-hd-r{display:flex;gap:10px;align-items:center;flex-shrink:0}

/* ── BUTTONS (Material You) ───────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:500;font-size:.875rem;padding:10px 20px;border-radius:var(--m3-radius-md);border:1px solid transparent;background:var(--m3-surface-variant);color:var(--text);cursor:pointer;transition:all var(--m3-transition);white-space:nowrap;text-decoration:none;line-height:1.4}
.btn:hover{background:var(--m3-surface-container-high);text-decoration:none}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--m3-primary);color:#fff;box-shadow:0 2px 8px rgba(99,102,241,.25)}
.btn-primary:hover{background:var(--m3-primary-hover);box-shadow:0 4px 12px rgba(99,102,241,.3)}
.btn-secondary{background:var(--m3-secondary-container);color:var(--m3-primary)}
.btn-secondary:hover{background:var(--m3-primary-container)}
.btn-ghost{background:transparent;color:var(--text2)}
.btn-ghost:hover{background:var(--m3-surface-variant);color:var(--text)}
.btn-danger{background:var(--red-d);color:var(--red);border-color:var(--red)}
.btn-danger:hover{background:#FECACA}
.btn-success{background:var(--green-d);color:var(--green);border-color:var(--green)}
.btn-success:hover{background:#BBF7D0}
.btn-warning{background:var(--amber-d);color:var(--amber);border-color:var(--amber)}
.btn-warning:hover{background:#FDE68A}
.btn-sm{font-size:.8rem;padding:6px 14px;border-radius:var(--m3-radius-sm)}
.btn-icon{width:36px;height:36px;padding:0;justify-content:center;border-radius:var(--m3-radius-md);font-size:18px}

/* M3 button aliases for compatibility with redesigned HTML files */
.m3-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:500;font-size:.875rem;padding:10px 20px;border-radius:var(--m3-radius-md);border:1px solid transparent;background:var(--m3-surface-variant);color:var(--text);cursor:pointer;transition:all var(--m3-transition);white-space:nowrap;text-decoration:none;line-height:1.4}
.m3-btn-primary{background:var(--m3-primary);color:#fff;box-shadow:0 2px 8px rgba(99,102,241,.25)}
.m3-btn-primary:hover{background:var(--m3-primary-hover);box-shadow:0 4px 12px rgba(99,102,241,.3)}
.m3-btn-secondary{background:var(--m3-secondary-container);color:var(--m3-primary);border:1px solid var(--m3-outline)}
.m3-btn-secondary:hover{background:var(--m3-primary-container)}
.m3-btn-ghost{background:transparent;color:var(--text2)}
.m3-btn-ghost:hover{background:var(--m3-surface-variant);color:var(--text)}
.m3-btn-danger{background:var(--red-d);color:var(--red)}
.m3-btn-danger:hover{background:#FECACA}
.m3-btn-success{background:var(--green-d);color:var(--green)}
.m3-btn-success:hover{background:#BBF7D0}
.m3-btn-warning{background:var(--amber-d);color:var(--amber)}
.m3-btn-warning:hover{background:#FDE68A}
.m3-btn-sm{font-size:.8rem;padding:6px 14px;border-radius:var(--m3-radius-sm)}

.material-icons{font-family:'Material Icons';font-weight:400;font-style:normal;font-size:20px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}

/* ── CARDS (Material You) ──────────────────────────────────────────────── */
.card{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);box-shadow:var(--m3-elevation-1);overflow:hidden}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--m3-outline-variant)}
.card-header h2,.card-header h3{font-size:.9rem;font-weight:600}
.card-body{padding:20px}
.card-meta{font-size:.75rem;color:var(--text2);font-family:var(--mono)}

/* Material You card variants */
.m3-card{background:var(--m3-surface);border-radius:var(--m3-radius-lg);box-shadow:var(--m3-elevation-2);border:1px solid var(--m3-outline-variant);padding:24px}
.m3-card:hover{box-shadow:var(--m3-elevation-3)}
.m3-card-elevated{background:var(--m3-surface);border-radius:var(--m3-radius-lg);box-shadow:var(--m3-elevation-3);border:none}
.m3-card-filled{background:var(--m3-surface-variant);border-radius:var(--m3-radius-lg);border:none}
.m3-card-outlined{background:var(--m3-surface);border-radius:var(--m3-radius-lg);border:1px solid var(--m3-outline-variant)}

.m3-section-title{font-size:1.05rem;font-weight:600;color:var(--text);margin:0 0 20px 0;display:flex;align-items:center;gap:10px}
.m3-section-title .material-icons{font-size:22px;color:var(--m3-primary)}

/* ── STAT CARDS ────────────────────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.stat-card{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);padding:20px;box-shadow:var(--m3-elevation-1);transition:all var(--m3-transition)}
.stat-card:hover{box-shadow:var(--m3-elevation-2);transform:translateY(-2px)}
.stat-label{font-size:.72rem;font-weight:500;color:var(--text2);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.stat-value{font-size:2rem;font-weight:700;letter-spacing:-.04em;line-height:1}
.sv-blue{color:var(--blue)}.sv-green{color:var(--green)}.sv-red{color:var(--red)}.sv-amber{color:var(--amber)}

/* ── M3 STAT CARDS ─────────────────────────────────────────────────────── */
.m3-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.m3-stat-card{background:var(--m3-surface);border-radius:var(--m3-radius-lg);padding:20px;text-align:center;box-shadow:var(--m3-elevation-1);border:1px solid var(--m3-outline-variant);transition:all var(--m3-transition)}
.m3-stat-card:hover{box-shadow:var(--m3-elevation-2);transform:translateY(-2px)}
.m3-stat-icon{width:48px;height:48px;border-radius:var(--m3-radius-md);display:flex;align-items:center;justify-content:center;margin:0 auto 12px}
.m3-stat-icon .material-icons{font-size:24px}
.m3-stat-icon-primary{background:var(--m3-primary-container);color:var(--m3-primary)}
.m3-stat-icon-success{background:var(--green-d);color:var(--green)}
.m3-stat-icon-warning{background:var(--amber-d);color:var(--amber)}
.m3-stat-icon-error{background:var(--red-d);color:var(--red)}
.m3-stat-value{font-size:2.2rem;font-weight:700;font-family:var(--mono);color:var(--text);line-height:1.2}
.m3-stat-value.m3-stat-success{color:var(--green)}
.m3-stat-value.m3-stat-warning{color:var(--amber)}
.m3-stat-value.m3-stat-error{color:var(--red)}
.m3-stat-label{font-size:.78rem;color:var(--text3);font-weight:500;margin-top:6px}

/* ── SITE CARDS ────────────────────────────────────────────────────────── */
.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}
.site-card{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);overflow:hidden;box-shadow:var(--m3-elevation-1);transition:box-shadow .2s,border-color .2s}
.site-card:hover{box-shadow:var(--m3-elevation-2);border-color:var(--m3-outline)}
.site-card-header{padding:14px 16px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:1px solid var(--m3-outline-variant)}
.site-card-name{font-size:.9rem;font-weight:600}
.site-card-loc{font-size:.75rem;color:var(--text2);margin-top:2px}
.status-pill{font-size:.7rem;font-weight:600;padding:4px 12px;border-radius:var(--m3-radius-full);white-space:nowrap;flex-shrink:0}
.pill-ok{background:var(--green-d);color:var(--green)}
.pill-partial{background:var(--amber-d);color:var(--amber)}
.pill-offline{background:var(--red-d);color:var(--red)}
.pill-unknown{background:var(--m3-surface-variant);color:var(--text3)}

/* ── M3 CHIPS ──────────────────────────────────────────────────────────── */
.m3-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:var(--m3-radius-full);font-size:.72rem;font-weight:600;white-space:nowrap}
.m3-chip-success{background:var(--green-d);color:var(--green)}
.m3-chip-warning{background:var(--amber-d);color:var(--amber)}
.m3-chip-error{background:var(--red-d);color:var(--red)}
.m3-chip-neutral{background:var(--m3-surface-variant);color:var(--text3)}
.m3-chip-primary{background:var(--m3-primary-container);color:var(--m3-primary)}
.m3-chip .material-icons{font-size:14px}
.m3-chip-icon{font-size:14px;width:14px;height:14px}
.m3-chip.blue{background:var(--blue-d);color:var(--blue)}
.m3-chip.green{background:var(--green-d);color:var(--green)}
.m3-chip.red{background:var(--red-d);color:var(--red)}
.m3-chip.amber{background:var(--amber-d);color:var(--amber)}
.m3-stat-icon.blue{background:var(--blue-d);color:var(--blue)}
.m3-stat-icon.green{background:var(--green-d);color:var(--green)}
.m3-stat-icon.red{background:var(--red-d);color:var(--red)}
.m3-stat-icon.amber{background:var(--amber-d);color:var(--amber)}

/* ── DEVICE ROWS ───────────────────────────────────────────────────────── */
.device-list{padding:4px 0}
.device-row{display:flex;align-items:center;padding:10px 16px;gap:12px;cursor:pointer;transition:background .1s}
.device-row:hover{background:var(--m3-surface-variant)}
.dev-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot-on{background:var(--green);box-shadow:0 0 0 3px var(--green-d)}
.dot-off{background:var(--red);box-shadow:0 0 0 3px var(--red-d)}
.dot-unk{background:var(--bdr2)}
.dev-info{flex:1;min-width:0}
.dev-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dev-sub{font-size:.72rem;color:var(--text2);margin-top:2px;font-family:var(--mono)}
.dev-right{text-align:right;flex-shrink:0;font-size:.72rem}
.dev-status{font-weight:500;color:var(--text2)}
.dev-ago{color:var(--text3);margin-top:2px;font-size:.68rem}

/* ── TELE CHIPS ────────────────────────────────────────────────────────── */
.tele-row{display:flex;flex-wrap:wrap;gap:6px;padding:12px 16px;border-top:1px solid var(--m3-outline-variant)}
.tc{font-family:var(--mono);font-size:.7rem;padding:4px 10px;border-radius:6px;background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant)}
.tc .tk{color:var(--text3)}.tc .tv{color:var(--text)}
.tc .t{color:var(--green)}.tc .f{color:var(--red)}

/* ── CARD FOOTER ───────────────────────────────────────────────────────── */
.card-footer{padding:12px 16px;border-top:1px solid var(--m3-outline-variant);background:var(--m3-surface-variant);display:flex;gap:8px}

/* ── TABLE ──────────────────────────────────────────────────────────────── */
.table-wrap{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);overflow:hidden;box-shadow:var(--m3-elevation-1)}
table{width:100%;border-collapse:collapse;font-size:.82rem}
thead th{text-align:left;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);padding:12px 16px;border-bottom:1px solid var(--m3-outline-variant);background:var(--m3-surface-variant)}
td{padding:12px 16px;border-bottom:1px solid var(--m3-outline-variant);vertical-align:middle}
tr:last-child td{border-bottom:none}
tbody tr:hover td{background:var(--m3-surface-variant)}

.m3-notif-table{width:100%;border-collapse:collapse;font-size:.82rem}
.m3-notif-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--m3-outline-variant);font-weight:600;color:var(--text2)}
.m3-notif-table th:not(:first-child){text-align:center}
.m3-notif-table td{padding:10px 12px;border-bottom:1px solid var(--m3-outline-variant)}
.m3-notif-table td:not(:first-child){text-align:center}
.m3-notif-table tr:hover td{background:var(--m3-surface-variant)}

/* ── BADGES ────────────────────────────────────────────────────────────── */
.badge{font-size:.7rem;font-weight:500;padding:3px 10px;border-radius:var(--m3-radius-full);font-family:var(--mono)}
.badge-admin{background:var(--blue-d);color:var(--blue)}
.badge-technician{background:var(--amber-d);color:var(--amber)}
.badge-client{background:var(--green-d);color:var(--green)}

.vb{display:inline-block;padding:2px 8px;border-radius:6px;font-family:var(--mono);font-size:.73rem}
.vb-t{background:var(--green-d);color:var(--green)}
.vb-f{background:var(--red-d);color:var(--red)}
.vb-n{background:var(--blue-d);color:var(--blue)}
.vb-s{background:var(--sur2);color:var(--text2);border:1px solid var(--bdr)}

/* ── FORM (Material You) ───────────────────────────────────────────────── */
.form-field{margin-bottom:14px}
.form-field label{display:block;font-size:.78rem;font-weight:500;color:var(--text2);margin-bottom:6px}
.form-field input,.form-field select,.form-field textarea{width:100%;background:var(--m3-surface);border:1.5px solid var(--m3-outline);border-radius:var(--m3-radius-sm);color:var(--text);font-family:var(--sans);font-size:.875rem;padding:12px 14px;outline:none;transition:border-color var(--m3-transition),box-shadow var(--m3-transition);resize:vertical}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text3)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--m3-primary);box-shadow:0 0 0 3px var(--m3-primary-container)}
.form-field select option{background:var(--m3-surface)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}

.m3-input{width:100%;padding:12px 16px;border:1px solid var(--m3-outline);border-radius:var(--m3-radius-sm);font-size:.875rem;background:var(--m3-surface);color:var(--text);transition:border-color var(--m3-transition),box-shadow var(--m3-transition);box-sizing:border-box;font-family:inherit}
.m3-input:focus{outline:none;border-color:var(--m3-primary);box-shadow:0 0 0 3px var(--m3-primary-container)}
.m3-input::placeholder{color:var(--text3)}
.m3-select{padding:12px 40px 12px 16px;border:1px solid var(--m3-outline);border-radius:var(--m3-radius-sm);font-size:.875rem;background:var(--m3-surface);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Cpath fill='%23757575' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:20px;font-family:inherit}
.m3-select:focus{outline:none;border-color:var(--m3-primary);box-shadow:0 0 0 3px var(--m3-primary-container)}
.m3-form-field{margin-bottom:16px}
.m3-form-field label{display:block;font-size:.8rem;font-weight:500;color:var(--text2);margin-bottom:6px}
.m3-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px}
.m3-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--m3-outline-variant)}
.m3-toggle-row:last-child{border-bottom:none}
.m3-toggle-info{flex:1}
.m3-toggle-title{font-size:.9rem;font-weight:500;color:var(--text);margin-bottom:2px}
.m3-toggle-desc{font-size:.78rem;color:var(--text3)}
.m3-toggle-switch{position:relative;width:48px;height:28px;flex-shrink:0}
.m3-toggle-switch input{opacity:0;width:0;height:0}
.m3-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--m3-outline);border-radius:14px;transition:all var(--m3-transition)}
.m3-toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background:white;border-radius:50%;transition:all var(--m3-transition);box-shadow:0 2px 4px rgba(0,0,0,0.2)}
.m3-toggle-switch input:checked+.m3-toggle-slider{background:var(--m3-primary)}
.m3-toggle-switch input:checked+.m3-toggle-slider:before{transform:translateX(20px)}

/* ── TABS ──────────────────────────────────────────────────────────────── */
.tab-bar{display:flex;border-bottom:1px solid var(--m3-outline-variant);margin-bottom:20px;gap:4px;padding:4px;background:var(--m3-surface-variant);border-radius:var(--m3-radius-lg)}
.tab-btn{font-size:.875rem;font-weight:500;padding:10px 20px;border:none;background:transparent;color:var(--text2);cursor:pointer;border-radius:var(--m3-radius-md);transition:all var(--m3-transition);display:flex;align-items:center;gap:8px}
.tab-btn:hover{background:var(--m3-surface-container-high);color:var(--text)}
.tab-btn.active{background:var(--m3-surface);color:var(--m3-primary);box-shadow:var(--m3-elevation-1)}
.tab-panel{display:none}.tab-panel.active{display:block}

.m3-tab-bar{display:flex;gap:4px;background:var(--m3-surface-variant);padding:6px;border-radius:var(--m3-radius-lg);margin-bottom:28px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.m3-tab-btn{padding:10px 20px;border:none;background:transparent;border-radius:var(--m3-radius-md);font-size:.875rem;font-weight:500;color:var(--text2);cursor:pointer;transition:all var(--m3-transition);white-space:nowrap;display:flex;align-items:center;gap:8px;font-family:inherit}
.m3-tab-btn:hover{background:var(--m3-surface-container-high);color:var(--text)}
.m3-tab-btn.active{background:var(--m3-surface);color:var(--m3-primary);box-shadow:var(--m3-elevation-1)}
.m3-tab-btn .material-icons{font-size:18px}

/* ── MODAL (Material You) ──────────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
[data-theme=dark] .modal-overlay{background:rgba(0,0,0,.6)}
.modal-overlay.open{display:flex}
.modal{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-xl);width:100%;max-width:500px;max-height:88vh;overflow-y:auto;box-shadow:var(--m3-shadow-raised);animation:mIn .25s ease}
.modal.modal-wide{max-width:680px}
@keyframes mIn{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}
.modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 0}
.modal-header h3{font-size:1.05rem;font-weight:700}
.modal-header .modal-sub{font-size:.78rem;color:var(--text2);margin-top:2px}
.modal-close{width:32px;height:32px;border-radius:var(--m3-radius-sm);border:none;background:transparent;color:var(--text3);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--m3-transition);margin-left:12px}
.modal-close:hover{background:var(--m3-surface-variant);color:var(--text)}
.modal-body{padding:20px 24px}
.modal-footer{padding:16px 24px 20px;border-top:1px solid var(--m3-outline-variant);display:flex;justify-content:flex-end;gap:10px}

/* M3 modal aliases */
.m3-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;display:none;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px)}
[data-theme=dark] .m3-modal-overlay{background:rgba(0,0,0,.6)}
.m3-modal-overlay.open{display:flex}
.m3-modal{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-xl);width:100%;max-width:500px;max-height:88vh;overflow:hidden;box-shadow:var(--m3-shadow-raised);animation:mIn .25s ease;display:flex;flex-direction:column}
.m3-modal-wide{max-width:680px}
.m3-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--m3-outline-variant)}
.m3-modal-header h3{font-size:1rem;font-weight:700}
.m3-modal-sub{font-size:.78rem;color:var(--text2);margin-top:2px}
.m3-modal-close{width:32px;height:32px;border-radius:var(--m3-radius-sm);border:none;background:transparent;color:var(--text3);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--m3-transition);margin-left:12px}
.m3-modal-close:hover{background:var(--m3-surface-variant);color:var(--text)}
.m3-modal-body{padding:20px 24px;overflow-y:auto;flex:1}
.m3-modal-footer{padding:16px 24px 20px;border-top:1px solid var(--m3-outline-variant);display:flex;justify-content:flex-end;gap:10px}
.m3-label{display:block;font-size:.8rem;font-weight:500;color:var(--text2);margin-bottom:6px}

/* ── TOASTS ────────────────────────────────────────────────────────────── */
#toasts{position:fixed;bottom:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast{font-size:.875rem;padding:12px 18px;border-radius:var(--m3-radius-md);background:var(--m3-surface);border:1px solid var(--m3-outline-variant);color:var(--text);box-shadow:var(--m3-shadow-raised);animation:tIn .3s ease;min-width:220px;pointer-events:all}
.toast-ok{background:var(--green-d);border-color:var(--green);color:var(--green)}
.toast-err{background:var(--red-d);border-color:var(--red);color:var(--red)}
@keyframes tIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}

/* ── EVENT LOG ─────────────────────────────────────────────────────────── */
.log-row{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;border-bottom:1px solid var(--m3-outline-variant);font-size:.78rem}
.log-row:hover{background:var(--m3-surface-variant)}.log-row:last-child{border-bottom:none}
.log-ts{color:var(--text3);flex-shrink:0;min-width:80px;font-family:var(--mono)}
.log-tag{padding:2px 10px;border-radius:var(--m3-radius-full);font-size:.65rem;font-weight:600;flex-shrink:0;text-transform:uppercase}
.lt-telemetry{background:var(--blue-d);color:var(--blue)}
.lt-connect{background:var(--green-d);color:var(--green)}
.lt-disconnect{background:var(--red-d);color:var(--red)}
.lt-notification{background:var(--m3-secondary-container);color:var(--m3-secondary)}
.lt-critical{background:var(--red-d);color:var(--red)}
.lt-recovery{background:var(--green-d);color:var(--green)}
.log-msg{color:var(--text2);word-break:break-all;flex:1}
.log-tag + .log-msg{margin-left:0}

/* ── SITE CHIPS ────────────────────────────────────────────────────────── */
.site-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.chip{font-size:.75rem;padding:5px 12px;border-radius:var(--m3-radius-full);background:var(--m3-surface-variant);border:1.5px solid var(--m3-outline-variant);color:var(--text2);cursor:pointer;transition:all var(--m3-transition);user-select:none}
.chip:hover{background:var(--m3-surface-container-high)}
.chip.sel{background:var(--m3-primary-container);border-color:var(--m3-primary);color:var(--m3-primary);font-weight:500}

/* ── EMPTY STATE ────────────────────────────────────────────────────────── */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center;gap:10px}
.empty-icon{font-size:2.5rem;opacity:.25}
.empty-title{font-size:.9rem;font-weight:600;color:var(--text2)}
.empty-text{font-size:.8rem;color:var(--text3);max-width:260px;line-height:1.6}

/* ── RESOURCE BARS ─────────────────────────────────────────────────────── */
.res-bar-wrap{margin-bottom:16px}
.res-bar-label{display:flex;justify-content:space-between;font-size:.78rem;margin-bottom:6px}
.res-bar-label span:first-child{font-weight:500;color:var(--text2)}
.res-bar-label span:last-child{font-family:var(--mono);color:var(--text3)}
.res-bar-track{height:8px;background:var(--m3-surface-variant);border-radius:4px;overflow:hidden}
.res-bar-fill{height:100%;border-radius:4px;transition:width .6s ease,background .4s}

.m3-progress-bar{width:100%;height:8px;background:var(--m3-surface-variant);border-radius:4px;overflow:hidden;margin:8px 0}
.m3-progress-fill{height:100%;border-radius:4px;transition:width 500ms ease}

/* ── CODE ──────────────────────────────────────────────────────────────── */
code{font-family:var(--mono);font-size:.85em;background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant);padding:2px 6px;border-radius:4px;color:var(--m3-primary)}
pre{font-family:var(--mono);font-size:.78rem;background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant);padding:14px;border-radius:var(--m3-radius-md);overflow-x:auto;color:var(--text2)}

/* ── GATEWAY ───────────────────────────────────────────────────────────── */
.gw-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--m3-outline-variant)}
.gw-item:last-child{border-bottom:none}
.gw-dot{width:10px;height:10px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px var(--green-d);flex-shrink:0}

/* ── PULSE ─────────────────────────────────────────────────────────────── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 1.5s infinite;margin-right:6px;vertical-align:middle}

/* ── INFO BOXES ────────────────────────────────────────────────────────── */
.m3-info-box{background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-md);padding:16px 20px;display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.m3-info-box .material-icons{color:var(--m3-primary);font-size:20px;flex-shrink:0;margin-top:1px}
.m3-info-box-content{font-size:.85rem;color:var(--text2);line-height:1.6}
.m3-info-box-content strong{color:var(--text)}
.m3-info-box-info{background:var(--m3-primary-container)}
.m3-info-box-info .material-icons{color:var(--m3-primary)}

/* ── USER CARDS ────────────────────────────────────────────────────────── */
.m3-user-card{background:var(--m3-surface);border-radius:var(--m3-radius-lg);padding:20px;box-shadow:var(--m3-elevation-1);border:1px solid var(--m3-outline-variant);margin-bottom:12px;transition:all var(--m3-transition)}
.m3-user-card:hover{box-shadow:var(--m3-elevation-2)}
.m3-badge-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.m3-channel-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--m3-surface-variant);border-radius:var(--m3-radius-full);font-size:.78rem;font-weight:500;color:var(--text2);cursor:pointer;transition:all var(--m3-transition);user-select:none}
.m3-channel-pill:hover{background:var(--m3-surface-container-high)}
.m3-channel-pill input{width:16px;height:16px;accent-color:var(--m3-primary)}

/* ── ACCORDION ─────────────────────────────────────────────────────────── */
.m3-accordion{background:var(--m3-surface-variant);border-radius:var(--m3-radius-md);overflow:hidden;margin-bottom:8px}
.m3-accordion-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;transition:background var(--m3-transition)}
.m3-accordion-header:hover{background:var(--m3-surface-container-high)}
.m3-accordion-title{font-size:.85rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}
.m3-accordion-title .material-icons{font-size:18px;color:var(--m3-primary)}
.m3-accordion-icon{transition:transform var(--m3-transition)}
.m3-accordion.open .m3-accordion-icon{transform:rotate(180deg)}
.m3-accordion-content{display:none;padding:0 16px 16px}
.m3-accordion.open .m3-accordion-content{display:block}

/* ── DIVIDER ───────────────────────────────────────────────────────────── */
.m3-divider{height:1px;background:var(--m3-outline-variant);margin:24px 0}

/* ── SETTINGS ──────────────────────────────────────────────────────────── */
.settings-section{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);padding:24px;margin-bottom:16px;box-shadow:var(--m3-elevation-1)}
.settings-section h3{font-size:.9rem;font-weight:600;padding-bottom:14px;margin-bottom:18px;border-bottom:1px solid var(--m3-outline-variant)}

/* ── LOG ENTRIES ───────────────────────────────────────────────────────── */
.m3-log-entry{display:flex;gap:16px;padding:12px 0;border-bottom:1px solid var(--m3-outline-variant);font-size:.82rem}
.m3-log-time{font-family:var(--mono);color:var(--text3);min-width:150px;flex-shrink:0}
.m3-log-action{font-family:var(--mono);font-weight:600;color:var(--m3-primary);min-width:120px;flex-shrink:0}
.m3-log-detail{color:var(--text2);flex:1}
.m3-log-ip{color:var(--text3);margin-left:8px}

/* ── STATUS INDICATORS ─────────────────────────────────────────────────── */
.m3-status-indicator{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--m3-radius-full);font-size:.78rem;font-weight:500}
.m3-status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.m3-status-dot.ok{background:var(--green);box-shadow:0 0 0 4px var(--green-d)}
.m3-status-dot.warning{background:var(--amber);box-shadow:0 0 0 4px var(--amber-d)}
.m3-status-dot.error{background:var(--red);box-shadow:0 0 0 4px var(--red-d)}
.m3-status-ready{background:var(--green-d);color:var(--green)}
.m3-status-warning{background:var(--amber-d);color:var(--amber)}
.m3-status-error{background:var(--red-d);color:var(--red)}
.m3-status-inactive{background:var(--m3-surface-variant);color:var(--text3)}
.m3-status-indicator .material-icons{font-size:16px}

/* ── SCROLLBAR ────────────────────────────────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--m3-outline);border-radius:3px}

/* ── MOBILE RESPONSIVE ────────────────────────────────────────────────── */
.hamburger-btn{display:none!important;margin-right:4px}
@media(max-width:768px){
  .hamburger-btn{display:flex!important}
  .sidebar{position:fixed;top:var(--hh);left:0;bottom:0;z-index:200;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--m3-shadow-raised);width:var(--sw)}
  body.sidebar-open .sidebar{transform:translateX(0)}
  body.sidebar-open::after{content:'';position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:199;pointer-events:all}

  .app-layout{display:block;height:auto}
  .main-content{padding:16px;gap:16px;min-height:calc(100vh - var(--hh))}

  .page-hd{flex-wrap:wrap;gap:10px}
  .page-hd-r{flex-wrap:wrap}

  .stats-row,.m3-stat-grid{grid-template-columns:repeat(2,1fr)}
  .sites-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .m3-form-grid{grid-template-columns:1fr}

  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{font-size:.78rem}
  thead th,td{padding:10px 12px}

  .modal-overlay{padding:10px;align-items:flex-end}
  .modal{border-radius:var(--m3-radius-lg) var(--m3-radius-lg) 0 0;max-width:100%;max-height:92vh;animation:mInMobile .25s ease}
  @keyframes mInMobile{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}

  .topbar{padding:0 12px;gap:8px}
  .topbar-logo img{height:24px}
  .topbar-sep{display:none}
  #hUser{display:none}

  .btn{padding:10px 16px;font-size:.875rem}
  .btn-sm{padding:8px 14px;font-size:.8rem;min-height:36px}
  .btn-icon{width:36px;height:36px}

  #toasts{bottom:12px;left:12px;right:12px}
  .toast{min-width:unset}

  .card-body,.settings-section{padding:16px}
  .device-row{padding:12px 16px}
  .stat-value{font-size:1.7rem}
  .m3-stat-value{font-size:1.8rem}

  [style*="grid-template-columns:repeat(4,1fr)"]{grid-template-columns:repeat(2,1fr)!important}
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns:200px 1fr"]{grid-template-columns:110px 1fr!important}
}

/* ═══════════════════════════════════════════════════════════════════════════
   M3 Aliases — ensures all HTML files using m3-prefixed class names work
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── M3 Log Rows (used by events.html) ──────────────────────────────────── */
.m3-log-row{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;border-bottom:1px solid var(--m3-outline-variant);font-size:.78rem}
.m3-log-row:hover{background:var(--m3-surface-variant)}
.m3-log-row:last-child{border-bottom:none}
.m3-log-ts{color:var(--text3);flex-shrink:0;min-width:80px;font-family:var(--mono)}
.m3-log-tag{padding:2px 10px;border-radius:var(--m3-radius-full);font-size:.65rem;font-weight:600;flex-shrink:0;text-transform:uppercase}
.m3-log-msg{color:var(--text2);word-break:break-all;flex:1}
.m3-log-connect{background:var(--green-d);color:var(--green)}
.m3-log-disconnect{background:var(--red-d);color:var(--red)}
.m3-log-telemetry{background:var(--blue-d);color:var(--blue)}

/* ── M3 Form / Table / Badge Aliases ────────────────────────────────────── */
.m3-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.m3-table-wrap{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);overflow:hidden;box-shadow:var(--m3-elevation-1)}
.m3-badge{font-size:.7rem;font-weight:500;padding:3px 10px;border-radius:var(--m3-radius-full);font-family:var(--mono)}
.m3-table{width:100%;border-collapse:collapse;font-size:.82rem}
.m3-table th{text-align:left;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);padding:12px 16px;border-bottom:1px solid var(--m3-outline-variant);background:var(--m3-surface-variant)}
.m3-table td{padding:12px 16px;border-bottom:1px solid var(--m3-outline-variant);vertical-align:middle}
.m3-table tr:last-child td{border-bottom:none}
.m3-table tbody tr:hover td{background:var(--m3-surface-variant)}

/* ── M3 Empty States ────────────────────────────────────────────────────── */
.m3-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center;gap:10px}
.m3-empty-icon{font-size:2.5rem;opacity:.25;color:var(--text3)}
.m3-empty-title{font-size:.9rem;font-weight:600;color:var(--text2)}
.m3-empty-text{font-size:.8rem;color:var(--text3);max-width:260px;line-height:1.6}
.m3-empty-state{text-align:center;padding:32px;color:var(--text3);font-size:.875rem}

/* ── M3 Icon Size Utilities ─────────────────────────────────────────────── */
.material-icons.m3-icon-sm{font-size:18px}
.material-icons.m3-icon-md{font-size:24px}

/* ── M3 Grid Utilities ──────────────────────────────────────────────────── */
.m3-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.m3-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

@media(max-width:768px){
  .m3-form-row,.m3-grid-2{grid-template-columns:1fr}
  .m3-grid-3{grid-template-columns:1fr 1fr}
}

/* ═══════════════════════════════════════════════════════════════════════════
   Additional M3 Components — added to complete the design system
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Form Hints ─────────────────────────────────────────────────────────── */
.m3-form-hint{font-size:.72rem;color:var(--text3);margin-top:4px;font-weight:400}

/* ── Chip Variants ─────────────────────────────────────────────────────── */
.m3-chip-ok{background:var(--green-d);color:var(--green)}
.m3-chip-err{background:var(--red-d);color:var(--red)}

/* ── Banners ────────────────────────────────────────────────────────────── */
.m3-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--m3-radius-md);font-size:.85rem}
.m3-banner-neutral{background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant);color:var(--text2)}
.m3-banner-err{background:var(--red-d);border:1px solid var(--red);color:var(--red)}
.m3-banner-ok{background:var(--green-d);border:1px solid var(--green);color:var(--green)}

/* ── Tele Row ───────────────────────────────────────────────────────────── */
.m3-tele-row{display:flex;flex-wrap:wrap;gap:6px;padding:12px 16px;border-top:1px solid var(--m3-outline-variant)}

/* ── Success Message ─────────────────────────────────────────────────────── */
.m3-success-msg{background:var(--green-d);border:1px solid var(--green);border-radius:var(--m3-radius-md);padding:12px 16px;font-size:.85rem;color:var(--green);display:flex;align-items:center;gap:8px}

/* ── Form Controls ──────────────────────────────────────────────────────── */
.m3-checkbox-wrapper{display:flex;align-items:center;gap:8px;cursor:pointer}
.m3-checkbox-wrapper input{width:18px;height:18px;accent-color:var(--m3-primary)}
.m3-textarea{width:100%;padding:12px 16px;border:1px solid var(--m3-outline);border-radius:var(--m3-radius-sm);font-size:.875rem;background:var(--m3-surface);color:var(--text);transition:border-color var(--m3-transition),box-shadow var(--m3-transition);font-family:inherit;resize:vertical}
.m3-textarea:focus{outline:none;border-color:var(--m3-primary);box-shadow:0 0 0 3px var(--m3-primary-container)}
.m3-file-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-md);color:var(--m3-primary);font-size:.82rem;cursor:pointer;transition:all var(--m3-transition);text-decoration:none}
.m3-file-link:hover{background:var(--m3-primary-container);border-color:var(--m3-primary);text-decoration:none}

/* ── Template Groups ─────────────────────────────────────────────────────── */
.m3-template-group{border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);overflow:hidden;margin-bottom:16px}
.m3-template-group-title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3);padding:10px 14px;background:var(--m3-surface-variant);border-bottom:1px solid var(--m3-outline-variant)}

/* ── Status Card ────────────────────────────────────────────────────────── */
.m3-status-card{background:var(--m3-surface);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-lg);padding:16px;box-shadow:var(--m3-elevation-1)}

/* ── Card Components ────────────────────────────────────────────────────── */
.m3-card-header{padding:16px 20px;border-bottom:1px solid var(--m3-outline-variant);display:flex;align-items:center;justify-content:space-between}
.m3-card-header h3{font-size:.9rem;font-weight:600}
.m3-card-body{padding:20px}
.m3-card-actions{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--m3-outline-variant);background:var(--m3-surface-variant)}
.m3-card-full{background:var(--m3-surface);border-radius:var(--m3-radius-lg);box-shadow:var(--m3-elevation-2);border:1px solid var(--m3-outline-variant);overflow:hidden}

/* ── Tab Content Alias ──────────────────────────────────────────────────── */
.tab-content{display:none}.tab-content.active{display:block}

/* ── Alert Variants ─────────────────────────────────────────────────────── */
.m3-alert{display:none;align-items:center;gap:10px;border-radius:var(--m3-radius-md);font-size:.875rem;padding:12px 16px}
.m3-alert.show{display:flex}
.m3-alert-error{background:var(--red-d);border:1px solid rgba(220,38,38,.2);color:var(--red)}
.m3-alert-success{background:var(--green-d);border:1px solid rgba(22,163,74,.2);color:var(--green)}
.m3-alert-info{background:var(--blue-d);border:1px solid rgba(37,99,235,.2);color:var(--blue)}
.m3-alert-info .material-icons,.m3-alert-success .material-icons,.m3-alert-error .material-icons{font-size:20px}

/* ── Input Field ────────────────────────────────────────────────────────── */
.m3-input-field{margin-bottom:16px}
.m3-input-field label{display:block;font-size:.8rem;font-weight:500;color:var(--text2);margin-bottom:6px}

/* ── Sub-Tab Panels (system.html, site.html) ──────────────────────────── */
/* Visibility is managed by JS via inline style — classes are semantic */

/* ── Mini Stat Cards (site.html hero) ─────────────────────────────────── */
.stat-mini-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}
.stat-mini{background:var(--m3-surface-variant);border:1px solid var(--m3-outline-variant);border-radius:var(--m3-radius-md);padding:10px 16px;min-width:80px;text-align:center}
.stat-mini-label{font-size:.68rem;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.stat-mini-val{font-size:1.25rem;font-weight:700;font-family:var(--mono);color:var(--text)}

/* ── Status Pill (M3 alias) ───────────────────────────────────────────── */
.m3-status-pill{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;padding:4px 12px;border-radius:var(--m3-radius-full);white-space:nowrap}

/* ── Token Hint ────────────────────────────────────────────────────────── */
.m3-token-hint{background:var(--green-d);border:1px solid var(--green);border-radius:var(--m3-radius-md);padding:12px 16px;font-size:.82rem;color:var(--green);display:flex;align-items:center;gap:8px;margin-top:8px}
.m3-token-hint .material-icons{font-size:18px}

/* ── Generate Token Button ─────────────────────────────────────────────── */
.m3-gen-token-btn{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;padding:4px 12px;border-radius:var(--m3-radius-full);border:1px solid var(--m3-outline);background:var(--m3-surface-variant);color:var(--m3-primary);cursor:pointer;transition:all var(--m3-transition);font-family:var(--sans)}
.m3-gen-token-btn:hover{background:var(--m3-primary-container);border-color:var(--m3-primary)}

/* ── M3 Button Icon & Active State ─────────────────────────────────────── */
.m3-btn-icon{width:36px;height:36px;padding:0;justify-content:center;border-radius:var(--m3-radius-md);font-size:18px}
.m3-btn:active,.btn:active{transform:scale(.98)}
.m3-btn:hover{text-decoration:none}

/* ── Form Spacing Fix — grid children don't need extra bottom margin ──── */
.m3-form-grid>.m3-form-field{margin-bottom:0}
.m3-form-row>.m3-form-field{margin-bottom:0}
