/* =====================================================================
   HarborBeat — apple.com-inspired theme (mobile-first, SF system type)
   Frosted slim nav · Apple grays · pill buttons · generous whitespace
   ===================================================================== */

:root{
  /* Apple palette */
  --ink:#1d1d1f;            /* Apple near-black */
  --ink-2:#424245;
  --muted:#6e6e73;          /* Apple secondary gray */
  --line:#d2d2d7;           /* Apple hairline */
  --line-2:#e8e8ed;
  --bg:#ffffff;
  --bg-2:#f5f5f7;           /* Apple signature light gray */
  --blue:#0071e3;           /* Apple blue */
  --blue-hover:#0077ed;
  --blue-press:#006edb;

  /* HarborBeat brand accents (used sparingly / dark surfaces) */
  --navy:#0b2545;
  --navy-2:#13315c;
  --harbor:#1b6ca8;
  --gold:#f4b942;
  --gold-2:#e0a52b;
  --brick-2:#c1432a;
  --green:#1c8a4e;

  --font:-apple-system,BlinkMacSystemFont,"SF Pro Text","SF Pro Display","Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  --r-sm:10px;--r:14px;--r-lg:18px;--r-xl:24px;--r-pill:980px;
  --shadow:0 1px 3px rgba(0,0,0,.06);
  --shadow-md:0 4px 16px rgba(0,0,0,.08);
  --shadow-lg:0 12px 40px rgba(0,0,0,.12);
  --header-h:52px;
  --bn-h:60px;              /* bottom nav height */
}

/* ---- Reset / iOS-safe base ---- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}
body{
  font-family:var(--font);color:var(--ink);background:var(--bg);margin:0;
  font-size:17px;line-height:1.47;          /* Apple body size */
  letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;height:auto}
a{color:var(--blue);text-decoration:none}
a:hover{color:var(--blue-hover);text-decoration:none}
h1,h2,h3,h4,h5,h6{letter-spacing:-.022em;line-height:1.1;font-weight:600;color:var(--ink)}
input,select,textarea,button{font-family:inherit;font-size:16px}
button{cursor:pointer}
.hb-main{min-height:60vh}
.hb-narrow{max-width:720px;margin-inline:auto}
.container{max-width:1180px;padding-inline:22px}
@media (max-width:575px){ .container{padding-inline:16px} }
@media (hover:none){ .nav-link,.dropdown-item,.hb-chip,.btn,.hb-subnav-link,.hb-account-nav a,.hb-cat-list a,.hb-bottomnav a,.hb-drawer-nav a{min-height:44px} }

/* =====================================================================
   HEADER — Apple frosted slim bar
   ===================================================================== */
.hb-header{
  position:sticky;top:0;z-index:1030;
  background:rgba(255,255,255,.72);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-bottom:1px solid var(--line);
}
.hb-header-row{display:flex;align-items:center;gap:.6rem;height:var(--header-h)}
.hb-burger{background:none;border:none;color:var(--ink);font-size:1.5rem;line-height:1;padding:.2rem .35rem;display:inline-flex;align-items:center}
.hb-brand{display:flex;align-items:center;gap:.45rem;color:var(--ink)!important;font-size:1.2rem;font-weight:700;letter-spacing:-.03em;flex:0 0 auto}
.hb-brand-mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--harbor),var(--navy));display:grid;place-items:center;color:#fff;font-size:1rem}
.hb-brand-text{white-space:nowrap}
.hb-brand-text strong{color:var(--blue)}

.hb-search{flex:1 1 auto;max-width:460px;margin:0 auto}
.hb-search .input-group{background:var(--bg-2);border-radius:var(--r-pill);overflow:hidden;border:1px solid transparent}
.hb-search .input-group:focus-within{background:#fff;border-color:var(--line)}
.hb-search .input-group-text{background:transparent;border:none;color:var(--muted);padding-left:1rem}
.hb-search .form-control{background:transparent;border:none;box-shadow:none!important;font-size:.95rem;padding-left:.2rem}
.hb-search .form-control::placeholder{color:var(--muted)}

.hb-header-actions{display:flex;align-items:center;gap:.5rem;flex:0 0 auto;margin-left:auto}
.hb-icon-btn{width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);font-size:1.1rem;background:transparent}
.hb-icon-btn:hover{background:var(--bg-2);color:var(--ink)}
.hb-notif-badge{font-size:.58rem;position:absolute;top:2px;right:2px}
.hb-hood-btn,.hb-user-btn{background:var(--bg-2);color:var(--ink);border:none;border-radius:var(--r-pill);font-weight:500;font-size:.88rem;padding:.42rem .9rem;white-space:nowrap}
.hb-hood-btn:hover,.hb-user-btn:hover{background:var(--line-2);color:var(--ink)}
.hb-hood-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:.5rem}
.hb-hood-menu{max-height:64vh;overflow:auto}
.hb-login-btn{background:transparent;color:var(--ink);border:none;border-radius:var(--r-pill);font-weight:500;padding:.42rem .9rem}
.hb-login-btn:hover{background:var(--bg-2);color:var(--ink)}
.hb-cta-btn{background:var(--blue);color:#fff!important;font-weight:500;border:none;border-radius:var(--r-pill);padding:.42rem 1.05rem;white-space:nowrap}
.hb-cta-btn:hover{background:var(--blue-hover);color:#fff}
.hb-cta-btn:active{background:var(--blue-press)}
.hb-cta-label{display:inline}

/* Sub-nav: slim centered section bar */
.hb-subnav{border-top:1px solid var(--line-2)}
.hb-subnav-list{list-style:none;display:flex;justify-content:center;gap:.2rem;margin:0;padding:0;height:44px;align-items:center;overflow-x:auto;scrollbar-width:none}
.hb-subnav-list::-webkit-scrollbar{display:none}
.hb-subnav-link{display:inline-flex;align-items:center;height:44px;padding:0 .8rem;color:var(--ink-2);font-size:.82rem;font-weight:500;letter-spacing:-.01em;white-space:nowrap;border-bottom:2px solid transparent;transition:color .15s}
.hb-subnav-link:hover{color:var(--ink)}
.hb-subnav-link.active{color:var(--blue);border-bottom-color:var(--blue)}
@media (max-width:991px){ .hb-search{margin:0} }
@media (min-width:1280px){ .hb-subnav-list{gap:.6rem} }

/* =====================================================================
   MOBILE DRAWER (Offcanvas)
   ===================================================================== */
.hb-drawer{width:min(86vw,360px);background:#fff;border-right:1px solid var(--line)}
.hb-drawer .offcanvas-header{border-bottom:1px solid var(--line-2);padding:1rem 1.1rem}
.hb-drawer .offcanvas-body{padding:1rem 1.1rem 2rem}
.hb-search-drawer .input-group{background:var(--bg-2);border-radius:var(--r-pill);overflow:hidden}
.hb-search-drawer .input-group-text{background:transparent;border:none;color:var(--muted)}
.hb-search-drawer .form-control{background:transparent;border:none;box-shadow:none!important}
.hb-drawer-label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:1.1rem 0 .5rem}
/* Compact 2-column tile grid with colored icons */
.hb-drawer-grid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}
.hb-drawer-tile{display:flex;align-items:center;gap:.6rem;padding:.6rem .65rem;border-radius:14px;background:var(--bg-2);color:var(--ink);font-size:.9rem;font-weight:500;min-height:56px;line-height:1.12}
.hb-drawer-tile:hover{background:var(--line-2);color:var(--ink)}
.hb-drawer-tile.active{background:#eaf2fe;color:var(--blue)}
.hb-drawer-ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:var(--ic,var(--blue));color:#fff;font-size:1.05rem;flex:0 0 34px;box-shadow:0 2px 6px color-mix(in srgb,var(--ic,var(--blue)) 35%,transparent)}
.hb-drawer-tile-label{min-width:0}
.hb-drawer-hoods{display:flex;flex-wrap:wrap;gap:.4rem}
.hb-drawer-account{margin-top:1.4rem;border-top:1px solid var(--line-2);padding-top:1rem;display:flex;flex-direction:column;gap:.2rem}
.hb-drawer-acc-link{display:flex;align-items:center;gap:.7rem;padding:.6rem .3rem;color:var(--ink);font-weight:500;border-radius:10px}
.hb-drawer-acc-link .bi{color:var(--muted);width:22px}
.hb-drawer-acc-link:hover{background:var(--bg-2)}

/* =====================================================================
   SECTION HEADS / TYPE
   ===================================================================== */
.hb-eyebrow{display:inline-block;font-size:.74rem;font-weight:600;letter-spacing:0;color:var(--blue)}
.hb-eyebrow-light{color:var(--gold)}
.hb-section{padding-block:2rem}   /* padding-block only — never kill container's inline padding */
.hb-section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.1rem;gap:.75rem}
.hb-section-title{font-size:clamp(1.3rem,4.5vw,1.7rem);font-weight:600;color:var(--ink);margin:0;display:flex;align-items:center;gap:.5rem;min-width:0;letter-spacing:-.02em}
.hb-tick{display:none}                 /* Apple: no decorative ticks */
.hb-title-red{color:var(--brick-2)}.hb-title-gold{color:var(--gold-2)}
.hb-section-link{font-weight:400;font-size:.95rem;white-space:nowrap;flex:0 0 auto;color:var(--blue)}
.hb-section-link:hover{text-decoration:underline}
@media (min-width:768px){ .hb-section{padding-block:2.6rem} }

/* =====================================================================
   CARDS
   ===================================================================== */
.hb-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}
@media (hover:hover){ .hb-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)} }
.hb-card-imglink{display:block;position:relative}
.hb-card-img{display:block;width:100%;aspect-ratio:16/10;background-size:cover;background-position:center;background-color:var(--bg-2)}
.hb-card-img-sq{aspect-ratio:1/1}
.hb-card-img-wide{aspect-ratio:16/9}
.hb-card-body{padding:.9rem 1rem 1.1rem}
.hb-card-title{font-size:1.05rem;font-weight:600;line-height:1.3;margin:.25rem 0 .4rem;letter-spacing:-.015em}
.hb-card-title a{color:var(--ink)}.hb-card-title a:hover{color:var(--blue)}
.hb-card-title-sm{font-size:.98rem}
.hb-card-dek{color:var(--muted);font-size:.9rem;margin-bottom:.5rem;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hb-card-meta{color:var(--muted);font-size:.8rem;display:flex;flex-wrap:wrap;gap:.25rem;align-items:center}
.hb-hood-tag{position:absolute;left:.6rem;top:.6rem;background:rgba(0,0,0,.55);color:#fff;font-size:.68rem;font-weight:600;padding:.2rem .55rem;border-radius:var(--r-pill);backdrop-filter:blur(6px)}
.hb-hood-tag-inline{position:static;display:inline-block;margin-bottom:.6rem;background:var(--bg-2);color:var(--ink-2)}
.hb-promoted{position:absolute;right:.5rem;top:.5rem;background:var(--gold);color:var(--navy);font-size:.64rem;font-weight:700;padding:.18rem .5rem;border-radius:6px}
.hb-promoted-rent{background:var(--blue);color:#fff}.hb-promoted-buy{background:var(--brick-2);color:#fff}
.hb-price{font-size:1.15rem;font-weight:600;color:var(--ink)}
.hb-price-per,.hb-price-range{font-size:.8rem;color:var(--muted);font-weight:400;margin-left:.2rem}
.hb-tier{position:absolute;right:.5rem;top:.5rem;font-size:.64rem;font-weight:700;padding:.18rem .5rem;border-radius:6px}
.hb-tier-premium{background:var(--gold);color:var(--navy)}
.hb-tier-featured{background:var(--blue);color:#fff}
.hb-verified{color:var(--blue)}
.hb-stars{color:var(--gold);font-size:.85rem;display:inline-flex;align-items:center;gap:1px;flex-wrap:wrap}
.hb-stars-sm{font-size:.75rem}
.hb-stars-count{color:var(--muted);font-size:.75rem;margin-left:.2rem}
.hb-stars-light{color:#ffd96b}.hb-stars-light span{color:#f5f5f7}

/* Event card */
.hb-card-event .hb-card-body{padding:.75rem .9rem}
.hb-event-date{flex:0 0 56px;background:var(--bg-2);color:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.55rem 0}
.hb-event-mon{font-size:.66rem;text-transform:uppercase;font-weight:600;color:var(--brick-2);letter-spacing:.03em}
.hb-event-day{font-size:1.45rem;font-weight:600;line-height:1}
.hb-event-date-lg{flex-basis:auto;width:60px;border-radius:12px}
.hb-event-when{display:flex;gap:.8rem;align-items:center}
.hb-event-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}
.hb-pill{background:var(--bg-2);color:var(--ink-2);font-size:.72rem;font-weight:500;padding:.2rem .6rem;border-radius:var(--r-pill);white-space:nowrap}
.hb-pill-green{background:#e6f5ec;color:var(--green)}
.hb-pill-blue{background:#e6f1fb;color:var(--blue)}

/* Job card */
.hb-card-job{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);margin-bottom:.7rem;transition:.18s}
@media (hover:hover){ .hb-card-job:hover{box-shadow:var(--shadow-md)} }
.hb-card-job .hb-card-body{padding:.9rem 1rem}
.hb-job-logo{width:46px;height:46px;border-radius:12px;background:var(--bg-2);color:var(--navy);display:grid;place-items:center;font-size:1.2rem;flex:0 0 46px}
.hb-job-logo-lg{width:62px;height:62px;flex-basis:62px;font-size:1.55rem}
.hb-job-when{flex:0 0 auto}
.hb-joblist-lg .hb-card-job{margin-bottom:.85rem}

/* =====================================================================
   HERO
   ===================================================================== */
.hb-hero{padding:1.4rem 0 .4rem}
.hb-hero-main{display:block;border-radius:var(--r-xl);min-height:320px;background-size:cover;background-position:center;position:relative;overflow:hidden}
.hb-hero-body{position:absolute;bottom:0;left:0;right:0;padding:1.4rem}
.hb-hero-title{font-size:clamp(1.6rem,6.5vw,2.6rem);font-weight:600;line-height:1.07;margin:.4rem 0 .5rem;color:#fff;letter-spacing:-.03em}
.hb-hero-dek{font-size:clamp(.95rem,2.6vw,1.1rem);color:#fff;opacity:.92;max-width:48ch;margin-bottom:.5rem}
.hb-hero-meta{font-size:.8rem;color:#fff;opacity:.85}
.hb-hero-side{display:flex;flex-direction:column;gap:.9rem;height:100%;margin-top:.9rem}
.hb-widget.hb-widget-weather{background:linear-gradient(135deg,var(--harbor),var(--navy));color:#fff;border:none}
.hb-widget.hb-widget-weather .hb-weather-temp,.hb-widget.hb-widget-weather .hb-weather-city,.hb-widget.hb-widget-weather .hb-weather-date{color:#fff}
.hb-weather-now{display:flex;align-items:center;gap:.8rem;font-size:1.05rem}
.hb-weather-now .bi{font-size:2.1rem;color:var(--gold)}
.hb-weather-temp{font-size:1.7rem;font-weight:600;display:block;line-height:1}
.hb-weather-city{font-size:.8rem;opacity:.85}
.hb-weather-date{margin-top:.55rem;font-size:.8rem;opacity:.85}
@media (min-width:992px){
  .hb-hero{padding:2rem 0 .6rem}
  .hb-hero-main{min-height:460px}
  .hb-hero-body{padding:2rem}
  .hb-hero-side{margin-top:0}
}

/* =====================================================================
   WIDGETS
   ===================================================================== */
.hb-widget{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;margin-bottom:.9rem}
.hb-widget-title{font-size:.95rem;font-weight:600;color:var(--ink);margin-bottom:.7rem;display:flex;align-items:center;gap:.4rem}
.hb-widget-sticky{position:static}
.hb-widget-more{font-size:.85rem;font-weight:400;display:inline-block;margin-top:.4rem;color:var(--blue)}
.hb-mini-event{display:flex;gap:.55rem;align-items:baseline;padding:.55rem 0;border-bottom:1px solid var(--line-2);color:var(--ink)}
.hb-mini-event:last-of-type{border-bottom:none}
.hb-mini-event:hover{color:var(--blue)}
.hb-mini-date{flex:0 0 auto;font-size:.7rem;font-weight:600;color:var(--brick-2);text-transform:uppercase}
.hb-mini-title{font-size:.88rem;font-weight:500}
@media (min-width:992px){ .hb-widget-sticky{position:sticky;top:calc(var(--header-h) + 56px)} }

.hb-banner{display:block;margin:1rem 0;border-radius:var(--r-lg);overflow:hidden}
.hb-banner img{width:100%;display:block}

/* =====================================================================
   SPOTLIGHT
   ===================================================================== */
.hb-spotlight{background:var(--hood-color,var(--navy));color:#fff;padding:2.4rem 0;position:relative;overflow:hidden}
.hb-spotlight::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,37,69,.15),rgba(11,37,69,.72))}
.hb-spotlight .container{position:relative;z-index:1}
.hb-spotlight-title{font-size:clamp(1.8rem,6vw,2.6rem);font-weight:600;margin:.3rem 0;letter-spacing:-.02em}
.hb-spotlight-tag{font-size:clamp(.98rem,3vw,1.15rem);opacity:.92;margin-bottom:1.1rem}
.hb-hood-picker{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);border-radius:var(--r-lg);padding:1.1rem;backdrop-filter:blur(6px);margin-top:1rem}
.hb-hood-picker h6{color:#fff;font-weight:600;text-transform:none;font-size:.85rem;letter-spacing:0;opacity:.8}
.hb-hood-grid{display:flex;flex-wrap:wrap;gap:.4rem}
.hb-hood-chip{background:rgba(255,255,255,.14);color:#fff;font-size:.82rem;font-weight:500;padding:.4rem .8rem;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.12)}
.hb-hood-chip:hover{background:#fff;color:var(--navy)}
.hb-spotlight .btn.hb-cta-btn{background:#fff;color:var(--navy)!important}
.hb-spotlight .btn.hb-cta-btn:hover{background:#f0f0f0}
/* drawer hood chips (light context) */
.hb-drawer-hoods .hb-hood-chip{background:var(--bg-2);color:var(--ink);border:1px solid var(--line)}
.hb-drawer-hoods .hb-hood-chip:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.hb-drawer-hoods .hb-hood-chip-all{background:var(--navy);color:#fff;border-color:var(--navy)}
@media (min-width:992px){ .hb-spotlight{padding:3rem 0} .hb-hood-picker{margin-top:0} }

/* =====================================================================
   DEALS / COMMUNITY (home)
   ===================================================================== */
.hb-deal{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1rem;height:100%}
.hb-deal:hover{box-shadow:var(--shadow-md)}
.hb-deal-badge{font-size:.8rem;font-weight:600;color:var(--gold-2)}
.hb-deal-title{font-weight:600;color:var(--ink);font-size:.95rem}
.hb-deal-biz{font-size:.8rem;color:var(--muted)}
.hb-qlist .hb-q{display:flex;flex-direction:column;padding:.65rem .1rem;border-bottom:1px solid var(--line-2)}
.hb-q-cat{font-size:.7rem;font-weight:600;color:var(--blue);text-transform:none}
.hb-q-title{font-weight:500;color:var(--ink)}
.hb-q-meta{font-size:.78rem;color:var(--muted)}

/* Newsletter CTA */
.hb-news-cta{background:var(--bg-2);color:var(--ink);padding:3rem 0;margin-top:1.5rem;text-align:center}
.hb-news-cta h2{font-weight:600;font-size:clamp(1.5rem,5vw,2.1rem);letter-spacing:-.02em;color:var(--ink)}
.hb-news-cta p{color:var(--muted)}
.hb-news-cta strong{color:var(--blue)}
.hb-news-form{max-width:460px;margin:1.2rem auto 0}
.hb-news-msg{min-height:1.2em}

/* =====================================================================
   PAGE HEADS — Apple light
   ===================================================================== */
.hb-page-head{background:var(--bg-2);color:var(--ink);padding:2.4rem 0 2rem}
.hb-page-head h1{font-weight:600;font-size:clamp(1.8rem,6.5vw,2.6rem);margin:.3rem 0;color:var(--ink);letter-spacing:-.025em}
.hb-page-head p{color:var(--muted);max-width:62ch;margin:0;font-size:clamp(.98rem,2.6vw,1.15rem)}
.hb-page-head .hb-eyebrow,.hb-page-head .hb-eyebrow-light{color:var(--blue)}
.hb-page-head .form-control{background:#fff}
/* keep a few signature pages with subtle tint */
.hb-page-head-community{background:linear-gradient(135deg,#f5f5f7,#eef1f6)}
.hb-page-head-deals{background:linear-gradient(135deg,#fff7e9,#f5f5f7)}
@media (min-width:768px){ .hb-page-head{padding:3rem 0 2.4rem} }

/* =====================================================================
   CHIPS / FILTERS
   ===================================================================== */
.hb-chips{display:flex;gap:.5rem;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:.25rem;scrollbar-width:none}
.hb-chips::-webkit-scrollbar{display:none}
.hb-chip{background:var(--bg-2);border:1px solid transparent;color:var(--ink);font-size:.85rem;font-weight:500;padding:.45rem .9rem;border-radius:var(--r-pill);white-space:nowrap;display:inline-flex;align-items:center;flex:0 0 auto}
.hb-chip:hover{background:var(--line-2);color:var(--ink)}
.hb-chip.active{background:var(--ink);color:#fff}
@media (min-width:768px){ .hb-chips{flex-wrap:wrap;overflow:visible} }
.hb-filter{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;margin-bottom:1rem}
.hb-filter-title{font-weight:600;color:var(--ink);font-size:.92rem;margin-bottom:.7rem}
.hb-cat-list{list-style:none;padding:0;margin:0}
.hb-cat-list a{display:flex;align-items:center;padding:.5rem .2rem;color:var(--ink-2);font-size:.9rem;border-radius:6px}
.hb-cat-list a:hover{color:var(--blue)}
.hb-cat-list a.active{color:var(--blue);font-weight:600}

/* =====================================================================
   ARTICLE
   ===================================================================== */
.hb-breadcrumb{font-size:.82rem;color:var(--muted);margin-bottom:1rem;overflow-x:auto;white-space:nowrap;scrollbar-width:none}
.hb-breadcrumb::-webkit-scrollbar{display:none}
.hb-article{padding:1.6rem 0}
.hb-article-head{margin-bottom:1.2rem}
.hb-article-title{font-size:clamp(1.7rem,6.5vw,2.7rem);font-weight:600;color:var(--ink);line-height:1.08;letter-spacing:-.025em}
.hb-article-dek{font-size:clamp(1.05rem,3.2vw,1.3rem);color:var(--muted);font-weight:400;line-height:1.4}
.hb-article-byline{display:flex;flex-wrap:wrap;gap:.5rem 1rem;align-items:center;font-size:.85rem;color:var(--muted);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:.8rem 0;margin-top:1rem}
.hb-share{margin-left:0;display:flex;gap:.5rem;flex-wrap:wrap;width:100%}
.hb-share-btn,.hb-save-btn{background:var(--bg-2);border:none;border-radius:var(--r-pill);padding:.45rem .9rem;font-size:.82rem;font-weight:500;color:var(--ink);display:inline-flex;align-items:center;gap:.35rem}
.hb-share-btn:hover,.hb-save-btn:hover{background:var(--line-2);color:var(--ink)}
.hb-save-btn.active{background:var(--gold);color:var(--navy)}
.hb-article-hero{width:100%;border-radius:var(--r-xl);margin:1.2rem 0}
.hb-article-body{font-size:1.12rem;line-height:1.7;color:var(--ink-2)}
.hb-article-body h2,.hb-article-body h3{color:var(--ink);font-weight:600;margin-top:1.8rem;letter-spacing:-.02em}
.hb-article-body img{border-radius:12px}
.hb-article-body blockquote{border-left:3px solid var(--blue);padding-left:1.1rem;color:var(--muted);font-style:normal;margin-left:0}
.hb-related{margin-top:2.2rem;border-top:1px solid var(--line);padding-top:1.6rem}
@media (min-width:768px){ .hb-share{margin-left:auto;width:auto} }

/* Comments / reviews */
.hb-comments{margin-top:2.2rem;border-top:1px solid var(--line);padding-top:1.6rem}
.hb-comment,.hb-review{background:var(--bg-2);border:none;border-radius:var(--r-lg);padding:.9rem 1.1rem;margin-bottom:.7rem}
.hb-comment-head,.hb-review-head{display:flex;gap:.55rem;align-items:center;margin-bottom:.3rem;flex-wrap:wrap}
.hb-login-cta{background:var(--bg-2);border-radius:var(--r-lg);padding:.9rem 1.1rem;color:var(--ink-2)}
.hb-rating-input .bi{font-size:1.7rem;color:var(--gold);cursor:pointer;padding:.1rem}

/* =====================================================================
   LISTING / GALLERY
   ===================================================================== */
.hb-listing-title{font-size:clamp(1.4rem,5vw,1.9rem);font-weight:600;color:var(--ink);letter-spacing:-.02em}
.hb-listing-price{font-size:clamp(1.4rem,5vw,1.8rem);font-weight:600;color:var(--ink);margin:.2rem 0 .4rem}
.hb-gallery-main{width:100%;aspect-ratio:4/3;border-radius:var(--r-xl);background-size:cover;background-position:center;background-color:var(--bg-2)}
.hb-gallery-thumbs{display:flex;gap:.5rem;margin-top:.5rem;overflow-x:auto;scrollbar-width:none}
.hb-gallery-thumbs::-webkit-scrollbar{display:none}
.hb-gallery-thumbs span{width:70px;height:54px;border-radius:10px;background-size:cover;background-position:center;cursor:pointer;border:2px solid transparent;flex:0 0 auto}
.hb-seller{display:flex;gap:.7rem;align-items:center}
.hb-seller-avatar{width:46px;height:46px;border-radius:50%;background:var(--bg-2);display:grid;place-items:center;font-size:1.6rem;color:var(--harbor);flex:0 0 auto}
.hb-seller-avatar-lg{width:58px;height:58px;font-size:2rem}

/* =====================================================================
   NEIGHBORHOODS
   ===================================================================== */
.hb-hood-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:.22s}
@media (hover:hover){ .hb-hood-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)} }
.hb-hood-card-top{height:120px;display:flex;align-items:flex-end;padding:1rem}
.hb-hood-card-name{color:#fff;font-size:1.4rem;font-weight:600;letter-spacing:-.02em;text-shadow:0 2px 12px rgba(0,0,0,.3)}
.hb-hood-card-body{padding:.9rem 1.1rem}
.hb-hood-card-body p{color:var(--muted);font-size:.88rem;margin-bottom:.5rem;min-height:2.6em}
.hb-hood-card-stat{font-size:.8rem;font-weight:500;color:var(--blue)}
.hb-hood-hero{color:#fff;padding:2.4rem 0 2rem}
.hb-hood-hero h1{font-size:clamp(2rem,8vw,3rem);font-weight:600;color:#fff;letter-spacing:-.03em}
.hb-hood-hero-tag{font-size:clamp(1.05rem,3.5vw,1.25rem);opacity:.92}
.hb-follow-btn{font-weight:500;border-radius:var(--r-pill)}
.hb-hours{list-style:none;padding:0;margin:0;font-size:.88rem}
.hb-hours li{display:flex;justify-content:space-between;padding:.3rem 0;border-bottom:1px solid var(--line-2)}

/* Business cover / coupons */
.hb-biz-cover{min-height:220px;background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff}
.hb-biz-cover-body{padding:1.4rem 0}
.hb-biz-cover-body h1{font-weight:600;font-size:clamp(1.6rem,6vw,2.2rem);color:#fff;letter-spacing:-.02em}
.hb-biz-cats{display:grid;grid-template-columns:repeat(auto-fill,minmax(124px,1fr));gap:.7rem}
.hb-biz-cat{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1rem .6rem;text-align:center;color:var(--ink);font-weight:500;font-size:.85rem;transition:.18s}
.hb-biz-cat:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);color:var(--blue)}
.hb-biz-cat .bi{font-size:1.4rem;display:block;color:var(--blue);margin-bottom:.35rem}
.hb-biz-cat small{display:block;color:var(--muted);font-weight:500}
.hb-biz-search{max-width:560px;margin-top:1rem}
.hb-coupon-strip{display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.5rem}
.hb-coupon{display:flex;flex-wrap:wrap;background:#fffaf0;border:1px dashed var(--gold-2);border-radius:var(--r-lg);overflow:hidden}
.hb-coupon-left{background:var(--gold);color:var(--navy);display:grid;place-items:center;padding:1rem;min-width:104px;flex:1 1 104px}
.hb-coupon-discount{font-weight:700;font-size:1rem;text-align:center}
.hb-coupon-right{padding:.9rem 1.1rem;flex:1 1 200px}
.hb-coupon-code{display:inline-block;background:#fff;border:1px dashed var(--muted);border-radius:6px;padding:.1rem .5rem;font-family:ui-monospace,Menlo,monospace;font-size:.8rem;margin-right:.5rem}

/* Deals page */
.hb-deal-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;height:100%;display:flex;flex-direction:column}
.hb-deal-card-top{background:linear-gradient(135deg,var(--gold),var(--gold-2));padding:1.4rem;text-align:center}
.hb-deal-discount{font-size:1.4rem;font-weight:700;color:var(--navy)}
.hb-deal-card-body{padding:1.1rem;display:flex;flex-direction:column;flex-grow:1}
.hb-deal-card-body h3{font-size:1.05rem;font-weight:600;color:var(--ink)}
.hb-deal-biz-link{font-size:.84rem;font-weight:500}

/* Community */
.hb-qfeed-item,.hb-question{display:flex;gap:.85rem;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:.95rem 1.1rem;margin-bottom:.7rem}
@media (hover:hover){ .hb-qfeed-item:hover{box-shadow:var(--shadow-md)} }
.hb-qfeed-votes{flex:0 0 44px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-2);border-radius:12px;color:var(--ink);font-weight:600}
.hb-qfeed-votes .bi{color:var(--blue)}
.hb-qfeed-title{font-size:1.05rem;font-weight:600;color:var(--ink);margin:.2rem 0;letter-spacing:-.01em}
.hb-ask-form,.hb-answer-form,.hb-review-form,.hb-comment-form,.hb-form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem}
.hb-answer{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;margin-bottom:.7rem}
.hb-answer-accepted{border-color:var(--green);background:#f3fbf6}
.hb-accepted-badge{color:var(--green);font-weight:600;font-size:.8rem}
.hb-answer-meta{display:flex;gap:1rem;align-items:center;margin-top:.5rem;flex-wrap:wrap}
.hb-upvote{background:var(--bg-2);border:none;border-radius:var(--r-pill);padding:.3rem .8rem;font-size:.8rem;font-weight:500;color:var(--ink)}
.hb-poll-option{display:block;width:100%;text-align:left;background:var(--bg-2);border:none;border-radius:10px;padding:.65rem .8rem;margin-bottom:.4rem;position:relative;overflow:hidden;font-size:.88rem;font-weight:500}
.hb-poll-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(0,113,227,.16);z-index:0}
.hb-poll-label,.hb-poll-pct{position:relative;z-index:1}
.hb-poll-pct{float:right;color:var(--blue)}

/* =====================================================================
   AUTH / ACCOUNT
   ===================================================================== */
.hb-auth-card{max-width:420px;margin:2rem auto;background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:2rem;box-shadow:var(--shadow-md)}
.hb-account-side{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;margin-bottom:1rem}
.hb-account-user{display:flex;gap:.7rem;align-items:center;padding-bottom:.9rem;border-bottom:1px solid var(--line-2);margin-bottom:.7rem}
.hb-account-nav{list-style:none;padding:0;margin:0;display:flex;gap:.4rem;overflow-x:auto;scrollbar-width:none}
.hb-account-nav::-webkit-scrollbar{display:none}
.hb-account-nav a{display:flex;gap:.5rem;align-items:center;padding:.55rem .8rem;border-radius:var(--r-pill);color:var(--ink);font-weight:500;font-size:.9rem;white-space:nowrap;flex:0 0 auto;background:var(--bg-2)}
.hb-account-nav a:hover{background:var(--line-2);color:var(--blue)}
.hb-account-nav a.active{background:var(--ink);color:#fff}
.hb-stat{display:flex;flex-direction:column;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem;text-align:center;color:var(--ink)}
.hb-stat-num{font-size:1.5rem;font-weight:600;color:var(--blue)}
.hb-stat-label{font-size:.8rem;color:var(--muted);font-weight:500}
.hb-stat-cta{background:var(--blue);color:#fff}.hb-stat-cta .hb-stat-num{color:#fff}
.hb-message,.hb-notif{display:flex;gap:.8rem;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:.85rem 1.1rem;margin-bottom:.6rem}
.hb-message-unread,.hb-notif-unread{background:#f0f7ff;border-color:#cfe4fb}
.hb-notif .bi{font-size:1.3rem;color:var(--blue)}
.hb-saved-search{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);border-radius:10px;padding:.65rem .9rem;margin-bottom:.5rem;flex-wrap:wrap;gap:.4rem}
.hb-edition{display:flex;gap:.9rem;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.1rem}
.hb-edition>.bi{font-size:1.7rem;color:var(--blue);flex:0 0 auto}
@media (min-width:992px){
  .hb-account-nav{flex-direction:column;overflow:visible}
  .hb-account-nav a{background:transparent;border-radius:10px}
  .hb-account-nav a:hover{background:var(--bg-2)}
}

/* 404 */
.hb-404{padding:4rem 0;text-align:center}
.hb-404-num{font-size:clamp(4rem,18vw,7rem);font-weight:600;color:var(--ink);line-height:1;letter-spacing:-.04em}

/* =====================================================================
   FOOTER — Apple light footer
   ===================================================================== */
.hb-footer{background:var(--bg-2);color:var(--muted);padding:2.4rem 0 1.4rem;margin-top:2.5rem;border-top:1px solid var(--line)}
.hb-footer h6{color:var(--ink);font-weight:600;font-size:.82rem;letter-spacing:0;margin-bottom:.7rem;text-transform:none}
.hb-footer-links li{margin-bottom:.4rem}
.hb-footer-links a{color:var(--muted);font-size:.86rem}
.hb-footer-links a:hover{color:var(--blue)}
.hb-brand-footer{font-size:1.3rem;margin-bottom:.5rem}
.hb-footer-tag{color:var(--ink);font-weight:500}
.hb-social{display:flex;gap:.6rem;margin-top:.6rem}
.hb-social a{width:40px;height:40px;border-radius:50%;background:#fff;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink);font-size:1.05rem}
.hb-social a:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.hb-footer-rule{border-color:var(--line);margin:1.6rem 0 1rem}
.hb-footer-legal a{color:var(--muted)}

/* Pagination */
.hb-pagination{margin-top:1.6rem}
.hb-pagination .page-link{color:var(--ink);border-radius:var(--r-pill)!important;margin:0 3px;border-color:var(--line);min-width:42px;text-align:center}
.hb-pagination .active .page-link{background:var(--ink);border-color:var(--ink)}

/* =====================================================================
   MOBILE BOTTOM TAB BAR
   ===================================================================== */
.hb-bottomnav{
  position:fixed;left:0;right:0;bottom:0;z-index:1035;
  display:flex;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
  border-top:1px solid var(--line);
  height:calc(var(--bn-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);
}
.hb-bottomnav a{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  color:var(--muted);font-size:.64rem;font-weight:500;text-decoration:none;
}
.hb-bottomnav a .bi{font-size:1.35rem;line-height:1}
.hb-bottomnav a.active{color:var(--ink)}
.hb-bottomnav a.active .bi{color:var(--blue)}
.hb-bottomnav-fab{color:var(--blue)!important}
.hb-bottomnav-fab .bi{
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:var(--blue);color:#fff;font-size:1.5rem;margin-top:-18px;
  box-shadow:0 6px 16px rgba(0,113,227,.4);border:3px solid #fff;
}
body.has-bottomnav{padding-bottom:calc(var(--bn-h) + env(safe-area-inset-bottom))}
@media (min-width:992px){
  .hb-bottomnav{display:none}
  body.has-bottomnav{padding-bottom:0}
}

/* =====================================================================
   TOAST
   ===================================================================== */
.hb-toast-wrap{position:fixed;bottom:calc(var(--bn-h) + 16px + env(safe-area-inset-bottom));right:16px;left:16px;z-index:2000;display:flex;flex-direction:column;gap:.5rem;align-items:center;pointer-events:none}
.hb-toast{background:rgba(29,29,31,.92);backdrop-filter:blur(10px);color:#fff;padding:.7rem 1.2rem;border-radius:var(--r-pill);box-shadow:var(--shadow-lg);font-size:.9rem;font-weight:500;animation:hbslide .25s ease;max-width:92vw;text-align:center}
.hb-toast-error{background:rgba(193,67,42,.95)}
.hb-toast-success{background:rgba(28,138,78,.95)}
@keyframes hbslide{from{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}
@media (min-width:992px){ .hb-toast-wrap{left:auto;bottom:24px;align-items:flex-end} }

/* =====================================================================
   Bootstrap polish — Apple pills & inputs
   ===================================================================== */
.form-control,.form-select{border-radius:12px;border-color:var(--line);padding:.55rem .85rem;color:var(--ink)}
.form-control:focus,.form-select:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,113,227,.12)}
.form-label{font-weight:500;font-size:.9rem;color:var(--ink-2)}
.btn{border-radius:var(--r-pill);font-weight:500;padding:.5rem 1.2rem}
.btn-sm{padding:.35rem .9rem}
.btn-lg{padding:.7rem 1.6rem}
.btn-outline-secondary{border-color:var(--line);color:var(--ink)}
.btn-outline-secondary:hover{background:var(--bg-2);border-color:var(--line);color:var(--ink)}
.btn-outline-danger{border-color:#e9b8af;color:var(--brick-2)}
.btn-navy{background:var(--navy);color:#fff}
.alert{border-radius:var(--r-lg)}
.dropdown-menu{border-color:var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-md);padding:.4rem}
.dropdown-item{border-radius:8px;padding:.5rem .7rem;font-size:.92rem}
.dropdown-item:active{background:var(--blue)}
