:root{
  --bg:#f4efe5;
  --paper:#fbf8f0;
  --ink:#1d1713;
  --muted:#6d6259;
  --line:rgba(29,23,19,.15);
  --red:#8e201b;
  --red2:#5b1712;
  --dark:#12100e;
  --gold:#b9925b;
  --serif:Georgia,'Times New Roman',serif;
  --sans:Inter,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --shadow:0 24px 70px rgba(34,22,15,.14);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:116px}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
main,.section,.gallery{background:var(--bg)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
section[id]{scroll-margin-top:116px}

.container{width:min(1580px,calc(100% - 64px));margin-inline:auto}
.container-narrow{width:min(1440px,calc(100% - 96px));margin-inline:auto}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(244,239,229,.92);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.header-inner{height:96px;display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:flex;align-items:center;gap:16px;min-width:330px}
.brand img{width:58px;height:86px;object-fit:contain}
.brand-title{font-family:var(--serif);font-size:32px;line-height:.92;letter-spacing:.012em;font-weight:600}
.brand-middle{position:relative;top:0}
.nav{display:flex;align-items:center;gap:34px;font-size:15.5px;letter-spacing:.085em;text-transform:uppercase}
.nav a{position:relative;padding:10px 0;white-space:nowrap}
.nav a:after{content:"";position:absolute;left:0;right:100%;bottom:4px;height:1px;background:var(--ink);transition:right .35s cubic-bezier(.19,1,.22,1)}
.nav a:hover:after{right:0}
.burger{display:none;background:none;border:0;width:44px;height:44px;cursor:pointer}
.burger span{display:block;width:28px;height:2px;background:var(--ink);margin:6px auto}

.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  line-height:1.15;
  gap:10px;
  min-height:50px;
  padding:0 24px;
  border:1px solid rgba(29,23,19,.26);
  border-radius:0;
  background:transparent;
  color:var(--ink);
  font-weight:600;
  font-size:15px;
  letter-spacing:.01em;
  overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s,background .35s,color .35s;
  will-change:transform;
}
.btn::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:linear-gradient(115deg,transparent 0,rgba(255,255,255,.16) 38%,rgba(255,255,255,.45) 50%,rgba(255,255,255,.16) 62%,transparent 100%);
  transform:translateX(-130%);
  transition:transform .75s cubic-bezier(.2,.8,.2,1);
}
.btn span{position:relative;z-index:2}
.site-header .btn{line-height:1.18;text-align:center}
.site-header .btn span{display:block;text-align:center}
.btn:hover{transform:translateY(-2px);border-color:var(--red)}
.btn:hover::before{transform:translateX(130%)}
.btn-primary{background:var(--red);border-color:var(--red);color:#fff}
.site-header .btn-primary{min-width:174px;padding-left:22px;padding-right:22px}
.btn-primary:hover{background:#661812;color:#fff}
.btn-ghost{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.45);color:#fff}
.btn-ghost:hover{border-color:#fff;color:#fff}
.btn-large{width:100%;min-height:56px;font-weight:550;letter-spacing:.025em;font-size:17px}
.magnetic{will-change:transform}
.site-header .btn{min-height:50px;padding-inline:25px;font-size:15px}

h1,h2,h3{font-family:var(--serif);font-weight:400;margin:0;letter-spacing:-.035em}
h2{font-size:clamp(44px,4.05vw,68px);line-height:1.02;letter-spacing:-.025em}
.loose{letter-spacing:0}
.nowrap,.desktop-nowrap{white-space:nowrap}
br.mobile-only{display:none}

.hero{
  height:calc(100svh - 50px);
  min-height:690px;
  position:relative;
  display:block;
  padding-top:86px;
  background:var(--dark);
  color:#fff;
  overflow:hidden;
}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:65% 80%;filter:saturate(.94) contrast(1.05)}
.hero-media:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.48) 36%,rgba(0,0,0,.12) 74%,rgba(0,0,0,.26) 100%),linear-gradient(0deg,rgba(0,0,0,.55),transparent 44%)}
.hero .container{width:min(1180px,calc(100vw - 44px));margin:0 auto}
.hero-content{position:absolute;z-index:1;left:clamp(250px,31vw,620px);top:clamp(150px,31%,255px);width:clamp(420px,38vw,760px);max-width:none;padding:0;margin:0;transform:none}
.eyebrow{display:flex;align-items:center;gap:12px;margin:0 0 22px;color:rgba(255,255,255,.76);font-size:12px;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap}
.eyebrow:before{content:"";width:42px;height:1px;background:var(--gold);flex:0 0 42px}
.eyebrow>span{white-space:nowrap}
.eyebrow-separator{display:inline-block;margin:0 .42em;letter-spacing:0}
.hero h1{font-size:clamp(46px,4.55vw,86px);line-height:1.03;letter-spacing:-.026em;max-width:100%;text-wrap:balance}
.hero-title-line{display:block}
.hero-ceremony-word{position:relative;top:-.095em}
.hero-city-line{display:block;white-space:nowrap;letter-spacing:0}
.ur-gap{display:inline-block;margin-left:.04em}
.city-word{margin-left:-.07em}
.city-p{margin-left:-.07em}
.hero p:not(.eyebrow){max-width:clamp(360px,34vw,620px);margin:clamp(18px,1.6vw,28px) 0 clamp(22px,2vw,34px);color:rgba(255,255,255,.82);font-size:clamp(15.7px,1.04vw,19.7px);line-height:1.45;text-shadow:0 2px 18px rgba(0,0,0,.62)}
.hero-copy-line{display:block}
.nobr{white-space:nowrap}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:0}

.section{padding:66px 0}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:24px;margin-bottom:38px}
.section-lead{font-size:18px;color:var(--muted);max-width:980px;margin:18px 0 0}
.link-arrow{font-weight:800;border-bottom:1px solid currentColor;padding-bottom:5px;white-space:nowrap}

.gallery{padding:54px 0 24px;background:var(--bg)}
.gallery-top{display:flex;align-items:center;justify-content:center;margin:0 28px 24px;position:relative}
.gallery-top h2{font-size:clamp(38px,3.35vw,58px);line-height:1.03;letter-spacing:.028em;text-align:center}
.gallery-controls{display:flex;gap:12px;position:absolute;right:0;top:50%;transform:translateY(-50%)}
.circle-btn{width:54px;height:54px;min-width:54px;flex:0 0 54px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.42);display:grid;place-items:center;color:var(--ink);font-size:0;line-height:1;cursor:pointer;transition:background .3s,transform .3s;position:relative}
.circle-btn:before{content:"";position:absolute;left:50%;top:50%;width:13px;height:13px;border-top:2px solid currentColor;border-left:2px solid currentColor}
.circle-prev:before{transform:translate(-35%,-50%) rotate(-45deg)}
.circle-next:before{transform:translate(-65%,-50%) rotate(135deg)}
.circle-btn:hover{background:#fff;transform:translateY(-2px)}
.gallery-window{width:calc(100% - 50px);margin:0 0 0 60px;overflow:hidden;padding:0 28px;box-sizing:border-box;background:var(--bg)}
.gallery-rail{display:grid;grid-auto-flow:column;grid-auto-columns:calc((100% - 66px)/4);gap:22px;overflow-x:auto;scroll-snap-type:x mandatory;padding:0 0 16px;scrollbar-width:none;background:var(--bg)}
.gallery-rail::-webkit-scrollbar{display:none}
.gallery-card{scroll-snap-align:start;border-radius:16px;overflow:hidden;min-height:245px;box-shadow:0 18px 50px rgba(29,23,19,.11);background:#ddd;transition:transform .45s cubic-bezier(.19,1,.22,1),box-shadow .45s}
.gallery-card:hover{transform:translateY(-8px);box-shadow:0 30px 75px rgba(29,23,19,.18)}
.gallery-card img{width:100%;height:100%;aspect-ratio:16/10;object-fit:cover}
.photo-lightbox{position:fixed;inset:0;z-index:120;background:rgba(10,8,6,.88);display:grid;place-items:center;padding:28px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .28s ease,visibility .28s ease}
.photo-lightbox.is-open{opacity:1;visibility:visible;pointer-events:auto}
.photo-lightbox img{max-width:min(94vw,1400px);max-height:88vh;border-radius:18px;box-shadow:0 30px 90px rgba(0,0,0,.42);transform:scale(.965);transition:transform .32s cubic-bezier(.19,1,.22,1);object-fit:contain}
.photo-lightbox.is-open img{transform:scale(1)}
.lightbox-close{position:absolute;right:28px;top:24px;width:48px;height:48px;border:1px solid rgba(255,255,255,.28);border-radius:50%;background:rgba(255,255,255,.08);color:#fff;font-size:28px;line-height:1;cursor:pointer}
.gallery-card{cursor:pointer}

.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:26px}
.format-card{position:relative;background:rgba(255,255,255,.40);border:1px solid var(--line);border-radius:18px;overflow:hidden;min-height:425px;display:flex;flex-direction:column;transition:transform .45s cubic-bezier(.19,1,.22,1),box-shadow .45s,background .45s}
.format-card:hover{transform:translateY(-9px);box-shadow:var(--shadow);background:#fffaf1}
.card-link{position:absolute;inset:0;z-index:4}
.format-img{height:193px;overflow:hidden}
.format-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.19,1,.22,1)}
.format-card:hover .format-img img{transform:scale(1.07)}
.format-body{padding:25px;display:flex;flex-direction:column;gap:12px;flex:1}
.format-body h3{font-size:34px;line-height:1.02;letter-spacing:.02em}
.format-body p{margin:0;color:var(--muted);font-size:15px;line-height:1.5}
.price{margin-top:auto;font-weight:800;font-size:18px}
.price small{font-weight:500;color:var(--muted)}
.btn-mini{position:absolute;right:18px;bottom:18px;width:38px;height:38px;border:1px solid var(--line);border-radius:99px;display:grid;place-items:center;transition:transform .4s,background .4s,color .4s;background:rgba(255,255,255,.5)}
.format-card:hover .btn-mini{transform:translateX(5px);background:var(--ink);color:#fff}

.process{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:34px}
.step{border-top:1px solid var(--line);padding-top:20px}
.step:before{counter-increment:step;content:counter(step);display:grid;place-items:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);margin-bottom:14px;color:var(--muted)}
.step h3{font-size:27px;letter-spacing:.026em}
.step p{margin:8px 0 0;color:var(--muted)}
.process-img{border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.process-img img{width:100%;height:520px;object-fit:cover}
.panel{border:1px solid var(--line);border-radius:20px;padding:46px;background:rgba(255,255,255,.40);min-height:320px}
.panel p{max-width:760px;color:var(--muted);font-size:18px}
.panel img{border-radius:16px}
.studio-panel{display:grid;grid-template-columns:1fr auto;gap:42px;align-items:center;padding:60px 68px;min-height:0}
.studio-panel h2{white-space:normal}
.studio-panel p{font-size:21px;max-width:980px}
.studio-panel .btn{white-space:nowrap}

.cert-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:stretch}
.gift-side{background:linear-gradient(135deg,#1b1510 0%,#2b1712 45%,#7c241d 100%);color:#fff;border-radius:24px;padding:46px;min-height:100%;display:flex;flex-direction:column;justify-content:flex-start;overflow:hidden;position:relative}
.gift-side:after{content:"";position:absolute;right:-120px;top:-120px;width:280px;height:280px;border-radius:50%;background:rgba(185,146,91,.16);filter:blur(20px)}
.gift-side p{color:rgba(255,255,255,.78);max-width:560px}
.gift-title{font-size:clamp(54px,4.2vw,76px);line-height:1.08;letter-spacing:.01em;max-width:none;margin:0;text-align:left;transform:translateX(-24px)}
.gift-title span{display:block;white-space:nowrap}
.gift-title .gift-line-evening{text-align:center}
.gift-title .gift-line-mobile{display:none}
.mini-cert{margin:auto auto;background:#f8f1e4;color:var(--ink);border-radius:18px;padding:28px;box-shadow:0 24px 70px rgba(0,0,0,.24);position:relative;z-index:1;max-width:556px;width:min(100%,556px);align-self:center}
.mini-cert img{width:42px}
.mini-cert h3{font-size:38px;letter-spacing:.018em;margin-top:20px}
.mini-cert p{color:var(--muted);margin:0}
.mini-cert strong{font-size:20px}
.form-box{border:1px solid var(--line);border-radius:22px;padding:38px;background:rgba(255,255,255,.56);box-shadow:0 20px 60px rgba(29,23,19,.08)}
.form-box h2,.panel h2{letter-spacing:.010em}
.muted{color:var(--muted)}
.pay-form{display:grid;gap:13px;margin-top:22px}
.field span{display:block;font-size:13px;letter-spacing:.05em;color:var(--muted);margin:0 0 6px}
.field input,.field select,.field textarea{width:100%;border:1px solid rgba(29,23,19,.2);background:rgba(255,255,255,.78);border-radius:10px;min-height:48px;padding:11px 16px;font:inherit;color:var(--ink)}
.field-hint{display:block;margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.35;letter-spacing:0}
.field textarea{min-height:72px;resize:vertical}
.check{display:flex;gap:12px;align-items:flex-start;color:var(--muted);font-size:14px;line-height:1.45}
.check input{margin-top:4px}
.notice{border-left:2px solid var(--red);padding-left:13px;color:var(--muted);font-size:13px;margin:2px 0}

.footer{background:#12100e;color:#fff;padding:52px 0 28px;overflow:hidden}
.footer .container{width:min(1180px,calc(100% - 64px));margin:0 auto}
.footer-main{display:grid;grid-template-columns:1fr 1fr;column-gap:120px;align-items:start;justify-items:start}
.footer-main>div{width:auto;max-width:100%;justify-self:start;display:block;text-align:left}
.footer h3{font-family:var(--serif);font-size:30px;line-height:1.05;letter-spacing:.01em;text-align:left;margin:0 0 12px;color:#fff;font-weight:400}
.footer p{color:rgba(255,255,255,.72);margin:0;text-align:left;font-size:15px;line-height:1.65}
.footer a{color:inherit;text-decoration:none}
.legal-note{border-top:1px solid rgba(255,255,255,.15);margin-top:34px;padding-top:20px}
.legal-note p{max-width:920px;font-size:13px;line-height:1.55;color:rgba(255,255,255,.62)}

.reveal,.stagger>*{opacity:0;transform:translateY(18px);animation:rise .85s cubic-bezier(.19,1,.22,1) forwards}
.stagger>*:nth-child(2){animation-delay:.08s}
.stagger>*:nth-child(3){animation-delay:.16s}
.stagger>*:nth-child(4){animation-delay:.24s}
@keyframes rise{to{opacity:1;transform:none}}

@media (max-width:1350px){
  .nav{gap:22px;font-size:14px}
  .brand{min-width:285px}
  .brand-title{font-size:29px}
  .site-header .btn{font-size:14px;padding-inline:18px;min-width:164px}
}

@media (max-width:1200px){
  .hero-content{left:clamp(70px,20vw,250px);top:clamp(130px,30%,220px);width:clamp(390px,50vw,680px)}
  .hero h1{font-size:clamp(40px,5.1vw,64px);line-height:1.01}
  .hero-ceremony-word{top:-.112em}
  .hero p:not(.eyebrow){font-size:clamp(14.2px,1.20vw,17.7px);max-width:min(760px,100%);margin:22px 0 28px}
  .gallery-window{width:100%;margin:0 auto;padding:0 32px}
  .gallery-rail{grid-auto-columns:calc((100% - 44px)/3)}
  .cards{grid-template-columns:repeat(2,1fr)}
  .desktop-nowrap{white-space:normal}
}

@media (max-width:920px){
  html{scroll-padding-top:96px}
  section[id]{scroll-margin-top:96px}
  .container,.container-narrow{width:min(100% - 44px,1460px)}
  .nav,.site-header .btn-primary{display:none}
  .site-header.menu-open .nav{display:flex;position:absolute;left:auto;right:24px;top:calc(100% + 10px);width:min(270px,calc(100vw - 48px));flex-direction:column;align-items:flex-start;gap:0;padding:18px 22px 20px;background:rgba(244,239,229,.98);border:1px solid var(--line);box-shadow:0 18px 40px rgba(29,23,19,.12)}
  .site-header.menu-open .nav a{padding:12px 0}
  .burger{display:block}
  .header-inner{height:82px}
  .brand img{width:46px;height:72px}
  .brand-title{font-size:28px}
  .brand-middle{top:0}
  .hero{height:calc(100svh - 82px);min-height:620px;padding-top:82px}
  .hero-media img{object-position:60% 50%}
  .hero-media:after{background:linear-gradient(0deg,rgba(0,0,0,.80),rgba(0,0,0,.36) 48%,rgba(0,0,0,.46)),linear-gradient(90deg,rgba(0,0,0,.60),rgba(0,0,0,.16))}
  .hero-content{left:clamp(30px,7vw,64px);top:clamp(150px,34%,230px);width:min(610px,calc(100vw - 60px))}
  .hero h1{font-size:clamp(36px,7.6vw,58px);line-height:.98;letter-spacing:-.022em}
  .hero-ceremony-word{top:-.112em}
  .hero p:not(.eyebrow){font-size:clamp(12.7px,1.76vw,15.7px);line-height:1.42;max-width:min(760px,100%);margin:20px 0 26px}
  .city-word,.city-p{margin-left:-.055em}
  .ur-gap{margin-left:.03em}
  .section{padding:52px 0}
  .section-head{display:block}
  h2,.section-head h2,.form-box h2,.panel h2,.process h2{font-size:clamp(40px,7.2vw,58px);line-height:1.02}
  .process,.studio-panel,.cert-form-grid{grid-template-columns:1fr}
  .cert-form-grid{margin-top:0}
  .studio-panel{padding:42px}
  .footer-main{grid-template-columns:1fr;row-gap:34px;column-gap:0}
}

@media (max-width:620px){
  html{scroll-padding-top:88px}
  section[id]{scroll-margin-top:88px}
  .container,.container-narrow{width:min(100% - 28px,1460px)}
  .header-inner{height:78px}
  .brand{gap:10px;min-width:0}
  .brand img{width:42px;height:64px}
  .brand-title{font-size:23px}
  .brand-middle{top:-2px}
  .hero{height:calc(100svh - 78px);min-height:620px;padding-top:78px}
  .hero-media img{object-position:62% 50%}
  .hero-content{left:clamp(20px,5.5vw,34px);right:auto;top:clamp(145px,31%,205px);width:calc(100vw - clamp(40px,11vw,68px));max-width:none;padding:0;margin-left:0;transform:none}
  .eyebrow{display:block;white-space:normal;font-size:10px;letter-spacing:.22em;line-height:1.6}
  .hero .eyebrow{letter-spacing:clamp(1.4px,calc(3.14vw - 9.9px),3.6px)}
  .eyebrow:before{display:inline-block;vertical-align:middle;margin-right:12px}
  .hero .eyebrow-separator{margin:0 .30em}
  .hero h1{font-size:clamp(31px,9.7vw,44px);line-height:.95;letter-spacing:-.008em;max-width:100%}
  .hero h1 .hero-title-line:first-child{position:relative;top:-5px}
  .hero-ceremony-word{top:calc(-.142em)}
  .hero p:not(.eyebrow){font-size:clamp(11.7px,3.05vw,13.7px);line-height:1.42;max-width:none;width:calc(100vw - 44px);margin:20px 0 26px}
  .hero-actions .btn{width:100%}
  .gallery{padding-top:30px}
  .gallery-top{margin-inline:14px;justify-content:center;gap:0;padding:0 58px;min-height:52px}
  .gallery-top h2{font-size:34px;flex:1;text-align:center}
  .gallery-controls{position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:space-between;gap:0;pointer-events:none}
  .gallery-controls .circle-btn{width:48px;height:48px;min-width:48px;flex:0 0 48px;pointer-events:auto}
  .gallery-window{width:min(100% - 28px,1460px);margin:0 auto;padding:0;overflow:hidden}
  .gallery-rail{grid-auto-columns:100%;gap:0;padding-inline:0}
  .gallery-card{min-height:270px;margin:0 auto;width:100%}
  .gallery-card img{aspect-ratio:4/5}
  .section{padding:43px 0}
  #formats .section-head{margin-bottom:16px}
  #formats .link-arrow{display:inline-block;margin-top:19px}
  .cards{grid-template-columns:1fr}
  .format-card{min-height:auto}
  .format-img{height:205px}
  .format-body h3{font-size:31px}
  .steps{grid-template-columns:1fr}
  .process-img img{height:340px}
  .panel{padding:28px}
  .gift-side{padding:30px;border-radius:22px}
  .gift-title{font-size:clamp(36px,9vw,46px);line-height:1.05;letter-spacing:.005em;transform:translateY(-14px);text-align:center}
  .gift-title .gift-line-desktop{display:none}
  .gift-title .gift-line-mobile{display:block}
  .gift-title .gift-line-mobile-second{text-align:center}
  br.mobile-only{display:block}
  .mini-cert{padding:24px}
  .form-box{padding:26px}
  .field input,.field select{min-height:46px}
  .field textarea{min-height:68px}
  .footer{padding:44px 0 26px}
  .footer .container{width:calc(100% - 44px)}
  .footer h3{font-size:38px;line-height:1.08}
  .footer p{font-size:20px;line-height:1.55}
  .legal-note p{font-size:18px;line-height:1.55}
  .check{font-size:13.5px}
}



@media (max-width:420px){
  .hero-content{left:20px;top:clamp(140px,30%,190px);width:calc(100vw - 40px)}
  .hero .eyebrow-separator{margin:0 .30em}
  .hero h1{font-size:clamp(30px,9.4vw,38px);line-height:.95}
  .hero-ceremony-word{top:calc(-.16em)}
  .hero p:not(.eyebrow){font-size:clamp(11.4px,3.05vw,12.7px);line-height:1.42;width:calc(100vw - 36px);margin:18px 0 22px}
  .city-word,.city-p{margin-left:-.045em}
  .ur-gap{margin-left:.02em}
  .hero-actions{gap:10px}
}
