/* Vigilex premium responsive theme override — loaded after the legacy stylesheet. */
:root {
  --surface: #ffffff;
  --surface-soft: #f7f9fc;
  --surface-strong: #eaf0f8;
  --ink: var(--text-color, #142033);
  --muted: #637083;
  --line: rgba(34, 53, 79, .13);
  --shadow-sm: 0 8px 22px rgba(17, 29, 49, .08);
  --shadow-md: 0 18px 48px rgba(17, 29, 49, .13);
  --shadow-lg: 0 30px 78px rgba(6, 20, 42, .2);
  --radius-sm: 12px;
  --radius: 18px;
  --radius-lg: 28px;
  --focus-ring: 0 0 0 4px color-mix(in srgb, var(--primary) 25%, transparent);
  --header-height: 76px;
  color-scheme: light;
}

html[data-theme="dark"] {
  --surface: #111a2b;
  --surface-soft: #0b1322;
  --surface-strong: #17233a;
  --ink: #e9f1ff;
  --muted: #aebbd0;
  --line: rgba(219, 232, 255, .13);
  --shadow-sm: 0 8px 24px rgba(0, 0, 0, .22);
  --shadow-md: 0 20px 52px rgba(0, 0, 0, .28);
  --shadow-lg: 0 34px 84px rgba(0, 0, 0, .44);
  color-scheme: dark;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body { min-width: 320px; color: var(--ink); background: var(--page, var(--surface-soft)); font-family: var(--font, Inter, Arial, sans-serif); line-height: 1.55; text-rendering: optimizeLegibility; }
body::selection { background: color-mix(in srgb, var(--primary) 24%, transparent); }
img, svg, video { max-width: 100%; height: auto; }
a { color: inherit; text-underline-offset: .18em; }
a:hover { color: var(--primary); }
button, input, select, textarea { font: inherit; }
button, [role="button"] { -webkit-tap-highlight-color: transparent; }
:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 8px; }

.container { width: min(1180px, calc(100% - clamp(28px, 6vw, 72px))); }
.public-body main { min-height: calc(100dvh - 238px); }
.public-header { position: sticky; top: 0; z-index: 70; min-height: var(--header-height); display: flex; align-items: center; background: color-mix(in srgb, var(--header) 94%, transparent); border-bottom: 1px solid color-mix(in srgb, white 14%, transparent); box-shadow: 0 1px 0 rgba(255,255,255,.07), 0 10px 30px rgba(5, 15, 32, .12); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); }
.header-inner { position: relative; min-height: var(--header-height); display: flex; align-items: center; gap: 24px; }
.brand { gap: 11px; font-size: 1.03rem; font-weight: 800; letter-spacing: -.02em; color: #fff; text-decoration: none; white-space: nowrap; }
.brand:hover { color: #fff; opacity: .94; }
.logo-mark { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 12px; color: #fff; background: linear-gradient(135deg, var(--primary), var(--accent)); box-shadow: 0 8px 20px color-mix(in srgb, var(--primary) 36%, transparent); }
.brand img { width: 42px; height: 42px; object-fit: contain; border-radius: 12px; background: rgba(255,255,255,.12); }
.public-nav { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.public-nav > a:not(.button) { padding: 9px 12px; border-radius: 10px; color: rgba(255,255,255,.82); font-size: .91rem; font-weight: 650; text-decoration: none; }
.public-nav > a:not(.button):hover { color: #fff; background: rgba(255,255,255,.11); }
.public-nav .theme-toggle, .topbar .theme-toggle { min-width: 42px; min-height: 40px; padding-inline: 11px; border: 1px solid rgba(255,255,255,.16); color: #fff; background: rgba(255,255,255,.08); border-radius: 11px; }
.public-menu-button { display: none; margin-left: auto; color: #fff; border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.09); }

.button, button.button { display: inline-flex; align-items: center; justify-content: center; gap: 9px; min-height: 44px; padding: 11px 17px; border: 1px solid transparent; border-radius: 12px; color: #fff; background: linear-gradient(135deg, var(--primary), color-mix(in srgb, var(--primary) 80%, var(--accent))); box-shadow: 0 9px 22px color-mix(in srgb, var(--primary) 22%, transparent); font-weight: 750; line-height: 1.1; text-decoration: none; cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, filter .2s ease; }
.button:hover, button.button:hover { color: #fff; filter: brightness(1.06); transform: translateY(-1px); box-shadow: 0 13px 28px color-mix(in srgb, var(--primary) 29%, transparent); }
.button:active, button.button:active { transform: translateY(0); }
.button.button-small, .button-small { min-height: 37px; padding: 8px 13px; border-radius: 10px; font-size: .86rem; }
.button.button-ghost, .button-ghost { color: var(--primary); border-color: color-mix(in srgb, var(--primary) 30%, transparent); background: color-mix(in srgb, var(--primary) 6%, transparent); box-shadow: none; }
.button.button-ghost:hover, .button-ghost:hover { color: var(--primary); background: color-mix(in srgb, var(--primary) 12%, transparent); }

.hero-section { padding: clamp(22px, 4vw, 50px) 0 clamp(38px, 6vw, 78px); background: radial-gradient(circle at 80% 0%, color-mix(in srgb, var(--primary) 12%, transparent), transparent 33%); }
.hero-slider { position: relative; min-height: clamp(420px, 55vw, 560px); overflow: hidden; border: 1px solid rgba(255,255,255,.18); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); background: var(--slide-bg, #0f3d56); isolation: isolate; }
.hero-slider::after { content: ''; position: absolute; z-index: -1; inset: auto -12% -28% auto; width: min(440px, 60vw); aspect-ratio: 1; border-radius: 50%; background: color-mix(in srgb, var(--accent) 32%, transparent); filter: blur(10px); }
.hero-slider-track { position: relative; min-height: inherit; }
.hero-slide { position: absolute; inset: 0; display: grid; align-items: center; padding: clamp(30px, 7vw, 84px); color: #fff; background-color: var(--slide-bg, #0f3d56); background-position: center; background-size: cover; opacity: 0; pointer-events: none; transform: scale(1.025); transition: opacity .65s ease, transform 1.2s cubic-bezier(.2,.75,.2,1); }
.hero-slide.is-active { position: relative; opacity: 1; pointer-events: auto; transform: scale(1); }
.hero-slide::before { content: ''; position: absolute; inset: 0; z-index: -1; background: linear-gradient(120deg, rgba(4,11,25,.25), transparent 65%); }
.hero-content { width: min(680px, 100%); }
.hero-content .pill { display: inline-flex; align-items: center; min-height: 29px; padding: 5px 11px; border: 1px solid rgba(255,255,255,.24); border-radius: 999px; color: rgba(255,255,255,.95); background: rgba(255,255,255,.12); font-size: .74rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; backdrop-filter: blur(8px); }
.hero-content h1 { max-width: 760px; margin: 18px 0 16px; color: #fff; font-size: clamp(2.2rem, 5.4vw, 4.5rem); font-weight: 850; letter-spacing: -.055em; line-height: 1.02; text-wrap: balance; }
.hero-content p { max-width: 650px; margin: 0 0 25px; color: rgba(255,255,255,.88); font-size: clamp(1rem, 1.8vw, 1.21rem); }
.hero-content .button-light { color: #10213d; background: #fff; box-shadow: 0 14px 30px rgba(0,0,0,.17); }
.hero-content .button-light:hover { color: #10213d; }
.slider-controls { position: absolute; z-index: 4; right: clamp(18px, 3vw, 30px); bottom: 27px; display: flex; gap: 10px; }
.slider-control { width: 43px; height: 43px; display: grid; place-items: center; padding: 0; border: 1px solid rgba(255,255,255,.32); border-radius: 50%; color: #fff; background: rgba(8,18,37,.34); cursor: pointer; backdrop-filter: blur(12px); transition: background .2s ease, transform .2s ease; }
.slider-control:hover { background: rgba(255,255,255,.2); transform: translateY(-2px); }
.slider-dots { position: absolute; z-index: 4; left: clamp(26px, 4vw, 46px); bottom: 39px; display: flex; align-items: center; gap: 9px; }
.slider-dots button { width: 9px; height: 9px; padding: 0; border: 0; border-radius: 999px; background: rgba(255,255,255,.47); box-shadow: none; cursor: pointer; transition: width .22s ease, background .22s ease; }
.slider-dots button.active { width: 28px; background: #fff; }

.feature-section { padding: clamp(42px, 7vw, 80px) 0; }
.section-intro { max-width: 760px; margin-bottom: 30px; }
.eyebrow { color: var(--primary); font-size: .76rem; font-weight: 850; letter-spacing: .1em; text-transform: uppercase; }
.section-intro h2, .callout h2, .form-page-heading h1, .content-page h1 { margin: 9px 0 12px; color: var(--ink); font-size: clamp(1.75rem, 3.6vw, 3rem); line-height: 1.1; letter-spacing: -.04em; text-wrap: balance; }
.section-intro p, .callout p, .form-page-heading p { color: var(--muted); font-size: 1.02rem; }
.feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.feature-grid article { min-height: 220px; padding: 26px; overflow: hidden; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(145deg, var(--surface), color-mix(in srgb, var(--surface) 88%, var(--primary))); box-shadow: var(--shadow-sm); transition: transform .25s ease, box-shadow .25s ease; }
.feature-grid article:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.feature-grid article > span { width: 48px; height: 48px; display: grid; place-items: center; border-radius: 14px; color: var(--primary); background: color-mix(in srgb, var(--primary) 10%, transparent); font-size: 1.34rem; }
.feature-grid h3 { margin: 19px 0 7px; color: var(--ink); font-size: 1.12rem; }
.feature-grid p { margin: 0; color: var(--muted); }
.callout { margin-bottom: clamp(44px, 7vw, 90px); padding: clamp(26px, 5vw, 50px); display: flex; align-items: center; justify-content: space-between; gap: 28px; border: 1px solid color-mix(in srgb, var(--primary) 22%, transparent); border-radius: var(--radius-lg); background: radial-gradient(circle at 100% 0%, color-mix(in srgb, var(--accent) 21%, transparent), transparent 40%), color-mix(in srgb, var(--primary) 6%, var(--surface)); box-shadow: var(--shadow-sm); }
.callout > div { max-width: 730px; }

.panel, .content-card, .info-card, .form-panel, .table-wrap { border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); box-shadow: var(--shadow-sm); }
.panel, .form-panel { padding: clamp(20px, 3vw, 30px); }
.panel h2, .panel h3, .content-card h2 { color: var(--ink); letter-spacing: -.025em; }
input, select, textarea { width: 100%; min-height: 45px; padding: 10px 12px; border: 1px solid color-mix(in srgb, var(--ink) 17%, transparent); border-radius: 10px; color: var(--ink); background: color-mix(in srgb, var(--surface) 94%, var(--surface-strong)); outline: none; transition: border-color .18s ease, box-shadow .18s ease, background .18s ease; }
textarea { min-height: 106px; resize: vertical; }
input:focus, select:focus, textarea:focus { border-color: var(--primary); box-shadow: var(--focus-ring); background: var(--surface); }
input::placeholder, textarea::placeholder { color: color-mix(in srgb, var(--muted) 75%, transparent); }
label { color: var(--ink); font-weight: 700; }
label > input, label > select, label > textarea { margin-top: 6px; font-weight: 500; }
.form-grid { gap: 17px; }
.form-section { padding-block: 23px; border-top: 1px solid var(--line); }
.form-section:first-child { padding-top: 0; border-top: 0; }
.form-section h2 { margin-top: 0; }
.flash { max-width: min(1180px, calc(100% - clamp(28px, 6vw, 72px))); margin: 20px auto 0; border-radius: 13px; box-shadow: var(--shadow-sm); }

.app-shell { min-height: 100dvh; background: var(--page, var(--surface-soft)); }
.sidebar { width: 280px; padding: 16px 12px max(16px, env(safe-area-inset-bottom)); color: #eaf2ff; background: linear-gradient(175deg, color-mix(in srgb, var(--sidebar) 96%, #091223), var(--sidebar)); box-shadow: 14px 0 44px rgba(4,10,21,.13); }
.brand-side { min-height: 58px; padding: 0 6px 16px; border-bottom: 1px solid rgba(255,255,255,.1); }
.brand-side .brand { flex: 1; min-width: 0; }
.side-close { display: none; color: #fff; background: rgba(255,255,255,.09); border-color: rgba(255,255,255,.15); }
.sidebar-nav { padding-top: 17px; }
.nav-item, .nav-group-toggle { min-height: 43px; margin-bottom: 4px; border-radius: 11px; color: rgba(232,241,255,.78); }
.nav-item:hover, .nav-item.active, .nav-group-toggle:hover { color: #fff; background: color-mix(in srgb, var(--primary) 36%, rgba(255,255,255,.06)); }
.nav-group-toggle { font-weight: 750; }
.nav-group-links { margin: 1px 0 10px 11px; padding-left: 11px; border-left: 1px solid rgba(255,255,255,.15); }
.nav-group-links .nav-item { font-size: .89rem; }
.sidebar-bottom { border-top-color: rgba(255,255,255,.1); }
.main-area { min-width: 0; }
.topbar { position: sticky; top: 0; z-index: 45; min-height: var(--header-height); padding: 10px clamp(18px, 3vw, 34px); background: color-mix(in srgb, var(--surface) 88%, transparent); border-bottom: 1px solid var(--line); box-shadow: 0 7px 25px rgba(15,26,45,.045); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); }
.topbar-title strong { color: var(--ink); letter-spacing: -.025em; }
.topbar-actions { gap: 11px; }
.topbar .icon-button, .topbar .theme-toggle { color: var(--ink); border-color: var(--line); background: var(--surface); }
.topbar .theme-toggle { color: var(--ink); }
.profile-chip { padding: 5px 11px 5px 5px; border: 1px solid var(--line); border-radius: 999px; background: var(--surface); box-shadow: 0 4px 13px rgba(21,34,55,.04); }
.avatar { background: linear-gradient(135deg, var(--primary), var(--accent)); }
.page-content { padding: clamp(22px, 3.5vw, 42px); }
.portal-footer { padding: 18px clamp(22px, 3.5vw, 42px) max(22px, env(safe-area-inset-bottom)); color: var(--muted); }
.page-heading { gap: 20px; }
.page-heading h1 { color: var(--ink); font-size: clamp(1.56rem, 3vw, 2.4rem); letter-spacing: -.04em; }
.data-table-wrap, .table-responsive { overflow-x: auto; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); box-shadow: var(--shadow-sm); }
table { min-width: 640px; background: transparent; }
th { color: var(--muted); background: color-mix(in srgb, var(--surface-strong) 58%, transparent); font-size: .76rem; letter-spacing: .055em; text-transform: uppercase; }
td, th { border-bottom-color: var(--line); }
tr:hover td { background: color-mix(in srgb, var(--primary) 3%, transparent); }
.status, .status-badge { border-radius: 999px; font-weight: 750; }

.public-footer { margin-top: auto; padding: 44px 0 max(24px, env(safe-area-inset-bottom)); color: rgba(255,255,255,.78); background: linear-gradient(130deg, var(--footer), color-mix(in srgb, var(--footer) 80%, #020711)); }
.public-footer strong { color: #fff; font-size: 1.1rem; }
.public-footer a { color: rgba(255,255,255,.8); }
.public-footer a:hover { color: #fff; }
.footer-copy { margin-top: 28px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,.12); }

.document-modal-card { width: min(960px, calc(100vw - 28px)); max-height: min(800px, calc(100dvh - 28px)); border-radius: var(--radius); background: var(--surface); box-shadow: var(--shadow-lg); }
.document-modal-head { border-bottom-color: var(--line); }
.document-modal-actions { border-top-color: var(--line); }

@media (max-width: 1180px) {
  .feature-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .profile-chip-copy { display: none; }
  .topbar-title { min-width: 0; }
}

@media (max-width: 1040px) {
  .sidebar { width: min(330px, calc(100vw - 42px)); padding-top: max(16px, env(safe-area-inset-top)); }
  .side-close { display: grid; }
  .main-area { width: 100%; }
  .page-content { padding: 26px clamp(17px, 4vw, 30px); }
  .feature-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .feature-grid article:last-child { grid-column: 1 / -1; min-height: auto; }
}

@media (max-width: 780px) {
  :root { --header-height: 68px; }
  .container { width: min(100% - 28px, 1180px); }
  .public-header { min-height: var(--header-height); }
  .header-inner { min-height: var(--header-height); gap: 12px; }
  .brand img { width: 37px; height: 37px; }
  .public-menu-button { display: grid; }
  /* JS only makes the compact menu collapsible; navigation remains visible without JavaScript. */
  html.js .public-nav { display: none; }
  html.js .public-nav.open { display: grid; }
  .public-nav { position: absolute; z-index: 90; top: calc(100% - 3px); right: 0; left: 0; grid-template-columns: 1fr; gap: 4px; padding: 12px; border: 1px solid var(--line); border-radius: 0 0 var(--radius) var(--radius); background: color-mix(in srgb, var(--header) 96%, #0b1426); box-shadow: var(--shadow-lg); }
  .public-nav > a:not(.button) { padding: 11px 12px; }
  .public-nav .button, .public-nav .theme-toggle { width: 100%; justify-content: center; }
  .hero-section { padding-top: 16px; }
  .hero-slider { min-height: min(570px, calc(100dvh - 112px)); border-radius: 22px; }
  .hero-slide { padding: 30px 24px 80px; }
  .hero-content h1 { font-size: clamp(2rem, 10vw, 3rem); }
  .slider-dots { left: 24px; bottom: 24px; }
  .slider-controls { right: 20px; bottom: 17px; }
  .callout { align-items: flex-start; flex-direction: column; }
  .callout .button { width: 100%; }
  .feature-grid { grid-template-columns: 1fr; }
  .feature-grid article:last-child { grid-column: auto; }
  .topbar { min-height: 68px; padding: 8px 15px; }
  .topbar-title .eyebrow { display: none; }
  .topbar-title strong { display: block; overflow: hidden; max-width: 42vw; text-overflow: ellipsis; white-space: nowrap; }
  .topbar-actions { gap: 6px; }
  .topbar .theme-toggle span, .profile-chip { display: none; }
  .page-heading { align-items: flex-start; flex-direction: column; }
  .page-heading > .button, .page-heading-actions { width: 100%; }
  .page-heading > .button { justify-content: center; }
}

@media (max-width: 520px) {
  body { font-size: .95rem; }
  .brand > span:last-child { max-width: 166px; overflow: hidden; text-overflow: ellipsis; }
  .hero-slider { min-height: 510px; }
  .hero-content .pill { font-size: .67rem; letter-spacing: .045em; }
  .hero-content p { font-size: .98rem; }
  .slider-control { width: 39px; height: 39px; }
  .panel, .form-panel { padding: 18px; border-radius: 14px; }
  .form-grid, .two-column, .admin-two { grid-template-columns: 1fr; }
  .span-2 { grid-column: auto; }
  .page-content { padding: 20px 14px; }
  .flash { max-width: calc(100% - 28px); }
  .document-modal-card { width: calc(100vw - 16px); max-height: calc(100dvh - 16px); border-radius: 16px; }
  .document-modal-head, .document-modal-actions { padding: 14px; }
  .document-modal-body { padding: 14px; }
}

/* Foldable/dual-screen devices: avoid content under a hinge and keep cards useful in narrow segments. */
@supports (padding: env(viewport-segment-left 1 0)) {
  @media (horizontal-viewport-segments: 2) {
    .public-header, .topbar { padding-left: max(16px, env(safe-area-inset-left)); padding-right: max(16px, env(safe-area-inset-right)); }
    .hero-slider { min-height: min(530px, calc(100dvh - 126px)); }
    .hero-content { max-width: min(62vw, 660px); }
    .page-content { padding-left: max(20px, env(safe-area-inset-left)); padding-right: max(20px, env(safe-area-inset-right)); }
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; }
}

/* AI Control Center */
.ai-control-hero,.ai-control-grid,.ai-provider-grid{display:grid;gap:1rem}.ai-control-hero{grid-template-columns:minmax(0,1fr) auto;align-items:center}.ai-control-grid{grid-template-columns:1.45fr .85fr;margin:1rem 0}.ai-status-pill{padding:.65rem .85rem;border-radius:999px;font-weight:750;background:color-mix(in srgb,var(--success) 14%,var(--surface));color:var(--success);border:1px solid color-mix(in srgb,var(--success) 36%,var(--border))}.ai-status-pill.is-muted{background:var(--surface-raised);color:var(--muted);border-color:var(--border)}.panel-heading,.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.panel-heading h2,.section-heading h2,.ai-provider-card h3{margin:.15rem 0}.ai-readiness-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;margin:0}.ai-readiness-list div{padding:.65rem;border:1px solid var(--border);border-radius:.65rem;background:var(--surface-raised)}.ai-readiness-list dt{font-size:.78rem;color:var(--muted)}.ai-readiness-list dd{margin:.2rem 0 0;font-weight:700}.success-text{color:var(--success)}.danger-text{color:var(--danger)}.ai-safe-note{padding:.7rem .8rem;background:var(--surface-raised);border-left:3px solid var(--primary);border-radius:.4rem}.inline-actions,.provider-actions{display:flex;flex-wrap:wrap;gap:.55rem;align-items:center}.settings-toggle-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.6rem;margin:1rem 0}.toggle-row{display:flex!important;align-items:center;gap:.55rem;min-height:2.5rem;padding:.48rem .65rem;border:1px solid var(--border);border-radius:.65rem;background:var(--surface-raised);cursor:pointer}.toggle-row input{width:auto!important;accent-color:var(--primary)}.ai-form-grid{margin-top:.85rem}.ai-color-grid{display:grid;grid-template-columns:repeat(7,minmax(92px,1fr));gap:.6rem;margin-top:1rem}.ai-color-grid label{font-size:.78rem;color:var(--muted)}.ai-color-grid input{display:block;width:100%;height:2.2rem;margin-top:.25rem;padding:.15rem}.ai-provider-section{margin-top:1.2rem}.ai-provider-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ai-provider-card{display:flex;flex-direction:column;gap:.7rem}.ai-provider-card.is-enabled{box-shadow:0 0 0 1px color-mix(in srgb,var(--primary) 46%,transparent)}.ai-provider-card header{display:flex;align-items:center;gap:.75rem}.ai-provider-card header p,.ai-provider-card label small{margin:.16rem 0 0;color:var(--muted);font-size:.78rem}.provider-mark{display:grid;place-items:center;width:2.5rem;height:2.5rem;border-radius:.75rem;background:var(--primary);color:#fff;font-weight:800}.provider-openai{background:#202b3d}.provider-gemini{background:#5578ee}.provider-anthropic{background:#986f54}.provider-openrouter{background:#7d5ce6}.provider-health{display:flex;gap:.5rem;align-items:center;font-size:.86rem}.provider-health small{margin-left:auto;color:var(--muted)}.status-dot{width:.65rem;height:.65rem;border-radius:50%;background:var(--muted)}.status-dot.healthy{background:var(--success)}.status-dot.failed{background:var(--danger)}.provider-error{min-height:1.2rem;margin:0;color:var(--muted);font-size:.8rem}.routing-priority{display:grid;grid-template-columns:repeat(5,minmax(120px,1fr));gap:.6rem;margin-top:1rem}.routing-priority strong{grid-column:1/-1}.routing-priority label{display:grid;gap:.25rem;color:var(--muted)}.danger-zone{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1.2rem 0}.danger-button{background:var(--danger)!important;color:#fff!important}.vigilex-ai-active-dot.is-offline{background:#94a3b8!important;box-shadow:none!important}
@media(max-width:980px){.ai-control-grid,.ai-provider-grid{grid-template-columns:1fr}.settings-toggle-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.ai-color-grid{grid-template-columns:repeat(4,minmax(90px,1fr))}.routing-priority{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:620px){.ai-control-hero,.danger-zone,.panel-heading{grid-template-columns:1fr;display:grid}.ai-readiness-list,.settings-toggle-grid,.ai-color-grid{grid-template-columns:1fr}.routing-priority{grid-template-columns:1fr}.ai-provider-card .provider-actions .button{flex:1 1 45%}}
