/* ============================================================
   LocalDir — Main Stylesheet v2 (Mobile-First)
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --primary:#1a73e8;--primary-dark:#1557b0;--primary-light:#e8f0fe;
  --green:#34a853;--green-light:#e6f4ea;--orange:#fa7b17;--red:#ea4335;
  --yellow:#fbbc04;--dark:#202124;--gray-900:#3c4043;--gray-700:#5f6368;
  --gray-500:#80868b;--gray-300:#dadce0;--gray-100:#f1f3f4;--white:#ffffff;
  --bg:#f8f9fa;
  --shadow:0 1px 3px rgba(60,64,67,.3),0 2px 6px rgba(60,64,67,.12);
  --shadow-lg:0 1px 3px rgba(60,64,67,.3),0 8px 16px rgba(60,64,67,.18);
  --radius:12px;--radius-sm:8px;
  --font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--gray-900);line-height:1.6}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
input,select,textarea,button{font-family:var(--font)}

/* ─── Layout ─────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 16px}
.container--narrow{max-width:800px}

/* ─── Site Header ────────────── */
.site-header{background:var(--white);border-bottom:1px solid var(--gray-300);position:sticky;top:0;z-index:1000;box-shadow:0 1px 4px rgba(60,64,67,.12)}
.site-header__inner{display:flex;align-items:center;gap:12px;height:56px;padding:0 16px}
.site-logo{font-size:1.3rem;font-weight:800;color:var(--primary);white-space:nowrap;text-decoration:none;flex-shrink:0}
.site-logo span{color:var(--orange)}
.header-search{flex:1;max-width:480px;display:flex;border:1.5px solid var(--gray-300);border-radius:24px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.header-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,115,232,.15)}
.header-search input{flex:1;border:none;padding:8px 16px;font-size:.88rem;outline:none}
.header-search button{background:var(--primary);color:var(--white);border:none;padding:0 16px;cursor:pointer;font-size:.88rem;font-weight:600}
.header-nav{display:flex;align-items:center;gap:6px;margin-left:auto}
.header-nav a{color:var(--gray-700);font-size:.83rem;font-weight:500;padding:6px 9px;border-radius:6px;text-decoration:none;white-space:nowrap}
.header-nav a:hover{background:var(--gray-100);color:var(--primary)}
.header-nav .btn-list{background:var(--primary);color:var(--white);padding:7px 13px;border-radius:20px;font-size:.82rem}
.header-nav .btn-list:hover{background:var(--primary-dark);text-decoration:none}

/* Hamburger */
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto;flex-direction:column;justify-content:space-between;width:32px;height:26px;flex-shrink:0}
.hamburger span{display:block;height:3px;background:var(--gray-700);border-radius:2px;transition:all .25s}
.hamburger.open span:nth-child(1){transform:translateY(9px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* Mobile nav drawer */
.mobile-nav{display:none;background:var(--white);border-top:1px solid var(--gray-100);box-shadow:0 4px 12px rgba(0,0,0,.1)}
.mobile-nav.open{display:block}
.mobile-nav a{display:flex;align-items:center;padding:13px 18px;color:var(--gray-700);font-size:.93rem;font-weight:500;border-bottom:1px solid var(--gray-100);text-decoration:none}
.mobile-nav a:hover{background:var(--gray-100);color:var(--primary)}
.mobile-nav .btn-list-mobile{display:block;margin:12px 16px;background:var(--primary);color:var(--white);text-align:center;padding:13px;border-radius:8px;font-weight:700;font-size:.95rem}
.mobile-nav .btn-list-mobile:hover{background:var(--primary-dark);text-decoration:none}

/* Mobile search bar */
.mobile-search-bar{display:none;padding:9px 14px;background:var(--white);border-bottom:1px solid var(--gray-100)}
.mobile-search-bar form{display:flex;border:1.5px solid var(--gray-300);border-radius:8px;overflow:hidden}
.mobile-search-bar input{flex:1;border:none;padding:10px 13px;font-size:.92rem;outline:none}
.mobile-search-bar button{background:var(--primary);color:var(--white);border:none;padding:0 15px;cursor:pointer;font-size:.92rem;font-weight:600}

/* ─── Hero ───────────────────── */
.hero{background:linear-gradient(135deg,#1a73e8 0%,#0d47a1 100%);padding:40px 0 34px;text-align:center;color:var(--white)}
.hero__title{font-size:1.65rem;font-weight:800;margin-bottom:8px;line-height:1.3}
.hero__title em{color:#fbbc04;font-style:normal}
.hero__subtitle{font-size:.93rem;opacity:.9;margin-bottom:22px}
.hero-search{display:flex;max-width:600px;margin:0 auto 16px;background:var(--white);border-radius:50px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.25)}
.hero-search input{flex:1;border:none;padding:14px 20px;font-size:.95rem;outline:none;color:var(--dark)}
.hero-search button{background:var(--orange);color:var(--white);border:none;padding:0 24px;font-size:.95rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s}
.hero-search button:hover{background:#e06510}
.hero-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:6px}
.hero-tag{background:rgba(255,255,255,.18);color:var(--white);padding:5px 12px;border-radius:20px;font-size:.81rem;text-decoration:none;transition:background .2s}
.hero-tag:hover{background:rgba(255,255,255,.32);text-decoration:none}

/* ─── Stats Bar ──────────────── */
.stats-bar{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(4,1fr);overflow:hidden;margin-bottom:32px}
.stat-item{padding:16px 12px;text-align:center;border-right:1px solid var(--gray-100)}
.stat-item:last-child{border-right:none}
.stat-item__val{font-size:1.4rem;font-weight:800;color:var(--primary);line-height:1}
.stat-item__label{font-size:.71rem;color:var(--gray-500);margin-top:4px}

/* ─── Section ────────────────── */
.section{padding:32px 0}
.section__title{font-size:1.2rem;font-weight:700;color:var(--dark);margin-bottom:4px}
.section__sub{color:var(--gray-500);font-size:.86rem;margin-bottom:18px}
.section__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px}
.section__header .see-all{font-size:.84rem}

/* ─── Category Grid ──────────── */
.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}
.cat-card{background:var(--white);border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);padding:14px 8px;text-align:center;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;text-decoration:none;color:var(--gray-900);display:block}
.cat-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px);text-decoration:none;color:var(--primary)}
.cat-card__icon{font-size:1.6rem;margin-bottom:6px}
.cat-card__name{font-size:.74rem;font-weight:600;line-height:1.3}

/* ─── Business Card ──────────── */
.business-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.biz-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .2s,transform .15s;display:flex;flex-direction:column}
.biz-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.biz-card__cover{height:120px;background:var(--gray-100);overflow:hidden;position:relative}
.biz-card__cover img{width:100%;height:100%;object-fit:cover}
.biz-card__badge{position:absolute;top:8px;left:8px;color:var(--white);font-size:.67rem;font-weight:700;padding:3px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}
.biz-card__badge.featured{background:var(--yellow);color:var(--dark)}
.biz-card__badge.premium{background:linear-gradient(135deg,#7b2ff7,#c53364)}
.biz-card__badge.new-badge{background:var(--orange)}
.biz-card__badge.verified{background:var(--green)}
.biz-card__body{padding:12px 14px;flex:1}
.biz-card__logo-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.biz-card__logo{width:44px;height:44px;border-radius:8px;object-fit:cover;background:var(--gray-100);flex-shrink:0;border:1.5px solid var(--gray-300)}
.biz-card__name{font-size:.93rem;font-weight:700;color:var(--dark);line-height:1.3}
.biz-card__name a{color:inherit}
.biz-card__name a:hover{color:var(--primary);text-decoration:none}
.biz-card__cat{font-size:.74rem;color:var(--primary);font-weight:500;margin-bottom:3px}
.biz-card__rating{display:flex;align-items:center;gap:4px;font-size:.81rem;margin-bottom:5px}
.stars{color:var(--yellow);font-size:.87rem;letter-spacing:-1px}
.rating-score{font-weight:700;color:var(--dark)}
.review-count{color:var(--gray-500);font-size:.76rem}
.biz-card__address{font-size:.78rem;color:var(--gray-500);margin-bottom:3px}
.biz-card__urgency{font-size:.74rem;color:var(--red);font-weight:600;margin-top:3px}
.biz-card__actions{padding:8px 14px 12px;display:flex;gap:6px;flex-wrap:wrap}

/* ─── List Item ──────────────── */
.biz-list-item{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px;display:flex;gap:14px;transition:box-shadow .2s;margin-bottom:12px}
.biz-list-item:hover{box-shadow:var(--shadow-lg)}
.biz-list-item__logo{width:64px;height:64px;border-radius:var(--radius-sm);object-fit:cover;background:var(--gray-100);flex-shrink:0;border:1.5px solid var(--gray-300)}
.biz-list-item__content{flex:1;min-width:0}
.biz-list-item__name{font-size:.97rem;font-weight:700;color:var(--dark);margin-bottom:2px}
.biz-list-item__meta{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-bottom:5px;font-size:.79rem;color:var(--gray-500)}
.biz-list-item__desc{font-size:.83rem;color:var(--gray-700);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.biz-list-item__actions{display:flex;gap:6px;flex-wrap:wrap}

/* ─── Action Buttons ─────────── */
.btn-wa{background:#25d366;color:var(--white);border:none;padding:7px 13px;border-radius:20px;font-size:.79rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:background .2s;text-decoration:none;white-space:nowrap;-webkit-appearance:none}
.btn-wa:hover{background:#1db954;text-decoration:none;color:var(--white)}
.btn-dir{background:var(--primary-light);color:var(--primary);border:1.5px solid var(--primary);padding:7px 13px;border-radius:20px;font-size:.79rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;text-decoration:none;white-space:nowrap;transition:background .2s}
.btn-dir:hover{background:var(--primary);color:var(--white);text-decoration:none}
.btn-web{background:var(--gray-100);color:var(--gray-700);border:1.5px solid var(--gray-300);padding:7px 13px;border-radius:20px;font-size:.79rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;text-decoration:none;white-space:nowrap;transition:background .2s}
.btn-web:hover{background:var(--gray-300);text-decoration:none;color:var(--dark)}
.btn-call{background:var(--green);color:var(--white);border:none;padding:7px 13px;border-radius:20px;font-size:.79rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;text-decoration:none;white-space:nowrap;transition:background .2s}
.btn-call:hover{background:#2a8844;text-decoration:none;color:var(--white)}

/* ─── Listing Detail ─────────── */
.listing-layout{display:grid;grid-template-columns:1fr 300px;gap:24px;padding:18px 0 40px}
.listing-cover{border-radius:var(--radius);overflow:hidden;height:400px;background:var(--gray-100);margin-bottom:16px}
.listing-cover img{width:100%;height:100%;object-fit:cover;display:block}
.listing-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px}
.listing-logo{width:68px;height:68px;border-radius:var(--radius-sm);object-fit:cover;border:2px solid var(--gray-300);flex-shrink:0}
.listing-title{font-size:1.5rem;font-weight:800;color:var(--dark);line-height:1.2}
.listing-cat-badge{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:.77rem;font-weight:600;padding:3px 10px;border-radius:20px;margin-top:5px}
.listing-badges{display:flex;gap:5px;flex-wrap:wrap;margin-top:7px}
.badge{display:inline-block;font-size:.69rem;font-weight:700;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:.04em}
.badge--featured{background:var(--yellow);color:var(--dark)}
.badge--premium{background:linear-gradient(135deg,#7b2ff7,#c53364);color:var(--white)}
.badge--verified{background:var(--green);color:var(--white)}
.listing-actions{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}

/* ─── Info Cards ─────────────── */
.info-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:16px}
.info-card__title{font-size:.73rem;font-weight:700;text-transform:uppercase;color:var(--gray-500);letter-spacing:.07em;margin-bottom:12px}
.info-row{display:flex;gap:10px;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--gray-100);font-size:.87rem}
.info-row:last-child{border-bottom:none}
.info-row__icon{font-size:.93rem;color:var(--gray-500);width:20px;flex-shrink:0;margin-top:1px}
.info-row__label{color:var(--gray-500);font-size:.77rem;min-width:65px}
.info-row__val{color:var(--dark);flex:1}

/* ─── Sidebar ────────────────── */
.sidebar-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:16px}
.sidebar-card__title{font-size:.88rem;font-weight:700;color:var(--dark);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--gray-100)}

/* ─── Quote CTA ──────────────── */
.quote-cta{background:linear-gradient(135deg,var(--primary),#0d47a1);color:var(--white);border-radius:var(--radius);padding:20px;text-align:center;margin-bottom:16px}
.quote-cta h3{font-size:.97rem;margin-bottom:6px}
.quote-cta p{font-size:.83rem;opacity:.9;margin-bottom:12px}
.btn-quote{display:block;background:var(--white);color:var(--primary);font-weight:700;padding:11px 16px;border-radius:8px;font-size:.88rem;text-align:center;transition:background .2s;text-decoration:none}
.btn-quote:hover{background:var(--primary-light);text-decoration:none}

/* ─── Reviews ────────────────── */
.review-item{padding:12px 0;border-bottom:1px solid var(--gray-100)}
.review-item:last-child{border-bottom:none}
.review-item__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.review-item__name{font-weight:600;font-size:.87rem;color:var(--dark)}
.review-item__date{font-size:.74rem;color:var(--gray-500)}
.review-item__text{font-size:.84rem;color:var(--gray-700);line-height:1.5}

/* ─── Forms ──────────────────── */
.form-group{margin-bottom:15px}
.form-label{display:block;font-size:.84rem;font-weight:600;color:var(--gray-900);margin-bottom:5px}
.form-control{width:100%;padding:10px 13px;border:1.5px solid var(--gray-300);border-radius:var(--radius-sm);font-size:.92rem;font-family:var(--font);color:var(--dark);transition:border-color .2s,box-shadow .2s;background:var(--white);-webkit-appearance:none;appearance:none}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,115,232,.15)}
.form-control.is-invalid{border-color:var(--red)}
textarea.form-control{min-height:88px;resize:vertical}
select.form-control{cursor:pointer}
.form-hint{font-size:.74rem;color:var(--gray-500);margin-top:4px}
.btn-primary{background:var(--primary);color:var(--white);border:none;padding:11px 22px;border-radius:var(--radius-sm);font-size:.92rem;font-weight:600;cursor:pointer;transition:background .2s;display:inline-block;text-align:center;text-decoration:none;-webkit-appearance:none;touch-action:manipulation}
.btn-primary:hover{background:var(--primary-dark);text-decoration:none;color:var(--white)}
.btn-primary.full{width:100%;display:block;padding:13px}
.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1.5px solid var(--gray-300);padding:10px 20px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;display:inline-block;text-decoration:none}
.btn-secondary:hover{background:var(--gray-300);text-decoration:none;color:var(--dark)}

/* ─── Alerts ─────────────────── */
.alert{padding:11px 14px;border-radius:var(--radius-sm);font-size:.87rem;margin-bottom:16px}
.alert-success{background:var(--green-light);color:#065f46;border-left:4px solid var(--green)}
.alert-error{background:#fee2e2;color:#991b1b;border-left:4px solid var(--red)}
.alert-info{background:var(--primary-light);color:#1e40af;border-left:4px solid var(--primary)}
.alert-warning{background:#fef9c3;color:#78350f;border-left:4px solid var(--yellow)}

/* ─── Pagination ─────────────── */
.pagination{display:flex;justify-content:center;gap:5px;padding:18px 0;flex-wrap:wrap}
.page-btn{display:inline-block;padding:7px 12px;border:1.5px solid var(--gray-300);border-radius:6px;color:var(--gray-700);font-size:.84rem;font-weight:500;text-decoration:none;transition:all .15s}
.page-btn:hover,.page-btn.active{background:var(--primary);border-color:var(--primary);color:var(--white);text-decoration:none}

/* ─── Star Rating ────────────── */
.star-rating{display:flex;gap:3px}
.star-rating input{display:none}
.star-rating label{font-size:1.5rem;color:var(--gray-300);cursor:pointer;transition:color .1s}

/* ─── Map ────────────────────── */
.map-embed{border-radius:var(--radius-sm);overflow:hidden;background:var(--gray-100);height:200px;display:flex;align-items:center;justify-content:center}
.map-embed iframe{width:100%;height:100%;border:none}

/* ─── Modal ──────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:9000;align-items:flex-end;justify-content:center;padding:0}
.modal-overlay.active{display:flex}
.modal{background:var(--white);width:100%;max-width:480px;border-radius:16px 16px 0 0;box-shadow:0 -4px 30px rgba(0,0,0,.2);animation:slideUp .28s ease;overflow:hidden}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal__header{background:#25d366;color:var(--white);padding:16px 18px;display:flex;align-items:center;justify-content:space-between}
.modal__header h3{font-size:.95rem;font-weight:700}
.modal__close{background:none;border:none;color:var(--white);font-size:1.4rem;cursor:pointer;line-height:1;padding:0;touch-action:manipulation}
.modal__body{padding:18px;max-height:72vh;overflow-y:auto;-webkit-overflow-scrolling:touch}

/* ─── Breadcrumb ─────────────── */
.breadcrumb{display:flex;flex-wrap:wrap;gap:4px;align-items:center;font-size:.78rem;color:var(--gray-500);padding:8px 0}
.breadcrumb a{color:var(--primary)}
.breadcrumb__sep{color:var(--gray-300)}

/* ─── Gallery ────────────────── */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px;margin-top:8px}
.gallery-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;cursor:pointer;transition:opacity .2s}
.gallery-grid img:hover{opacity:.85}

/* ─── Lightbox ───────────────── */
#lightbox{cursor:pointer}
#lightbox img{max-width:92vw;max-height:84vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.5)}

/* ─── SEO Page ───────────────── */
.seo-intro{background:var(--white);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);margin-bottom:18px;font-size:.92rem;line-height:1.8;color:var(--gray-700)}
/* ─── FAQ Accordion ─────────────────────────────────────── */
/* Initial state: .faq-a has inline style="display:none" in HTML */
/* JS controls toggle via element.style.display — no CSS needed  */
/* for show/hide. CSS below is purely visual styling.            */

.faq-item {
  border-bottom: 1px solid var(--gray-100);
}
.faq-item:last-child { border-bottom: none; }

.faq-q {
  font-weight: 600;
  color: var(--dark);
  font-size: .92rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 14px 0;
  cursor: pointer;
  user-select: none;
  min-height: 48px; /* large tap target on mobile */
  -webkit-tap-highlight-color: transparent;
  transition: color .15s;
}
.faq-q:hover { color: var(--primary); }

.faq-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--gray-100);
  color: var(--gray-700);
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
  transition: background .2s, color .2s, transform .25s;
  line-height: 1;
}

.faq-item.faq-open .faq-q { color: var(--primary); }
.faq-item.faq-open .faq-icon {
  background: var(--primary-light);
  color: var(--primary);
  transform: rotate(45deg);
}

.faq-a {
  font-size: .87rem;
  color: var(--gray-700);
  line-height: 1.75;
  padding-bottom: 14px;
  /* display controlled by JS inline style */
}

/* ─── Admin Panel ────────────── */
.admin-layout{display:flex;min-height:100vh}
.admin-sidebar{width:230px;background:#1a1a2e;color:rgba(255,255,255,.8);flex-shrink:0;display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;overflow-y:auto;transition:transform .3s;z-index:800}
.admin-sidebar__logo{padding:18px 16px;font-size:1.1rem;font-weight:800;color:var(--white);border-bottom:1px solid rgba(255,255,255,.1)}
.admin-sidebar__logo span{color:var(--orange)}
.admin-nav{padding:8px 0;flex:1}
.admin-nav a{display:flex;align-items:center;gap:9px;padding:9px 16px;color:rgba(255,255,255,.7);font-size:.84rem;text-decoration:none;transition:background .15s,color .15s}
.admin-nav a:hover,.admin-nav a.active{background:rgba(255,255,255,.1);color:var(--white)}
.admin-nav a .nav-icon{font-size:.92rem;width:18px;text-align:center}
.admin-nav .nav-sep{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.3);padding:11px 16px 3px}
.admin-main{flex:1;margin-left:230px;background:var(--bg);min-height:100vh}
.admin-topbar{background:var(--white);border-bottom:1px solid var(--gray-300);padding:0 22px;height:54px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 1px 4px rgba(60,64,67,.1)}
.admin-topbar h1{font-size:1.05rem;font-weight:700;color:var(--dark)}
.admin-content{padding:20px}
.admin-menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;margin-right:8px}
.admin-menu-btn span{display:block;width:22px;height:2px;background:var(--gray-700);margin:4px 0;border-radius:2px}
.admin-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:14px;margin-bottom:22px}
.admin-card{background:var(--white);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:12px}
.admin-card__icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.admin-card__val{font-size:1.45rem;font-weight:800;color:var(--dark);line-height:1}
.admin-card__label{font-size:.73rem;color:var(--gray-500);margin-top:2px}
.table-wrapper{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:auto}
table{width:100%;border-collapse:collapse;font-size:.84rem}
thead th{background:var(--gray-100);padding:10px 13px;text-align:left;font-size:.73rem;font-weight:700;text-transform:uppercase;color:var(--gray-500);letter-spacing:.05em;white-space:nowrap}
tbody td{padding:10px 13px;border-top:1px solid var(--gray-100);vertical-align:middle}
tbody tr:hover{background:var(--bg)}
.badge-status{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.69rem;font-weight:700;text-transform:uppercase}
.badge-status.active{background:var(--green-light);color:var(--green)}
.badge-status.pending{background:#fef9c3;color:#78350f}
.badge-status.rejected{background:#fee2e2;color:var(--red)}
.badge-status.inactive{background:var(--gray-100);color:var(--gray-500)}
.badge-status.approved{background:var(--green-light);color:var(--green)}
.btn-sm{padding:5px 11px;font-size:.74rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;text-decoration:none;display:inline-block;transition:opacity .15s;white-space:nowrap}
.btn-sm:hover{opacity:.85;text-decoration:none}
.btn-approve{background:var(--green-light);color:var(--green)}
.btn-reject{background:#fee2e2;color:var(--red)}
.btn-edit{background:var(--primary-light);color:var(--primary)}
.btn-delete{background:#fee2e2;color:var(--red)}
.btn-view{background:var(--gray-100);color:var(--gray-700)}

/* ─── Owner ──────────────────── */
.owner-header{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:var(--white);padding:22px 0;margin-bottom:22px}

/* ─── Misc ───────────────────── */
.text-center{text-align:center}.text-muted{color:var(--gray-500)}
.mt-2{margin-top:12px}.mt-3{margin-top:20px}.mt-4{margin-top:32px}
.mb-2{margin-bottom:12px}.mb-3{margin-bottom:20px}
.fw-bold{font-weight:700}
.empty-state{text-align:center;padding:40px 16px;color:var(--gray-500)}
.empty-state__icon{font-size:2.5rem;margin-bottom:10px;opacity:.5}
.tag-cloud{display:flex;flex-wrap:wrap;gap:7px}
.tag-chip{background:var(--gray-100);padding:7px 13px;border-radius:20px;font-size:.81rem;color:var(--gray-700);text-decoration:none;transition:all .15s}
.tag-chip:hover{background:var(--primary-light);color:var(--primary);text-decoration:none}

/* ─── Search Layout ──────────── */
.search-layout{display:grid;grid-template-columns:210px 1fr;gap:20px;padding:6px 0 40px}
.search-sidebar{align-self:start;position:sticky;top:68px}

/* ================================================================
   TABLET — max-width: 900px
   ================================================================ */
@media(max-width:900px){
  .listing-layout{grid-template-columns:1fr}
  .search-layout{grid-template-columns:1fr}
  .search-sidebar{display:none}
  .business-grid{grid-template-columns:repeat(2,1fr)}
}

/* ================================================================
   MOBILE — max-width: 768px
   ================================================================ */
@media(max-width:768px){
  /* Header — desktop elements hidden, mobile elements shown */
  .header-search{display:none !important}
  .header-nav{display:none !important}
  /* !important overrides inline style="display:none" on these mobile elements */
  .hamburger{display:flex !important}
  .mobile-search-bar{display:block !important}
  .site-header__inner{height:52px;padding:0 14px}

  /* Hero */
  .hero{padding:26px 0 22px}
  .hero__title{font-size:1.38rem}
  .hero__subtitle{font-size:.86rem;margin-bottom:16px}
  .hero-search{border-radius:12px;flex-direction:column;margin:0 4px 14px}
  .hero-search input{padding:13px 16px;border-radius:12px 12px 0 0}
  .hero-search button{padding:13px 16px;border-radius:0 0 12px 12px;width:100%}
  .hero-tags{gap:5px;padding:0 4px}
  .hero-tag{font-size:.77rem;padding:4px 10px}

  /* Stats — 2×2 grid, no negative margin overlap on mobile */
  .stats-bar{
    grid-template-columns:repeat(2,1fr);
    margin-top:0 !important;
    margin-bottom:0;
    position:static !important;
    z-index:auto;
    border-radius:0;
    box-shadow:none;
    border-top:1px solid var(--gray-100);
    border-bottom:1px solid var(--gray-100)
  }
  .stat-item{padding:14px 10px}
  .stat-item:nth-child(1),.stat-item:nth-child(3){border-right:1px solid var(--gray-100)}
  .stat-item:nth-child(1),.stat-item:nth-child(2){border-bottom:1px solid var(--gray-100)}
  .stat-item__val{font-size:1.25rem}
  .stat-item__label{font-size:.68rem}

  /* Category — 3 columns, proper card grid */
  .category-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:4px}
  .cat-card{padding:12px 6px;display:flex;flex-direction:column;align-items:center}
  .cat-card__icon{font-size:1.4rem;margin-bottom:5px}
  .cat-card__name{font-size:.69rem;text-align:center}

  /* Section spacing */
  .section{padding:20px 0}
  .section__title{font-size:1.05rem}

  /* Business */
  .business-grid{grid-template-columns:1fr}
  .biz-list-item{gap:10px}
  .biz-list-item__logo{width:56px;height:56px}

  /* Listing */
  .listing-layout{grid-template-columns:1fr;gap:0;padding:14px 0 32px}
  .listing-cover{border-radius:0;margin-bottom:14px}
  .listing-title{font-size:1.2rem}
  .listing-logo{width:54px;height:54px}
  .listing-actions .btn-wa,.listing-actions .btn-dir,.listing-actions .btn-web,.listing-actions .btn-call{padding:9px 14px;font-size:.83rem}

  /* Admin */
  .admin-sidebar{transform:translateX(-100%)}
  .admin-sidebar.open{transform:translateX(0)}
  .admin-main{margin-left:0}
  .admin-topbar{padding:0 14px}
  .admin-content{padding:12px}
  .admin-cards{grid-template-columns:repeat(2,1fr);gap:10px}
  .admin-menu-btn{display:flex}
  .admin-menu-btn .admin-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:799}

  /* Forms */
  .form-grid-2{grid-template-columns:1fr !important}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:20px}

  /* Containers */
  .container{padding:0 13px}
  .info-card{padding:14px}
  .sidebar-card{padding:14px}
  .quote-cta{padding:18px}

  /* Modal */
  .modal{max-width:100%;border-radius:16px 16px 0 0}
}

/* ================================================================
   SMALL — max-width: 380px
   ================================================================ */
@media(max-width:380px){
  .hero__title{font-size:1.2rem}
  .category-grid{grid-template-columns:repeat(3,1fr);gap:5px}
  .cat-card{padding:9px 3px}
  .cat-card__icon{font-size:1.1rem}
  .cat-card__name{font-size:.62rem}
  .admin-cards{grid-template-columns:1fr}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .biz-card__actions{gap:5px}
  .btn-wa,.btn-dir,.btn-web,.btn-call{padding:7px 10px;font-size:.77rem}
}

/* ================================================================
   DESKTOP only
   ================================================================ */
@media(min-width:769px){
  .mobile-search-bar,.mobile-nav,.hamburger,.admin-menu-btn{display:none !important}
  .stats-bar{margin-top:-24px;position:relative;z-index:10}
  .category-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}
  .modal-overlay{align-items:center;padding:20px}
  .modal{border-radius:var(--radius)}
  @keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
}

/* ─── Footer ─────────────────── */
.site-footer{background:var(--dark);color:rgba(255,255,255,.75);padding:36px 0 20px;margin-top:48px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:28px;margin-bottom:28px}
.footer-brand__name{font-size:1.2rem;font-weight:800;color:var(--white);margin-bottom:7px}
.footer-brand__name span{color:var(--orange)}
.footer-brand__desc{font-size:.81rem;line-height:1.6}
.footer-col h4{font-size:.8rem;font-weight:700;color:var(--white);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}
.footer-col a{display:block;color:rgba(255,255,255,.62);font-size:.82rem;margin-bottom:7px;text-decoration:none}
.footer-col a:hover{color:var(--white)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:18px;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;flex-wrap:wrap;gap:7px}
