/* ═══════════════════════════════════════════════════════
   ZOOVIT — Combined Stylesheet v2.0
   Sections:
   1. Design Tokens / Variables
   2. Base Reset
   3. Navigation
   4. Buttons & Utilities
   5. Hero Section
   6. City Strip
   7. Business Cards
   8. Offer Cards
   9. Event Cards
  10. Blog Cards
  11. Category Page
  12. Business Detail Page
  13. Blogs Page
  14. Blog Detail Page
  15. Events Page / Detail
  16. Offers Page / Detail
  17. Contact Page
  18. Support Page
  19. Privacy & Terms Pages
  20. Footer
  21. City Modal
  22. Skeletons & Loading
  23. Pagination
  24. Empty States
  25. WhatsApp Float
  26. Responsive
═══════════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────────
   1. DESIGN TOKENS
───────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,400;1,9..144,700&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root {
  --navy:        #0c3360;
  --blue:        #1761b0;
  --blue-mid:    #2175cc;
  --sky:         #4aa3e8;
  --sky-light:   #bfe0f7;
  --pale:        #e6f2fc;
  --amber:       #f5a523;
  --amber-dark:  #d4880a;
  --amber-light: #fef3d8;
  --white:       #ffffff;
  --off-white:   #f8fbff;
  --gray-bg:     #f2f7fc;
  --gray-text:   #56687a;
  --gray-mid:    #8a9fb5;
  --gray-soft:   #dce9f4;
  --dark:        #091c30;
  --footer-bg:   #060e1a;
  --footer-text: rgba(255,255,255,.58);
  --font-display:'Fraunces', Georgia, serif;
  --font-body:   'Plus Jakarta Sans', sans-serif;
  --text-xs:11px;--text-sm:13px;--text-base:15px;--text-md:17px;
  --text-lg:clamp(16px,1.6vw,19px);--text-xl:clamp(22px,2.8vw,32px);
  --text-2xl:clamp(28px,4vw,44px);--text-3xl:clamp(34px,5.5vw,60px);
  --text-hero:clamp(38px,6.5vw,76px);
  --r-xs:6px;--r-sm:10px;--r-md:16px;--r-lg:22px;--r-xl:30px;--r-2xl:40px;
  --shadow-xs:0 2px 8px rgba(12,51,96,.06);
  --shadow-sm:0 4px 18px rgba(12,51,96,.09);
  --shadow-md:0 10px 36px rgba(12,51,96,.13);
  --shadow-lg:0 22px 60px rgba(12,51,96,.18);
  --shadow-xl:0 40px 90px rgba(12,51,96,.22);
  --ease:cubic-bezier(.22,.9,.36,1);
  --trans-fast:all .18s var(--ease);
  --trans:all .28s var(--ease);
  --max-w:1200px;
  --section-px:clamp(18px,5vw,80px);
  --section-py:clamp(36px,5vw,72px);
  --nav-h:68px;
}

/* ─────────────────────────────────────────────────────
   2. BASE RESET
───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%;}
body{font-family:var(--font-body);background:var(--white);color:var(--dark);overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased;padding-top:var(--nav-h);}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
input,textarea,select{font-family:inherit;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-thumb{background:var(--sky-light);border-radius:3px;}

/* ─────────────────────────────────────────────────────
   3. NAVIGATION
───────────────────────────────────────────────────── */
#zoovit-nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:1000;background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--sky-light);transition:box-shadow .25s;}
#zoovit-nav.scrolled{box-shadow:var(--shadow-md);}
.nav-inner{max-width:var(--max-w);height:100%;margin:0 auto;padding:0 var(--section-px);display:flex;align-items:center;gap:6px;position:relative;}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-right:14px;}
.nav-logo-img{width:38px;height:38px;object-fit:contain;border-radius:8px;}
.nav-logo-text{font-family:var(--font-display);font-size:20px;font-weight:800;color:var(--navy);letter-spacing:-.025em;white-space:nowrap;}
.nav-links{display:flex;align-items:center;gap:1px;margin-left:auto;}
.nav-link{font-size:13.5px;font-weight:500;color:var(--gray-text);padding:7px 11px;border-radius:8px;white-space:nowrap;transition:var(--trans-fast);position:relative;text-decoration:none;}
.nav-link:hover{color:var(--navy);background:var(--pale);}
.nav-link--active{color:var(--blue)!important;background:var(--pale);font-weight:600;}
.nav-link--active::after{content:'';position:absolute;bottom:-1px;left:8px;right:8px;height:2px;background:var(--blue);border-radius:1px;}
.nav-link--login{display:inline-flex;align-items:center;gap:5px;border:1.5px solid var(--gray-soft);border-radius:50px;padding:7px 14px!important;font-weight:600!important;color:var(--navy)!important;}
.nav-link--login:hover{border-color:var(--sky);background:var(--pale)!important;color:var(--blue)!important;}
.nav-link--events{color:var(--blue)!important;font-weight:600;}
.nav-link--offers{color:var(--amber-dark)!important;font-weight:600;}
.nav-city-btn{display:inline-flex;align-items:center;gap:6px;background:var(--pale);border:1.5px solid var(--sky-light);border-radius:50px;padding:7px 14px;font-size:12.5px;font-weight:600;color:var(--navy);cursor:pointer;transition:var(--trans-fast);flex-shrink:0;margin-left:6px;}
.nav-city-btn:hover{border-color:var(--sky);color:var(--blue);}
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5.5px;padding:8px;border-radius:8px;transition:background .18s;width:38px;height:38px;flex-shrink:0;}
.nav-hamburger:hover{background:var(--pale);}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:all .3s ease;transform-origin:center;}
.nav-hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
.nav-mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--white);border-bottom:1.5px solid var(--sky-light);padding:10px 20px 24px;flex-direction:column;gap:3px;z-index:999;box-shadow:0 16px 48px rgba(12,51,96,.18);max-height:calc(100vh - var(--nav-h));overflow-y:auto;}
.nav-mobile-menu.open{display:flex;}
.nav-mobile-menu .nav-link{font-size:15px;padding:13px 16px;border-radius:10px;display:block;width:100%;color:var(--gray-text);font-weight:500;}
.nav-mobile-menu .nav-link:hover,.nav-mobile-menu .nav-link--active{background:var(--pale);color:var(--navy);}
.nav-mobile-menu .nav-link--active{color:var(--blue)!important;border-left:3px solid var(--blue);padding-left:13px;font-weight:600;}
.nav-mobile-menu .nav-link--active::after{display:none;}
.nav-mobile-city{padding:12px 16px;border-top:1px solid var(--gray-soft);margin-top:8px;}
/* Desktop: hide hamburger and mobile menu */
@media(min-width:901px){
  .nav-hamburger{display:none!important;}
  .nav-mobile-menu{display:none!important;}
  .nav-mobile-menu.open{display:none!important;}
}
/* Mobile: hide nav links, show hamburger on far right */
@media(max-width:900px){
  .nav-links{display:none!important;}
  .nav-hamburger{display:flex!important;position:absolute;right:var(--section-px);top:50%;transform:translateY(-50%);}
  .nav-city-btn{display:none;}
}

/* ─────────────────────────────────────────────────────
   4. BUTTONS & LAYOUT UTILITIES
───────────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--section-px);width:100%;}
section{padding:var(--section-py) 0;}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap;}
.section-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:var(--text-xs);font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);margin-bottom:14px;}
.section-eyebrow::before{content:'';width:20px;height:2px;background:var(--blue);border-radius:1px;flex-shrink:0;}
.section-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--navy);line-height:1.1;letter-spacing:-.022em;}
.section-title em{font-style:italic;color:var(--blue);}
.section-sub{margin-top:14px;font-size:var(--text-base);color:var(--gray-text);line-height:1.78;max-width:520px;}
.page-title{font-family:var(--font-display);font-size:clamp(28px,4vw,52px);font-weight:800;color:var(--navy);line-height:1.1;margin-bottom:14px;}
.page-title em{color:var(--blue);font-style:italic;}
.page-sub{font-size:16px;color:var(--gray-text);line-height:1.72;max-width:560px;}
.page-hero{background:linear-gradient(168deg,var(--pale) 0%,var(--off-white) 100%);padding:clamp(28px,5vw,56px) 0 clamp(24px,4vw,48px);border-bottom:1.5px solid var(--gray-soft);}

.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:700;font-size:var(--text-sm);border-radius:50px;padding:12px 26px;cursor:pointer;border:none;transition:var(--trans);text-decoration:none;white-space:nowrap;}
.btn-primary{background:var(--blue);color:var(--white);box-shadow:0 6px 24px rgba(23,97,176,.3);}
.btn-primary:hover{background:var(--navy);transform:translateY(-2px);}
.btn-amber{background:var(--amber);color:var(--dark);box-shadow:0 6px 24px rgba(245,165,35,.35);}
.btn-amber:hover{background:var(--amber-dark);transform:translateY(-2px);}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--gray-soft);}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--pale);}
.btn-ghost-white{background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.28);color:white;}
.btn-ghost-white:hover{background:rgba(255,255,255,.22);}
.btn-outline-navy{background:transparent;border:1.5px solid var(--navy);color:var(--navy);}
.btn-outline-navy:hover{background:var(--navy);color:white;}
.btn-lg{padding:16px 36px;font-size:15px;}

.view-all-link{font-size:var(--text-sm);font-weight:700;color:var(--blue);display:inline-flex;align-items:center;gap:5px;transition:gap .2s;white-space:nowrap;}
.view-all-link svg{width:14px;height:14px;stroke:var(--blue);fill:none;stroke-width:2.5;transition:transform .2s;}
.view-all-link:hover{gap:9px;}
.view-all-link:hover svg{transform:translateX(3px);}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--gray-mid);margin-bottom:20px;}
.breadcrumb a{color:var(--blue);font-weight:500;}
.breadcrumb svg{width:14px;height:14px;stroke:var(--gray-mid);fill:none;stroke-width:2;}

/* ─────────────────────────────────────────────────────
   5. HERO SECTION
───────────────────────────────────────────────────── */
.hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:calc(var(--nav-h) + 60px) var(--section-px) 80px;position:relative;overflow:hidden;background:linear-gradient(168deg,#ddeefb 0%,#eaf5ff 42%,#f6fbff 100%);}
.hero-dot-grid{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(12,51,96,.07) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 80% 65% at 50% 50%,black 15%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 80% 65% at 50% 50%,black 15%,transparent 80%);}
.hero-glow-l{position:absolute;top:-100px;left:-180px;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(74,163,232,.2) 0%,transparent 70%);pointer-events:none;}
.hero-glow-r{position:absolute;bottom:-60px;right:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(245,165,35,.12) 0%,transparent 70%);pointer-events:none;}
.hero-inner{position:relative;z-index:1;text-align:center;width:100%;max-width:800px;margin:0 auto;}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:white;border:1px solid var(--gray-soft);border-radius:50px;padding:7px 18px 7px 10px;margin-bottom:30px;box-shadow:var(--shadow-xs);animation:fadeUp .5s ease both;font-size:13px;color:var(--navy);font-weight:500;}
.hero-badge-dot{width:8px;height:8px;background:var(--amber);border-radius:50%;animation:pulseDot 2s infinite;flex-shrink:0;}
@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.25)}}
.hero-h1{font-family:var(--font-display);font-size:var(--text-hero);font-weight:600;color:var(--navy);line-height:1.07;letter-spacing:-.022em;margin-bottom:22px;animation:fadeUp .5s .08s ease both;}
.hero-h1 em{font-style:italic;color:var(--blue);}
.hero-h1 .u-amber{position:relative;display:inline-block;color:var(--navy);}
.hero-h1 .u-amber::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:4px;background:var(--amber);border-radius:2px;}
.hero-sub{font-size:clamp(16px,1.8vw,19px);color:var(--gray-text);line-height:1.75;max-width:620px;margin:0 auto 40px;animation:fadeUp .5s .16s ease both;}
.hero-search-block{animation:fadeUp .5s .24s ease both;width:100%;max-width:640px;margin:0 auto 24px;}
.hero-search{display:flex;align-items:center;background:white;border-radius:var(--r-lg);border:2px solid var(--gray-soft);box-shadow:var(--shadow-md);overflow:hidden;transition:border-color .2s,box-shadow .2s;}
.hero-search:focus-within{border-color:var(--sky);box-shadow:0 8px 40px rgba(74,163,232,.22);}
.hero-search-icon{padding:0 16px;display:flex;align-items:center;flex-shrink:0;}
.hero-search-icon svg{width:19px;height:19px;stroke:var(--sky);stroke-width:2.5;fill:none;}
.hero-search input{flex:1;padding:17px 0;font-size:15px;color:var(--dark);border:none;outline:none;background:transparent;min-width:0;}
.hero-search input::placeholder{color:#a8bbc9;}
.hero-search-div{width:1px;height:28px;background:var(--gray-soft);flex-shrink:0;}
.hero-city-pick{display:flex;align-items:center;gap:7px;padding:0 18px;cursor:pointer;white-space:nowrap;font-size:14px;font-weight:600;color:var(--navy);flex-shrink:0;}
.hero-search-btn{background:var(--blue);color:white;font-weight:700;font-size:14px;padding:17px 26px;border:none;transition:background .2s;white-space:nowrap;flex-shrink:0;font-family:var(--font-body);}
.hero-search-btn:hover{background:var(--navy);}
.cat-pills{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;animation:fadeUp .5s .32s ease both;}
.cat-pill{display:flex;align-items:center;gap:6px;background:white;border:1.5px solid var(--gray-soft);border-radius:50px;padding:8px 16px;font-size:13px;font-weight:500;color:var(--navy);cursor:pointer;transition:var(--trans);box-shadow:var(--shadow-xs);}
.cat-pill:hover{border-color:var(--sky);color:var(--blue);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.cat-pill-icon{font-size:14px;}
.hero-scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(12,51,96,.3);font-size:10px;letter-spacing:.1em;font-weight:700;animation:bounceHint 2.5s infinite;}
.scroll-rod{width:1px;height:30px;background:linear-gradient(to bottom,transparent,rgba(12,51,96,.2));}
@keyframes bounceHint{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}

/* ─────────────────────────────────────────────────────
   6. CITY STRIP
───────────────────────────────────────────────────── */
.city-strip{background:var(--navy);overflow:hidden;border-top:1px solid rgba(74,163,232,.18);}
.city-strip-inner{max-width:var(--max-w);margin:0 auto;display:flex;overflow-x:auto;scrollbar-width:none;padding:0 var(--section-px);}
.city-strip-inner::-webkit-scrollbar{display:none;}
.city-chip{display:flex;align-items:center;gap:10px;padding:14px 22px;flex-shrink:0;cursor:pointer;border-right:1px solid rgba(255,255,255,.05);transition:background .2s;}
.city-chip:hover{background:rgba(255,255,255,.06);}
.city-chip.active{background:rgba(74,163,232,.14);}
.city-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.18);}
.city-chip.active .city-dot{background:var(--amber);}
.city-name{font-size:13px;font-weight:700;color:white;}
.city-chip.active .city-name{color:var(--amber);}

/* ─────────────────────────────────────────────────────
   7. BUSINESS CARDS
───────────────────────────────────────────────────── */
.biz-uniform-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.brand-card{display:flex;flex-direction:column;background:var(--white);border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;transition:var(--trans);position:relative;text-decoration:none;}
.brand-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--sky-light);}
.brand-card-img{height:160px;overflow:hidden;position:relative;background:var(--gray-bg);}
.brand-card-img img{width:100%;height:100%;object-fit:cover;}
.brand-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:36px;color:white;}
.brand-card-crown{position:absolute;top:12px;right:12px;background:var(--amber);color:var(--dark);font-size:11px;font-weight:800;padding:4px 10px 4px 8px;border-radius:20px;display:flex;align-items:center;gap:4px;box-shadow:0 4px 12px rgba(245,165,35,.4);}
.brand-card-body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column;}
.brand-card-category-row{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap;}
.b-badge{font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.03em;display:inline-flex;align-items:center;gap:3px;}
.b-badge.city{background:var(--pale);color:var(--blue);}
.b-badge.offer{background:var(--amber-light);color:#9a5800;}
.b-badge.cat{background:var(--gray-bg);color:var(--gray-text);}
.brand-name{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--navy);line-height:1.25;margin-bottom:4px;}
.brand-location{font-size:12px;color:var(--gray-text);display:flex;align-items:center;gap:4px;margin-bottom:10px;}
.brand-location svg{width:12px;height:12px;fill:var(--gray-mid);flex-shrink:0;}
.brand-rating{display:flex;align-items:center;gap:4px;margin-bottom:12px;}
.brand-stars{display:flex;gap:2px;}
.brand-stars svg{width:14px;height:14px;fill:var(--amber);}
.brand-rating-text{font-size:12px;color:var(--gray-text);font-weight:500;}
.brand-card-footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--gray-soft);}
.brand-view-btn{font-size:12px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:4px;}
.brand-view-btn:hover{gap:7px;}

/* recent biz cards */
.recent-biz-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.recent-biz-card{display:flex;flex-direction:column;background:var(--white);border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;transition:var(--trans);text-decoration:none;}
.recent-biz-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--sky-light);}
.rbc-top{height:110px;position:relative;display:flex;align-items:center;justify-content:center;}
.rbc-avatar{width:60px;height:60px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:22px;color:white;overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,.15);}
.rbc-new-badge{position:absolute;top:10px;right:12px;background:var(--amber);color:var(--dark);font-size:10px;font-weight:800;padding:3px 10px;border-radius:20px;}
.rbc-body{padding:0 16px 16px;}
.rbc-name{font-family:var(--font-display);font-size:15px;font-weight:800;color:var(--navy);margin-bottom:3px;line-height:1.2;}
.rbc-cat{font-size:11.5px;color:var(--gray-text);margin-bottom:8px;}
.rbc-footer{padding:12px 16px;border-top:1px solid var(--gray-soft);display:flex;align-items:center;justify-content:space-between;}
.rbc-city{font-size:11.5px;color:var(--gray-text);display:flex;align-items:center;gap:4px;}
.rbc-time{font-size:11px;color:var(--gray-mid);}

/* businesses listing page */
.biz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.biz-search-wrap{position:relative;}
.biz-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none;}
.biz-search-input{width:100%;padding:12px 16px 12px 42px;border:1.5px solid var(--gray-soft);border-radius:var(--r-sm);font-size:14px;color:var(--dark);outline:none;transition:border-color .2s;}
.biz-search-input:focus{border-color:var(--sky);}
.biz-filter-select{padding:12px 16px;border:1.5px solid var(--gray-soft);border-radius:var(--r-sm);font-size:14px;color:var(--dark);background:white;outline:none;cursor:pointer;}
.biz-filter-select:focus{border-color:var(--sky);}
.listing-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.listing-title{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--navy);}
.listing-count{font-size:13.5px;color:var(--gray-text);margin-top:4px;}
.sort-select{padding:10px 14px;border:1.5px solid var(--gray-soft);border-radius:var(--r-sm);font-size:13px;background:white;cursor:pointer;}

/* ─────────────────────────────────────────────────────
   8. OFFER CARDS
───────────────────────────────────────────────────── */
.offers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.offer-card{background:var(--white);border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;transition:var(--trans);text-decoration:none;display:flex;flex-direction:column;}
.offer-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--sky-light);}
.offer-card__header{height:100px;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;position:relative;}
.offer-card__icon{font-size:32px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.2));}
.offer-card__badge{font-family:var(--font-display);font-size:18px;font-weight:800;color:white;text-shadow:0 2px 6px rgba(0,0,0,.2);}
.offer-card__type{font-size:9.5px;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em;position:absolute;bottom:10px;right:10px;}
.offer-card__body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column;}
.offer-card__biz{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.offer-card__meta{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px;}
.offer-card__title{font-size:15px;font-weight:700;color:var(--navy);line-height:1.35;margin-bottom:10px;}
.offer-card__code{display:flex;align-items:center;gap:6px;background:var(--gray-bg);border-radius:var(--r-sm);padding:8px 12px;margin-bottom:12px;}
.offer-card__code-label{font-size:11px;color:var(--gray-text);font-weight:600;}
.offer-card__code-val{font-size:13px;font-weight:800;color:var(--navy);font-family:monospace;cursor:pointer;letter-spacing:.08em;}
.offer-card__copy{padding:4px 8px;background:var(--pale);border-radius:6px;color:var(--blue);transition:background .2s;flex-shrink:0;margin-left:auto;}
.offer-card__copy:hover{background:var(--sky-light);}
.offer-card__footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--gray-soft);}
.offer-card__expires{font-size:11.5px;color:var(--gray-text);}
.offer-card__cta{font-size:12px;font-weight:700;color:var(--blue);}

/* offer detail */
.offer-detail-layout{display:grid;grid-template-columns:1fr 320px;gap:28px;}
.offer-detail-card{background:white;border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;}
.offer-detail-header{height:160px;display:flex;align-items:center;gap:20px;padding:24px 28px;}
.offer-detail-icon{font-size:56px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.2));}
.offer-detail-badge{font-family:var(--font-display);font-size:28px;font-weight:800;color:white;margin-bottom:4px;}
.offer-detail-biz{font-size:15px;color:rgba(255,255,255,.75);font-weight:600;}
.offer-detail-body{padding:28px;}
.offer-detail-sidebar{background:white;border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);padding:24px;}
.offer-code-box{background:var(--pale);border:2px dashed var(--sky-light);border-radius:var(--r-md);padding:20px;text-align:center;}
.offer-code-box__label{font-size:12px;color:var(--gray-text);font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;}
.offer-code-box__inner{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px;}
.offer-code-box__code{font-size:28px;font-weight:900;color:var(--navy);font-family:monospace;letter-spacing:.12em;}
.offer-code-box__copy{background:var(--blue);color:white;padding:10px 20px;border-radius:50px;font-size:13px;font-weight:700;display:inline-flex;align-items:center;gap:6px;transition:var(--trans);}
.offer-code-box__copy:hover{background:var(--navy);}
.offer-code-box__hint{font-size:12px;color:var(--gray-text);}

/* offer type pills */
.offer-type-pill{display:inline-flex;align-items:center;gap:5px;padding:8px 18px;border-radius:50px;font-size:13px;font-weight:600;border:1.5px solid var(--gray-soft);color:var(--gray-text);background:white;cursor:pointer;transition:var(--trans);}
.offer-type-pill:hover,.offer-type-pill.active{border-color:var(--blue);color:var(--blue);background:var(--pale);}

/* ─────────────────────────────────────────────────────
   9. EVENT CARDS
───────────────────────────────────────────────────── */
.events-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.event-card{background:var(--white);border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;transition:var(--trans);text-decoration:none;display:flex;flex-direction:column;}
.event-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--sky-light);}
.event-card__banner{height:140px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;}
.event-card__banner img{width:100%;height:100%;object-fit:cover;}
.event-card__date-badge{position:absolute;bottom:10px;left:10px;background:var(--navy);color:white;border-radius:10px;padding:5px 10px;text-align:center;min-width:42px;box-shadow:0 2px 8px rgba(0,0,0,.25);}
.event-card__date-badge .day{font-family:var(--font-display);font-size:18px;font-weight:800;line-height:1;}
.event-card__date-badge .mon{font-size:10px;font-weight:700;text-transform:uppercase;opacity:.7;margin-top:2px;}
.event-card__body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column;}
.event-card__biz{font-size:11.5px;color:var(--blue);font-weight:700;margin-bottom:4px;}
.event-card__title{font-family:var(--font-display);font-size:16px;font-weight:800;color:var(--navy);line-height:1.3;margin-bottom:8px;}
.event-card__meta{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;}
.event-card__footer{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding-top:10px;border-top:1px solid var(--gray-soft);}
.event-card__location{font-size:11.5px;color:var(--gray-text);}
.event-card__cta{font-size:12px;font-weight:700;color:var(--blue);}

/* event detail */
.event-detail-layout{display:grid;grid-template-columns:1fr 320px;gap:28px;}
.event-detail-content{background:white;border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;}
.event-detail-banner{height:280px;position:relative;overflow:hidden;}
.event-detail-banner img{width:100%;height:100%;object-fit:cover;}
.event-detail-body{padding:32px;}
.event-html-content{font-size:15px;color:var(--gray-text);line-height:1.82;}
.event-html-content h1,.event-html-content h2,.event-html-content h3{font-family:var(--font-display);color:var(--navy);margin:20px 0 10px;line-height:1.3;}
.event-html-content p{margin-bottom:14px;}
.event-html-content ul,.event-html-content ol{padding-left:22px;margin-bottom:14px;}
.event-html-content li{margin-bottom:6px;}
.event-html-content img{border-radius:var(--r-md);max-width:100%;margin:16px 0;}
.event-html-content strong{color:var(--navy);font-weight:700;}

/* ─────────────────────────────────────────────────────
  10. BLOG CARDS
───────────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.blog-card{background:var(--white);border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;transition:var(--trans);text-decoration:none;display:flex;flex-direction:column;}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--sky-light);}
.blog-card-img{height:180px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;background:var(--pale);}
.blog-card-img img{width:100%;height:100%;object-fit:cover;}
.blog-card-img-placeholder{font-size:48px;}
.blog-type-badge{position:absolute;top:12px;left:12px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;padding:4px 12px;border-radius:20px;background:var(--navy);color:white;}
.blog-type-badge.news{background:var(--amber);color:var(--dark);}
.blog-type-badge.blog{background:var(--blue);color:white;}
.blog-card-body{padding:18px 20px 20px;flex:1;display:flex;flex-direction:column;}
.blog-card-title{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--navy);line-height:1.35;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.blog-card-excerpt{font-size:13.5px;color:var(--gray-text);line-height:1.68;margin-bottom:12px;flex:1;}
.blog-card-meta{margin-top:auto;padding-top:12px;border-top:1px solid var(--gray-soft);display:flex;align-items:center;justify-content:space-between;}
.blog-card-date{font-size:12px;color:var(--gray-mid);}
.blog-card-cta{font-size:12px;font-weight:700;color:var(--blue);}

/* blog category tabs */
.blog-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;}
.blog-tab{padding:9px 20px;border-radius:50px;font-size:13.5px;font-weight:600;border:1.5px solid var(--gray-soft);color:var(--gray-text);background:white;cursor:pointer;transition:var(--trans);}
.blog-tab:hover,.blog-tab.active{background:var(--blue);color:white;border-color:var(--blue);}

/* blog detail */
.blog-detail-layout{display:grid;grid-template-columns:1fr 300px;gap:32px;max-width:var(--max-w);margin:0 auto;}
.blog-detail-article{background:white;border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);overflow:hidden;}
.blog-detail-hero-img{height:360px;overflow:hidden;}
.blog-detail-hero-img img{width:100%;height:100%;object-fit:cover;}
.blog-detail-content{padding:40px;}
.blog-detail-title{font-family:var(--font-display);font-size:clamp(24px,3.5vw,40px);font-weight:800;color:var(--navy);line-height:1.15;margin-bottom:20px;letter-spacing:-.02em;}
.blog-detail-meta{display:flex;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:24px;border-bottom:1.5px solid var(--gray-soft);}
.blog-html-content{font-size:16px;color:var(--gray-text);line-height:1.9;}
.blog-html-content h1,.blog-html-content h2,.blog-html-content h3,.blog-html-content h4{font-family:var(--font-display);color:var(--navy);margin:28px 0 12px;line-height:1.3;}
.blog-html-content h2{font-size:26px;}
.blog-html-content h3{font-size:21px;}
.blog-html-content p{margin-bottom:18px;}
.blog-html-content ul,.blog-html-content ol{padding-left:24px;margin-bottom:18px;}
.blog-html-content li{margin-bottom:8px;}
.blog-html-content img{border-radius:var(--r-md);max-width:100%;margin:24px 0;}
.blog-html-content blockquote{border-left:4px solid var(--blue);padding:16px 20px;background:var(--pale);border-radius:0 var(--r-sm) var(--r-sm) 0;margin:20px 0;color:var(--navy);font-style:italic;}
.blog-html-content strong{color:var(--navy);font-weight:700;}
.blog-html-content a{color:var(--blue);text-decoration:underline;}
.blog-sidebar-card{background:white;border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);padding:24px;margin-bottom:16px;}
.blog-related-card{display:flex;gap:12px;text-decoration:none;padding:12px 0;border-bottom:1px solid var(--gray-soft);}
.blog-related-card:last-child{border-bottom:none;}
.blog-related-card:hover .blog-related-title{color:var(--blue);}
.blog-related-img{width:60px;height:60px;border-radius:var(--r-sm);background:var(--pale);flex-shrink:0;overflow:hidden;}
.blog-related-img img{width:100%;height:100%;object-fit:cover;}
.blog-related-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--navy);line-height:1.3;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .2s;}
.blog-related-date{font-size:11px;color:var(--gray-mid);}

/* ─────────────────────────────────────────────────────
  11. CATEGORIES PAGE
───────────────────────────────────────────────────── */
.cats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.cat-card{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-xl);padding:24px;text-decoration:none;transition:var(--trans);display:flex;flex-direction:column;}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--sky-light);}
.cat-card-header{display:flex;align-items:center;gap:14px;margin-bottom:16px;}
.cat-card-icon{width:52px;height:52px;border-radius:14px;background:var(--pale);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;}
.cat-card-name{font-family:var(--font-display);font-size:19px;font-weight:800;color:var(--navy);}
.cat-card-subcats{display:flex;flex-wrap:wrap;gap:6px;}
.cat-subcat-tag{font-size:11.5px;color:var(--gray-text);padding:4px 12px;background:var(--gray-bg);border-radius:20px;border:1px solid var(--gray-soft);}
.cat-card-footer{margin-top:16px;padding-top:14px;border-top:1px solid var(--gray-soft);display:flex;align-items:center;justify-content:space-between;}
.cat-card-cta{font-size:13px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:4px;}

.cats-search-bar{display:flex;gap:12px;max-width:500px;margin-bottom:32px;}
.cats-search-input{flex:1;padding:12px 18px;border:1.5px solid var(--gray-soft);border-radius:var(--r-sm);font-size:15px;outline:none;transition:border-color .2s;}
.cats-search-input:focus{border-color:var(--sky);}

/* ─────────────────────────────────────────────────────
  12. BUSINESS DETAIL PAGE
───────────────────────────────────────────────────── */
.biz-hero{background:linear-gradient(168deg,var(--pale) 0%,var(--off-white) 100%);border-bottom:1.5px solid var(--gray-soft);padding:clamp(32px,6vw,64px) 0;}
.biz-hero-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--section-px);display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.biz-hero-left{display:flex;align-items:flex-start;gap:20px;flex:1;min-width:260px;}
.biz-logo-big{width:100px;height:100px;border-radius:22px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:32px;color:white;overflow:hidden;box-shadow:var(--shadow-md);flex-shrink:0;border:3px solid rgba(255,255,255,.5);}
.biz-name{font-family:var(--font-display);font-size:clamp(22px,3.5vw,34px);font-weight:800;color:var(--navy);line-height:1.1;margin-bottom:6px;}
.biz-cat-line{font-size:14px;color:var(--gray-text);margin-bottom:12px;}
.biz-badges{display:flex;gap:7px;flex-wrap:wrap;}
.biz-badge{font-size:11.5px;font-weight:700;padding:4px 12px;border-radius:20px;}
.biz-badge.city{background:var(--pale);color:var(--blue);}
.biz-badge.verified{background:#dcfce7;color:#16a34a;}
.biz-badge.offer{background:var(--amber-light);color:#9a5800;}
.biz-action-btn{display:inline-flex;align-items:center;gap:6px;padding:12px 20px;border-radius:50px;font-size:14px;font-weight:700;cursor:pointer;transition:var(--trans);text-decoration:none;border:none;font-family:var(--font-body);}
.biz-action-btn.whatsapp{background:#25d366;color:white;}
.biz-action-btn.whatsapp:hover{background:#1da851;transform:translateY(-2px);}
.biz-action-btn.primary{background:var(--blue);color:white;}
.biz-action-btn.primary:hover{background:var(--navy);transform:translateY(-2px);}
.biz-action-btn.secondary{background:white;color:var(--navy);border:1.5px solid var(--gray-soft);}
.biz-action-btn.secondary:hover{border-color:var(--sky);color:var(--blue);}
.biz-detail-layout{max-width:var(--max-w);margin:0 auto;padding:40px var(--section-px);display:grid;grid-template-columns:1fr 300px;gap:32px;}
.biz-tabs{display:flex;gap:4px;border-bottom:2px solid var(--gray-soft);margin-bottom:28px;}
.biz-tab{padding:10px 18px;font-size:14px;font-weight:600;color:var(--gray-text);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s;}
.biz-tab.active{color:var(--blue);border-color:var(--blue);}
.biz-tab-panel{display:none;}
.biz-tab-panel.active{display:block;}

.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;}
.product-card{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-lg);overflow:hidden;transition:var(--trans);}
.product-card:hover{box-shadow:var(--shadow-md);border-color:var(--sky-light);}
.product-card-img{height:160px;background:var(--gray-bg);overflow:hidden;}
.product-card-img img{width:100%;height:100%;object-fit:cover;}
.product-card-body{padding:12px 14px 14px;}
.product-name{font-weight:700;font-size:14px;color:var(--navy);margin-bottom:4px;}
.product-price{font-size:15px;font-weight:800;color:var(--blue);}

/* ─────────────────────────────────────────────────────
  13. CONTACT PAGE
───────────────────────────────────────────────────── */
.contact-layout{max-width:var(--max-w);margin:0 auto;padding:clamp(40px,7vw,80px) var(--section-px);display:grid;grid-template-columns:1fr 1.4fr;gap:40px;}
.contact-info-col{display:flex;flex-direction:column;gap:16px;}
.contact-info-card{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-xl);padding:24px;display:flex;align-items:flex-start;gap:16px;transition:var(--trans);}
.contact-info-card:hover{box-shadow:var(--shadow-sm);border-color:var(--sky-light);}
.contact-info-icon{width:48px;height:48px;border-radius:12px;background:var(--pale);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;}
.contact-info-text h4{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.contact-info-text p{font-size:14px;color:var(--gray-text);line-height:1.65;}
.contact-info-text a{color:var(--blue);font-weight:600;}
.contact-form-card{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-xl);padding:40px;}
.contact-form-card h3{font-family:var(--font-display);font-size:24px;font-weight:800;color:var(--navy);margin-bottom:8px;}
.contact-form-card>p{font-size:14px;color:var(--gray-text);margin-bottom:24px;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group.full{grid-column:1/-1;}
.form-group label{font-size:13px;font-weight:600;color:var(--navy);}
.form-group input,.form-group textarea,.form-group select{padding:12px 16px;border:1.5px solid var(--gray-soft);border-radius:var(--r-sm);font-size:14.5px;color:var(--dark);outline:none;transition:border-color .2s;background:var(--off-white);}
.form-group input:focus,.form-group textarea:focus{border-color:var(--sky);background:white;}
.form-group textarea{resize:vertical;min-height:110px;}
.form-submit{width:100%;padding:15px;background:var(--blue);color:white;border-radius:50px;font-size:15px;font-weight:700;cursor:pointer;transition:var(--trans);border:none;margin-top:8px;}
.form-submit:hover{background:var(--navy);transform:translateY(-2px);}

/* ─────────────────────────────────────────────────────
  14. SUPPORT PAGE
───────────────────────────────────────────────────── */
.support-hero-search{max-width:540px;margin:28px auto 0;}
.support-search-input-wrap{display:flex;align-items:center;background:white;border:2px solid var(--gray-soft);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);}
.support-search-input-wrap:focus-within{border-color:var(--sky);}
.support-search-input-wrap input{flex:1;padding:16px 18px;font-size:15px;border:none;outline:none;background:transparent;}
.support-search-input-wrap button{padding:16px 22px;background:var(--blue);color:white;font-weight:700;font-size:14px;border:none;cursor:pointer;transition:background .2s;}
.support-search-input-wrap button:hover{background:var(--navy);}
.support-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:48px;}
.support-cat-card{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-lg);padding:22px;text-align:center;transition:var(--trans);cursor:pointer;}
.support-cat-card:hover{border-color:var(--sky-light);box-shadow:var(--shadow-sm);}
.support-cat-icon{font-size:28px;margin-bottom:10px;}
.support-cat-name{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--navy);margin-bottom:4px;}
.support-cat-count{font-size:12px;color:var(--gray-mid);}
.accordion-item{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-lg);margin-bottom:10px;overflow:hidden;}
.accordion-head{padding:18px 22px;font-size:15px;font-weight:600;color:var(--navy);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;transition:background .15s;}
.accordion-head:hover{background:var(--gray-bg);}
.accordion-chevron{width:18px;height:18px;stroke:var(--gray-mid);fill:none;stroke-width:2;transition:transform .3s;flex-shrink:0;}
.accordion-head.open .accordion-chevron{transform:rotate(180deg);}
.accordion-body{font-size:14.5px;color:var(--gray-text);line-height:1.75;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s;}
.accordion-body.open{max-height:400px;padding:0 22px 20px;}

/* ─────────────────────────────────────────────────────
  15. PRIVACY / TERMS PAGES
───────────────────────────────────────────────────── */
.legal-layout{max-width:820px;margin:0 auto;padding:clamp(40px,7vw,80px) var(--section-px);}
.legal-content{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-xl);padding:clamp(28px,5vw,60px);}
.legal-content h2{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--navy);margin:28px 0 12px;}
.legal-content h3{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--navy);margin:20px 0 8px;}
.legal-content p{font-size:14.5px;color:var(--gray-text);line-height:1.8;margin-bottom:16px;}
.legal-content ul,.legal-content ol{padding-left:22px;margin-bottom:16px;}
.legal-content li{font-size:14.5px;color:var(--gray-text);line-height:1.75;margin-bottom:6px;}
.legal-content a{color:var(--blue);}
.legal-content strong{color:var(--navy);font-weight:700;}
.legal-last-updated{font-size:13px;color:var(--gray-mid);margin-bottom:28px;padding-bottom:20px;border-bottom:1.5px solid var(--gray-soft);}

/* ─────────────────────────────────────────────────────
  16. FOOTER
───────────────────────────────────────────────────── */
footer{background:var(--footer-bg);color:var(--footer-text);}
.footer-top-band{padding:clamp(48px,7vw,80px) 0 0;}
.footer-newsletter{max-width:var(--max-w);margin:0 auto;padding:0 var(--section-px) 48px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.07);}
.footer-newsletter__text h4{font-family:var(--font-display);font-size:19px;font-weight:700;color:white;margin-bottom:4px;}
.footer-newsletter__text p{font-size:13.5px;color:var(--footer-text);}
.footer-newsletter__form{display:flex;gap:8px;flex:1;min-width:240px;max-width:420px;}
.footer-newsletter__input{flex:1;padding:12px 18px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:50px;color:white;font-size:14px;outline:none;}
.footer-newsletter__input::placeholder{color:rgba(255,255,255,.35);}
.footer-newsletter__input:focus{border-color:rgba(74,163,232,.5);}
.footer-newsletter__btn{padding:12px 22px;background:var(--amber);color:var(--dark);border:none;border-radius:50px;font-weight:700;font-size:14px;cursor:pointer;transition:background .2s;white-space:nowrap;}
.footer-newsletter__btn:hover{background:var(--amber-dark);}
.footer-main{max-width:var(--max-w);margin:0 auto;padding:48px var(--section-px);display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;}
.footer-brand p,.footer-tagline{font-size:13.5px;color:var(--footer-text);line-height:1.75;margin-top:14px;max-width:280px;}
.footer-logo{display:flex;align-items:center;gap:10px;text-decoration:none;}
.footer-logo-img{width:36px;height:36px;border-radius:8px;}
.footer-logo-text{font-family:var(--font-display);font-size:20px;font-weight:800;color:white;}
.footer-socials{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap;}
.footer-social-btn{width:36px;height:36px;background:rgba(255,255,255,.07);border-radius:10px;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.footer-social-btn:hover{background:rgba(255,255,255,.14);}
.footer-social-btn svg{width:16px;height:16px;fill:none;stroke:rgba(255,255,255,.65);stroke-width:2;}
.footer-app-note{display:block;font-size:12px;color:rgba(255,255,255,.3);margin-top:14px;}
.footer-col h5{font-family:var(--font-display);font-size:13px;font-weight:700;color:white;letter-spacing:.06em;text-transform:uppercase;margin-bottom:16px;}
.footer-links li{margin-bottom:10px;}
.footer-links a{font-size:13.5px;color:var(--footer-text);transition:color .2s;}
.footer-links a:hover{color:white;}
.footer-divider{height:1px;background:rgba(255,255,255,.06);max-width:var(--max-w);margin:0 auto;}
.footer-bottom{max-width:var(--max-w);margin:0 auto;padding:22px var(--section-px);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.footer-copy{font-size:12.5px;color:rgba(255,255,255,.28);}
.footer-legal{display:flex;gap:20px;}
.footer-legal a{font-size:12.5px;color:rgba(255,255,255,.35);transition:color .2s;}
.footer-legal a:hover{color:white;}

/* ─────────────────────────────────────────────────────
  17. CITY MODAL
───────────────────────────────────────────────────── */
.city-modal-overlay{position:fixed;inset:0;background:rgba(6,14,26,.75);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:16px;}
.city-modal-box{background:white;border-radius:var(--r-xl);width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl);}
.city-modal-head{padding:22px 24px 0;display:flex;align-items:center;justify-content:space-between;}
.city-modal-title{font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--navy);display:flex;align-items:center;gap:8px;}
.modal-close{width:34px;height:34px;border-radius:50%;background:var(--gray-bg);display:flex;align-items:center;justify-content:center;transition:background .2s;}
.modal-close:hover{background:var(--gray-soft);}
.modal-close svg{stroke:var(--gray-text);}
.city-top-row{display:flex;gap:8px;padding:16px 20px 0;flex-wrap:wrap;}
.city-modal-all-btn,.city-modal-detect{flex:1;min-width:200px;display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:var(--r-md);background:var(--gray-bg);border:1.5px solid var(--gray-soft);cursor:pointer;transition:var(--trans);text-align:left;}
.city-modal-all-btn:hover,.city-modal-detect:hover{border-color:var(--sky);background:var(--pale);}
.city-detect-icon{width:36px;height:36px;border-radius:10px;background:white;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-xs);}
.city-detect-icon svg{stroke:var(--blue);}
.city-modal-all-btn strong,.city-modal-detect strong{font-size:13.5px;font-weight:700;color:var(--navy);display:block;}
.city-modal-all-btn small,.city-modal-detect small{font-size:11.5px;color:var(--gray-text);}
.city-detect-arrow{stroke:var(--gray-mid);margin-left:auto;flex-shrink:0;}
.city-modal-search-wrap{position:relative;margin:14px 20px 0;}
.city-modal-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);stroke:var(--gray-mid);pointer-events:none;}
.city-modal-search{width:100%;padding:12px 16px 12px 42px;border:1.5px solid var(--gray-soft);border-radius:var(--r-sm);font-size:14px;color:var(--dark);outline:none;transition:border-color .2s;}
.city-modal-search:focus{border-color:var(--sky);}
.city-modal-grid{padding:14px 20px 20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;overflow-y:auto;flex:1;}
.city-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--r-md);background:var(--gray-bg);border:1.5px solid transparent;cursor:pointer;transition:var(--trans);text-align:left;width:100%;}
.city-card:hover,.city-card--active{border-color:var(--sky);background:var(--pale);}
.city-card-emoji{font-size:20px;flex-shrink:0;}
.city-card-info strong{font-size:13px;font-weight:700;color:var(--navy);display:block;}
.city-card-info small{font-size:11px;color:var(--gray-text);}
.city-card-check{stroke:var(--blue);margin-left:auto;flex-shrink:0;}
.city-grid-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;gap:12px;color:var(--gray-text);grid-column:1/-1;}
.city-grid-loading svg{stroke:var(--sky);animation:spin 1.2s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─────────────────────────────────────────────────────
  18. SKELETONS & LOADING
───────────────────────────────────────────────────── */
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.sk-card,.sk-offer,.sk-blog,.sk-event{border-radius:var(--r-xl);overflow:hidden;background:linear-gradient(90deg,var(--gray-bg) 25%,var(--gray-soft) 50%,var(--gray-bg) 75%);background-size:200% 100%;animation:shimmer 1.6s infinite;}
.sk-card{height:280px;}
.sk-offer{height:220px;}
.sk-blog{height:300px;}
.sk-event{height:240px;}
.sk-recent-card{height:200px;border-radius:var(--r-xl);background:linear-gradient(90deg,var(--gray-bg) 25%,var(--gray-soft) 50%,var(--gray-bg) 75%);background-size:200% 100%;animation:shimmer 1.6s infinite;}

/* ─────────────────────────────────────────────────────
  19. PAGINATION
───────────────────────────────────────────────────── */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:40px;flex-wrap:wrap;}
.page-btn{min-width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);font-size:14px;font-weight:600;color:var(--gray-text);background:white;border:1.5px solid var(--gray-soft);transition:var(--trans);cursor:pointer;text-decoration:none;}
.page-btn:hover{border-color:var(--sky);color:var(--blue);}
.page-btn.active{background:var(--blue);color:white;border-color:var(--blue);}
.page-btn-nav{padding:0 14px;}

/* ─────────────────────────────────────────────────────
  20. EMPTY STATES
───────────────────────────────────────────────────── */
.empty-state{grid-column:1/-1;text-align:center;padding:64px 20px;color:var(--gray-text);}
.empty-state__icon{font-size:52px;margin-bottom:16px;}
.empty-state p{font-size:15px;line-height:1.65;}
.empty-state a{color:var(--blue);font-weight:600;}

/* ─────────────────────────────────────────────────────
  21. WHATSAPP FLOAT
───────────────────────────────────────────────────── */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:998;display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#25D366,#1da851);color:white;padding:13px 22px 13px 16px;border-radius:50px;font-family:var(--font-body);font-weight:700;font-size:14px;text-decoration:none;box-shadow:0 8px 28px rgba(37,211,102,.45);transition:var(--trans);}
.wa-float:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(37,211,102,.55);color:white;}
.wa-float__icon{width:30px;height:30px;flex-shrink:0;}
.wa-float__pulse{position:absolute;inset:0;border-radius:50px;background:rgba(37,211,102,.35);animation:waPulse 2.4s infinite;z-index:-1;}
@keyframes waPulse{0%{transform:scale(1);opacity:.6}70%{transform:scale(1.35);opacity:0}100%{opacity:0}}

/* ─────────────────────────────────────────────────────
  22. LOAD MORE / PAGINATION
───────────────────────────────────────────────────── */
.load-more-wrap{text-align:center;margin-top:40px;}
.load-more-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 36px;background:white;border:1.5px solid var(--gray-soft);border-radius:50px;font-size:14px;font-weight:700;color:var(--navy);cursor:pointer;transition:var(--trans);}
.load-more-btn:hover{border-color:var(--blue);color:var(--blue);}
.load-more-count{font-size:13px;color:var(--gray-text);text-align:center;margin-bottom:12px;}
.spinner{width:14px;height:14px;border:2px solid var(--gray-soft);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite;display:inline-block;}

/* ─────────────────────────────────────────────────────
  23. INDEX PAGE BLOG / OFFERS / EVENTS SECTION
───────────────────────────────────────────────────── */
.idx-blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.idx-blog-card{display:flex;flex-direction:column;background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-xl);overflow:hidden;transition:var(--trans);text-decoration:none;}
.idx-blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--sky-light);}
.idx-blog-card__img{height:160px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;}
.idx-blog-card__img img{width:100%;height:100%;object-fit:cover;}
.idx-blog-card__emoji{font-size:40px;}
.idx-blog-card__badge{position:absolute;top:10px;left:10px;background:var(--amber);color:var(--dark);font-size:10px;font-weight:800;padding:4px 10px;border-radius:20px;}
.idx-blog-card__body{padding:16px 18px 18px;flex:1;display:flex;flex-direction:column;}
.idx-blog-card__meta{font-size:11.5px;color:var(--gray-mid);margin-bottom:6px;}
.idx-blog-card__title{font-family:var(--font-display);font-size:16px;font-weight:800;color:var(--navy);line-height:1.35;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.idx-blog-card__cta{margin-top:auto;font-size:12px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:4px;}

/* filter bar */
.offers-filter-bar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px;}

/* ─────────────────────────────────────────────────────
  24. RESPONSIVE
───────────────────────────────────────────────────── */
@media(max-width:1024px){
  .biz-uniform-grid,.biz-grid,.offers-grid,.events-grid,.idx-blog-grid{grid-template-columns:repeat(2,1fr);}
  .recent-biz-cards-grid{grid-template-columns:repeat(2,1fr);}
  .biz-detail-layout{grid-template-columns:1fr;}
  .offer-detail-layout,.event-detail-layout{grid-template-columns:1fr;}
  .blog-detail-layout{grid-template-columns:1fr;}
  .footer-main{grid-template-columns:1fr 1fr;}
  .contact-layout{grid-template-columns:1fr;}
  .support-cats{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:680px){
  .biz-uniform-grid,.biz-grid,.offers-grid,.events-grid,.idx-blog-grid,.recent-biz-cards-grid,.blog-grid{grid-template-columns:1fr;}
  .cats-grid{grid-template-columns:1fr;}
  .hero-search{flex-wrap:wrap;border-radius:var(--r-md);}
  .hero-search-div{display:none;}
  .hero-city-pick{padding:10px 16px;border-top:1px solid var(--gray-soft);width:100%;}
  .hero-search-btn{width:100%;justify-content:center;border-radius:0 0 var(--r-md) var(--r-md);}
  .footer-main{grid-template-columns:1fr;}
  .footer-newsletter{flex-direction:column;gap:16px;}
  .footer-newsletter__form{max-width:100%;}
  .wa-float span:last-child{display:none;}
  .wa-float{padding:13px 16px;}
  .form-grid{grid-template-columns:1fr;}
  .support-cats{grid-template-columns:1fr;}
  .city-top-row{flex-direction:column;}
}

/* ─────────────────────────────────────────────────────
  25. BUSINESS FILTERS BAR
───────────────────────────────────────────────────── */
.biz-filters-bar{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:20px;align-items:center;}
.b-badge.subcat{background:#f0e6ff;color:#7c3aed;font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:20px;}

/* ─────────────────────────────────────────────────────
  26. LOGIN PAGE
───────────────────────────────────────────────────── */
.login-page{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;justify-content:center;padding:40px 20px;background:var(--gray-bg);}
.login-card{background:white;border-radius:var(--r-xl);border:1.5px solid var(--gray-soft);padding:clamp(28px,5vw,48px);width:100%;max-width:460px;box-shadow:var(--shadow-md);}
.login-divider{text-align:center;font-size:13px;color:var(--gray-mid);margin:20px 0;position:relative;}
.login-divider::before,.login-divider::after{content:'';position:absolute;top:50%;width:42%;height:1px;background:var(--gray-soft);}
.login-divider::before{left:0;} .login-divider::after{right:0;}

/* ─────────────────────────────────────────────────────
  27. ABOUT PAGE
───────────────────────────────────────────────────── */
.about-hero{position:relative;overflow:hidden;background:linear-gradient(168deg,#0c3360 0%,#1761b0 60%,#0e6e8a 100%);padding:clamp(80px,12vw,140px) 0 clamp(60px,10vw,100px);text-align:center;}
.about-hero__bg-dots{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.07) 1px,transparent 1px);background-size:28px 28px;}
.about-hero__glow-left{position:absolute;top:-100px;left:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(74,163,232,.25) 0%,transparent 70%);pointer-events:none;}
.about-hero__glow-right{position:absolute;bottom:-80px;right:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(245,165,35,.18) 0%,transparent 70%);pointer-events:none;}
.about-hero__inner{position:relative;z-index:1;max-width:780px;margin:0 auto;padding:0 var(--section-px);}
.about-hero__eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--amber);margin-bottom:20px;}
.about-hero__h1{font-family:var(--font-display);font-size:clamp(28px,5vw,56px);font-weight:800;color:white;line-height:1.1;letter-spacing:-.025em;margin-bottom:22px;}
.about-hero__h1 em{color:var(--amber);font-style:italic;}
.about-hero__sub{font-size:clamp(15px,1.7vw,18px);color:rgba(255,255,255,.72);line-height:1.78;max-width:600px;margin:0 auto 40px;}
.about-hero__stats{display:flex;align-items:center;justify-content:center;gap:0;flex-wrap:wrap;background:rgba(255,255,255,.08);border-radius:var(--r-xl);padding:24px 32px;border:1px solid rgba(255,255,255,.12);max-width:640px;margin:0 auto;}
.about-stat{text-align:center;padding:0 24px;}
.about-stat__num{font-family:var(--font-display);font-size:clamp(26px,4vw,40px);font-weight:800;color:var(--amber);line-height:1;}
.about-stat__label{font-size:12px;color:rgba(255,255,255,.55);margin-top:4px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;}
.about-stat__divider{width:1px;height:40px;background:rgba(255,255,255,.18);}

.about-mission{padding:var(--section-py) 0;background:white;}
.about-mission__inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--section-px);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;}
.about-mission__body{font-size:15px;color:var(--gray-text);line-height:1.8;margin-top:14px;}
.about-mission__card{background:var(--gray-bg);border-radius:var(--r-lg);padding:24px;margin-bottom:16px;border:1.5px solid var(--gray-soft);transition:var(--trans);}
.about-mission__card:hover{border-color:var(--sky-light);box-shadow:var(--shadow-sm);}
.about-mission__card--highlight{background:var(--pale);border-color:var(--sky-light);}
.about-mission__card-icon{font-size:26px;display:block;margin-bottom:10px;}
.about-mission__card h3{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.about-mission__card p{font-size:14px;color:var(--gray-text);line-height:1.7;}

.compare-table{border-radius:var(--r-xl);overflow:hidden;border:1.5px solid var(--gray-soft);margin-top:32px;}
.compare-header{display:grid;grid-template-columns:2fr 1.5fr 1.5fr;background:var(--navy);}
.col-head{padding:16px 20px;font-size:13px;font-weight:700;color:rgba(255,255,255,.6);text-align:center;}
.col-head.zoovit{color:var(--amber);}
.col-head.others{color:rgba(255,255,255,.5);}
.zoovit-star{display:inline-block;background:var(--amber);color:var(--dark);font-size:9px;padding:2px 8px;border-radius:20px;margin-left:6px;font-weight:800;letter-spacing:.04em;vertical-align:middle;}
.compare-row{display:grid;grid-template-columns:2fr 1.5fr 1.5fr;border-bottom:1px solid var(--gray-soft);}
.compare-row:last-child{border-bottom:none;}
.compare-row:nth-child(even){background:var(--gray-bg);}
.compare-cell{padding:14px 20px;font-size:14px;display:flex;align-items:center;gap:8px;}
.compare-cell.label{font-weight:600;color:var(--navy);}
.compare-cell.yes{color:#1a7a40;}
.compare-cell.no{color:#c04a00;}
.yes-icon,.no-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.yes-icon{background:#dcfce7;}
.no-icon{background:#fee2e2;}
.yes-icon svg,.no-icon svg{width:12px;height:12px;}

.about-values{padding:var(--section-py) 0;background:white;}
.about-values__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px;}
.about-value-card{background:var(--gray-bg);border-radius:var(--r-xl);padding:28px 24px;border:1.5px solid var(--gray-soft);position:relative;overflow:hidden;transition:var(--trans);}
.about-value-card:hover{border-color:var(--sky-light);box-shadow:var(--shadow-sm);transform:translateY(-4px);}
.about-value-card__num{font-family:var(--font-display);font-size:48px;font-weight:900;color:var(--gray-soft);position:absolute;top:-10px;right:16px;line-height:1;}
.about-value-card__icon{font-size:28px;display:block;margin-bottom:14px;}
.about-value-card h3{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--navy);margin-bottom:10px;}
.about-value-card p{font-size:14px;color:var(--gray-text);line-height:1.72;}

.about-diff{padding:var(--section-py) 0;background:var(--gray-bg);}
.about-diff__inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--section-px);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.about-diff__list{list-style:none;margin-top:28px;display:flex;flex-direction:column;gap:14px;}
.about-diff__list li{display:flex;gap:12px;font-size:15px;color:var(--gray-text);line-height:1.65;}
.about-diff__list li strong{color:var(--navy);}
.about-diff__list-icon{width:22px;height:22px;background:#dcfce7;color:#16a34a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;margin-top:2px;}
.about-diff__visual{position:relative;height:380px;}
.about-diff__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:white;border-radius:var(--r-xl);padding:20px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:8px;font-family:var(--font-display);font-weight:800;color:var(--navy);font-size:15px;z-index:2;}
.about-diff__bubble{position:absolute;background:white;border-radius:50px;padding:10px 18px;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:var(--navy);box-shadow:var(--shadow-sm);border:1.5px solid var(--gray-soft);}
.about-diff__bubble-icon{font-size:18px;}
.about-diff__bubble--1{top:10%;left:5%;}
.about-diff__bubble--2{top:10%;right:5%;}
.about-diff__bubble--3{bottom:10%;left:5%;}
.about-diff__bubble--4{bottom:10%;right:5%;}

.stakes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px;}
.stake-card{background:var(--navy);border-radius:var(--r-xl);padding:32px 28px;transition:var(--trans);}
.stake-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);}
.stake-num{font-family:var(--font-display);font-size:clamp(36px,5vw,52px);font-weight:900;color:var(--amber);margin-bottom:12px;line-height:1;}
.stake-card h4{font-family:var(--font-display);font-size:17px;font-weight:700;color:white;margin-bottom:8px;}
.stake-card p{font-size:14px;color:rgba(255,255,255,.58);line-height:1.72;}

.about-team{padding:var(--section-py) 0;background:var(--gray-bg);}
.about-team__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:36px;}
.about-team-card{background:white;border-radius:var(--r-xl);padding:28px 22px;text-align:center;border:1.5px solid var(--gray-soft);transition:var(--trans);}
.about-team-card:hover{box-shadow:var(--shadow-md);border-color:var(--sky-light);transform:translateY(-4px);}
.about-team-card__avatar{width:70px;height:70px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:800;font-size:22px;color:white;margin:0 auto 16px;}
.about-team-card__name{font-family:var(--font-display);font-size:16px;font-weight:800;color:var(--navy);margin-bottom:4px;}
.about-team-card__role{font-size:13px;color:var(--blue);font-weight:600;margin-bottom:12px;}
.about-team-card__bio{font-size:13.5px;color:var(--gray-text);line-height:1.7;margin-bottom:16px;}
.about-team-card__links{display:flex;gap:8px;justify-content:center;}
.about-team-card__link{width:32px;height:32px;background:var(--pale);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--blue);transition:background .2s;}
.about-team-card__link:hover{background:var(--sky-light);}

.about-timeline{padding:var(--section-py) 0;background:white;}
.about-timeline__inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--section-px);display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:start;}
.about-timeline__steps{display:flex;flex-direction:column;gap:0;position:relative;margin-top:8px;}
.about-timeline__steps::before{content:'';position:absolute;left:14px;top:16px;bottom:16px;width:2px;background:var(--gray-soft);}
.about-tl-item{display:flex;gap:20px;padding-bottom:32px;position:relative;}
.about-tl-item__dot{width:30px;height:30px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;}
.about-tl-item__dot--done{background:var(--blue);}
.about-tl-item__dot--done::after{content:'✓';color:white;font-size:13px;font-weight:800;}
.about-tl-item__dot--active{background:var(--amber);}
.about-tl-item__dot--active::after{content:'●';color:white;font-size:10px;}
.about-tl-item__dot--future{background:var(--gray-soft);}
.about-tl-item__dot--future::after{content:'○';color:var(--gray-mid);font-size:12px;}
.about-tl-item__content{padding-top:4px;}
.about-tl-item__date{font-size:12px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;}
.about-tl-item__content h3{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.about-tl-item__content p{font-size:14px;color:var(--gray-text);line-height:1.7;}

.about-cta-band{background:linear-gradient(135deg,var(--navy),#1761b0);padding:clamp(48px,8vw,80px) 0;}
.about-cta-band__inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--section-px);display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.about-cta-band__h2{font-family:var(--font-display);font-size:clamp(22px,3.5vw,34px);font-weight:800;color:white;margin-bottom:8px;}
.about-cta-band__sub{font-size:15px;color:rgba(255,255,255,.65);}
.about-cta-band__actions{display:flex;align-items:center;gap:20px;flex-wrap:wrap;flex-shrink:0;}
.about-cta-band__link{font-size:14px;font-weight:700;color:rgba(255,255,255,.75);text-decoration:none;transition:color .2s;}
.about-cta-band__link:hover{color:white;}

/* ─────────────────────────────────────────────────────
  28. ABOUT PAGE RESPONSIVE
───────────────────────────────────────────────────── */
@media(max-width:1024px){
  .about-mission__inner,.about-diff__inner,.about-timeline__inner{grid-template-columns:1fr;gap:36px;}
  .about-values__grid,.about-team__grid{grid-template-columns:repeat(2,1fr);}
  .stakes-grid{grid-template-columns:repeat(2,1fr);}
  .compare-row{grid-template-columns:1fr 1fr 1fr;}
  .about-diff__visual{height:260px;}
  .about-cta-band__inner{flex-direction:column;text-align:center;}
}
@media(max-width:680px){
  .about-hero__stats{flex-direction:column;gap:16px;}
  .about-stat__divider{display:none;}
  .about-values__grid,.about-team__grid,.stakes-grid{grid-template-columns:1fr;}
  .compare-cell.label{display:none;}
  .compare-row,.compare-header{grid-template-columns:1fr 1fr;}
  .col-head:first-child{display:none;}
  .about-diff__visual{display:none;}
  .about-timeline__steps::before{display:none;}
}

/* ─────────────────────────────────────────────────────
  29. REDESIGNED CATEGORIES PAGE
───────────────────────────────────────────────────── */
.cats-full-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;}
.cat-full-card{background:white;border:1.5px solid var(--gray-soft);border-radius:var(--r-xl);overflow:hidden;transition:var(--trans);}
.cat-full-card:hover{box-shadow:var(--shadow-md);border-color:var(--sky-light);}
.cat-full-header{display:flex;align-items:center;gap:14px;padding:18px 20px;text-decoration:none;transition:background .2s;}
.cat-full-header:hover{background:var(--pale);}
.cat-full-icon{width:48px;height:48px;border-radius:12px;background:var(--pale);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;border:1.5px solid var(--sky-light);}
.cat-full-info{flex:1;min-width:0;}
.cat-full-name{font-family:var(--font-display);font-size:17px;font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:3px;}
.cat-full-counts{font-size:12px;color:var(--gray-text);}
.cat-count-dot{margin:0 4px;color:var(--gray-mid);}
.cat-full-arrow{color:var(--blue);flex-shrink:0;opacity:.6;transition:opacity .2s,transform .2s;}
.cat-full-header:hover .cat-full-arrow{opacity:1;transform:translateX(3px);}
.cat-full-subcats{display:flex;flex-wrap:wrap;gap:6px;padding:0 18px 16px;border-top:1px solid var(--gray-soft);padding-top:12px;}
.cat-sub-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 11px 5px 8px;background:var(--gray-bg);border:1px solid var(--gray-soft);border-radius:20px;text-decoration:none;font-size:12px;color:var(--gray-text);transition:var(--trans-fast);font-weight:500;}
.cat-sub-chip:hover{background:var(--pale);border-color:var(--sky);color:var(--blue);}
.cat-sub-icon{font-size:13px;line-height:1;}
.cat-sub-name{line-height:1.2;}
.cat-sub-count{background:var(--navy);color:white;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px;margin-left:2px;}

/* Tighter spacing globally */
:root { --section-py: clamp(36px,5vw,72px); }
.section-header{margin-bottom:24px;}
.page-hero{padding:clamp(24px,4vw,48px) 0 clamp(20px,3vw,36px);}

@media(max-width:680px){
  .cats-full-grid{grid-template-columns:1fr;}
}

/* ─────────────────────────────────────────────────────
  30. BUSINESS DETAIL ENHANCEMENTS
───────────────────────────────────────────────────── */
.biz-tab-count{display:inline-flex;align-items:center;justify-content:center;background:var(--blue);color:white;font-size:10px;font-weight:800;min-width:18px;height:18px;padding:0 5px;border-radius:20px;margin-left:5px;vertical-align:middle;}
.biz-tab.active .biz-tab-count{background:white;color:var(--blue);}

/* Listing header flex for add-business button */
.listing-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px;}

/* ─────────────────────────────────────────────────────
  31. OFFER DETAIL & EVENT DETAIL PAGES
───────────────────────────────────────────────────── */
.offer-code-box{background:var(--gray-bg);border-radius:var(--r-lg);padding:18px 20px;border:1.5px dashed var(--sky);}
.offer-code-box__label{font-size:11px;font-weight:700;color:var(--gray-mid);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;}
.offer-code-box__inner{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.offer-code-box__code{font-family:var(--font-display);font-weight:900;color:var(--navy);}
.offer-code-box__hint{font-size:12px;color:var(--gray-text);}
.offer-detail-layout{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start;}
.event-detail-layout{display:grid;grid-template-columns:1fr 320px;gap:24px;align-items:start;}
.offer-detail-sidebar{background:white;border-radius:var(--r-xl);padding:22px;border:1.5px solid var(--gray-soft);}
@media(max-width:900px){
  .offer-detail-layout,.event-detail-layout{grid-template-columns:1fr;}
}

/* ─────────────────────────────────────────────────────
  30. ADD BUSINESS MODAL / FORM GRID
───────────────────────────────────────────────────── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group label{font-size:13px;font-weight:600;color:var(--navy);}
.form-group input,.form-group textarea,.form-group select{
  padding:10px 14px;border:1.5px solid var(--gray-soft);border-radius:var(--r-md);
  font-size:14px;color:var(--navy);font-family:var(--font-body);outline:none;
  transition:border-color .2s;background:white;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--sky);}
.form-submit{width:100%;padding:13px;background:var(--blue);color:white;border:none;
  border-radius:var(--r-md);font-family:var(--font-display);font-size:15px;font-weight:700;
  cursor:pointer;transition:background .2s;}
.form-submit:hover{background:var(--navy);}
@media(max-width:520px){.form-grid{grid-template-columns:1fr;}}

/* ─────────────────────────────────────────────────────
  31. PRODUCT COMING SOON STATE (already styled inline)
     + event/offer card as <a> fix
───────────────────────────────────────────────────── */
a.event-card{display:flex;flex-direction:column;}
a.offer-card{display:flex;flex-direction:column;}
