/* Hochzeitssängerin — elegant wedding design system */
:root{
  --bg:#FBF7F2;
  --surface:#FFFFFF;
  --ink:#2B2622;
  --accent:#B08D57;
  --accent-dark:#8c6e3f;
  --rose:#C8A2A8;
  --muted:#7A7068;
  --line:#e7ddd0;
  --serif:'Playfair Display', Georgia, 'Times New Roman', serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}
*{box-sizing:border-box}
body.wedding-body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:1.02rem;
  line-height:1.7;
  margin:0;
}
h1,h2,h3,h4,.footer-title{font-family:var(--serif);font-weight:600;letter-spacing:.2px;color:var(--ink)}
.site-main{display:block}
.container-xxl{max-width:1240px;margin-inline:auto;padding-inline:1.25rem;width:100%}

.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:1rem;top:1rem;background:var(--ink);color:#fff;padding:.5rem .9rem;border-radius:6px;z-index:1100}
.eyebrow,.hero-stage__eyebrow,.footer-kicker{
  display:inline-block;font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:.6rem;
}

/* Header / nav */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(251,247,242,.94);
  backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.wedding-navbar{padding:.7rem 0}
.wedding-brand{display:flex;flex-direction:column;text-decoration:none;line-height:1.15}
.wedding-brand__title{font-family:var(--serif);font-size:1.5rem;font-weight:700;color:var(--ink)}
.wedding-brand__sub{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.wedding-nav-list{display:flex;gap:.4rem;align-items:center;margin:0;padding:0;list-style:none;flex-wrap:wrap}
.wedding-navbar .nav-link{color:var(--ink);font-weight:500;font-size:.95rem;padding:.45rem .8rem;border-radius:999px;transition:color .2s,background .2s}
.wedding-navbar .nav-link:hover,.wedding-navbar .nav-link.active{color:var(--accent-dark);background:rgba(176,141,87,.1)}
.wedding-navbar .dropdown-menu{border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 40px rgba(43,38,34,.12);padding:.4rem}
.wedding-navbar .dropdown-item{border-radius:8px;font-size:.92rem;color:var(--ink)}
.wedding-navbar .dropdown-item:hover{background:rgba(176,141,87,.12);color:var(--accent-dark)}
.navbar-toggler{padding:.3rem .5rem}

/* Hero */
.hero-stage{position:relative;min-height:62vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-stage__media{position:absolute;inset:0}
.hero-stage__media img{width:100%;height:100%;object-fit:cover}
.hero-stage__wash{position:absolute;inset:0;background:linear-gradient(120deg,rgba(35,27,20,.78),rgba(43,38,34,.35))}
.hero-stage__inner{position:relative;z-index:2;padding:5rem 1.25rem}
.hero-stage__card{max-width:640px}
.hero-stage__card h1{color:#fff;font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.1;margin:.2rem 0 1rem}
.hero-stage__card p{color:rgba(255,255,255,.92);font-size:1.1rem;max-width:34rem}
.hero-stage__eyebrow{color:#e8c086}
.hero-stage__actions{margin-top:1.6rem}
.hero-stage__primary{background:var(--accent);color:#fff;border:none;padding:.8rem 1.8rem;border-radius:999px;font-weight:600;text-decoration:none;display:inline-block;transition:background .2s,transform .2s}
.hero-stage__primary:hover{background:var(--accent-dark);color:#fff;transform:translateY(-1px)}

/* Page shell */
.page-shell{padding:3.5rem 0}
.page-shell--wide .container-xxl{max-width:1100px}
.section-panel,.article-panel,.listing-panel,.static-panel{background:transparent}
.page-hero-card{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--accent);
  border-radius:14px;padding:1.8rem 2rem;margin-bottom:2rem;box-shadow:0 14px 36px rgba(43,38,34,.06)}
.page-hero-card h1{font-size:clamp(1.8rem,3.5vw,2.6rem);margin:.1rem 0 .5rem}
.page-hero-card p{color:var(--muted);margin:0;max-width:46rem}

/* Prose / content blocks */
.prose-panel{font-size:1.04rem}
.content-heading{font-family:var(--serif);margin:2rem 0 .8rem;color:var(--ink)}
.content-heading--2{font-size:1.7rem}
.content-heading--3{font-size:1.35rem}
.content-copy{margin:0 0 1.15rem}
.content-copy p{margin:0 0 1.1rem}
.content-figure{margin:1.6rem 0}
.content-figure img,.content-main-image img{width:100%;height:auto;border-radius:12px;display:block}
.content-figure figcaption,.content-gallery figcaption{font-size:.85rem;color:var(--muted);margin-top:.4rem}
.content-list{margin:0 0 1.2rem;padding-left:1.25rem}
.content-list li{margin-bottom:.45rem}
.content-quote{border-left:3px solid var(--rose);background:#fff;padding:1rem 1.4rem;margin:1.6rem 0;
  font-family:var(--serif);font-style:italic;font-size:1.18rem;color:var(--ink);border-radius:0 10px 10px 0}
.content-rule{border:none;border-top:1px solid var(--line);margin:2.4rem 0}
.content-code{background:#2b2622;color:#f6efe6;padding:1rem 1.2rem;border-radius:10px;overflow:auto}
.content-embed{margin:1.6rem 0}
.content-table-wrap{overflow-x:auto;margin:1.6rem 0}
.content-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line)}
.content-table th,.content-table td{padding:.7rem .9rem;border:1px solid var(--line);text-align:left}
.content-table th{background:rgba(176,141,87,.12);font-family:var(--sans);font-weight:600}
.content-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin:1.6rem 0}
.content-gallery__item img{width:100%;height:100%;object-fit:cover;border-radius:10px}
.content-mini-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1.1rem 1.3rem;margin-bottom:1rem;transition:box-shadow .2s,transform .2s}
.content-mini-card:hover{box-shadow:0 14px 30px rgba(43,38,34,.1);transform:translateY(-2px)}
.content-mini-card h3{font-size:1.2rem;margin:0 0 .4rem}
.content-mini-card p{margin:0;color:var(--muted)}

/* Content body link styling (scoped descendant selectors) */
.prose-panel a,.content-copy a,.content-mini-card a,.category-intro a,.page-hero-card p a{
  color:var(--accent-dark);text-decoration:underline;text-decoration-color:var(--rose);
  text-underline-offset:2px;transition:color .2s}
.prose-panel a:hover,.content-copy a:hover,.content-mini-card a:hover,.category-intro a:hover{color:var(--accent)}

/* TOC */
.content-toc{background:#fff;border:1px solid var(--line);border-radius:12px;padding:1rem 1.3rem;margin-bottom:1.6rem}
.content-toc strong{display:block;font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:var(--accent);margin-bottom:.5rem}
.content-toc ul{margin:0;padding-left:1.1rem}
.content-toc a{color:var(--ink);text-decoration:none}
.content-toc a:hover{color:var(--accent-dark)}
.content-summary{font-family:var(--serif);font-size:1.18rem;font-style:italic;color:var(--ink)}
.content-meta-line{color:var(--muted);font-size:.9rem;margin-top:.6rem;display:flex;gap:1.2rem;flex-wrap:wrap}
.content-layout-shell--with-side{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:2rem;align-items:start}
.content-layout-shell--reverse{grid-template-columns:260px minmax(0,1fr)}
.content-layout-shell__aside{position:sticky;top:90px}
.content-toc--mobile{display:none}

/* Category grid */
.category-intro{margin-bottom:2rem}
.category-grid{display:grid;gap:1.4rem}
.category-grid--2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.category-grid--3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.content-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}
.content-card:hover{box-shadow:0 16px 34px rgba(43,38,34,.1);transform:translateY(-2px)}
.content-card__media img{width:100%;height:190px;object-fit:cover}
.content-card__body{padding:1.1rem 1.3rem}
.content-card__body h3{font-size:1.2rem;margin:.2rem 0 .5rem}
.content-card--horizontal{flex-direction:row}
.content-card--horizontal .content-card__media img{width:140px;height:100%}
.content-card--minimal{border:none;border-left:3px solid var(--accent);border-radius:0;background:transparent;box-shadow:none}
.category-card__more{display:inline-block;margin-top:.6rem;color:var(--accent-dark);font-weight:600;text-decoration:none}
.category-card__more:hover{color:var(--accent)}

/* Sidebar / aside */
.site-aside{display:flex;flex-direction:column;gap:1.4rem}
.aside-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.aside-card__body{padding:1.1rem 1.3rem}
.aside-card--image img{width:100%;height:170px;object-fit:cover}
.aside-card h3{font-size:1.25rem;margin:.2rem 0 .5rem}
.aside-card p{color:var(--muted);margin:0}
.aside-link-list{list-style:none;margin:0;padding:0}
.aside-link-list li{border-top:1px solid var(--line);padding:.5rem 0}
.aside-link-list li:first-child{border-top:none}
.aside-link-list a{color:var(--ink);text-decoration:none}
.aside-link-list a:hover{color:var(--accent-dark)}

/* Breadcrumbs */
.breadcrumbs-trail ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;padding:0;margin:0 0 1.2rem;font-size:.85rem;color:var(--muted)}
.breadcrumbs-trail li:not(:last-child)::after{content:'›';margin-left:.5rem;color:var(--accent)}
.breadcrumbs-trail a{color:var(--accent-dark);text-decoration:none}

/* Footer */
.site-footer{background:#2b2622;color:#f3e9dd;padding:3rem 0 1.5rem;margin-top:2rem}
.site-footer .footer-title{color:#fff;font-size:1.6rem}
.site-footer .footer-kicker{color:#e8c086}
.footer-copy{color:rgba(243,233,221,.78);max-width:24rem}
.footer-heading{font-family:var(--sans);text-transform:uppercase;letter-spacing:.14em;font-size:.8rem;color:#e8c086;margin-bottom:.8rem}
.footer-link-list{list-style:none;margin:0;padding:0}
.footer-link-list li{margin-bottom:.5rem}
.footer-link-list a{color:rgba(243,233,221,.86);text-decoration:none}
.footer-link-list a:hover{color:#fff;text-decoration:underline}
.footer-meta{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;border-top:1px solid rgba(243,233,221,.18);margin-top:2rem;padding-top:1.2rem;font-size:.82rem;color:rgba(243,233,221,.6)}

@media (max-width:991px){
  .content-layout-shell--with-side,.content-layout-shell--reverse{grid-template-columns:1fr}
  .content-layout-shell__aside.desktop-only{display:none}
  .content-toc--mobile{display:block}
  .wedding-nav-list{align-items:flex-start;padding:.6rem 0}
}
@media (max-width:575px){
  .content-card--horizontal{flex-direction:column}
  .content-card--horizontal .content-card__media img{width:100%;height:190px}
  .page-hero-card{padding:1.4rem 1.3rem}
}
