*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy-950:#020B18;--navy-900:#041427;--navy-800:#082040;--navy-700:#0D3060;
  --navy-600:#1045A0;--navy-500:#1A5DC8;--navy-400:#3578E5;--navy-300:#6BA3F0;
  --navy-200:#B8D4FA;--navy-100:#E0EDFE;--navy-50:#F0F7FF;
  --gold-600:#B8860B;--gold-500:#D4A017;--gold-400:#F0BE2A;--gold-300:#F7D460;
  --red-500:#DC2626;--red-100:#FEE2E2;--red-50:#FFF5F5;
  --green-600:#16A34A;--green-100:#DCFCE7;
  --slate-900:#0F172A;--slate-800:#1E293B;--slate-700:#334155;
  --slate-600:#475569;--slate-500:#64748B;--slate-400:#94A3B8;
  --slate-300:#CBD5E1;--slate-200:#E2E8F0;--slate-100:#F1F5F9;--slate-50:#F8FAFC;
  --white:#FFFFFF;
  --radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px rgba(0,0,0,.1),0 2px 6px rgba(0,0,0,.07);
  --shadow-lg:0 10px 30px rgba(0,0,0,.12),0 4px 12px rgba(0,0,0,.08);
  --shadow-card:0 0 0 1px rgba(0,0,0,.05),0 2px 8px rgba(0,0,0,.06);
  --focus-ring:0 0 0 3px rgba(26,93,200,.18);
  --transition-fast:all .15s cubic-bezier(.4,0,.2,1);
  --transition-med:all .25s cubic-bezier(.4,0,.2,1);
}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--slate-50);color:var(--slate-800);min-height:100dvh;line-height:1.5}

/* ─── ACCESSIBILITY ──────────────────────────────────────── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.skip-link{position:absolute;top:-100%;left:1rem;background:var(--navy-900);color:#fff;padding:.5rem 1rem;border-radius:0 0 var(--radius-md) var(--radius-md);font-size:.85rem;font-weight:600;z-index:9999;text-decoration:none;transition:top .15s}
.skip-link:focus{top:0;outline:3px solid var(--gold-400);outline-offset:2px}

/* ─── TOP NAV ─────────────────────────────────────────────── */
.topbar{background:var(--navy-900);color:var(--white);padding:0 1.25rem;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.3)}
.topbar-brand{display:flex;align-items:center;gap:.6rem}
.topbar-logo{width:36px;height:36px;background:var(--navy-700);border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--gold-400);flex-shrink:0}
.topbar-logo svg{width:20px;height:20px;pointer-events:none}
.topbar-title{font-size:.9rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--white);line-height:1.1}
.topbar-sub{font-size:.65rem;color:var(--navy-300);letter-spacing:.06em;text-transform:uppercase}
.topbar-actions{display:flex;gap:.5rem}

/* ─── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;cursor:pointer;border:none;transition:var(--transition-fast);font-family:inherit;text-decoration:none;white-space:nowrap;position:relative;user-select:none}
.btn svg{pointer-events:none;flex-shrink:0}
.btn:focus-visible{outline:2px solid var(--gold-400);outline-offset:2px}
.btn-primary{background:var(--navy-500);color:var(--white);box-shadow:0 1px 2px rgba(0,0,0,.1)}
.btn-primary:hover{background:var(--navy-400);box-shadow:0 2px 8px rgba(26,93,200,.3);transform:translateY(-1px)}
.btn-primary:active{transform:translateY(0);box-shadow:none}
.btn-gold{background:var(--gold-400);color:var(--navy-950);box-shadow:0 1px 2px rgba(0,0,0,.1)}
.btn-gold:hover{background:var(--gold-300);transform:translateY(-1px)}
.btn-gold:active{transform:translateY(0)}
.btn-ghost{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.2)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-danger{background:var(--red-500);color:var(--white)}
.btn-danger:hover{background:#b91c1c;transform:translateY(-1px)}
.btn-sm{padding:.35rem .7rem;font-size:.75rem}
.btn-icon{padding:.45rem;border-radius:var(--radius-sm)}
/* OWASP: disabled must communicate state beyond opacity alone */
.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none;transform:none!important;box-shadow:none!important}
.btn:disabled::after{content:'';position:absolute;inset:0;border-radius:inherit;background:rgba(255,255,255,.08)}

/* ─── LAYOUT ──────────────────────────────────────────────── */
.app{display:flex;flex-direction:column;min-height:100dvh;padding-top:60px}
.main-content{flex:1;padding:1.5rem 1.25rem;max-width:1400px;margin:0 auto;width:100%}

/* ─── VIEWS ──────────────────────────────────────────────── */
.view{display:none}
.view.active{display:block}
#view-print.active{display:flex}

/* ─── DASHBOARD ──────────────────────────────────────────── */
.dash-header{margin-bottom:1.5rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.dash-header h1{font-size:1.5rem;font-weight:800;color:var(--navy-900);letter-spacing:-.02em}
.dash-header p{font-size:.875rem;color:var(--slate-500);margin-top:.25rem}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}
.stat-card{background:var(--white);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-card);border-top:3px solid var(--navy-500);
  opacity:0;transform:translateY(16px);animation:fadeUp .4s cubic-bezier(.22,1,.36,1) forwards}
.stat-card:nth-child(1){animation-delay:0ms}
.stat-card:nth-child(2){animation-delay:60ms}
.stat-card:nth-child(3){animation-delay:120ms}
.stat-card:nth-child(4){animation-delay:180ms}
.stat-card:nth-child(5){animation-delay:240ms}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
.stat-card.gold{border-color:var(--gold-400)}
.stat-card.green{border-color:#16a34a}
.stat-card.red{border-color:var(--red-500)}
.stat-value{font-size:2rem;font-weight:800;color:var(--navy-900);line-height:1}
.stat-label{font-size:.75rem;color:var(--slate-500);margin-top:.3rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}
.dash-toolbar{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap;align-items:center}
.search-box{flex:1;min-width:200px;position:relative}
.search-box input{width:100%;padding:.55rem 1rem .55rem 2.4rem;border:1.5px solid var(--slate-200);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;background:var(--white);color:var(--slate-800);transition:border .15s,box-shadow .15s;-webkit-appearance:none;line-height:1.5}
.search-box input:focus{outline:none;border-color:var(--navy-400);box-shadow:var(--focus-ring)}
.search-box input:focus-visible{outline:none}
.search-box svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--slate-400);pointer-events:none}

/* ─── TABLE ───────────────────────────────────────────────── */
.table-wrap{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}
.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:.82rem}
thead{background:var(--navy-900)}
th{color:var(--navy-200);font-weight:600;padding:.7rem 1rem;text-align:left;white-space:nowrap;letter-spacing:.03em;font-size:.75rem;text-transform:uppercase}
td{padding:.7rem 1rem;border-bottom:1px solid var(--slate-100);color:var(--slate-700);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--slate-50)}
.badge{display:inline-flex;align-items:center;padding:.2rem .55rem;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.02em}
.badge-blue{background:var(--navy-100);color:var(--navy-700)}
.badge-gold{background:#fef9c3;color:#854d0e}
.badge-green{background:var(--green-100);color:#15803d}
.badge-red{background:var(--red-100);color:#dc2626}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--slate-400)}
.empty-state svg{width:48px;height:48px;margin:0 auto 1rem;opacity:.4}
.empty-state h3{font-size:1rem;font-weight:600;color:var(--slate-600);margin-bottom:.4rem}
.empty-state p{font-size:.85rem}
.table-footer{padding:.75rem 1rem;border-top:1px solid var(--slate-100);font-size:.8rem;color:var(--slate-500);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.action-btns{display:flex;gap:.4rem}

/* ─── FORM VIEW ───────────────────────────────────────────── */
.form-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;flex-wrap:wrap}
.form-header h1{font-size:1.4rem;font-weight:800;color:var(--navy-900);letter-spacing:-.02em}
.form-header .back-btn{display:flex;align-items:center;gap:.35rem;color:var(--slate-500);font-size:.85rem;font-weight:500;cursor:pointer;border:none;background:none;font-family:inherit;padding:.25rem .5rem;border-radius:var(--radius-sm);min-height:44px;min-width:44px}
.form-header .back-btn:hover{color:var(--navy-600);background:var(--slate-100)}
.form-header .back-btn:focus-visible{outline:2px solid var(--navy-400);outline-offset:2px}

.rids-form{display:flex;flex-direction:column;gap:1.5rem}
.form-section{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}
.section-title{background:var(--navy-900);color:var(--white);padding:.75rem 1.25rem;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;gap:.5rem}
.section-title .dot{width:6px;height:6px;border-radius:50%;background:var(--gold-400);flex-shrink:0}
.section-body{padding:1.25rem}
.fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.fields-grid.cols-2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.fields-grid.cols-1{grid-template-columns:1fr}
.field-full{grid-column:1/-1}
.field-group{display:flex;flex-direction:column;gap:.35rem}
.field-group label{font-size:.75rem;font-weight:600;color:var(--slate-600);text-transform:uppercase;letter-spacing:.04em}
/* iOS auto-zoom fix: inputs must be at least 16px font-size on mobile — scale visually via transform is not worth it, just use 1rem */
.field-group input,.field-group select,.field-group textarea{width:100%;padding:.55rem .85rem;border:1.5px solid var(--slate-200);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--slate-800);background:var(--white);transition:border .15s,box-shadow .15s;-webkit-appearance:none;line-height:1.5}
.field-group input:focus,.field-group select:focus,.field-group textarea:focus{outline:none;border-color:var(--navy-400);box-shadow:var(--focus-ring)}
.field-group input:focus-visible,.field-group select:focus-visible,.field-group textarea:focus-visible{outline:none}
.field-group textarea{resize:vertical;min-height:80px}
.field-group select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394A3B8' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}
.field-required::after{content:' *';color:var(--red-500)}
/* Validation error state */
.field-group.has-error input,.field-group.has-error select,.field-group.has-error textarea{border-color:var(--red-500);box-shadow:0 0 0 3px rgba(220,38,38,.1)}
.field-error-msg{font-size:.72rem;color:var(--red-500);font-weight:500;margin-top:.2rem}

/* Repeatable rows */
.repeat-section{display:flex;flex-direction:column;gap:.75rem}
.repeat-row{display:grid;gap:.75rem;padding:1rem;background:var(--slate-50);border-radius:var(--radius-md);border:1px solid var(--slate-200);position:relative}
.repeat-row-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}
.repeat-row-num{font-size:.72rem;font-weight:700;color:var(--navy-600);text-transform:uppercase;letter-spacing:.04em}
.add-row-btn{display:flex;align-items:center;gap:.4rem;color:var(--navy-600);font-size:.82rem;font-weight:600;cursor:pointer;border:1.5px dashed var(--navy-300);background:transparent;padding:.55rem 1rem;border-radius:var(--radius-sm);width:100%;justify-content:center;font-family:inherit;transition:var(--transition-fast);min-height:44px}
.add-row-btn:hover{background:var(--navy-50);border-color:var(--navy-500)}
.add-row-btn:focus-visible{outline:2px solid var(--navy-400);outline-offset:2px}
.del-row-btn{position:absolute;top:.75rem;right:.75rem;background:none;border:none;cursor:pointer;color:var(--slate-400);padding:.35rem;border-radius:4px;transition:color .15s;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}
.del-row-btn:hover{color:var(--red-500);background:var(--red-50)}
.del-row-btn:focus-visible{outline:2px solid var(--red-500);outline-offset:2px}

.form-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end;padding:1.25rem;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}

/* ─── MODAL ───────────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(2px)}
.modal-overlay.open{display:flex}
.modal{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden;animation:slideUp .2s cubic-bezier(.22,1,.36,1)}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--slate-100);display:flex;align-items:center;justify-content:space-between}
.modal-header h2{font-size:1.05rem;font-weight:700;color:var(--slate-900)}
.modal-body{padding:1.25rem 1.5rem}
.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--slate-100);display:flex;gap:.75rem;justify-content:flex-end}

/* ─── TOAST ───────────────────────────────────────────────── */
#toast-container{position:fixed;bottom:1.25rem;right:1.25rem;z-index:400;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}
.toast{background:var(--slate-900);color:var(--white);padding:.75rem 1.1rem;border-radius:var(--radius-md);font-size:.82rem;font-weight:500;display:flex;align-items:center;gap:.5rem;box-shadow:var(--shadow-lg);animation:toastIn .25s cubic-bezier(.22,1,.36,1);pointer-events:all;max-width:300px}
.toast.success{background:var(--green-600)}
.toast.error{background:var(--red-500)}
.toast.warning{background:#D97706}
@keyframes toastIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
@keyframes toastOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(30px)}}
.toast.out{animation:toastOut .25s ease forwards}
.toast-close{background:none;border:none;color:rgba(255,255,255,.7);cursor:pointer;padding:.15rem;border-radius:3px;line-height:1;margin-left:.25rem;font-size:.9rem}
.toast-close:hover{color:#fff}

/* ─── DETAIL VIEW ─────────────────────────────────────────── */
.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;padding:1.25rem}
.detail-item label{font-size:.72rem;font-weight:700;color:var(--slate-400);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:.2rem}
.detail-item span{font-size:.9rem;color:var(--slate-800);font-weight:500}
.detail-table{width:100%;border-collapse:collapse;font-size:.82rem}
.detail-table th{background:var(--slate-100);padding:.5rem .75rem;text-align:left;font-size:.72rem;font-weight:700;color:var(--slate-500);text-transform:uppercase;letter-spacing:.04em}
.detail-table td{padding:.55rem .75rem;border-bottom:1px solid var(--slate-100);color:var(--slate-700)}

/* ─── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:767px){
  .main-content{padding:1rem .75rem}
  .topbar-title{font-size:.8rem}
  .topbar-sub{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .dash-toolbar{flex-direction:column;align-items:stretch}
  .search-box{min-width:0}
  th:nth-child(n+4),td:nth-child(n+4){display:none}
  .fields-grid,.fields-grid.cols-2{grid-template-columns:1fr}
  .form-actions{flex-direction:column}
  .form-actions .btn{width:100%;justify-content:center;min-height:48px}
  #toast-container{left:.75rem;right:.75rem;bottom:.75rem}
  .toast{max-width:100%}
  /* Larger touch targets on mobile */
  .btn{min-height:44px}
  .btn-sm{min-height:36px}
  td .btn-sm{min-height:32px}
}
@media(min-width:1024px){
  .main-content{padding:2rem 2rem}
  .dash-header h1{font-size:1.8rem}
}

/* ─── PRINT PREVIEW ───────────────────────────────────────── */
#view-print{display:none;position:fixed;inset:0;z-index:200;background:#c8c8c8;flex-direction:column;overflow-y:auto}
.rids-page{background:#fff;width:210mm;min-height:297mm;margin:0 auto 20px;padding:7mm 9mm;font-family:'Arial',sans-serif;font-size:7pt;color:#000;box-shadow:0 4px 24px rgba(0,0,0,.3);position:relative;-webkit-print-color-adjust:exact;print-color-adjust:exact;color-adjust:exact}
.rids-page *{box-sizing:border-box}
.rids-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:2mm;gap:2mm}
.rids-hdr-logo-placeholder{width:14mm;height:14mm;border:1px solid #999;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:5pt;text-align:center;color:#666;flex-shrink:0}
.rids-hdr-text{text-align:center;flex:1}
.rids-hdr-text h1{font-size:9.5pt;font-weight:bold;text-transform:uppercase;letter-spacing:.03em;margin:0;line-height:1.3}
.rids-hdr-text h2{font-size:8.5pt;font-weight:bold;text-transform:uppercase;letter-spacing:.03em;margin:0;line-height:1.3}
.rids-cn-row{display:flex;align-items:stretch;border:1px solid #000;margin-bottom:2mm;font-size:6.5pt}
.rids-cn-label{padding:.8mm 1.5mm;border-right:1px solid #000;white-space:nowrap;font-size:6pt;display:flex;align-items:center;line-height:1.3}
.rids-cn-box{padding:.8mm 1.5mm;font-size:7.5pt;font-weight:bold;min-width:9mm;display:flex;align-items:center}
.rids-cn-cells{display:flex;flex:1}
.rids-cn-cell{flex:1;border-left:1px solid #000;min-height:5mm}
.rids-section-title{font-size:7.5pt;font-weight:bold;text-transform:uppercase;margin:1.5mm 0 .6mm;letter-spacing:.01em}
.rids-sub-title{font-size:7pt;font-weight:bold;text-transform:uppercase;margin:1mm 0 .5mm}
/* ── TABLES ── */
.rp-table{width:100%;border-collapse:collapse;font-size:6.5pt;margin-bottom:1.5mm;border:1px solid #000;table-layout:fixed}
.rp-table th{border:1px solid #000;padding:.8mm 1mm;background:#d9d9d9;text-align:center;font-weight:bold;font-size:6pt;text-transform:uppercase;color:#000;vertical-align:middle;line-height:1.2;white-space:normal;word-break:break-word}
.rp-table td{border:1px solid #000;padding:.8mm 1mm;vertical-align:middle;text-align:center;color:#1a4fa0;text-transform:uppercase;font-size:6.5pt;line-height:1.3;word-break:break-word}
.rp-table td.left{text-align:left}
/* ── INLINE FIELD ROWS ── */
.rids-block{border:1px solid #000;margin-bottom:1.5mm}
.rids-inline-row{display:flex;align-items:stretch;border-bottom:1px solid #000}
.rids-inline-row:last-child{border-bottom:none}
.rids-field{display:flex;flex-direction:column;flex:1;border-right:1px solid #000;min-height:6.5mm}
.rids-field:last-child{border-right:none}
.rids-field-val{font-size:7pt;flex:1;padding:.7mm 1mm .4mm;text-align:center;color:#1a4fa0;text-transform:uppercase;display:flex;align-items:center;justify-content:center;line-height:1.2}
.rids-field-lbl{font-size:5pt;color:#000;text-align:center;text-transform:uppercase;padding:.4mm .8mm;border-top:1px solid #ccc;background:#f5f5f5;line-height:1.1;font-weight:bold;letter-spacing:.02em}
.rids-field.left .rids-field-val{text-align:left;justify-content:flex-start}
.rids-field.left .rids-field-lbl{text-align:left}
/* ── ADDR / CONTACT ── */
.rids-addr-block{border:1px solid #000;margin-bottom:1.5mm}
.rids-addr-row{display:flex;align-items:stretch;border-bottom:1px solid #000}
.rids-addr-row:last-child{border-bottom:none}
.rids-addr-label{font-weight:bold;white-space:nowrap;padding:.8mm 1.2mm;font-size:6.5pt;color:#000;background:#f5f5f5;border-right:1px solid #000;display:flex;align-items:center;min-width:30mm}
.rids-addr-val{padding:.8mm 1.2mm;flex:1;color:#1a4fa0;text-transform:uppercase;font-size:6.5pt;display:flex;align-items:center;min-height:5.5mm;line-height:1.2}
/* ── SIGNATURE ── */
.rids-sig-block{margin-top:4mm;display:flex;justify-content:space-between;align-items:flex-end}
.rids-sig-line{border-top:1px solid #000;text-align:center;padding-top:1mm;min-width:60mm;font-size:6.5pt;color:#000;line-height:1.4}
.rids-note{display:none}
.print-toolbar{display:flex;gap:.75rem;justify-content:center;align-items:center;flex-wrap:wrap;padding:.85rem 1.5rem;background:var(--navy-900);border-bottom:2px solid var(--navy-700);position:sticky;top:0;z-index:20;box-shadow:0 2px 12px rgba(0,0,0,.4)}
.print-toolbar .btn-ghost{border-color:rgba(255,255,255,.3);color:rgba(255,255,255,.9)}
.print-toolbar .btn-ghost:hover{background:rgba(255,255,255,.12)}
@page{size:A4 portrait;margin:0}
@media print{
  body>*:not(#view-print){display:none!important}
  #view-print{display:block!important;position:static!important;overflow:visible!important;background:none!important}
  .topbar,.print-toolbar{display:none!important}
  /* Remove min-height so overflowing pages do not create extra blank pages */
  .rids-page{
    box-shadow:none!important;margin:0!important;width:100%!important;
    padding:5mm 7mm!important;min-height:0!important;overflow:visible!important;
    page-break-after:always;break-after:page;
    /* Force exact colors so borders print deep black, not gray */
    -webkit-print-color-adjust:exact;print-color-adjust:exact;color-adjust:exact;
  }
  .rids-page:last-child{page-break-after:auto;break-after:auto}
  .rids-note{display:none!important}
  /* Ensure all borders print solid black */
  .rids-block,.rids-inline-row,.rids-field,.rids-addr-block,.rids-addr-row,
  .rids-cn-row,.rp-table,.rp-table th,.rp-table td{border-color:#000!important}
}

/* ─── OTHER ───────────────────────────────────────────────── */
.tag{display:inline-block;background:var(--navy-100);color:var(--navy-700);padding:.15rem .5rem;border-radius:4px;font-size:.72rem;font-weight:600;margin:.1rem}
hr.divider{border:none;border-top:1px solid var(--slate-200);margin:.5rem 0}
.mono{font-family:'IBM Plex Mono',monospace;font-size:.8rem}
.form-officer input:not([type="date"]):not([type="number"]):not([type="email"]):not([type="tel"]):not(.mono),
.form-officer select:not(#f-classification):not(#f-rank):not(#f-sex):not(#f-civil-status):not(#f-build):not(#f-blood){text-transform:uppercase}
.form-ep input:not([type="date"]):not([type="number"]):not([type="email"]):not([type="tel"]):not(.mono),
.form-ep select:not(#f-classification):not(#f-rank):not(#f-sex):not(#f-civil-status):not(#f-build):not(#f-blood){text-transform:capitalize}
.field-readonly{background:var(--slate-100)!important;color:var(--slate-500)!important;cursor:default}

/* ─── MILITARY DATE WIDGET ─────────────────────────────────── */
.mil-date-wrap{position:relative;display:flex;flex-direction:column;gap:0}
.mil-date-display{width:100%;padding:.55rem .85rem;border:1.5px solid var(--slate-200);border-radius:var(--radius-sm);font-size:1rem;font-family:'IBM Plex Mono',monospace;color:var(--slate-800);background:var(--white);cursor:pointer;transition:border .15s,box-shadow .15s;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:42px}
.mil-date-display:focus,.mil-date-display.open{outline:none;border-color:var(--navy-400);box-shadow:var(--focus-ring)}
.mil-date-display:focus-visible{outline:2px solid var(--navy-400);outline-offset:2px}
.mil-date-display .placeholder{color:var(--slate-400);font-family:'Plus Jakarta Sans',sans-serif;font-size:.875rem}
.mil-date-display .cal-icon{color:var(--slate-400);flex-shrink:0}
.mil-date-picker{position:absolute;top:calc(100% + 4px);left:0;z-index:150;background:var(--white);border:1.5px solid var(--slate-200);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.75rem;min-width:260px;display:none}
.mil-date-picker.open{display:block;animation:slideUp .15s ease}
.mil-date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}
.mil-date-picker-header span{font-size:.85rem;font-weight:700;color:var(--navy-900)}
.mil-date-nav{background:none;border:none;cursor:pointer;color:var(--slate-500);padding:.2rem .4rem;border-radius:4px;font-size:1rem;line-height:1;min-width:28px;min-height:28px}
.mil-date-nav:hover{background:var(--slate-100);color:var(--navy-700)}
.mil-date-nav:focus-visible{outline:2px solid var(--navy-400);outline-offset:1px}
.mil-date-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.4rem}
.mil-date-grid .dow{font-size:.65rem;font-weight:700;color:var(--slate-400);text-align:center;padding:.2rem 0;text-transform:uppercase}
.mil-date-cell{font-size:.78rem;text-align:center;padding:.3rem .1rem;border-radius:4px;cursor:pointer;color:var(--slate-700);border:none;background:none;font-family:inherit;line-height:1.2;min-height:24px}
.mil-date-cell:hover{background:var(--navy-100);color:var(--navy-700)}
.mil-date-cell:focus-visible{outline:2px solid var(--navy-400);outline-offset:1px}
.mil-date-cell.today{font-weight:700;color:var(--navy-600)}
.mil-date-cell.selected{background:var(--navy-600);color:var(--white)!important;font-weight:700}
.mil-date-cell.other-month{color:var(--slate-300)}
.mil-date-cell.disabled{pointer-events:none;opacity:.3}
.mil-date-selects{display:flex;gap:.4rem;margin-bottom:.5rem}
.mil-date-selects select{flex:1;padding:.3rem .4rem;border:1.5px solid var(--slate-200);border-radius:4px;font-size:.78rem;font-family:inherit;background:var(--white);cursor:pointer}
.mil-date-selects select:focus{outline:none;border-color:var(--navy-400)}
.mil-date-clear{width:100%;margin-top:.4rem;padding:.3rem;font-size:.75rem;color:var(--slate-500);background:none;border:1px solid var(--slate-200);border-radius:4px;cursor:pointer;font-family:inherit}
.mil-date-clear:hover{background:var(--slate-50);color:var(--red-500);border-color:var(--red-200)}

/* ─── UPLOAD MODAL ──────────────────────────────────────── */
.upload-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.upload-modal-overlay.open{opacity:1;pointer-events:all}
.upload-modal{background:#fff;border-radius:14px;width:min(560px,94vw);max-height:88vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.22);display:flex;flex-direction:column}
.upload-modal-head{padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--slate-100);display:flex;align-items:center;justify-content:space-between}
.upload-modal-head h2{font-size:1rem;font-weight:700;color:var(--navy-900)}
.upload-modal-head p{font-size:.78rem;color:var(--slate-500);margin-top:.15rem}
.upload-modal-body{padding:1.25rem 1.5rem;flex:1}
.upload-drop-zone{border:2px dashed var(--slate-300);border-radius:10px;padding:2rem 1rem;text-align:center;cursor:pointer;transition:border .15s,background .15s;position:relative}
.upload-drop-zone:hover,.upload-drop-zone.drag-over{border-color:var(--navy-400);background:var(--navy-50)}
.upload-drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.upload-drop-zone svg{color:var(--navy-400);margin-bottom:.75rem;pointer-events:none}
.upload-drop-zone h3{font-size:.9rem;font-weight:600;color:var(--navy-800)}
.upload-drop-zone p{font-size:.78rem;color:var(--slate-500);margin-top:.25rem}
.upload-file-list{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.upload-file-item{display:flex;align-items:center;gap:.75rem;padding:.65rem .85rem;background:var(--slate-50);border:1px solid var(--slate-200);border-radius:8px;font-size:.82rem}
.upload-file-item .file-icon{color:var(--navy-500);flex-shrink:0;pointer-events:none}
.upload-file-item .file-name{flex:1;font-weight:500;color:var(--navy-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.upload-file-item .file-size{color:var(--slate-400);font-size:.75rem;flex-shrink:0}
.upload-file-item .file-remove{color:var(--slate-400);cursor:pointer;background:none;border:none;padding:.25rem .3rem;border-radius:4px;line-height:1;min-width:28px;min-height:28px;display:flex;align-items:center;justify-content:center}
.upload-file-item .file-remove:hover{color:var(--red-500);background:var(--red-50)}
.upload-file-item .file-remove:focus-visible{outline:2px solid var(--red-500);outline-offset:1px}
.upload-progress{margin-top:1rem}
.upload-progress-bar-wrap{height:6px;background:var(--slate-100);border-radius:99px;overflow:hidden;margin:.4rem 0}
.upload-progress-bar{height:100%;background:linear-gradient(90deg,var(--navy-500),var(--navy-400));border-radius:99px;transition:width .3s;width:0%}
.upload-progress-label{font-size:.78rem;color:var(--slate-600);display:flex;justify-content:space-between}
.upload-modal-foot{padding:.75rem 1.5rem 1.25rem;border-top:1px solid var(--slate-100);display:flex;justify-content:flex-end;gap:.75rem}

/* ─── FLAGS ──────────────────────────────────────────────── */
.flag-badge{display:inline-flex;align-items:center;gap:.25rem;background:#FFF7ED;color:#C2410C;border:1px solid #FED7AA;border-radius:99px;padding:.1rem .45rem;font-size:.68rem;font-weight:600;cursor:pointer;white-space:nowrap}
.flag-badge:hover{background:#FFEDD5}
.flags-panel{background:#FFF7ED;border:1px solid #FED7AA;border-radius:8px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.4rem}
.flags-panel-title{font-size:.75rem;font-weight:700;color:#C2410C;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem}
.flag-item{display:flex;align-items:flex-start;gap:.5rem;font-size:.78rem;color:#92400E}
.flag-item svg{flex-shrink:0;margin-top:.1rem;color:#F97316;pointer-events:none}
.flag-item.critical{color:#991B1B}
.flag-item.critical svg{color:#EF4444}
.flag-item .flag-field{font-weight:600;color:#C2410C}

/* ─── SETTINGS VIEW ──────────────────────────────────────── */
.settings-layout{display:flex;gap:1.5rem;align-items:flex-start}
.settings-sidebar{width:200px;flex-shrink:0;position:sticky;top:1rem}
.settings-sidebar-item{padding:.55rem .85rem;border-radius:8px;font-size:.82rem;cursor:pointer;color:var(--slate-600);font-weight:500;display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem;transition:background .12s,color .12s;min-height:40px}
.settings-sidebar-item:hover{background:var(--slate-100);color:var(--navy-700)}
.settings-sidebar-item:focus-visible{outline:2px solid var(--navy-400);outline-offset:1px}
.settings-sidebar-item.active{background:var(--navy-100);color:var(--navy-700);font-weight:600}
.settings-panel{flex:1;min-width:0}
.dd-table{width:100%;border-collapse:collapse;font-size:.82rem}
.dd-table th{padding:.5rem .75rem;text-align:left;font-size:.72rem;font-weight:700;color:var(--slate-500);text-transform:uppercase;letter-spacing:.04em;border-bottom:2px solid var(--slate-200)}
.dd-table td{padding:.5rem .75rem;border-bottom:1px solid var(--slate-100);vertical-align:middle}
.dd-table tr:hover td{background:var(--slate-50)}
.dd-status-badge{display:inline-flex;align-items:center;gap:.25rem;border-radius:99px;padding:.15rem .55rem;font-size:.7rem;font-weight:600}
.dd-status-badge.on{background:#DCFCE7;color:#166534}
.dd-status-badge.off{background:var(--slate-100);color:var(--slate-400)}
.dd-edit-row{background:var(--navy-50)!important}
.dd-edit-row td{padding:.25rem .5rem}
.dd-desc{font-size:.75rem;color:var(--slate-400);margin-top:.1rem}
.dd-group-title{font-size:.8rem;font-weight:700;color:var(--navy-800);text-transform:uppercase;letter-spacing:.05em;padding:.75rem .75rem .3rem;background:var(--slate-50);border-bottom:1px solid var(--slate-200);border-top:2px solid var(--slate-200);margin-top:.5rem}

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

/* ═══════════════════════════════════════════════════════════════
   THEME TOGGLE BUTTON
═══════════════════════════════════════════════════════════════ */
.theme-toggle{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .65rem;border-radius:20px;border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.85);background:rgba(255,255,255,.08);cursor:pointer;font-family:inherit;transition:all .2s;flex-shrink:0}
.theme-toggle:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.35)}
.theme-toggle:focus-visible{outline:2px solid var(--gold-400);outline-offset:2px}
.toggle-track{width:28px;height:16px;background:rgba(255,255,255,.2);border-radius:8px;position:relative;transition:background .25s;flex-shrink:0}
.toggle-knob{position:absolute;top:2px;left:2px;width:12px;height:12px;background:#fff;border-radius:50%;transition:transform .25s cubic-bezier(.4,0,.2,1),background .25s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.toggle-knob.dark{transform:translateX(12px);background:var(--gold-400)}
[data-theme="dark"] .toggle-track{background:rgba(240,190,42,.35)}
.icon-sun,.icon-moon{flex-shrink:0;transition:opacity .2s}
.hidden{display:none!important}

/* ═══════════════════════════════════════════════════════════════
   DARK MODE  —  Philippine Navy Deep Dark Scheme
   Base: deep navy #010C1A / #020B18
   Surface: #041427 / #071E3D
   Elevated: #0A2550 / #0D3060
   Text: #C8DEFF (primary) / #7AA3CC (muted)
   Gold accent: #F0BE2A stays
═══════════════════════════════════════════════════════════════ */
[data-theme="dark"]{
  /* Re-map semantic tokens for dark */
  --dm-bg:       #010C1A;
  --dm-surface:  #041427;
  --dm-raised:   #071E3D;
  --dm-elevated: #0A2550;
  --dm-border:   rgba(30,80,160,.55);
  --dm-border-strong: rgba(52,120,220,.4);
  --dm-text:     #C8DEFF;
  --dm-text-muted: #6B9AC4;
  --dm-text-faint: #3A6090;
  --dm-input-bg: #071E3D;
  --dm-overlay:  rgba(1,12,26,.85);
}

/* Body & base */
[data-theme="dark"] body{
  background:var(--dm-bg);
  color:var(--dm-text);
}

/* ── TOP NAV ─────────────────────────────── */
[data-theme="dark"] .topbar{
  background:linear-gradient(135deg,#010C1A 0%,#041427 100%);
  border-bottom:1px solid var(--dm-border);
  box-shadow:0 2px 16px rgba(0,0,0,.6);
}
[data-theme="dark"] .topbar-sub{color:var(--dm-text-muted)}

/* ── LAYOUT ──────────────────────────────── */
[data-theme="dark"] .app{background:var(--dm-bg)}

/* ── DASHBOARD ───────────────────────────── */
[data-theme="dark"] .dash-header h1{color:#E8F0FF}
[data-theme="dark"] .dash-header p{color:var(--dm-text-muted)}

/* ── STAT CARDS ──────────────────────────── */
[data-theme="dark"] .stat-card{
  background:var(--dm-surface);
  border-color:var(--dm-border);
  box-shadow:0 0 0 1px var(--dm-border),0 4px 16px rgba(0,0,0,.4);
}
[data-theme="dark"] .stat-value{color:#E8F0FF}
[data-theme="dark"] .stat-label{color:var(--dm-text-muted)}
[data-theme="dark"] .stat-card.gold{border-top-color:var(--gold-400)}
[data-theme="dark"] .stat-card.green{border-top-color:#22c55e}
[data-theme="dark"] .stat-card.red{border-top-color:#f87171}

/* ── TOOLBAR & SEARCH ────────────────────── */
[data-theme="dark"] .search-box input{
  background:var(--dm-raised);
  border-color:var(--dm-border);
  color:var(--dm-text);
}
[data-theme="dark"] .search-box input::placeholder{color:var(--dm-text-faint)}
[data-theme="dark"] .search-box input:focus{border-color:var(--navy-400);box-shadow:0 0 0 3px rgba(52,120,220,.2)}
[data-theme="dark"] .search-box svg{color:var(--dm-text-faint)}
[data-theme="dark"] select.filter-select{
  background:var(--dm-raised);
  border-color:var(--dm-border);
  color:var(--dm-text);
}

/* ── TABLE ───────────────────────────────── */
[data-theme="dark"] .table-wrap{
  background:var(--dm-surface);
  box-shadow:0 0 0 1px var(--dm-border),0 4px 16px rgba(0,0,0,.4);
}
[data-theme="dark"] thead{background:linear-gradient(135deg,#010C1A,#041427)}
[data-theme="dark"] th{color:var(--navy-300);border-bottom:1px solid var(--dm-border)}
[data-theme="dark"] td{
  color:var(--dm-text);
  border-bottom:1px solid var(--dm-border);
}
[data-theme="dark"] tr:hover td{background:rgba(10,37,80,.5)}
[data-theme="dark"] .table-footer{
  background:var(--dm-surface);
  border-top:1px solid var(--dm-border);
  color:var(--dm-text-muted);
}
/* Badges */
[data-theme="dark"] .badge-blue{background:rgba(16,69,160,.35);color:#93C5FD}
[data-theme="dark"] .badge-gold{background:rgba(240,190,42,.15);color:#FCD34D}
[data-theme="dark"] .badge-green{background:rgba(34,197,94,.12);color:#86EFAC}
[data-theme="dark"] .badge-red{background:rgba(239,68,68,.12);color:#FCA5A5}

/* ── FORM SECTIONS ───────────────────────── */
[data-theme="dark"] .form-section{
  background:var(--dm-surface);
  box-shadow:0 0 0 1px var(--dm-border);
}
[data-theme="dark"] .section-title{
  background:linear-gradient(135deg,#010C1A 0%,#041427 100%);
  border-bottom:1px solid var(--dm-border);
}
[data-theme="dark"] .section-body{background:var(--dm-surface)}

/* ── FORM INPUTS ─────────────────────────── */
[data-theme="dark"] .field-group label{color:var(--navy-300)}
[data-theme="dark"] .field-group input,
[data-theme="dark"] .field-group select,
[data-theme="dark"] .field-group textarea{
  background:var(--dm-input-bg);
  border-color:var(--dm-border);
  color:var(--dm-text);
}
[data-theme="dark"] .field-group input::placeholder,
[data-theme="dark"] .field-group textarea::placeholder{color:var(--dm-text-faint)}
[data-theme="dark"] .field-group input:focus,
[data-theme="dark"] .field-group select:focus,
[data-theme="dark"] .field-group textarea:focus{
  border-color:var(--navy-400);
  box-shadow:0 0 0 3px rgba(52,120,220,.2);
}
[data-theme="dark"] .field-group input[readonly],
[data-theme="dark"] .field-group input[style*="background:var(--slate-100)"],
[data-theme="dark"] .field-readonly{
  background:rgba(7,30,61,.7)!important;
  color:var(--dm-text-muted)!important;
}
/* Select arrow for dark mode */
[data-theme="dark"] .field-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B9AC4' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
}
/* AFPSN O- prefix */
[data-theme="dark"] #afpsn-wrap{border-color:var(--dm-border)!important}
[data-theme="dark"] #afpsn-prefix{
  background:var(--dm-elevated)!important;
  color:var(--gold-400)!important;
  border-right-color:var(--dm-border)!important;
}

/* ── REPEATABLE ROWS ─────────────────────── */
[data-theme="dark"] .repeat-row{
  background:var(--dm-raised);
  border-color:var(--dm-border);
}
[data-theme="dark"] .repeat-row-num{color:var(--navy-300)}
[data-theme="dark"] .add-row-btn{
  color:var(--navy-300);
  border-color:var(--dm-border-strong);
}
[data-theme="dark"] .add-row-btn:hover{
  background:rgba(10,37,80,.6);
  border-color:var(--navy-400);
  color:#93C5FD;
}
[data-theme="dark"] .del-row-btn{color:var(--dm-text-faint)}
[data-theme="dark"] .del-row-btn:hover{background:rgba(239,68,68,.12);color:#f87171}

/* ── FORM ACTIONS ────────────────────────── */
[data-theme="dark"] .form-actions{
  background:var(--dm-surface);
  box-shadow:0 0 0 1px var(--dm-border);
}
[data-theme="dark"] .form-header h1{color:#E8F0FF}
[data-theme="dark"] .back-btn{color:var(--dm-text-muted)!important}
[data-theme="dark"] .back-btn:hover{background:var(--dm-raised)!important;color:var(--navy-300)!important}
[data-theme="dark"] hr.divider{border-top-color:var(--dm-border)}

/* ── MODAL ───────────────────────────────── */
[data-theme="dark"] .modal{
  background:var(--dm-surface);
  box-shadow:0 24px 64px rgba(0,0,0,.7),0 0 0 1px var(--dm-border);
}
[data-theme="dark"] .modal-header{
  border-bottom-color:var(--dm-border);
}
[data-theme="dark"] .modal-header h2{color:#E8F0FF}
[data-theme="dark"] .modal-footer{border-top-color:var(--dm-border)}
[data-theme="dark"] .modal-body p{color:var(--dm-text-muted)}
[data-theme="dark"] .modal-body strong{color:var(--dm-text)}
[data-theme="dark"] .modal-overlay{background:var(--dm-overlay)}

/* ── TOAST ───────────────────────────────── */
[data-theme="dark"] .toast{
  background:var(--dm-elevated);
  border:1px solid var(--dm-border-strong);
  box-shadow:0 8px 24px rgba(0,0,0,.5);
}
[data-theme="dark"] .toast.success{background:#14532D;border-color:#166534}
[data-theme="dark"] .toast.error{background:#7F1D1D;border-color:#991B1B}
[data-theme="dark"] .toast.warning{background:#78350F;border-color:#92400E}

/* ── DETAIL VIEW ─────────────────────────── */
[data-theme="dark"] .detail-item label{color:var(--dm-text-faint)}
[data-theme="dark"] .detail-item span{color:var(--dm-text)}
[data-theme="dark"] .detail-table th{
  background:var(--dm-raised);
  color:var(--dm-text-muted);
  border-bottom-color:var(--dm-border);
}
[data-theme="dark"] .detail-table td{
  color:var(--dm-text);
  border-bottom-color:var(--dm-border);
}

/* ── FLAGS ───────────────────────────────── */
[data-theme="dark"] .flag-badge{background:rgba(194,65,12,.2);color:#FCA5A5;border-color:rgba(239,68,68,.3)}
[data-theme="dark"] .flags-panel{background:rgba(120,53,15,.15);border-color:rgba(234,88,12,.25)}
[data-theme="dark"] .flags-panel-title{color:#FCA5A5}
[data-theme="dark"] .flag-item{color:#FCD9C4}
[data-theme="dark"] .flag-item .flag-field{color:#FCA5A5}
[data-theme="dark"] .flag-item.critical{color:#FCA5A5}

/* ── UPLOAD MODAL ────────────────────────── */
[data-theme="dark"] .upload-modal{
  background:var(--dm-surface);
  box-shadow:0 24px 64px rgba(0,0,0,.7),0 0 0 1px var(--dm-border);
}
[data-theme="dark"] .upload-modal-head{
  border-bottom-color:var(--dm-border);
}
[data-theme="dark"] .upload-modal-head h2{color:#E8F0FF}
[data-theme="dark"] .upload-modal-head p{color:var(--dm-text-muted)}
[data-theme="dark"] .upload-modal-foot{border-top-color:var(--dm-border)}
[data-theme="dark"] .upload-drop-zone{
  border-color:var(--dm-border-strong);
  background:var(--dm-raised);
}
[data-theme="dark"] .upload-drop-zone:hover,
[data-theme="dark"] .upload-drop-zone.drag-over{
  border-color:var(--navy-400);
  background:rgba(10,37,80,.6);
}
[data-theme="dark"] .upload-drop-zone h3{color:#E8F0FF}
[data-theme="dark"] .upload-drop-zone p{color:var(--dm-text-muted)}
[data-theme="dark"] .upload-file-list .upload-file-item{
  background:var(--dm-raised);
  border-color:var(--dm-border);
}
[data-theme="dark"] .upload-file-item .file-name{color:#E8F0FF}
[data-theme="dark"] .upload-file-item .file-size{color:var(--dm-text-faint)}
[data-theme="dark"] .upload-progress-bar-wrap{background:var(--dm-elevated)}
[data-theme="dark"] .upload-progress-label{color:var(--dm-text-muted)}
[data-theme="dark"] #upload-log{color:var(--dm-text-muted)}

/* ── SETTINGS VIEW ───────────────────────── */
[data-theme="dark"] #view-settings{background:var(--dm-bg)!important}
[data-theme="dark"] .settings-sidebar-item{color:var(--dm-text-muted)}
[data-theme="dark"] .settings-sidebar-item:hover{background:var(--dm-raised);color:#93C5FD}
[data-theme="dark"] .settings-sidebar-item.active{background:rgba(16,69,160,.3);color:#93C5FD}
[data-theme="dark"] .settings-panel > div,
[data-theme="dark"] .settings-panel > div > div{background:var(--dm-surface)!important;border-color:var(--dm-border)!important}
[data-theme="dark"] .dd-table th{color:var(--dm-text-muted);border-bottom-color:var(--dm-border)}
[data-theme="dark"] .dd-table td{border-bottom-color:var(--dm-border);color:var(--dm-text)}
[data-theme="dark"] .dd-table tr:hover td{background:var(--dm-raised)}
[data-theme="dark"] .dd-group-title{
  background:var(--dm-raised);
  border-color:var(--dm-border);
  color:#93C5FD;
}
[data-theme="dark"] .dd-desc{color:var(--dm-text-faint)}
[data-theme="dark"] .dd-status-badge.on{background:rgba(34,197,94,.15);color:#86EFAC}
[data-theme="dark"] .dd-status-badge.off{background:var(--dm-raised);color:var(--dm-text-faint)}
[data-theme="dark"] #api-key-input{
  background:var(--dm-input-bg)!important;
  border-color:var(--dm-border)!important;
  color:var(--dm-text)!important;
}

/* ── MIL DATE PICKER ─────────────────────── */
[data-theme="dark"] .mil-date-display{
  background:var(--dm-input-bg);
  border-color:var(--dm-border);
  color:var(--dm-text);
}
[data-theme="dark"] .mil-date-display .placeholder{color:var(--dm-text-faint)}
[data-theme="dark"] .mil-date-display .cal-icon{color:var(--dm-text-faint)}
[data-theme="dark"] .mil-date-display:focus,
[data-theme="dark"] .mil-date-display.open{border-color:var(--navy-400)}
[data-theme="dark"] .mil-date-picker{
  background:var(--dm-surface);
  border-color:var(--dm-border);
  box-shadow:0 8px 32px rgba(0,0,0,.6);
}
[data-theme="dark"] .mil-date-picker-header span{color:#E8F0FF}
[data-theme="dark"] .mil-date-nav{color:var(--dm-text-muted)}
[data-theme="dark"] .mil-date-nav:hover{background:var(--dm-raised);color:#93C5FD}
[data-theme="dark"] .mil-date-grid .dow{color:var(--dm-text-faint)}
[data-theme="dark"] .mil-date-cell{color:var(--dm-text)}
[data-theme="dark"] .mil-date-cell:hover{background:rgba(16,69,160,.4);color:#93C5FD}
[data-theme="dark"] .mil-date-cell.today{color:var(--gold-400)}
[data-theme="dark"] .mil-date-cell.selected{background:var(--navy-600);color:#fff!important}
[data-theme="dark"] .mil-date-cell.other-month{color:var(--dm-text-faint)}
[data-theme="dark"] .mil-date-selects select{
  background:var(--dm-raised);
  border-color:var(--dm-border);
  color:var(--dm-text);
}
[data-theme="dark"] .mil-date-clear{
  background:var(--dm-raised);
  border-color:var(--dm-border);
  color:var(--dm-text-muted);
}
[data-theme="dark"] .mil-date-clear:hover{background:rgba(239,68,68,.15);color:#f87171;border-color:rgba(239,68,68,.3)}

/* ── EMPTY STATE ─────────────────────────── */
[data-theme="dark"] .empty-state{color:var(--dm-text-faint)}
[data-theme="dark"] .empty-state h3{color:var(--dm-text-muted)}

/* ── PRINT TOOLBAR ───────────────────────── */
[data-theme="dark"] .print-toolbar{
  background:linear-gradient(135deg,#010C1A,#041427);
  border-bottom-color:var(--dm-border);
}

/* ═══════════════════════════════════════════════════════════════
   PORTAL DARK MODE
═══════════════════════════════════════════════════════════════ */
[data-theme="dark"] .portal-shell{background:var(--dm-bg)}
[data-theme="dark"] .portal-topbar{
  background:linear-gradient(135deg,#010C1A 0%,#041427 100%);
  border-bottom:1px solid var(--dm-border);
}
[data-theme="dark"] .portal-topbar-sub{color:var(--dm-text-muted)}
[data-theme="dark"] .portal-hero h1{color:#E8F0FF}
[data-theme="dark"] .portal-hero p{color:var(--dm-text-muted)}

/* Portal option cards */
[data-theme="dark"] .portal-option-card{
  background:var(--dm-surface);
  border-color:var(--dm-border);
  box-shadow:0 2px 8px rgba(0,0,0,.3);
}
[data-theme="dark"] .portal-option-card:hover{
  border-color:var(--navy-400);
  box-shadow:0 4px 20px rgba(16,69,160,.3);
}
[data-theme="dark"] .portal-option-title{color:#E8F0FF}
[data-theme="dark"] .portal-option-desc{color:var(--dm-text-muted)}
[data-theme="dark"] .portal-option-arrow{color:var(--dm-text-faint)}
[data-theme="dark"] .portal-option-icon.blue{background:rgba(16,69,160,.25)}
[data-theme="dark"] .portal-option-icon.gold{background:rgba(240,190,42,.1)}
[data-theme="dark"] .portal-divider{color:var(--dm-text-faint)}
[data-theme="dark"] .portal-divider::before,
[data-theme="dark"] .portal-divider::after{background:var(--dm-border)}

/* Portal success */
[data-theme="dark"] .portal-success-card{
  background:var(--dm-surface);
  border-color:var(--dm-border);
}
[data-theme="dark"] .portal-success-name{color:#E8F0FF}
[data-theme="dark"] .portal-success-meta{color:var(--dm-text-muted)}
[data-theme="dark"] .portal-success-icon{background:rgba(34,197,94,.12)}

/* Portal upload */
[data-theme="dark"] .portal-upload-body{background:var(--dm-bg)}
[data-theme="dark"] .portal-upload-drop{
  border-color:var(--dm-border-strong);
  background:var(--dm-raised);
}
[data-theme="dark"] .portal-upload-drop:hover,
[data-theme="dark"] .portal-upload-drop.dragover{
  border-color:var(--navy-400);
  background:rgba(10,37,80,.6);
}
[data-theme="dark"] .portal-upload-drop h3{color:#E8F0FF}
[data-theme="dark"] .portal-upload-drop p{color:var(--dm-text-muted)}
[data-theme="dark"] .portal-upload-drop-icon{background:rgba(16,69,160,.25)}
[data-theme="dark"] .portal-upload-file-item{
  background:var(--dm-surface);
  border-color:var(--dm-border);
}
[data-theme="dark"] .portal-upload-file-name{color:#E8F0FF}
[data-theme="dark"] .portal-upload-progress{
  background:var(--dm-surface);
  border-color:var(--dm-border);
}
[data-theme="dark"] #portal-progress-text,
[data-theme="dark"] #portal-progress-pct{color:var(--dm-text-muted)}
[data-theme="dark"] #portal-progress-bar{background:linear-gradient(90deg,var(--navy-500),var(--navy-400))}
[data-theme="dark"] #portal-progress-bar{box-shadow:0 0 8px rgba(52,120,220,.4)}
[data-theme="dark"] .portal-api-key-note{
  background:rgba(240,190,42,.06);
  border-color:rgba(240,190,42,.2);
  color:var(--dm-text-muted);
}
[data-theme="dark"] .portal-api-key-note strong{color:#E8F0FF}
[data-theme="dark"] #portal-api-key-input{
  background:var(--dm-input-bg);
  border-color:var(--dm-border);
  color:var(--dm-text);
}
[data-theme="dark"] .portal-form-header{
  background:linear-gradient(135deg,#010C1A,#041427);
  border-bottom:1px solid var(--dm-border);
}

/* ── MISC DARK FIXES ──────────────────────── */
[data-theme="dark"] .tag{background:rgba(16,69,160,.25);color:#93C5FD}
[data-theme="dark"] .mono{color:var(--dm-text)}
/* Ghost buttons in dark stay readable */
[data-theme="dark"] .btn-ghost{
  border-color:rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);
}
[data-theme="dark"] .btn-ghost:hover{background:rgba(255,255,255,.08)}
/* Inline action buttons in table (not topbar) */
[data-theme="dark"] td .btn-ghost{
  border-color:var(--dm-border);
  color:var(--dm-text-muted);
  background:transparent;
}
[data-theme="dark"] td .btn-ghost:hover{background:var(--dm-raised);color:#93C5FD}
/* Self-submitted badge */
[data-theme="dark"] .self-sub-badge{background:rgba(240,190,42,.1)!important;color:#FCD34D!important;border-color:rgba(240,190,42,.25)!important}
