:root {
  --bg-deep: #07111F; --bg-card: #0A1628; --bg-surface: #0D1B2E; --bg-hover: #112240;
  --border: rgba(255,255,255,.06); --border-active: rgba(201,168,76,.3);
  --gold: #C9A84C; --gold-light: #E8D5A3; --gold-dim: rgba(201,168,76,.15);
  --blue: #4A90D9; --blue-dim: rgba(74,144,217,.15);
  --green: #34D399; --green-dim: rgba(52,211,153,.12);
  --amber: #F59E0B; --amber-dim: rgba(245,158,11,.12);
  --red: #EF4444; --red-dim: rgba(239,68,68,.12);
  --text: #E2E8F0; --text-dim: #64748B; --text-muted: #475569;
  --font-ui: 'Inter', system-ui, sans-serif;
  --font-head: 'Cormorant Garamond', serif;
  --radius: 16px; --radius-sm: 10px;
  --shadow: 0 4px 24px rgba(0,0,0,.35), 0 1px 3px rgba(0,0,0,.25);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.5), 0 2px 8px rgba(0,0,0,.3);
  --glow-gold: 0 0 20px rgba(201,168,76,.15);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-ui);background:var(--bg-deep);color:var(--text);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--text-dim);text-decoration:none;transition:color .2s}a:hover{color:#fff}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:3px}

/* Blueprint BG */
body::before{content:'';position:fixed;inset:0;background-image:
  linear-gradient(rgba(74,144,217,.03) 1px,transparent 1px),
  linear-gradient(90deg,rgba(74,144,217,.03) 1px,transparent 1px);
  background-size:40px 40px;pointer-events:none;z-index:0}

/* ── HEADER ── */
.ctl-hdr{background:rgba(7,17,31,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.ctl-hdr__inner{max-width:1400px;margin:0 auto;padding:12px 28px;display:flex;align-items:center;gap:20px}
.ctl-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.ctl-brand__text{font-family:var(--font-ui);font-weight:800;font-size:18px;color:#fff;letter-spacing:1px}
.ctl-brand__text small{font-weight:400;color:var(--gold);margin-left:4px;font-size:12px}
.ctl-nav{display:flex;gap:4px;margin-left:auto}
.ctl-nav a{padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text-dim);transition:all .2s}
.ctl-nav a:hover{background:var(--bg-hover);color:var(--text)}
.ctl-nav a.active{background:var(--gold-dim);color:var(--gold);font-weight:600}
.ctl-right{display:flex;align-items:center;gap:14px;margin-left:16px}
.lang-switch{display:flex;gap:2px;background:var(--bg-surface);border-radius:8px;padding:2px;border:1px solid var(--border)}
.lang-switch button{background:none;border:none;color:var(--text-dim);font-size:11px;font-weight:600;padding:4px 8px;border-radius:6px;cursor:pointer;font-family:var(--font-ui);transition:all .2s}
.lang-switch button.active{background:var(--gold-dim);color:var(--gold)}
.lang-switch button:hover:not(.active){color:var(--text)}
.ctl-user{display:flex;align-items:center;gap:6px;color:var(--text-dim);font-size:13px}
.btn-logout{background:none;border:1px solid var(--border);color:var(--text-dim);padding:6px 12px;border-radius:8px;font-size:11px;cursor:pointer;font-family:var(--font-ui);font-weight:500;transition:all .2s}
.btn-logout:hover{border-color:var(--red);color:var(--red)}

/* ── LOADING ── */
.ctl-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;color:var(--text-dim);position:relative;z-index:1}
.ctl-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ctl-error{text-align:center;padding:80px 24px;color:var(--red);font-size:16px;position:relative;z-index:1}

/* ── PAGE ── */
.ctl-page{max-width:1400px;margin:0 auto;padding:32px 28px;display:grid;gap:24px;position:relative;z-index:1}

/* ── HERO ── */
.ctl-hero{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.ctl-hero__bg{position:absolute;inset:0;background:linear-gradient(135deg,#0F2040 0%,#1A3060 40%,#0D1B2E 100%);z-index:0}
.ctl-hero__bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 80% 20%,rgba(201,168,76,.08),transparent 60%)}
.ctl-hero__content{position:relative;z-index:1;padding:36px;display:flex;justify-content:space-between;align-items:center;gap:32px}
.ctl-hero__eyebrow{display:flex;align-items:center;gap:8px;font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--gold);margin-bottom:12px;font-weight:600}
.ctl-hero__title{font-family:var(--font-head);font-size:clamp(26px,4vw,38px);font-weight:700;color:#fff;line-height:1.15;margin-bottom:14px}
.ctl-hero__meta{display:flex;flex-wrap:wrap;align-items:center;gap:16px;font-size:13px;color:var(--text-dim)}
.ctl-hero__meta span{display:flex;align-items:center;gap:5px}
.ctl-hero__meta svg{opacity:.6}
.ctl-hero__gauge{flex-shrink:0}
.gauge{width:130px;height:130px;filter:drop-shadow(0 0 12px rgba(201,168,76,.2))}
.gauge__fill{transition:stroke-dasharray 1.2s ease}
.gauge__pct{font-size:22px;font-weight:700;fill:#fff}
.gauge__label{font-size:8px;fill:var(--text-dim);text-transform:uppercase;letter-spacing:.8px}

/* ── STATS ── */
.ctl-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:22px;display:flex;flex-direction:column;gap:8px;transition:all .25s;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent);opacity:0;transition:opacity .3s}
.stat-card:hover{border-color:var(--border-active);transform:translateY(-2px);box-shadow:var(--glow-gold)}
.stat-card:hover::before{opacity:1}
.stat-card__icon{color:var(--gold);opacity:.7}
.stat-card__value{font-size:28px;font-weight:700;color:#fff}
.stat-card__label{font-size:12px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.6px}

/* ── SECTION ── */
.ctl-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.ctl-section__head{padding:20px 28px;border-bottom:1px solid var(--border);background:rgba(13,27,46,.5)}
.ctl-section__head h2{font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:10px}
.ctl-section__head h2 svg{color:var(--gold);opacity:.7}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge--green{background:var(--green-dim);color:var(--green);border:1px solid rgba(52,211,153,.2)}
.badge--gold{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(201,168,76,.2)}
.badge--amber{background:var(--amber-dim);color:var(--amber);border:1px solid rgba(245,158,11,.2)}
.badge--red{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.2)}
.badge--blue{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(74,144,217,.2)}
.badge--gray{background:rgba(100,116,139,.12);color:var(--text-dim);border:1px solid rgba(100,116,139,.15)}

/* ── TIMELINE ── */
.timeline{padding:28px;display:grid;gap:0}
.tl-item{display:flex;gap:20px;position:relative;padding-bottom:24px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:'';position:absolute;left:9px;top:24px;bottom:0;width:2px;background:var(--border)}
.tl-item:last-child::before{display:none}
.tl-dot{width:20px;height:20px;border-radius:50%;border:2px solid var(--border);background:var(--bg-deep);flex-shrink:0;margin-top:2px;transition:all .3s;position:relative;z-index:1}
.tl-item--done .tl-dot{border-color:var(--green);background:var(--green);box-shadow:0 0 8px rgba(52,211,153,.3)}
.tl-item--active .tl-dot{border-color:var(--gold);background:var(--gold);box-shadow:0 0 8px rgba(201,168,76,.3);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 8px rgba(201,168,76,.3)}50%{box-shadow:0 0 16px rgba(201,168,76,.5)}}
.tl-item--done::before{background:var(--green)}
.tl-content{flex:1}
.tl-code{font-size:11px;color:var(--gold);font-weight:700;letter-spacing:.5px;margin-bottom:2px}
.tl-trigger{font-size:15px;font-weight:600;color:var(--text);margin-bottom:6px}
.tl-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;font-size:12px;color:var(--text-dim)}

/* ── RISK GRID ── */
.risk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;padding:24px}
.risk-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:18px;transition:all .25s}
.risk-card:hover{border-color:var(--border-active);transform:translateY(-1px)}
.risk-card--high{border-left:3px solid var(--red)}
.risk-card--medium{border-left:3px solid var(--amber)}
.risk-card--low{border-left:3px solid var(--green)}
.risk-card__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.risk-card__code{font-size:11px;font-weight:700;color:var(--gold);letter-spacing:.5px}
.risk-card__title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px}
.risk-card__mit{font-size:12px;color:var(--text-dim);display:flex;align-items:flex-start;gap:6px;line-height:1.5}
.risk-card__mit svg{flex-shrink:0;margin-top:2px;opacity:.5}

/* ── QUICK ACCESS ── */
.ctl-quick{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.qa-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;transition:all .25s;color:var(--text-dim)}
.qa-card:hover{border-color:var(--border-active);color:var(--gold);transform:translateY(-2px);box-shadow:var(--glow-gold)}
.qa-card svg{opacity:.6;transition:opacity .2s}
.qa-card:hover svg{opacity:1;color:var(--gold)}
.qa-card span{font-size:13px;font-weight:600}

/* ── FORMS ── */
.ctl-form{padding:24px 28px;display:grid;gap:16px}
.ctl-form label{display:block;font-size:12px;color:var(--text-dim);font-weight:500;text-transform:uppercase;letter-spacing:.4px}
.ctl-form input,.ctl-form textarea,.ctl-form select{display:block;width:100%;margin-top:6px;padding:11px 14px;background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);color:#fff;font-size:14px;font-family:var(--font-ui);outline:none;transition:border-color .2s,box-shadow .2s}
.ctl-form input:focus,.ctl-form textarea:focus,.ctl-form select:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-dim)}
.ctl-form textarea{resize:vertical;min-height:80px}
.ctl-form select{appearance:auto}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.range-row{display:flex;align-items:center;gap:12px;margin-top:6px}
.range-row input[type=range]{flex:1;accent-color:var(--gold)}
.range-row span{min-width:40px;text-align:right;font-weight:700;color:var(--gold);font-size:14px}
.btn-gold{display:inline-flex;align-items:center;justify-content:center;padding:12px 28px;background:linear-gradient(135deg,var(--gold),#B8973F);color:var(--bg-deep);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font-ui);transition:all .2s;letter-spacing:.3px;max-width:280px}
.btn-gold:hover{box-shadow:var(--glow-gold);transform:translateY(-1px)}
.btn-gold.loading{opacity:.6;pointer-events:none}

/* ── REPORT CARDS ── */
.rep-list{padding:24px 28px;display:grid;gap:16px}
.rep-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;position:relative}
.rep-card__bar{position:absolute;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--gold),var(--gold-light));transition:width .6s}
.rep-card__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;flex-wrap:wrap;gap:8px}
.rep-card__header strong{font-size:16px;color:#fff}
.rep-card__week{font-size:12px;color:var(--text-dim);margin-left:8px}
.rep-pct{font-size:13px;color:var(--gold);font-weight:700;margin-left:8px}
.rep-summary{padding:0 20px 12px;color:var(--text-dim);font-size:14px;line-height:1.7}
.rep-lists{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding:0 20px 16px}
.rep-lists h4{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:6px}
.rep-lists ul{list-style:none}
.rep-lists li{padding:3px 0;font-size:13px;color:var(--text-dim)}
.rep-lists li::before{content:'→ ';color:var(--gold)}
.rep-footer{padding:12px 20px;border-top:1px solid var(--border);font-size:11px;color:var(--text-muted)}

/* ── EVIDENCE ── */
.ev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;padding:24px}
.ev-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:all .25s}
.ev-card:hover{border-color:var(--border-active);transform:translateY(-2px)}
.ev-card__media{height:180px;overflow:hidden;background:var(--bg-deep)}
.ev-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.ev-card:hover .ev-card__media img{transform:scale(1.05)}
.ev-card__file{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}
.ev-card__info{padding:14px}
.ev-phase{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--gold);font-weight:600}
.ev-card__info p{font-size:13px;color:var(--text-dim);margin-top:4px}
.ev-meta{font-size:11px;color:var(--text-muted);margin-top:6px}

/* ── APPROVALS ── */
.appr-list{padding:24px 28px;display:grid;gap:16px}
.appr-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px;transition:all .25s}
.appr-card--approved{border-left:3px solid var(--green)}
.appr-card--rejected{border-left:3px solid var(--red)}
.appr-card--pending{border-left:3px solid var(--amber)}
.appr-card__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.appr-card__head strong{font-size:15px;color:#fff}
.appr-desc{font-size:13px;color:var(--text-dim);margin-bottom:8px}
.appr-notes{font-size:12px;color:var(--text-muted);font-style:italic;margin-bottom:8px;padding:8px;background:var(--bg-deep);border-radius:6px}
.appr-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:11px;color:var(--text-muted)}
.appr-actions{display:flex;gap:10px;margin-top:12px}
.btn-approve,.btn-reject{padding:8px 18px;border-radius:8px;font-size:12px;font-weight:700;border:none;cursor:pointer;font-family:var(--font-ui);transition:all .2s}
.btn-approve{background:var(--green-dim);color:var(--green);border:1px solid rgba(52,211,153,.3)}
.btn-approve:hover{background:rgba(52,211,153,.25)}
.btn-reject{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.3)}
.btn-reject:hover{background:rgba(239,68,68,.25)}

/* ── LOGIN ── */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;position:relative}
.login-bg{position:fixed;inset:0;background:linear-gradient(135deg,#07111F 0%,#0F2040 50%,#07111F 100%);z-index:0}
.login-bg::after{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 50% 30%,rgba(201,168,76,.06),transparent 70%)}
.login-wrapper{position:relative;z-index:1;width:100%;max-width:420px}
.login-card{background:rgba(10,22,40,.9);backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:24px;padding:48px 40px;box-shadow:var(--shadow-lg)}
.login-brand{display:flex;align-items:center;gap:14px;margin-bottom:32px}
.login-brand__name{font-family:var(--font-ui);font-weight:800;font-size:24px;color:#fff;letter-spacing:1.5px;display:block}
.login-brand__sub{font-size:12px;color:var(--gold);letter-spacing:2px;font-weight:500}
.login-lang{display:flex;gap:2px;background:var(--bg-surface);border-radius:8px;padding:2px;border:1px solid var(--border);margin-bottom:28px;width:fit-content}
.login-lang button{background:none;border:none;color:var(--text-dim);font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;cursor:pointer;font-family:var(--font-ui);transition:all .2s}
.login-lang button.active{background:var(--gold-dim);color:var(--gold)}
.login-title{font-family:var(--font-head);font-size:28px;font-weight:700;color:#fff;margin-bottom:6px}
.login-sub{font-size:13px;color:var(--text-dim);margin-bottom:28px}
.login-form label{display:block;margin-bottom:18px}
.login-form label span{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);font-weight:600;display:block;margin-bottom:6px}
.login-form input{display:block;width:100%;padding:13px 16px;background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius-sm);color:#fff;font-size:15px;font-family:var(--font-ui);outline:none;transition:border-color .2s,box-shadow .2s}
.login-form input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-dim)}
.login-error{color:var(--red);font-size:13px;margin-top:12px;min-height:20px;text-align:center}
.login-footer{text-align:center;margin-top:28px;font-size:12px;color:var(--text-muted)}
.login-footer strong{color:var(--gold)}

/* ── TOAST ── */
.toast{position:fixed;bottom:-60px;left:50%;transform:translateX(-50%);padding:12px 24px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;z-index:9999;transition:bottom .3s ease;font-family:var(--font-ui)}
.toast.show{bottom:28px}
.toast--success{background:var(--green-dim);color:var(--green);border:1px solid rgba(52,211,153,.3)}
.toast--info{background:var(--blue-dim);color:var(--blue);border:1px solid rgba(74,144,217,.3)}
.toast--error{background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.3)}

/* ── EMPTY ── */
.empty{padding:40px;text-align:center;color:var(--text-muted);font-size:14px}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.ctl-stats{grid-template-columns:repeat(2,1fr)}.ctl-quick{grid-template-columns:1fr}}
@media(max-width:768px){
  .ctl-hdr__inner{flex-wrap:wrap;padding:10px 16px;gap:10px}
  .ctl-nav{order:3;width:100%;justify-content:center}
  .ctl-hero__content{flex-direction:column;text-align:center;padding:24px}
  .ctl-hero__meta{justify-content:center}
  .ctl-hero__gauge{align-self:center}
  .ctl-stats{grid-template-columns:1fr 1fr}
  .risk-grid{grid-template-columns:1fr}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .ev-grid{grid-template-columns:1fr 1fr}
  .ctl-quick{grid-template-columns:1fr}
}
@media(max-width:480px){
  .ctl-stats{grid-template-columns:1fr}
  .ev-grid{grid-template-columns:1fr}
  .login-card{padding:32px 24px}
}
