/* ═══════════════════════════════════════════════════════════
   ATHAR (أثر) — Innovation Impact Measurement Toolkit
   styles.css — Portal HUD Design System
   Supreme Legislation Committee · DGEP 2026 · C7 Innovation
   ═══════════════════════════════════════════════════════════ */

:root {
  --bg-0:#0a0f1a;--bg-1:#0f1729;--bg-2:#141e33;--bg-3:#1a2740;--bg-4:#213050;
  --border-1:#1e2d48;--border-2:#263a5a;
  --text-1:#e2eaf6;--text-2:#9aadcc;--text-3:#607a9e;
  --gold:#C9A227;--teal:#00d4aa;--cyan:#00d4ff;--green:#00e88f;--red:#ff4d5e;--amber:#ffb830;--purple:#c084fc;
  --font:'DM Sans',sans-serif;--font-head:'Orbitron',sans-serif;--font-mono:'Share Tech Mono',monospace;--font-ar:'Noto Kufi Arabic',sans-serif;
  --sidebar-w:230px;--topbar-h:54px;--radius:8px;--radius-sm:4px;
}
[data-theme="light"]{--bg-0:#f4f6f9;--bg-1:#fff;--bg-2:#fff;--bg-3:#eef1f5;--bg-4:#dde2ea;--border-1:#d4d9e2;--border-2:#bfc6d2;--text-1:#1a202c;--text-2:#4a5568;--text-3:#7b8a9e;--teal:#0a9e80;--cyan:#0088aa;--green:#059669;--gold:#9e7e2e;}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px}
body{font-family:var(--font);background:var(--bg-0);color:var(--text-1);min-height:100vh;line-height:1.6;overflow-x:hidden}
::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-1)}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:3px}
::selection{background:rgba(0,212,170,.25)}
a{color:var(--cyan);text-decoration:none;cursor:pointer}
.text-3{color:var(--text-3)}.text-ar{font-family:var(--font-ar);direction:rtl}
.mono-label{font-family:var(--font-mono);font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-3)}

/* ═══ LANDING ═══ */
.landing-overlay{position:fixed;inset:0;z-index:9999;background:var(--bg-0);display:flex;align-items:center;justify-content:center;animation:fadeUp .8s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.landing-container{text-align:center}.landing-brand{margin-bottom:40px}
.landing-logo{width:100px;height:100px;margin:0 auto 24px;position:relative;display:flex;align-items:center;justify-content:center}
.landing-logo-core{color:var(--teal);animation:pulse 3s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
.landing-orbit{position:absolute;width:90px;height:90px;border:1px solid rgba(0,212,170,.2);border-radius:50%;animation:spin 12s linear infinite}
.landing-orbit.o2{width:70px;height:70px;border-color:rgba(0,212,255,.15);animation-duration:8s;animation-direction:reverse}
.landing-orbit-dot{position:absolute;top:-3px;left:50%;transform:translateX(-50%);width:6px;height:6px;background:var(--teal);border-radius:50%;box-shadow:0 0 8px var(--teal)}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.landing-title{font-family:var(--font-head);font-size:36px;font-weight:800;letter-spacing:8px;color:var(--text-1);text-shadow:0 0 30px rgba(0,212,170,.15)}
.landing-subtitle-ar{font-family:var(--font-ar);font-size:28px;color:var(--teal);margin:4px 0 8px;opacity:.9}
.landing-subtitle{font-family:var(--font-mono);font-size:11px;letter-spacing:3px;color:var(--text-3);text-transform:uppercase}
.landing-meta{font-family:var(--font-mono);font-size:9px;letter-spacing:1.5px;color:var(--text-3);margin-top:8px}
.landing-enter-btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--teal),var(--cyan));color:var(--bg-0);border:none;padding:14px 36px;border-radius:30px;font-family:var(--font-head);font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .3s;margin-bottom:16px;box-shadow:0 4px 20px rgba(0,212,170,.3)}
.landing-enter-btn:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(0,212,170,.4)}
.landing-folder-btn{display:inline-flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--border-2);color:var(--text-3);padding:8px 20px;border-radius:20px;font-family:var(--font-mono);font-size:10px;letter-spacing:1px;cursor:pointer;transition:all .3s}
.landing-folder-btn:hover{border-color:var(--teal);color:var(--teal)}

/* ═══ APP LAYOUT ═══ */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;grid-template-areas:"sidebar topbar" "sidebar content";min-height:100vh}

/* ═══ SIDEBAR ═══ */
.sidebar{grid-area:sidebar;background:var(--bg-1);border-right:1px solid var(--border-1);display:flex;flex-direction:column;z-index:100;overflow:hidden}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border-1)}
.brand-logo{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,212,170,.1),rgba(0,212,255,.1));border-radius:8px;color:var(--teal);flex-shrink:0}
.brand-text-primary{font-family:var(--font-head);font-size:14px;font-weight:700;letter-spacing:2px;color:var(--text-1)}
.brand-text-sub{font-family:var(--font-mono);font-size:8px;letter-spacing:1.5px;color:var(--text-3);text-transform:uppercase}
.sidebar-nav{flex:1;padding:8px;overflow-y:auto;display:flex;flex-direction:column;gap:1px}
.nav-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-2);font-size:12.5px;font-family:var(--font);cursor:pointer;transition:all .2s;text-align:left;border-left:2px solid transparent}
.nav-btn:hover{background:var(--bg-3);color:var(--text-1)}.nav-btn.active{background:linear-gradient(135deg,rgba(0,212,170,.12),rgba(0,212,255,.08));color:var(--teal);border-left-color:var(--teal)}
.nav-divider{padding:12px 12px 4px;font-family:var(--font-mono);font-size:8px;letter-spacing:2px;color:var(--text-3);text-transform:uppercase;border-top:1px solid var(--border-1);margin-top:4px}
.sidebar-footer{padding:10px 16px;border-top:1px solid var(--border-1)}
.fs-status{display:flex;align-items:center;gap:8px;cursor:pointer;padding:3px 0}
.fs-dot{width:7px;height:7px;border-radius:50%;background:var(--text-3);flex-shrink:0;transition:all .3s}
.fs-dot.connected{background:var(--green);box-shadow:0 0 6px var(--green)}
#fsLabel{font-family:var(--font-mono);font-size:9px;color:var(--text-3)}
.sidebar-meta{font-family:var(--font-mono);font-size:9px;color:var(--text-3);margin-top:4px}

/* ═══ TOPBAR ═══ */
.topbar{grid-area:topbar;background:var(--bg-1);border-bottom:1px solid var(--border-1);display:flex;align-items:center;padding:0 20px;gap:16px}
.topbar-toggle{display:none;background:none;border:none;color:var(--text-2);font-size:18px;cursor:pointer}
.topbar-info{flex:1}.topbar-title{font-family:var(--font-head);font-size:13px;font-weight:600;letter-spacing:1.5px;color:var(--text-1)}
.topbar-sub{font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.5px}
.topbar-actions{display:flex;gap:6px}
.icon-btn{width:34px;height:34px;background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s;color:var(--text-2)}
.icon-btn:hover{background:var(--bg-4);border-color:var(--border-2)}

/* ═══ CONTENT ═══ */
.content{grid-area:content;padding:20px 24px;overflow-y:auto;max-height:calc(100vh - var(--topbar-h))}
.page{display:none;animation:fadeIn .3s ease}.page.show{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ═══ DASHBOARD ═══ */
.dash-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:16px;flex-wrap:wrap}
.hud-title{font-family:var(--font-head);font-size:18px;font-weight:700;letter-spacing:3px;margin:0}
.hud-sub{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:3px}
.dash-quick-stats{display:flex;gap:16px}
.qs{text-align:center;font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--teal)}
.qs span{display:block;font-family:var(--font-mono);font-size:8px;color:var(--text-3);letter-spacing:.5px;font-weight:400;margin-top:2px}

/* Gauge Grid */
.gauge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:14px;margin-bottom:20px}
.gauge-card{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:16px;text-align:center;transition:all .2s}
.gauge-card:hover{border-color:var(--border-2);box-shadow:0 0 12px rgba(0,212,255,.08)}
.gauge-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.gauge-icon{font-size:20px}.gauge-grade{font-family:var(--font-head);font-size:10px;letter-spacing:2px;font-weight:700}
.gauge-ring-wrap{width:110px;height:110px;margin:0 auto 10px;position:relative;display:flex;align-items:center;justify-content:center}
.gauge-svg{width:100%;height:100%}.gauge-arc{transition:stroke-dasharray .8s ease}
.gauge-value{position:absolute;font-family:var(--font-head);font-size:22px;font-weight:800;letter-spacing:1px}
.gauge-name{font-size:12px;font-weight:600;color:var(--text-1)}.gauge-name-ar{font-family:var(--font-ar);font-size:10px;color:var(--text-3);direction:rtl;margin-top:2px}
.gauge-targets{display:flex;justify-content:center;gap:12px;margin-top:8px;font-family:var(--font-mono);font-size:8px;color:var(--text-3)}
.gauge-detail{font-size:10px;color:var(--text-3);margin-top:8px;line-height:1.5;min-height:28px}

.dash-bottom{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:4px}
.dash-panel{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:14px}
.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-1)}
.panel-title{font-size:12px;font-weight:600;color:var(--text-1)}
.recent-item{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border-1)}
.recent-item:last-child{border:none}.recent-cat{font-size:16px}
.recent-info{flex:1}.recent-name{font-size:12px;font-weight:500;color:var(--text-1)}.recent-meta{font-size:9px;color:var(--text-3);font-family:var(--font-mono)}
.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.status-pill{font-family:var(--font-mono);font-size:9px;letter-spacing:.5px}
.empty-msg{font-size:12px;color:var(--text-3);padding:16px 0;text-align:center}
.sbar{display:flex;align-items:center;gap:10px;padding:5px 0}
.sbar-label{font-size:10px;color:var(--text-2);width:130px;flex-shrink:0}
.sbar-track{flex:1;height:5px;background:var(--bg-4);border-radius:3px;overflow:hidden}
.sbar-fill{height:100%;border-radius:3px;transition:width .5s}
.sbar-num{font-family:var(--font-mono);font-size:11px;color:var(--text-1);width:30px;text-align:right}

/* ═══ PAGE ACTIONS ═══ */
.page-actions{display:flex;align-items:center;gap:12px;margin-bottom:16px}

/* ═══ PROJECTS ═══ */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}
.proj-card{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:14px;transition:all .2s}
.proj-card:hover{border-color:var(--border-2)}
.proj-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.proj-cat{font-size:11px;color:var(--text-3)}.proj-name{font-size:14px;font-weight:600;color:var(--text-1)}
.proj-name-ar{font-family:var(--font-ar);font-size:11px;color:var(--text-3);direction:rtl;margin-top:2px}
.proj-dept{font-size:10px;color:var(--text-3);margin:4px 0}
.proj-desc{font-size:11px;color:var(--text-2);line-height:1.5;margin:6px 0}
.proj-measurements{display:flex;gap:12px;font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:8px;padding-top:8px;border-top:1px solid var(--border-1)}
.proj-actions{display:flex;gap:6px;margin-top:8px}

/* ═══ MEASUREMENT PAGES (Financial, Operational, Stakeholder) ═══ */
.measure-header{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:20px;padding:16px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius)}
.measure-kpi-live{text-align:center;min-width:140px}
.kpi-big{font-family:var(--font-head);font-size:36px;font-weight:800;letter-spacing:1px}
.kpi-label{font-size:11px;color:var(--text-2);margin-top:4px}
.kpi-label .text-ar{font-size:9px;color:var(--text-3)}
.kpi-target{font-family:var(--font-mono);font-size:8px;color:var(--text-3);margin-top:6px;letter-spacing:.5px}
.measure-stats{display:flex;gap:16px;flex:1;justify-content:center}
.ms{text-align:center;font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--text-1)}
.ms span{display:block;font-family:var(--font-mono);font-size:8px;color:var(--text-3);font-weight:400;margin-top:2px;letter-spacing:.5px}

.measure-table-wrap{overflow-x:auto}
.measure-table{width:100%;border-collapse:collapse;background:var(--bg-2);border-radius:var(--radius);overflow:hidden}
.measure-table th{background:var(--bg-3);font-family:var(--font-mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--text-3);padding:9px 10px;text-align:left;border-bottom:1px solid var(--border-1)}
.measure-table td{padding:8px 10px;border-bottom:1px solid var(--border-1);font-size:12px;color:var(--text-2);vertical-align:middle}
.measure-table tr:hover td{background:var(--bg-3)}
.num{font-family:var(--font-mono);font-size:12px;text-align:right}
.note-cell{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11px;color:var(--text-3)}

.formula-box{margin-top:12px;padding:10px 14px;background:var(--bg-2);border:1px solid var(--border-1);border-left:3px solid var(--teal);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:11px;color:var(--text-2)}
.formula-box .mono-label{margin-right:6px;color:var(--teal)}

/* Live calculation in forms */
.live-calc{margin-top:4px}.live-result{padding:10px;background:var(--bg-3);border-radius:var(--radius-sm);font-size:13px;color:var(--text-2)}
.live-result strong{font-family:var(--font-head);font-size:18px;letter-spacing:1px}

/* ═══ STRATEGIC ═══ */
.strategic-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.strat-panel{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:14px}
.goal-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-1)}
.goal-row:last-child{border:none}
.goal-name{font-size:12px;font-weight:500;color:var(--text-1)}.goal-name-ar{font-family:var(--font-ar);font-size:9px;color:var(--text-3);direction:rtl;margin-top:2px}
.goal-count{font-family:var(--font-mono);font-size:10px;color:var(--teal)}
.align-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-1)}
.align-row:last-child{border:none}
.align-row.unaligned{opacity:.6}.align-proj{font-size:12px;flex-shrink:0;min-width:120px}
.align-goals{display:flex;gap:4px;flex-wrap:wrap}
.goal-tag{font-family:var(--font-mono);font-size:8px;background:rgba(0,212,170,.1);color:var(--teal);padding:2px 8px;border-radius:8px}
.no-goals{font-size:10px;color:var(--amber)}
.goal-checks{display:flex;flex-direction:column;gap:6px}
.goal-check{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--text-2);cursor:pointer}
.goal-check input{margin-top:3px}

/* ═══ ANALYTICS ═══ */
.analytics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:16px}
.ana-card{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:16px;transition:all .2s}
.ana-card:hover{border-color:var(--border-2)}
.ana-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:12px;font-weight:600;color:var(--text-2)}
.ana-grade{font-family:var(--font-head);font-size:10px;letter-spacing:2px;font-weight:700}
.ana-value{font-family:var(--font-head);font-size:28px;font-weight:800;letter-spacing:1px;text-align:center;margin:8px 0}
.ana-targets{margin:10px 0}.target-bar{position:relative;height:4px;background:var(--bg-4);border-radius:2px;margin:16px 0 8px}
.target-marker{position:absolute;top:-8px;width:2px;height:20px;background:var(--amber)}
.target-marker span{position:absolute;top:-12px;left:-8px;font-family:var(--font-mono);font-size:7px;color:var(--text-3);white-space:nowrap}
.target-marker.y2{background:var(--cyan)}.target-marker.elite{background:var(--gold)}
.target-current{position:absolute;top:-2px;width:8px;height:8px;border-radius:50%;transform:translateX(-50%)}
.ana-trend{margin-top:10px}.trend-svg{width:100%}.ana-trend-empty{font-size:9px;color:var(--text-3);text-align:center;padding:8px}
.ana-actions{display:flex;gap:10px}

/* ═══ REPORT ═══ */
.report-controls{display:flex;gap:10px;margin-bottom:16px}
.report-preview{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius);padding:32px;max-width:900px}
.rpt-cover{text-align:center;padding:40px 20px;border-bottom:2px solid var(--teal);margin-bottom:28px}
.rpt-badge{display:inline-block;background:var(--bg-4);color:var(--teal);font-family:var(--font-head);font-size:10px;letter-spacing:3px;padding:6px 20px;border-radius:20px;margin-bottom:16px}
.rpt-cover h1{font-family:var(--font-head);font-size:20px;margin:12px 0 8px;color:var(--text-1);letter-spacing:1px}
.rpt-cover h2{font-family:var(--font-ar);font-size:16px;color:var(--teal);direction:rtl}
.rpt-meta{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:16px;line-height:1.8}
.rpt-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border-1)}
.rpt-section h3{font-family:var(--font-head);font-size:12px;letter-spacing:1px;color:var(--text-1);margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid var(--teal)}
.rpt-section h4{font-family:var(--font-mono);font-size:10px;letter-spacing:1px;color:var(--teal);text-transform:uppercase;margin:12px 0 4px}
.rpt-section p{font-size:12px;color:var(--text-2);line-height:1.7}.rpt-section em{color:var(--text-3)}
.rpt-footer{text-align:center;margin-top:32px;padding-top:16px;border-top:2px solid var(--border-1);font-family:var(--font-mono);font-size:9px;color:var(--text-3)}

/* ═══ AI CHAT ═══ */
.chat-container{display:flex;flex-direction:column;height:calc(100vh - var(--topbar-h) - 48px);max-width:800px}
.chat-messages{flex:1;overflow-y:auto;padding:12px 0;display:flex;flex-direction:column;gap:10px}
.chat-msg{display:flex;gap:8px;align-items:flex-start;max-width:85%}
.chat-msg.user{align-self:flex-end;flex-direction:row-reverse}
.chat-avatar{font-size:18px;flex-shrink:0}
.chat-bubble{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:10px 14px;font-size:12.5px;line-height:1.6;color:var(--text-1)}
.chat-msg.user .chat-bubble{background:linear-gradient(135deg,rgba(0,212,170,.1),rgba(0,212,255,.06));border-color:rgba(0,212,170,.2)}
.chat-welcome{text-align:center;padding:40px 20px}.chat-welcome-icon{font-size:40px;margin-bottom:10px}
.chat-welcome h3{font-family:var(--font-head);font-size:14px;letter-spacing:1px;margin-bottom:6px}
.chat-welcome p{font-size:11px;color:var(--text-2);max-width:400px;margin:0 auto 14px}
.chat-suggestions{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}
.chat-sug{background:var(--bg-3);border:1px solid var(--border-2);color:var(--text-2);padding:5px 12px;border-radius:14px;font-size:10px;cursor:pointer;transition:all .2s}
.chat-sug:hover{background:var(--bg-4);color:var(--teal);border-color:var(--teal)}
.chat-input-row{display:flex;gap:8px;padding-top:10px;border-top:1px solid var(--border-1)}
.chat-input{flex:1;resize:none;height:42px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:10px 12px;color:var(--text-1);font-family:var(--font);font-size:12.5px}
.chat-input:focus{outline:none;border-color:var(--teal)}

/* ═══ SETTINGS ═══ */
.settings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.settings-panel{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:16px}
.settings-actions{display:flex;flex-direction:column;gap:6px}
.target-inputs{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--text-3)}

/* ═══ FORMS ═══ */
.form-stack{display:flex;flex-direction:column;gap:12px}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-2col .full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:4px}
.form-group label{font-family:var(--font-mono);font-size:10px;letter-spacing:.8px;color:var(--text-3);text-transform:uppercase}
.field-input,.field-select,.field-textarea{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);color:var(--text-1);font-family:var(--font);font-size:12px;padding:8px 10px;transition:border-color .2s;width:100%}
.field-input:focus,.field-select:focus,.field-textarea:focus{outline:none;border-color:var(--teal)}
.field-input.xs{padding:4px 6px;font-size:11px;width:60px}
.field-textarea{min-height:56px;resize:vertical}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-sm);font-family:var(--font);font-size:12px;font-weight:500;border:1px solid var(--border-2);background:var(--bg-3);color:var(--text-2);cursor:pointer;transition:all .2s}
.btn:hover{background:var(--bg-4);color:var(--text-1)}
.btn-primary{background:linear-gradient(135deg,var(--teal),var(--cyan));color:var(--bg-0);border:none;font-weight:600}
.btn-primary:hover{opacity:.9}
.btn-ai{border-color:var(--purple);color:var(--purple)}.btn-ai:hover{background:rgba(192,132,252,.1)}
.btn-danger{border-color:var(--red);color:var(--red)}.btn-danger:hover{background:rgba(255,77,94,.1)}
.btn-sm{padding:4px 8px;font-size:10px;background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);color:var(--text-2);cursor:pointer;transition:all .2s}
.btn-sm:hover{background:var(--bg-4)}.btn-sm.btn-danger{border-color:var(--red);color:var(--red)}.btn-sm.btn-ai{border-color:var(--purple);color:var(--purple)}

/* ═══ MODAL ═══ */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);z-index:1000}.modal-backdrop.show{display:block}
.modal{display:none;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001;max-width:92vw;max-height:90vh;overflow:auto}
.modal.show{display:block;animation:modalIn .2s ease}
@keyframes modalIn{from{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}
.modal-content{background:var(--bg-1);border:1px solid var(--border-1);border-radius:var(--radius);width:520px;max-width:92vw;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.modal-content.modal-lg{width:680px}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:2px solid var(--teal)}
.modal-header h3{font-family:var(--font-head);font-size:12px;letter-spacing:1px;color:var(--text-1)}
.modal-close{background:none;border:none;color:var(--text-3);font-size:18px;cursor:pointer}.modal-close:hover{color:var(--text-1)}
.modal-body{padding:16px 18px}.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border-1)}

/* AI Result */
.ai-result{}.ai-block{margin-bottom:14px}
.ai-block h4{font-family:var(--font-mono);font-size:10px;letter-spacing:1px;color:var(--teal);text-transform:uppercase;margin-bottom:6px}
.ai-block p{font-size:12px;color:var(--text-2);line-height:1.6}
.ai-item{padding:5px 0 5px 12px;font-size:12px;color:var(--text-2);border-left:2px solid var(--border-2);margin-bottom:4px}
.ai-item.good{border-color:var(--green)}.ai-item.warn{border-color:var(--amber)}
.ai-score{display:flex;align-items:center;gap:18px;margin-bottom:18px;padding:14px;background:var(--bg-2);border-radius:var(--radius)}
.score-ring{width:72px;height:72px;border-radius:50%;background:conic-gradient(var(--teal) calc(var(--s)*1%),var(--bg-4) 0%);display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.score-ring::after{content:'';position:absolute;width:58px;height:58px;border-radius:50%;background:var(--bg-2)}
.score-ring span{position:relative;z-index:1;font-family:var(--font-head);font-size:20px;font-weight:800;color:var(--teal)}
.readiness{font-family:var(--font-head);font-size:16px;font-weight:700;color:var(--text-1);letter-spacing:1px}

/* ═══ TOAST ═══ */
.toast-container{position:fixed;bottom:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:6px}
.toast{padding:9px 16px;border-radius:var(--radius);font-size:11px;font-weight:500;color:var(--text-1);background:var(--bg-2);border:1px solid var(--border-1);box-shadow:0 2px 12px rgba(0,0,0,.3);transform:translateX(120%);transition:transform .3s}
.toast.show{transform:translateX(0)}
.toast-success{border-color:var(--green);color:var(--green)}.toast-error{border-color:var(--red);color:var(--red)}.toast-info{border-color:var(--cyan);color:var(--cyan)}

/* ═══ METHODOLOGY / MANUAL ═══ */
.meth-manual{max-width:920px}

.meth-cover{text-align:center;padding:36px 20px;border-bottom:2px solid var(--teal);margin-bottom:28px}
.meth-badge{display:inline-block;background:var(--bg-4);color:var(--teal);font-family:var(--font-head);font-size:9px;letter-spacing:3px;padding:5px 18px;border-radius:16px;margin-bottom:14px}
.meth-cover h1{font-family:var(--font-head);font-size:18px;letter-spacing:2px;color:var(--text-1);margin:8px 0}
.meth-cover h2{font-family:var(--font-ar);font-size:16px;color:var(--teal);direction:rtl;margin-bottom:12px}
.meth-cover-meta{display:flex;flex-direction:column;gap:2px;font-family:var(--font-mono);font-size:9px;color:var(--text-3)}

.meth-toc{background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);padding:18px;margin-bottom:24px}
.meth-toc-title{font-family:var(--font-head);font-size:12px;letter-spacing:1.5px;color:var(--text-1);margin-bottom:14px}
.meth-toc-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.meth-toc-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;font-size:12px;color:var(--text-2)}
.meth-toc-item:hover{background:var(--bg-3);color:var(--teal)}
.toc-num{font-family:var(--font-head);font-size:11px;color:var(--teal);min-width:24px;font-weight:700}
.toc-ar{font-size:9px;color:var(--text-3);margin-left:auto}

.meth-section{margin-bottom:28px;padding:20px;background:var(--bg-2);border:1px solid var(--border-1);border-radius:var(--radius);position:relative}
.meth-section-num{position:absolute;top:16px;right:16px;font-family:var(--font-head);font-size:28px;font-weight:900;color:var(--bg-4);letter-spacing:2px;opacity:.6;pointer-events:none}
.meth-section h3{font-family:var(--font-head);font-size:13px;letter-spacing:1.5px;color:var(--text-1);margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--teal)}
.meth-section h3 .text-ar{font-size:11px;color:var(--teal);margin-left:8px;font-weight:400}
.meth-body{font-size:12.5px;color:var(--text-2);line-height:1.8}
.meth-body p{margin-bottom:10px}.meth-body ul{margin:6px 0 12px 16px}.meth-body li{margin-bottom:4px}
.meth-body strong{color:var(--text-1)}.meth-body em{color:var(--text-3);font-style:italic}

.meth-callout{background:var(--bg-3);border:1px solid var(--border-2);border-left:3px solid var(--cyan);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:12px 16px;margin:12px 0}
.meth-callout.purpose{border-left-color:var(--teal)}
.meth-callout-title{font-family:var(--font-mono);font-size:10px;letter-spacing:1px;color:var(--teal);text-transform:uppercase;margin-bottom:6px;font-weight:600}
.meth-callout p{margin-bottom:0;font-size:12px}

.meth-two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.meth-box{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);padding:12px}
.meth-box-title{font-family:var(--font-mono);font-size:10px;letter-spacing:1px;color:var(--text-1);font-weight:600;margin-bottom:8px}

/* Dimension Cards */
.meth-dim-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.meth-dim-card{background:var(--bg-3);border:1px solid var(--border-1);border-top:3px solid var(--dim-color);border-radius:var(--radius);padding:14px;transition:all .2s}
.meth-dim-card:hover{border-color:var(--dim-color)}
.meth-dim-icon{font-size:26px;margin-bottom:6px}
.meth-dim-name{font-size:13px;font-weight:600;color:var(--text-1);margin-bottom:6px;line-height:1.4}
.meth-dim-name .text-ar{font-size:10px;color:var(--text-3)}
.meth-dim-desc{font-size:11px;color:var(--text-2);line-height:1.6;margin-bottom:8px}
.meth-dim-axis,.meth-dim-owner{font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.5px}

/* Workflow Steps */
.meth-workflow{margin-top:8px}
.meth-step{display:flex;gap:16px;margin-bottom:4px;position:relative;padding-bottom:16px}
.meth-step:not(:last-child)::before{content:'';position:absolute;left:17px;top:36px;bottom:0;width:2px;background:var(--border-1)}
.meth-step-num{width:36px;height:36px;flex-shrink:0;background:linear-gradient(135deg,var(--teal),var(--cyan));color:var(--bg-0);font-family:var(--font-head);font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;border-radius:50%;z-index:1}
.meth-step-content{flex:1;padding-top:2px}
.meth-step-title{font-size:14px;font-weight:600;color:var(--text-1);margin-bottom:3px}
.meth-step-page{font-family:var(--font-mono);font-size:9px;color:var(--text-3);margin-bottom:8px}
.meth-step-page a{color:var(--teal);cursor:pointer}
.meth-step-content p{font-size:12px;color:var(--text-2);margin-bottom:6px}
.meth-step-content ul{margin:4px 0 8px 16px;font-size:12px;color:var(--text-2)}
.meth-step-content li{margin-bottom:2px}
.meth-step-tip{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);padding:8px 10px;font-size:11px;color:var(--text-2);margin-top:6px}
.meth-step-tip strong{color:var(--amber)}

/* KPI Table */
.meth-kpi-table{overflow-x:auto;margin:12px 0}
.meth-kpi-table table{width:100%;border-collapse:collapse;background:var(--bg-3);border-radius:var(--radius);overflow:hidden;font-size:11px}
.meth-kpi-table th{background:var(--bg-4);font-family:var(--font-mono);font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);padding:8px 10px;text-align:left;border-bottom:1px solid var(--border-1)}
.meth-kpi-table td{padding:8px 10px;border-bottom:1px solid var(--border-1);color:var(--text-2);vertical-align:top}
.meth-kpi-table .formula{font-family:var(--font-mono);font-size:10px;color:var(--cyan)}
.meth-kpi-table .elite{color:var(--gold);font-weight:700}
.meth-grade-row{font-size:12px;color:var(--text-2);margin-top:4px}
.meth-grade{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1px}

/* Data Collection Cards */
.meth-dc-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.meth-dc-card{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius);overflow:hidden}
.meth-dc-header{padding:10px 14px;font-size:12px;font-weight:600;color:var(--text-1);border-bottom:3px solid var(--border-2)}
.meth-dc-body{padding:12px 14px;font-size:11px;color:var(--text-2);line-height:1.7}
.meth-dc-body ul{margin:4px 0 8px 14px}.meth-dc-body li{margin-bottom:2px}
.meth-dc-label{font-family:var(--font-mono);font-size:9px;letter-spacing:1px;color:var(--teal);text-transform:uppercase;margin:8px 0 3px;font-weight:600}
.meth-dc-label:first-child{margin-top:0}

/* Evidence List */
.meth-evidence-list{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.meth-ev-item{display:flex;gap:12px;padding:12px;background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm)}
.meth-ev-check{font-size:18px;flex-shrink:0}
.meth-ev-title{font-size:13px;font-weight:600;color:var(--text-1);margin-bottom:3px}
.meth-ev-detail{font-size:11px;color:var(--text-2);line-height:1.6}
.meth-ev-ar{font-size:10px;color:var(--text-3);margin-top:4px}

/* Maturity Model */
.meth-maturity{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.meth-mat-level{display:flex;align-items:flex-start;gap:14px;padding:12px;background:var(--bg-3);border:1px solid var(--border-1);border-left:4px solid var(--mat-color);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.meth-mat-badge{font-family:var(--font-head);font-size:9px;letter-spacing:1px;color:var(--mat-color);min-width:50px;flex-shrink:0;font-weight:700;padding-top:2px}
.meth-mat-name{font-size:13px;font-weight:600;color:var(--text-1);margin-bottom:3px}
.meth-mat-name .text-ar{font-size:10px;color:var(--text-3);margin-left:6px;font-weight:400}
.meth-mat-desc{font-size:11px;color:var(--text-2);line-height:1.6}

/* AIRL Grid */
.meth-airl-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.meth-airl-card{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius);padding:14px;display:flex;gap:12px}
.meth-airl-letter{font-family:var(--font-head);font-size:28px;font-weight:900;color:var(--teal);line-height:1;flex-shrink:0;opacity:.8}
.meth-airl-name{font-size:12px;font-weight:600;color:var(--text-1);margin-bottom:4px}
.meth-airl-desc{font-size:11px;color:var(--text-2);line-height:1.6}
.meth-airl-desc strong{color:var(--teal);font-size:10px;font-family:var(--font-mono)}

/* Roles Table */
.meth-roles-table{overflow-x:auto;margin-top:8px}
.meth-roles-table table{width:100%;border-collapse:collapse;background:var(--bg-3);border-radius:var(--radius);overflow:hidden;font-size:11px}
.meth-roles-table th{background:var(--bg-4);font-family:var(--font-mono);font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);padding:8px 10px;text-align:left;border-bottom:1px solid var(--border-1)}
.meth-roles-table td{padding:8px 10px;border-bottom:1px solid var(--border-1);color:var(--text-2);vertical-align:top}

/* Tool Guide Cards */
.meth-tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px}
.meth-tool-card{background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius);padding:14px;text-align:center}
.meth-tool-icon{font-size:24px;margin-bottom:6px}
.meth-tool-name{font-size:12px;font-weight:600;color:var(--text-1);margin-bottom:6px}
.meth-tool-card p{font-size:10.5px;color:var(--text-2);line-height:1.6;text-align:left}

/* Section EN subtitle */
.meth-section-en{font-size:10px;color:var(--cyan);margin-left:8px;font-weight:400;letter-spacing:.5px}

/* Classification badge */
.meth-classification{display:inline-block;background:var(--cyan);color:var(--bg-0);font-family:var(--font-mono);font-size:9px;letter-spacing:1px;padding:3px 14px;border-radius:2px;font-weight:600}

/* TOC list (single column) */
.meth-toc-list{display:flex;flex-direction:column;gap:2px}
.toc-en{margin-left:auto;font-size:10px;color:var(--text-3);font-family:var(--font)}

/* Approval table */
.meth-approval-table table{width:100%;border-collapse:collapse;background:var(--bg-3);border-radius:var(--radius);overflow:hidden;font-size:11px}
.meth-approval-table th,.meth-approval-table td{padding:10px 12px;border:1px solid var(--border-1);text-align:center;vertical-align:middle}
.meth-approval-table th{background:var(--bg-4);font-family:var(--font-mono);font-size:9px;letter-spacing:.5px;color:var(--text-3)}
.meth-approval-table td{color:var(--text-2);min-height:40px}
.meth-approval-table .row-label{background:var(--bg-4);font-weight:600;color:var(--teal);text-align:right;font-size:10px;min-width:80px}

/* Objectives list */
.meth-obj-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.meth-obj{display:flex;gap:12px;padding:10px 12px;background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm)}
.meth-obj-num{width:28px;height:28px;flex-shrink:0;background:linear-gradient(135deg,var(--teal),var(--cyan));color:var(--bg-0);font-family:var(--font-head);font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;border-radius:50%}
.meth-obj div{font-size:11.5px;color:var(--text-2);line-height:1.6}
.meth-obj strong{color:var(--text-1)}

/* Provisions list */
.meth-provisions{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.meth-prov{display:flex;gap:12px;padding:10px 12px;background:var(--bg-3);border:1px solid var(--border-1);border-left:3px solid var(--cyan);border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.meth-prov>span{font-family:var(--font-head);font-size:11px;font-weight:700;color:var(--cyan);min-width:18px;padding-top:2px}
.meth-prov div{font-size:11.5px;color:var(--text-2);line-height:1.6}
.meth-prov strong{color:var(--text-1)}

/* Definition groups */
.meth-def-group{margin-bottom:18px}
.meth-def-group-title{font-family:var(--font-mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal);font-weight:600;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border-1)}
.meth-def-table{overflow-x:auto}
.meth-def-table table{width:100%;border-collapse:collapse;background:var(--bg-3);border-radius:var(--radius);overflow:hidden;font-size:11px}
.meth-def-table th{background:var(--bg-4);font-family:var(--font-mono);font-size:9px;letter-spacing:.8px;text-transform:uppercase;color:var(--text-3);padding:8px 10px;text-align:left;border-bottom:1px solid var(--border-1)}
.meth-def-table td{padding:8px 10px;border-bottom:1px solid var(--border-1);color:var(--text-2);vertical-align:top}

/* References list */
.meth-ref-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.meth-ref{padding:8px 12px;background:var(--bg-3);border:1px solid var(--border-1);border-radius:var(--radius-sm);font-size:11.5px;color:var(--text-2);line-height:1.6}
.meth-ref .text-ar{font-size:10px;color:var(--text-3);display:block;margin-top:2px}

.meth-manual-footer{text-align:center;margin-top:28px;padding-top:16px;border-top:2px solid var(--border-1);font-family:var(--font-mono);font-size:9px;color:var(--text-3);line-height:1.8}

/* ═══ RESPONSIVE ═══ */
@media(max-width:768px){
  .app{grid-template-columns:1fr;grid-template-areas:"topbar" "content"}
  .sidebar{position:fixed;left:-270px;top:0;bottom:0;width:260px;z-index:200;transition:left .3s}
  .sidebar.open{left:0}
  .topbar-toggle{display:block}.content{padding:14px}
  .dash-bottom,.strategic-grid{grid-template-columns:1fr}
  .gauge-grid,.proj-grid,.analytics-grid,.settings-grid{grid-template-columns:1fr}
  .measure-header{flex-direction:column;text-align:center}
  .measure-stats{flex-wrap:wrap}.form-2col{grid-template-columns:1fr}
  .meth-two-col,.meth-dim-grid,.meth-dc-grid,.meth-airl-grid{grid-template-columns:1fr}
  .meth-tool-grid{grid-template-columns:1fr 1fr}.meth-toc-grid{grid-template-columns:1fr}
}
