:root{
  --bg:#fffdfb;
  --bg-alt:#faf7f2;
  --text:#1f1d1b;
  --muted:#6f6b65;
  --brand:#7a1c2f; /* deep maroon */
  --accent:#b4915a; /* muted gold */
  --border:#e8e2da;
  --radius:20px;
  --shadow:0 10px 30px rgba(0,0,0,.08);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5}
img{max-width:100%;display:block}

/* Wider container so header has less side whitespace */
.container{width:min(1280px, 96%);margin-inline:auto}

.muted{color:var(--muted)}
.small{font-size:.95rem}
.section{padding:72px 0}
.section-alt{background:var(--bg-alt);padding:72px 0}
.section-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:28px;gap:16px}
.section-head h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.2rem);margin:0}

/* =========================
   HEADER
   ========================= */
.site-header{position:sticky;top:0;z-index:1000;background:#fff;backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--border)}

/* Top utility bar */
.topbar{background:#fff;border-bottom:1px solid var(--border);font-size:.85rem}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:6px 0}
.top-links,.top-social{display:flex;gap:18px;list-style:none;margin:0;padding:0}
.top-links a,.top-social a{color:var(--muted);text-decoration:none}
.top-links a:hover,.top-social a:hover{color:var(--brand)}

/* Middle row: search • centered logo • icons */
.masthead{
  display:grid;
  grid-template-columns: 1fr auto 1fr; /* centers logo perfectly */
  align-items:center;
  gap:12px;
  padding:10px 0;
}
.mast-toggle{display:none;border:1px solid var(--border);background:#fff;border-radius:10px;padding:8px 10px;align-items:center;gap:8px}
.mast-toggle .bar{display:block;width:18px;height:2px;background:var(--text);margin:3px 0}
.mast-toggle .label{font-size:.85rem;color:var(--muted)}

.search{
  justify-self:start;
  width:100%;
  max-width:420px;
  padding:6px 12px;
  border:1px solid var(--border);
  border-radius:24px;
  display:flex;align-items:center;gap:8px;
}
.search-ic{width:16px;height:16px;opacity:.6}
.search input{border:none;outline:none;background:transparent;font-size:.9rem;min-width:0;width:100%}

/* Brand: icon + wordmark */
.brand{
  justify-self:center;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.brand-icon{ height:40px; width:auto; flex:0 0 auto; }
.brand-word{ height:28px; width:auto; flex:0 0 auto; }
.brand--footer .brand-icon{ height:28px; }
.brand--footer .brand-word{ height:20px; }

/* Responsive tweaks */
@media (min-width:1100px){
  .brand-icon{ height:44px; }
  .brand-word{ height:32px; }
}
@media (max-width:700px){
  .brand-icon{ height:32px; }
  .brand-word{ height:24px; }
}

.mast-icons{justify-self:end;display:flex;gap:12px}
.icon-link{display:grid;place-items:center;width:34px;height:34px;border-radius:999px;border:1px solid var(--border);color:var(--text);text-decoration:none}
.icon-link:hover{border-color:var(--brand);color:var(--brand)}

/* Category strip with underline + mega */
.category-nav{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#fff}
.cat-list{display:flex;gap:28px;list-style:none;margin:0;padding:10px 0;overflow:auto}
.cat-link{
  text-decoration:none;color:#623030;
  text-transform:uppercase;letter-spacing:.10em;font-weight:600;
  padding:10px 4px;border-bottom:2px solid transparent;display:inline-block;white-space:nowrap
}
.cat-link:hover,.cat-link:focus{color:var(--brand)}
.cat-link.active,.has-mega:hover > .cat-link{border-bottom-color:var(--brand)}

.has-mega{position:relative}
.mega{
  position:absolute;left:0;top:100%;
  background:#fff;border:1px solid var(--border);border-radius:16px;
  padding:18px 20px;display:none;gap:28px;box-shadow:var(--shadow);z-index:1001
}
.has-mega:hover .mega{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr))}
.mega-col{display:grid;gap:8px}
.mega-col h5{margin:0 0 6px;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.mega-link{padding:6px 8px;border-radius:10px;text-decoration:none;color:var(--text);font-size:.95rem}
.mega-link:hover{background:var(--bg-alt);color:var(--brand)}

/* =========================
   HERO (NO-CROP)
   ========================= */
.hero{position:relative; overflow:hidden; background:#000;}
.hero-track{ display:flex; transition:transform .6s ease; }
.hero-slide{ position:relative; flex:0 0 100%; }
.hero-img{
  width:100%; height:auto; display:block;
  aspect-ratio:2048/663;           /* consistent shape while loading */
}
.hero-slide::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(0,0,0,.55), transparent 52%);
  pointer-events:none;
}
.overlay{
  position:absolute; right:0; bottom:min(4vw,40px);
  color:#fff; max-width:min(54ch,48vw);
  padding: clamp(16px,2vw,28px) clamp(20px,3vw,40px);
}
.overlay h1{
  font-family:'Playfair Display',serif;
  font-weight:700;
  font-size:clamp(1.8rem,4vw,3rem);
  margin:0 0 8px;
}
.overlay p{margin:0; font-size:1.05rem}
.hero-dots{
  position:absolute; left:50%; bottom:16px; transform:translateX(-50%);
  display:flex; gap:10px;
}
.hero-dots button{
  width:12px; height:12px; border-radius:999px;
  border:1px solid #fff; background:transparent;
}
.hero-dots button[aria-current="true"]{ background:#fff; }

/* =========================
   WEDDING EDIT TILES
   ========================= */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tile{position:relative;border-radius:var(--radius);overflow:hidden;text-decoration:none;color:#fff}
.tile span{position:absolute;left:16px;bottom:16px;background:rgba(0,0,0,.55);padding:8px 10px;border-radius:999px}
.tile img{height:100%;width:100%;object-fit:cover;aspect-ratio:4/5}

/* =========================
   CURATED CARDS
   ========================= */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.card img{aspect-ratio:1/1;object-fit:cover}
.card-body{padding:16px}
.btn{display:inline-block;background:var(--brand);color:#fff;text-decoration:none;padding:10px 14px;border-radius:12px;font-weight:600}
.btn:hover{opacity:.9}

/* =========================
   CATEGORY CHIPS
   ========================= */
.categories{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.category{display:grid;place-items:center;border:1px solid var(--border);border-radius:14px;padding:26px;text-decoration:none;color:var(--text);font-weight:600;background:linear-gradient(180deg,#fff,var(--bg-alt))}
.category:hover{border-color:var(--brand);color:var(--brand)}

/* =========================
   GALLERY + LIGHTBOX
   ========================= */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-item img{border-radius:16px;aspect-ratio:1/1;object-fit:cover}
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(0,0,0,.8);z-index:2000}
.lightbox img{max-width:90vw;max-height:80vh;border-radius:16px;box-shadow:var(--shadow)}
.lightbox.show{display:flex}
.lightbox-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:999px;border:none;background:#fff;cursor:pointer}

/* =========================
   ABOUT
   ========================= */
.about{max-width:70ch}

/* =========================
   CONTACT
   ========================= */
.contact{}
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.contact-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px;box-shadow:var(--shadow)}
.contact-card a{color:var(--brand);text-decoration:none}

/* =========================
   FOOTER
   ========================= */
.site-footer{border-top:1px solid var(--border);padding:40px 0;background:#fff}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px}
.footer-grid h4{margin:0 0 8px;font-family:'Playfair Display',serif}
.footer-grid ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer-grid a{text-decoration:none;color:var(--text)}
.footer-grid a:hover{color:var(--brand)}
.social{display:grid;gap:8px}
.copyright{text-align:center;color:var(--muted);margin-top:16px}

/* Mobile sticky contact */
.contact-cta{position:fixed;right:16px;bottom:16px;background:var(--accent);color:#fff;text-decoration:none;padding:12px 16px;border-radius:999px;box-shadow:var(--shadow);font-weight:700}

/* =========================
   RESPONSIVE
   ========================= */
@media (max-width:1100px){
  .search{max-width:360px}
}
@media (max-width:1000px){
  .tiles{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:1fr 1fr}
  .categories{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:900px){
  .masthead{grid-template-columns:auto 1fr auto}
  .brand{order:2}
  .search{order:3;max-width:none}
  .mast-icons{display:none}
  .mast-toggle{display:inline-flex;order:1}
  .category-nav .cat-list{display:none;flex-direction:column;gap:10px;padding:12px 0}
  .category-nav .cat-list.open{display:flex}
  .has-mega:hover .mega{position:static;display:grid;grid-template-columns:1fr 1fr}
}
@media (max-width:700px){
  .overlay{padding:20px}
  .card-grid{grid-template-columns:1fr}
  .categories{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr}
  .contact-cards{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
