﻿/* ================================================================
   Apna Noida — Design System v3
   ================================================================ */

:root {
  --orange:      #f97316;
  --orange-d:    #ea580c;
  --orange-lt:   #fff7ed;
  --dark:        #0f172a;
  --dark-2:      #1e293b;
  --dark-3:      #334155;
  --text:        #0f172a;
  --text-2:      #1e293b;
  --sub:         #64748b;
  --muted:       #94a3b8;
  --bg:          #fffaf2;
  --surface:     #ffffff;
  --border:      #e2e8f0;
  --border-lt:   #f1f5f9;
  --radius-sm:   8px;
  --radius-md:   14px;
  --radius-lg:   20px;
  --radius-xl:   26px;
  --shadow-xs:   0 1px 4px rgba(15,23,42,0.06);
  --shadow-sm:   0 2px 10px rgba(15,23,42,0.07);
  --shadow-md:   0 8px 28px rgba(15,23,42,0.10);
  --shadow-lg:   0 20px 50px rgba(15,23,42,0.15);
  --shadow-xl:   0 32px 72px rgba(15,23,42,0.20);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
main { background:var(--bg); }
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }
button { font-family:inherit; }
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:#cbd5e1; border-radius:99px; }

/* Animations */
@keyframes fadeUp   { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:none} }
@keyframes scaleIn  { from{opacity:0;transform:scale(0.94)}      to{opacity:1;transform:none} }
@keyframes spin     { to{transform:rotate(360deg)} }
@keyframes shimmer  { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
@keyframes pulseGlow{ 0%,100%{opacity:.7} 50%{opacity:1} }
@keyframes popupIn  { from{opacity:0;transform:translateY(18px) scale(.98)} to{opacity:1;transform:none} }
.fade-up  { animation:fadeUp  0.5s cubic-bezier(.22,1,.36,1) both; }
.scale-in { animation:scaleIn 0.3s ease both; }

/* ================================================================
   HEADER
   ================================================================ */
.site-header {
  background:rgba(255,250,242,0.96);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:50;
  box-shadow:0 1px 0 rgba(0,0,0,0.04), 0 2px 8px rgba(0,0,0,0.04);
}
.header-inner {
  max-width:1280px; margin:0 auto; padding:0 24px;
  height:60px; display:flex; align-items:center;
  justify-content:space-between; gap:16px;
}
.logo-btn {
  display:flex; align-items:center;
  background:none; border:none; cursor:pointer; padding:0; text-decoration:none;
}
.logo-img {
  height:38px; width:auto; display:block;
  object-fit:contain;
  transition:opacity .2s;
}
.logo-btn:hover .logo-img { opacity:.85; }
/* fallback classes kept for backward compat */
.logo-icon { display:none; }
.logo-text { display:none; }
.logo-name { display:none; }
.logo-sub  { display:none; }

.site-nav { display:flex; align-items:center; gap:2px; }
.nav-link {
  display:flex; align-items:center; gap:6px; padding:7px 14px;
  border-radius:9px; border:none; background:none; cursor:pointer;
  color:var(--sub); font-size:13.5px; font-weight:600;
  transition:color .15s,background .15s; text-decoration:none; white-space:nowrap;
}
.nav-link:hover  { background:var(--bg); color:var(--text-2); }
.nav-link.active { background:var(--orange-lt); color:var(--orange-d); font-weight:700; }
.nav-add {
  display:flex; align-items:center; gap:7px; padding:8px 16px;
  border-radius:9px; border:none; margin-left:6px;
  background:linear-gradient(135deg,var(--orange),var(--orange-d));
  cursor:pointer; color:#fff; font-size:13.5px; font-weight:700;
  transition:opacity .15s,transform .15s; text-decoration:none;
  box-shadow:0 3px 12px rgba(234,88,12,0.3);
}
.nav-add:hover { opacity:.92; transform:translateY(-1px); }

.nav-mobile-btn {
  padding:8px; border-radius:9px; border:none; background:none;
  cursor:pointer; color:var(--sub); display:none;
  transition:background .15s;
}
.nav-mobile-btn:hover { background:var(--bg); }
.nav-mobile-btn svg { display:block; }

.mobile-menu {
  display:none; flex-direction:column; gap:2px;
  background:var(--bg); border-top:1px solid var(--border-lt);
  padding:8px 16px 14px;
}
.mobile-menu.open { display:flex; }
.mobile-link {
  display:block; padding:11px 14px; border-radius:9px;
  border:none; background:none; cursor:pointer;
  color:var(--dark-3); font-size:14px; font-weight:600;
  text-decoration:none; transition:background .13s;
}
.mobile-link:hover { background:var(--bg); }
.mobile-link.active { background:#f0fdf4; color:#15803d; font-weight:800; }
.mobile-link.orange {
  background:var(--orange-lt); color:var(--orange-d); font-weight:700;
  margin-top:4px;
}

@media(max-width:700px){
  .site-nav { display:none; }
  .nav-mobile-btn { display:flex; align-items:center; }
}

/* ================================================================
   HERO
   ================================================================ */
.landing-hero {
  position:relative; overflow:hidden; background:var(--dark); min-height:470px;
}
.hero-bg {
  position:absolute; inset:0;
  background-image:
    linear-gradient(103deg,rgba(2,6,23,0.94) 0%,rgba(15,23,42,0.80) 54%,rgba(15,23,42,0.58) 100%),
    image-set(
      url('/images/hero_section-960.webp') type('image/webp') 1x,
      url('/images/hero_section-1360.webp') type('image/webp') 2x,
      url('/images/hero_section-960.jpg') type('image/jpeg') 1x,
      url('/images/hero_section.png') type('image/png') 2x
    );
  background-size:cover; background-position:center 42%;
}
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(2,6,23,0.08),rgba(2,6,23,0.28));
}
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,transparent 68%,var(--bg) 100%);
}
.hero-inner {
  max-width:1200px; margin:0 auto; position:relative; padding:52px 24px 62px;
}
.hero-grid {
  display:grid; grid-template-columns:minmax(0,1fr) 340px; gap:30px;
  align-items:center;
}
.hero-content { max-width:760px; }
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  color:#fed7aa; font-size:11.5px; font-weight:800;
  background:rgba(249,115,22,0.16); border:1px solid rgba(253,186,116,0.3);
  padding:6px 14px; border-radius:99px; margin-bottom:20px;
  backdrop-filter:blur(8px); letter-spacing:.05em; text-transform:uppercase;
}
.hero-title {
  font-size:clamp(38px,5.5vw,64px); font-weight:900; color:#fff;
  line-height:.96; margin-bottom:16px; font-family:'Baloo 2',cursive;
  text-shadow:0 8px 32px rgba(0,0,0,0.44); letter-spacing:0;
}
.hero-desc {
  color:#cbd5e1; font-size:clamp(14px,1.7vw,17px);
  margin-bottom:22px; line-height:1.7; max-width:560px; font-weight:400;
}

/* Search */
.hero-search-panel {
  width:min(100%,760px); padding:14px; border-radius:20px;
  background:rgba(255,255,255,0.94); border:1px solid rgba(255,255,255,0.70);
  box-shadow:0 24px 60px rgba(0,0,0,0.30);
}
.hero-search-head {
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:2px 4px 12px;
}
.hero-search-head span {
  display:block; color:#f97316; font-size:10px; font-weight:900; letter-spacing:.08em;
  text-transform:uppercase; margin-bottom:3px;
}
.hero-search-head strong {
  display:block; color:#0f172a; font-size:14px; font-weight:900;
}
.hero-search-head a {
  flex:0 0 auto; color:#0f172a; background:#fff7ed; border:1px solid #fed7aa;
  border-radius:99px; padding:8px 12px; font-size:12px; font-weight:900;
}
.search-form {
  position:relative; max-width:100%; display:grid; grid-template-columns:minmax(220px,1fr) 170px auto; gap:8px;
}
.search-icon {
  position:absolute; left:18px; top:50%; transform:translateY(-50%);
  color:var(--muted); pointer-events:none; width:17px; height:17px;
}
.search-input {
  width:100%; height:54px; padding:0 16px 0 48px; border-radius:14px;
  background:#f8fafc; color:var(--text); font-size:14px; font-weight:600;
  border:1px solid #e2e8f0; outline:none; transition:border-color .2s,background .2s;
}
.search-input:focus { border-color:var(--orange); background:#fff; }
.search-input::placeholder { color:#94a3b8; }
.search-area-select {
  width:100%; height:54px; padding:0 14px; border-radius:14px;
  background:#f8fafc; color:var(--text); font-size:13px; font-weight:800;
  border:1px solid #e2e8f0; outline:none; cursor:pointer;
}
.search-area-select:focus { border-color:var(--orange); }
.search-btn {
  position:static; transform:none; min-width:108px; height:54px;
  background:linear-gradient(135deg,var(--orange),var(--orange-d));
  color:#fff; border:none; border-radius:14px; padding:0 22px;
  font-size:13.5px; font-weight:800; cursor:pointer;
  transition:opacity .15s,transform .15s;
}
.search-btn:hover { opacity:.92; transform:translateY(-1px); }

.quick-tags { display:flex; gap:8px; flex-wrap:wrap; margin-top:12px; }
.quick-tag {
  background:#f8fafc; border:1px solid #e2e8f0; color:#334155;
  border-radius:99px; padding:7px 13px; font-size:12px; font-weight:800;
  cursor:pointer; transition:background .15s,color .15s,border-color .15s;
}
.quick-tag:hover { background:#fff7ed; color:#c2410c; border-color:#fed7aa; }

.weekly-market-popup {
  position:fixed; right:24px; bottom:24px; z-index:120; width:min(430px,calc(100vw - 32px));
  display:block; overflow:hidden; border-radius:18px;
  background:#fff; border:1px solid rgba(226,232,240,.95); box-shadow:0 26px 70px rgba(15,23,42,.22);
  opacity:0; pointer-events:none;
}
.weekly-market-popup.show { animation:popupIn .28s ease both; pointer-events:auto; }
.weekly-market-popup[hidden] { display:none; }
.weekly-popup-close {
  position:absolute; top:10px; right:10px; z-index:2; width:30px; height:30px; border-radius:999px;
  display:grid; place-items:center; border:1px solid rgba(226,232,240,.9); background:rgba(255,255,255,.92);
  color:#475569; cursor:pointer;
}
.weekly-popup-close svg { width:15px; height:15px; }
.weekly-popup-media {
  display:block; aspect-ratio:701/561; max-height:190px; background:#07111f; border-bottom:1px solid #e2e8f0;
}
.weekly-popup-media img {
  width:100%; height:100%; object-fit:contain; object-position:center; background:#07111f;
}
.weekly-popup-body { padding:16px 16px 15px; min-width:0; }
.weekly-popup-kicker {
  color:#ea580c; font-size:10px; font-weight:900; letter-spacing:.08em; text-transform:uppercase; margin-bottom:5px;
}
.weekly-popup-body h2 { color:#0f172a; font-size:18px; line-height:1.15; margin:0 32px 7px 0; font-weight:900; }
.weekly-popup-body p { color:#64748b; font-size:12.5px; line-height:1.45; margin-bottom:13px; }
.weekly-popup-place {
  margin:8px 0 8px; padding:10px 12px; border-radius:12px; background:#f8fafc; border:1px solid #e2e8f0;
}
.weekly-popup-place span {
  display:block; color:#ea580c; font-size:10px; font-weight:900; letter-spacing:.08em; text-transform:uppercase; margin-bottom:3px;
}
.weekly-popup-place strong {
  display:block; color:#0f172a; font-size:13px; line-height:1.35; font-weight:900;
}
.weekly-popup-time {
  display:inline-flex; width:max-content; max-width:100%; margin-bottom:12px; padding:6px 10px;
  border-radius:999px; background:#fff7ed; color:#c2410c; border:1px solid #fed7aa;
  font-size:12px; font-weight:900;
}
.weekly-popup-actions { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.weekly-popup-primary,
.weekly-popup-secondary {
  border-radius:999px; padding:9px 12px; font-size:12px; font-weight:900; border:0; cursor:pointer;
}
.weekly-popup-primary { color:#fff; background:linear-gradient(135deg,#f97316,#ea580c); }
.weekly-popup-secondary { color:#475569; background:#f8fafc; border:1px solid #e2e8f0; }

.weather-card {
  width:100%; border:1px solid rgba(255,255,255,0.18); border-radius:20px;
  background:linear-gradient(160deg,rgba(15,23,42,0.86),rgba(30,41,59,0.70));
  color:#fff; padding:18px;
  box-shadow:0 24px 70px rgba(0,0,0,0.34);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
}
.weather-card-top {
  display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:14px;
}
.weather-label {
  color:#fed7aa; font-size:11px; font-weight:900; letter-spacing:.06em; text-transform:uppercase;
  margin-bottom:4px;
}
.weather-card h2 {
  color:#fff; font-family:'Baloo 2',cursive; font-size:28px; line-height:1; margin:0;
  letter-spacing:0;
}
.weather-status {
  flex:0 0 auto; border-radius:99px; padding:6px 10px; font-size:11px; font-weight:900;
  background:rgba(255,255,255,0.13); color:#e2e8f0; border:1px solid rgba(255,255,255,0.18);
}
.weather-status.online { color:#bbf7d0; background:rgba(22,163,74,0.18); border-color:rgba(134,239,172,0.26); }
.weather-status.offline { color:#fecaca; background:rgba(220,38,38,0.18); border-color:rgba(252,165,165,0.26); }
.weather-main {
  display:flex; align-items:center; gap:14px; padding:2px 0 14px;
  border-bottom:1px solid rgba(255,255,255,0.16);
}
.weather-symbol {
  width:62px; aspect-ratio:1; border-radius:16px; display:grid; place-items:center;
  background:linear-gradient(145deg,rgba(251,191,36,0.95),rgba(249,115,22,0.88));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.35),0 14px 36px rgba(249,115,22,0.26);
}
.weather-symbol span {
  width:27px; aspect-ratio:1; border-radius:50%; background:#fff7ed; display:block;
  box-shadow:0 0 0 9px rgba(255,247,237,0.20);
}
.weather-cloud,
.weather-fog,
.weather-cloud-sun { background:linear-gradient(145deg,#93c5fd,#64748b); }
.weather-rain,
.weather-showers,
.weather-drizzle,
.weather-storm { background:linear-gradient(145deg,#60a5fa,#1d4ed8); }
.weather-snow { background:linear-gradient(145deg,#e0f2fe,#94a3b8); }
.weather-temp {
  font-size:36px; font-weight:900; line-height:1; color:#fff; letter-spacing:0;
}
.weather-condition {
  color:#cbd5e1; font-size:13px; font-weight:700; margin-top:6px;
}
.weather-meta {
  display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:12px;
}
.weather-meta div {
  min-width:0; padding:10px; border-radius:12px; background:rgba(15,23,42,0.34);
  border:1px solid rgba(255,255,255,0.12);
}
.weather-meta span {
  display:block; color:#cbd5e1; font-size:11px; font-weight:700; margin-bottom:5px;
}
.weather-meta strong {
  display:block; color:#fff; font-size:14px; font-weight:900; line-height:1.25;
  overflow-wrap:anywhere;
}
.weather-meta div:last-child { grid-column:1/-1; }
.weather-foot {
  display:flex; justify-content:space-between; gap:12px; color:#cbd5e1;
  font-size:11.5px; font-weight:700; margin-top:12px; padding-top:12px;
  border-top:1px solid rgba(255,255,255,0.14);
}

/* ================================================================
   STATS BAR
   ================================================================ */
.stats-section { padding:28px 24px 4px; }
.stats-grid {
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:16px;
}
.stat-card {
  display:flex; align-items:center; gap:16px;
  background:var(--surface); border-radius:var(--radius-md); padding:20px 22px;
  border:1px solid var(--border); box-shadow:var(--shadow-sm);
  transition:transform .22s,box-shadow .22s;
}
.stat-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.stat-card-link { text-decoration:none; color:inherit; }
.stat-icon-box {
  width:48px; height:48px; border-radius:14px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.stat-icon-box svg { width:22px; height:22px; }
.stat-icon { font-size:24px; }
.stat-val { font-weight:900; font-size:24px; color:var(--text); line-height:1; }
.stat-lbl { font-size:12px; color:var(--muted); font-weight:500; margin-top:3px; }

/* ================================================================
   SECTION HEADS
   ================================================================ */
.section-head { display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:20px; flex-wrap:wrap; }
.section-eyebrow {
  font-size:11px; font-weight:800; color:var(--orange); text-transform:uppercase;
  letter-spacing:.1em; margin-bottom:6px;
}
.section-title { font-size:24px; font-weight:900; color:var(--dark); font-family:'Baloo 2',cursive; line-height:1.1; }
.section-sub   { color:var(--sub); font-size:13px; margin-top:5px; line-height:1.6; }

/* ================================================================
   SPOTLIGHT / FEATURES
   ================================================================ */
.spotlight-section { margin-bottom:52px; }
.spotlight-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; }
.spotlight-card {
  min-height:260px; border-radius:var(--radius-xl); overflow:hidden;
  position:relative; background-size:cover; background-position:center;
  background-color:#1e293b;
  box-shadow:var(--shadow-md); cursor:default;
  transition:transform .26s ease,box-shadow .26s ease;
}
.spotlight-card:hover { transform:translateY(-6px) scale(1.008); box-shadow:var(--shadow-xl); }
.spotlight-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(15,23,42,0.90),rgba(15,23,42,0.06));
  transition:opacity .26s;
}
.spotlight-card::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(249,115,22,0.18),transparent 50%);
}
.spotlight-body { position:absolute; left:20px; right:20px; bottom:20px; z-index:1; }
.spotlight-num {
  display:inline-flex; background:rgba(255,255,255,0.16); color:#fff;
  border:1px solid rgba(255,255,255,0.24); border-radius:99px;
  padding:4px 11px; font-size:11px; font-weight:800; margin-bottom:10px;
  backdrop-filter:blur(6px); letter-spacing:.04em;
}
.spotlight-card h3 { color:#fff; font-size:17px; font-weight:900; margin-bottom:7px; font-family:'Baloo 2',cursive; }
.spotlight-card p  { color:rgba(255,255,255,0.76); font-size:12.5px; line-height:1.6; }

/* ================================================================
   CATEGORY CARDS
   ================================================================ */
.cats-head { margin-bottom:20px; }
.cats-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:18px; margin-bottom:56px;
}
.cat-card {
  border:none; border-radius:var(--radius-xl); padding:0; cursor:pointer;
  overflow:hidden; position:relative; min-height:258px; width:100%;
  background-size:cover; background-position:center;
  background-color:#1e293b;
  box-shadow:var(--shadow-md);
  transition:transform .24s ease,box-shadow .24s ease;
  display:block; text-decoration:none;
}
.cat-card:hover { transform:translateY(-7px) scale(1.012); box-shadow:var(--shadow-xl); }
.cat-card-overlay2 {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(15,23,42,0.95) 0%,rgba(15,23,42,0.60) 48%,rgba(15,23,42,0.10) 100%);
  transition:opacity .24s;
}
.cat-card:hover .cat-card-overlay2 { opacity:.88; }
.cat-card-inner {
  position:relative; min-height:258px; padding:18px;
  display:flex; flex-direction:column; justify-content:space-between;
}
.cat-card-top { display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.cat-card-icon {
  width:50px; height:50px; border-radius:14px;
  background:rgba(255,255,255,0.92); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  font-size:24px; box-shadow:0 8px 24px rgba(0,0,0,0.22);
  flex-shrink:0; transition:transform .22s;
}
.cat-card:hover .cat-card-icon { transform:scale(1.1); }
.cat-card-count {
  background:rgba(255,255,255,0.16); color:#fff; font-size:12px; font-weight:800;
  padding:6px 12px; border-radius:99px;
  border:1px solid rgba(255,255,255,0.22); backdrop-filter:blur(8px); white-space:nowrap;
}
.cat-card-label { color:rgba(255,255,255,0.68); font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; margin-bottom:5px; }
.cat-card-name  { color:#fff; font-size:22px; font-weight:900; line-height:1.05; margin-bottom:8px; font-family:'Baloo 2',cursive; text-shadow:0 2px 16px rgba(0,0,0,0.38); }
.cat-card-desc  { color:rgba(255,255,255,0.72); font-size:12px; margin-bottom:14px; line-height:1.5; }
.cat-card-btn {
  background:rgba(255,255,255,0.14); color:#fff; font-size:12px; font-weight:800;
  padding:8px 14px; border-radius:10px;
  display:inline-flex; align-items:center; gap:6px;
  border:1px solid rgba(255,255,255,0.22); backdrop-filter:blur(8px);
  transition:background .22s;
}
.cat-card:hover .cat-card-btn { background:rgba(249,115,22,0.75); }

/* ================================================================
   LATEST SECTION
   ================================================================ */
.latest-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.latest-title { font-size:20px; font-weight:900; color:var(--dark); font-family:'Baloo 2',cursive; }
.view-all-btn {
  display:inline-flex; align-items:center; gap:5px;
  color:var(--orange); font-size:13px; font-weight:700;
  background:var(--orange-lt); border:none; cursor:pointer; text-decoration:none;
  padding:7px 14px; border-radius:9px; transition:background .15s;
}
.view-all-btn:hover { background:#fee2c4; }

/* ================================================================
   ENTERPRISE CARD
   ================================================================ */
.ent-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }

.ent-card {
  background:var(--surface); border-radius:var(--radius-lg); border:1px solid var(--border);
  overflow:hidden; display:flex; flex-direction:column;
  box-shadow:var(--shadow-xs);
  transition:transform .24s cubic-bezier(.22,1,.36,1),box-shadow .24s ease;
}
.ent-card:hover { transform:translateY(-5px); box-shadow:0 18px 50px rgba(15,23,42,0.13); }

.ent-bar { height:3px; flex-shrink:0; }

.ent-image {
  height:148px; position:relative;
  background-size:cover; background-position:center; flex-shrink:0; overflow:hidden;
  background-color:#e2e8f0;
}
.ent-image::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(15,23,42,0.55),rgba(15,23,42,0.0));
}
.ent-image-overlay { display:none; }
.ent-image-badges { position:absolute; left:14px; bottom:13px; display:flex; align-items:center; gap:8px; z-index:1; }
.ent-cat-icon {
  width:36px; height:36px; border-radius:10px;
  background:rgba(255,255,255,0.94); backdrop-filter:blur(6px);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; box-shadow:0 6px 18px rgba(0,0,0,0.22);
  transition:transform .2s;
}
.ent-card:hover .ent-cat-icon { transform:scale(1.08); }
.ent-cat-badge {
  background:rgba(15,23,42,0.68); color:#fff;
  border:1px solid rgba(255,255,255,0.18); border-radius:99px;
  padding:4px 10px; font-size:10.5px; font-weight:700;
  backdrop-filter:blur(8px);
}
.ent-verified-badge {
  background:rgba(22,163,74,0.92); color:#fff;
  border:1px solid rgba(187,247,208,0.8); border-radius:99px;
  padding:4px 10px; font-size:10.5px; font-weight:900;
  backdrop-filter:blur(8px);
}

.ent-body { padding:16px 18px; flex:1; display:flex; flex-direction:column; gap:8px; }
.ent-name-row { display:flex; align-items:flex-start; justify-content:space-between; gap:8px; }
.ent-name     { font-weight:800; font-size:14px; color:var(--text); line-height:1.35; flex:1; }
.ent-badge    { font-size:10px; font-weight:700; padding:3px 8px; border-radius:99px; white-space:nowrap; flex-shrink:0; }
.ent-badge-verified { background:#f0fdf4; color:#15803d; border:1px solid #bbf7d0; }

.ent-meta     { display:flex; align-items:flex-start; gap:7px; }
.ent-meta-ico { color:var(--muted); margin-top:2px; flex-shrink:0; width:13px; height:13px; }
.ent-meta-txt { font-size:12px; color:var(--sub); line-height:1.4; }
.ent-meta-orange { color:var(--orange); }

.ent-footer-row {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:10px; border-top:1px solid var(--border-lt);
  font-size:11px; color:var(--muted); gap:8px;
}
.ent-footer-loc { display:flex; align-items:center; gap:5px; }
.ent-footer-loc svg { width:11px; height:11px; flex-shrink:0; color:var(--muted); }
.ent-footer-date { display:flex; align-items:center; gap:5px; white-space:nowrap; }
.ent-footer-date svg { width:11px; height:11px; flex-shrink:0; }

.ent-view-btn {
  display:flex; align-items:center; justify-content:center; gap:6px;
  margin:4px 18px 0; padding:9px 0; border-radius:10px;
  font-size:13px; font-weight:700; cursor:pointer;
  transition:all .18s; border-width:1.5px; border-style:solid;
  text-decoration:none;
}
.ent-actions { padding:8px 18px 16px; display:flex; gap:8px; }
.ent-inquiry-btn {
  flex:1; display:flex; align-items:center; justify-content:center; gap:7px;
  padding:9px 0; border-radius:10px;
  color:#fff; border:none; font-size:13px; font-weight:700; cursor:pointer;
  transition:opacity .15s,transform .15s;
}
.ent-inquiry-btn:hover { opacity:.88; transform:translateY(-1px); }
.ent-wa-btn {
  display:flex; align-items:center; justify-content:center;
  padding:9px 13px; border-radius:10px;
  background:#25D366; color:#fff; border:none; cursor:pointer;
  transition:opacity .15s,transform .15s; flex-shrink:0;
}
.ent-wa-btn:hover { opacity:.88; transform:translateY(-1px); }

/* ================================================================
   CATEGORY PAGE HERO
   ================================================================ */
.cat-page-hero { padding:36px 24px; position:relative; overflow:hidden; background:var(--dark); }
.cat-page-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.cat-hero-inner {
  max-width:1280px; margin:0 auto; position:relative;
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}
.cat-hero-back {
  display:flex; align-items:center; gap:6px;
  background:rgba(255,255,255,0.14); border:1px solid rgba(255,255,255,0.26);
  color:#fff; border-radius:11px; padding:9px 16px;
  font-size:13px; font-weight:700; backdrop-filter:blur(8px);
  flex-shrink:0; text-decoration:none; transition:background .15s;
}
.cat-hero-back:hover { background:rgba(255,255,255,0.24); }
.cat-hero-icon {
  width:54px; height:54px; border-radius:16px;
  background:rgba(255,255,255,0.92); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  font-size:26px; box-shadow:0 12px 30px rgba(0,0,0,0.24);
}
.cat-hero-count {
  margin-left:auto; background:rgba(255,255,255,0.14);
  backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,0.24);
  border-radius:14px; padding:12px 20px; text-align:center;
}

/* ================================================================
   SEARCH BANNER
   ================================================================ */
.search-banner { background:linear-gradient(135deg,#1a2744,#1e293b); padding:26px 24px; }
.verified-banner { background:linear-gradient(135deg,#14532d,#166534); }
.search-banner-inner {
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
}

/* ================================================================
   LIST WRAP
   ================================================================ */
.ent-list-wrap { max-width:1280px; margin:0 auto; padding:28px 24px 52px; }

/* ================================================================
   BUSINESS DETAIL
   ================================================================ */
.biz-hero { position:relative; min-height:300px; overflow:hidden; background:#111827; }
.biz-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; }
.biz-hero-inner { position:relative; max-width:1240px; margin:0 auto; padding:36px 24px 48px; }
.back-btn {
  display:inline-flex; align-items:center; gap:6px; min-height:38px;
  border:1px solid rgba(255,255,255,0.22); background:rgba(255,255,255,0.10);
  color:#fff; border-radius:10px; padding:0 15px;
  font-size:13px; font-weight:700; cursor:pointer; text-decoration:none;
  margin-bottom:28px; transition:background .15s; backdrop-filter:blur(8px);
}
.back-btn:hover { background:rgba(255,255,255,0.20); }
.biz-hero h1 {
  color:#fff; font-size:clamp(28px,4.5vw,54px);
  line-height:1.02; font-weight:950; font-family:'Baloo 2',cursive;
  max-width:880px; text-shadow:0 10px 30px rgba(0,0,0,0.38); margin-bottom:18px;
}
.biz-hero-tags { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px; }
.biz-hero-tag {
  background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.20);
  color:#fff; border-radius:99px; padding:6px 14px; font-size:12px; font-weight:700; backdrop-filter:blur(8px);
}
.biz-hero-tag-verified {
  background:rgba(22,163,74,0.88); border:1px solid rgba(187,247,208,0.7);
  color:#fff; border-radius:99px; padding:6px 14px; font-size:12px; font-weight:900; backdrop-filter:blur(8px);
}
.biz-hero-tag-orange { background:rgba(249,115,22,0.85); color:#fff; border-radius:99px; padding:6px 14px; font-size:12px; font-weight:800; }
.biz-meta-tag {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(255,255,255,0.12); color:#fff;
  border:1px solid rgba(255,255,255,0.18); border-radius:99px;
  padding:8px 14px; font-size:13px; font-weight:700; backdrop-filter:blur(8px);
}
.biz-grid {
  display:grid; grid-template-columns:minmax(0,1fr) 370px;
  gap:24px; max-width:1240px; margin:30px auto 60px; padding:0 24px;
}
.panel {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; box-shadow:var(--shadow-xs);
  transition:box-shadow .2s;
}
.panel:hover { box-shadow:var(--shadow-md); }
.panel-bar { height:3px; }
.panel-body { padding:20px 22px; }
.panel-section-title {
  display:flex; align-items:center; gap:9px;
  color:var(--muted); font-size:11px; font-weight:800;
  text-transform:uppercase; letter-spacing:.09em; margin-bottom:14px;
}
.activity-item {
  display:grid; grid-template-columns:64px 1fr; gap:14px;
  align-items:start; padding:14px; border:1px solid var(--border);
  border-radius:12px; background:var(--bg); margin-bottom:10px;
}
.activity-nic {
  color:var(--orange-d); background:var(--orange-lt); border:1px solid #fed7aa;
  border-radius:10px; padding:8px; font-size:12px; font-weight:900; text-align:center;
}
.activity-desc { color:var(--text); font-size:15px; line-height:1.6; font-weight:700; }
.biz-gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:10px; }
.biz-gallery-item {
  min-height:118px; border-radius:12px; background:#e2e8f0 center/cover no-repeat;
  border:1px solid var(--border); position:relative; overflow:hidden; text-decoration:none;
  box-shadow:var(--shadow-xs); transition:transform .18s,box-shadow .18s;
}
.biz-gallery-item:hover { transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.biz-gallery-item span {
  position:absolute; left:9px; top:9px; background:rgba(15,23,42,.76); color:#fff;
  border-radius:99px; padding:4px 9px; font-size:10px; font-weight:900;
}
.facts-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.fact-card {
  background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:18px;
  transition:transform .2s,box-shadow .2s;
}
.fact-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.fact-label { color:var(--muted); font-size:10px; font-weight:900; text-transform:uppercase; letter-spacing:.07em; margin-bottom:8px; }
.fact-val   { color:#172033; font-size:16px; font-weight:900; word-break:break-word; }
.aside-card-image { height:190px; background-size:cover; background-position:center; }
.aside-meta-row { display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.aside-cat-icon { width:44px; height:44px; border-radius:12px; background:var(--orange-lt); display:grid; place-items:center; font-size:22px; }
.aside-btn {
  height:46px; display:flex; align-items:center; justify-content:center; gap:8px;
  border-radius:12px; font-size:14px; font-weight:800; text-decoration:none; cursor:pointer; border:none;
  margin-bottom:10px; width:100%; transition:opacity .15s,transform .15s;
}
.aside-btn:hover { opacity:.88; transform:translateY(-1px); }
.aside-btn-dark  { background:var(--dark); color:#fff; }
.aside-btn-green { background:#25D366; color:#fff; }
.aside-btn-share { background:#fff7ed; color:#c2410c; border:1px solid #fed7aa; }
.share-status {
  display:none; margin-top:2px; padding:9px 11px; border-radius:10px;
  background:#f0fdf4; border:1px solid #bbf7d0; color:#15803d;
  font-size:12px; font-weight:800; line-height:1.35;
}
.share-status.show { display:block; }
.share-status.error { background:#fef2f2; border-color:#fecaca; color:#b91c1c; }

/* ================================================================
   INQUIRY FORM
   ================================================================ */
.inquiry-panel {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:22px; box-shadow:var(--shadow-md);
}
.inquiry-title { font-size:17px; font-weight:950; color:#172033; margin-bottom:18px; }
.form-group    { margin-bottom:13px; }
.form-label    { display:block; color:var(--sub); font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; margin-bottom:5px; }
.form-input,.form-textarea {
  width:100%; border:1.5px solid #dbe3ef; border-radius:10px;
  background:var(--surface); color:#172033; padding:0 13px;
  outline:none; font-size:14px; font-family:inherit;
  transition:border-color .15s,box-shadow .15s;
}
.form-input   { height:44px; }
.form-textarea { height:90px; padding-top:11px; resize:vertical; }
.form-input:focus,.form-textarea:focus {
  border-color:var(--orange);
  box-shadow:0 0 0 3px rgba(249,115,22,0.11);
}
.submit-btn {
  width:100%; height:46px; border:none; border-radius:12px;
  background:linear-gradient(135deg,var(--orange),var(--orange-d));
  color:#fff; font-size:14px; font-weight:800; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:8px;
  box-shadow:0 8px 22px rgba(234,88,12,0.26); transition:opacity .15s,transform .15s;
}
.submit-btn:hover { opacity:.92; transform:translateY(-1px); }
.submit-btn:disabled { opacity:.65; cursor:not-allowed; transform:none; }
.form-success {
  background:#f0fdf4; color:#15803d; border:1px solid #bbf7d0;
  border-radius:10px; padding:11px 13px; font-size:13px; font-weight:700;
  margin-top:10px; display:none;
}
.form-error {
  background:#fef2f2; color:#b91c1c; border:1px solid #fecaca;
  border-radius:10px; padding:11px 13px; font-size:13px; font-weight:700;
  margin-top:10px; display:none;
}
.form-success.show,.form-error.show { display:block; animation:fadeUp .3s ease; }

/* ================================================================
   GALLERY
   ================================================================ */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:16px; }
.gallery-item {
  border-radius:16px; overflow:hidden; background:var(--border-lt);
  aspect-ratio:4/3; cursor:pointer; position:relative;
  box-shadow:var(--shadow-sm); transition:transform .22s,box-shadow .22s;
}
.gallery-item:hover { transform:scale(1.02); box-shadow:var(--shadow-md); }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform .3s ease; }
.gallery-item:hover img { transform:scale(1.05); }
.gallery-caption { padding:8px 10px; font-size:12px; color:var(--sub); font-weight:600; }
.lightbox { display:none; position:fixed; inset:0; background:rgba(0,0,0,.9); z-index:1000; align-items:center; justify-content:center; padding:1rem; backdrop-filter:blur(8px); }
.lightbox.open { display:flex; }
.lightbox img { max-width:90vw; max-height:85vh; border-radius:18px; box-shadow:0 30px 80px rgba(0,0,0,0.5); }
.lightbox-close { position:absolute; top:1rem; right:1.5rem; font-size:2.2rem; color:#fff; cursor:pointer; background:rgba(255,255,255,0.12); border:none; line-height:1; width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; }

/* ================================================================
   LISTING REQUEST PAGE
   ================================================================ */
.listing-hero { position:relative; overflow:hidden; background:var(--dark); }
.listing-hero-bg {
  position:absolute; inset:0;
  background-image:
    linear-gradient(100deg,rgba(15,23,42,0.97),rgba(15,23,42,0.72)),
    image-set(
      url('/images/hero_section-960.webp') type('image/webp') 1x,
      url('/images/hero_section-1360.webp') type('image/webp') 2x,
      url('/images/hero_section-960.jpg') type('image/jpeg') 1x,
      url('/images/hero_section.png') type('image/png') 2x
    );
  background-size:cover; background-position:center;
}
.listing-hero-inner { max-width:1180px; margin:0 auto; padding:38px 24px 46px; position:relative; }
.listing-form-grid {
  display:grid; grid-template-columns:minmax(0,0.9fr) minmax(0,1.1fr);
  gap:22px; max-width:1180px; margin:30px auto 64px; padding:0 24px;
}
.form-panel {
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:24px; box-shadow:var(--shadow-sm);
}
.form-panel-title { display:flex; align-items:center; gap:10px; margin-bottom:20px; }
.form-panel-icon {
  width:40px; height:40px; border-radius:12px; background:var(--orange-lt);
  color:var(--orange-d); display:grid; place-items:center; flex-shrink:0; font-size:18px;
}
.form-panel h2 { color:#172033; font-size:17px; font-weight:950; }
.field-label { color:var(--sub); font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; display:block; margin-bottom:5px; }
.field-error  { color:#dc2626; font-size:11px; font-weight:700; margin-top:4px; display:block; }
.field-input,.field-select,.field-textarea {
  width:100%; height:44px; border:1.5px solid #dbe3ef; border-radius:10px;
  background:var(--surface); color:#172033; padding:0 13px;
  font-size:14px; font-family:inherit; outline:none;
  transition:border-color .15s,box-shadow .15s;
}
.field-input:focus,.field-select:focus,.field-textarea:focus {
  border-color:var(--orange); box-shadow:0 0 0 3px rgba(249,115,22,0.11);
}
.field-textarea { height:auto; padding-top:11px; resize:vertical; }
.upload-box {
  min-height:46px; border:1.5px dashed #fdba74; border-radius:12px;
  background:var(--orange-lt); color:var(--orange-d); font-size:13px; font-weight:800;
  display:flex; align-items:center; justify-content:center; gap:8px;
  cursor:pointer; padding:0 16px; transition:background .15s;
}
.upload-box:hover { background:#fee2c4; }
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.img-preview { height:130px; border-radius:14px; background-size:cover; background-position:center; border:1px solid var(--border); }
.orange-btn {
  min-height:46px; border:none; border-radius:12px;
  background:linear-gradient(135deg,var(--orange),var(--orange-d));
  color:#fff; font-size:14px; font-weight:800;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  cursor:pointer; padding:0 20px; width:100%;
  box-shadow:0 8px 22px rgba(234,88,12,0.24); transition:opacity .15s,transform .15s;
}
.orange-btn:hover { opacity:.92; transform:translateY(-1px); }
.orange-btn:disabled { opacity:.7; cursor:not-allowed; transform:none; }
.secondary-btn {
  min-height:46px; border:1.5px solid #fed7aa; border-radius:12px;
  background:var(--orange-lt); color:var(--orange-d); font-size:14px; font-weight:800;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  cursor:pointer; padding:0 20px; transition:background .15s;
}
.secondary-btn:hover { background:#fee2c4; }

/* ================================================================
   ABOUT PAGE
   ================================================================ */
.about-hero-section {
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,#1e40af 0%,#2563eb 50%,#3b82f6 100%);
  padding:3.5rem 1.25rem; text-align:center; color:#fff;
}
.about-wrap { max-width:800px; margin:2rem auto; padding:0 1.25rem 3rem; }
.about-wrap h2 { font-size:1.2rem; font-weight:800; margin:1.75rem 0 .6rem; color:var(--text); }
.about-wrap p  { color:var(--sub); line-height:1.8; margin-bottom:.75rem; }

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer { background:#0f172a; color:#64748b; margin-top:auto; }
.footer-top {
  max-width:1280px; margin:0 auto; padding:60px 24px 52px;
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr 1fr; gap:36px;
}
.footer-logo {
  display:flex; align-items:center; gap:11px;
  text-decoration:none; margin-bottom:18px;
  width:max-content;
  background:#fff;
  border-radius:12px;
  padding:8px 12px;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
}
.footer-logo-img {
  height:42px; width:auto; display:block;
  max-width:230px;
  object-fit:contain;
  opacity:1;
  transition:opacity .2s;
}
.footer-logo:hover .footer-logo-img { opacity:1; }
/* fallback */
.footer-logo-icon,.footer-logo-name,.footer-logo-sub { display:none; }
.footer-tagline {
  font-size:13px; line-height:1.8; color:#64748b; margin-bottom:22px; max-width:320px;
}
.footer-cta {
  display:inline-flex; align-items:center; padding:10px 20px; border-radius:10px;
  background:rgba(249,115,22,0.12); border:1px solid rgba(249,115,22,0.28);
  color:#fb923c; font-size:13px; font-weight:700; text-decoration:none;
  transition:background .15s,color .15s;
}
.footer-cta:hover { background:rgba(249,115,22,0.22); color:#fdba74; }
.footer-col-title {
  color:#fff; font-size:11.5px; font-weight:800; text-transform:uppercase;
  letter-spacing:.09em; margin-bottom:14px; padding-bottom:10px;
  border-bottom:1px solid #1e293b;
}
.footer-link {
  display:block; color:#64748b; font-size:13px; font-weight:500;
  text-decoration:none; padding:5px 0; transition:color .15s;
}
.footer-link:hover { color:#e2e8f0; }
.footer-bottom { border-top:1px solid #1e293b; padding:18px 24px; }
.footer-bottom-inner {
  max-width:1280px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:8px;
}
.footer-copy { font-size:12px; color:#475569; }

/* ================================================================
   FAB
   ================================================================ */
.fab {
  position:fixed; right:24px; bottom:24px; z-index:80;
  display:flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--orange),var(--orange-d));
  color:#fff; border:none; border-radius:999px;
  padding:13px 20px; font-size:14px; font-weight:800; cursor:pointer;
  box-shadow:0 10px 30px rgba(234,88,12,0.38),0 4px 10px rgba(234,88,12,0.26);
  text-decoration:none; transition:box-shadow .2s,transform .2s;
}
.fab:hover { box-shadow:0 16px 42px rgba(234,88,12,0.48); transform:translateY(-2px) scale(1.03); }

/* ================================================================
   EMPTY / LOADING
   ================================================================ */
.loading-wrap { text-align:center; padding:80px 0; }
.spinner { width:40px; height:40px; border:4px solid var(--border); border-top-color:var(--orange); border-radius:50%; animation:spin .8s linear infinite; margin:0 auto 14px; }
.empty-state { text-align:center; padding:68px 20px; }
.empty-state .empty-icon { margin-bottom:14px; }
.empty-state p { color:var(--sub); font-size:14px; }

/* ================================================================
   MAIN CONTAINER
   ================================================================ */
.main-wrap { max-width:1280px; margin:0 auto; padding:32px 24px 40px; }

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1100px){
  .stats-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .biz-grid { grid-template-columns:minmax(0,1fr) 330px; }
}
@media(max-width:960px){
  .footer-top { grid-template-columns:1fr 1fr 1fr; gap:28px; }
  .footer-brand { grid-column:1/-1; }
  .spotlight-grid { grid-template-columns:1fr 1fr !important; }
  .biz-grid { grid-template-columns:1fr !important; }
  .listing-form-grid { grid-template-columns:1fr !important; }
  .facts-grid { grid-template-columns:1fr 1fr !important; }
  .landing-hero { min-height:0; }
  .hero-grid { grid-template-columns:1fr; gap:26px; }
  .weather-card { max-width:680px; }
}
@media(max-width:720px){
  .landing-hero { min-height:0; }
  .hero-inner { padding:42px 20px 46px; }
  .hero-search-panel { padding:12px; border-radius:18px; }
  .hero-search-head { align-items:flex-start; }
  .hero-search-head a { padding:7px 10px; }
  .search-form { grid-template-columns:1fr; max-width:100%; }
  .search-icon { top:29px; transform:translateY(-50%); }
  .search-input,.search-area-select,.search-btn { height:54px; }
  .weather-card { padding:18px; border-radius:16px; }
  .weather-main { align-items:flex-start; }
  .weather-symbol { width:66px; border-radius:16px; }
  .weather-temp { font-size:34px; }
  .weather-meta div { padding:10px 12px; }
  .stats-grid { grid-template-columns:1fr !important; }
  .spotlight-grid { grid-template-columns:1fr !important; }
  .ent-grid { grid-template-columns:1fr 1fr; }
  .cats-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .header-inner { padding:0 16px; }
  .main-wrap { padding:24px 16px 32px; }
}
@media(max-width:560px){
  .ent-grid { grid-template-columns:1fr; }
  .cats-grid { grid-template-columns:1fr 1fr; }
  .two-col { grid-template-columns:1fr !important; }
  .facts-grid { grid-template-columns:1fr !important; }
  .listing-form-grid,.biz-grid { grid-template-columns:1fr !important; }
  .footer-top { grid-template-columns:1fr 1fr; padding:40px 20px 32px; gap:28px; }
  .footer-brand { grid-column:1/-1; }
  .footer-bottom-inner { flex-direction:column; align-items:flex-start; gap:4px; }
  .fab { right:16px; bottom:16px; padding:11px 17px; font-size:13px; }
  .hero-inner { padding:34px 16px 42px; }
  .search-input { font-size:13px; }
  .search-btn { padding:10px 14px; font-size:12px; }
  .weather-meta { grid-template-columns:1fr 1fr; gap:8px; }
  .weather-foot { flex-direction:column; gap:6px; }
}
@media(max-width:420px){
  .cats-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr; }
}

/* ================================================================
   FAB GROUP (expanded)
   ================================================================ */
.fab-group { position:fixed; right:24px; bottom:24px; z-index:80; display:flex; flex-direction:column; align-items:flex-end; gap:10px; }
.fab-menu { display:flex; flex-direction:column; gap:8px; align-items:flex-end; }
.fab-menu-item {
  display:flex; align-items:center; gap:10px;
  background:#fff; border:1px solid var(--border);
  border-radius:14px; padding:11px 16px;
  font-size:13.5px; font-weight:700; color:var(--text);
  text-decoration:none; white-space:nowrap;
  box-shadow:0 6px 20px rgba(15,23,42,0.14);
  transition:transform .18s, box-shadow .18s;
  animation:fadeUp .18s ease both;
}
.fab-menu-item:hover { transform:translateX(-3px); box-shadow:0 10px 30px rgba(15,23,42,0.18); }
.fab-menu-icon { font-size:18px; }
@media(max-width:560px){
  .fab-group { right:16px; bottom:16px; }
  .fab-menu-item { font-size:13px; padding:10px 14px; }
}

/* ================================================================
   WORKERS & PROFESSIONALS — public pages
   ================================================================ */

/* Filter pill tabs */
.filter-tabs {
  display:flex; gap:8px; flex-wrap:wrap; align-items:center;
}
.filter-tab {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:999px;
  border:1.5px solid var(--border); background:var(--surface);
  color:var(--sub); font-size:13px; font-weight:600; cursor:pointer;
  transition:all .18s; white-space:nowrap; line-height:1;
}
.filter-tab:hover { border-color:var(--orange); color:var(--orange-d); background:var(--orange-lt); }
.filter-tab.active {
  background:linear-gradient(135deg,var(--orange),var(--orange-d));
  border-color:var(--orange-d); color:#fff; font-weight:700;
  box-shadow:0 4px 14px rgba(234,88,12,0.30);
}

/* Worker card grid */
.worker-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(270px,1fr));
  gap:20px;
}

/* Worker card */
.worker-card {
  background:var(--surface); border-radius:var(--radius-lg);
  border:1px solid var(--border); overflow:hidden;
  box-shadow:var(--shadow-xs);
  display:flex; flex-direction:column;
  transition:transform .24s cubic-bezier(.22,1,.36,1), box-shadow .24s ease;
  cursor:pointer; text-decoration:none; color:inherit;
}
.worker-card:hover { transform:translateY(-5px); box-shadow:0 18px 50px rgba(15,23,42,0.13); }

.worker-card-img-wrap {
  height:160px; overflow:hidden; position:relative; flex-shrink:0;
  background:linear-gradient(135deg,#f1f5f9,#e2e8f0);
}
.worker-card-img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .3s ease;
}
.worker-card:hover .worker-card-img { transform:scale(1.05); }
.worker-card-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  font-size:56px;
}

.worker-cat-pill {
  position:absolute; top:12px; left:12px;
  background:rgba(15,23,42,0.72); color:#fff;
  border:1px solid rgba(255,255,255,0.18);
  border-radius:99px; padding:4px 11px;
  font-size:10.5px; font-weight:700; backdrop-filter:blur(8px);
}
.worker-verified-pill {
  position:absolute; top:12px; right:12px;
  background:rgba(22,163,74,0.90); color:#fff;
  border:1px solid rgba(187,247,208,0.6);
  border-radius:99px; padding:4px 10px;
  font-size:10.5px; font-weight:800; backdrop-filter:blur(8px);
}

.worker-card-body {
  padding:16px 18px; flex:1; display:flex; flex-direction:column; gap:6px;
}
.worker-card-name {
  font-weight:800; font-size:15px; color:var(--text); line-height:1.3;
}
.worker-card-spec {
  font-size:12.5px; color:var(--sub); line-height:1.45;
}
.worker-card-meta {
  display:flex; flex-wrap:wrap; gap:8px; margin-top:4px;
}
.worker-meta-chip {
  display:inline-flex; align-items:center; gap:4px;
  font-size:11.5px; color:var(--sub); font-weight:500;
}

.worker-card-actions {
  display:flex; gap:8px; padding:10px 18px 16px;
}
.worker-call-btn {
  flex:1; display:flex; align-items:center; justify-content:center; gap:6px;
  padding:9px 0; border-radius:10px;
  background:#15803d; color:#fff; border:none;
  font-size:13px; font-weight:700; cursor:pointer; text-decoration:none;
  transition:opacity .15s,transform .15s;
}
.worker-call-btn:hover { opacity:.9; transform:translateY(-1px); }
.worker-wa-btn {
  flex:1; display:flex; align-items:center; justify-content:center; gap:6px;
  padding:9px 0; border-radius:10px;
  background:#25d366; color:#fff; border:none;
  font-size:13px; font-weight:700; cursor:pointer; text-decoration:none;
  transition:opacity .15s,transform .15s;
}
.worker-wa-btn:hover { opacity:.9; transform:translateY(-1px); }

/* Category banner on workers hero */
.workers-hero-cats {
  display:flex; gap:8px; flex-wrap:wrap; margin-top:20px;
}
.workers-hero-cat {
  display:inline-flex; align-items:center; gap:5px;
  background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.20);
  color:#e2e8f0; border-radius:99px; padding:6px 14px;
  font-size:12px; font-weight:600; backdrop-filter:blur(8px);
  transition:background .15s, color .15s;
}
.workers-hero-cat:hover { background:rgba(249,115,22,0.28); color:#fff; cursor:pointer; }

/* Worker detail page */
.worker-detail-wrap { max-width:840px; margin:40px auto; padding:0 20px 60px; }
.worker-detail-card {
  background:var(--surface); border-radius:var(--radius-xl);
  box-shadow:var(--shadow-md); overflow:hidden;
}
.worker-detail-img { width:100%; max-height:300px; object-fit:cover; display:block; }
.worker-detail-placeholder {
  width:100%; height:200px; background:linear-gradient(135deg,#f1f5f9,#e2e8f0);
  display:flex; align-items:center; justify-content:center; font-size:80px;
}
.worker-detail-body { padding:28px 32px; }
.worker-info-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:14px; margin:20px 0;
}
.worker-info-chip {
  background:var(--bg); border-radius:12px; padding:14px 16px;
  border:1px solid var(--border);
}
.worker-info-chip-label {
  font-size:10px; color:var(--muted); font-weight:800;
  text-transform:uppercase; letter-spacing:.07em; margin-bottom:5px;
}
.worker-info-chip-val { font-weight:800; color:var(--text); font-size:14px; }

/* Homepage workers section */
.workers-section { margin-top:52px; }
.workers-cta-banner {
  background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f172a 100%);
  border-radius:var(--radius-xl); overflow:hidden; position:relative;
  padding:36px 40px; display:flex; align-items:center;
  justify-content:space-between; gap:24px; flex-wrap:wrap;
  box-shadow:var(--shadow-lg);
}
.workers-cta-banner::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 80% at 80% 50%, rgba(249,115,22,0.18), transparent 65%);
}
.workers-cta-text { position:relative; }
.workers-cta-eyebrow {
  font-size:11px; font-weight:800; color:#fb923c;
  text-transform:uppercase; letter-spacing:.1em; margin-bottom:10px;
}
.workers-cta-title {
  font-size:clamp(20px,3vw,30px); font-weight:900; color:#fff;
  font-family:'Baloo 2',cursive; line-height:1.1; margin-bottom:10px;
}
.workers-cta-sub { font-size:14px; color:#94a3b8; line-height:1.6; max-width:520px; }
.workers-cta-actions { display:flex; gap:12px; flex-wrap:wrap; position:relative; }
.workers-cta-btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 22px; border-radius:12px;
  background:linear-gradient(135deg,var(--orange),var(--orange-d));
  color:#fff; font-size:14px; font-weight:800; text-decoration:none;
  box-shadow:0 8px 22px rgba(234,88,12,0.36);
  transition:opacity .15s,transform .15s;
}
.workers-cta-btn-primary:hover { opacity:.9; transform:translateY(-1px); }
.workers-cta-btn-secondary {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 22px; border-radius:12px;
  background:rgba(255,255,255,0.10); border:1.5px solid rgba(255,255,255,0.22);
  color:#e2e8f0; font-size:14px; font-weight:700; text-decoration:none;
  backdrop-filter:blur(8px);
  transition:background .15s;
}
.workers-cta-btn-secondary:hover { background:rgba(255,255,255,0.18); }

/* Essential services */
.essential-services {
  margin-top:64px;
  padding:28px;
  background:linear-gradient(135deg,#ffffff 0%,#fff7ed 100%);
  border:1px solid #fed7aa;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm);
}
.essential-head {
  display:flex; align-items:flex-end; justify-content:space-between;
  gap:18px; margin-bottom:22px; flex-wrap:wrap;
}
.essential-eyebrow {
  color:var(--orange-d); font-size:11px; font-weight:900;
  letter-spacing:.12em; text-transform:uppercase; margin-bottom:6px;
}
.essential-head h2 {
  margin:0; color:#0f172a; font-family:'Baloo 2',cursive;
  font-size:clamp(26px,4vw,38px); line-height:1; font-weight:900;
}
.essential-head p {
  margin:8px 0 0; max-width:620px;
  color:var(--sub); font-size:14px; line-height:1.55;
}
.essential-head-link {
  display:inline-flex; align-items:center; justify-content:center;
  height:38px; padding:0 14px; border-radius:10px;
  background:#fff; border:1px solid #fed7aa;
  color:#c2410c; font-size:13px; font-weight:800;
  box-shadow:var(--shadow-xs);
  transition:background .15s, transform .15s;
}
.essential-head-link:hover {
  background:#ffedd5;
  transform:translateY(-1px);
}
.essential-grid {
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.essential-card {
  min-height:112px; display:flex; align-items:center; gap:13px;
  padding:16px; background:#fff;
  border:1px solid #ffedd5; border-radius:16px;
  box-shadow:0 6px 18px rgba(15,23,42,.05);
  color:#1f2937; text-decoration:none;
  position:relative; overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.essential-card::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:var(--orange);
}
.essential-card:hover {
  transform:translateY(-3px);
  border-color:#fdba74;
  box-shadow:0 14px 30px rgba(15,23,42,.10);
  background:#fffaf5;
}
.essential-icon {
  width:46px; height:46px; border-radius:13px;
  display:grid; place-items:center; flex:0 0 auto;
  background:#fff7ed; color:var(--orange-d);
}
.essential-icon svg { width:23px; height:23px; }
.essential-text { display:flex; flex-direction:column; min-width:0; }
.essential-label {
  width:fit-content; margin-bottom:4px; padding:2px 7px;
  border-radius:999px; background:#f8fafc; color:#64748b;
  font-size:10px; font-weight:900; letter-spacing:.04em; text-transform:uppercase;
}
.essential-name { color:#334155; font-size:14px; font-weight:850; line-height:1.25; }
.essential-meta { display:flex; align-items:center; gap:9px; margin-top:6px; }
.essential-number {
  color:#020617; font-size:19px; line-height:1;
  font-weight:900; letter-spacing:.01em; white-space:nowrap;
}
.essential-call {
  display:inline-flex; align-items:center; justify-content:center;
  height:24px; padding:0 9px; border-radius:999px;
  background:var(--orange-lt); color:var(--orange-d);
  font-size:11px; font-weight:900;
}
.essential-shield::before,.essential-fire::before { background:#ef4444; }
.essential-shield .essential-icon,.essential-fire .essential-icon { background:#fef2f2; color:#dc2626; }
.essential-medical::before,.essential-hospital::before { background:#16a34a; }
.essential-medical .essential-icon,.essential-hospital .essential-icon { background:#f0fdf4; color:#15803d; }
.essential-phone::before { background:#db2777; }
.essential-phone .essential-icon { background:#fdf2f8; color:#be185d; }
.essential-bolt::before { background:#eab308; }
.essential-bolt .essential-icon { background:#fefce8; color:#a16207; }
.essential-building::before { background:#2563eb; }
.essential-building .essential-icon { background:#eff6ff; color:#1d4ed8; }
.essential-train::before { background:#0d9488; }
.essential-train .essential-icon { background:#f0fdfa; color:#0f766e; }

/* ================================================================
   WEEKLY MARKET PAGE
   ================================================================ */
.weekly-hero { position:relative; overflow:hidden; min-height:360px; background:#0f172a; color:#fff; }
.weekly-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; transform:scale(1.02); }
.weekly-hero-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(to bottom,transparent 65%,var(--bg)); }
.weekly-hero-inner { position:relative; max-width:1180px; margin:0 auto; padding:50px 24px 70px; }
.weekly-back {
  display:inline-flex; width:max-content; border-radius:999px; padding:8px 12px; margin-bottom:34px;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.22); color:#fff; font-size:12px; font-weight:900;
}
.weekly-kicker { color:#fed7aa; font-size:11px; font-weight:900; letter-spacing:.08em; text-transform:uppercase; margin-bottom:10px; }
.weekly-hero h1 {
  font-family:'Baloo 2',cursive; font-size:clamp(38px,5.4vw,66px); line-height:.95; letter-spacing:0; margin-bottom:15px;
}
.weekly-hero p { max-width:660px; color:#e2e8f0; font-size:17px; line-height:1.7; margin-bottom:24px; }
.weekly-hero-actions { display:flex; flex-wrap:wrap; gap:10px; }
.weekly-primary,.weekly-secondary { border-radius:999px; padding:12px 16px; font-size:13px; font-weight:900; }
.weekly-primary { background:#f97316; color:#fff; }
.weekly-secondary { background:rgba(255,255,255,.14); color:#fff; border:1px solid rgba(255,255,255,.22); }
.weekly-wrap { max-width:1180px; margin:0 auto; padding:34px 24px 70px; }
.weekly-today { display:grid; grid-template-columns:minmax(0,1fr) 340px; gap:18px; align-items:stretch; margin-bottom:28px; }
.weekly-today-copy,.weekly-today-card,.weekly-intro,.weekly-shopping-guide,.weekly-source-note {
  background:#fff; border:1px solid #e2e8f0; border-radius:18px; box-shadow:var(--shadow-sm);
}
.weekly-today-copy { padding:24px; }
.weekly-today-copy span,.weekly-section-head span { color:#ea580c; font-size:11px; font-weight:900; letter-spacing:.08em; text-transform:uppercase; }
.weekly-today-copy h2,.weekly-section-head h2,.weekly-intro h2,.weekly-source-note h2 {
  color:#0f172a; font-family:'Baloo 2',cursive; font-size:32px; line-height:1; letter-spacing:0; margin:6px 0 10px;
}
.weekly-today-copy p,.weekly-intro p,.weekly-source-note p { color:#64748b; line-height:1.75; font-size:15px; }
.weekly-today-card {
  padding:24px; display:flex; flex-direction:column; justify-content:center; gap:10px; background:linear-gradient(135deg,#fff7ed,#fff);
}
.weekly-today-card strong { color:#0f172a; font-size:19px; line-height:1.35; }
.weekly-today-card span { color:#ea580c; font-weight:900; }
.weekly-intro { display:grid; grid-template-columns:minmax(0,1fr) 320px; gap:22px; padding:26px; margin-bottom:34px; }
.weekly-intro aside { background:#0f172a; color:#fff; border-radius:16px; padding:20px; display:flex; flex-direction:column; gap:12px; }
.weekly-intro aside strong { color:#fed7aa; font-size:12px; text-transform:uppercase; letter-spacing:.08em; }
.weekly-intro aside span { color:#e2e8f0; font-size:13px; line-height:1.45; }
.weekly-section-head { margin:0 0 18px; }
.weekly-day-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; margin-bottom:44px; }
.weekly-day-card { overflow:hidden; background:#fff; border:1px solid #e2e8f0; border-radius:18px; box-shadow:var(--shadow-sm); }
.weekly-day-img { aspect-ratio:701/561; background:#07111f; overflow:hidden; }
.weekly-day-img img { width:100%; height:100%; object-fit:contain; object-position:center; }
.weekly-day-body { padding:17px; }
.weekly-day-top { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-bottom:12px; }
.weekly-day-top h3 { color:#0f172a; font-size:21px; font-weight:900; margin:0; }
.weekly-day-top span {
  color:#15803d; background:#f0fdf4; border:1px solid #bbf7d0; border-radius:999px; padding:5px 9px; font-size:11px; font-weight:900;
}
.weekly-muted .weekly-day-top span { color:#854d0e; background:#fffbeb; border-color:#fde68a; }
.weekly-day-body dl { display:grid; gap:10px; margin-bottom:12px; }
.weekly-day-body dt { color:#94a3b8; font-size:10px; font-weight:900; letter-spacing:.08em; text-transform:uppercase; margin-bottom:2px; }
.weekly-day-body dd { color:#0f172a; font-size:13px; font-weight:800; line-height:1.4; }
.weekly-day-body p { color:#64748b; font-size:13px; line-height:1.55; }
.weekly-guide-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:12px; }
.weekly-shopping-guide { padding:26px; margin-bottom:28px; }
.weekly-guide-grid div { min-width:0; border-radius:14px; background:#f8fafc; border:1px solid #e2e8f0; padding:15px; }
.weekly-guide-grid strong { display:block; color:#0f172a; font-size:14px; margin-bottom:6px; }
.weekly-guide-grid span { color:#64748b; font-size:13px; line-height:1.45; }
.weekly-source-note { padding:24px; }

/* Worker preview cards on homepage (slim) */
.worker-preview-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:14px; margin:20px 0;
}
.worker-preview-card {
  background:var(--surface); border-radius:var(--radius-md);
  border:1px solid var(--border); padding:16px;
  display:flex; flex-direction:column; gap:8px;
  box-shadow:var(--shadow-xs);
  transition:transform .2s,box-shadow .2s;
  text-decoration:none; color:inherit;
}
.worker-preview-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.worker-preview-emoji { font-size:28px; line-height:1; }
.worker-preview-cat { font-size:10.5px; font-weight:800; color:var(--orange-d); text-transform:uppercase; letter-spacing:.06em; }
.worker-preview-name { font-size:13.5px; font-weight:800; color:var(--text); line-height:1.3; }
.worker-preview-spec { font-size:11.5px; color:var(--sub); }
.worker-preview-badge {
  display:inline-flex; align-items:center; gap:4px;
  font-size:11px; font-weight:700;
  background:#f0fdf4; color:#15803d;
  border:1px solid #bbf7d0; border-radius:99px; padding:2px 8px;
  width:fit-content;
}

@media(max-width:720px) {
  .worker-grid { grid-template-columns:1fr 1fr; }
  .workers-cta-banner { padding:24px 20px; }
  .worker-detail-body { padding:20px; }
  .worker-info-grid { grid-template-columns:1fr 1fr; }
  .essential-services { padding:20px; margin-top:44px; border-radius:20px; }
  .essential-grid { grid-template-columns:1fr; gap:12px; }
  .essential-card { min-height:92px; padding:14px; border-radius:14px; }
  .essential-number { font-size:18px; }
  .weekly-today,.weekly-intro { grid-template-columns:1fr; }
  .weekly-day-grid,.weekly-guide-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:560px) {
  .worker-grid { grid-template-columns:1fr; }
  .worker-preview-grid { grid-template-columns:1fr 1fr; }
  .weekly-market-popup {
    left:14px; right:14px; bottom:14px; width:auto; border-radius:16px;
  }
  .weekly-popup-media { max-height:145px; }
  .weekly-popup-body { padding:14px 13px; }
  .weekly-popup-body h2 { font-size:16px; }
  .weekly-popup-body p { font-size:12px; margin-bottom:10px; }
  .weekly-popup-primary,.weekly-popup-secondary { padding:8px 10px; font-size:11px; }
  .weekly-hero-inner { padding:36px 16px 54px; }
  .weekly-wrap { padding:24px 16px 48px; }
  .weekly-day-grid,.weekly-guide-grid { grid-template-columns:1fr; }
  .weekly-today-copy,.weekly-today-card,.weekly-intro,.weekly-shopping-guide,.weekly-source-note { border-radius:16px; padding:20px; }
  .weekly-hero p { font-size:15px; }
}
@media(min-width:721px) and (max-width:1100px) {
  .essential-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .weekly-day-grid { grid-template-columns:1fr 1fr; }
  .weekly-guide-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:380px) {
  .worker-preview-grid { grid-template-columns:1fr; }
}

