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

:root{
  /* palette – dark (Forseti) */
  --bg:        #060B0E;
  --bg-card:   #0D1117;
  --bg-card-hover: #131A22;
  --bg-code:   #111921;
  --bg-toolbar:#090E13;
  --border:    #1B2832;
  --border-hl: #253545;
  --text:      #E2E8F0;
  --text-dim:  #8B9BB5;
  --text-code: #C8D4E0;
  --accent:    #00E5A0;
  --accent-dim:#00B87F;
  --accent-bg: rgba(0,229,160,.08);
  --gold:      #D4A843;
  --gold-glow: rgba(212,168,67,.12);
  --mimir-blue:#6C8CFF;
  --mimir-bg:  rgba(108,140,255,.08);
  --linux:     #f0c040;
  --linux-bg:  rgba(240,192,64,.08);
  --linux-border:rgba(240,192,64,.18);
  --windows:   #40b0f0;
  --windows-bg:rgba(64,176,240,.08);
  --windows-border:rgba(64,176,240,.18);
  --aws:       #f90;
  --aws-bg:    rgba(255,153,0,.08);
  --aws-border:rgba(255,153,0,.18);
  --azure:     #0078d4;
  --azure-bg:  rgba(0,120,212,.08);
  --azure-border:rgba(0,120,212,.18);
  --gcp:       #4285f4;
  --gcp-bg:    rgba(66,133,244,.08);
  --gcp-border:rgba(66,133,244,.18);
  --compliant: #34d399;
  --compliant-bg:rgba(52,211,153,.06);
  --compliant-border:rgba(52,211,153,.15);
  --danger:    #f87171;
  --radius:    12px;
  --radius-sm: 8px;
  --shadow:    0 2px 12px rgba(0,0,0,.45);
  --font:      'Inter',system-ui,sans-serif;
  --mono:      'JetBrains Mono','Fira Code',monospace;
  --transition: .2s ease;
}

[data-theme="light"]{
  --bg:        #F2F5F8;
  --bg-card:   #ffffff;
  --bg-card-hover: #f5f8fa;
  --bg-code:   #EEF1F5;
  --bg-toolbar:#ffffff;
  --border:    #D8DEE6;
  --border-hl: #BCC5D2;
  --text:      #1A1D2B;
  --text-dim:  #5A6578;
  --text-code: #3A4055;
  --accent:    #00B87F;
  --accent-dim:#009968;
  --accent-bg: rgba(0,184,127,.06);
  --gold:      #B8912A;
  --gold-glow: rgba(184,145,42,.08);
  --mimir-blue:#4A6AD4;
  --mimir-bg:  rgba(74,106,212,.06);
  --linux-bg:  rgba(180,140,20,.06);
  --linux-border:rgba(180,140,20,.18);
  --linux:     #a07800;
  --windows-bg:rgba(20,120,200,.06);
  --windows-border:rgba(20,120,200,.18);
  --windows:   #1478c8;
  --aws:       #c77600;
  --aws-bg:    rgba(199,118,0,.06);
  --aws-border:rgba(199,118,0,.18);
  --azure:     #0060a8;
  --azure-bg:  rgba(0,96,168,.06);
  --azure-border:rgba(0,96,168,.18);
  --gcp:       #2a6cd4;
  --gcp-bg:    rgba(42,108,212,.06);
  --gcp-border:rgba(42,108,212,.18);
  --compliant-bg:rgba(16,140,90,.05);
  --compliant-border:rgba(16,140,90,.15);
  --compliant: #0e8c5a;
  --shadow:    0 2px 12px rgba(0,0,0,.07);
}

html{scroll-behavior:smooth;font-size:15px}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

/* ── Header ── */
#site-header{
  background:var(--bg-card);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}
.header-inner{
  max-width:1280px;margin:0 auto;
  padding:16px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  flex-wrap:wrap;
}
.brand{display:flex;align-items:center;gap:14px}
.brand-icon{
  width:44px;height:44px;
  background:linear-gradient(135deg,var(--accent),#a78bfa);
  border-radius:12px;display:grid;place-items:center;
  color:#fff;flex-shrink:0;
}
.brand-icon svg{width:22px;height:22px}
.brand h1{font-size:1.25rem;font-weight:700;line-height:1.3;letter-spacing:-.01em}
.brand .subtitle{font-size:.8rem;color:var(--text-dim);font-weight:500}
.header-actions{display:flex;gap:8px}

/* Buttons */
.btn-icon{
  width:38px;height:38px;border:1px solid var(--border);border-radius:var(--radius-sm);
  background:transparent;color:var(--text-dim);cursor:pointer;
  display:grid;place-items:center;transition:var(--transition);
}
.btn-icon:hover{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-dim)}
.btn-icon svg{width:18px;height:18px}
[data-theme="light"] .icon-moon{display:none}
:root:not([data-theme="light"]) .icon-sun{display:none}

/* ── Resource Links Bar ── */
#resources-bar{
  background:var(--bg-code);
  border-bottom:1px solid var(--border);
}
.resources-inner{
  max-width:1280px;margin:0 auto;
  padding:8px 24px;
  display:flex;align-items:center;gap:12px;
  overflow-x:auto;
}
.resources-label{
  font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-dim);display:flex;align-items:center;gap:5px;
  flex-shrink:0;
}
.resources-links{
  display:flex;gap:6px;flex-wrap:nowrap;
}
.resources-links a{
  font-size:.75rem;font-weight:500;
  padding:4px 12px;border-radius:20px;
  border:1px solid var(--border);
  color:var(--accent);background:var(--accent-bg);
  text-decoration:none;white-space:nowrap;
  transition:var(--transition);
}
.resources-links a:hover{
  background:var(--accent);color:#fff;
  border-color:var(--accent);
}

/* ── Toolbar ── */
#toolbar{
  background:var(--bg-toolbar);
  border-bottom:1px solid var(--border);
  position:sticky;top:77px;z-index:90;
}
.toolbar-inner{
  max-width:1280px;margin:0 auto;
  padding:14px 24px 12px;
  display:flex;flex-direction:column;gap:12px;
}
.search-wrap{
  position:relative;display:flex;align-items:center;
}
.search-icon{
  position:absolute;left:14px;width:18px;height:18px;color:var(--text-dim);pointer-events:none;
}
.search-kbd{
  position:absolute;right:12px;
  font-family:var(--mono);font-size:.7rem;
  padding:2px 7px;border-radius:4px;
  border:1px solid var(--border);color:var(--text-dim);
  background:var(--bg);pointer-events:none;
}
#search{
  width:100%;padding:10px 50px 10px 42px;
  border:1px solid var(--border);border-radius:var(--radius-sm);
  background:var(--bg-card);color:var(--text);
  font-family:var(--font);font-size:.92rem;
  transition:var(--transition);outline:none;
}
#search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
#search::placeholder{color:var(--text-dim)}

.filter-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.os-filters,.family-filters{display:flex;gap:6px;flex-wrap:wrap}
.family-filters{border-left:1px solid var(--border);padding-left:12px}

.chip{
  font-family:var(--font);font-size:.78rem;font-weight:500;
  padding:5px 12px;border-radius:20px;
  border:1px solid var(--border);
  background:transparent;color:var(--text-dim);
  cursor:pointer;transition:var(--transition);
  display:inline-flex;align-items:center;gap:5px;
  white-space:nowrap;
}
.chip:hover{border-color:var(--accent-dim);color:var(--text)}
.chip.active{background:var(--accent-bg);border-color:var(--accent-dim);color:var(--accent);font-weight:600}

/* ── Stats ── */
#stats-bar{background:var(--bg)}
.stats-inner{
  max-width:1280px;margin:0 auto;padding:10px 24px;
  font-size:.8rem;color:var(--text-dim);display:flex;gap:8px;align-items:center;
}
.stats-sep{opacity:.4}

/* ── Cards Container ── */
#cards-container{
  max-width:1280px;margin:0 auto;
  padding:8px 24px 60px;
  display:flex;flex-direction:column;gap:12px;
}

/* ── Card ── */
.cmd-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 24px;
  transition:var(--transition);
  animation:fadeUp .35s ease both;
}
.cmd-card:hover{background:var(--bg-card-hover);border-color:var(--border-hl);box-shadow:var(--shadow)}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}

.card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.os-badge{
  font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  padding:3px 10px;border-radius:6px;flex-shrink:0;
}
.os-badge.linux{color:var(--linux);background:var(--linux-bg);border:1px solid var(--linux-border)}
.os-badge.windows{color:var(--windows);background:var(--windows-bg);border:1px solid var(--windows-border)}
.os-badge.aws{color:var(--aws);background:var(--aws-bg);border:1px solid var(--aws-border)}
.os-badge.azure{color:var(--azure);background:var(--azure-bg);border:1px solid var(--azure-border)}
.os-badge.gcp{color:var(--gcp);background:var(--gcp-bg);border:1px solid var(--gcp-border)}
.family-badge{
  font-size:.68rem;font-weight:600;
  padding:3px 10px;border-radius:6px;
  color:var(--accent);background:var(--accent-bg);
  border:1px solid rgba(108,140,255,.15);
  flex-shrink:0;
}
.card-title{
  font-size:1rem;font-weight:700;flex:1;min-width:200px;
}

.card-desc{
  font-size:.88rem;color:var(--text-dim);margin-bottom:14px;line-height:1.55;
}
.controls-row{
  display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px;
}
.ctrl-tag{
  font-family:var(--mono);font-size:.68rem;font-weight:500;
  padding:2px 8px;border-radius:4px;
  background:rgba(168,130,255,.08);color:#a882ff;
  border:1px solid rgba(168,130,255,.15);
  cursor:default;white-space:nowrap;
}
[data-theme="light"] .ctrl-tag{
  background:rgba(100,60,200,.06);color:#5c30b8;
  border:1px solid rgba(100,60,200,.15);
}
.ksi-tag{
  font-family:var(--mono);font-size:.68rem;font-weight:500;
  padding:2px 8px;border-radius:4px;
  background:rgba(0,190,170,.08);color:#00c4a8;
  border:1px solid rgba(0,190,170,.15);
  cursor:default;white-space:nowrap;
}
[data-theme="light"] .ksi-tag{
  background:rgba(0,140,120,.06);color:#007a68;
  border:1px solid rgba(0,140,120,.15);
}

.cmd-block{
  position:relative;
  background:var(--bg-code);
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  padding:14px 48px 14px 16px;
  margin-bottom:12px;
  overflow-x:auto;
}
.cmd-block code{
  font-family:var(--mono);font-size:.82rem;color:var(--text-code);
  white-space:pre-wrap;word-break:break-all;line-height:1.7;
}
.cmd-block .copy-btn{
  position:absolute;top:8px;right:8px;
  width:30px;height:30px;border:1px solid var(--border);
  border-radius:6px;background:var(--bg-card);color:var(--text-dim);
  cursor:pointer;display:grid;place-items:center;
  transition:var(--transition);opacity:.6;
}
.cmd-block .copy-btn:hover{opacity:1;color:var(--accent);border-color:var(--accent-dim)}
.cmd-block .copy-btn svg{width:14px;height:14px}
.cmd-block .copy-btn.copied{color:var(--compliant);border-color:var(--compliant)}

.compliant-section{
  background:var(--compliant-bg);
  border:1px solid var(--compliant-border);
  border-radius:var(--radius-sm);
  padding:14px 18px;
}
.compliant-label{
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:var(--compliant);margin-bottom:8px;display:flex;align-items:center;gap:6px;
}
.compliant-label svg{width:14px;height:14px}
.compliant-section ul{
  list-style:none;padding:0;margin:0;
}
.compliant-section li{
  font-size:.84rem;color:var(--text);
  padding:3px 0 3px 18px;position:relative;line-height:1.55;
}
.compliant-section li::before{
  content:'✓';position:absolute;left:0;color:var(--compliant);font-weight:700;font-size:.78rem;
}

/* ── DoD IL5 Section ── */
.il5-section{
  background:rgba(245,166,35,.06);
  border:1px solid rgba(245,166,35,.18);
  border-radius:var(--radius-sm);
  padding:14px 18px;margin-top:10px;
}
.il5-label{
  font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;
  color:#e8a020;margin-bottom:8px;display:flex;align-items:center;gap:6px;
}
[data-theme="light"] .il5-label{color:#b07800}
.il5-label svg{width:14px;height:14px}
.il5-section ul{list-style:none;padding:0;margin:0}
.il5-section li{
  font-size:.84rem;color:var(--text);
  padding:3px 0 3px 18px;position:relative;line-height:1.55;
}
.il5-section li::before{
  content:'⬥';position:absolute;left:0;color:#e8a020;font-weight:700;font-size:.72rem;
}
[data-theme="light"] .il5-section{
  background:rgba(200,130,0,.06);
  border-color:rgba(200,130,0,.2);
}

/* ── No results ── */
.no-results{
  text-align:center;padding:60px 20px;color:var(--text-dim);
}
.no-results svg{width:48px;height:48px;opacity:.3;margin-bottom:16px}
.no-results p{font-size:.95rem}

/* ── Back-to-top ── */
.btn-top{
  position:fixed;bottom:28px;right:28px;
  width:44px;height:44px;border-radius:50%;
  background:var(--accent);color:#fff;border:none;
  box-shadow:0 4px 16px rgba(108,140,255,.35);
  opacity:0;pointer-events:none;
  transition:var(--transition);z-index:80;
}
.btn-top.visible{opacity:1;pointer-events:auto}
.btn-top:hover{transform:scale(1.08)}

/* ── Footer ── */
#site-footer{
  text-align:center;padding:28px 24px 36px;
  font-size:.78rem;color:var(--text-dim);
  border-top:1px solid var(--border);
  line-height:1.7;
}

/* ── Print ── */
@media print{
  #site-header,#toolbar,#stats-bar,.btn-top,.copy-btn,#site-footer,.header-actions{display:none!important}
  body{background:#fff;color:#111}
  .cmd-card{break-inside:avoid;border:1px solid #ccc;page-break-inside:avoid}
  .compliant-section{background:#f0fdf4}
  #cards-container{padding:0}
}

/* ── Responsive ── */
@media(max-width:640px){
  .header-inner{padding:12px 14px}
  .brand h1{font-size:1.05rem}
  .toolbar-inner{padding:10px 14px}
  #cards-container{padding:6px 14px 40px}
  .cmd-card{padding:16px}
  .family-filters{border-left:none;padding-left:0;border-top:1px solid var(--border);padding-top:8px}
}

/* ── Project Sidebar ── */
.grc-layout{display:flex;min-height:calc(100vh - 140px)}
.grc-main{flex:1;min-width:0;overflow-x:hidden}
.project-sidebar{width:260px;flex-shrink:0;border-left:1px solid var(--border);background:var(--bg-card);overflow-y:auto;position:sticky;top:77px;height:calc(100vh - 77px)}
.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.sidebar-add-btn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--accent);font-size:1rem;font-weight:700;cursor:pointer;display:grid;place-items:center;transition:var(--transition)}
.sidebar-add-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.sidebar-project{padding:12px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:var(--transition)}
.sidebar-project:hover{background:var(--bg-card-hover)}
.sidebar-project.active{background:rgba(108,140,255,.06);border-left:3px solid var(--accent)}
.sidebar-project.archived{opacity:.6}
@media(max-width:900px){.project-sidebar{display:none}.grc-layout{display:block}}
@media print{.project-sidebar{display:none!important}}

/* ── KSI Page Styles ── */
.ksi-grid{
  display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:12px;
}
@media(min-width:900px){
  .ksi-grid{grid-template-columns:1fr 1fr 1fr}
}
.ksi-csp-block{margin:0}
.ksi-csp-label{
  font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-dim);margin-bottom:6px;display:flex;align-items:center;gap:6px;
}
.ksi-csp-block .cmd-block{margin-bottom:0}
.ksi-csp-block .os-badge{font-size:.62rem;padding:2px 6px}
