/*
Theme Name: B&B Photography
Theme URI: https://example.com
Author: You
Author URI: https://example.com
Description: Elegant, light-and-airy wedding photography theme for B&B Photography LLC. Clean black & white aesthetic, portfolio post types, and inviting layouts.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: bbp
*/

:root{
  --ink:#111111;
  --bg:#ffffff;
  --muted:#757575;
  --alt:#f7f6f4;
  --max:1100px;
  --radius:16px;
  --shadow:0 10px 30px rgba(0,0,0,.06);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  line-height:1.7;font-size:16px;
}

h1,h2,h3,h4{
  font-family: "Playfair Display", Georgia, 'Times New Roman', serif;
  margin:0 0 .5em;line-height:1.2
}
p{margin:0 0 1em;color:var(--ink)}
img{max-width:100%;height:auto;display:block;border-radius:12px}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section.alt{background:var(--alt)}

/* Header */
.site-header{
  position:sticky;top:0;z-index:99;
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 20px;border-bottom:1px solid #eee;background:rgba(255,255,255,.85);backdrop-filter:blur(10px)
}
.brand{font-family:"Playfair Display", Georgia, serif;font-size:22px;text-decoration:none;color:var(--ink);letter-spacing:.5px}
.nav{display:flex;gap:18px;align-items:center}
.nav a{color:var(--ink);text-decoration:none}
.nav .cta{border:1px solid var(--ink);padding:8px 12px;border-radius:999px}
.nav-toggle{display:none}
@media (max-width:860px){
  .nav-toggle{display:inline-flex;border:1px solid #333;background:none;padding:8px 12px;border-radius:999px}
  .nav{display:none;position:absolute;right:16px;top:64px;background:#fff;border:1px solid #eee;border-radius:12px;padding:12px;flex-direction:column;box-shadow:var(--shadow)}
  .nav.open{display:flex}
}

/* Hero */
.hero{position:relative}
.hero img{width:100%;height:70vh;object-fit:cover;border-radius:0}
.hero .overlay{
  position:absolute;inset:auto 0 10% 0;text-align:center;color:#fff;padding:0 20px;
}
.hero h1{font-size:clamp(28px, 3.5vw + 12px, 56px);text-shadow:0 10px 30px rgba(0,0,0,.35)}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;text-decoration:none;border:1px solid #111;color:#111;background:#fff}

/* Grids */
.grid{display:grid;gap:18px}
.grid.two{grid-template-columns:repeat(2,1fr)}
.grid.three{grid-template-columns:repeat(3,1fr)}
@media (max-width:920px){.grid.two{grid-template-columns:1fr}.grid.three{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid.three{grid-template-columns:1fr}}

/* Cards */
.card{background:#fff;border:1px solid #eee;border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}

/* Footer */
.site-footer{padding:40px 20px;border-top:1px solid #eee;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.site-footer .social{list-style:none;display:flex;gap:12px;margin:0;padding:0}

/* FAQ */
.faq details{background:#fff;border:1px solid #eee;border-radius:12px;padding:14px}
.faq details+details{margin-top:10px}
.faq summary{cursor:pointer;font-weight:600}

/* Galleries */
.post-grid article{display:grid;gap:10px}
.post-grid .meta{color:var(--muted);font-size:.95em}
