/* ---------- Photo by Josefin · style.css ---------- */
/* Single-file stylesheet. Mobile-first. No JS deps.   */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@300;400;500;600&display=swap');

:root{
  --c-bg:       #faf8f3;
  --c-bg-alt:   #f0ece2;
  --c-ink:      #2b2926;
  --c-ink-soft: #5c5850;
  --c-rule:     #e5dfd1;
  --c-gold:     #ceb55c;
  --c-gold-dk:  #a88f3f;
  --c-white:    #ffffff;
  --ff-serif:  'Cormorant Garamond', Georgia, serif;
  --ff-sans:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mw:        1240px;
  --mw-prose:  680px;
  --s-1:       .5rem;
  --s-2:       1rem;
  --s-3:       1.5rem;
  --s-4:       2.5rem;
  --s-5:       4rem;
  --s-6:       6rem;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background:var(--c-bg);
  color:var(--c-ink);
  font-family:var(--ff-sans);
  font-weight:400;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-gold-dk);text-decoration:underline;text-underline-offset:.15em;text-decoration-thickness:1px}
a:hover{color:var(--c-ink)}
hr{border:0;border-top:1px solid var(--c-rule);margin:var(--s-4) 0}

h1,h2,h3,h4{font-family:var(--ff-serif);font-weight:500;line-height:1.15;margin:0 0 var(--s-2);letter-spacing:.01em}
h1{font-size:clamp(2.2rem,5vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.4rem)}
h3{font-size:1.4rem}
p{margin:0 0 var(--s-2)}
.lead{font-family:var(--ff-serif);font-style:italic;font-size:clamp(1.15rem,2vw,1.4rem);color:var(--c-ink-soft);line-height:1.5}
.eyebrow{text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;font-weight:500;color:var(--c-gold-dk);margin:0 0 var(--s-2)}
blockquote{margin:var(--s-4) 0;padding:0 var(--s-3);border-left:2px solid var(--c-gold);font-family:var(--ff-serif);font-style:italic;font-size:1.2rem;line-height:1.5;color:var(--c-ink-soft)}
blockquote cite{display:block;margin-top:var(--s-1);font-size:.85rem;font-style:normal;letter-spacing:.12em;text-transform:uppercase;color:var(--c-ink)}

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

/* ---------- Header ---------- */
.site-header{background:var(--c-bg);border-bottom:1px solid var(--c-rule);position:sticky;top:0;z-index:50}
.site-header__inner{
  max-width:var(--mw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--s-2) var(--s-3);gap:var(--s-3);
}
.site-brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--c-ink)}
.site-brand__mark{
  font-family:var(--ff-serif);font-size:1.4rem;font-weight:600;
  width:2.2rem;height:2.2rem;border:1px solid var(--c-gold);
  border-radius:50%;display:grid;place-items:center;color:var(--c-gold-dk);
}
.site-brand__mark span{font-size:.7em;margin:0 .05em;color:var(--c-gold)}
.site-brand__name{font-family:var(--ff-serif);font-size:1.25rem;letter-spacing:.04em}
.site-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:var(--s-3)}
.site-nav a{
  color:var(--c-ink);text-decoration:none;font-size:.92rem;
  letter-spacing:.08em;text-transform:uppercase;padding:.3rem 0;
  border-bottom:1px solid transparent;
}
.site-nav a:hover,.site-nav a[aria-current="page"]{border-bottom-color:var(--c-gold)}
.nav-toggle{display:none;background:transparent;border:0;padding:.5rem;cursor:pointer}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--c-ink);margin:5px 0;transition:.2s}

@media (max-width:860px){
  .nav-toggle{display:block}
  .site-nav{
    position:absolute;top:100%;left:0;right:0;background:var(--c-bg);
    border-bottom:1px solid var(--c-rule);max-height:0;overflow:hidden;transition:max-height .3s;
  }
  .site-nav.is-open{max-height:30rem}
  .site-nav ul{flex-direction:column;padding:var(--s-3)}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;padding:.9rem 2rem;
  background:var(--c-ink);color:#fff;text-decoration:none;
  font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid var(--c-ink);transition:.2s;
}
.btn:hover{background:var(--c-gold-dk);border-color:var(--c-gold-dk);color:#fff}
.btn--ghost{background:transparent;color:var(--c-ink)}
.btn--ghost:hover{background:var(--c-ink);color:#fff}

/* ---------- Layout helpers ---------- */
main{display:block}
.section{padding:var(--s-5) var(--s-3)}
.section--tight{padding:var(--s-4) var(--s-3)}
.section--bg{background:var(--c-bg-alt)}
.container{max-width:var(--mw);margin:0 auto}
.prose{max-width:var(--mw-prose);margin:0 auto}
.prose p,.prose ul,.prose ol{font-size:1.05rem}
.text-center{text-align:center}

.breadcrumb{max-width:var(--mw);margin:0 auto;padding:var(--s-2) var(--s-3);font-size:.82rem;color:var(--c-ink-soft);letter-spacing:.05em}
.breadcrumb a{color:var(--c-ink-soft)}
.breadcrumb span{margin:0 .4em;color:var(--c-rule)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:70vh;display:grid;place-items:center;overflow:hidden;color:#fff;text-align:center}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(rgba(0,0,0,.25),rgba(0,0,0,.45)),var(--hero-img) center/cover no-repeat;
}
.hero__inner{position:relative;z-index:1;padding:var(--s-6) var(--s-3);max-width:820px}
.hero h1{color:#fff;margin-bottom:var(--s-2)}
.hero .lead{color:rgba(255,255,255,.92)}
.hero .btn{margin-top:var(--s-3);background:#fff;color:var(--c-ink);border-color:#fff}
.hero .btn:hover{background:var(--c-gold);border-color:var(--c-gold);color:#fff}

/* ---------- Intro block (image + text) ---------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-5);align-items:center;max-width:var(--mw);margin:0 auto}
.feature__img img{width:100%;aspect-ratio:4/5;object-fit:cover}
.feature__body h2{margin-bottom:var(--s-3)}
.feature--reverse .feature__img{order:2}
@media (max-width:860px){.feature,.feature--reverse{grid-template-columns:1fr;gap:var(--s-3)}.feature--reverse .feature__img{order:0}}

/* ---------- Gallery ---------- */
.gallery{display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);max-width:var(--mw);margin:0 auto}
.gallery a,.gallery img{display:block}
.gallery img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform .4s}
.gallery a:hover img{transform:scale(1.02)}
.gallery--mixed img:nth-child(3n+1){aspect-ratio:3/4}
.gallery--mixed img:nth-child(3n+2){aspect-ratio:4/3}
@media (max-width:760px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:440px){.gallery{grid-template-columns:1fr}}

/* ---------- Testimonials ---------- */
.testimonials{display:grid;gap:var(--s-4);grid-template-columns:1fr 1fr;max-width:var(--mw);margin:0 auto}
.testimonials blockquote{margin:0;background:var(--c-bg);padding:var(--s-3)}
@media (max-width:760px){.testimonials{grid-template-columns:1fr}}

/* ---------- Packages ---------- */
.packages{display:grid;gap:var(--s-3);grid-template-columns:repeat(3,1fr);max-width:var(--mw);margin:var(--s-4) auto 0}
.package{background:var(--c-white);padding:var(--s-4) var(--s-3);border:1px solid var(--c-rule);text-align:center}
.package h3{font-size:1.6rem;color:var(--c-gold-dk);margin-bottom:var(--s-1)}
.package__price{font-family:var(--ff-serif);font-size:1.1rem;color:var(--c-ink-soft);margin-bottom:var(--s-2)}
.package ul{list-style:none;padding:0;margin:var(--s-3) 0;text-align:left}
.package ul li{padding:.4rem 0;border-bottom:1px dashed var(--c-rule);font-size:.95rem}
.package ul li:last-child{border-bottom:0}
@media (max-width:860px){.packages{grid-template-columns:1fr}}

/* ---------- Contact form ---------- */
.contact-form{max-width:640px;margin:var(--s-4) auto 0;display:grid;gap:var(--s-2)}
.contact-form label{font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--c-ink-soft)}
.contact-form input,.contact-form select,.contact-form textarea{
  width:100%;padding:.8rem 1rem;border:1px solid var(--c-rule);background:var(--c-white);
  font-family:var(--ff-sans);font-size:1rem;color:var(--c-ink);
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{outline:2px solid var(--c-gold);outline-offset:2px}
.contact-form textarea{min-height:8rem;resize:vertical}

/* ---------- Article ---------- */
.article-hero{position:relative;min-height:46vh;display:grid;place-items:end center;overflow:hidden;color:#fff;text-align:center}
.article-hero::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(0,0,0,.15),rgba(0,0,0,.55)),url('/assets/images/article-featured.jpg') center/cover no-repeat}
.article-hero__inner{position:relative;padding:var(--s-5) var(--s-3);max-width:800px}
.article-hero h1{color:#fff}
.article-hero .meta{letter-spacing:.15em;text-transform:uppercase;font-size:.78rem;color:rgba(255,255,255,.85);margin:var(--s-2) 0 0}

.article{padding:var(--s-5) var(--s-3)}
.article .prose h2{margin-top:var(--s-4);color:var(--c-ink)}
.article .prose h3{margin-top:var(--s-3)}
.article .prose p{color:var(--c-ink);line-height:1.8}
.callout{background:var(--c-bg-alt);border-left:3px solid var(--c-gold);padding:var(--s-3);margin:var(--s-3) 0;font-size:.98rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--c-ink);color:#e8e3d6;margin-top:var(--s-6)}
.site-footer__inner{max-width:var(--mw);margin:0 auto;padding:var(--s-5) var(--s-3);display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--s-4)}
.site-footer__title{font-family:var(--ff-serif);font-size:1.3rem;color:#fff;margin:0 0 var(--s-2);font-weight:500}
.site-footer__nav{list-style:none;padding:0;margin:0}
.site-footer__nav li{margin:.3rem 0}
.site-footer a{color:#e8e3d6}
.site-footer a:hover{color:var(--c-gold)}
.site-footer__bar{
  border-top:1px solid #3d3a34;max-width:var(--mw);margin:0 auto;
  padding:var(--s-3);display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s-2);
  font-size:.85rem;color:#a39f94;
}
.site-footer__credit a{color:#c9b876}
@media (max-width:760px){.site-footer__inner{grid-template-columns:1fr}}

/* ---------- 404 ---------- */
.not-found{min-height:60vh;display:grid;place-items:center;text-align:center;padding:var(--s-5) var(--s-3)}
.not-found h1{font-size:clamp(3rem,8vw,6rem);color:var(--c-gold);margin-bottom:var(--s-2)}

/* ---------- Utility ---------- */
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
.mt-4{margin-top:var(--s-4)}
