/* ============================================================
   STPI Photo Portal — Enterprise v3
   Software Technology Parks of India | MeitY | Govt. of India
   Brand: Navy #0D2B6E  ·  Saffron #F47920  ·  White #FFFFFF
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Inter:wght@300;400;500;600&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --navy:         #0D2B6E;
  --navy-mid:     #16398A;
  --navy-light:   #2255B4;
  --navy-pale:    #EEF2FB;
  --saffron:      #F47920;
  --saffron-dk:   #D4641A;
  --saffron-lt:   #FEF0E6;
  --saffron-glow: rgba(244,121,32,.16);
  --gold:         #EFA00B;
  --bg:           #F0F4FA;
  --bg-2:         #E8EEF8;
  --surface:      #FFFFFF;
  --surface-2:    #F8FAFF;
  --surface-3:    #F2F5FC;
  --border:       #D5DFEF;
  --border-lt:    #E8EFF9;
  --text-h:       #0D2B6E;
  --text-body:    #2C3A52;
  --text-muted:   #6B7B9A;
  --text-light:   #A0AFC8;
  --green:        #16A34A;   --green-bg:   #F0FDF4;  --green-border:#BBF7D0;
  --amber:        #D97706;   --amber-bg:   #FFFBEB;  --amber-border:#FDE68A;
  --red:          #DC2626;   --red-bg:     #FEF2F2;  --red-border:  #FECACA;
  --blue:         #2563EB;   --blue-bg:    #EFF6FF;  --blue-border: #BFDBFE;
  --purple:       #7C3AED;   --purple-bg:  #F5F3FF;
  --teal:         #0D9488;   --teal-bg:    #F0FDFA;
  --radius-xs:    4px;
  --radius-sm:    6px;
  --radius:       10px;
  --radius-lg:    16px;
  --radius-xl:    22px;
  --shadow-xs:    0 1px 3px rgba(13,43,110,.06);
  --shadow-sm:    0 2px 8px rgba(13,43,110,.09);
  --shadow:       0 4px 16px rgba(13,43,110,.12);
  --shadow-lg:    0 8px 32px rgba(13,43,110,.16);
  --shadow-xl:    0 16px 48px rgba(13,43,110,.2);
  --transition:   all .18s ease;
  --sidebar-w:    248px;
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:14px}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--text-body);line-height:1.6;min-height:100vh;display:flex;flex-direction:column}
h1,h2,h3,h4,h5,h6,.font-jakarta{font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:var(--text-h);font-weight:700;line-height:1.25}
a{color:var(--navy-light);text-decoration:none}
a:hover{color:var(--saffron)}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--border-lt)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ── Gov Banner ─────────────────────────────────────────────── */
.gov-banner{
  background:linear-gradient(90deg,var(--navy) 0%,var(--navy-mid) 100%);
  padding:5px 24px;display:flex;align-items:center;justify-content:space-between;
  font-size:11px;color:rgba(255,255,255,.6);letter-spacing:.02em;flex-shrink:0;
  border-bottom:2px solid var(--saffron);
}
.gov-banner strong{color:#fff;font-family:'Plus Jakarta Sans',sans-serif}
.gov-badge-wrap{display:flex;align-items:center;gap:6px}
.gov-badge{
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:var(--radius-xs);padding:1px 8px;font-size:9.5px;
  color:rgba(255,255,255,.85);font-weight:700;letter-spacing:.06em;
}
.gov-badge.tricolor{
  background:linear-gradient(90deg,#FF9933 33%,#fff 33%,#fff 66%,#138808 66%);
  color:var(--navy);border:1px solid rgba(0,0,0,.2);font-weight:800;
}
.gov-flag{display:inline-flex;gap:2px;align-items:center}
.gov-flag span{display:inline-block;width:10px;height:4px;border-radius:1px}
.gov-flag .f1{background:#FF9933}.gov-flag .f2{background:#fff;border:1px solid #ddd}.gov-flag .f3{background:#138808}

/* ── Navbar ─────────────────────────────────────────────────── */
.portal-nav{
  background:var(--surface);border-bottom:3px solid var(--saffron);
  box-shadow:0 2px 12px rgba(13,43,110,.1);position:sticky;top:0;z-index:1040;flex-shrink:0;
}
.nav-inner{display:flex;align-items:stretch;height:64px;padding:0 24px;gap:0}
.nav-brand{display:flex;align-items:center;gap:13px;text-decoration:none;padding-right:22px;border-right:1px solid var(--border-lt);flex-shrink:0}
.brand-emblem{
  width:44px;height:44px;
  background:linear-gradient(135deg,var(--navy),var(--navy-mid));
  border-radius:var(--radius);display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;color:var(--saffron);position:relative;overflow:hidden;
  box-shadow:0 3px 12px rgba(13,43,110,.25);
}
.brand-emblem::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--saffron)}
.brand-name{font-family:'Plus Jakarta Sans',sans-serif;font-size:.95rem;font-weight:800;color:var(--navy);display:block;letter-spacing:-.01em;line-height:1.2}
.brand-tagline{font-size:9px;color:var(--text-light);text-transform:uppercase;letter-spacing:.07em;display:block}
.nav-links{display:flex;align-items:stretch;list-style:none;flex:1;gap:0;padding-left:12px}
.nav-links li{display:flex;align-items:stretch}
.nav-links a{
  display:flex;align-items:center;gap:7px;padding:0 13px;
  font-size:.81rem;font-weight:500;color:var(--text-body);
  border-bottom:3px solid transparent;transition:var(--transition);position:relative;top:3px;
}
.nav-links a:hover{color:var(--navy);border-bottom-color:var(--border)}
.nav-links a.active{color:var(--navy);font-weight:600;border-bottom-color:var(--saffron)}
.nav-links a i{font-size:.74rem;color:var(--text-light)}
.nav-links a.active i,.nav-links a:hover i{color:var(--saffron)}
.nav-right{display:flex;align-items:center;gap:6px;margin-left:auto;padding-left:14px;border-left:1px solid var(--border-lt)}
.nav-icon-btn{width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;transition:var(--transition);background:transparent;border:1px solid transparent;position:relative;font-size:.85rem}
.nav-icon-btn:hover{background:var(--bg);border-color:var(--border);color:var(--navy)}
.notif-badge{position:absolute;top:5px;right:5px;width:7px;height:7px;background:var(--red);border-radius:50%;border:2px solid #fff}
.notif-count{position:absolute;top:3px;right:3px;min-width:16px;height:16px;background:var(--red);border-radius:20px;border:2px solid #fff;font-size:8px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;padding:0 3px}
.user-chip{display:flex;align-items:center;gap:9px;padding:5px 11px 5px 5px;background:var(--bg);border:1px solid var(--border);border-radius:100px;cursor:pointer;transition:var(--transition)}
.user-chip:hover{border-color:var(--navy-light);background:var(--navy-pale)}
.user-avatar{width:30px;height:30px;background:linear-gradient(135deg,var(--navy),var(--navy-light));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:#fff;flex-shrink:0}
.user-avatar.sm{width:26px;height:26px;font-size:.65rem}
.user-avatar.lg{width:42px;height:42px;font-size:.95rem}
.user-avatar.xl{width:56px;height:56px;font-size:1.2rem}
.user-name-sm{font-size:.76rem;font-weight:600;color:var(--text-h);display:block}
.user-role-sm{font-size:.63rem;color:var(--text-muted);display:block}
.dropdown-menu{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow-lg)!important;padding:6px!important;min-width:210px}
.dropdown-item{color:var(--text-body)!important;border-radius:var(--radius-sm)!important;padding:8px 12px!important;font-size:.81rem;transition:var(--transition)}
.dropdown-item:hover{background:var(--bg)!important;color:var(--navy)!important}
.dropdown-item i{width:16px;color:var(--text-muted);margin-right:9px}
.dropdown-divider{border-color:var(--border-lt)!important;margin:4px 0!important}

/* ── Admin Sidebar Layout ───────────────────────────────────── */
.admin-layout{display:flex;min-height:calc(100vh - 98px)}
.admin-sidebar{
  width:var(--sidebar-w);background:var(--navy);flex-shrink:0;
  position:sticky;top:67px;height:calc(100vh - 67px);
  overflow-y:auto;display:flex;flex-direction:column;
}
.admin-sidebar::-webkit-scrollbar{width:3px}
.admin-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15)}
.sidebar-section{padding:14px 10px 4px}
.sidebar-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.28);padding:0 8px;margin-bottom:4px}
.sidebar-link{
  display:flex;align-items:center;gap:9px;padding:9px 10px;
  border-radius:var(--radius-sm);color:rgba(255,255,255,.58);
  font-size:.8rem;font-weight:500;transition:var(--transition);
  margin-bottom:1px;position:relative;cursor:pointer;text-decoration:none;
}
.sidebar-link:hover{background:rgba(255,255,255,.08);color:rgba(255,255,255,.9)}
.sidebar-link.active{background:rgba(244,121,32,.2);color:#fff}
.sidebar-link.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--saffron);border-radius:0 2px 2px 0}
.sidebar-link i{width:17px;text-align:center;font-size:.82rem;flex-shrink:0;color:rgba(255,255,255,.35)}
.sidebar-link:hover i,.sidebar-link.active i{color:var(--saffron)}
.sidebar-badge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.sidebar-footer{margin-top:auto;padding:14px 12px;border-top:1px solid rgba(255,255,255,.08);font-size:.7rem;color:rgba(255,255,255,.25);text-align:center}
.sidebar-divider{height:1px;background:rgba(255,255,255,.07);margin:4px 10px}
.admin-content{flex:1;padding:28px 28px;overflow:hidden;min-width:0}

/* ── Page Header ───────────────────────────────────────────── */
.page-header{margin-bottom:24px}
.page-header-row{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:12px}
.page-title{font-size:1.45rem;font-weight:800;color:var(--navy);letter-spacing:-.02em;line-height:1.2}
.page-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:3px}
.breadcrumb{background:none;padding:0;margin-bottom:6px}
.breadcrumb-item a{color:var(--text-muted);font-size:.75rem}
.breadcrumb-item a:hover{color:var(--saffron)}
.breadcrumb-item.active{color:var(--text-light);font-size:.75rem}
.breadcrumb-item+.breadcrumb-item::before{color:var(--text-light)}

/* ── KPI Cards ─────────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px;margin-bottom:24px}
.kpi-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:20px;display:flex;flex-direction:column;gap:12px;
  transition:var(--transition);position:relative;overflow:hidden;
}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.kpi-card.kc-blue::before{background:linear-gradient(90deg,var(--blue),#60A5FA)}
.kpi-card.kc-green::before{background:linear-gradient(90deg,var(--green),#4ADE80)}
.kpi-card.kc-amber::before{background:linear-gradient(90deg,var(--amber),#FCD34D)}
.kpi-card.kc-red::before{background:linear-gradient(90deg,var(--red),#F87171)}
.kpi-card.kc-purple::before{background:linear-gradient(90deg,var(--purple),#A78BFA)}
.kpi-card.kc-navy::before{background:linear-gradient(90deg,var(--navy),var(--navy-light))}
.kpi-card.kc-teal::before{background:linear-gradient(90deg,var(--teal),#2DD4BF)}
.kpi-card.kc-saffron::before{background:linear-gradient(90deg,var(--saffron),var(--gold))}
.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--border)}
.kpi-top{display:flex;align-items:center;justify-content:space-between}
.kpi-icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.kpi-icon.ki-blue{background:var(--blue-bg);color:var(--blue)}
.kpi-icon.ki-green{background:var(--green-bg);color:var(--green)}
.kpi-icon.ki-amber{background:var(--amber-bg);color:var(--amber)}
.kpi-icon.ki-red{background:var(--red-bg);color:var(--red)}
.kpi-icon.ki-purple{background:var(--purple-bg);color:var(--purple)}
.kpi-icon.ki-navy{background:var(--navy-pale);color:var(--navy)}
.kpi-icon.ki-teal{background:var(--teal-bg);color:var(--teal)}
.kpi-icon.ki-saffron{background:var(--saffron-lt);color:var(--saffron)}
.kpi-trend{font-size:.7rem;font-weight:600;padding:2px 7px;border-radius:var(--radius-xs);display:inline-flex;align-items:center;gap:3px}
.kpi-trend.up{background:var(--green-bg);color:var(--green)}
.kpi-trend.down{background:var(--red-bg);color:var(--red)}
.kpi-trend.neutral{background:var(--bg);color:var(--text-muted)}
.kpi-value{font-size:1.9rem;font-weight:800;font-family:'Plus Jakarta Sans',sans-serif;color:var(--text-h);line-height:1}
.kpi-label{font-size:.75rem;color:var(--text-muted);font-weight:500;margin-top:2px}
.kpi-sub{font-size:.7rem;color:var(--text-light);margin-top:8px;padding-top:10px;border-top:1px solid var(--border-lt);display:flex;align-items:center;gap:5px}

/* ── Cards ─────────────────────────────────────────────────── */
.card-e{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xs)}
.card-e-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-lt);gap:12px;flex-wrap:wrap}
.card-e-title{font-size:.88rem;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px}
.card-e-title i{color:var(--saffron);font-size:.82rem}
.card-e-body{padding:20px}
.card-e-body.p0{padding:0}
.card-e-footer{padding:12px 20px;border-top:1px solid var(--border-lt);background:var(--surface-3)}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{border-radius:var(--radius-sm)!important;font-size:.8rem!important;font-weight:600!important;transition:var(--transition)!important}
.btn-navy{background:var(--navy)!important;border-color:var(--navy)!important;color:#fff!important}
.btn-navy:hover{background:var(--navy-mid)!important;border-color:var(--navy-mid)!important}
.btn-saffron{background:var(--saffron)!important;border-color:var(--saffron)!important;color:#fff!important}
.btn-saffron:hover{background:var(--saffron-dk)!important;border-color:var(--saffron-dk)!important}
.btn-outline-navy{border-color:var(--navy)!important;color:var(--navy)!important}
.btn-outline-navy:hover{background:var(--navy)!important;color:#fff!important}
.btn-outline-saffron{border-color:var(--saffron)!important;color:var(--saffron)!important}
.btn-outline-saffron:hover{background:var(--saffron)!important;color:#fff!important}
.btn-primary{background:var(--navy)!important;border-color:var(--navy)!important;color:#fff!important}
.btn-primary:hover{background:var(--navy-mid)!important}
.btn-success{background:var(--green)!important;border-color:var(--green)!important}
.btn-warning{background:var(--amber)!important;border-color:var(--amber)!important;color:#fff!important}
.btn-danger{background:var(--red)!important;border-color:var(--red)!important}
.btn-xs{padding:.2rem .55rem!important;font-size:.72rem!important}
.btn-sm{padding:.3rem .75rem!important;font-size:.78rem!important}
.btn-icon{width:32px;height:32px;padding:0!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;border-radius:var(--radius-sm)!important;flex-shrink:0}
.btn-icon-sm{width:26px;height:26px}

/* ── Forms ──────────────────────────────────────────────────── */
.form-control,.form-select{
  border-color:var(--border)!important;background:var(--surface)!important;
  color:var(--text-body)!important;border-radius:var(--radius-sm)!important;
  font-size:.82rem!important;padding:.5rem .85rem!important;transition:var(--transition)!important;
}
.form-control::placeholder{color:var(--text-light)!important}
.form-control:focus,.form-select:focus{
  border-color:var(--navy-light)!important;
  box-shadow:0 0 0 3px rgba(34,85,180,.1)!important;
}
.form-label{font-size:.78rem;font-weight:600;color:var(--text-body);margin-bottom:5px}
.input-group-text{background:var(--bg)!important;border-color:var(--border)!important;color:var(--text-muted)!important;font-size:.82rem}
.form-check-input{border-color:var(--border)!important}
.form-check-input:checked{background-color:var(--navy)!important;border-color:var(--navy)!important}
textarea.form-control{resize:vertical}

/* ── Tables ─────────────────────────────────────────────────── */
.table-e{width:100%;border-collapse:collapse;font-size:.8rem}
.table-e thead th{background:var(--surface-3);color:var(--text-muted);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;border-bottom:1px solid var(--border);white-space:nowrap}
.table-e tbody td{padding:11px 14px;border-bottom:1px solid var(--border-lt);color:var(--text-body);vertical-align:middle}
.table-e tbody tr:last-child td{border-bottom:none}
.table-e tbody tr:hover td{background:var(--surface-2)}
.table-responsive{overflow-x:auto}

/* ── Badges ─────────────────────────────────────────────────── */
.badge-status{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-xs);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.bs-pending {background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.bs-approved{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.bs-rejected{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.bs-deleted {background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}
.bs-active  {background:var(--green-bg);color:var(--green);border:1px solid var(--green-border)}
.bs-inactive{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}
.badge-role{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-xs);font-size:.66rem;font-weight:700;text-transform:capitalize}
.br-admin    {background:var(--red-bg);color:var(--red);border:1px solid var(--red-border)}
.br-moderator{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-border)}
.br-employee {background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-border)}
.br-uploader {background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}

/* ── Alerts ─────────────────────────────────────────────────── */
.alert{border-radius:var(--radius-sm)!important;font-size:.82rem;border:none!important}
.alert-success{background:var(--green-bg)!important;color:var(--green)!important;border-left:4px solid var(--green)!important}
.alert-danger {background:var(--red-bg)!important;color:var(--red)!important;border-left:4px solid var(--red)!important}
.alert-warning{background:var(--amber-bg)!important;color:var(--amber)!important;border-left:4px solid var(--amber)!important}
.alert-info   {background:var(--blue-bg)!important;color:var(--blue)!important;border-left:4px solid var(--blue)!important}
.btn-close{filter:none!important;opacity:.5}

/* ── Hero Section (Home) ────────────────────────────────────── */
.hero-wrap{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 60%,#1e4fc2 100%);padding:0;position:relative;overflow:hidden}
.hero-wrap::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.hero-inner{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;min-height:460px;align-items:stretch}
.hero-left{padding:60px 48px;display:flex;flex-direction:column;justify-content:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(244,121,32,.18);border:1px solid rgba(244,121,32,.35);border-radius:100px;padding:5px 14px;font-size:.72rem;font-weight:700;color:var(--saffron);text-transform:uppercase;letter-spacing:.07em;margin-bottom:20px}
.hero-title{font-size:clamp(2rem,3.5vw,3rem);font-weight:800;color:#fff;line-height:1.1;letter-spacing:-.03em;margin-bottom:16px}
.hero-title span{color:var(--saffron)}
.hero-desc{font-size:.92rem;color:rgba(255,255,255,.62);line-height:1.7;margin-bottom:28px;max-width:480px}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap}
.hero-right{background:rgba(0,0,0,.2);position:relative;overflow:hidden;min-height:320px}
.hero-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);height:100%;gap:2px}
.hero-gallery-grid img{width:100%;height:100%;object-fit:cover;opacity:.65;transition:var(--transition)}
.hero-gallery-grid img:hover{opacity:.9}
.hero-gallery-grid .hero-img-tall{grid-row:span 2}
.hero-stats-bar{display:flex;gap:0;border-top:1px solid rgba(255,255,255,.1)}
.hero-stat{flex:1;padding:18px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.hero-stat:last-child{border-right:none}
.hero-stat-val{font-size:1.5rem;font-weight:800;font-family:'Plus Jakarta Sans',sans-serif;color:#fff}
.hero-stat-val span{color:var(--saffron)}
.hero-stat-lbl{font-size:.68rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.06em;margin-top:1px}

/* ── Album & Photo Grids ────────────────────────────────────── */
.album-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.album-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;text-decoration:none;color:inherit;transition:var(--transition);display:block;
}
.album-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:rgba(13,43,110,.2)}
.album-cover{aspect-ratio:4/3;overflow:hidden;background:var(--bg);position:relative}
.album-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.album-card:hover .album-cover img{transform:scale(1.06)}
.album-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 30%,rgba(13,43,110,.7));opacity:0;transition:var(--transition);display:flex;align-items:center;justify-content:center}
.album-card:hover .album-overlay{opacity:1}
.album-overlay-icon{width:44px;height:44px;background:rgba(255,255,255,.9);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:1.1rem}
.album-badge{position:absolute;top:10px;right:10px;background:rgba(13,43,110,.75);backdrop-filter:blur(4px);color:#fff;font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:100px}
.album-event-badge{position:absolute;top:10px;left:10px;background:var(--saffron);color:#fff;font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:100px;text-transform:uppercase;letter-spacing:.05em}
.album-info{padding:14px 16px}
.album-title{font-size:.88rem;font-weight:700;color:var(--text-h);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.album-meta{font-size:.72rem;color:var(--text-muted);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.album-meta i{color:var(--text-light);font-size:.65rem}
.album-footer{padding:10px 16px;background:var(--surface-3);border-top:1px solid var(--border-lt);display:flex;align-items:center;justify-content:space-between}
.album-count{font-size:.72rem;font-weight:600;color:var(--navy);display:flex;align-items:center;gap:5px}
.album-date{font-size:.7rem;color:var(--text-light)}

.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.photo-tile{position:relative;aspect-ratio:1;overflow:hidden;border-radius:var(--radius);border:1px solid var(--border);cursor:zoom-in;background:var(--bg)}
.photo-tile img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;display:block}
.photo-tile:hover img{transform:scale(1.08)}
.photo-tile-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 45%,rgba(13,43,110,.75));opacity:0;transition:var(--transition);display:flex;align-items:flex-end;padding:10px}
.photo-tile:hover .photo-tile-overlay{opacity:1}
.photo-tile-cap{color:#fff;font-size:.7rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.photo-tile-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:var(--transition)}
.photo-tile:hover .photo-tile-actions{opacity:1}
.photo-tile-btn{width:28px;height:28px;background:rgba(255,255,255,.9);border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--navy);font-size:.72rem;transition:var(--transition)}
.photo-tile-btn:hover{background:#fff;color:var(--saffron)}

/* ── Gallery Filters ────────────────────────────────────────── */
.gallery-filter{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:20px;display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.gallery-filter .form-group{display:flex;flex-direction:column;gap:4px;min-width:160px;flex:1}

/* ── Auth ───────────────────────────────────────────────────── */
.auth-outer{min-height:calc(100vh - 98px);display:flex}
.auth-left{flex:1;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}
.auth-left::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.auth-left-content{position:relative;z-index:1;text-align:center;max-width:360px}
.auth-left-logo{width:68px;height:68px;background:rgba(255,255,255,.1);border:2px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.8rem;color:var(--saffron);margin:0 auto 22px}
.auth-left h2{color:#fff;font-size:1.6rem;margin-bottom:8px}
.auth-left p{color:rgba(255,255,255,.5);font-size:.82rem;line-height:1.7}
.auth-feature-list{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:10px}
.auth-feature-list li{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.6);font-size:.78rem}
.auth-feature-list li i{width:28px;height:28px;background:rgba(244,121,32,.18);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--saffron);font-size:.78rem;flex-shrink:0}
.auth-right{width:440px;flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:48px 40px;background:var(--surface)}
.auth-card{width:100%;max-width:360px}
.auth-card h1{font-size:1.4rem;margin-bottom:5px}
.auth-card .sub{font-size:.8rem;color:var(--text-muted);margin-bottom:28px}
.auth-divider{text-align:center;position:relative;margin:18px 0;font-size:.72rem;color:var(--text-light)}
.auth-divider::before{content:'';position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border)}
.auth-divider span{background:var(--surface);padding:0 10px;position:relative}

/* ── Upload ─────────────────────────────────────────────────── */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-lg);background:var(--surface-2);padding:3rem 2rem;text-align:center;cursor:pointer;transition:var(--transition)}
.upload-zone:hover,.upload-zone.dragging{border-color:var(--saffron);background:var(--saffron-lt)}
.upload-zone-icon{font-size:2.2rem;color:var(--saffron);margin-bottom:10px;opacity:.8}
.upload-zone h5{font-size:.92rem;color:var(--navy);margin-bottom:3px}
.upload-zone p{font-size:.78rem;color:var(--text-muted)}
.preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(88px,1fr));gap:7px}
.preview-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:1;border:2px solid var(--border)}
.preview-item img{width:100%;height:100%;object-fit:cover}
.preview-label{position:absolute;bottom:0;left:0;right:0;background:rgba(13,43,110,.65);color:#fff;font-size:.58rem;padding:2px 4px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.workflow{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-top:14px}
.wf-step{display:flex;flex-direction:column;align-items:center;gap:5px}
.wf-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem}
.wf-upload{background:var(--blue-bg);color:var(--blue)}.wf-review{background:var(--amber-bg);color:var(--amber)}.wf-publish{background:var(--green-bg);color:var(--green)}
.wf-label{font-size:.68rem;color:var(--text-muted);font-weight:600}
.wf-arrow{color:var(--text-light);font-size:.7rem}

/* ── Moderation ─────────────────────────────────────────────── */
.mod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.mod-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:relative;transition:var(--transition)}
.mod-card:hover{box-shadow:var(--shadow)}
.mod-top-bar{position:absolute;top:0;left:0;right:0;height:3px}
.mod-top-bar.pending{background:var(--amber)}.mod-top-bar.approved{background:var(--green)}.mod-top-bar.rejected{background:var(--red)}.mod-top-bar.deleted{background:var(--text-light)}
.mod-cb-wrap{position:absolute;top:12px;left:12px;z-index:2}
.mod-img-wrap{aspect-ratio:4/3;overflow:hidden;cursor:zoom-in;background:var(--bg);position:relative}
.mod-img{width:100%;height:100%;object-fit:cover;transition:transform .3s;display:block}
.mod-img-wrap:hover .mod-img{transform:scale(1.05)}
.mod-hover{position:absolute;inset:0;background:rgba(13,43,110,.42);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.3rem;opacity:0;transition:var(--transition)}
.mod-img-wrap:hover .mod-hover{opacity:1}
.mod-body{padding:10px 12px}
.mod-album{font-size:.65rem;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mod-cap{font-size:.78rem;color:var(--text-body);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mod-uploader{font-size:.7rem;color:var(--text-muted);margin-top:3px;display:flex;align-items:center;gap:4px}
.mod-date{font-size:.65rem;color:var(--text-light);margin-top:2px}
.mod-actions{padding:8px 10px;border-top:1px solid var(--border-lt);display:flex;gap:5px;flex-wrap:wrap;background:var(--surface-3)}

/* ── Activity Feed ──────────────────────────────────────────── */
.activity-feed{list-style:none;padding:0;display:flex;flex-direction:column;gap:0}
.activity-item{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--border-lt);font-size:.78rem;align-items:flex-start}
.activity-item:last-child{border-bottom:none;padding-bottom:0}
.activity-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.68rem;flex-shrink:0;margin-top:1px}
.ad-approved{background:var(--green-bg);color:var(--green)}.ad-rejected{background:var(--red-bg);color:var(--red)}
.ad-upload{background:var(--blue-bg);color:var(--blue)}.ad-pending{background:var(--amber-bg);color:var(--amber)}
.activity-body{flex:1;min-width:0}
.activity-body strong{color:var(--navy);font-weight:600}
.activity-meta{font-size:.7rem;color:var(--text-muted);margin-top:1px}
.activity-time{font-size:.66rem;color:var(--text-light);white-space:nowrap;flex-shrink:0;margin-top:3px}

/* ── Progress Bars ──────────────────────────────────────────── */
.prog-row{display:flex;align-items:center;gap:10px;font-size:.78rem;margin-bottom:10px}
.prog-label{width:130px;color:var(--text-body);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}
.prog-bar-wrap{flex:1;background:var(--bg);border-radius:100px;height:7px;overflow:hidden}
.prog-bar{height:100%;border-radius:100px;transition:width .6s ease}
.prog-val{width:36px;text-align:right;color:var(--text-muted);flex-shrink:0}

/* ── NAS Status Panel ───────────────────────────────────────── */
.nas-status-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px}
.nas-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.nas-status-dot.online{background:var(--green);box-shadow:0 0 0 3px var(--green-bg)}
.nas-status-dot.offline{background:var(--red);box-shadow:0 0 0 3px var(--red-bg)}

/* ── Photo Viewer ───────────────────────────────────────────── */
.photo-viewer-overlay{position:fixed;inset:0;background:rgba(6,12,30,.97);z-index:9999;display:flex;flex-direction:column;user-select:none}
.viewer-toolbar{background:rgba(13,43,110,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.07);padding:7px 16px;display:flex;align-items:center;gap:7px;flex-shrink:0;flex-wrap:wrap}
.toolbar-group{display:flex;align-items:center;gap:2px}
.vbtn{background:transparent;border:none;color:rgba(255,255,255,.55);width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.82rem;transition:var(--transition)}
.vbtn:hover{background:rgba(255,255,255,.1);color:#fff}
.vbtn-sep{width:1px;height:16px;background:rgba(255,255,255,.1);margin:0 3px}
.vbtn-close:hover{background:rgba(220,38,38,.3);color:#f87171}
.viewer-info{flex:1;text-align:center;min-width:0}
.viewer-caption{color:rgba(255,255,255,.78);font-size:.8rem;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.viewer-counter{color:rgba(255,255,255,.35);font-size:.7rem;display:block}
.viewer-stage{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:grab}
.viewer-stage:active{cursor:grabbing}
.viewer-img-wrap{transform-origin:center center;will-change:transform}
.viewer-img-wrap img{display:block;max-width:100vw;max-height:calc(100vh - 125px);pointer-events:none;border-radius:3px;box-shadow:0 12px 48px rgba(0,0,0,.7);transition:opacity .2s}
.viewer-loader{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3)}
.viewer-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(13,43,110,.65);border:1px solid rgba(255,255,255,.12);color:#fff;width:42px;height:64px;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:var(--transition);z-index:3}
.viewer-nav:hover{background:rgba(244,121,32,.55);border-color:var(--saffron);color:var(--saffron)}
.viewer-prev{left:10px}.viewer-next{right:10px}
.viewer-thumbstrip{display:flex;gap:3px;padding:5px 8px;background:rgba(13,43,110,.85);overflow-x:auto;flex-shrink:0}
.vthumb{width:48px;height:48px;object-fit:cover;border-radius:var(--radius-sm);cursor:pointer;opacity:.4;transition:var(--transition);flex-shrink:0;border:2px solid transparent}
.vthumb:hover{opacity:.7}.vthumb.active{opacity:1;border-color:var(--saffron)}
.viewer-zoom-indicator{position:fixed;top:74px;left:50%;transform:translateX(-50%);background:rgba(13,43,110,.92);color:#fff;padding:4px 14px;border-radius:100px;font-size:.75rem;z-index:10001;pointer-events:none}

/* ── Pagination ─────────────────────────────────────────────── */
.page-link{background:var(--surface)!important;border-color:var(--border)!important;color:var(--navy)!important;font-size:.78rem;border-radius:var(--radius-sm)!important}
.page-item.active .page-link{background:var(--navy)!important;border-color:var(--navy)!important;color:#fff!important}
.page-link:hover{background:var(--navy-pale)!important}

/* ── Footer ─────────────────────────────────────────────────── */
.portal-footer{background:var(--navy);color:rgba(255,255,255,.45);padding:22px 32px;font-size:.74rem;border-top:3px solid var(--saffron);flex-shrink:0}
.footer-brand{font-family:'Plus Jakarta Sans',sans-serif;font-weight:800;color:#fff;font-size:.9rem}
.footer-brand i{color:var(--saffron)}
.footer-links{display:flex;gap:14px;flex-wrap:wrap}
.footer-links a{color:rgba(255,255,255,.38);font-size:.72rem}
.footer-links a:hover{color:var(--saffron)}
.footer-gov{font-size:.65rem;color:rgba(255,255,255,.25);margin-top:2px}

/* ── Misc ───────────────────────────────────────────────────── */
.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}
.empty-state i{color:var(--border);font-size:3rem}
.empty-state h4{color:var(--text-body);margin-top:12px;font-size:.95rem;font-weight:600}
.empty-state p{font-size:.8rem;margin-top:5px}
.section-divider{height:1px;background:var(--border-lt);margin:20px 0}
.text-navy{color:var(--navy)!important}.text-saffron{color:var(--saffron)!important}
.bg-navy{background:var(--navy)!important}.bg-saffron{background:var(--saffron)!important}
canvas{max-width:100%}
.spin{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Responsive ─────────────────────────────────────────────── */
@media(max-width:1100px){.hero-inner{grid-template-columns:1fr}.hero-right{display:none}}
@media(max-width:992px){.admin-sidebar{display:none}.admin-content{padding:18px}.auth-left{display:none}.auth-right{width:100%}}
@media(max-width:768px){.page-title{font-size:1.2rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.album-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.kpi-grid{grid-template-columns:repeat(2,1fr)}.mod-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.hero-left{padding:36px 24px}}
@media(max-width:480px){.kpi-grid{grid-template-columns:1fr 1fr}.hero-cta{flex-direction:column}}

/* ═══════════════════════════════════════════════════════
   HOME PAGE — HERO SECTION v3
   ═══════════════════════════════════════════════════════ */

/* Hero wrapper */
.hero-section {
  position: relative;
  background: linear-gradient(135deg, #0a1e52 0%, var(--navy) 40%, #1a3f8a 100%);
  overflow: hidden;
  min-height: 560px;
  display: flex;
  flex-direction: column;
}

/* Mosaic background */
.hero-bg-mosaic {
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 2px;
  z-index: 0;
}
.hero-mosaic-cell {
  overflow: hidden;
}
.hero-mosaic-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.7) brightness(0.55);
  transition: transform 8s ease;
}
.hero-mosaic-cell:hover img {
  transform: scale(1.06);
}
.hero-mosaic-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,
    rgba(10,30,82,.96) 0%,
    rgba(13,43,110,.88) 35%,
    rgba(13,43,110,.6) 65%,
    rgba(13,43,110,.82) 100%);
  z-index: 1;
}

/* Content layout */
.hero-content-wrap {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 48px;
  align-items: center;
  padding: 52px 56px 40px;
  flex: 1;
}

/* Left panel */
.hero-left-panel {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.hero-gov-strip {
  display: flex;
  align-items: center;
  gap: 14px;
}
.hero-emblem {
  flex-shrink: 0;
}
.hero-emblem-ring {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 2px solid rgba(244,121,32,.5);
  background: rgba(244,121,32,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--saffron);
  box-shadow: 0 0 0 6px rgba(244,121,32,.06);
}
.hero-gov-label {
  font-size: .75rem;
  font-weight: 600;
  color: rgba(255,255,255,.55);
  letter-spacing: .04em;
}
.hero-gov-sub {
  font-size: .82rem;
  font-weight: 700;
  color: rgba(255,255,255,.85);
  font-family: 'Plus Jakarta Sans', sans-serif;
  letter-spacing: .01em;
}
.hero-main-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  letter-spacing: -.03em;
  margin: 0;
}
.hero-title-accent {
  color: var(--saffron);
  position: relative;
}
.hero-title-accent::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -4px;
  right: 0;
  height: 3px;
  background: var(--saffron);
  border-radius: 2px;
  opacity: .4;
}
.hero-desc {
  font-size: .9rem;
  color: rgba(255,255,255,.55);
  line-height: 1.75;
  max-width: 520px;
  margin: 0;
}
.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 100px;
  padding: 4px 13px;
  font-size: .72rem;
  font-weight: 600;
  color: rgba(255,255,255,.7);
  letter-spacing: .02em;
}
.hero-pill i {
  color: var(--saffron);
  font-size: .7rem;
}
.hero-cta-row {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.btn-hero-primary {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: var(--saffron);
  color: #fff;
  font-size: .85rem;
  font-weight: 700;
  padding: 12px 26px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: var(--transition);
  font-family: 'Plus Jakarta Sans', sans-serif;
  box-shadow: 0 4px 16px rgba(244,121,32,.35);
  border: none;
}
.btn-hero-primary:hover {
  background: var(--saffron-dk);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px rgba(244,121,32,.45);
}
.btn-hero-ghost {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: transparent;
  color: rgba(255,255,255,.8);
  font-size: .85rem;
  font-weight: 600;
  padding: 11px 24px;
  border-radius: var(--radius);
  text-decoration: none;
  border: 1.5px solid rgba(255,255,255,.25);
  transition: var(--transition);
}
.btn-hero-ghost:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
  border-color: rgba(255,255,255,.45);
}

/* Right panel — photo showcase */
.hero-right-panel {
  position: relative;
}
.hero-photo-showcase {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.hero-photo-main {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 2px solid rgba(255,255,255,.1);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  aspect-ratio: 16/10;
}
.hero-photo-main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-photo-badge {
  position: absolute;
  bottom: 12px;
  left: 12px;
  background: rgba(13,43,110,.85);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  padding: 5px 12px;
  border-radius: 100px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.hero-photo-badge i { color: var(--gold); }
.hero-photo-grid-mini {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.hero-mini-cell {
  border-radius: var(--radius-sm);
  overflow: hidden;
  border: 1.5px solid rgba(255,255,255,.08);
  aspect-ratio: 1;
}
.hero-mini-cell img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s;
}
.hero-mini-cell:hover img { transform: scale(1.08); }

/* Stats strip */
.hero-stats-strip {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  background: rgba(0,0,0,.3);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 0 56px;
}
.hero-stat-item {
  flex: 1;
  padding: 18px 20px;
  text-align: center;
}
.hero-stat-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.7rem;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: 4px;
}
.hero-stat-num span { color: var(--saffron); font-size: 1.1rem; }
.hero-stat-lbl {
  font-size: .67rem;
  color: rgba(255,255,255,.4);
  text-transform: uppercase;
  letter-spacing: .07em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}
.hero-stat-lbl i { color: var(--saffron); font-size: .6rem; }
.hero-stat-sep {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,.1);
  flex-shrink: 0;
}

/* Announcement band */
.announce-band {
  background: linear-gradient(90deg, var(--navy-mid), var(--navy));
  border-top: 2px solid var(--saffron);
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: 10px 0;
}
.announce-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.announce-tag {
  flex-shrink: 0;
  background: var(--saffron);
  color: #fff;
  font-size: .7rem;
  font-weight: 800;
  padding: 3px 12px;
  border-radius: 100px;
  text-transform: uppercase;
  letter-spacing: .06em;
  display: flex;
  align-items: center;
  gap: 5px;
}
.announce-text {
  font-size: .78rem;
  color: rgba(255,255,255,.55);
  flex: 1;
}
.announce-link {
  flex-shrink: 0;
  font-size: .75rem;
  font-weight: 700;
  color: var(--saffron);
  text-decoration: none;
  white-space: nowrap;
  display: flex;
  align-items: center;
  gap: 5px;
}
.announce-link:hover { color: var(--gold); }

/* Home sections */
.home-section {
  max-width: 1440px;
  margin: 0 auto;
  padding: 52px 40px;
}
.home-section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}
.section-eyebrow {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--saffron);
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.section-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -.02em;
  margin: 0;
}

/* How it Works */
.hiw-section {
  background: linear-gradient(135deg, var(--navy) 0%, #1a3f8a 100%);
  padding: 60px 40px;
  position: relative;
  overflow: hidden;
}
.hiw-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hiw-grid {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  position: relative;
  z-index: 1;
}
.hiw-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  padding: 28px 22px;
  transition: var(--transition);
  position: relative;
}
.hiw-card:hover {
  background: rgba(255,255,255,.1);
  transform: translateY(-3px);
}
.hiw-num {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 2.4rem;
  font-weight: 800;
  color: rgba(255,255,255,.06);
  line-height: 1;
  position: absolute;
  top: 16px;
  right: 20px;
}
.hiw-icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  margin-bottom: 16px;
}
.hiw-icon-saffron { background: rgba(244,121,32,.2); color: var(--saffron); }
.hiw-icon-green   { background: rgba(22,163,74,.2);  color: #4ade80; }
.hiw-icon-blue    { background: rgba(37,99,235,.2);  color: #60a5fa; }
.hiw-icon-purple  { background: rgba(124,58,237,.2); color: #a78bfa; }
.hiw-title {
  font-size: .92rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.hiw-desc {
  font-size: .76rem;
  color: rgba(255,255,255,.45);
  line-height: 1.65;
  margin: 0;
}

/* CTA band */
.cta-band {
  background: linear-gradient(90deg, var(--saffron) 0%, var(--saffron-dk) 100%);
  padding: 36px 40px;
}
.cta-band-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.cta-title {
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 1.25rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: 4px;
}
.cta-desc {
  font-size: .82rem;
  color: rgba(255,255,255,.7);
  margin: 0;
}
.cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  flex-shrink: 0;
}
.cta-band .btn-hero-primary {
  background: #fff;
  color: var(--saffron);
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}
.cta-band .btn-hero-primary:hover {
  background: rgba(255,255,255,.92);
  color: var(--saffron-dk);
}
.cta-band .btn-hero-ghost {
  border-color: rgba(255,255,255,.4);
  color: rgba(255,255,255,.9);
}

/* Hero responsive */
@media(max-width:1100px) {
  .hero-content-wrap { grid-template-columns:1fr; padding:40px 32px 32px; }
  .hero-right-panel  { display:none; }
  .hero-bg-mosaic    { grid-template-columns:repeat(3,1fr); }
  .hiw-grid          { grid-template-columns:repeat(2,1fr); }
}
@media(max-width:768px) {
  .hero-stats-strip  { flex-wrap:wrap; padding:0 20px; }
  .hero-stat-item    { padding:14px 10px; }
  .hero-stat-sep     { display:none; }
  .hero-stat-num     { font-size:1.3rem; }
  .announce-inner    { padding:0 20px; }
  .home-section      { padding:36px 20px; }
  .hiw-section       { padding:40px 20px; }
  .cta-band          { padding:28px 20px; }
  .hiw-grid          { grid-template-columns:1fr; }
  .hero-content-wrap { padding:36px 24px 28px; }
}
