/* Styles for generated pages (location landing pages + blog). Loaded after
   site.css, reusing its design tokens. */

/* Page hero (dark photo band) */
.page-hero{position:relative;background-size:cover;background-position:center;color:#fff;
  padding:64px 0 56px;background-color:var(--navy-deep)}
.page-hero.short{padding:52px 0 40px}
.page-hero .wrap{position:relative}
.page-hero h1{color:#fff;font-size:clamp(2rem,4.4vw,3.2rem);font-weight:700;margin:8px 0 0}
.page-hero .lead{color:rgba(255,255,255,.88);font-size:1.12rem;max-width:60ch;margin:16px 0 0}
.page-hero .hero-cta{margin-top:24px}
.page-hero .hero-trust{margin-top:22px}

/* Breadcrumbs */
.crumbs{font-size:.82rem;color:rgba(255,255,255,.72);margin-bottom:12px;font-weight:600}
.crumbs a{color:rgba(255,255,255,.9)}
.crumbs span{color:#fff}

/* Compact services on location pages */
.svc-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.svc-mini{background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);padding:22px;box-shadow:var(--shadow-sm)}
.svc-mini h3{font-family:var(--font-display);color:var(--ink);font-size:1.12rem;margin:0 0 6px}
.svc-mini p{margin:0;color:var(--body);font-size:.95rem}

/* Why grid (reused on location pages) */
.why-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:40px;align-items:start}
.why-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:24px}
.why-list h3{font-family:var(--font-display);font-size:1.08rem;margin:0 0 5px}
.why-list h3::before{content:"✓";color:var(--aqua);font-weight:800;margin-right:8px}
.why-list p{margin:0;color:var(--body);font-size:.94rem}
.why-list.light h3{color:#fff}
.why-list.light p{color:rgba(255,255,255,.8)}

/* FAQ */
.faq{display:grid;gap:12px;max-width:820px}
.faq-item{background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);padding:4px 20px}
.faq-item summary{cursor:pointer;font-family:var(--font-display);font-weight:600;color:var(--ink);padding:16px 0;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";float:right;color:var(--aqua);font-weight:800}
.faq-item[open] summary::after{content:"–"}
.faq-item p{margin:0 0 16px;color:var(--body)}

/* Areas index grid */
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.area-card{display:block;background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.area-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);text-decoration:none}
.area-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.area-card-body{padding:14px 16px}
.area-card-body h3{font-family:var(--font-display);color:var(--ink);font-size:1.05rem;margin:0}
.area-card-body span{font-size:.82rem;color:var(--muted)}

/* Blog index cards */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post-card{display:block;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);text-decoration:none}
.post-card img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.post-card-body{padding:18px 20px 22px}
.post-date{font-size:.78rem;color:var(--aqua-deep);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.post-card-body h3{font-family:var(--font-display);color:var(--ink);font-size:1.18rem;margin:8px 0 8px;line-height:1.2}
.post-card-body p{margin:0;color:var(--body);font-size:.94rem}

/* Article prose */
.prose{max-width:760px;margin:0 auto;font-size:1.08rem;color:var(--body)}
.prose h2{font-family:var(--font-display);color:var(--ink);font-size:1.6rem;margin:34px 0 12px}
.prose h3{font-family:var(--font-display);color:var(--ink);font-size:1.25rem;margin:26px 0 10px}
.prose p{margin:0 0 16px}
.prose ul,.prose ol{margin:0 0 18px;padding-left:22px}
.prose li{margin:0 0 8px}
.prose a{color:var(--aqua-deep);font-weight:600}
.prose img{width:100%;border-radius:var(--r-md);margin:20px 0}
.prose blockquote{border-left:4px solid var(--aqua);margin:20px 0;padding:6px 0 6px 18px;color:var(--ink);font-style:italic}
.prose hr{border:0;border-top:1px solid var(--line);margin:30px 0}

@media (max-width:880px){
  .svc-mini-grid,.area-grid{grid-template-columns:1fr 1fr}
  .post-grid{grid-template-columns:1fr 1fr}
  .why-grid{grid-template-columns:1fr;gap:24px}
  .why-list{grid-template-columns:1fr}
}
@media (max-width:560px){
  .svc-mini-grid,.area-grid,.post-grid{grid-template-columns:1fr}
  .page-hero{padding:44px 0 36px}
}
