/* ===== Matri Aloy – Modern Redesign ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ══════════ CSS Variables (Light/Dark) ══════════ */
:root {
  --bg-primary:#f0f4f8; --bg-secondary:#ffffff;
  --text-primary:#0f172a; --text-secondary:#475569; --text-muted:#94a3b8;
  --accent:#7c3aed; --accent-hover:#6d28d9; --accent-glow:rgba(124,58,237,.25);
  --accent2:#10b981;
  --card-bg:rgba(255,255,255,.75); --card-border:rgba(226,232,240,.6);
  --card-shadow:0 8px 32px rgba(15,23,42,.08);
  --input-bg:#f8fafc; --input-border:#e2e8f0; --input-focus-ring:rgba(124,58,237,.2);
  --sidebar1-bg:#0f172a; --sidebar2-bg:rgba(248,250,252,.92);
  --topbar-bg:rgba(255,255,255,.7);
  --table-head:#f1f5f9; --table-border:#e2e8f0;
  --login-left-bg:linear-gradient(135deg,#7c3aed 0%,#4f46e5 50%,#2563eb 100%);
  --login-left-overlay:rgba(0,0,0,.25);
  --transition-theme:.35s cubic-bezier(.4,0,.2,1);
}

[data-theme="dark"] {
  --bg-primary:#0b1120; --bg-secondary:#1e293b;
  --text-primary:#f1f5f9; --text-secondary:#cbd5e1; --text-muted:#64748b;
  --accent:#a78bfa; --accent-hover:#8b5cf6; --accent-glow:rgba(167,139,250,.3);
  --card-bg:rgba(30,41,59,.65); --card-border:rgba(51,65,85,.5);
  --card-shadow:0 8px 32px rgba(0,0,0,.3);
  --input-bg:rgba(15,23,42,.6); --input-border:#334155; --input-focus-ring:rgba(167,139,250,.25);
  --sidebar1-bg:#020617; --sidebar2-bg:rgba(15,23,42,.92);
  --topbar-bg:rgba(15,23,42,.7);
  --table-head:rgba(30,41,59,.9); --table-border:#1e293b;
  --login-left-bg:linear-gradient(135deg,#1e1b4b 0%,#312e81 50%,#1e3a5f 100%);
  --login-left-overlay:rgba(0,0,0,.45);
}

/* ══════════ Base Reset ══════════ */
*,*::before,*::after{box-sizing:border-box}
body.matri-login-page{margin:0;padding:0;font-family:'Inter',system-ui,sans-serif;min-height:100vh;height:100vh;overflow:hidden;background:var(--bg-primary);color:var(--text-primary);transition:background var(--transition-theme),color var(--transition-theme)}
body.matri-login-page:not(.app-active) .site-bg,
body.matri-login-page:not(.app-active) .portal,
body.matri-login-page:not(.app-active) .portal-header,
body.matri-login-page:not(.app-active) .portal-ticker,
body.matri-login-page:not(.app-active) .portal-nav,
body.matri-login-page:not(.app-active) .portal-footer{display:none!important}
body.matri-login-page.app-active{overflow:auto;height:auto}

/* ══════════ Animated BG Orbs ══════════ */
.ma-orb{position:fixed;border-radius:50%;filter:blur(100px);opacity:.5;pointer-events:none;z-index:0;animation:orbFloat 18s ease-in-out infinite alternate}
.ma-orb-1{width:420px;height:420px;background:var(--accent);top:-120px;left:-80px}
.ma-orb-2{width:350px;height:350px;background:#3b82f6;bottom:-80px;right:-60px;animation-delay:-6s}
.ma-orb-3{width:280px;height:280px;background:#ec4899;top:40%;left:50%;animation-delay:-12s}
[data-theme="dark"] .ma-orb{opacity:.2}
@keyframes orbFloat{0%{transform:translate(0,0) scale(1)}50%{transform:translate(60px,-40px) scale(1.15)}100%{transform:translate(-30px,50px) scale(.9)}}

/* ══════════ Theme Toggle ══════════ */
.theme-toggle{width:48px;height:48px;border-radius:14px;border:1px solid var(--card-border);background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s;z-index:50;box-shadow:var(--card-shadow)}
.theme-toggle:hover{transform:scale(1.08) rotate(8deg);border-color:var(--accent)}
.theme-toggle svg{width:22px;height:22px;transition:transform .4s}
.theme-toggle .ico-moon{display:none}
[data-theme="dark"] .theme-toggle .ico-sun{display:none}
[data-theme="dark"] .theme-toggle .ico-moon{display:block}
.login-theme-pos{position:absolute;top:24px;right:24px}

/* ══════════ LOGIN SCREEN ══════════ */
.os-login-wrapper{display:flex;height:100vh;width:100%;position:relative;z-index:1}

/* Left Panel */
.os-left{flex:1 1 55%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:#0f0a1e}
.os-left-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.92;transition:opacity var(--transition-theme)}
[data-theme="dark"] .os-left-img{opacity:.7;filter:brightness(.85)}

/* Right Panel */
.os-right{flex:0 0 clamp(380px,40vw,520px);display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg-primary);position:relative;z-index:2;transition:background var(--transition-theme)}

.os-login-card{width:100%;max-width:420px;animation:slideUp .6s ease-out}
@keyframes slideUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}

.os-card-icon{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 8px 24px var(--accent-glow);animation:iconPulse 3s ease-in-out infinite}
@keyframes iconPulse{0%,100%{box-shadow:0 8px 24px var(--accent-glow)}50%{box-shadow:0 12px 36px var(--accent-glow)}}
.os-card-icon svg{width:30px;height:30px;stroke:#fff}
.os-card-title{font-size:1.7rem;font-weight:800;color:var(--text-primary);text-align:center;margin:0 0 6px}
.os-card-subtitle{text-align:center;color:var(--text-secondary);font-size:.9rem;margin:0 0 6px}
.os-card-divider{width:100%;height:1px;background:var(--input-border);margin:18px 0 22px;position:relative}
.os-card-divider::after{content:'♥';position:absolute;top:-9px;left:50%;transform:translateX(-50%);font-size:.7rem;color:var(--accent);background:var(--bg-primary);padding:0 10px;transition:background var(--transition-theme)}

/* Form Fields */
.os-field{margin-bottom:18px}
.os-field label{display:block;font-weight:600;font-size:.82rem;color:var(--text-secondary);margin-bottom:6px}
.os-input-wrap{position:relative;display:flex;align-items:center}
.os-input-wrap .os-icon{position:absolute;left:14px;color:var(--text-muted);display:flex;pointer-events:none}
.os-input-wrap .os-icon svg{width:17px;height:17px}
.os-input-wrap select,.os-input-wrap input{width:100%;padding:12px 14px 12px 42px;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:12px;font-size:.9rem;font-family:inherit;color:var(--text-primary);outline:none;transition:all .25s;-webkit-appearance:none;appearance:none}
.os-input-wrap select{padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.os-input-wrap input:focus,.os-input-wrap select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--input-focus-ring)}
[data-theme="dark"] .os-input-wrap select option{background:var(--bg-secondary);color:var(--text-primary)}
.os-toggle-pw{position:absolute;right:12px;background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;display:flex}
.os-toggle-pw svg{width:17px;height:17px}
.os-extras{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;font-size:.82rem}
.os-remember{display:flex;align-items:center;gap:7px;color:var(--text-secondary);cursor:pointer}
.os-remember input{accent-color:var(--accent);width:15px;height:15px}
.os-forgot{color:var(--accent);text-decoration:none;font-weight:600}
.os-forgot:hover{text-decoration:underline}

.os-submit{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 6px 20px var(--accent-glow);transition:all .3s;position:relative;overflow:hidden}
.os-submit::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .6s}
.os-submit:hover::before{left:100%}
.os-submit:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--accent-glow)}
.os-submit svg{width:18px;height:18px}
.form-message{text-align:center;margin-top:10px;font-size:.82rem;color:#ef4444;min-height:18px}
.os-secure{text-align:center;margin-top:18px;font-size:.78rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;gap:6px}
.os-secure svg{width:15px;height:15px;color:var(--accent2)}

/* ══════════ POST-LOGIN DASHBOARD ══════════ */
body.matri-login-page .os-login-wrapper.is-hidden{display:none}
body.matri-login-page .os-app-shell{display:none}
body.matri-login-page .os-app-shell.is-visible{display:block}
body.matri-login-page.app-active{height:100vh;overflow:hidden;background:var(--bg-primary);transition:background var(--transition-theme)}
body.matri-login-page.app-active .site-bg{display:none}

.md-dashboard{display:flex;height:100vh;width:100vw;position:relative;z-index:1;font-family:'Inter',sans-serif}

/* Sidebar Primary */
.md-sidebar-primary{width:72px;background:var(--sidebar1-bg);display:flex;flex-direction:column;align-items:center;padding:20px 0;z-index:10;box-shadow:2px 0 20px rgba(0,0,0,.15);transition:background var(--transition-theme)}
.md-nav-icons,.md-nav-bottom{display:flex;flex-direction:column;gap:16px;width:100%;align-items:center}
.md-nav-bottom{margin-top:auto}
.md-icon-btn{background:0 0;border:none;color:rgba(255,255,255,.4);width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s}
.md-icon-btn svg{width:20px;height:20px}
.md-icon-btn:hover{color:#fff;background:rgba(255,255,255,.08)}
.md-icon-btn.active{color:var(--accent);background:var(--bg-primary)}

/* Sidebar Secondary */
.md-sidebar-secondary{width:270px;background:var(--sidebar2-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;flex-direction:column;z-index:9;border-right:1px solid var(--card-border);transition:all var(--transition-theme)}
.md-brand{padding:22px 20px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--card-border)}
.md-logo-icon{width:44px;height:44px;flex-shrink:0}
.md-brand h2{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.35}
.md-menu{padding:18px 14px;display:flex;flex-direction:column;gap:6px;flex:1}
.md-menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:0 0;border:none;border-radius:12px;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .25s;text-align:left}
.md-menu-item svg{width:20px;height:20px;stroke:currentColor;flex-shrink:0}
.md-menu-item:hover{background:rgba(124,58,237,.06);color:var(--accent)}
.md-menu-item.active{background:linear-gradient(135deg,rgba(124,58,237,.1),rgba(124,58,237,.05));color:var(--accent);font-weight:700;box-shadow:0 2px 8px rgba(124,58,237,.08)}
.md-map-area{padding:10px;height:200px;border-top:1px solid var(--card-border);display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.02);flex-shrink:0;transition:all var(--transition-theme)}
.md-map-area img{max-width:140px;opacity:.85;transition:all .3s}
[data-theme="dark"] .md-map-area{background:rgba(255,255,255,.02)}
[data-theme="dark"] .md-map-area img{filter:brightness(.8) contrast(1.1);opacity:.7}

/* Main Area */
.md-main-area{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}

/* Topbar */
.md-topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 28px;background:var(--topbar-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--card-border);z-index:2;transition:all var(--transition-theme)}
.md-topbar-title{font-weight:700;color:var(--text-primary);font-size:1rem}
.md-topbar-actions{display:flex;align-items:center;gap:16px;margin-left:auto}

.md-profile-block{display:flex;align-items:center;gap:10px;background:var(--card-bg);padding:5px 14px 5px 5px;border-radius:999px;border:1px solid var(--card-border);backdrop-filter:blur(8px)}
.md-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;display:flex;align-items:center;justify-content:center}
.md-avatar svg{width:18px;height:18px}
.md-profile-text{display:flex;flex-direction:column;line-height:1.2}
.md-profile-text strong{font-size:.82rem;color:var(--text-primary)}
.md-profile-text span{font-size:.72rem;color:var(--text-muted)}
.md-btn-icon{background:var(--card-bg);border:1px solid var(--card-border);width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:.25s}
.md-btn-icon svg{width:18px;height:18px}
.md-btn-icon:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-1px)}
.md-btn-link{display:flex;align-items:center;gap:7px;background:0 0;border:none;color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;text-decoration:none;padding:8px 12px;border-radius:10px;transition:.25s}
.md-btn-link svg{width:16px;height:16px}
.md-btn-link:hover{background:var(--card-bg);color:var(--accent)}

/* Content Body */
.md-content-body{flex:1;overflow-y:auto;padding:28px;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}
.md-content-body::-webkit-scrollbar{width:5px}
.md-content-body::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}

.tab-panel{display:none;animation:panelIn .4s ease-out}
.tab-panel.active{display:block}
@keyframes panelIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Cards */
.md-card{background:var(--card-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--card-border);border-radius:20px;padding:28px;box-shadow:var(--card-shadow);margin-bottom:20px;transition:all var(--transition-theme)}
.md-card:hover{box-shadow:0 12px 40px rgba(15,23,42,.12)}
[data-theme="dark"] .md-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.4)}
.md-card-header{margin-bottom:20px}
.md-card-header h3{font-size:1.25rem;color:var(--text-primary);margin:0 0 6px;font-weight:700}
.md-card-header h4{font-size:1.1rem;color:var(--text-primary);margin:0;font-weight:600}
.md-card-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.md-card-date{display:flex;align-items:center;gap:6px;color:var(--text-muted);font-size:.85rem}
.md-card-date svg{width:16px;height:16px}
.md-card-meta{font-size:.85rem;color:var(--text-muted);margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--card-border)}
.md-card-stats{display:flex;gap:16px;flex-wrap:wrap}
.md-stat-item{background:linear-gradient(135deg,rgba(124,58,237,.08),rgba(124,58,237,.03));padding:12px 18px;border-radius:14px;font-size:.88rem;color:var(--text-primary);border:1px solid rgba(124,58,237,.1);transition:all .25s}
.md-stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--accent-glow)}
.md-stat-item strong{color:var(--accent);font-size:1.05rem}

/* Forms */
.md-form-section h4{font-size:.88rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px;margin:0 0 14px;font-weight:700}
.md-input-grid{display:grid;gap:16px}
.md-grid-4{grid-template-columns:repeat(4,1fr)}
.span-1{grid-column:span 1}.span-2{grid-column:span 2}.span-4{grid-column:span 4}

.md-input-group label{display:block;font-size:.82rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.md-input-group input,.md-input-group select,.md-input-group textarea{width:100%;padding:11px 14px;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:10px;font-size:.9rem;font-family:inherit;color:var(--text-primary);transition:all .25s;box-sizing:border-box;outline:none}
.md-input-group input:focus,.md-input-group select:focus,.md-input-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--input-focus-ring)}
[data-theme="dark"] .md-input-group select option{background:var(--bg-secondary);color:var(--text-primary)}
.md-select-wrap{position:relative}
.md-input-disabled{opacity:.6;cursor:not-allowed}

.md-form-grid-layout{display:flex;gap:28px}
.md-col-left{flex:0 0 260px}
.md-col-right{flex:1}

.md-upload-box{border:2px dashed var(--input-border);border-radius:16px;padding:22px;text-align:center;transition:.3s}
.md-upload-box:hover{border-color:var(--accent);background:rgba(124,58,237,.02)}
.md-upload-circle{width:60px;height:60px;background:var(--input-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;border:2px solid var(--input-border)}
.md-upload-circle svg{width:26px;height:26px}
.md-upload-box-horizontal{display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left;padding:16px 20px}
.md-upload-box-vertical{display:flex;flex-direction:column;align-items:center;text-align:center;padding:20px 16px;transition:transform .25s ease,box-shadow .25s ease;cursor:default}
.md-upload-box-vertical:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 28px rgba(0,0,0,.12),0 4px 10px rgba(0,0,0,.08)}
.md-upload-actions{display:flex;align-items:center;gap:10px}
.md-pdf-icon{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:6px 12px;border-radius:8px;font-size:.75rem;font-weight:700}

/* Buttons */
.md-btn-teal,.md-btn-submit{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;border:none;padding:11px 22px;border-radius:12px;font-weight:600;font-size:.88rem;cursor:pointer;transition:all .3s;box-shadow:0 4px 14px var(--accent-glow)}
.md-btn-teal:hover,.md-btn-submit:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--accent-glow)}
.md-btn-reset,.md-btn-outline{background:transparent;color:var(--text-primary);border:1.5px solid var(--input-border);padding:11px 22px;border-radius:12px;font-weight:600;font-size:.88rem;cursor:pointer;transition:.25s}
.md-btn-reset:hover,.md-btn-outline:hover{background:var(--card-bg);border-color:var(--accent);color:var(--accent)}
.md-form-submit-row{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}

/* Tables */
.table-wrap{overflow-x:auto;border-radius:14px;border:1px solid var(--table-border);background:var(--input-bg);transition:all var(--transition-theme)}
table{width:100%;border-collapse:collapse}
th,td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--table-border);color:var(--text-primary);font-size:.88rem}
th{background:var(--table-head);font-weight:700;text-transform:uppercase;font-size:.78rem;letter-spacing:.5px;color:var(--text-secondary)}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(124,58,237,.03)}

/* Utility */
.mt-3{margin-top:20px}
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.md-upload-label{font-size:.88rem;color:var(--text-secondary)}

/* Proof Matrix (Child Marriage) */
.proof-matrix{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:10px}
.proof-card{background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:14px;padding:16px;text-align:center;transition:.25s}
.proof-card:hover{border-color:var(--accent)}
.proof-card h5{font-size:.82rem;color:var(--text-secondary);margin:0 0 10px;font-weight:700}
.proof-card input[type="file"]{font-size:.8rem;color:var(--text-secondary);width:100%}
.proof-empty{font-size:.78rem;color:var(--text-muted);margin:6px 0 0}
.proof-preview{width:100%;max-height:120px;object-fit:contain;border-radius:8px;margin-top:8px}
.file-input{display:none}

/* Back to Portal Home button on login screens */
.os-back-home{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;padding:10px 20px;border-radius:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:var(--text-secondary);font-size:.82rem;font-weight:600;text-decoration:none;transition:all .25s ease;cursor:pointer}
.os-back-home:hover{background:rgba(255,255,255,.15);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.os-back-home svg{width:16px;height:16px;flex-shrink:0}

/* Responsive */
@media(max-width:1024px){.md-form-grid-layout{flex-direction:column}.md-col-left{flex:none;width:100%;max-width:360px;margin:0 auto}.proof-matrix{grid-template-columns:1fr}}
@media(max-width:768px){.os-left{display:none}.os-right{flex:1}.md-sidebar-secondary{display:none}.md-grid-4{grid-template-columns:1fr}.span-1,.span-2,.span-4{grid-column:span 1}}