/* ============================================================
   app.css — TRRI v3 — Mobile-first, PWA-ready
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@400;600;700&family=Inter:wght@400;500;600&display=swap');

:root {
  --road:#2C1A0E; --soil:#5C3317; --terracotta:#C4622D; --gold:#D4950A;
  --gold-light:#F5C842; --savanna:#F5EDD6; --green-deep:#1A3A1F;
  --green:#2E6B35; --green-light:#4A9A52; --cream:#FBF6EC;
  --white:#FFFFFF; --text:#1C1009; --text-muted:#6B4C30;
  --border:rgba(92,51,23,0.15); --radius:8px; --radius-lg:12px;
  --topbar-h:64px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;background:var(--cream);color:var(--text);min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;}
a{color:var(--terracotta);text-decoration:none;}
a:hover{text-decoration:underline;}
img{max-width:100%;height:auto;}

/* ── PWA INSTALL BANNER ── */
#pwa-banner{position:fixed;bottom:0;left:0;right:0;z-index:500;padding:12px 16px;background:var(--green-deep);border-top:2px solid var(--gold);display:none;}
#pwa-banner-inner{max-width:600px;margin:0 auto;display:flex;align-items:center;gap:12px;}
#pwa-install-btn{background:var(--gold);color:var(--road);border:none;border-radius:6px;padding:8px 16px;font-family:'Oswald',sans-serif;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;}

/* ── TOPBAR ── */
.topbar{background:var(--road);border-bottom:3px solid var(--gold);position:fixed;top:0;left:0;right:0;z-index:300;height:var(--topbar-h);}
.topbar-inner{max-width:1200px;margin:0 auto;padding:0 16px;display:flex;align-items:center;gap:12px;height:100%;}
.topbar-spacer{height:var(--topbar-h);}
.topbar-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.topbar-logo{width:44px;height:44px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;flex-shrink:0;}
.brand-text{display:flex;flex-direction:column;}
.brand-name{font-family:'Oswald',sans-serif;font-size:15px;font-weight:700;color:var(--white);line-height:1.1;}
.brand-sub{font-size:10px;color:var(--gold-light);letter-spacing:.07em;text-transform:uppercase;}
.topbar-nav{display:flex;gap:2px;flex:1;}
.nav-link{padding:6px 12px;font-size:13px;color:rgba(255,255,255,.75);border-radius:6px;transition:all .15s;text-decoration:none;white-space:nowrap;}
.nav-link:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none;}
.nav-link.active{background:rgba(255,255,255,.12);color:#fff;font-weight:600;}
.nav-link.btn-accent{background:var(--terracotta);color:#fff;font-weight:600;margin-left:4px;}
.nav-link.btn-accent:hover{background:var(--soil);}
.topbar-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0;}
.user-chip{display:flex;align-items:center;gap:8px;}
.user-avatar{width:34px;height:34px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:12px;font-weight:700;color:var(--road);flex-shrink:0;}
.user-info{display:flex;flex-direction:column;}
.user-name{font-size:13px;font-weight:600;color:#fff;line-height:1.2;}
.user-role{font-size:10px;color:var(--gold-light);text-transform:uppercase;letter-spacing:.06em;}
.btn-logout{font-size:12px;color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.2);border-radius:5px;padding:5px 10px;text-decoration:none;transition:all .15s;white-space:nowrap;}
.btn-logout:hover{background:rgba(255,255,255,.1);color:#fff;text-decoration:none;}

/* ── HAMBURGER ── */
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;border-radius:6px;}
.hamburger span{display:block;width:22px;height:2px;background:rgba(255,255,255,.8);border-radius:2px;transition:all .25s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ── MOBILE NAV DRAWER ── */
.mobile-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:399;opacity:0;transition:opacity .25s;}
.mobile-overlay.open{display:block;opacity:1;}
.mobile-nav{position:fixed;top:0;right:-280px;width:280px;height:100%;background:var(--road);z-index:400;transition:right .28s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:-4px 0 20px rgba(0,0,0,.4);}
.mobile-nav.open{right:0;}
.mobile-nav-header{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:12px;background:rgba(0,0,0,.2);margin-top:var(--topbar-h);}
.mobile-nav-links{padding:12px 8px;}
.mobile-nav-link{display:flex;align-items:center;gap:14px;padding:14px 14px;border-radius:10px;color:rgba(255,255,255,.8);text-decoration:none;margin-bottom:4px;transition:all .15s;font-size:15px;font-weight:500;}
.mobile-nav-link:hover,.mobile-nav-link.active{background:rgba(255,255,255,.1);color:#fff;text-decoration:none;}
.mobile-nav-link.accent{background:var(--terracotta);color:#fff;margin-top:8px;}
.mobile-nav-link.accent:hover{background:var(--soil);}
.mobile-nav-logout{margin-top:12px;border-top:1px solid rgba(255,255,255,.1);padding-top:16px;color:rgba(255,255,255,.5);}
.mnl-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0;}
.mnl-label{flex:1;}

/* ── LAYOUT ── */
.page-content{flex:1;padding:20px 16px 80px;}
.container{max-width:1200px;margin:0 auto;}
.container-sm{max-width:560px;margin:0 auto;}
.container-md{max-width:800px;margin:0 auto;}

/* ── CARDS ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px;}
.card-header{padding:14px 16px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.card-title{font-family:'Oswald',sans-serif;font-size:16px;font-weight:600;color:var(--text);letter-spacing:.02em;}
.card-body{padding:16px;}
.card-accent-top{border-top:3px solid var(--terracotta);}
.card-accent-green{border-top:3px solid var(--green);}

/* ── STAT CARDS ── */
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px;}
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;}
.stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:5px;}
.stat-value{font-family:'Oswald',sans-serif;font-size:24px;font-weight:700;color:var(--text);line-height:1;}
.stat-sub{font-size:12px;color:var(--text-muted);margin-top:3px;}

/* ── PROGRESS ── */
.progress-wrap{margin-bottom:16px;}
.progress-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:7px;font-size:13px;color:var(--text-muted);flex-wrap:wrap;gap:4px;}
.progress-header strong{color:var(--text);}
.progress-bar{height:14px;background:var(--savanna);border-radius:7px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--terracotta),var(--gold));border-radius:7px;transition:width 1s ease;}
.progress-meta{font-size:12px;color:var(--text-muted);margin-top:5px;}

/* ── HERO BAND ── */
.hero-band{background:linear-gradient(135deg,var(--road) 0%,var(--soil) 100%);padding:20px 16px;margin:-20px -16px 20px;border-bottom:3px solid var(--gold);}
.hero-band-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.hero-logo{width:64px;height:64px;border-radius:50%;border:3px solid var(--gold);object-fit:cover;flex-shrink:0;}
.hero-band-text .tagline{font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);margin-bottom:3px;}
.hero-band-text h1{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;color:var(--white);line-height:1.2;}
.hero-band-right{margin-left:auto;}
.gauge-wrap{display:flex;flex-direction:column;align-items:center;gap:2px;}
.gauge-pct{font-family:'Oswald',sans-serif;font-size:18px;font-weight:700;color:var(--gold-light);}
.gauge-sub{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.5);}

/* ── FORMS ── */
.form-group{margin-bottom:14px;}
.form-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:5px;}
.form-label .req{color:var(--terracotta);}
.form-input,.form-select,.form-textarea{width:100%;padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:16px;/* 16px prevents iOS zoom */font-family:'Inter',sans-serif;color:var(--text);background:var(--cream);transition:border-color .15s;outline:none;-webkit-appearance:none;appearance:none;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--terracotta);background:#fff;}
.form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B4C30' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;}
.form-textarea{resize:vertical;min-height:80px;font-size:15px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;}
.form-hint{font-size:12px;color:var(--text-muted);margin-top:4px;}
.form-error{font-size:12px;color:var(--terracotta);margin-top:4px;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;border:none;border-radius:var(--radius);font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;letter-spacing:.04em;cursor:pointer;text-decoration:none;transition:background .15s,transform .1s;-webkit-tap-highlight-color:transparent;min-height:44px;}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--terracotta);color:#fff;}
.btn-primary:hover{background:var(--soil);color:#fff;text-decoration:none;}
.btn-green{background:var(--green);color:#fff;}
.btn-green:hover{background:var(--green-deep);color:#fff;text-decoration:none;}
.btn-gold{background:var(--gold);color:var(--road);}
.btn-gold:hover{background:#b07e08;color:var(--road);text-decoration:none;}
.btn-outline{background:transparent;border:1.5px solid var(--terracotta);color:var(--terracotta);}
.btn-outline:hover{background:var(--terracotta);color:#fff;text-decoration:none;}
.btn-sm{padding:7px 14px;font-size:13px;min-height:36px;}
.btn-xs{padding:5px 10px;font-size:12px;border-radius:5px;min-height:30px;}
.btn-full{width:100%;}
.btn-group{display:flex;gap:10px;flex-wrap:wrap;}

/* ── TABLES — mobile scroll ── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
table{width:100%;border-collapse:collapse;font-size:14px;}
th{background:var(--savanna);padding:10px 12px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;}
td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:#fdf9f4;}
.td-amount{font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;color:var(--green);}
.table-footer{padding:10px 0 4px;font-size:13px;color:var(--text-muted);}

/* ── BADGES ── */
.badge{display:inline-block;padding:3px 8px;border-radius:5px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;}
.badge-gold{background:#FFF3CD;color:#854F0B;}
.badge-green{background:#D4EDDA;color:#155724;}
.badge-terracotta{background:#FDEEE8;color:#8B3A15;}
.badge-blue{background:#D1ECF1;color:#0c5460;}
.badge-gray{background:#e9ecef;color:#495057;}

/* ── ALERTS ── */
.alert{padding:12px 14px;border-radius:var(--radius);font-size:14px;margin-bottom:14px;line-height:1.5;}
.alert-success{background:#D4EDDA;color:#155724;border:1px solid #C3E6CB;}
.alert-error{background:#F8D7DA;color:#721c24;border:1px solid #F5C6CB;}
.alert-warning{background:#FFF3CD;color:#856404;border:1px solid #FFEAA7;}
.alert-info{background:#D1ECF1;color:#0c5460;border:1px solid #BEE5EB;}

/* ── AUTH ── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px;background:var(--road);}
.auth-card{background:var(--white);border-radius:16px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.35);}
.auth-header{background:var(--road);padding:24px 24px 20px;text-align:center;border-bottom:3px solid var(--gold);}
.auth-logo-img{width:80px;height:80px;border-radius:50%;border:3px solid var(--gold);object-fit:cover;margin-bottom:12px;}
.auth-title{font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;color:var(--white);}
.auth-sub{font-size:12px;color:var(--gold-light);margin-top:3px;}
.auth-body{padding:24px;}
.auth-footer{background:var(--savanna);padding:14px 24px;text-align:center;font-size:13px;color:var(--text-muted);border-top:1px solid var(--border);}

/* ── TWO-COL ── */
.two-col{display:grid;grid-template-columns:1fr 340px;gap:16px;align-items:start;}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}

/* ── CONTRIB LIST ── */
.contrib-list{list-style:none;}
.contrib-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.contrib-item:last-child{border-bottom:none;}
.c-avatar{width:36px;height:36px;border-radius:50%;background:var(--savanna);display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:12px;font-weight:600;color:var(--soil);flex-shrink:0;}
.c-info{flex:1;min-width:0;}
.c-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.c-meta{font-size:12px;color:var(--text-muted);margin-top:1px;}
.c-amount{font-family:'Oswald',sans-serif;font-size:15px;font-weight:600;color:var(--green);flex-shrink:0;}

/* ── WARD BARS ── */
.ward-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border);}
.ward-row:last-child{border-bottom:none;}
.ward-name{font-size:13px;font-weight:500;color:var(--text);flex:0 0 130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ward-bar-wrap{flex:1;height:7px;background:var(--savanna);border-radius:4px;overflow:hidden;}
.ward-bar{height:100%;background:var(--terracotta);border-radius:4px;}
.ward-total{font-size:12px;font-weight:600;color:var(--green);min-width:60px;text-align:right;}

/* ── COUNTDOWN ── */
.countdown{display:flex;gap:8px;}
.cd-block{flex:1;background:var(--savanna);border-radius:var(--radius);padding:10px 6px;text-align:center;}
.cd-num{font-family:'Oswald',sans-serif;font-size:22px;font-weight:700;color:var(--terracotta);line-height:1;}
.cd-unit{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-top:2px;}

/* ── BANK DETAILS ── */
.bank-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);}
.bank-row:last-child{border-bottom:none;}
.bank-key{font-size:13px;color:var(--text-muted);}
.bank-val{font-size:13px;font-weight:600;font-family:monospace;color:var(--text);}

/* ── PROFILE ── */
.profile-hero{background:linear-gradient(135deg,var(--road),var(--soil));border-radius:var(--radius-lg);padding:20px 16px;margin-bottom:16px;display:flex;align-items:center;gap:14px;}
.profile-avatar{width:56px;height:56px;background:var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;color:var(--road);flex-shrink:0;}
.profile-info .profile-name{font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;color:#fff;}
.profile-info .profile-meta{font-size:13px;color:rgba(255,255,255,.65);margin-top:3px;}
.profile-badge{display:inline-block;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:2px 10px;border-radius:20px;font-size:11px;color:var(--gold-light);text-transform:uppercase;letter-spacing:.06em;margin-top:5px;}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:36px 16px;color:var(--text-muted);}
.empty-state .empty-icon{font-size:36px;opacity:.35;margin-bottom:8px;}
.empty-state .empty-title{font-size:15px;font-weight:600;margin-bottom:4px;}
.empty-state .empty-desc{font-size:13px;line-height:1.6;}

/* ── PAGE HEADER ── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px;}
.page-header h2{font-family:'Oswald',sans-serif;font-size:20px;font-weight:600;color:var(--text);}
.page-header p{font-size:13px;color:var(--text-muted);margin-top:2px;}

/* ── RECEIPT ── */
.receipt-card{background:#fff;width:100%;max-width:480px;font-family:'Inter',sans-serif;border:2px solid var(--road);border-radius:4px;overflow:hidden;}
.rc-header{background:var(--road);padding:14px 16px;display:flex;align-items:center;gap:10px;}
.rc-logo-img{width:44px;height:44px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;flex-shrink:0;}
.rc-org{flex:1;}
.rc-org-name{font-family:'Oswald',sans-serif;font-size:15px;font-weight:700;color:#fff;}
.rc-org-sub{font-size:10px;color:var(--gold-light);letter-spacing:.07em;text-transform:uppercase;margin-top:1px;}
.rc-address{font-size:10px;color:rgba(255,255,255,.5);text-align:right;line-height:1.5;}
.rc-gold-bar{height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-light),var(--gold));}
.rc-meta{padding:10px 16px 8px;display:flex;justify-content:space-between;align-items:baseline;background:var(--savanna);border-bottom:1px solid var(--border);}
.rc-label{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:2px;}
.rc-receipt-no{font-family:'Oswald',sans-serif;font-size:20px;font-weight:700;color:var(--terracotta);}
.rc-date{font-size:13px;font-weight:600;color:var(--text);}
.rc-body{padding:12px 16px;}
.rc-row{display:flex;padding:6px 0;border-bottom:1px solid rgba(92,51,23,.07);}
.rc-row:last-child{border-bottom:none;}
.rc-key{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;width:110px;flex-shrink:0;padding-top:1px;}
.rc-val{font-size:13px;font-weight:600;color:var(--text);flex:1;}
.rc-amount-box{margin:8px 16px;background:var(--road);border-radius:8px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;}
.rc-amount-label{font-size:11px;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.06em;}
.rc-amount-sub{font-size:10px;color:rgba(255,255,255,.4);margin-top:1px;}
.rc-amount-val{font-family:'Oswald',sans-serif;font-size:24px;font-weight:700;color:var(--gold-light);}
.rc-purpose{margin:0 16px 8px;background:var(--savanna);border-radius:6px;padding:8px 12px;font-size:11px;color:var(--text-muted);text-align:center;}
.rc-sig{padding:8px 16px 12px;display:flex;justify-content:flex-end;}
.rc-sig-line{border-top:1px solid var(--border);padding-top:4px;font-size:11px;color:var(--text-muted);text-align:center;min-width:110px;}
.rc-sig-line small{opacity:.6;}
.rc-footer{background:var(--green-deep);padding:10px 16px;display:flex;justify-content:space-between;align-items:flex-start;font-size:11px;color:rgba(255,255,255,.6);line-height:1.5;}
.rc-footer strong{color:var(--gold-light);}
.rc-tagline{background:var(--terracotta);padding:7px 16px;text-align:center;font-family:'Oswald',sans-serif;font-size:11px;letter-spacing:.08em;color:#fff;text-transform:uppercase;}
.receipt-page{display:flex;flex-direction:column;align-items:center;gap:14px;padding:12px 0;}
.receipt-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;width:100%;}

/* ── SEARCH BAR ── */
.search-bar{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;}

/* ── PoP UPLOAD ── */
.pop-upload-zone{border:2px dashed var(--border);border-radius:10px;padding:24px 16px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--cream);}
.pop-upload-zone:hover,.pop-upload-zone.drag-over{border-color:var(--terracotta);background:#fdf5ef;}
.pop-preview-img{max-width:180px;max-height:130px;border-radius:6px;object-fit:cover;}

/* ── FOOTER ── */
.app-footer{background:var(--road);border-top:3px solid var(--gold);padding:20px 16px;margin-top:auto;}
.footer-inner{max-width:1200px;margin:0 auto;text-align:center;}
.footer-logo{width:60px;height:60px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;margin-bottom:10px;}
.app-footer p{font-size:13px;color:rgba(255,255,255,.6);margin-top:4px;}
.footer-sub{font-size:11px;color:rgba(255,255,255,.35);margin-top:3px !important;}

/* ── PRINT ── */
@media print{
  .topbar,.topbar-spacer,.receipt-actions,.app-footer,.page-header,#pwa-banner,.mobile-nav,.mobile-overlay{display:none !important;}
  .receipt-page{padding:0;}
  body{background:#fff;}
}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .two-col{grid-template-columns:1fr;}
  .three-col{grid-template-columns:1fr 1fr;}
}

@media(max-width:700px){
  /* Show hamburger, hide desktop nav and user info */
  .hamburger{display:flex;}
  .topbar-nav,.user-info,.btn-logout{display:none;}

  .form-row,.form-row-3{grid-template-columns:1fr;}
  .three-col{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr 1fr;}
  .ward-name{flex:0 0 100px;}

  /* Hero band stacks */
  .hero-band-inner{flex-direction:column;align-items:flex-start;gap:12px;}
  .hero-band-right{display:none;}

  /* Table: hide less important columns on mobile */
  table .hide-mobile{display:none;}

  /* Buttons full width on mobile forms */
  .btn-group{flex-direction:column;}
  .btn-group .btn{width:100%;}

  /* Receipt */
  .receipt-card{max-width:100%;}
  .rc-address{display:none;}
}

@media(max-width:400px){
  .stats-grid{grid-template-columns:1fr;}
  .brand-sub{display:none;}
}
