:root{
  --ivory:#f6f1e7;
  --parchment:#ede2cb;
  --ink:#1c1612;
  --umber:#3b2a1d;
  --gold:#a8854a;
  --gold-light:#c9a563;
  --crimson:#6b1f1a;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ivory);
  color:var(--ink);
  font-family:'Cormorant Garamond','Garamond',serif;
  font-size:19px;line-height:1.65;
  overflow-x:hidden;
  background-image:
    radial-gradient(ellipse at top,rgba(168,133,74,0.08),transparent 60%),
    radial-gradient(ellipse at bottom,rgba(107,31,26,0.06),transparent 60%);
}
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.2 0 0 0 0 0.15 0 0 0 0 0.08 0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.5;z-index:1;mix-blend-mode:multiply;
}
main,nav,header,footer{position:relative;z-index:2}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 50px;
  background:rgba(246,241,231,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(168,133,74,0.25);
  z-index:100;
}
.brand{
  font-family:'Cinzel',serif;
  font-size:18px;letter-spacing:.22em;
  color:var(--umber);text-decoration:none;
}
.brand span{color:var(--gold)}
nav ul{display:flex;gap:38px;list-style:none}
nav a{
  font-family:'Cinzel',serif;
  font-size:12px;letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--umber);text-decoration:none;
  transition:color .3s;
  position:relative;padding:4px 0;
}
nav a:hover{color:var(--gold)}
nav a.active{color:var(--crimson)}
nav a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;
  height:1px;background:var(--gold);
}
nav .menu-toggle{display:none}

/* HERO */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;padding:140px 30px 80px;position:relative;
}
.hero-sm{min-height:60vh;padding:180px 30px 60px}
.hero-ornament{
  font-family:'Cinzel',serif;color:var(--gold);
  font-size:14px;letter-spacing:.4em;margin-bottom:30px;
}
.hero-ornament::before,.hero-ornament::after{content:"❦";margin:0 18px;color:var(--gold-light)}
.hero h1{
  font-family:'Italiana',serif;
  font-size:clamp(56px,11vw,150px);
  line-height:.95;font-weight:400;
  color:var(--umber);margin-bottom:18px;letter-spacing:.01em;
}
.hero-sm h1{font-size:clamp(48px,8vw,96px)}
.hero h1 em{
  font-family:'Cormorant Garamond',serif;font-style:italic;
  font-weight:300;color:var(--crimson);
}
.hero .by{
  font-family:'Cinzel',serif;
  font-size:13px;letter-spacing:.45em;
  text-transform:uppercase;color:var(--gold);
  margin-bottom:40px;
}
.hero p.tag{
  max-width:620px;font-size:22px;font-style:italic;
  color:var(--umber);opacity:.85;margin-bottom:50px;
}
.cta{
  display:inline-block;padding:18px 48px;
  border:1px solid var(--gold);color:var(--umber);
  font-family:'Cinzel',serif;font-size:12px;
  letter-spacing:.3em;text-transform:uppercase;
  text-decoration:none;background:transparent;cursor:pointer;
  transition:all .4s;position:relative;overflow:hidden;
}
.cta::before{
  content:"";position:absolute;inset:0;background:var(--umber);
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s;z-index:-1;
}
.cta:hover{color:var(--ivory);border-color:var(--umber)}
.cta:hover::before{transform:scaleX(1)}
.cta-row{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
.scroll-hint{
  position:absolute;bottom:30px;left:50%;
  transform:translateX(-50%);
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:.3em;
  color:var(--gold);animation:bob 2.5s ease-in-out infinite;
}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}

/* SECTION HEADING */
section{padding:120px 50px;max-width:1300px;margin:0 auto}
.section-head{text-align:center;margin-bottom:80px}
.eyebrow{
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:.45em;
  color:var(--gold);text-transform:uppercase;margin-bottom:18px;
}
.section-head h2{
  font-family:'Italiana',serif;
  font-size:clamp(42px,6vw,76px);
  color:var(--umber);font-weight:400;
}
.section-head h2 em{font-family:'Cormorant Garamond';font-style:italic;color:var(--crimson)}
.divider{
  display:block;margin:24px auto;
  width:80px;height:1px;background:var(--gold);position:relative;
}
.divider::before{
  content:"❦";position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%);
  background:var(--ivory);padding:0 10px;
  color:var(--gold);font-size:14px;
}

/* ABOUT */
.about{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center}
.about-portrait{
  position:relative;aspect-ratio:3/4;background:#ddd;
  border:1px solid var(--gold);
  box-shadow:0 0 0 12px var(--ivory),0 0 0 14px var(--gold),0 30px 60px rgba(28,22,18,0.25);
}
.about-portrait img{width:100%;height:100%;object-fit:cover;display:block;filter:sepia(.08) contrast(1.02)}
.about-portrait::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(28,22,18,0.15));
  pointer-events:none;
}
.about-text h3{font-family:'Italiana',serif;font-size:42px;color:var(--umber);font-weight:400;margin-bottom:8px}
.about-text .role{
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:.4em;
  text-transform:uppercase;color:var(--gold);margin-bottom:30px;
}
.about-text p{margin-bottom:20px;color:var(--ink);opacity:.88}
.about-text p.dropcap::first-letter{
  font-family:'Italiana',serif;font-size:64px;float:left;
  line-height:.85;padding:6px 10px 0 0;color:var(--crimson);
}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:60px 50px}
.gallery.cols-2{grid-template-columns:repeat(2,1fr)}
.piece{cursor:pointer;transition:transform .5s}
.piece:hover{transform:translateY(-8px)}
.frame{
  position:relative;background:var(--parchment);
  padding:18px;border:1px solid var(--gold);
  box-shadow:
    inset 0 0 0 1px rgba(168,133,74,0.5),
    inset 0 0 0 6px var(--parchment),
    inset 0 0 0 7px var(--gold-light),
    0 25px 55px rgba(28,22,18,0.3),
    0 10px 25px rgba(28,22,18,0.15);
}
.frame::before{content:"";position:absolute;inset:8px;border:1px double var(--gold);pointer-events:none}
.frame img{width:100%;aspect-ratio:1/1.15;object-fit:cover;display:block;filter:contrast(1.04) saturate(1.02)}
.plaque{text-align:center;margin-top:24px}
.plaque .title{font-family:'Italiana',serif;font-size:24px;color:var(--umber);font-style:italic}
.plaque .meta{
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold);margin-top:6px;
}

/* COMMISSION */
.commission{
  background:linear-gradient(180deg,var(--parchment),#e4d6b8);
  margin:80px -50px 0;padding:120px 50px;
  border-top:1px solid var(--gold);border-bottom:1px solid var(--gold);
  position:relative;
}
.commission-inner{max-width:780px;margin:0 auto}
.commission-intro{
  text-align:center;font-style:italic;font-size:21px;
  color:var(--umber);max-width:620px;margin:0 auto 60px;opacity:.9;
}
form{display:grid;gap:24px}
.row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
label{
  display:block;font-family:'Cinzel',serif;font-size:10px;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);margin-bottom:10px;
}
input,select,textarea{
  width:100%;background:rgba(246,241,231,0.6);
  border:none;border-bottom:1px solid var(--gold);
  padding:12px 4px;font-family:'Cormorant Garamond',serif;
  font-size:18px;color:var(--ink);outline:none;
  transition:border-color .3s,background .3s;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--crimson);background:rgba(246,241,231,0.95);
}
textarea{min-height:130px;resize:vertical;font-family:'Cormorant Garamond',serif}
button[type=submit]{margin-top:20px;justify-self:center}

/* PROCESS STEPS */
.steps{
  display:grid;grid-template-columns:repeat(4,1fr);gap:40px;
  margin-top:40px;
}
.step{text-align:center;position:relative}
.step .num{
  font-family:'Italiana',serif;font-size:64px;
  color:var(--gold);line-height:1;margin-bottom:16px;
}
.step h4{
  font-family:'Cinzel',serif;font-size:13px;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--umber);margin-bottom:14px;
}
.step p{font-size:17px;opacity:.85;font-style:italic}

/* PRICING */
.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:40px}
.tier{
  background:rgba(237,226,203,0.5);
  border:1px solid var(--gold);
  padding:50px 36px;text-align:center;
  position:relative;transition:transform .4s,box-shadow .4s;
}
.tier:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(28,22,18,0.2)}
.tier::before{content:"";position:absolute;inset:6px;border:1px double var(--gold);pointer-events:none}
.tier h4{font-family:'Italiana',serif;font-size:32px;color:var(--umber);margin-bottom:6px}
.tier .size{
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold);margin-bottom:24px;
}
.tier .price{
  font-family:'Italiana',serif;font-size:44px;
  color:var(--crimson);margin-bottom:24px;
}
.tier .price small{font-size:14px;color:var(--umber);opacity:.7;display:block;font-style:italic}
.tier ul{list-style:none;text-align:left;margin-top:20px}
.tier li{
  padding:10px 0;border-bottom:1px solid rgba(168,133,74,0.2);
  font-style:italic;
}
.tier li::before{content:"❦  ";color:var(--gold)}
.tier li:last-child{border:none}

/* QUOTE / TESTIMONIAL */
.quote{
  text-align:center;max-width:780px;margin:80px auto;
  padding:50px 40px 44px;position:relative;
  border-top:1px solid rgba(168,133,74,0.5);
  border-bottom:1px solid rgba(168,133,74,0.5);
}
.quote::before,
.quote::after{
  content:"";position:absolute;left:50%;
  width:6px;height:6px;
  background:var(--gold);
  transform:translateX(-50%) rotate(45deg);
}
.quote::before{top:-3px}
.quote::after{bottom:-3px}
.quote p{
  font-family:'Italiana',serif;font-size:28px;font-style:italic;
  color:var(--umber);line-height:1.45;
  quotes:"\201C" "\201D";
}
.quote p::before{content:open-quote;color:var(--gold);margin-right:4px;font-size:1em;opacity:.7}
.quote p::after{content:close-quote;color:var(--gold);margin-left:4px;font-size:1em;opacity:.7}
.quote .attr{
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold);margin-top:28px;
  display:flex;align-items:center;justify-content:center;gap:14px;
}
.quote .attr::before,
.quote .attr::after{
  content:"";width:20px;height:1px;background:var(--gold);opacity:.6;
}

/* CONTACT */
.contact{text-align:center}
.contact-grid{display:flex;justify-content:center;gap:80px;flex-wrap:wrap;margin-top:40px}
.contact-item .label{
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold);margin-bottom:10px;
}
.contact-item a{
  font-family:'Italiana',serif;font-size:24px;
  color:var(--umber);text-decoration:none;
  border-bottom:1px solid transparent;
  transition:border-color .3s,color .3s;
}
.contact-item a:hover{color:var(--crimson);border-bottom-color:var(--crimson)}

/* FAQ */
.faq{max-width:780px;margin:0 auto}
.faq details{
  border-bottom:1px solid rgba(168,133,74,0.4);
  padding:24px 0;cursor:pointer;
}
.faq summary{
  font-family:'Italiana',serif;font-size:24px;color:var(--umber);
  list-style:none;display:flex;justify-content:space-between;align-items:center;
}
.faq summary::after{content:"+";color:var(--gold);font-size:28px;font-family:'Cinzel',serif;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:18px;font-style:italic;opacity:.85}

/* FOOTER */
footer{
  text-align:center;padding:60px 30px 40px;
  border-top:1px solid rgba(168,133,74,0.3);margin-top:60px;
}
footer .brand{font-size:16px}
footer p{margin-top:14px;font-size:13px;font-style:italic;color:var(--umber);opacity:.7}
footer .social{margin-top:20px;display:flex;gap:30px;justify-content:center}
footer .social a{
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:.25em;
  text-transform:uppercase;color:var(--gold);text-decoration:none;
}
footer .social a:hover{color:var(--crimson)}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;background:rgba(20,15,10,0.94);
  display:none;justify-content:center;align-items:center;
  z-index:1000;padding:40px;cursor:zoom-out;
}
.lightbox.active{display:flex}
.lightbox img{
  max-width:90vw;max-height:85vh;
  box-shadow:0 0 80px rgba(168,133,74,0.4);
  border:8px solid var(--ivory);outline:1px solid var(--gold);
}
.lightbox-caption{
  position:absolute;bottom:30px;left:50%;
  transform:translateX(-50%);color:var(--ivory);
  font-family:'Italiana',serif;font-size:22px;
  font-style:italic;text-align:center;
}

/* RESPONSIVE */
@media(max-width:1100px){
  .gallery{grid-template-columns:repeat(2,1fr);gap:50px 40px}
}
@media(max-width:900px){
  nav{padding:18px 24px}
  nav ul{gap:18px}
  nav a{font-size:10px}
  section{padding:80px 24px}
  .about{grid-template-columns:1fr;gap:50px}
  .about-portrait{max-width:380px;margin:0 auto}
  .gallery,.gallery.cols-2{grid-template-columns:repeat(2,1fr);gap:45px 30px}
  .commission{margin:60px -24px 0;padding:80px 24px}
  .row{grid-template-columns:1fr}
  .contact-grid{gap:40px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .pricing{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}
  /* testimonials grid on home page */
  .quote[style*="margin:0"]{margin:0 auto !important}
  section > div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important;gap:30px !important}
}
@media(max-width:700px){
  /* hamburger-style nav */
  nav{
    flex-direction:row;justify-content:space-between;align-items:center;
    padding:16px 20px;
  }
  nav .brand{font-size:11px;letter-spacing:.15em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  nav .menu-toggle{
    display:flex;flex-direction:column;gap:5px;
    background:transparent;border:none;cursor:pointer;padding:8px;
  }
  nav .menu-toggle span{
    display:block;width:26px;height:1.5px;background:var(--umber);
    transition:transform .3s,opacity .3s;
  }
  nav.open .menu-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  nav.open .menu-toggle span:nth-child(2){opacity:0}
  nav.open .menu-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  nav ul{
    position:fixed;top:60px;left:0;right:0;
    background:rgba(246,241,231,0.98);
    backdrop-filter:blur(10px);
    flex-direction:column;gap:0;padding:20px 0;
    border-bottom:1px solid rgba(168,133,74,0.3);
    transform:translateY(-120%);opacity:0;pointer-events:none;
    transition:transform .4s,opacity .3s;
  }
  nav.open ul{transform:translateY(0);opacity:1;pointer-events:auto}
  nav ul li{text-align:center;width:100%}
  nav ul li a{
    display:block;padding:16px 20px;font-size:12px;letter-spacing:.25em;
    border-bottom:1px solid rgba(168,133,74,0.15);
  }
  nav ul li:last-child a{border-bottom:none}

  .hero{padding:120px 20px 60px;min-height:85vh}
  .hero-sm{min-height:auto;padding:140px 20px 40px}
  .hero p.tag{font-size:18px;margin-bottom:36px}
  .hero .by{font-size:11px;letter-spacing:.35em;margin-bottom:30px}
  .hero-ornament{font-size:11px;letter-spacing:.3em;margin-bottom:22px}
  .hero-ornament::before,.hero-ornament::after{margin:0 10px}
  .cta{padding:15px 32px;font-size:11px;letter-spacing:.25em}
  .cta-row{gap:14px;flex-direction:column;align-items:stretch}
  .cta-row .cta{text-align:center}
  .scroll-hint{font-size:9px}

  section{padding:60px 20px}
  .section-head{margin-bottom:50px}
  .section-head h2{font-size:clamp(34px,9vw,48px)}
  .eyebrow{font-size:10px;letter-spacing:.35em}

  .gallery,.gallery.cols-2{grid-template-columns:1fr;gap:40px;max-width:420px;margin-left:auto;margin-right:auto}
  .frame{padding:10px}
  .frame::before{inset:4px}
  .plaque{margin-top:18px}
  .plaque .title{font-size:21px}

  .about-text h3{font-size:34px}
  .about-text p.dropcap::first-letter{font-size:52px}

  .commission{margin:50px -20px 0;padding:60px 20px}
  .commission-intro{font-size:18px;margin-bottom:40px}

  .steps{grid-template-columns:1fr;gap:36px}
  .step .num{font-size:52px}

  .tier{padding:36px 24px}
  .tier h4{font-size:28px}
  .tier .price{font-size:38px}

  .quote{padding:36px 24px;margin:50px auto}
  .quote p{font-size:22px}
  .quote .attr{font-size:10px;letter-spacing:.25em;margin-top:20px}
  .quote .attr::before,.quote .attr::after{width:14px}

  .contact-grid{flex-direction:column;gap:30px}
  .contact-item a{font-size:20px}

  .filters{gap:8px;margin-bottom:40px}
  .filter-btn{padding:8px 14px;font-size:10px;letter-spacing:.15em}

  .faq summary{font-size:20px}
  .faq details{padding:20px 0}

  .lightbox{padding:16px}
  .lightbox img{border-width:4px}
  .lightbox-caption{font-size:16px;bottom:16px}

  footer{padding:40px 20px 30px}
  footer .social{gap:18px;flex-wrap:wrap}
  footer .social a{font-size:10px;letter-spacing:.2em}
  footer .brand{font-size:12px;letter-spacing:.15em}
}
@media(max-width:420px){
  .hero h1{font-size:46px;line-height:1}
  .hero-sm h1{font-size:40px}
  .hero p.tag{font-size:16px}
  .section-head h2{font-size:32px}
  .frame{padding:8px}
  .quote p{font-size:19px}
  .about-text h3{font-size:28px}
}

.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s,transform 1s}
.reveal.in{opacity:1;transform:none}

/* FORM THANK YOU */
.form-success{
  display:none;text-align:center;padding:40px 20px;
  font-family:'Italiana',serif;
}
.form-success.show{display:block;animation:fadeIn .6s}
.form-success h3{font-size:36px;color:var(--crimson);margin-bottom:14px}
.form-success p{font-size:20px;font-style:italic;color:var(--umber);opacity:.85}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
