:root{
  --teal:#0e5f63; --teal-700:#0b4a4d; --teal-900:#0b282a;
  --terra:#d8693b; --terra-600:#c25a30;
  --sand:#f6f1e7; --paper:#ffffff; --ink:#1b2627; --muted:#5d6b6c;
  --line:#e6e0d4; --gold:#c9a14a;
  --shadow:0 1px 2px rgba(11,40,42,.06),0 8px 24px rgba(11,40,42,.06);
  --radius:16px; --radius-sm:10px;
  --maxw:1140px;
  --font-display:"Sora",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.15;color:var(--teal-900);margin:0 0 .4em}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4em;font-family:var(--font-display);font-weight:600;font-size:.95rem;padding:.7em 1.3em;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.18s;text-decoration:none;white-space:nowrap}
.btn--primary{background:var(--teal);color:#fff}
.btn--primary:hover{background:var(--teal-700);text-decoration:none}
.btn--ghost{background:transparent;border-color:var(--line);color:var(--teal-900)}
.btn--ghost:hover{border-color:var(--teal);text-decoration:none}
.btn--light{background:#fff;color:var(--teal-900)}
.btn--light:hover{background:var(--sand);text-decoration:none}
.btn--danger{background:transparent;border-color:#e5c4b9;color:var(--terra-600)}
.btn--danger:hover{background:#fbeee8;text-decoration:none}
.btn--lg{padding:.9em 1.7em;font-size:1.02rem}
.btn--small{padding:.45em .9em;font-size:.82rem}
.linklike{background:none;border:none;color:var(--teal);font:inherit;cursor:pointer;padding:0}
.linklike:hover{text-decoration:underline}

/* Header */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:68px;gap:1rem}
.brand{display:flex;align-items:center;gap:.55rem;font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--teal-900)}
.brand:hover{text-decoration:none}
.brand-mark{width:34px;height:34px;border-radius:9px;background:var(--teal);color:#fff;display:grid;place-items:center;font-size:1.1rem;box-shadow:inset 0 0 0 2px rgba(255,255,255,.15)}
.brand-tld{color:var(--terra)}
.brand--light,.brand--light .brand-text{color:#fff}
.site-nav{display:flex;align-items:center;gap:1.4rem}
.site-nav a{color:var(--teal-900);font-weight:500;font-size:.95rem}
.site-nav a:hover{color:var(--teal)}
.nav-cta{background:var(--teal);color:#fff!important;padding:.55em 1.1em;border-radius:999px;font-weight:600}
.nav-cta:hover{background:var(--teal-700);text-decoration:none}
.inline-form{display:inline}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--teal-900);border-radius:2px}

/* Flash */
.flash-wrap{margin-top:1rem}
.flash{padding:.8rem 1.1rem;border-radius:var(--radius-sm);margin-bottom:.6rem;font-size:.93rem}
.flash--error{background:#fbeee8;color:#9c3b1a;border:1px solid #f0cfc2}
.flash--success{background:#e7f3ec;color:#1c6b3f;border:1px solid #c5e3d1}

/* Hero */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--teal-900),var(--teal) 70%);color:#fff;padding:5rem 0 5.5rem}
.hero-pattern{position:absolute;inset:0;opacity:.13;background-image:radial-gradient(circle at 20% 30%,#fff 0 2px,transparent 2px),radial-gradient(circle at 70% 60%,var(--gold) 0 3px,transparent 3px);background-size:46px 46px,80px 80px}
.hero-inner{position:relative}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;font-weight:600;color:var(--gold);margin:0 0 1rem}
.hero h1{color:#fff;font-size:clamp(2.1rem,5vw,3.6rem);font-weight:800;margin:0 0 1rem}
.hero-sub{font-size:1.12rem;max-width:620px;color:rgba(255,255,255,.88);margin:0 0 2rem}
.searchbar{display:flex;gap:.5rem;max-width:580px;background:#fff;padding:.5rem;border-radius:999px;box-shadow:var(--shadow)}
.searchbar input{flex:1;border:none;outline:none;padding:.6rem 1rem;font:inherit;font-size:1rem;color:var(--ink);background:transparent}
.searchbar--page{margin:0 auto 2.5rem}
.hero-cities{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.6rem}
.hero-cities a{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;padding:.35em .9em;border-radius:999px;font-size:.85rem}
.hero-cities a:hover{background:rgba(255,255,255,.22);text-decoration:none}

/* Sections */
.section{padding:3.6rem 0}
.section--narrow{max-width:760px}
.section--article{max-width:760px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.8rem}
.kicker{text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;font-weight:700;color:var(--terra);margin:0 0 .3rem}
.section-head h1,.section-head h2{font-size:clamp(1.6rem,3vw,2.2rem);margin:0}
.section-more{font-weight:600;white-space:nowrap}
.band{background:var(--sand);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.result-count{color:var(--muted);font-size:.9rem}

/* City cards */
.ccard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem}
.ccard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.2s;color:inherit}
.ccard:hover{transform:translateY(-4px);text-decoration:none;border-color:#d8cfbd}
.ccard-img{aspect-ratio:16/10;background-size:cover;background-position:center;position:relative;background-color:var(--teal-700)}
.ccard-region{position:absolute;left:12px;bottom:12px;background:rgba(11,40,42,.78);color:#fff;font-size:.72rem;padding:.3em .7em;border-radius:999px;letter-spacing:.03em}
.ccard-body{padding:1.1rem 1.2rem 1.3rem}
.ccard-body h3{font-size:1.25rem;margin:0 0 .3rem}
.ccard-body p{color:var(--muted);font-size:.92rem;margin:0 0 .8rem}
.ccard-link{color:var(--teal);font-weight:600;font-size:.9rem}

/* Business cards */
.bcard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.2rem}
.bcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;box-shadow:var(--shadow);transition:.2s;color:inherit;display:flex;flex-direction:column}
.bcard:hover{transform:translateY(-3px);text-decoration:none;border-color:#d8cfbd}
.bcard--premium{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold),var(--shadow)}
.bcard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem}
.bcard-icon{font-size:1.6rem}
.badge{font-size:.7rem;font-weight:700;padding:.25em .7em;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}
.badge--premium{background:linear-gradient(135deg,var(--gold),#e0bd6c);color:#5a4410}
.bcard h3{font-size:1.12rem;margin:0 0 .15rem}
.bcard-meta{color:var(--muted);font-size:.82rem;margin:0 0 .6rem}
.bcard-desc{color:var(--ink);font-size:.9rem;margin:0 0 1rem;flex:1}
.bcard-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:.8rem}
.rating{color:var(--terra-600);font-weight:600;font-size:.88rem}
.rating em{color:var(--muted);font-weight:400;font-style:normal}
.rating--lg{font-size:1.05rem;margin:.3rem 0 0}
.bcard-link{color:var(--teal);font-weight:600;font-size:.86rem}

/* Post cards */
.pcard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem}
.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;box-shadow:var(--shadow);transition:.2s;color:inherit;display:block}
.pcard:hover{transform:translateY(-3px);text-decoration:none;border-color:#d8cfbd}
.pcard h3{font-size:1.18rem;margin:0 0 .5rem}
.pcard-tag{display:inline-block;background:var(--sand);color:var(--teal-700);font-size:.74rem;font-weight:600;padding:.25em .7em;border-radius:999px;margin-bottom:.6rem}
.pcard p{color:var(--muted);font-size:.92rem;margin:0 0 .8rem}
.pcard-link{color:var(--teal);font-weight:600;font-size:.88rem}

/* CTA band */
.cta-band{background:linear-gradient(135deg,var(--terra),var(--terra-600));color:#fff}
.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:3rem 0}
.cta-inner h2{color:#fff;margin:0 0 .4rem}
.cta-inner p{margin:0;max-width:560px;color:rgba(255,255,255,.92)}

/* Breadcrumb */
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:1.2rem}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb--light,.breadcrumb--light a{color:rgba(255,255,255,.85)}

/* City detail */
.city-hero{min-height:340px;display:flex;align-items:flex-end;background-size:cover;background-position:center;color:#fff}
.city-hero-inner{padding:2rem 0 2.4rem}
.city-region{text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:600;color:var(--gold);margin:0 0 .3rem}
.city-hero h1{color:#fff;font-size:clamp(2rem,5vw,3.2rem);margin:0}
.city-layout{display:grid;grid-template-columns:1fr 320px;gap:2.5rem;padding:3rem 20px}
.city-content .lead{font-size:1.2rem;color:var(--ink);margin:0 0 2rem}
.city-section{margin-bottom:1.8rem}
.city-section h2{font-size:1.4rem;border-left:4px solid var(--terra);padding-left:.7rem}
.city-section p{color:#2c3a3b}
.faq details{border:1px solid var(--line);border-radius:var(--radius-sm);padding:.9rem 1.1rem;margin-bottom:.7rem;background:#fff}
.faq summary{font-weight:600;cursor:pointer;font-family:var(--font-display);color:var(--teal-900)}
.faq p{margin:.7rem 0 0;color:var(--muted)}
.city-side{display:flex;flex-direction:column;gap:1.2rem}
.side-card{background:var(--sand);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem}
.side-card h3{font-size:1.05rem;margin:0 0 .8rem}
.side-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.side-list a{color:var(--teal-900);font-size:.92rem}
.side-more{display:inline-block;margin-top:.8rem;font-weight:600;font-size:.88rem}
.map-embed{display:block;background:#fff;border:1px dashed var(--teal);border-radius:var(--radius-sm);padding:1.1rem;text-align:center;font-weight:600}

/* Business detail */
.detail{display:grid;grid-template-columns:1fr 340px;gap:2.5rem;padding:1rem 20px 3rem}
.detail-head{display:flex;gap:1.1rem;margin-bottom:1.2rem}
.detail-icon{font-size:2.6rem}
.detail-head h1{font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 .2rem}
.detail-meta{color:var(--muted);margin:0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.detail-desc{font-size:1.05rem;color:#2c3a3b}
.detail-subhead{font-size:1.25rem;margin-top:1.6rem}
.hours{border-collapse:collapse;width:100%;max-width:320px}
.hours th{text-align:left;padding:.4rem .8rem .4rem 0;color:var(--muted);font-weight:500;width:60px}
.hours td{padding:.4rem 0}
.contact-card{background:var(--sand);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;position:sticky;top:90px}
.contact-card h2{font-size:1.2rem;margin:0 0 1rem}
.contact-row{display:flex;gap:.6rem;align-items:flex-start;margin:.5rem 0;font-size:.93rem}
.contact-actions{display:flex;gap:.6rem;margin-top:1.2rem;flex-wrap:wrap}

/* Article */
.article{max-width:720px}
.article-tag{display:inline-block;background:var(--sand);color:var(--teal-700);font-size:.78rem;font-weight:600;padding:.3em .8em;border-radius:999px;margin-bottom:1rem}
.article h1{font-size:clamp(1.8rem,4vw,2.6rem)}
.article-meta{color:var(--muted);font-size:.9rem;margin:0 0 1.5rem}
.article .lead{font-size:1.2rem;color:var(--ink);font-weight:500}
.article p{color:#2c3a3b;margin:0 0 1.1rem}

/* Search */
.search-h{font-size:1.4rem;margin:2rem 0 1rem}
.empty{text-align:center;padding:3rem 1rem;color:var(--muted);background:var(--sand);border-radius:var(--radius);display:flex;flex-direction:column;gap:1rem;align-items:center}

/* Filters */
.filterbar{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2rem;background:var(--sand);padding:1rem;border-radius:var(--radius)}
.filterbar input,.filterbar select{padding:.6rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:#fff;color:var(--ink)}
.filterbar input{flex:1;min-width:160px}

/* Auth & forms */
.auth-wrap{display:flex;justify-content:center}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.4rem;width:100%;max-width:440px}
.auth-card h1{font-size:1.7rem}
.muted{color:var(--muted)}
.form{display:flex;flex-direction:column;gap:1rem;margin-top:1.2rem}
.form label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:500;color:var(--teal-900)}
.form input,.form select,.form textarea{padding:.7rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);font:inherit;background:#fff;color:var(--ink)}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,95,99,.12)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.auth-alt{margin-top:1.2rem;font-size:.92rem;color:var(--muted)}
.auth-demo{margin-top:1rem;font-size:.8rem;color:var(--muted);background:var(--sand);padding:.7rem;border-radius:var(--radius-sm)}
.auth-demo code{background:#fff;padding:.1em .4em;border-radius:4px;font-size:.85em}

/* Tables / admin */
.admin-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;font-size:.92rem}
.admin-table th{text-align:left;background:var(--sand);padding:.8rem 1rem;font-family:var(--font-display);font-size:.82rem;color:var(--teal-900)}
.admin-table td{padding:.8rem 1rem;border-top:1px solid var(--line)}
.admin-table .right{text-align:right;display:flex;gap:.4rem;justify-content:flex-end;flex-wrap:wrap}
.status{font-size:.76rem;font-weight:600;padding:.25em .7em;border-radius:999px}
.status--published{background:#e7f3ec;color:#1c6b3f}
.status--draft{background:#fdf1e3;color:#9c6a1a}
.upsell{margin-top:2.5rem;background:linear-gradient(135deg,var(--teal-900),var(--teal));color:#fff;border-radius:var(--radius);padding:1.6rem}
.upsell h3{color:#fff;margin:0 0 .4rem}
.upsell p{margin:0;color:rgba(255,255,255,.9);font-size:.93rem}
.upsell em{color:var(--gold);font-style:normal}

/* Stat grid */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:2rem}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;text-align:center;box-shadow:var(--shadow)}
.stat-num{display:block;font-family:var(--font-display);font-size:2rem;font-weight:800;color:var(--teal)}
.stat-lbl{color:var(--muted);font-size:.85rem}

/* Admin bar */
.admin-bar{background:var(--teal-900);color:#fff}
.admin-bar-inner{display:flex;align-items:center;gap:1.5rem;height:48px}
.admin-bar-label{font-family:var(--font-display);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold)}
.admin-bar nav{display:flex;gap:1.2rem}
.admin-bar nav a{color:rgba(255,255,255,.8);font-size:.9rem}
.admin-bar nav a:hover,.admin-bar nav a.active{color:#fff}

/* Footer */
.site-footer{background:var(--teal-900);color:rgba(255,255,255,.8);margin-top:3rem;padding:3rem 0 1.5rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand p{margin:.8rem 0 0;font-size:.92rem;max-width:280px}
.site-footer h4{color:#fff;font-size:.95rem;margin:0 0 .9rem}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.site-footer ul a{color:rgba(255,255,255,.8);font-size:.9rem}
.site-footer ul a:hover{color:#fff}
.footer-bottom{padding-top:1.2rem;font-size:.84rem;color:rgba(255,255,255,.6)}

/* Misc */
.center{text-align:center}
.big-404{font-family:var(--font-display);font-size:5rem;font-weight:800;color:var(--terra);margin:0;line-height:1}

/* Responsive */
@media (max-width:900px){
  .city-layout,.detail{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-card{position:static}
}
@media (max-width:720px){
  .nav-toggle{display:flex}
  .site-nav{position:absolute;top:68px;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);flex-direction:column;align-items:stretch;gap:0;padding:.5rem 20px 1rem;display:none;box-shadow:var(--shadow)}
  .site-nav.open{display:flex}
  .site-nav a,.site-nav .inline-form{padding:.7rem 0;border-bottom:1px solid var(--line)}
  .nav-cta{text-align:center;margin-top:.6rem;border-bottom:none!important}
  .cta-inner{flex-direction:column;align-items:flex-start}
  .section-head{flex-direction:column;align-items:flex-start;gap:.4rem}
  .form-row{grid-template-columns:1fr}
}
