/* =============================================================
   Bhopal.info Portal -- shared chrome & tokens
   MOBILE-FIRST rebuild: 2026-06-04
   Breakpoints: 480 / 768 / 1024 / 1280 (min-width only)
   Authority: docs/00_core/RESPONSIVE_SYSTEM.md
   ================================================================ */

/* TOKENS */
:root{
  --red:#B71C1C; --red-h:#7F0000; --red-lt:#FFEBEE; --red-m:#EF9A9A;
  --orange:#F57C00; --orange-h:#E65100; --orange-lt:#FFF3E0; --orange-m:#FFB74D;
  --green:#8FB339; --green-lt:#F1F8E9; --green-d:#5a7a1a;
  --g50:#FAFAFA; --g100:#F5F5F5; --g200:#EEEEEE; --g300:#E0E0E0;
  --g400:#BDBDBD; --g500:#9E9E9E; --g700:#616161; --g900:#212121;
  --white:#FFFFFF; --footer:#111111;
  --serif:'Noto Serif',serif;
  --sans:'Noto Sans','Noto Sans Devanagari',sans-serif;
  --max:1200px; --pad:14px;
}
@media(min-width:480px){ :root{ --pad:18px; } }
@media(min-width:768px){ :root{ --pad:24px; } }
@media(min-width:1024px){ :root{ --pad:32px; } }

/* RESET */
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden}
body{font-family:var(--sans);font-size:15px;background:var(--g50);color:var(--g900);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
img.leaflet-tile{display:inline}

/* CONTAINER */
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* UTILITY BAR - hidden mobile, shown md+ */
.util-bar{display:none}
@media(min-width:768px){
  .util-bar{display:flex;background:var(--g900);color:var(--g500);font-size:11px;padding:0 var(--pad);height:28px;align-items:center;justify-content:space-between}
  .util-left{display:flex;gap:16px;align-items:center}
  .util-right{display:flex;gap:12px;align-items:center}
  .util-right a{color:var(--g500);transition:color 150ms}
  .util-right a:hover{color:#fff}
  .lang-btn{font-size:11px;font-weight:600;padding:2px 8px;border:1px solid #333;cursor:pointer;background:transparent;color:var(--g500);font-family:var(--sans);transition:all 150ms}
  .lang-btn.active{background:var(--red);color:#fff;border-color:var(--red)}
}

/* ============================================================
   HEADER — Two-row layout
   Row 1: Logo + Search + User  (header-top)
   Row 2: Full-width nav bar    (header-nav-row)  — desktop only
   ============================================================ */
.header{background:var(--white);border-bottom:3px solid var(--red);position:sticky;top:0;z-index:100}

/* ---- ROW 1 BASE (mobile) ---- */
.header-top{max-width:100%;margin:0 auto;padding:0 var(--pad);height:54px;display:flex;align-items:center;gap:10px}
.logo-link{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}
.logo-img{height:36px;width:auto}
.logo-divider{display:none}
.logo-lockup{display:none}
.header-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.search-wrap{display:none}
.search-input{flex:1;border:none;background:transparent;font-family:var(--sans);font-size:13px;color:var(--g900);padding:7px 10px;outline:none}
.search-input::placeholder{color:var(--g400)}
.search-btn{padding:7px 10px;background:transparent;border:none;cursor:pointer;display:flex;align-items:color:var(--g500);transition:color 150ms}
.search-btn:hover{color:var(--red)}
.acct{display:none}
.btn-header-signin{display:none}

/* ---- ROW 2 BASE (hidden on mobile) ---- */
.header-nav-row{display:none}
.header-nav-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.main-nav{display:flex;align-items:stretch;gap:0;overflow:visible}

/* Hamburger */
.mob-menu-btn{display:flex;flex-direction:column;justify-content:space-between;width:36px;height:36px;min-width:44px;min-height:44px;background:none;border:none;cursor:pointer;padding:9px 5px;flex-shrink:0}
.ham-bar{display:block;width:100%;height:2px;background:var(--g900);border-radius:2px;transition:transform 220ms,opacity 220ms}

/* Mobile search button */
.mob-search-btn{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;background:none;border:none;cursor:pointer;color:var(--g700);flex-shrink:0}

/* ---- TABLET (768px+): show logo lockup ---- */
@media(min-width:768px){
  .header-top{height:64px;gap:12px}
  .logo-img{height:46px}
  .logo-divider{display:block;width:1px;height:44px;background:var(--g200);flex-shrink:0}
  .logo-lockup{display:flex;flex-direction:column;gap:2px;line-height:1.15}
  .ll-name{font-family:var(--serif);font-size:13px;font-weight:700;color:var(--g900);white-space:nowrap}
  .ll-tag{font-size:10px;color:var(--g500);white-space:nowrap;letter-spacing:.01em}
}

/* ---- DESKTOP (1024px+): show nav row 2, hide hamburger ---- */
@media(min-width:1024px){
  .header-top{max-width:var(--max);margin:0 auto;height:68px}
  .logo-img{height:52px}
  .mob-menu-btn{display:none}
  .mob-search-btn{display:none}
  .search-wrap{display:flex;align-items:center;background:var(--g100);border:1px solid var(--g200);overflow:hidden;transition:border-color 150ms,width 150ms;width:200px}
  .search-wrap:focus-within{border-color:var(--red);background:var(--white);width:260px}
  .acct{display:block;position:relative;flex-shrink:0}
  .btn-header-signin{display:inline-flex}

  /* Row 2 nav bar */
  .header-nav-row{display:block;background:var(--white);border-top:1px solid var(--g100)}
  .header-nav-inner{display:flex;align-items:stretch}
  .main-nav{width:100%;justify-content:flex-start}
}

/* Desktop nav */
.nav-link{font-size:13px;font-weight:500;color:var(--g700);padding:0 14px;height:40px;display:flex;align-items:center;gap:6px;border-bottom:3px solid transparent;transition:color 150ms,border-color 150ms;white-space:nowrap;background:none;border-left:none;border-right:none;border-top:none;cursor:pointer;font-family:var(--sans)}
.nav-link .nav-ico{width:15px;height:15px;color:var(--g400);transition:color 150ms}
.nav-link:hover{color:var(--red)}
.nav-link:hover .nav-ico{color:var(--red)}
.nav-link.active{color:var(--red);border-bottom-color:var(--red);font-weight:600}
.nav-link.active .nav-ico{color:var(--red)}
.nav-more{position:relative;display:flex;align-items:stretch}
.nav-more-btn{gap:4px}
.nav-more-btn.has-active{color:var(--red)}
.nav-more.open .nav-more-btn{color:var(--red)}
.nav-more.open .nav-more-btn .nav-ico{transform:rotate(180deg)}
.nav-more-menu{display:none;position:absolute;top:100%;right:0;min-width:188px;background:var(--white);border:1px solid var(--g200);padding:6px;z-index:120;flex-direction:column;margin-top:-2px}
.nav-more.open .nav-more-menu{display:flex}
.nav-more-menu .nav-link{height:auto;padding:9px 12px;border-bottom:none;width:100%;font-weight:500}
.nav-more-menu .nav-link:hover{background:var(--g50)}
.nav-more-menu .nav-link.active{background:var(--red-lt);font-weight:600}
.nav-more-menu .nav-link .nav-ico{width:16px;height:16px}

/* Account chip */
.acct-btn{display:flex;align-items:center;gap:8px;background:var(--white);border:1px solid var(--g200);padding:4px 11px 4px 4px;cursor:pointer;transition:border-color 150ms;font-family:var(--sans)}
.acct-btn:hover{border-color:var(--red)}
.acct-av{width:30px;height:30px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:var(--serif);flex-shrink:0}
.acct-nm{font-size:12.5px;font-weight:600;color:var(--g900);white-space:nowrap}
.acct-btn .chev{width:14px;height:14px;color:var(--g500);transition:transform 150ms}
.acct.open .acct-btn .chev{transform:rotate(180deg)}
.acct-menu{display:none;position:absolute;top:calc(100% + 9px);right:0;min-width:236px;background:#fff;border:1px solid var(--g200);padding:6px;z-index:200;flex-direction:column}
.acct.open .acct-menu{display:flex}
.acct-head{display:flex;gap:11px;align-items:center;padding:10px 11px 13px;border-bottom:1px solid var(--g200);margin-bottom:6px}
.acct-head .av{width:42px;height:42px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;font-family:var(--serif);flex-shrink:0}
.acct-head .nm{font-size:13.5px;font-weight:700;color:var(--g900)}
.acct-head .mt{font-size:11.5px;color:var(--g500);display:flex;align-items:center;gap:4px;margin-top:2px}
.acct-head .mt i{width:12px;height:12px;color:var(--green)}
.acct-item{display:flex;align-items:center;gap:11px;padding:9px 11px;font-size:13px;color:var(--g700);cursor:pointer;font-weight:500;transition:background 150ms,color 150ms}
.acct-item:hover{background:var(--g50);color:var(--red)}
.acct-item i{width:16px;height:16px;color:var(--g500);transition:color 150ms}
.acct-item:hover i{color:var(--red)}
.acct-item .tag{margin-left:auto;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--orange-h);background:var(--orange-lt);padding:2px 7px;margin-top:6px;padding-top:11px}

/* MOBILE NAV DRAWER */
.mob-nav-drawer{position:fixed;top:0;left:-100%;width:82vw;max-width:320px;height:100vh;background:var(--white);z-index:999;display:flex;flex-direction:column;transition:left 260ms ease;overflow-y:auto;border-right:3px solid var(--red)}
.mob-nav-drawer.open{left:0}
.mob-nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.52);z-index:998}
.mob-nav-overlay.open{display:block}
.mob-nav-header{display:flex;align-items:center;justify-content:space-between;background:var(--red);padding:14px 16px;flex-shrink:0}
.mob-nav-logo{height:32px;width:auto}
.mob-nav-close{background:none;border:none;color:#fff;font-size:22px;cursor:pointer;line-height:1;padding:4px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.mob-nav-links{flex:1;display:flex;flex-direction:column;padding:6px 0}
.mob-nav-link{display:flex;align-items:center;gap:12px;padding:13px 20px;font-size:15px;font-weight:500;color:#424242;border-bottom:1px solid var(--g100);transition:background 150ms,color 150ms;min-height:44px;text-decoration:none}
.mob-nav-link i,.mob-nav-link svg{width:17px;height:17px;color:var(--g500);flex-shrink:0;transition:color 150ms}
.mob-nav-link:hover,.mob-nav-link.active{background:#fff5f5;color:var(--red);border-left:3px solid var(--red);padding-left:17px}
.mob-nav-link:hover i,.mob-nav-link.active i{color:var(--red)}
.mob-nav-footer{padding:16px;border-top:1px solid var(--g200);flex-shrink:0}
.mob-nav-footer .btn{width:100%;justify-content:center}
@media(min-width:1024px){
  .mob-nav-drawer{display:none!important}
  .mob-nav-overlay{display:none!important}
}

/* MOBILE SEARCH OVERLAY */
.mob-search-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:997;align-items:flex-start;padding-top:60px}
.mob-search-overlay.open{display:flex}
.mob-search-inner{width:100%;max-width:600px;margin:0 auto;padding:0 16px}
.mob-search-form{display:flex;border:2px solid var(--red);overflow:hidden;background:#fff}
.mob-search-input{flex:1;border:none;outline:none;font-family:var(--sans);font-size:16px;color:var(--g900);padding:14px 16px;min-height:44px}
.mob-search-submit{background:var(--red);color:#fff;border:none;font-family:var(--sans);font-size:14px;font-weight:600;padding:0 20px;cursor:pointer;min-height:44px}
.mob-search-cancel{display:block;text-align:center;margin-top:14px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;padding:8px}
@media(min-width:1024px){.mob-search-overlay{display:none!important}}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;line-height:1}
.badge-red{background:var(--red);color:#fff}
.badge-orange{background:var(--orange);color:#fff}
.badge-green{background:var(--green);color:#fff}
.badge-gray{background:var(--g100);color:var(--g700);border:1px solid var(--g200)}
.badge-outline-green{background:transparent;color:var(--green-d);border:1px solid var(--green)}
.badge-outline-orange{background:transparent;color:var(--orange-h);border:1px solid var(--orange-m)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-family:var(--sans);font-weight:600;cursor:pointer;border:1px solid transparent;padding:10px 18px;font-size:13px;line-height:1;transition:background 150ms,color 150ms,border-color 150ms;white-space:nowrap;min-height:44px}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-h)}
.btn-secondary{background:var(--orange);color:#fff}
.btn-secondary:hover{background:var(--orange-h)}
.btn-outline{background:transparent;color:var(--red);border-color:var(--red)}
.btn-outline:hover{background:var(--red-lt)}
.btn-ghost{background:transparent;color:var(--g700);border-color:var(--g200)}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}
.btn-lg{padding:14px 26px;font-size:15px}
.btn-block{width:100%}

/* SECTION HEADING */
.section-hd{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--red);padding-bottom:10px;margin-bottom:20px;flex-wrap:wrap;gap:8px}
.section-hd h2{font-family:var(--sans);font-size:14px;font-weight:700;color:var(--g900);text-transform:uppercase;letter-spacing:.06em}
.see-all{font-size:12px;font-weight:600;color:var(--red);white-space:nowrap}
.see-all:hover{color:var(--red-h)}

/* PLACEHOLDER */
.ph{background:repeating-linear-gradient(135deg,var(--g100) 0,var(--g100) 8px,var(--g200) 8px,var(--g200) 16px)}
.ph-orange{background:repeating-linear-gradient(135deg,#FFF3E0 0,#FFF3E0 8px,#FFE0B2 8px,#FFE0B2 16px)}
.ph-label{font-size:11px;color:var(--g400);font-family:'Courier New',monospace;text-align:center}

/* FOOTER */
@media(min-width:1024px){.footer-grid{grid-template-columns:220px 1fr 1fr;gap:36px;margin-bottom:28px}}
/* FORM CONTROLS */
.field{display:flex;flex-direction:column;gap:6px}
.field > label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--g700)}
.field .req{color:var(--red)}
.input,.select,.textarea{width:100%;font-family:var(--sans);font-size:14px;color:var(--g900);background:var(--white);border:1px solid var(--g300);padding:11px 12px;outline:none;transition:border-color 150ms;min-height:44px}
.input:focus,.select:focus,.textarea:focus{border-color:var(--red)}
.input::placeholder,.textarea::placeholder{color:var(--g400)}
.textarea{resize:vertical;min-height:120px;line-height:1.55}
.select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%239E9E9E' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}
.field .hint{font-size:11.5px;color:var(--g500);line-height:1.4}
.input-group{display:flex;align-items:center;background:var(--white);border:1px solid var(--g300);overflow:hidden;transition:border-color 150ms}
.input-group:focus-within{border-color:var(--red)}
.input-group > i{width:16px;height:16px;color:var(--g500);margin-left:12px;flex-shrink:0}
.input-group .input{border:none;border-radius:0}
.input-group .addon{align-self:stretch;display:flex;align-items:center;background:var(--g100);border-left:1px solid var(--g200);padding:0 13px;font-size:13px;color:var(--g700);font-weight:600;white-space:nowrap}
.form-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:768px){.form-grid{grid-template-columns:1fr 1fr;gap:16px 18px}}
.form-grid .span2{grid-column:1 / -1}

/* Toggle */
.switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0;position:absolute}
.switch .track{position:absolute;cursor:pointer;inset:0;background:var(--g300);border-radius:24px;transition:background 150ms}
.switch .track:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform 150ms}
.switch input:checked + .track{background:var(--green)}
.switch input:checked + .track:before{transform:translateX(20px)}

/* Data table */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.dtable-wrap{border:1px solid var(--g200);overflow:hidden;background:#fff}
.dtable{width:100%;border-collapse:collapse;min-width:480px}
.dtable th{text-align:left;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--g500);padding:12px 16px;background:var(--g50);border-bottom:1px solid var(--g200);white-space:nowrap}
.dtable td{padding:13px 16px;font-size:13.5px;color:var(--g900);border-bottom:1px solid var(--g100);vertical-align:middle}
.dtable tbody tr:last-child td{border-bottom:none}
.dtable tbody tr{transition:background 150ms}
.dtable tbody tr:hover{background:var(--g50)}

/* Status tags */
.stag{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;padding:4px 10px;text-transform:uppercase;letter-spacing:.03em;line-height:1.2;white-space:nowrap}
.stag i{width:12px;height:12px}
.stag.pending{background:var(--orange-lt);color:var(--orange-h)}
.stag.progress{background:var(--g100);color:var(--g700);border:1px solid var(--g200)}
.stag.done{background:var(--green-lt);color:var(--green-d)}
.stag.review{background:var(--orange-lt);color:var(--orange-h)}
.stag.rejected{background:var(--red-lt);color:var(--red)}

/* Page head */
.page-head{background:var(--white);border-bottom:1px solid var(--g200)}
.page-head-in{max-width:var(--max);margin:0 auto;padding:16px var(--pad)}
@media(min-width:768px){.page-head-in{padding:24px var(--pad)}}
.page-head h1{font-family:var(--serif);font-size:clamp(20px,5vw,26px);font-weight:700;color:var(--g900);line-height:1.2}
.page-head .sub{font-size:clamp(13px,2vw,14px);color:var(--g700);margin-top:5px}

/* Panel */
.panel{background:var(--white);border:1px solid var(--g200);align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--g200);flex-wrap:wrap}
@media(min-width:768px){.panel-hd{padding:16px 20px}}
.panel-hd h3{font-family:var(--sans);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--g900);display:flex;align-items:center;gap:9px}
.panel-hd h3 i{width:16px;height:16px;color:var(--red)}
.panel-bd{padding:16px}
@media(min-width:768px){.panel-bd{padding:20px}}

/* Icon button */
.iconbtn{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-size:12px;font-weight:600;padding:8px 12px;border:1px solid var(--g200);background:#fff;color:var(--g700);cursor:pointer;transition:all 150ms;white-space:nowrap;min-height:44px}
.iconbtn i{width:14px;height:14px}
.iconbtn:hover{border-color:var(--red);color:var(--red)}
.iconbtn.green{color:var(--green-d);border-color:var(--green)}
.iconbtn.green:hover{background:var(--green-lt)}
.iconbtn.red{color:var(--red);border-color:var(--red-m)}
.iconbtn.red:hover{background:var(--red-lt)}
.iconbtn.solid-green{background:var(--green);border-color:var(--green);color:#fff}
.iconbtn.solid-green:hover{background:var(--green-d)}
.iconbtn.solid-red{background:var(--red);border-color:var(--red);color:#fff}
.iconbtn.solid-red:hover{background:var(--red-h)}

/* STATIC PAGES */
.static-wrap{max-width:860px;margin:0 auto;padding:0 var(--pad) 48px}
.static-hero{border-left:4px solid var(--red);padding:24px 0 18px 18px;margin:20px 0 28px}
.static-hero h1{font-size:clamp(20px,5vw,26px);font-weight:700;color:var(--g900);margin:0 0 6px}
.static-sub{font-size:13.5px;color:var(--g500);margin:0}
.notice-bar{display:flex;align-items:flex-start;gap:10px;background:#fff8e1;border-left:3px solid var(--orange);padding:12px 16px;margin-bottom:28px;font-size:12.5px;color:var(--g700);line-height:1.5}
.notice-bar i{flex-shrink:0;width:15px;height:15px;margin-top:1px;color:var(--orange)}
.static-section{margin-bottom:32px}
.static-section h2{font-size:15px;font-weight:700;color:var(--g900);margin:0 0 10px;padding-bottom:8px;border-bottom:1px solid var(--g300)}
.static-section p{font-size:13.5px;color:var(--g700);line-height:1.75;margin:0 0 10px}
.static-section a{color:var(--red)}
.static-section a:hover{text-decoration:underline}
.about-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:12px}
@media(min-width:480px){.about-grid{grid-template-columns:1fr 1fr}}
@media(min-width:768px){.about-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}
.about-tile{display:flex;align-items:flex-start;gap:12px;padding:14px;border:1px solid var(--g300);background:#fff}
.about-tile i{flex-shrink:0;width:18px;height:18px;color:var(--red);margin-top:2px}
.about-tile strong{display:block;font-size:13px;font-weight:600;color:var(--g900);margin-bottom:3px}
.about-tile span{font-size:12px;color:var(--g500);line-height:1.5}
.tagline-display{font-size:clamp(14px,3vw,17px);font-weight:700;color:var(--red);border-left:3px solid var(--orange);padding-left:14px;margin:0}

/* FORM UTILITIES */
.form-label{display:block;font-size:.75rem;font-weight:700;color:var(--g700);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px}
.form-input,.form-select{width:100%;border:1px solid var(--g300);padding:10px 12px;font-size:.875rem;color:var(--g900);background:#fff;outline:none;min-height:44px}
.form-input:focus,.form-select:focus{border-color:var(--red)}
textarea.form-input{resize:vertical}
.card-box{background:#fff;border:1px solid var(--g200);padding:16px}
@media(min-width:768px){.card-box{padding:20px}}
.card-label{font-size:.72rem;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.06em}
.alert-success{background:#F1F8E9;border:1px solid #C5E1A5;color:#33691E;padding:12px 16px;font-size:.875rem}
.alert-error{background:#FFEBEE;border:1px solid #EF9A9A;color:#B71C1C;padding:12px 16px;font-size:.875rem}

/* RESPONSIVE UTILITIES */
.show-mobile{display:none!important}
.show-mobile-flex{display:none!important}
@media(max-width:1023px){.hide-desktop{display:none!important}}
@media(min-width:1024px){
  .hide-mobile{display:none!important}
  .show-mobile{display:block!important}
  .show-mobile-flex{display:flex!important}
}
.mob-full{width:100%!important;max-width:100%!important}
.stack-md{display:flex;flex-direction:column;gap:16px}
@media(min-width:768px){.stack-md{flex-direction:row}}
.stack-lg{display:flex;flex-direction:column;gap:16px}
@media(min-width:1024px){.stack-lg{flex-direction:row}}
.grid-auto{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:480px){.grid-auto{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}
.grid-auto-sm{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}


/* PLATFORM PAGINATION (bi-pagination)
   Used across all modules. Replaces Laravel default Tailwind/SVG arrows.
   Mobile-first. No SVGs. Text-based prev/next. */
.bi-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:4px;padding:20px 0 8px}
.bi-page{display:inline-flex;align-items:center;justify-content:center;min-width:34px;height:34px;padding:0 10px;font-size:13px;font-weight:600;color:var(--g900,#212121);text-decoration:none;border:1px solid var(--g200,#E0E0E0);background:#fff;transition:background 120ms,color 120ms,border-color 120ms;white-space:nowrap}
.bi-page:hover{background:var(--g100,#F5F5F5);border-color:var(--g400,#BDBDBD)}
.bi-page--active{background:var(--red,#B71C1C);border-color:var(--red,#B71C1C);color:#fff;cursor:default}
.bi-page--active:hover{background:var(--red,#B71C1C);color:#fff}
.bi-page--disabled{color:var(--g400,#BDBDBD);border-color:var(--g100,#F5F5F5);background:var(--g50,#FAFAFA);cursor:default}
.bi-page--dots{border:none;background:none;color:var(--g500,#9E9E9E);cursor:default;min-width:20px}

/* -- Contact form utilities (used in contact-form partial) -- */
.field-label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--g600);margin-bottom:5px}
.field-label .req{color:var(--red);font-weight:700}
.field-error{display:block;font-size:12px;color:var(--red);margin-top:4px}
.input--error,.textarea--error{border-color:var(--red) !important}
.notice-bar--green{background:var(--green-lt);border-left-color:var(--green);color:var(--green-d)}
.notice-bar--green i{color:var(--green)}
.notice-bar--red{background:var(--red-lt);border-left-color:var(--red);color:var(--red)}
.notice-bar--red i{color:var(--red)}
.contact-form-wrap{max-width:600px}
@media(max-width:540px){.contact-form-wrap .form-row{grid-template-columns:1fr !important}}
/* ============================================================
   SITE FOOTER — redesigned
   ============================================================ */
.site-footer{background:#0f0f0f;padding:48px 0 0;margin-top:8px;border-top:3px solid var(--red)}
.sf-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}

/* Grid: brand | explore | company */
.sf-grid{display:grid;grid-template-columns:1fr;gap:36px;margin-bottom:36px}
@media(min-width:640px){.sf-grid{grid-template-columns:1fr 1fr;gap:32px}}
@media(min-width:1024px){.sf-grid{grid-template-columns:260px 1fr 180px;gap:48px}}

/* Brand column */
.sf-logo-link{display:inline-block;margin-bottom:10px}
.sf-logo{height:44px;width:auto;display:block}
.sf-tagline{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--red);margin:0 0 8px}
.sf-blurb{font-size:12.5px;color:#777;line-height:1.65;margin:0 0 20px}

/* Social icons */
.sf-social{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.sf-soc{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:6px;background:#1a1a1a;color:#888;transition:background 150ms,color 150ms;flex-shrink:0}
.sf-soc:hover{color:#fff}
.sf-fb:hover{background:#1877f2}
.sf-x:hover{background:#1d1d1d;color:#e7e7e7}
.sf-ig:hover{background:radial-gradient(circle at 30% 107%,#fdf497 0,#fdf497 5%,#fd5949 45%,#d6249f 60%,#285aeb 90%);color:#fff}
.sf-wa:hover{background:#25d366}
.sf-yt:hover{background:#ff0000}

/* Contact */
.sf-contact{display:flex;flex-direction:column;gap:8px}
.sf-contact-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:#666;text-decoration:none;transition:color 150ms}
.sf-contact-row:hover{color:#fff}
.sf-contact-row svg{flex-shrink:0;color:#555}

/* Nav columns */
.sf-col-head{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:#444;margin:0 0 14px;padding-bottom:8px;border-bottom:1px solid #222}
.sf-links{display:flex;flex-direction:column;gap:9px}
.sf-links-2col{display:grid;grid-template-columns:1fr 1fr;gap:9px 20px}
.sf-links a{font-size:13px;color:#888;text-decoration:none;transition:color 150ms;line-height:1.3}
.sf-links a:hover{color:#fff}

/* Bottom bar */
.sf-bottom{border-top:1px solid #1e1e1e;padding:16px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap}
.sf-bottom>span:first-child{font-size:12px;color:#555;white-space:nowrap;flex-shrink:0}
.sf-disc{font-size:11px;color:#333;line-height:1.5;text-align:right}

/* Contact obfuscation — cf-link elements */
.cf-link{display:inline-flex;align-items:center;gap:6px;text-decoration:none;transition:color 150ms}
.cf-phone-text:empty::before{content:attr(data-p1) " " attr(data-p2);font-size:inherit}
.cf-email-text:empty::before{content:"[enable JavaScript to view]";font-size:inherit;opacity:.5}
