:root{--primary:#E9B121;--primary-dark:#2D1E00;--primary-mid:#6B4E00;--primary-light:#FFF3D0;--bg:#FFFBF0;--card:#fff;--text:#1C1200;--muted:#7A6840;--border:#EDE0B8;--sidebar-text:#FFF3D0}
*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text)}
.shell{display:flex;min-height:100vh}

/* ── sidebar: hidden by default (mobile-first), shown on desktop ─────── */
.side{display:none;width:250px;background:var(--primary-dark);color:var(--sidebar-text);padding:24px;flex-direction:column;border-right:3px solid var(--primary)}
.brand{display:flex;flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:25px}
.brand img{width:60px;height:auto}
.brand-name{font-size:20px;font-weight:800;color:var(--primary);letter-spacing:.5px}
.side a{display:block;color:var(--sidebar-text);text-decoration:none;padding:12px;border-radius:10px;margin:6px 0;border-left:3px solid transparent;transition:background .15s,border-color .15s}
.side a:hover{background:rgba(233,177,33,.15);border-left-color:var(--primary)}
.side a.nav-active{background:rgba(233,177,33,.22);border-left-color:var(--primary);color:var(--primary);font-weight:700}
.side nav{flex:1}
.side-footer{margin-top:auto;padding-top:16px;border-top:1px solid rgba(233,177,33,.25)}

/* ── content: full-width by default (mobile), offset on desktop ─────── */
.content{margin-left:0;padding:16px;padding-bottom:84px;width:100%}

/* ── desktop breakpoint ─────────────────────────────────────────────── */
@media(min-width:901px){
  .side{display:flex;position:fixed;top:0;bottom:0}
  .content{margin-left:250px;padding:26px;width:calc(100% - 250px);padding-bottom:26px}
  .mobile-header,.mobile-nav{display:none}
  .grid{grid-template-columns:repeat(4,minmax(0,1fr))}
  .form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* ── shared component styles ────────────────────────────────────────── */
.hero{background:linear-gradient(135deg,var(--primary-dark),var(--primary-mid));color:var(--primary-light);border-radius:22px;padding:28px;margin-bottom:22px;border-bottom:4px solid var(--primary)}
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.card{background:var(--card);border-radius:18px;padding:20px;box-shadow:0 10px 24px rgba(233,177,33,.10);border-top:3px solid var(--primary)}
.metric{font-size:34px;font-weight:800;color:var(--primary-dark)}.muted{color:var(--muted)}
.form-grid{display:grid;grid-template-columns:1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}.field label{font-weight:700;color:var(--primary-dark)}
.input,select,textarea{width:100%;padding:12px;border:1px solid var(--border);border-radius:12px;background:#fff;color:var(--text)}
.input:focus,select:focus,textarea:focus{outline:2px solid var(--primary);border-color:var(--primary)}
.btn{border:0;border-radius:12px;padding:12px 16px;font-weight:700;cursor:pointer;transition:filter .15s}.btn:hover{filter:brightness(1.1)}
.btn-primary{background:var(--primary-dark);color:var(--primary-light)}.btn-secondary{background:var(--primary-light);color:var(--primary-dark)}.btn-gold{background:var(--primary);color:var(--primary-dark)}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;border:1px solid var(--border)}
.table th{background:var(--primary-dark);color:var(--primary-light)}.table th,.table td{padding:12px;border-bottom:1px solid var(--border);text-align:left}.table tr:hover td{background:var(--primary-light)}
.status{padding:5px 9px;border-radius:999px;background:var(--primary-light);color:var(--primary-dark);font-size:12px;font-weight:700}
.map{height:650px;border-radius:20px;overflow:hidden;border:2px solid var(--primary)}
.qrbox{background:var(--primary-light);border:1px dashed var(--primary);border-radius:18px;padding:18px;text-align:center}
.tab-bar{display:flex;gap:10px;margin-top:18px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── small screen ───────────────────────────────────────────────────── */
@media(max-width:560px){.grid{grid-template-columns:1fr}.hero{padding:20px}.content{padding:12px;padding-bottom:84px}}

/* ── QR scanner modal ────────────────────────────────────────────────── */
.qr-modal{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;padding:16px}
.qr-modal--hidden{display:none}
.qr-modal-box{background:#fff;border-radius:20px;padding:22px;width:100%;max-width:420px;box-shadow:0 24px 64px rgba(0,0,0,.45)}
.qr-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.qr-modal-close{background:var(--primary-light);border:0;border-radius:50%;width:34px;height:34px;font-size:18px;cursor:pointer;color:var(--primary-dark);font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center}
#qr-reader{border-radius:14px;overflow:hidden;width:100%}

/* ── mobile top header ───────────────────────────────────────────────── */
.mobile-header{display:none;position:sticky;top:0;z-index:200;background:var(--primary-dark);border-bottom:3px solid var(--primary);padding:12px 16px;align-items:center;gap:10px}
.mobile-header img{width:36px;height:auto;flex-shrink:0}
.mobile-header-name{font-size:17px;font-weight:800;color:var(--primary);letter-spacing:.4px}

/* ── mobile bottom tab bar ───────────────────────────────────────────── */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;background:var(--primary-dark);border-top:3px solid var(--primary);padding-bottom:env(safe-area-inset-bottom)}
.mobile-nav-items{display:flex;justify-content:space-around;align-items:stretch}
.mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;flex:1;padding:8px 4px;text-decoration:none;color:var(--sidebar-text);font-size:11px;font-weight:600;letter-spacing:.3px;transition:color .15s}
.mobile-nav-item .mobile-nav-icon{font-size:22px;line-height:1}
.mobile-nav-item.nav-active{color:var(--primary)}
.mobile-nav-item.nav-active .mobile-nav-icon{filter:drop-shadow(0 0 4px var(--primary))}

/* show mobile chrome only on small screens — must be AFTER the display:none base rules */
@media(max-width:900px){
  .mobile-header{display:flex}
  .mobile-nav{display:block}
}

/* ── user chip ───────────────────────────────────────────────────────── */
.user-chip{display:flex;align-items:center;gap:8px;padding:8px 4px;color:var(--primary-light);font-size:13px;margin-bottom:8px;overflow:hidden}
.user-icon{font-size:18px;flex-shrink:0}
.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btn-signout{width:100%;background:transparent;border:1px solid var(--primary);color:var(--primary);border-radius:10px;padding:8px 12px;font-weight:700;cursor:pointer;font-size:13px;transition:background .15s}
.btn-signout:hover{background:rgba(233,177,33,.18)}

/* ── auth pages ──────────────────────────────────────────────────────── */
.auth-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--primary-dark)}
.auth-wrap{width:100%;max-width:480px;padding:24px}
.auth-card{background:var(--card);border-radius:22px;padding:36px;box-shadow:0 16px 48px rgba(0,0,0,.35);border-top:4px solid var(--primary)}
.auth-logo{display:flex;align-items:center;gap:14px;margin-bottom:28px}
.auth-logo img{width:52px;height:auto}
.auth-logo-name{font-size:20px;font-weight:800;color:var(--primary-dark)}
.auth-title{margin:0 0 22px;font-size:22px;font-weight:800;color:var(--primary-dark)}
.auth-error{background:#fff0f0;border:1px solid #f5a0a0;color:#8b0000;border-radius:10px;padding:10px 14px;margin-bottom:16px;font-size:14px}
.auth-validation{color:#c0392b;font-size:12px;margin-top:2px}
.auth-check{display:flex;align-items:center;gap:8px;margin:14px 0;font-size:14px}
.auth-check input{width:auto}
.auth-submit{width:100%;margin-top:6px;padding:14px;font-size:15px}
.auth-switch{text-align:center;margin-top:20px;font-size:14px;color:var(--muted)}
.auth-switch a{color:var(--primary-dark);font-weight:700}
@media(max-width:520px){.auth-card{padding:24px;border-radius:16px}}

/* ── FORCE hide sidebar on mobile — must be last rule in file ─────────── */
@media(max-width:900px){
  .side{display:none!important;width:0!important;padding:0!important;border:none!important;overflow:hidden!important}
  .content{margin-left:0!important;width:100%!important}
}

/* ── Records: table on desktop, cards on mobile ──────────────────────── */
.records-table-wrap{display:block}
.records-cards-wrap{display:none}

@media(max-width:900px){
  .records-table-wrap{display:none}
  .records-cards-wrap{display:flex;flex-direction:column;gap:12px}
}

.record-card{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;box-shadow:0 2px 8px rgba(233,177,33,.08)}
.record-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.record-card-initiative{font-weight:700;color:var(--primary-dark);font-size:14px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.record-card-row{display:flex;gap:8px;font-size:13px;align-items:baseline}
.record-card-label{font-weight:700;color:var(--muted);min-width:52px;flex-shrink:0;font-size:11px;text-transform:uppercase;letter-spacing:.4px}
.record-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:6px;border-top:1px solid var(--border)}

/* ── Maintenance banner (top QR scanned) ────────────────────────────── */
.maintenance-banner{border:2px solid #E67E22;background:#FFF3E0}
.maintenance-banner strong{color:#7D3C00}

/* ── Print: hide Blazor shell chrome when printing ───────────────────── */
@media print{
  .side,.mobile-nav,.mobile-header{display:none!important}
  .content{margin-left:0!important;width:100%!important;padding:0!important}
}
