/* ============================================================
   InCity network — shared stylesheet.  Warm & local.
   Colors come from CSS variables injected per-city in <head>.
   ============================================================ */

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--paper);line-height:1.6;
  font-size:17px;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{line-height:1.2;margin:0 0 .5em;font-weight:800;letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,4.5vw,2.9rem)}
h2{font-size:clamp(1.4rem,3vw,2rem)}
p{margin:0 0 1rem}
.wrap{width:100%;max-width:1140px;margin-inline:auto;padding-inline:20px}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.center{text-align:center}
.nowrap{white-space:nowrap}
.lead{font-size:1.15rem;color:#4a3f39}

.skip-link{position:absolute;left:-999px;top:0;background:var(--primary);color:#fff;padding:.6rem 1rem;z-index:100}
.skip-link:focus{left:0}

/* ---- Buttons ---------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:.4em;justify-content:center;
  background:var(--primary);color:#fff;border:1px solid var(--primary);
  padding:.7rem 1.2rem;border-radius:10px;font-weight:700;font-size:.95rem;
  cursor:pointer;transition:transform .05s ease,background .15s ease;text-decoration:none;
}
.btn:hover{background:var(--primary-dark);border-color:var(--primary-dark);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:.45rem .8rem;font-size:.85rem;border-radius:8px}
.btn-accent{background:var(--accent);border-color:var(--accent);color:#3a2b12}
.btn-accent:hover{filter:brightness(.95);background:var(--accent)}
.btn-ghost{background:transparent;color:var(--primary);border-color:var(--line)}
.btn-ghost:hover{background:#fff;border-color:var(--primary);color:var(--primary)}
.btn-block{display:flex;width:100%;margin-top:.5rem}
.btn-row{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin:1rem 0}

/* ---- Header / nav ----------------------------------------- */
.site-header{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.7rem}
.brand{display:inline-flex;align-items:baseline;font-weight:900;font-size:1.35rem;letter-spacing:-.02em;text-decoration:none;color:var(--ink)}
.brand-mark{background:var(--primary);color:#fff;padding:.05em .32em;border-radius:7px;margin-right:.12em}
.brand-city{color:var(--ink)}
.brand--footer{color:#fff}.brand--footer .brand-city{color:#fff}
.primary-nav ul{display:flex;align-items:center;gap:.3rem;list-style:none;margin:0;padding:0}
.primary-nav a{display:inline-block;padding:.5rem .8rem;border-radius:8px;color:var(--ink);font-weight:600;font-size:.95rem}
.primary-nav a:hover{background:var(--paper);text-decoration:none}
.primary-nav a[aria-current="page"]{color:var(--primary)}
.nav-cta a{background:var(--primary);color:#fff}
.nav-cta a:hover{background:var(--primary-dark)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* ---- Hero ------------------------------------------------- */
.hero{
  background:
    radial-gradient(1200px 400px at 80% -10%, color-mix(in srgb,var(--accent) 35%,transparent), transparent),
    linear-gradient(160deg, color-mix(in srgb,var(--primary) 12%,var(--paper)), var(--paper));
  padding:clamp(2.5rem,6vw,4.5rem) 0 clamp(2rem,4vw,3rem);
  border-bottom:1px solid var(--line);
}
.hero-kicker{text-transform:uppercase;letter-spacing:.08em;font-size:.8rem;font-weight:700;color:var(--primary);margin:0 0 .5rem}
.hero-title{margin:0 0 .5rem}
.hero-sub{font-size:1.15rem;max-width:44ch;color:#4a3f39}
.hero-quick{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.1rem}
.hero-quick a{background:var(--card);border:1px solid var(--line);padding:.35rem .75rem;border-radius:999px;font-size:.9rem;font-weight:600;color:var(--ink)}
.hero-quick a:hover{border-color:var(--primary);color:var(--primary);text-decoration:none}

/* Local weather widget */
.weather{
  display:inline-flex;align-items:center;gap:.6rem;margin:0 0 1.1rem;min-height:2.9rem;
  background:var(--card);border:1px solid var(--line);border-radius:999px;
  padding:.4rem .9rem .4rem .6rem;color:var(--ink);font-weight:600;font-size:.9rem;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
}
.weather:hover{text-decoration:none;border-color:var(--primary)}
.weather-icon{font-size:1.5rem;line-height:1}
.weather-body{display:flex;flex-direction:column;line-height:1.15}
.weather-temp{font-weight:800}
.weather-desc{font-size:.78rem;color:var(--muted);font-weight:500}
.weather-city{color:var(--muted);font-weight:500}

.searchbar{display:flex;gap:.5rem;max-width:640px;margin-top:.5rem}
.searchbar input{
  flex:1;padding:.85rem 1rem;border:1px solid var(--line);border-radius:10px;
  font-size:1rem;background:#fff;color:var(--ink);
}
.searchbar input:focus{outline:2px solid var(--primary);outline-offset:1px;border-color:var(--primary)}

/* ---- Sections --------------------------------------------- */
.section{padding-block:clamp(2rem,4vw,3.2rem)}
.section--tint{background:color-mix(in srgb,var(--accent) 12%,var(--paper));border-block:1px solid var(--line)}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.2rem;flex-wrap:wrap}
.section-head h2{margin:0}
.section-link{font-weight:700;font-size:.95rem;white-space:nowrap}

/* ---- Category grid ---------------------------------------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.cat-tile{
  display:flex;flex-direction:column;gap:.2rem;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:1.1rem;color:var(--ink);transition:.15s;position:relative;
}
.cat-tile:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.06);text-decoration:none}
.cat-icon{font-size:1.7rem}
.cat-name{font-weight:800}
.cat-blurb{font-size:.85rem;color:var(--muted)}
.cat-count{margin-top:.4rem;font-size:.75rem;font-weight:700;color:var(--primary)}

/* ---- Business cards --------------------------------------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.1rem}
.biz-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1.1rem;display:flex;flex-direction:column;gap:.6rem;position:relative}
.biz-card--featured{border-color:var(--accent);box-shadow:0 6px 18px color-mix(in srgb,var(--accent) 30%,transparent)}
.badge{position:absolute;top:.8rem;right:.8rem;font-size:.7rem;font-weight:800;padding:.2rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}
.badge--featured{background:var(--accent);color:#3a2b12}
.biz-card-head{display:flex;gap:.7rem;align-items:flex-start;padding-right:4.5rem}
.biz-avatar{font-size:1.6rem;width:2.6rem;height:2.6rem;display:grid;place-items:center;background:var(--paper);border-radius:10px;flex:none}
.biz-avatar--lg{font-size:2.4rem;width:4rem;height:4rem}
.biz-avatar--logo{background:#fff;border:1px solid var(--line);overflow:hidden;padding:4px}
.biz-avatar--logo img{width:100%;height:100%;object-fit:contain;display:block}
.biz-name{font-size:1.1rem;margin:0}
.biz-name a{color:var(--ink)}
.biz-cat{font-size:.82rem;font-weight:600;color:var(--primary)}
.biz-desc{font-size:.92rem;color:#4a3f39;margin:0}
.biz-meta{list-style:none;margin:0;padding:0;font-size:.85rem;color:var(--muted);display:flex;flex-direction:column;gap:.2rem}
.biz-meta a{color:var(--muted)}
.biz-card-foot{display:flex;gap:.5rem;margin-top:auto;flex-wrap:wrap}

/* ---- Split CTA -------------------------------------------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.split-item{border-radius:16px;padding:1.6rem;border:1px solid var(--line)}
.split-item--resources{background:var(--card)}
.split-item--cta{background:linear-gradient(150deg,color-mix(in srgb,var(--primary) 90%,#000),var(--primary));color:#fff}
.split-item--cta h2{color:#fff}
.split-item--cta p{color:#fff;opacity:.95}
.chip-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
.chip{display:inline-block;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:.4rem .85rem;font-size:.88rem;font-weight:600;color:var(--ink)}
.chip:hover{border-color:var(--primary);color:var(--primary);text-decoration:none}

/* ---- Ad slot ---------------------------------------------- */
.ad-slot{max-width:1140px;margin:2rem auto;padding:1.2rem;border:2px dashed var(--line);border-radius:12px;text-align:center;color:var(--muted);background:var(--card)}
.ad-slot-label{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;margin-bottom:.2rem}

/* ---- Breadcrumb ------------------------------------------- */
.breadcrumb{font-size:.85rem;color:var(--muted);padding-top:1rem}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--primary)}

/* ---- Page hero (interior) --------------------------------- */
.page-hero{padding-block:clamp(1.6rem,4vw,2.6rem) 1.2rem}
.page-hero-sub{font-size:1.1rem;color:#4a3f39;max-width:60ch}

/* ---- Landing ---------------------------------------------- */
.landing-hero{padding-block:1.5rem .5rem}
.landing-intro{font-size:1.1rem;color:#4a3f39;max-width:70ch}
.landing-count{font-weight:700;color:var(--primary);font-size:.9rem}
.empty-state{background:var(--card);border:1px dashed var(--line);border-radius:14px;padding:2.5rem 1.5rem;text-align:center}

/* ---- FAQ -------------------------------------------------- */
.faq{display:flex;flex-direction:column;gap:.6rem;max-width:820px}
.faq-item{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:.4rem 1rem}
.faq-item summary{cursor:pointer;font-weight:700;padding:.6rem 0;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:"＋";color:var(--primary);font-weight:800;margin-right:.5rem}
.faq-item[open] summary::before{content:"－"}
.faq-item p{margin:.2rem 0 .8rem;color:#4a3f39}

/* ---- Directory layout ------------------------------------- */
.directory-layout{display:grid;grid-template-columns:250px 1fr;gap:1.6rem;padding-top:1.5rem}
.dir-rail{position:sticky;top:80px;align-self:start}
.rail-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.rail-list{list-style:none;margin:0;padding:0}
.rail-list a{display:flex;justify-content:space-between;gap:.5rem;padding:.5rem .6rem;border-radius:8px;color:var(--ink);font-size:.92rem}
.rail-list a:hover{background:var(--card);text-decoration:none}
.rail-count{color:var(--muted);font-size:.8rem}
.dir-group{margin-bottom:2.2rem}

/* ---- Business detail -------------------------------------- */
.biz-detail{padding-top:1rem}
.biz-detail-head{display:flex;gap:1rem;align-items:center;margin-bottom:1.2rem}
.biz-detail-head h1{margin:.2rem 0}
.biz-detail-sub{color:var(--muted);margin:0}
.biz-detail-grid{display:grid;grid-template-columns:1fr 340px;gap:1.6rem;align-items:start}
.tag-row{display:flex;flex-wrap:wrap;gap:.4rem;margin:1rem 0}
.tag{background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:.25rem .7rem;font-size:.8rem;color:var(--muted)}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:1.2rem;position:sticky;top:80px}
.info-title{font-size:1rem;margin:0 0 .8rem}
.info-list{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.6rem;font-size:.92rem}
.info-list li{display:flex;gap:.6rem;align-items:flex-start}
.info-list li span{flex:none}
.claim-note{font-size:.82rem;color:var(--muted);margin-top:.8rem;text-align:center}

/* ---- Resources -------------------------------------------- */
.res-jump{display:flex;flex-wrap:wrap;gap:.5rem;padding-block:1rem}
.res-jump a{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:.4rem .85rem;font-size:.85rem;font-weight:600;color:var(--ink)}
.res-jump a:hover{border-color:var(--primary);color:var(--primary);text-decoration:none}
.res-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(460px,1fr));gap:1.4rem;padding-top:1rem}
.res-group{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:1.3rem;scroll-margin-top:80px}
.res-group-head h2{font-size:1.2rem;margin:0}
.res-group-head p{font-size:.9rem;color:var(--muted);margin:.3rem 0 1rem}
/* two columns of links per resource group */
.res-links{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;column-gap:1.4rem}
.res-link{border-bottom:1px solid var(--line);padding:.55rem 0}
.res-link a{display:flex;flex-direction:column;gap:.05rem;font-weight:600;color:var(--ink)}
.res-link a:hover{color:var(--primary)}
.res-link-meta{font-size:.78rem;color:var(--muted);font-weight:500}
.res-note{font-size:.8rem;color:var(--muted);margin:.15rem 0 0}
@media (max-width:560px){.res-links{grid-template-columns:1fr}}

/* ---- Blog ------------------------------------------------- */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.4rem;padding-block:1.5rem}
.post-card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:1.4rem;display:flex;flex-direction:column;gap:.5rem}
.post-tag{align-self:flex-start;background:color-mix(in srgb,var(--accent) 25%,#fff);color:#5a3d13;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:.2rem .6rem;border-radius:999px}
.post-card-title{font-size:1.25rem;margin:0}
.post-card-title a{color:var(--ink)}
.post-meta{font-size:.82rem;color:var(--muted);margin:0}
.post-excerpt{color:#4a3f39;margin:0}
.read-more{font-weight:700;margin-top:auto}

/* ---- Article / prose -------------------------------------- */
.prose,.article{max-width:760px}
.article-head{padding-top:1rem}
.article-body{font-size:1.08rem}
.article-body h2{margin-top:1.8rem}
.article-body h3{margin-top:1.4rem}
.article-body ul{padding-left:1.3rem}
.article-body blockquote{border-left:3px solid var(--accent);margin:1rem 0;padding:.3rem 0 .3rem 1rem;color:var(--muted);font-style:italic}
.article-foot{margin-top:2rem;padding-top:1.2rem;border-top:1px solid var(--line)}
.prose ul{padding-left:1.3rem}
.prose h2{margin-top:1.8rem}

/* ---- Forms ------------------------------------------------ */
.form-wrap{max-width:680px;padding-block:1rem 3rem}
.stack-form{display:flex;flex-direction:column;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.35rem}
.field label{font-weight:700;font-size:.9rem}
.field input,.field select,.field textarea{
  padding:.7rem .8rem;border:1px solid var(--line);border-radius:10px;font-size:1rem;
  background:#fff;color:var(--ink);font-family:inherit;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--primary);outline-offset:1px;border-color:var(--primary)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-section{border:1px solid var(--line);border-radius:12px;padding:1rem 1.2rem 1.2rem;margin:0;display:flex;flex-direction:column;gap:1rem}
.form-section legend{font-weight:800;padding:0 .45rem;font-size:.9rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.notice{border-radius:12px;padding:1.2rem 1.4rem;margin-bottom:1.4rem}
.notice--success{background:color-mix(in srgb,var(--success) 15%,#fff);border:1px solid var(--success)}
.notice--error{background:#fdecec;border:1px solid #d9534f}
.notice ul{margin:.4rem 0 0;padding-left:1.2rem}

/* ---- Error page ------------------------------------------- */
.error-page{padding-block:3rem}
.error-code{font-size:4rem;font-weight:900;color:var(--accent);margin:0;line-height:1}

/* ---- Footer ----------------------------------------------- */
.site-footer{background:#211a17;color:#d9cdc2;margin-top:3rem;padding-block:2.5rem 1.5rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:1.6rem}
.footer-brand p{color:#b6a99d;font-size:.9rem}
.footer-col h4{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;margin:0 0 .7rem}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.45rem}
.footer-col a{color:#d9cdc2;font-size:.92rem}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid #3a2f2a;margin-top:1.8rem;padding-top:1.2rem;font-size:.82rem;color:#9a8d82;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-bottom .muted{color:#8a7d72}

/* ---- Responsive ------------------------------------------- */
@media (max-width:860px){
  .directory-layout{grid-template-columns:1fr}
  .dir-rail{position:static}
  .rail-list{display:grid;grid-template-columns:1fr 1fr;gap:.2rem}
  .biz-detail-grid{grid-template-columns:1fr}
  .info-card{position:static}
  .split{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  body{font-size:16px}
  .nav-toggle{display:flex}
  .primary-nav{display:none;position:absolute;left:0;right:0;top:100%;background:var(--card);border-bottom:1px solid var(--line);padding:.6rem}
  .primary-nav.open{display:block}
  .primary-nav ul{flex-direction:column;align-items:stretch;gap:.1rem}
  .primary-nav a{padding:.7rem .8rem}
  .header-inner{position:relative}
  .grid-2{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column}
}
