/* ---------- Elite Military Intelligence Theme ---------- */
:root{
  --bg:#0a0e1a;         /* ultra-deep navy */
  --bg-2:#0f1423;       /* secondary navy */
  --card:rgba(26,31,46,0.8);  /* glass cards */
  --card-border:rgba(42,52,65,0.6);
  --card-hover:rgba(30,35,48,0.9);
  --text:#f8fafc;       /* crisp white */
  --muted:#94a3b8;      /* sophisticated gray */
  --accent:#38bdf8;     /* intelligence blue */
  --accent-2:#fbbf24;   /* command gold */
  --red:#ef4444;        /* critical alerts */
  --blue:#60a5fa;       /* info blue */
  --green:#22c55e;      /* success green */
  --amber:#f59e0b;      /* warning amber */
  --line:rgba(255,255,255,0.1);
  --shadow:0 20px 40px rgba(0,0,0,0.4);
  --glow:0 0 20px rgba(56,189,248,0.15);
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Helvetica Neue,Arial;
  color:var(--text);
  background:var(--bg);
}

/* Animated gradient background */
.app-bg{
  position:fixed; inset:0; z-index:-2;
  background: radial-gradient(1200px 600px at 10% -10%, #1e3a8a40, transparent),
              radial-gradient(900px 500px at 90% 10%, #0ea5e940, transparent),
              linear-gradient(180deg, var(--bg), var(--bg-2));
  filter:saturate(120%);
}

/* Shell containers */
.shell{ max-width:1200px; margin:0 auto; padding:12px 16px; }
.header{ display:flex; align-items:center; justify-content:space-between; padding:8px 0; }
.main{ padding-top:4px; padding-bottom:24px; }
.footer{ border-top:1px solid var(--line); opacity:.8; }

/* Brand */
.brand{ display:flex; align-items:center; gap:12px; }
.logo{ width:36px; height:36px; color:var(--accent); filter:drop-shadow(0 2px 8px #0ea5e955); }
.brand-text h1{ margin:0; font-size:18px; letter-spacing:.4px; }
.subtitle{ color:var(--muted); font-size:12px; }

/* Nav */
.nav{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.nav a{
  color:var(--text);
  text-decoration:none;
  padding:6px 10px;
  border:1px solid transparent;
  border-radius:8px;
  transition:all .18s ease;
}
.nav a:hover{ border-color:var(--card-border); background:var(--card); }
.nav .pill{
  background:linear-gradient(135deg, var(--accent), #60a5fa);
  color:#031322 !important;
  border: none;
  font-weight:700;
}

/* Generic layout */
h2.page-title, h2{ margin:0 0 8px 0; font-size:22px; }
.desc{ color:var(--muted); margin:6px 0 14px; }

.container, .onepager, .card{
  background:var(--card);
  border:1px solid var(--card-border);
  border-radius:16px;
  padding:16px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(6px);
}

/* Forms */
.form{ display:grid; gap:12px; }
.form .row{ display:grid; gap:12px; grid-template-columns:repeat(2,1fr); }
.form input,.form textarea,.form select{
  width:100%; padding:10px 12px;
  background:#0c1226; color:var(--text);
  border:1px solid var(--line); border-radius:12px;
}
button,.btn{
  display:inline-block; cursor:pointer;
  background:linear-gradient(135deg, var(--accent), #60a5fa);
  color:#031322; border:none; border-radius:12px;
  padding:10px 14px; font-weight:800;
  box-shadow:0 8px 20px rgba(14,165,233,.2);
  text-decoration:none;
}
.btn.subtle{ background:#1b2545; color:#cfe1ff; }

/* Tables */
.table, .gap-table{
  width:100%; border-collapse:separate; border-spacing:0;
  overflow:hidden; border-radius:14px; background:#0b1226; border:1px solid var(--line);
}
.table th, .gap-table th{
  background:#0f1a3a; color:#dbe7ff; text-align:left; font-weight:700; padding:12px;
}
.table td, .gap-table td{ padding:12px; border-top:1px solid var(--line); vertical-align:top; }
.table tr:hover td, .gap-table tr:hover td{ background:#0f162c; }

/* Utilities */
.truncate{ max-width:420px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mono{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace; }

/* KPI / Badges */
.stats-bar{ display:flex; gap:12px; flex-wrap:wrap; margin:12px 0; }
.stat{ padding:12px 14px; border-radius:14px; border:1px solid var(--card-border); background:linear-gradient(180deg,#0a1428,#0a1122); }
.stat-kpi{ font-size:22px; font-weight:900; }
.stat-label{ color:var(--muted); font-size:12px; }

.risk-tag{ padding:4px 10px; border-radius:999px; font-weight:900; font-size:12px; color:#051122; }
.risk-tag.low{ background:var(--green); }
.risk-tag.medium{ background:var(--amber); }
.risk-tag.high{ background:#fca5a5; }

/* ---------- Hero Section & Modern Layout ---------- */
.hero { 
  display:grid; 
  grid-template-columns:1.6fr 1fr; 
  gap:20px; 
  margin:0 0 24px; 
  align-items:stretch; 
}

.kpi-grid { 
  display:grid; 
  grid-template-columns:repeat(3,1fr); 
  gap:12px; 
  margin-top:16px;
}

.kpi { 
  padding:16px; 
  border:1px solid var(--card-border); 
  border-radius:12px; 
  background:linear-gradient(180deg,#0a1428,#0b1324); 
  text-align:center;
  transition:all .2s ease;
}

.kpi:hover { 
  border-color:var(--accent); 
  background:linear-gradient(180deg,#0c1630,#0d1426); 
}

.kpi .num { 
  font-size: clamp(24px,2.8vw,32px); 
  font-weight: 900; 
  color:var(--text);
  display:block;
  margin-bottom:4px;
}

.kpi .label { 
  color:var(--muted); 
  font-size:11px; 
  letter-spacing:.5px; 
  text-transform:uppercase;
}

.radar { 
  position:relative; 
  border-radius:12px; 
  background: radial-gradient(60% 60% at 50% 50%, #0ea5e930, transparent 60%), 
              linear-gradient(135deg, rgba(56,189,248,0.12), rgba(251,191,36,0.06)); 
  overflow:hidden; 
  min-height:200px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.radar::after { 
  content:""; 
  position:absolute; 
  inset:-40%; 
  background:conic-gradient(from 0deg, rgba(56,189,248,.3), transparent 40%); 
  animation:sweep 4s linear infinite; 
  mix-blend-mode:screen; 
}

@keyframes sweep { 
  to { transform: rotate(360deg); } 
}

.radar-content {
  position:relative;
  z-index:1;
  text-align:center;
  color:var(--text);
}

.dashboard-grid-2 { 
  display:grid; 
  grid-template-columns:1fr 1fr; 
  gap:20px; 
  margin-bottom:20px;
}

.dashboard-grid-2-1 { 
  display:grid; 
  grid-template-columns:2fr 1fr; 
  gap:20px; 
}

.status-dot { 
  width:8px; 
  height:8px; 
  border-radius:50%; 
  display:inline-block; 
  box-shadow: 0 0 8px currentColor; 
}

.status-dot.green { color:var(--green); }
.status-dot.amber { color:var(--amber); }
.status-dot.red { color:var(--red); }

.card-title {
  margin:0 0 16px; 
  color:var(--accent-2); 
  font-size:14px; 
  font-weight:700; 
  letter-spacing:0.5px;
  text-transform:uppercase;
}

.hero-title {
  font-size:28px;
  font-weight:900;
  margin:0 0 8px;
  background:linear-gradient(135deg, var(--text), var(--accent));
  background-clip:text;
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

.hero-subtitle {
  color:var(--muted);
  font-size:14px;
  margin:0 0 20px;
  letter-spacing:0.5px;
}

/* Responsive */
@media (max-width: 768px) {
  .hero { grid-template-columns: 1fr; }
  .kpi-grid { grid-template-columns: repeat(2,1fr); }
  .dashboard-grid-2, .dashboard-grid-2-1 { grid-template-columns: 1fr; }
}
.risk-tag.critical{ background:var(--red); border:2px solid #7f1d1d; }

/* ---------- Mobile Responsiveness ---------- */

/* Mobile Navigation */
.mobile-menu-toggle{
  display: none;
  background: none;
  border: none;
  color: var(--accent);
  font-size: 24px;
  cursor: pointer;
  padding: 8px;
}

.mobile-nav{
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  z-index: 1000;
  backdrop-filter: blur(10px);
}

.mobile-nav.active{ display: block; }

.mobile-nav-close{
  position: absolute;
  top: 16px;
  right: 16px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid var(--accent);
  color: var(--accent);
  font-size: 24px;
  cursor: pointer;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mobile-nav-content{
  position: relative;
  background: rgba(11, 16, 32, 0.95);
  backdrop-filter: blur(20px);
  margin: 60px 20px 20px 20px;
  border-radius: 16px;
  border: 1px solid var(--card-border);
  padding: 20px;
  max-height: calc(100vh - 160px);
  overflow-y: auto;
}

.mobile-nav-links{
  display: grid;
  gap: 8px;
  margin-top: 16px;
}

.mobile-nav-links a{
  display: block;
  padding: 12px 16px;
  color: var(--text);
  text-decoration: none;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid var(--card-border);
  border-radius: 8px;
  text-align: left;
  font-weight: 500;
  font-size: 14px;
  transition: all 0.2s ease;
}

.mobile-nav-links a:hover{
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--accent);
}

/* Touch-friendly buttons */
.touch-friendly{
  min-height: 44px;
  min-width: 44px;
  padding: 12px 16px !important;
}

/* Mobile-specific layouts */
@media (max-width: 768px) {
  /* Container adjustments */
  .shell{ padding: 12px; max-width: 100%; }
  
  /* Header mobile */
  .header{ 
    flex-wrap: wrap; 
    gap: 12px;
    padding-top: 12px;
  }
  
  /* Hide desktop nav, show mobile toggle */
  .nav{ display: none; }
  .mobile-menu-toggle{ display: block; }
  
  /* Typography scaling */
  h2.page-title, h2{ font-size: 20px; }
  .brand-text h1{ font-size: 18px; }
  .subtitle{ font-size: 11px; }
  
  /* Stats bar mobile */
  .stats-bar{ 
    display: grid; 
    grid-template-columns: repeat(2, 1fr); 
    gap: 8px; 
  }
  
  .stat{ 
    padding: 10px 12px; 
    text-align: center;
  }
  
  .stat-kpi{ font-size: 18px; }
  .stat-label{ font-size: 11px; }
  
  /* Forms mobile */
  .form .row{ 
    grid-template-columns: 1fr; 
    gap: 8px; 
  }
  
  .form input, .form textarea, .form select{
    padding: 14px 16px;
    font-size: 16px; /* Prevents zoom on iOS */
    border-radius: 8px;
  }
  
  /* Tables mobile - horizontal scroll */
  .table-container{
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  .table, .gap-table{
    min-width: 600px;
  }
  
  .table td, .gap-table td{
    padding: 10px 8px;
    font-size: 14px;
  }
  
  /* Truncate shorter on mobile */
  .truncate{ max-width: 200px; }
  
  /* Buttons mobile */
  button, .btn{
    padding: 14px 20px;
    font-size: 14px;
    border-radius: 8px;
    min-height: 48px;
  }
  
  /* Cards mobile */
  .container, .onepager, .card{
    border-radius: 12px;
    padding: 12px;
    margin-bottom: 12px;
  }
  
  /* Quick actions mobile */
  .quick-actions{
    display: grid;
    gap: 8px;
    grid-template-columns: 1fr;
  }
  
  .quick-action{
    padding: 16px;
    text-align: center;
  }
}

/* Tablet adjustments */
@media (max-width: 1024px) and (min-width: 769px) {
  .shell{ padding: 14px; }
  
  .stats-bar{ 
    display: grid; 
    grid-template-columns: repeat(3, 1fr); 
    gap: 10px; 
  }
  
  .form .row{ 
    grid-template-columns: repeat(2, 1fr); 
  }
}

/* Large mobile / small tablet */
@media (max-width: 480px) {
  .shell{ padding: 8px; }
  
  .stats-bar{ 
    grid-template-columns: 1fr; 
  }
  
  .brand{ gap: 8px; }
  .logo{ width: 28px; height: 28px; }
  .brand-text h1{ font-size: 16px; }
  
  /* Single column forms */
  .form .row{ grid-template-columns: 1fr; }
  
  /* Smaller cards */
  .container, .onepager, .card{
    padding: 10px;
    border-radius: 8px;
  }
}

/* Touch device optimizations */
@media (pointer: coarse) {
  /* Larger touch targets */
  .nav a, button, .btn, input, select, textarea{
    min-height: 44px;
  }
  
  /* Better hover states for touch */
  .table tr:hover td, .gap-table tr:hover td{ 
    background: transparent; 
  }
  
  .table tr:active td, .gap-table tr:active td{ 
    background: #0f162c; 
  }
}

.flag{ padding:3px 8px; border-radius:999px; font-size:12px; font-weight:800; margin-right:6px; }
.flag.commander{ background:#ef4444; color:#fff; }
.flag.systemic{ background:#60a5fa; color:#031322; }

/* Filters */
.filter{ display:flex; gap:12px; align-items:end; flex-wrap:wrap; margin:12px 0; }

/* Print (one-pager) */
@media print{
  body{ background:#fff !important; color:#000 !important; }
  .header,.footer,.nav,.stats-bar,.filter{ display:none !important; }
  .onepager,.container,.card{ border:none; box-shadow:none; background:#fff; }
  h1,h2,h3{ color:#000 !important; border-color:#000 !important; }
}

.section-title{
  margin:0 0 4px;
  padding-bottom:4px;
  border-bottom:1px solid var(--card-border);
  letter-spacing:.3px;
}