/* ═══ LOON PAWS — PREMIUM CSS STYLESHEET ═══ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  /* ── Official LGU Loon palette ── */
  --navy:#003087;          /* Deep Navy Blue — primary */
  --navy-ink:#001E52;
  --sky:#00AEEF;           /* Sky Blue — bright accent */
  --sky-light:#E3F6FE;
  --terra:#E67A3D;         /* Terracotta — warm accent */
  --terra-dark:#C75F26;--terra-light:#FBEDE2;
  --blue:#0067C2;          /* accessible link/primary blue (AA on white) */
  --blue-hover:#003087;--blue-light:#E6EEF8;--blue-300:#66C6F2;
  --green:#0E8A5F;--green-light:#E3F8EF;
  --amber:#B7791F;--amber-light:#FBF1D9;
  --red:#C2410C;--red-2:#B91C1C;--red-light:#FDECE7;
  --gray-50:#F7F9FC;--gray-100:#EEF2F8;--gray-200:#E2E8F1;--gray-300:#CBD5E1;
  --gray-400:#94A3B8;--gray-500:#64748B;--gray-600:#475569;--gray-700:#334155;
  --gray-800:#16223A;--white:#FFFFFF;
  --surface:#FFFFFF;       /* themable card/header surface */
  /* Gradients */
  --grad-blue:linear-gradient(135deg,#0073C6 0%,#003087 100%);
  --grad-accent:linear-gradient(135deg,#F0915A 0%,#E67A3D 100%);
  --grad-sidebar:linear-gradient(180deg,#003087 0%,#00256C 58%,#001E52 100%);
  /* Subtle "Chocolate Hills" backdrop — soft sky/terracotta light + rolling-hill silhouette */
  --hills:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='220' viewBox='0 0 1440 220'%3E%3Cpath fill='%23003087' fill-opacity='0.035' d='M0,160 C120,90 240,90 360,140 C480,190 600,200 720,150 C840,100 960,90 1080,135 C1200,180 1320,180 1440,140 L1440,220 L0,220 Z'/%3E%3Cpath fill='%2300AEEF' fill-opacity='0.04' d='M0,185 C160,135 300,135 460,170 C620,205 760,205 920,170 C1080,135 1240,140 1440,180 L1440,220 L0,220 Z'/%3E%3C/svg%3E");
  --grad-page:radial-gradient(1100px 520px at 100% -12%,rgba(0,174,239,.10) 0%,transparent 60%),radial-gradient(900px 480px at -8% 8%,rgba(230,122,61,.07) 0%,transparent 55%),linear-gradient(180deg,#FAFCFF 0%,#F1F5FB 100%);
  /* Layout */
  --sidebar-w:240px;--header-h:60px;
  --radius:14px;--radius-sm:10px;--radius-lg:20px;
  /* Elevation */
  --shadow-sm:0 1px 2px rgba(0,30,82,.06);
  --shadow:0 1px 3px rgba(0,30,82,.05),0 10px 26px -10px rgba(0,30,82,.16);
  --shadow-lg:0 18px 48px -12px rgba(0,30,82,.26);
  --ring:0 0 0 3.5px rgba(0,174,239,.22);
  --hairline:1px solid rgba(0,30,82,.08);
}
body{font-family:'DM Sans',sans-serif;font-size:14px;background:var(--grad-page) fixed,var(--hills) bottom center / 1440px auto no-repeat fixed;color:var(--gray-800);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color .3s,color .3s;}

/* ═══ ICONS (Lucide line icons) ═══ */
.lucide,svg.lucide,[data-lucide]{width:1em;height:1em;stroke-width:2;vertical-align:-0.15em;flex-shrink:0;}
svg.lucide{display:inline-block;}
.icon-lg svg,.icon-lg.lucide{width:1.4em;height:1.4em;}
button svg.lucide,.header-btn svg.lucide,.link-btn svg.lucide,.btn-primary svg.lucide{vertical-align:-0.18em;}
.brand-icon{color:#fff;overflow:hidden;background:transparent;}
.brand-icon.brand-fallback{background:var(--grad-accent);}
.brand-icon img{width:100%;height:100%;object-fit:contain;}
.brand-icon svg.lucide{width:20px;height:20px;}
.nav-item .ni svg.lucide{width:17px;height:17px;}
.qa-icon svg.lucide{width:22px;height:22px;}
.feat-icon svg.lucide{width:22px;height:22px;color:var(--sky);}
.notif-icon-wrap svg.lucide{width:18px;height:18px;}
.stat-ic svg.lucide{width:18px;height:18px;}
.pet-ph svg.lucide{width:46px;height:46px;stroke-width:1.5;opacity:.85;}
.adopt-thumb svg.lucide{width:34px;height:34px;stroke-width:1.6;}

/* ═══ SIDEBAR ═══ */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--grad-sidebar);display:flex;flex-direction:column;z-index:100;overflow-y:auto;border-right:1px solid rgba(255,255,255,.06);box-shadow:1px 0 0 rgba(0,0,0,.2);scrollbar-width:none;-ms-overflow-style:none;}
/* Hide the sidebar scrollbar but keep it scrollable so no menu item is cut off. */
.sidebar::-webkit-scrollbar{width:0;height:0;display:none;}
.sidebar-brand{padding:9px 16px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:11px;flex-shrink:0;}
.brand-icon{width:64px;height:64px;background:transparent;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;box-shadow:none;}
/* Compact logo inside the sidebar header (login-page logo stays large). */
.sidebar-brand .brand-icon{width:42px;height:42px;}
.brand-icon.brand-fallback{background:var(--grad-accent);box-shadow:0 6px 16px -4px rgba(230,122,61,.55),inset 0 1px 0 rgba(255,255,255,.3);}
.brand-text strong{display:block;font-size:14.5px;font-weight:700;color:white;letter-spacing:.4px;}
.brand-text span{display:block;font-size:9.5px;color:rgba(255,255,255,.5);letter-spacing:1px;text-transform:uppercase;margin-top:1px;}
.nav-section-label{font-size:9.5px;text-transform:uppercase;letter-spacing:1.1px;color:rgba(255,255,255,.32);padding:5px 18px 2px;font-weight:600;}
.nav-item{position:relative;display:flex;align-items:center;gap:11px;margin:0 9px;padding:5px 12px;color:rgba(255,255,255,.66);cursor:pointer;border-radius:9px;transition:color .18s,background .18s;font-size:13px;font-weight:500;user-select:none;line-height:1.2;}
.nav-item:hover{color:white;background:rgba(255,255,255,.06);}
.nav-item.active{color:white;background:linear-gradient(135deg,rgba(0,174,239,.30),rgba(0,174,239,.12));box-shadow:inset 0 0 0 1px rgba(0,174,239,.3);}
.nav-item.active::before{content:'';position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:3px;background:var(--sky);box-shadow:0 0 12px var(--sky);}
.nav-item .ni{font-size:15px;opacity:.7;width:18px;text-align:center;}
.nav-item.active .ni{opacity:1;}
.nav-badge{margin-left:auto;background:var(--grad-blue);color:white;font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;box-shadow:0 2px 6px -1px rgba(0,48,135,.6);}
.sidebar-footer{margin-top:auto;padding:9px 16px;border-top:1px solid rgba(255,255,255,.07);}
.sidebar-clock{color:rgba(255,255,255,.5);font-size:11px;text-align:center;letter-spacing:.3px;}

/* ═══ MAIN LAYOUT ═══ */
.main{margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column;}
.header{position:sticky;top:0;height:var(--header-h);background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:var(--hairline);display:flex;align-items:center;padding:0 22px;gap:11px;z-index:50;}
.header-title{font-size:16px;font-weight:700;color:var(--navy);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.2px;}
.search-bar{display:flex;align-items:center;gap:8px;background:var(--gray-100);border:1px solid transparent;border-radius:10px;padding:8px 12px;flex:1;max-width:280px;transition:all .18s;}
.search-bar:focus-within{background:white;border-color:var(--blue);box-shadow:var(--ring);}
.search-bar input{border:none;background:none;outline:none;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--gray-800);width:100%;}
.search-bar input::placeholder{color:var(--gray-400);}
.map-search{display:flex;align-items:center;gap:7px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:9px;padding:7px 11px;min-width:210px;transition:all .18s;}
.map-search:focus-within{background:white;border-color:var(--blue);box-shadow:var(--ring);}
.map-search i,.map-search svg{width:15px;height:15px;color:var(--gray-400);flex-shrink:0;}
.map-search input{border:none;background:none;outline:none;font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--gray-800);width:100%;padding:0;}
.map-search input::placeholder{color:var(--gray-400);}
.header-btn{display:flex;align-items:center;gap:6px;padding:8px 13px;border-radius:9px;border:1px solid var(--gray-200);background:white;font-size:12.5px;font-family:'DM Sans',sans-serif;cursor:pointer;color:var(--gray-700);transition:all .15s;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-sm);}
.header-btn:hover{background:var(--gray-50);border-color:var(--gray-300);transform:translateY(-1px);}
.header-btn.primary{background:var(--grad-blue);color:white;border-color:transparent;box-shadow:0 6px 16px -5px rgba(0,48,135,.65);}
.header-btn.primary:hover{filter:brightness(1.05);box-shadow:0 10px 22px -6px rgba(0,48,135,.7);}
.header-btn.danger{background:var(--red-light);color:var(--red-2);border-color:rgba(185,28,28,.18);}
.header-btn.danger:hover{background:var(--red-2);color:white;}
.header-avatar{width:34px;height:34px;border-radius:50%;background:var(--grad-blue);display:flex;align-items:center;justify-content:center;color:white;font-size:12.5px;font-weight:700;cursor:pointer;flex-shrink:0;box-shadow:0 4px 12px -3px rgba(0,48,135,.6),inset 0 1px 0 rgba(255,255,255,.3);transition:transform .15s;}
.header-avatar:hover{transform:scale(1.06);}
.notif-bell{position:relative;cursor:pointer;font-size:18px;padding:4px;}
.notif-dot{position:absolute;top:2px;right:2px;width:9px;height:9px;background:var(--red-2);border-radius:50%;border:2px solid white;}
.content{padding:24px;flex:1;animation:fadeUp .35s ease;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}

/* ═══ PAGES ═══ */
.page{display:none;}
.page.active{display:block;}

/* ═══ STATS CARDS ═══ */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px;}
.stat-card{position:relative;background:white;border-radius:var(--radius);padding:20px;border:var(--hairline);box-shadow:var(--shadow);cursor:default;transition:transform .18s,box-shadow .18s;overflow:hidden;}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-blue);opacity:.9;}
.stat-card::after{content:'';position:absolute;top:-30px;right:-30px;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle,rgba(0,48,135,.07),transparent 70%);}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.stat-label{font-size:11px;color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px;}
.stat-value{font-size:30px;font-weight:400;color:var(--navy);font-family:'DM Serif Display',serif;margin-bottom:5px;line-height:1;letter-spacing:-.5px;}
.stat-change{font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:3px;}
.stat-change.up{color:var(--green);}
.stat-change.down{color:var(--red);}
.stat-change.neutral{color:var(--gray-400);}

/* ═══ SECTION HEADERS ═══ */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.section-title{font-size:15px;font-weight:700;color:var(--navy);letter-spacing:-.2px;}
.link-btn{font-size:12px;color:var(--blue);cursor:pointer;font-weight:600;background:none;border:none;font-family:inherit;transition:color .15s;}
.link-btn:hover{color:var(--blue-hover);text-decoration:underline;}

/* ═══ CARDS & TABLES ═══ */
.card{background:white;border-radius:var(--radius);border:var(--hairline);box-shadow:var(--shadow);overflow:hidden;}
.card-header{padding:16px 18px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;}
.table-wrap{overflow-x:auto;}
/* Editable report preview — highlight typeable cells while in Edit mode */
#rpt-printable.editing td{outline:1px dashed var(--blue,#0046b8);background:#fffdf3;cursor:text;}
#rpt-printable.editing td:focus{outline:2px solid var(--blue,#0046b8);background:#fff;}
/* Owner "Manage Pet" cell — small inline Lucide icons (no emoji). */
.mng-cell{white-space:nowrap;}
.mng-cell svg.lucide{width:14px;height:14px;vertical-align:-3px;}
.mng-cell .mng-sep{color:var(--gray-300);margin:0 3px;}
table{width:100%;border-collapse:collapse;}
thead th{padding:12px 18px;font-size:10.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--gray-500);background:var(--gray-50);text-align:left;font-weight:700;border-bottom:1px solid var(--gray-200);white-space:nowrap;}
tbody td{padding:13px 18px;font-size:13px;color:var(--gray-700);border-bottom:1px solid var(--gray-100);vertical-align:middle;}
/* Inventory table — pin the Edit/Delete actions so they stay visible on wide tables */
.inv-actions{position:sticky;right:0;text-align:center;white-space:nowrap;}
tbody td.inv-actions{background:#fff;box-shadow:-7px 0 8px -7px rgba(0,0,0,.15);}
thead th.inv-actions{background:var(--gray-50);box-shadow:-7px 0 8px -7px rgba(0,0,0,.15);text-align:center;z-index:1;}
.inv-btn{display:inline-flex;align-items:center;gap:4px;font-size:11.5px;font-weight:600;padding:4px 9px;border-radius:7px;border:1px solid var(--gray-200);background:#fff;cursor:pointer;font-family:inherit;transition:all .15s;}
.inv-btn svg.lucide{width:13px;height:13px;}
.inv-btn.edit{color:var(--blue);border-color:#bfdbfe;}
.inv-btn.edit:hover{background:#eff6ff;}
.inv-btn.del{color:var(--red);border-color:#fecaca;}
.inv-btn.del:hover{background:#fef2f2;}
tbody tr{transition:background .12s;}
tbody tr:last-child td{border-bottom:none;}
tbody tr:hover td{background:#F7FAFF;}
.td-mono{font-family:'DM Mono',ui-monospace,monospace;font-size:11.5px;color:var(--gray-400);letter-spacing:-.2px;}

/* ═══ BADGES ═══ */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 11px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap;border:1px solid transparent;}
.badge::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.85;}
.badge-green{background:var(--green-light);color:var(--green);border-color:rgba(14,138,95,.16);}
.badge-blue{background:var(--blue-light);color:var(--blue);border-color:rgba(0,48,135,.16);}
.badge-amber{background:var(--amber-light);color:var(--amber);border-color:rgba(183,121,31,.18);}
.badge-red{background:var(--red-light);color:var(--red-2);border-color:rgba(185,28,28,.16);}
.badge-gray{background:var(--gray-100);color:var(--gray-600);border-color:rgba(71,85,105,.12);}
.badge-navy{background:rgba(15,39,69,.07);color:var(--navy);border-color:rgba(15,39,69,.12);}

/* ═══ GRIDS ═══ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}

/* ═══ CHARTS ═══ */
.chart-area{height:200px;position:relative;padding:12px 0 0;}
.chart-bar-wrap{display:flex;align-items:flex-end;gap:6px;height:160px;padding:0 16px;}
.chart-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;}
.chart-bar{width:100%;border-radius:6px 6px 2px 2px;transition:opacity .2s,transform .2s;cursor:pointer;min-width:14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.3);}
.chart-bar:hover{opacity:.85;transform:scaleY(1.03);transform-origin:bottom;}
.chart-bar-label{font-size:10px;color:var(--gray-400);font-weight:600;}
.chart-bar-val{font-size:10px;color:var(--gray-600);font-weight:700;}
.donut-wrap{display:flex;align-items:center;gap:18px;padding:18px;}
.donut-legend{display:flex;flex-direction:column;gap:9px;}
.legend-item{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--gray-600);font-weight:500;}
.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 0 3px rgba(0,0,0,.03);}

/* ═══ FORMS ═══ */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:22px;}
.form-field{display:flex;flex-direction:column;gap:6px;}
.form-field.full{grid-column:span 2;}
.form-field label{font-size:11.5px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;}
.form-field input,.form-field select,.form-field textarea{padding:10px 13px;border:1.5px solid var(--gray-200);border-radius:10px;font-size:13.5px;font-family:'DM Sans',sans-serif;color:var(--gray-800);background:var(--gray-50);transition:border-color .15s,box-shadow .15s,background .15s;outline:none;}
.form-field input:hover,.form-field select:hover,.form-field textarea:hover{background:white;border-color:var(--gray-300);}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--blue);background:white;box-shadow:var(--ring);}
.form-field textarea{resize:vertical;min-height:72px;}
.form-field input.err,.form-field select.err{border-color:var(--red-2);}
.form-actions{padding:16px 22px;border-top:1px solid var(--gray-100);display:flex;align-items:center;justify-content:flex-end;gap:10px;background:var(--gray-50);}
.required-star{color:var(--red-2);}
/* Registration form: section headers + per-field explanations */
.form-sec{grid-column:span 2;display:flex;align-items:center;gap:8px;margin:8px 0 2px;font-size:12px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--navy);}
.form-sec::after{content:"";flex:1;height:1px;background:var(--gray-200);}
.field-hint{font-size:11px;font-weight:400;color:var(--gray-400);line-height:1.35;margin-top:-1px;text-transform:none;letter-spacing:0;}

/* ═══ PET CARDS ═══ */
.pet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.pet-card{background:white;border:var(--hairline);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:var(--shadow);}
.pet-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:rgba(0,48,135,.25);}
.pet-card-img{height:108px;display:flex;align-items:center;justify-content:center;font-size:48px;position:relative;overflow:hidden;text-shadow:0 8px 18px rgba(15,39,69,.22);}
.pet-card-img::after{content:'';position:absolute;inset:0;background:radial-gradient(130px 90px at 50% 12%,rgba(255,255,255,.6),transparent 72%);pointer-events:none;}
.pet-card-body{padding:14px 15px;}
.pet-card-name{font-size:14.5px;font-weight:700;color:var(--navy);margin-bottom:2px;letter-spacing:-.2px;}
.pet-card-sub{font-size:12px;color:var(--gray-400);margin-bottom:9px;}
.pet-card-row{display:flex;align-items:center;justify-content:space-between;}
.pet-action-btn{flex:1;padding:7px 8px;border-radius:8px;font-size:11.5px;font-weight:600;font-family:'DM Sans',sans-serif;cursor:pointer;border:1px solid var(--gray-200);transition:all .15s;text-align:center;}
.pet-action-btn.edit{background:var(--blue-light);color:var(--blue);border-color:rgba(0,48,135,.18);}
.pet-action-btn.edit:hover{background:var(--blue);color:white;}
.pet-action-btn.view{background:var(--green-light);color:var(--green);border-color:rgba(14,138,95,.18);}
.pet-action-btn.view:hover{background:var(--green);color:white;}
.pet-action-btn.delete{background:var(--red-light);color:var(--red-2);border-color:rgba(185,28,28,.18);}
.pet-action-btn.delete:hover{background:var(--red-2);color:white;}

/* ═══ NOTIFICATIONS ═══ */
.notif-item{display:flex;gap:13px;padding:15px 18px;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background .15s;align-items:center;}
.notif-item:hover{background:#F7FAFF;}
.notif-item:last-child{border-bottom:none;}
.notif-icon-wrap{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;box-shadow:inset 0 0 0 1px rgba(15,39,69,.05);}
.notif-body{flex:1;min-width:0;}
.notif-title{font-size:13.5px;font-weight:600;color:var(--navy);}
.notif-desc{font-size:12px;color:var(--gray-500);margin-top:2px;}
.notif-time{font-size:11px;color:var(--gray-400);flex-shrink:0;font-weight:500;}

/* ═══ MAP ═══ */
#loon-map{width:100%;height:360px;border-radius:var(--radius);border:var(--hairline);z-index:1;}
.leaflet-popup-content-wrapper{border-radius:12px;box-shadow:var(--shadow-lg);font-family:"DM Sans",sans-serif;}
.leaflet-popup-content{font-size:13px;color:var(--gray-800);padding:4px 2px;}
.map-popup-title{font-weight:700;color:#003087;font-size:14px;margin-bottom:4px;}
.map-popup-row{font-size:12px;color:var(--gray-600);margin:2px 0;}

/* ═══ QUICK ACTIONS ═══ */
.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px;}
.quick-action{background:white;border-radius:var(--radius);padding:18px 12px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;border:var(--hairline);transition:all .18s;text-align:center;box-shadow:var(--shadow);}
.quick-action:hover{border-color:rgba(0,48,135,.3);transform:translateY(-3px);box-shadow:var(--shadow-lg);}
.quick-action:hover .qa-icon{background:var(--grad-blue);color:white;box-shadow:0 8px 18px -5px rgba(0,48,135,.6);transform:scale(1.05);}
.qa-icon{width:46px;height:46px;border-radius:13px;background:var(--gray-100);display:flex;align-items:center;justify-content:center;font-size:21px;transition:all .18s;}
.qa-label{font-size:12.5px;font-weight:600;color:var(--gray-700);}

/* ═══ ALERTS ═══ */
.alert{padding:13px 16px;border-radius:11px;font-size:13px;margin-bottom:14px;display:flex;align-items:flex-start;gap:10px;line-height:1.5;}
.alert-info{background:var(--blue-light);color:#1A3FA8;border:1px solid rgba(0,48,135,.16);}
.alert-warn{background:var(--amber-light);color:var(--amber);border:1px solid rgba(183,121,31,.18);}
.alert-danger{background:var(--red-light);color:var(--red-2);border:1px solid rgba(185,28,28,.16);}
.alert-success{background:var(--green-light);color:var(--green);border:1px solid rgba(14,138,95,.16);}

/* ═══ TABS ═══ */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--gray-200);margin-bottom:18px;}
.tab{padding:10px 16px;font-size:13px;font-weight:600;color:var(--gray-500);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;font-family:'DM Sans',sans-serif;background:none;border-top:none;border-left:none;border-right:none;}
.tab:hover{color:var(--navy);}
.tab.active{color:var(--blue);border-bottom-color:var(--blue);}

/* ═══ PROGRESS & CHIPS ═══ */
.progress-bar{height:7px;background:var(--gray-100);border-radius:20px;overflow:hidden;margin-top:4px;}
.progress-fill{height:100%;border-radius:20px;transition:width .6s cubic-bezier(.4,0,.2,1);box-shadow:inset 0 1px 0 rgba(255,255,255,.3);}
.chip-row{display:flex;gap:7px;flex-wrap:wrap;}
.chip{padding:5px 13px;border-radius:20px;border:1px solid var(--gray-200);font-size:12px;font-weight:500;font-family:'DM Sans',sans-serif;cursor:pointer;background:white;color:var(--gray-600);transition:all .15s;}
.chip:hover{border-color:var(--blue);color:var(--blue);}
.chip.active{background:var(--grad-blue);color:white;border-color:transparent;box-shadow:0 4px 12px -3px rgba(0,48,135,.55);}

/* ═══ SCROLLBAR ═══ */
::-webkit-scrollbar{width:7px;height:7px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:10px;border:2px solid transparent;background-clip:padding-box;}
::-webkit-scrollbar-thumb:hover{background:var(--gray-400);background-clip:padding-box;}

/* ═══ MODALS ═══ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(10,26,48,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:300;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.open{display:flex;}
.modal{background:white;border-radius:var(--radius-lg);width:100%;max-width:620px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalIn .24s cubic-bezier(.2,.8,.2,1);border:1px solid rgba(255,255,255,.6);}
@keyframes modalIn{from{transform:translateY(16px) scale(.97);opacity:0;}to{transform:none;opacity:1;}}
.modal-lg{max-width:780px;}
.modal-sm{max-width:460px;}
.modal-header{padding:20px 22px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);z-index:1;}
.modal-title{font-size:16px;font-weight:700;color:var(--navy);letter-spacing:-.2px;}
.modal-close{font-size:22px;color:var(--gray-400);background:none;border:none;cursor:pointer;line-height:1;padding:3px 8px;border-radius:8px;transition:all .15s;}
.modal-close:hover{background:var(--gray-100);color:var(--gray-800);}

/* ═══ AUTH SHELL ═══ */
.auth-shell{display:flex;height:100vh;overflow:hidden;}
.auth-left{width:420px;background:var(--grad-sidebar);flex-shrink:0;display:flex;flex-direction:column;justify-content:center;padding:22px 30px;gap:14px;position:relative;overflow:hidden;}
.auth-left::before{content:'';position:absolute;top:-120px;right:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(0,174,239,.38),transparent 65%);}
.auth-left::after{content:'';position:absolute;bottom:-140px;left:-100px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(230,122,61,.26),transparent 65%);}
.auth-left>*{position:relative;z-index:1;}
.brand{display:flex;align-items:center;gap:13px;}
.brand-name{font-size:19px;font-weight:700;color:white;letter-spacing:.5px;}
.brand-sub{font-size:11px;color:rgba(255,255,255,.5);}
.panel-headline{font-family:'DM Serif Display',serif;font-size:30px;color:white;line-height:1.14;letter-spacing:-.5px;}
.panel-headline em{color:var(--blue-300);font-style:italic;}
.panel-sub{font-size:12px;color:rgba(255,255,255,.62);line-height:1.5;}
.panel-features{display:flex;flex-direction:column;gap:10px;}
.feat{display:flex;align-items:flex-start;gap:12px;}
.feat-icon{font-size:19px;flex-shrink:0;width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08);}
.feat-text strong{display:block;font-size:13.5px;font-weight:600;color:white;margin-bottom:2px;}
.feat-text span{font-size:12px;color:rgba(255,255,255,.52);line-height:1.5;}
.lgu-badge{display:flex;align-items:center;gap:13px;background:rgba(255,255,255,.06);border-radius:13px;padding:11px 12px;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(6px);}
.lgu-seal{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:18px;}
.lgu-label{color:rgba(255,255,255,.5);font-size:11px;line-height:1.5;}
.lgu-label strong{color:rgba(255,255,255,.8);display:block;font-size:12px;}
.auth-right{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 24px;background:var(--grad-page);overflow-y:auto;height:100vh;}
.auth-card{width:100%;max-width:480px;background:white;border-radius:var(--radius-lg);padding:34px;box-shadow:var(--shadow);border:var(--hairline);margin-top:8px;}

/* ═══════════ LOGIN REDESIGN — glass card over the Municipal Hall hero ═══════════ */
.auth-shell{position:relative;display:flex;align-items:center;justify-content:center;height:100vh;min-height:100vh;overflow:hidden;
  background:linear-gradient(125deg,rgba(0,16,48,.84) 0%,rgba(0,34,90,.62) 48%,rgba(0,48,135,.42) 100%),url('../img/landing/municipal-hall.jpg') center 32%/cover no-repeat;}
/* Left info text floats OVER the hero as an overlay so the card can sit in the page centre */
.auth-shell .auth-left{display:flex;background:transparent;position:absolute;left:44px;top:50%;transform:translateY(-50%);width:330px;z-index:2;gap:11px;}
.auth-shell .auth-left::before,.auth-shell .auth-left::after{display:none;}
/* compact the left info text so it sits tighter over the hero */
.auth-shell .auth-left .brand-name{font-size:17px;}
.auth-shell .auth-left .panel-headline{font-size:26px;line-height:1.1;}
.auth-shell .auth-left .panel-sub{font-size:11.5px;line-height:1.42;}
.auth-shell .auth-left .panel-features{gap:8px;}
.auth-shell .auth-left .feat-icon{width:34px;height:34px;}
.auth-shell .auth-left .feat-text strong{font-size:12.5px;margin-bottom:1px;}
.auth-shell .auth-left .feat-text span{font-size:11px;line-height:1.35;}
.auth-shell .auth-left .lgu-badge{padding:8px 11px;}
.auth-shell .auth-left .auth-logos img{height:36px;}
.auth-shell .auth-right{flex:initial;width:auto;display:flex;align-items:center;justify-content:center;background:transparent;height:auto;overflow:visible;padding:24px;}
/* Frosted glass sign-in card — same translucent glass family as the EN / dark-mode toggle pills.
   Higher specificity (.auth-right .auth-card) so it stays identical in light AND dark mode. */
.auth-shell .auth-right .auth-card{width:100%;max-width:430px;margin:0;border-radius:22px;padding:30px 32px;
  background:rgba(10,22,54,.42);backdrop-filter:blur(26px) saturate(1.3);-webkit-backdrop-filter:blur(26px) saturate(1.3);
  border:1px solid rgba(255,255,255,.34);box-shadow:0 30px 80px rgba(0,8,32,.55);max-height:94vh;overflow-y:auto;}
/* light text so everything stays readable on the translucent glass */
.auth-shell .auth-card>a{color:rgba(255,255,255,.85)!important;}
.auth-shell .auth-card .auth-heading{color:#fff;}
.auth-shell .auth-card .auth-hint{color:rgba(255,255,255,.82);}
.auth-shell .auth-card .auth-hint strong{color:#fff;}
.auth-shell .auth-card label{color:rgba(255,255,255,.92);}
.auth-shell .auth-card .switch-hint{color:rgba(255,255,255,.82);}
.auth-shell .auth-card .step{color:rgba(255,255,255,.72);}
.auth-shell .auth-card .strength-label{color:rgba(255,255,255,.8);}
.auth-shell .auth-card [style*="gray-400"]{color:rgba(255,255,255,.72)!important;}
.auth-shell .auth-card .auth-card-brand .acb-text strong{color:#fff;}
.auth-shell .auth-card .auth-card-brand .acb-text span{color:rgba(255,255,255,.75);}
/* tab switcher on glass */
.auth-shell .auth-card .auth-tabs{background:rgba(255,255,255,.12);}
.auth-shell .auth-card .auth-tab{color:rgba(255,255,255,.82);}
.auth-shell .auth-card .auth-tab.active{background:rgba(255,255,255,.95);color:var(--navy);}
/* inputs stay near-solid so the dark field text reads crisply on the glass */
.auth-shell .auth-card .field input,.auth-shell .auth-card .field select{background:rgba(255,255,255,.9);border-color:rgba(255,255,255,.6);color:var(--gray-800);}
.auth-shell .auth-card .field input:focus,.auth-shell .auth-card .field select:focus{background:#fff;}
/* keep the multi-step Create Account form compact so it fits the card without scrolling */
.auth-shell .auth-card .auth-tabs{margin-bottom:16px;}
.auth-shell #panel-register .auth-heading{margin-bottom:2px;}
.auth-shell #panel-register .auth-hint{margin-bottom:12px;}
.auth-shell #panel-register .field{margin-bottom:9px;gap:4px;}
.auth-shell #panel-register .field input,.auth-shell #panel-register .field select{padding:9px 12px 9px 40px;}
.auth-shell #panel-register .form-row{gap:10px;}
.auth-shell #panel-register .steps{margin-bottom:14px;}
.auth-shell #panel-register .strength-bars{margin-bottom:2px;}
.auth-shell #panel-register .check-row{margin-bottom:10px;}
.auth-shell #panel-register .btn-primary{margin-bottom:8px;padding:11px;}
/* glass top-right toggles (language / dark mode) on the login hero */
.auth-shell .float-btn{background:rgba(255,255,255,.16);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.42);color:#fff;box-shadow:0 8px 24px rgba(0,8,32,.32);}
.auth-shell .float-btn:hover{background:rgba(255,255,255,.28);}
.auth-card-brand{display:none;align-items:center;gap:11px;justify-content:center;margin:4px 0 16px;}   /* desktop: brand shown on the left panel; revealed on mobile when the panel hides */
.auth-card-brand img{width:54px;height:54px;border-radius:50%;object-fit:cover;background:#fff;box-shadow:0 3px 10px rgba(0,0,0,.14);}
.auth-card-brand .acb-text{text-align:left;}
.auth-card-brand .acb-text strong{display:block;font-size:18px;color:var(--navy,#00184F);letter-spacing:.4px;font-weight:800;line-height:1.1;}
.auth-card-brand .acb-text span{display:block;font-size:11px;color:var(--gray-500);letter-spacing:.3px;margin-top:1px;}
/* Dark mode must NOT swap the left panel to its own background image — it's a transparent
   overlay now, so the single Municipal Hall hero stays the same in light AND dark mode. */
[data-theme=dark] .auth-shell .auth-left{background:transparent;}
[data-theme=dark] .auth-shell .auth-left::before,[data-theme=dark] .auth-shell .auth-left::after{display:none;}
@media(max-width:1200px){ .auth-shell .auth-left{display:none;} .auth-shell .auth-card-brand{display:flex;} }
/* Phone view: card goes full-width with comfortable padding; toggles tuck into the corner */
@media(max-width:560px){
  .auth-shell{height:auto;min-height:100vh;align-items:flex-start;}
  .auth-shell .auth-right{width:100%;padding:64px 14px 28px;}
  .auth-shell .auth-right .auth-card{max-width:none;margin:0;padding:24px 20px;border-radius:18px;}
  .auth-shell .float-toggles{top:12px;right:12px;}
}
.auth-tabs{display:flex;background:var(--gray-100);border-radius:12px;padding:4px;margin-bottom:28px;}
.auth-tab{flex:1;padding:10px;border-radius:9px;font-size:13.5px;font-weight:600;font-family:'DM Sans',sans-serif;border:none;background:none;cursor:pointer;color:var(--gray-500);transition:all .18s;}
.auth-tab.active{background:white;color:var(--navy);box-shadow:var(--shadow-sm);}
.auth-heading{font-size:24px;font-weight:700;color:var(--navy);margin-bottom:4px;letter-spacing:-.4px;}
.auth-hint{font-size:13px;color:var(--gray-400);margin-bottom:24px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:15px;}
.field label{font-size:11.5px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;}
.input-wrap{position:relative;}
.input-wrap .icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--gray-400);pointer-events:none;}
.input-wrap .eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:14px;color:var(--gray-400);cursor:pointer;user-select:none;background:none;border:none;padding:2px;}
.field input,.field select{width:100%;padding:11px 12px 11px 40px;border:1.5px solid var(--gray-200);border-radius:10px;font-size:13.5px;font-family:'DM Sans',sans-serif;color:var(--gray-800);background:var(--gray-50);outline:none;transition:border-color .15s,box-shadow .15s,background .15s;}
.field input.no-icon,.field select.no-icon{padding-left:13px;}
.field input:focus,.field select:focus{border-color:var(--blue);background:white;box-shadow:var(--ring);}
.field input.err{border-color:var(--red-2);box-shadow:0 0 0 3px rgba(185,28,28,.1);}
.field input.ok{border-color:var(--green);}
.err-msg{font-size:11.5px;color:var(--red-2);display:none;align-items:center;gap:4px;margin-top:3px;}
.err-msg.show{display:flex;}
.ok-msg{font-size:11.5px;color:var(--green);display:none;align-items:center;gap:4px;margin-top:3px;}
.ok-msg.show{display:flex;}
.strength-bars{display:flex;gap:4px;margin-bottom:4px;}
.strength-bar{height:4px;flex:1;border-radius:2px;background:var(--gray-200);transition:background .25s;}
.strength-label{font-size:11px;color:var(--gray-400);}
.check-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;}
.check-row input[type=checkbox]{width:16px;height:16px;margin-top:1px;flex-shrink:0;accent-color:var(--blue);cursor:pointer;}
.check-row label{font-size:12.5px;color:var(--gray-600);cursor:pointer;line-height:1.5;}
.check-row a{color:var(--blue);text-decoration:none;font-weight:600;}
.check-row a:hover{text-decoration:underline;}
.divider{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--gray-300);margin:14px 0;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--gray-200);}
.btn-primary{width:100%;padding:13px;background:var(--grad-blue);color:white;border:none;border-radius:11px;font-size:14px;font-weight:700;font-family:'DM Sans',sans-serif;cursor:pointer;transition:filter .15s,transform .1s,box-shadow .15s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:14px;box-shadow:0 8px 20px -6px rgba(0,48,135,.6);}
.btn-primary:hover{filter:brightness(1.06);box-shadow:0 12px 26px -7px rgba(0,48,135,.68);}
.btn-primary:active{transform:scale(.99);}
.btn-primary:disabled{background:var(--gray-300);cursor:not-allowed;box-shadow:none;}
.forgot-link{text-align:right;margin-top:-8px;margin-bottom:16px;}
.forgot-link a{font-size:12.5px;color:var(--blue);text-decoration:none;font-weight:600;}
.switch-hint{text-align:center;font-size:13px;color:var(--gray-400);margin-top:4px;}
.switch-hint a{color:var(--blue);cursor:pointer;font-weight:600;}
.alert-box{padding:12px 14px;border-radius:10px;font-size:13px;display:none;align-items:flex-start;gap:9px;margin-bottom:14px;line-height:1.5;}
.alert-box.show{display:flex;}
.alert-success2{background:var(--green-light);color:#066043;border:1px solid rgba(14,138,95,.16);}
.alert-error2{background:var(--red-light);color:#991B1B;border:1px solid rgba(185,28,28,.16);}
.alert-info2{background:var(--blue-light);color:#1A3FA8;border:1px solid rgba(0,48,135,.16);}
.steps{display:flex;align-items:center;gap:6px;margin-bottom:22px;}
.step{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-400);font-weight:600;}
.step.active{color:var(--blue);}
.step.done{color:var(--green);}
.step-dot{width:24px;height:24px;border-radius:50%;border:1.5px solid var(--gray-300);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--gray-400);transition:all .2s;}
.step.active .step-dot{border-color:var(--blue);background:var(--grad-blue);color:white;box-shadow:0 4px 10px -2px rgba(0,48,135,.55);}
.step.done .step-dot{border-color:var(--green);background:var(--green);color:white;}
.step-line{flex:1;height:2px;background:var(--gray-200);border-radius:2px;}
.step-line.done{background:var(--green);}
.otp-row{display:flex;gap:10px;justify-content:center;margin:14px 0;}
.otp-input{width:50px;height:56px;border:1.5px solid var(--gray-200);border-radius:12px;text-align:center;font-size:22px;font-weight:700;font-family:'DM Sans',sans-serif;color:var(--navy);outline:none;background:var(--gray-50);transition:border-color .15s,box-shadow .15s,background .15s;}
.otp-input:focus{border-color:var(--blue);background:white;box-shadow:var(--ring);}
.otp-input.err{border-color:var(--red-2);}
.auth-modal-bg{display:none;position:fixed;inset:0;background:rgba(10,26,48,.4);backdrop-filter:blur(4px);z-index:400;align-items:center;justify-content:center;}
.auth-modal-bg.open{display:flex;}
.auth-modal{background:white;border-radius:var(--radius-lg);width:380px;max-width:95vw;padding:30px;box-shadow:var(--shadow-lg);animation:modalIn .24s ease;}
.modal-close-btn{float:right;font-size:20px;color:var(--gray-400);background:none;border:none;cursor:pointer;line-height:1;margin-top:-4px;}
.privacy-modal{max-width:600px;max-height:85vh;overflow-y:auto;}
.privacy-section h4{font-size:13px;font-weight:700;color:var(--navy);margin:16px 0 6px;}
.privacy-section p,.privacy-section li{font-size:12.5px;color:var(--gray-600);line-height:1.6;}
.privacy-section ul{padding-left:18px;}
.privacy-section li{margin-bottom:4px;}
.dpa-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 11px;background:var(--blue-light);color:var(--blue);border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.3px;border:1px solid rgba(0,48,135,.16);}

/* ═══ ADOPTION THUMB ═══ */
.adopt-thumb{width:66px;height:66px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:36px;flex-shrink:0;border:1px solid var(--gray-200);text-shadow:0 6px 14px rgba(15,39,69,.2);box-shadow:var(--shadow-sm);}

/* ═══ ADOPTION REACTIONS / SHARE ═══ */
/* Adoption action buttons (Like / Comment / Share / Inquire) */
.ig-action{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--gray-600);padding:8px 12px;border-radius:9px;transition:background .15s,color .15s,transform .1s;}
.ig-action:hover{background:var(--gray-100);color:var(--navy);}
.ig-action:active{transform:scale(.96);}
.ig-action svg.lucide{width:18px;height:18px;}
.ig-action.liked{color:#ED4956;}
.ig-action.liked svg.lucide{fill:#ED4956;}
/* Instagram-style single heart */
.like-btn{background:none;border:none;cursor:pointer;padding:4px;display:inline-flex;align-items:center;color:var(--gray-700);transition:transform .15s,color .15s;}
.like-btn svg.lucide{width:24px;height:24px;}
.like-btn:hover{color:#ED4956;transform:scale(1.12);}
.like-btn.liked{color:#ED4956;animation:heart-pop .3s ease;}
.like-btn.liked svg.lucide{fill:#ED4956;}
@keyframes heart-pop{0%{transform:scale(1);}40%{transform:scale(1.32);}100%{transform:scale(1);}}
.ig-act{background:none;border:none;cursor:pointer;padding:4px;display:inline-flex;align-items:center;color:var(--gray-700);transition:transform .15s,color .15s;}
.ig-act svg.lucide{width:23px;height:23px;}
.ig-act:hover{color:var(--navy);transform:scale(1.1);}
.react-action{font-weight:600;color:var(--gray-600);padding:6px 10px;border-radius:8px;}
.react-action:hover{background:var(--gray-100);text-decoration:none;}
.share-link{display:flex;align-items:center;justify-content:center;gap:6px;color:#fff;text-decoration:none;font-size:13px;font-weight:600;padding:11px;border-radius:10px;transition:filter .15s;}
.share-link:hover{filter:brightness(1.08);}

/* ═══ TOAST ═══ */
#toast{position:fixed;bottom:24px;right:24px;background:var(--navy-ink);color:white;padding:13px 20px;border-radius:12px;font-size:13px;font-weight:500;z-index:9999;box-shadow:var(--shadow-lg);transition:opacity .3s,transform .3s;font-family:'DM Sans',sans-serif;max-width:360px;display:none;border:1px solid rgba(255,255,255,.08);}
.live-dot{display:inline-block;width:8px;height:8px;background:#22C55E;border-radius:50%;margin-right:5px;animation:pulse-dot 1.5s infinite;box-shadow:0 0 0 0 rgba(34,197,94,.6);}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,.5);}50%{opacity:.7;transform:scale(1.25);box-shadow:0 0 0 5px rgba(34,197,94,0);}}
.realtime-banner{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--green);font-weight:600;}

/* ═══ QR CODE ═══ */
.qr-box{background:white;border:1px solid var(--gray-200);border-radius:12px;padding:16px;text-align:center;box-shadow:var(--shadow-sm);}
.qr-placeholder{width:120px;height:120px;background:#003087;margin:0 auto 8px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:white;font-size:11px;font-family:monospace;line-height:1.4;letter-spacing:1px;}
.qr-id{font-family:monospace;font-size:13px;font-weight:700;color:var(--navy);}

/* ═══ DETAIL GRID ═══ */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:22px;}
.detail-item{display:flex;flex-direction:column;gap:4px;background:var(--gray-50);border:1px solid var(--gray-100);border-radius:10px;padding:11px 13px;}
.detail-label{font-size:10.5px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;}
.detail-value{font-size:13.5px;color:var(--gray-800);font-weight:600;}

/* ═══ APPOINTMENT CONFIRM ═══ */
.appt-confirm-box{background:var(--green-light);border:1px solid rgba(14,138,95,.16);border-radius:12px;padding:16px;margin:0 22px 14px;display:none;}
.appt-confirm-box.show{display:block;}
.appt-confirm-box .conf-title{font-size:14px;font-weight:700;color:var(--green);margin-bottom:8px;}
.appt-confirm-detail{font-size:13px;color:var(--gray-700);line-height:1.7;}

/* ═══ IMAGE UPLOAD ═══ */
.img-upload-box{border:2px dashed var(--gray-300);border-radius:12px;padding:24px 16px;text-align:center;cursor:pointer;transition:all .2s;background:var(--gray-50);position:relative;overflow:hidden;}
.img-upload-box:hover,.img-upload-box.drag-over{border-color:var(--blue);background:var(--blue-light);}
.img-upload-box input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.img-preview-wrap{position:relative;display:block;margin-top:10px;}
.img-preview-wrap img{width:100%;max-height:200px;object-fit:cover;border-radius:10px;display:block;}
.img-preview-wrap .img-remove{position:absolute;top:6px;right:6px;background:rgba(185,28,28,.9);color:white;border:2px solid white;border-radius:50%;width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;font-weight:700;line-height:1;backdrop-filter:blur(4px);}
.img-preview-wrap .img-remove:hover{background:var(--red-2);}

/* ═══ TERRACOTTA ACCENTS ═══ */
.badge-terra{background:var(--terra-light);color:var(--terra-dark);border-color:rgba(230,122,61,.24);}
.header-btn.accent{background:var(--grad-accent);color:#fff;border-color:transparent;box-shadow:0 6px 16px -5px rgba(230,122,61,.6);}
.header-btn.accent:hover{filter:brightness(1.05);box-shadow:0 10px 22px -6px rgba(230,122,61,.66);}
.text-accent{color:var(--terra);}

/* ═══ THEME / LANGUAGE TOGGLES ═══ */
.icon-btn{width:38px;height:38px;padding:0;justify-content:center;font-size:16px;}
.lang-pill{font-weight:700;letter-spacing:.4px;}
.float-toggles{position:fixed;top:18px;right:20px;z-index:500;display:flex;gap:8px;}
.float-btn{min-width:42px;height:40px;padding:0 13px;border-radius:11px;border:1.5px solid var(--gray-200);background:#fff;color:var(--navy);font-family:'DM Sans',sans-serif;font-size:13.5px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s;box-shadow:0 8px 20px -6px rgba(0,48,135,.38);}
.float-btn svg.lucide{width:17px;height:17px;}
.float-btn:hover{border-color:var(--sky);color:var(--blue);transform:translateY(-1px);box-shadow:0 12px 26px -8px rgba(0,48,135,.5);}
[data-theme=dark] .float-btn{background:var(--surface);color:var(--gray-800);border-color:var(--gray-200);}
/* Language picker menu */
.lang-menu{position:fixed;z-index:600;background:#fff;border:1px solid var(--gray-200);border-radius:12px;box-shadow:var(--shadow-lg);padding:6px;min-width:190px;display:none;}
.lang-menu.open{display:block;animation:modalIn .15s ease;}
.lang-opt{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:9px 12px;border:none;background:none;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13.5px;color:var(--gray-700);cursor:pointer;text-align:left;}
.lang-opt:hover{background:var(--gray-100);}
.lang-opt.active{background:var(--blue-light);color:var(--blue);font-weight:700;}
[data-theme=dark] .lang-menu{background:var(--surface);}

/* ═══ DARK MODE ═══ */
[data-theme=dark]{
  --navy:#E9EEF8;                 /* "navy" is used as heading text → make it light */
  --blue:#5BB8F5;--blue-hover:#8CCDF8;--blue-light:#12243E;--blue-300:#66C6F2;
  --sky-light:#0C2230;--terra-light:#2C1C12;
  --green-light:#102A20;--amber-light:#2A2310;--red-light:#2E1714;
  --gray-50:#1A222F;--gray-100:#212B3A;--gray-200:#313D4F;--gray-300:#475266;
  --gray-400:#8392A6;--gray-500:#9AA7BA;--gray-600:#B6C1D1;--gray-700:#D2DAE6;--gray-800:#EAEFF7;
  --surface:#161D2A;--white:#161D2A;
  --hairline:1px solid rgba(255,255,255,.08);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 1px 3px rgba(0,0,0,.35),0 12px 30px -12px rgba(0,0,0,.6);
  --shadow-lg:0 22px 55px -14px rgba(0,0,0,.7);
  --ring:0 0 0 3.5px rgba(0,174,239,.3);
  --grad-page:radial-gradient(1100px 520px at 100% -12%,rgba(0,174,239,.10) 0%,transparent 60%),radial-gradient(900px 480px at -8% 8%,rgba(230,122,61,.07) 0%,transparent 55%),linear-gradient(180deg,#0E141F 0%,#0A0F18 100%);
  --hills:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1440' height='220' viewBox='0 0 1440 220'%3E%3Cpath fill='%2300AEEF' fill-opacity='0.05' d='M0,160 C120,90 240,90 360,140 C480,190 600,200 720,150 C840,100 960,90 1080,135 C1200,180 1320,180 1440,140 L1440,220 L0,220 Z'/%3E%3C/svg%3E");
}
/* Surfaces that used literal white need explicit dark backgrounds */
[data-theme=dark] .card,
[data-theme=dark] .stat-card,
[data-theme=dark] .pet-card,
[data-theme=dark] .quick-action,
[data-theme=dark] .chip,
[data-theme=dark] .header-btn,
[data-theme=dark] .auth-card,
[data-theme=dark] .modal{background:var(--surface);}
[data-theme=dark] .header{background:rgba(16,21,30,.82);}
[data-theme=dark] .modal-header{background:rgba(22,29,42,.92);}
[data-theme=dark] .auth-right{background:transparent;}
[data-theme=dark] .auth-tabs,
[data-theme=dark] .search-bar{background:var(--gray-100);}
[data-theme=dark] .auth-tab.active{background:var(--surface);color:var(--gray-800);}
[data-theme=dark] .search-bar:focus-within,
[data-theme=dark] .form-field input:focus,
[data-theme=dark] .form-field select:focus,
[data-theme=dark] .form-field textarea:focus,
[data-theme=dark] .field input:focus,
[data-theme=dark] .field select:focus{background:var(--surface);}
[data-theme=dark] .header-btn.primary{color:#fff;}
[data-theme=dark] .modal{border-color:rgba(255,255,255,.06);}

/* ═══ RESPONSIVE ═══ */
/* Mobile menu button (hamburger) + slide-in sidebar overlay — hidden on desktop */
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--navy,#00184F);padding:6px;border-radius:8px;margin-right:2px;align-items:center;justify-content:center;}
.menu-btn i{width:22px;height:22px;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,10,40,.45);z-index:99;}
/* The LOONPAWS emblem renders as a clean circle wherever it's a brand icon */
img[src*="loonpaws-emblem"]{border-radius:50%;object-fit:cover;background:#fff;}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);transition:transform .22s ease;}
  .sidebar.open{transform:none;}
  .sidebar-overlay.show{display:block;}
  .menu-btn{display:inline-flex;}
  .main{margin-left:0;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .quick-actions{grid-template-columns:1fr 1fr;}
  .grid-2,.grid-3,.pet-grid{grid-template-columns:1fr;}
  .auth-left{display:none;}
  .float-toggles{top:12px;right:12px;}
  .header .search-bar{display:none;}   /* free up space on small screens */
}
/* Phone hardening (≤600px): stack modal forms, tighten chrome so nothing overflows */
@media(max-width:600px){
  .form-grid{grid-template-columns:1fr;padding:18px 16px;gap:13px;}
  .form-field.full{grid-column:span 1;}
  .form-row{grid-template-columns:1fr;}
  .stats-grid,.quick-actions{grid-template-columns:1fr 1fr;gap:11px;}
  .header{padding:0 13px;gap:8px;}
  .header-title{font-size:14.5px;}
  .modal-overlay{padding:12px;}
  .form-actions{flex-wrap:wrap;}
  .otp-row{gap:7px;}
  .page-head,.section-head{flex-wrap:wrap;gap:10px;}
}

/* ═══════════ PREMIUM GOVERNMENT THEME PASS ═══════════
   Extends the landing page's design language (deep navy, PH gold, tricolor,
   serif display headings, the Loon Municipal Hall photo) to the auth screen
   and the app shell. Pure visual overrides — no behavior changes. */

/* — Auth: left panel becomes the Municipal Hall hero — */
.auth-left{
  width:460px;
  background:linear-gradient(160deg,rgba(0,14,48,.95) 0%,rgba(0,28,86,.90) 52%,rgba(0,48,135,.72) 100%),url('../img/landing/loon-plaza.jpg') center 60%/cover no-repeat;
}
.auth-left::before{background:radial-gradient(circle,rgba(245,197,24,.16),transparent 65%);}
.auth-left::after{background:radial-gradient(circle,rgba(0,174,239,.20),transparent 65%);}
.panel-headline{font-family:Georgia,'Times New Roman',serif;font-size:32px;}
.panel-headline em{color:#F5C518;}
.feat-icon{background:rgba(245,197,24,.10);border-color:rgba(245,197,24,.22);}
.feat-icon svg.lucide{color:#F5C518;}
.lgu-badge{border-color:rgba(245,197,24,.22);}
.auth-logos{display:flex;gap:10px;align-items:center;}
.auth-logos img{height:44px;width:auto;filter:drop-shadow(0 0 6px rgba(255,255,255,.45)) drop-shadow(0 3px 9px rgba(0,0,0,.5));}

/* — Auth: card + gold primary CTA — */
.auth-heading{font-family:Georgia,'Times New Roman',serif;letter-spacing:0;}
.btn-primary{background:linear-gradient(135deg,#F5C518,#E9A410);color:#3A2A00;box-shadow:0 8px 20px -6px rgba(233,164,16,.55);}
.btn-primary:hover{filter:brightness(1.04);box-shadow:0 12px 26px -7px rgba(233,164,16,.6);}
.btn-primary:disabled{background:var(--gray-300);color:#fff;}

/* — App shell: deeper navy sidebar with gold active state — */
:root{--grad-sidebar:linear-gradient(180deg,#002B79 0%,#001A52 55%,#001238 100%);}
.sidebar-brand{border-bottom:1px solid rgba(245,197,24,.18);}
.nav-item.active{background:linear-gradient(135deg,rgba(245,197,24,.18),rgba(245,197,24,.07));box-shadow:inset 0 0 0 1px rgba(245,197,24,.30);}
.nav-item.active::before{background:#F5C518;box-shadow:0 0 12px rgba(245,197,24,.8);}

/* — App header: serif title (the PH-tricolor hairline was removed) — */
.header{border-bottom:var(--hairline);}
.header-title{font-family:Georgia,'Times New Roman',serif;font-size:17.5px;letter-spacing:0;}

/* — Stat cards: top accent stripe removed — */
.stat-card::before{display:none;}

/* — Loading screen: premium 10-second splash around the Loon seal — */
#app-loader{position:fixed;inset:0;z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;transition:opacity .6s ease;background:linear-gradient(150deg,#000C28 0%,#001A52 38%,#00257A 64%,#013A9E 100%);background-size:170% 170%;animation:loaderBg 9s ease-in-out infinite;overflow:hidden;}
#app-loader.hidden{opacity:0;pointer-events:none;}
@keyframes loaderBg{0%,100%{background-position:0% 0%;}50%{background-position:100% 100%;}}
/* pulsing gold halo behind the seal */
#app-loader::before{content:'';position:absolute;width:620px;height:620px;border-radius:50%;background:radial-gradient(circle,rgba(245,197,24,.16) 0%,rgba(245,197,24,.05) 45%,transparent 68%);animation:haloPulse 3.2s ease-in-out infinite;pointer-events:none;}
@keyframes haloPulse{0%,100%{transform:scale(1);opacity:.65;}50%{transform:scale(1.18);opacity:1;}}
/* faint rotating conic sheen across the whole screen */
#app-loader::after{content:'';position:absolute;inset:-40%;background:conic-gradient(from 0deg,transparent 0 78%,rgba(255,255,255,.045) 86%,transparent 94%);animation:loaderSweep 7s linear infinite;pointer-events:none;}
@keyframes loaderSweep{to{transform:rotate(360deg);}}
/* the seal: entrance pop, then a gentle float, ringed by two counter-rotating arcs */
.loader-ring{position:relative;width:152px;height:152px;display:flex;align-items:center;justify-content:center;animation:loaderEnter .9s cubic-bezier(.18,.9,.32,1.25) both;}
@keyframes loaderEnter{from{transform:scale(.5);opacity:0;}to{transform:scale(1);opacity:1;}}
.loader-ring img{width:96px;height:96px;object-fit:contain;border-radius:50%;background:#fff;padding:7px;box-shadow:0 0 0 5px rgba(255,255,255,.08),0 14px 40px rgba(0,0,0,.55),0 0 38px rgba(245,197,24,.28);animation:loaderFloat 3.4s ease-in-out infinite;}
@keyframes loaderFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-7px);}}
.loader-ring::before{content:'';position:absolute;inset:0;border-radius:50%;border:3px solid rgba(255,255,255,.10);border-top-color:#F5C518;border-right-color:rgba(245,197,24,.40);animation:loaderSpin 1.4s cubic-bezier(.55,.15,.45,.85) infinite;}
.loader-ring::after{content:'';position:absolute;inset:11px;border-radius:50%;border:2px solid transparent;border-bottom-color:rgba(255,255,255,.55);border-left-color:rgba(255,255,255,.18);animation:loaderSpinRev 2.1s linear infinite;}
@keyframes loaderSpin{to{transform:rotate(360deg);}}
@keyframes loaderSpinRev{to{transform:rotate(-360deg);}}
/* wordmark: tracking-in entrance + shimmering gold on "PAWS" */
.loader-brand{font-family:Georgia,'Times New Roman',serif;font-size:27px;font-weight:700;color:#fff;letter-spacing:3px;animation:brandIn 1.1s .25s cubic-bezier(.2,.8,.2,1) both;text-shadow:0 2px 14px rgba(0,0,0,.4);}
@keyframes brandIn{from{opacity:0;letter-spacing:12px;transform:translateY(10px);}to{opacity:1;letter-spacing:3px;transform:none;}}
.loader-brand em{font-style:normal;background:linear-gradient(90deg,#F5C518 25%,#FFF3C2 42%,#F5C518 58%);background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:goldShine 2.6s linear infinite;}
@keyframes goldShine{to{background-position:220% center;}}
/* PH tricolor reveal under the wordmark */
.loader-tricolor{height:3px;border-radius:3px;background:linear-gradient(90deg,#0038A8 0 34%,#CE1126 34% 67%,#FCD116 67% 100%);animation:triGrow 1.2s .55s cubic-bezier(.2,.85,.25,1) both;}
@keyframes triGrow{from{width:0;opacity:0;}to{width:150px;opacity:1;}}
/* staged status message */
.loader-msg{font-size:13px;color:rgba(255,255,255,.72);letter-spacing:.5px;min-height:18px;animation:msgFade .55s ease both;}
@keyframes msgFade{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:none;}}
/* the wonders of Loon — full-screen Ken Burns slideshow behind a navy veil */
.loader-photos{position:absolute;inset:0;z-index:0;overflow:hidden;}
.loader-photo{position:absolute;inset:0;background-position:center;background-size:cover;background-repeat:no-repeat;opacity:0;transition:opacity 2s cubic-bezier(.4,0,.2,1);}
.loader-photo.on{opacity:1;animation:kenburns 9s ease-out forwards;}
@keyframes kenburns{from{transform:scale(1.04);}to{transform:scale(1.12) translate(-1%,-.8%);}}
.loader-shade{position:absolute;inset:0;z-index:1;background:linear-gradient(150deg,rgba(0,10,38,.86) 0%,rgba(0,24,79,.76) 45%,rgba(0,37,122,.66) 100%),radial-gradient(ellipse at center,transparent 30%,rgba(0,8,30,.6) 100%);}
/* keep the seal/wordmark/dots above the photos and veil */
.loader-ring,.loader-brand,.loader-tricolor,.loader-msg,.loader-dots{position:relative;z-index:3;}
#app-loader::before,#app-loader::after{z-index:2;}
/* three pulsing gold dots — the quiet, premium "working" indicator */
.loader-dots{display:flex;gap:10px;animation:msgFade .6s .4s ease both;}
.loader-dots span{width:9px;height:9px;border-radius:50%;background:#F5C518;box-shadow:0 0 12px rgba(245,197,24,.85);animation:dotPulse 1.3s ease-in-out infinite;}
.loader-dots span:nth-child(2){animation-delay:.18s;}
.loader-dots span:nth-child(3){animation-delay:.36s;}
@keyframes dotPulse{0%,100%{opacity:.25;transform:scale(.7);}40%{opacity:1;transform:scale(1.05);}}

/* — Dark mode adjustments for the theme pass — */
[data-theme=dark] .auth-left{background:linear-gradient(160deg,rgba(0,8,28,.96) 0%,rgba(0,20,62,.92) 52%,rgba(0,34,96,.80) 100%),url('../img/landing/loon-plaza.jpg') center 60%/cover no-repeat;}
[data-theme=dark] .btn-primary{color:#2A1F00;}
[data-theme=dark] #landing-page{background:#fff;color:#16223A;}
