:root{
  --cream:#f6f1e7;
  --cream-2:#efe7d6;
  --paper:#fbf7ef;
  --ink:#1f1a14;
  --ink-soft:#3b342b;
  --muted:#7a6f5e;
  --line:#d9cfbb;
  --accent:#a8612a;
  --accent-deep:#7e4317;
  --gold:#c39b54;
  --shadow:0 30px 60px -25px rgba(60,40,15,.35);
  --radius:14px;
  --max:1240px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;letter-spacing:.005em;color:var(--ink);margin:0}
h1{font-size:clamp(2.6rem,6vw,5.4rem);line-height:1.04}
h2{font-size:clamp(2rem,3.6vw,3.2rem);line-height:1.1}
h3{font-size:clamp(1.4rem,2vw,1.8rem)}
p{margin:0 0 1em}

/* topbar */
.topbar{background:var(--ink);color:#e7dfce;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase}
.topbar-inner{max-width:var(--max);margin:0 auto;padding:.6rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}
.topbar a:hover{color:#fff}
.topbar .sep{opacity:.4;margin:0 .6rem}
.topbar .socials{display:flex;gap:.9rem}
.topbar .socials a{opacity:.85}
.topbar .socials a:hover{opacity:1}

/* nav */
.nav{position:sticky;top:0;z-index:50;background:rgba(246,241,231,.92);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid rgba(217,207,187,.6)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:1.1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:flex;align-items:baseline;gap:.55rem;line-height:1}
.brand .mark{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;font-size:1.9rem;color:var(--ink)}
.brand .mark .amp{color:var(--accent)}
.brand .sub{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}
.menu{display:flex;gap:2rem;list-style:none;margin:0;padding:0}
.menu a{position:relative;font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);padding:.4rem 0}
.menu a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.menu a:hover{color:var(--accent-deep)}
.menu a:hover::after,.menu a.active::after{transform:scaleX(1)}
.menu a.active{color:var(--accent-deep)}
.nav .cta{border:1px solid var(--ink);color:var(--ink);padding:.65rem 1.2rem;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;transition:background .25s,color .25s}
.nav .cta:hover{background:var(--ink);color:var(--cream)}
.burger{display:none;border:none;background:none;cursor:pointer;padding:.4rem}
.burger span{display:block;width:26px;height:1.5px;background:var(--ink);margin:5px 0;transition:transform .25s,opacity .25s}

/* shared buttons */
.btn{display:inline-block;padding:.95rem 1.6rem;font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;border:1px solid currentColor;transition:all .25s ease;cursor:pointer}
.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-deep);border-color:var(--accent-deep)}
.btn-ghost{color:#fdf6e6}
.btn-ghost:hover{background:#fdf6e6;color:var(--ink)}
.btn-dark{color:var(--ink);border-color:var(--ink)}
.btn-dark:hover{background:var(--ink);color:var(--cream)}

/* eyebrow / dividers */
.eyebrow{display:inline-flex;align-items:center;gap:.8rem;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:#e6d6b3;margin-bottom:1.4rem}
.eyebrow::before,.eyebrow::after{content:"";width:42px;height:1px;background:#e6d6b3;opacity:.7}
.kicker{font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;color:var(--accent)}
.divider{width:48px;height:1px;background:var(--accent);margin:1.2rem auto 1.6rem;position:relative}
.divider::before,.divider::after{content:"";position:absolute;top:50%;width:6px;height:6px;border-radius:50%;background:var(--accent);transform:translateY(-50%)}
.divider::before{left:-14px}
.divider::after{right:-14px}

/* hero (homepage) */
.hero{position:relative;overflow:hidden;background:#1a140d;color:#fff;min-height:88vh;display:flex;align-items:flex-end}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg .slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.4s ease;transform:scale(1.06);animation:slowzoom 14s linear infinite alternate}
.hero-bg .slide.active{opacity:1}
@keyframes slowzoom{from{transform:scale(1.02)}to{transform:scale(1.12)}}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,15,8,.15) 0%,rgba(20,15,8,.55) 60%,rgba(20,15,8,.85) 100%)}
.hero-content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:6rem 1.5rem 5rem;width:100%}
.hero h1{color:#fdf6e6;max-width:18ch;font-weight:500;text-shadow:0 8px 40px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:#f0c98a;font-weight:500}
.hero-lede{margin-top:1.4rem;max-width:46ch;color:#ece2cf;font-size:1.05rem;line-height:1.7}
.hero-actions{margin-top:2.2rem;display:flex;gap:.9rem;flex-wrap:wrap}
.hero-dots{position:absolute;right:2rem;bottom:2.4rem;z-index:3;display:flex;gap:.6rem}
.hero-dots button{width:30px;height:2px;border:0;background:rgba(255,255,255,.35);cursor:pointer;padding:0;transition:background .3s}
.hero-dots button.on{background:#f0c98a}

/* hero — scroll-morph gallery (homepage): cards scatter → line → circle → arch */
.morph-hero{position:relative;overflow:hidden;background:var(--paper);height:100vh;min-height:560px}
.morph-stage{position:absolute;inset:0;z-index:1}
/* each card is centred at the stage middle, then transformed to x/y/rotate/scale by JS */
.mc{position:absolute;left:50%;top:50%;width:64px;height:90px;margin:-45px 0 0 -32px;perspective:900px;
  will-change:transform,opacity;cursor:pointer}
.mc-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.mc:hover .mc-inner{transform:rotateY(180deg)}
.mc-front,.mc-back{position:absolute;inset:0;border-radius:10px;overflow:hidden;backface-visibility:hidden;-webkit-backface-visibility:hidden;box-shadow:0 12px 26px rgba(20,15,8,.3)}
.mc-front{background:var(--cream-2)}
.mc-front img{width:100%;height:100%;object-fit:cover;display:block}
.mc-front::after{content:"";position:absolute;inset:0;background:rgba(20,15,8,.1);transition:background .3s}
.mc:hover .mc-front::after{background:transparent}
.mc-back{transform:rotateY(180deg);background:var(--ink);color:#fdf6e6;display:grid;place-items:center;text-align:center;padding:.4rem;border:1px solid rgba(195,155,84,.4)}
.mc-back .mc-view{font-size:.5rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.2rem}
.mc-back .mc-name{font-family:'Cormorant Garamond',serif;font-size:.82rem;line-height:1.1}
/* hero copy — fades in once the arch has formed (JS adds .show) */
.morph-content{position:absolute;left:50%;top:70%;transform:translate(-50%,-50%) translateY(14px);z-index:20;
  width:min(92vw,640px);text-align:center;opacity:0;pointer-events:none;
  transition:opacity 1s ease,transform 1s ease}
.morph-content.show{opacity:1;transform:translate(-50%,-50%);pointer-events:auto}
.morph-content .eyebrow{display:inline-block;color:var(--accent);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase}
.morph-content h1{margin-top:.9rem;color:var(--ink);font-weight:500;font-size:clamp(2.4rem,5.6vw,4.6rem);line-height:1.04;text-shadow:0 2px 18px rgba(251,247,239,.7)}
.morph-content h1 em{font-style:italic;color:var(--accent);font-weight:500}
.morph-content .hero-lede{margin:1.3rem auto 0;max-width:48ch;color:var(--ink-soft);font-size:1.08rem;line-height:1.7}
.morph-content .hero-actions{margin-top:2.2rem;display:flex;gap:.9rem;flex-wrap:wrap;justify-content:center}
@media(min-width:768px){.mc{width:78px;height:108px;margin:-54px 0 0 -39px}}

/* category page hero */
.page-hero{position:relative;overflow:hidden;background:#1a140d;color:#fff;min-height:48vh;display:flex;align-items:flex-end}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.6;transform:scale(1.04)}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,15,8,.4) 0%,rgba(20,15,8,.85) 100%)}
.page-hero-content{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:5rem 1.5rem 3rem;width:100%}
.crumbs{display:flex;gap:.6rem;color:#d9c8a4;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:1rem}
.crumbs a:hover{color:#fff}
.crumbs span{opacity:.5}
.page-hero h1{font-size:clamp(2.4rem,5vw,4.4rem);color:#fdf6e6;font-weight:500;max-width:none;text-shadow:0 8px 40px rgba(0,0,0,.35)}
.page-hero h1 em{font-style:italic;color:#f0c98a;font-weight:500}
.page-hero-lede{margin-top:1rem;max-width:60ch;color:#ece2cf}

/* intro */
.intro{background:var(--paper);padding:5rem 1.5rem}
.intro-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:center}
.intro h2 span{color:var(--accent);font-style:italic}
.intro .signature{margin-top:1.6rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--accent-deep)}
.intro-image{position:relative;aspect-ratio:5/4;background:var(--cream-2);box-shadow:var(--shadow);border-radius:6px;overflow:hidden}
.intro-image img{width:100%;height:100%;object-fit:cover}
.intro-image::before{content:"";position:absolute;inset:18px;border:1px solid rgba(255,255,255,.6);pointer-events:none;z-index:2}
.intro-image .badge{position:absolute;left:-22px;top:30px;z-index:3;background:var(--accent);color:#fff;padding:.5rem 1.1rem;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;box-shadow:0 8px 18px rgba(168,97,42,.35)}

/* section heads */
.section-head{text-align:center;max-width:720px;margin:0 auto 3rem}
.section-head h2{margin:.6rem 0 .9rem}
.section-head p{color:var(--muted);margin:0 auto;max-width:60ch}

/* category cards (home) */
.categories{padding:6rem 1.5rem;background:var(--cream)}
.cards{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.card{position:relative;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 18px 36px -22px rgba(60,40,15,.35);transition:transform .5s,box-shadow .5s}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -25px rgba(60,40,15,.5)}
.card .frame{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--cream-2)}
.card .frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s}
.card:hover .frame img{transform:scale(1.06)}
.card .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(20,15,8,.55))}
.card .label{position:absolute;left:1.3rem;bottom:1.1rem;z-index:2;color:#fff;font-family:'Cormorant Garamond',serif;font-size:1.8rem;font-weight:500;letter-spacing:.02em}
.card .meta{padding:1.4rem 1.5rem 1.6rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;border-top:1px solid var(--line)}
.card .meta span{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.card .meta a{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid currentColor;padding-bottom:2px}

/* home gallery */
.gallery{padding:6rem 1.5rem;background:var(--paper)}
/* interactive bento gallery */
.bento-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:140px;gap:14px}
.bento-item{position:relative;overflow:hidden;background:var(--cream-2);border-radius:8px;cursor:pointer;user-select:none;transition:transform .25s ease,box-shadow .25s ease,opacity .2s ease}
.bento-item img{width:100%;height:100%;object-fit:cover;pointer-events:none;transition:transform 1.4s,filter .8s}
.bento-item:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(20,15,8,.18);z-index:2}
.bento-item:hover img{transform:scale(1.05);filter:brightness(.92)}
.bento-item .cap{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:.9rem 1rem;opacity:0;transition:opacity .25s ease}
.bento-item .cap::before{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,15,8,.82) 0%,rgba(20,15,8,.35) 45%,transparent 75%)}
.bento-item:hover .cap{opacity:1}
.bento-item .cap h3{position:relative;color:#fdf6e6;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.2rem;line-height:1.15}
.bento-item .cap p{position:relative;color:rgba(253,246,230,.78);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;margin-top:.25rem}
.bento-item.dragging{opacity:.4}
.bento-item.drop-target{outline:2px dashed var(--accent);outline-offset:-6px}
.b1{grid-column:span 6;grid-row:span 3}
.b2{grid-column:span 3;grid-row:span 2}
.b3{grid-column:span 3;grid-row:span 2}
.b4{grid-column:span 4;grid-row:span 2}
.b5{grid-column:span 4;grid-row:span 3}
.b6{grid-column:span 4;grid-row:span 2}
.b7{grid-column:span 6;grid-row:span 2}
.b8{grid-column:span 6;grid-row:span 2}

/* exhibition modal — portrait hung & framed on a gallery wall */
.bento-modal{position:fixed;inset:0;z-index:120;display:none;align-items:center;justify-content:center;padding:1.5rem;
  background:radial-gradient(82% 70% at 50% 32%,#efe7d6 0%,#cdbfa6 58%,#94866c 100%)}
.bento-modal.open{display:flex;animation:bmWall .4s ease}
@keyframes bmWall{from{opacity:0}to{opacity:1}}
.bm-stage{position:relative;display:flex;flex-direction:column;align-items:center;max-width:min(92vw,820px)}
/* picture light glow above the frame */
.bm-figure::before{content:"";position:absolute;left:50%;top:-34px;transform:translateX(-50%);width:62%;height:60px;
  background:radial-gradient(ellipse at center,rgba(255,246,224,.55),transparent 70%);filter:blur(7px);pointer-events:none;z-index:2}
/* gilt frame */
.bm-figure{position:relative;margin:0;cursor:pointer;padding:16px;border-radius:3px;
  background:linear-gradient(135deg,#e3c074 0%,#b88a3c 42%,#8c6526 56%,#dcb45f 100%);
  box-shadow:inset 0 2px 2px rgba(255,255,255,.45),inset 0 -3px 4px rgba(0,0,0,.4),
    0 2px 0 rgba(0,0,0,.2),0 44px 80px rgba(20,15,8,.5),0 12px 24px rgba(20,15,8,.4)}
/* cream mount / passe-partout */
.bm-mount{background:#f6f1e7;padding:18px;box-shadow:inset 0 0 0 1px rgba(20,15,8,.12),inset 0 2px 8px rgba(20,15,8,.2)}
.bm-figure img{display:block;width:auto;max-width:100%;max-height:62vh;object-fit:contain;background:#15100a}
/* brass gallery label */
.bm-plate{margin-top:20px;max-width:380px;text-align:center;padding:.55rem 1.1rem;border-radius:3px;color:#2a1d09;
  background:linear-gradient(#d2ac63,#a8812f);box-shadow:0 5px 12px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.45)}
.bm-plate h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.25rem;line-height:1.1}
.bm-plate p{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;opacity:.82;margin-top:.15rem}
.bm-close{position:absolute;top:-14px;right:-14px;width:40px;height:40px;display:grid;place-items:center;border-radius:50%;border:0;cursor:pointer;background:var(--cream);color:var(--ink);box-shadow:0 8px 20px rgba(0,0,0,.35);transition:transform .2s,background .2s}
.bm-close:hover{transform:scale(1.08);background:#fff}
.bm-dock{position:fixed;left:50%;bottom:1.4rem;transform:translateX(-50%);display:flex;align-items:center;gap:.2rem;padding:.5rem .7rem;border-radius:14px;background:rgba(195,155,84,.16);border:1px solid rgba(195,155,84,.4);box-shadow:0 12px 30px rgba(0,0,0,.4);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:grab;touch-action:none}
.bm-dock.dragging{cursor:grabbing}
.bm-thumb{position:relative;width:42px;height:42px;flex:none;border-radius:8px;overflow:hidden;cursor:pointer;opacity:.85;transition:transform .25s ease,opacity .2s ease,box-shadow .2s ease}
.bm-thumb:nth-child(odd){transform:rotate(-9deg)}
.bm-thumb:nth-child(even){transform:rotate(9deg)}
.bm-thumb img{width:100%;height:100%;object-fit:cover;pointer-events:none}
.bm-thumb:hover{transform:rotate(0) scale(1.25) translateY(-6px);opacity:1;z-index:5}
.bm-thumb.active{transform:rotate(0) scale(1.2) translateY(-6px);opacity:1;box-shadow:0 0 0 2px rgba(253,246,230,.8),0 10px 24px rgba(0,0,0,.4);z-index:4}

/* portfolio (category page) gallery — masonry via CSS columns */
.portfolio{padding:5rem 1.5rem 6rem;background:var(--paper)}
.filter-bar{
  max-width:var(--max);margin:0 auto 2.6rem;display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;
}
.filter-bar button{
  appearance:none;background:transparent;border:1px solid var(--line);color:var(--ink-soft);
  font:inherit;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.7rem 1.1rem;cursor:pointer;border-radius:30px;transition:all .25s;
}
.filter-bar button:hover{border-color:var(--accent);color:var(--accent-deep)}
.filter-bar button.on{background:var(--ink);color:var(--cream);border-color:var(--ink)}

.masonry{max-width:var(--max);margin:0 auto;column-count:3;column-gap:1.4rem}
.masonry figure{
  break-inside:avoid;margin:0 0 1.4rem;background:#fff;
  box-shadow:0 14px 28px -18px rgba(60,40,15,.35);border-radius:4px;overflow:hidden;
  transition:transform .4s ease, box-shadow .4s ease, opacity .35s ease;
}
.masonry figure.hide{display:none}
.masonry figure:hover{transform:translateY(-4px);box-shadow:0 24px 50px -20px rgba(60,40,15,.5)}
.masonry figure img{width:100%;height:auto;display:block;background:var(--cream-2)}
.masonry figcaption{
  padding:1rem 1.2rem 1.2rem;display:flex;justify-content:space-between;align-items:baseline;gap:.8rem;
  border-top:1px solid var(--line);
}
.masonry figcaption .name{
  font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;color:var(--ink);
}
.masonry figcaption .medium{
  font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
}

/* bespoke banner */
.bespoke{position:relative;color:#fff;overflow:hidden;background:#1a140d}
.bespoke .bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.55;transform:scale(1.04)}
.bespoke::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,15,8,.85),rgba(20,15,8,.4))}
.bespoke-inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:7rem 1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.bespoke .kicker{color:#f0c98a}
.bespoke h2{color:#fdf6e6;font-weight:500}
.bespoke h2 em{color:#f0c98a;font-style:italic}
.bespoke p{color:#ece2cf;max-width:48ch}
.bespoke .btn-primary{background:#fdf6e6;color:var(--ink);border-color:#fdf6e6}
.bespoke .btn-primary:hover{background:transparent;color:#fdf6e6}

/* commission strip (compact, on category pages) */
.commission-strip{background:var(--cream);padding:5rem 1.5rem;text-align:center}
.commission-strip .glyph{font-family:'Cormorant Garamond',serif;font-size:5rem;line-height:.5;color:var(--accent);opacity:.7}
.commission-strip h2{margin:1rem 0 .8rem}
.commission-strip h2 em{color:var(--accent);font-style:italic}
.commission-strip p{color:var(--ink-soft);max-width:54ch;margin:0 auto 1.6rem}
.commission-strip .actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

/* testimonial */
.quote{padding:7rem 1.5rem;background:var(--cream);text-align:center}
.quote .glyph{font-family:'Cormorant Garamond',serif;font-size:6rem;line-height:.5;color:var(--accent);opacity:.7}
.quote blockquote{max-width:780px;margin:1rem auto 1.6rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.4;color:var(--ink)}
.quote cite{font-style:normal;font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}

/* contact */
.contact{padding:6rem 1.5rem;background:var(--paper)}
.contact-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:4rem;align-items:start}
.info-card{background:#fff;padding:2.5rem;border:1px solid var(--line);border-radius:6px;box-shadow:var(--shadow)}
.info-row{padding:1.1rem 0;border-bottom:1px solid var(--line);display:flex;gap:1rem;align-items:flex-start}
.info-row:last-child{border-bottom:0}
.info-row .icon{width:38px;height:38px;border-radius:50%;background:var(--cream);display:grid;place-items:center;flex:none;color:var(--accent)}
.info-row .label{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.info-row .value{font-size:1.05rem;color:var(--ink);font-weight:500;margin-top:.1rem}
.info-row a:hover{color:var(--accent-deep)}
form{display:grid;gap:1rem}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
label{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:.4rem}
input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;padding:.9rem 1rem;font:inherit;color:var(--ink);border-radius:4px;transition:border-color .2s,box-shadow .2s}
textarea{min-height:140px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px rgba(168,97,42,.15)}

/* footer */
footer{background:var(--ink);color:#cec4ad;padding:4.5rem 1.5rem 2rem}
.foot-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem}
footer h4{color:#fdf6e6;font-size:1.1rem;margin-bottom:1rem;font-family:'Inter',sans-serif;font-weight:500;letter-spacing:.18em;text-transform:uppercase}
footer a:hover{color:#fdf6e6}
.foot-brand .mark{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:2rem;color:#fdf6e6}
.foot-brand p{margin-top:.6rem;color:#a59679;font-size:.95rem;line-height:1.7}
.foot-list{list-style:none;padding:0;margin:0;display:grid;gap:.7rem;font-size:.92rem}
.foot-socials{display:flex;gap:.7rem;margin-top:.4rem}
.foot-socials a{width:38px;height:38px;border:1px solid #4a4233;border-radius:50%;display:grid;place-items:center;color:#cec4ad;transition:all .25s}
.foot-socials a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.foot-bottom{max-width:var(--max);margin:3rem auto 0;padding-top:1.6rem;border-top:1px solid #2c2519;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.8rem;color:#7e7460;font-size:.78rem;letter-spacing:.12em}

/* reveal */
/* reveal — visible by DEFAULT; a pure-CSS fade plays once on load and always
   ends visible (animation-fill-mode:both). No dependency on JS, the scroll
   observer, or cache state, so content can never get stuck invisible. */
.reveal{opacity:1;transform:none;animation:revealIn .7s ease both}
.reveal.in{opacity:1;transform:none}
/* opacity stays 1 the whole time — only a gentle slide — so content is visible
   even if the animation is paused or never runs. */
@keyframes revealIn{from{transform:translateY(16px)}to{transform:none}}
@media(prefers-reduced-motion:reduce){.reveal{animation:none}}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(15,11,6,.94);z-index:100;display:none;align-items:center;justify-content:center;padding:3rem 1.5rem}
.lightbox.open{display:flex}
.lightbox figure{margin:0;max-width:min(1100px,100%);max-height:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}
.lightbox img{max-width:100%;max-height:80vh;object-fit:contain;box-shadow:0 30px 80px -20px rgba(0,0,0,.6)}
.lightbox figcaption{color:#ece2cf;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.2rem;text-align:center}
.lightbox .lb-close{position:absolute;top:1.4rem;right:1.6rem;background:none;border:0;color:#ece2cf;font-size:2rem;line-height:1;cursor:pointer;padding:.4rem .6rem}
.lightbox .lb-close:hover{color:#fff}
.lightbox .lb-prev,.lightbox .lb-next{position:absolute;top:50%;transform:translateY(-50%);background:none;border:0;color:#ece2cf;font-size:2.4rem;cursor:pointer;padding:.4rem 1rem;transition:color .2s}
.lightbox .lb-prev:hover,.lightbox .lb-next:hover{color:#fff}
.lightbox .lb-prev{left:.6rem}
.lightbox .lb-next{right:.6rem}

/* before / after reveal slider */
.ba-section{padding:6rem 1.5rem;background:var(--cream)}
.ba{position:relative;max-width:760px;margin:2.6rem auto 0;aspect-ratio:4/3;border-radius:10px;overflow:hidden;
  box-shadow:var(--shadow);user-select:none;touch-action:none;cursor:ew-resize;--pos:50%}
.ba:focus-visible{outline:3px solid var(--accent);outline-offset:3px}
.ba-img{position:absolute;inset:0}
.ba-img img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
/* the "before" layer is the same artwork rendered as a graphite-style underdrawing,
   clipped to the slider position. Swap its src for a real photo/sketch any time. */
.ba-before{clip-path:inset(0 calc(100% - var(--pos)) 0 0)}
.ba-before img{filter:grayscale(1) contrast(1.18) brightness(1.05)}
.ba-handle{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:rgba(253,246,230,.95);
  transform:translateX(-1px);box-shadow:0 0 0 1px rgba(20,15,8,.25);z-index:3;pointer-events:none}
.ba-handle span{position:absolute;top:50%;left:50%;width:46px;height:46px;transform:translate(-50%,-50%);
  border-radius:50%;background:var(--cream);box-shadow:0 6px 18px rgba(20,15,8,.4)}
.ba-handle span::before,.ba-handle span::after{content:"";position:absolute;top:50%;width:0;height:0;
  border-block:6px solid transparent}
.ba-handle span::before{left:10px;border-right:8px solid var(--accent)}
.ba-handle span::after{right:10px;border-left:8px solid var(--accent)}
.ba-label{position:absolute;bottom:12px;z-index:4;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;
  color:#fff;background:rgba(20,15,8,.55);padding:.32rem .6rem;border-radius:3px;pointer-events:none}
.ba-label-l{left:12px}
.ba-label-r{right:12px}

/* signing signature — visible by default; JS layers the "draw" on (.js-sign) */
.signature{margin-top:1.5rem;display:inline-block;position:relative}
.signature .sig-dash{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.6rem;color:var(--accent-deep);vertical-align:.2em}
.sig-name{font-family:'Mr Dafoe',cursive;font-size:clamp(2.3rem,4.4vw,3rem);line-height:.9;color:var(--accent-deep)}
.sig-underline{display:block;width:min(260px,78%);height:14px;margin-top:.1rem;overflow:visible}
.sig-underline path{fill:none;stroke:var(--gold);stroke-width:2.4;stroke-linecap:round}
.signature.js-sign .sig-name{clip-path:inset(0 100% 0 0);transition:clip-path 1.5s cubic-bezier(.6,.15,.2,1)}
.signature.js-sign.signed .sig-name{clip-path:inset(0 0 0 0)}
.signature.js-sign .sig-underline path{stroke-dasharray:var(--len);stroke-dashoffset:var(--len);transition:stroke-dashoffset 1s ease 1.15s}
.signature.js-sign.signed .sig-underline path{stroke-dashoffset:0}

/* bespoke journey stepper */
.journey{padding:6rem 1.5rem;background:var(--paper)}
.journey-track{max-width:var(--max);margin:3rem auto 0;padding:0;list-style:none;position:relative;
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.6rem}
/* connector line behind the nodes, drawn left→right on reveal */
.journey-track::before{content:"";position:absolute;top:33px;left:12.5%;right:12.5%;height:2px;
  background:linear-gradient(to right,var(--gold),var(--accent));transform:scaleX(0);transform-origin:left;
  transition:transform 1.1s ease .2s;z-index:0}
.journey-track.in::before{transform:scaleX(1)}
.jstep{position:relative;text-align:center;padding:0 .4rem}
.jstep .jnode{position:relative;z-index:1;width:66px;height:66px;margin:0 auto;border-radius:50%;
  display:grid;place-items:center;color:var(--accent);background:var(--cream);
  box-shadow:0 10px 24px rgba(20,15,8,.14),inset 0 0 0 1px rgba(168,97,42,.25);transition:transform .3s ease,box-shadow .3s ease}
.jstep .jnode svg{width:30px;height:30px}
.jstep:hover .jnode{transform:translateY(-4px);box-shadow:0 16px 30px rgba(20,15,8,.2),inset 0 0 0 1px var(--accent)}
.jstep .jnum{display:block;margin-top:1rem;font-size:.66rem;letter-spacing:.3em;color:var(--accent);font-weight:600}
.jstep h3{margin-top:.35rem;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.4rem;color:var(--ink)}
.jstep p{margin-top:.5rem;color:var(--ink-soft);font-size:.96rem;line-height:1.6;max-width:24ch;margin-left:auto;margin-right:auto}
.journey-cta{text-align:center;margin-top:3rem}
/* stagger each step's reveal */
.jstep:nth-child(1){transition-delay:.05s}
.jstep:nth-child(2){transition-delay:.15s}
.jstep:nth-child(3){transition-delay:.25s}
.jstep:nth-child(4){transition-delay:.35s}

/* FAQ */
.faq{padding:6rem 1.5rem;background:var(--cream)}
.faq-list{max-width:var(--max);margin:2.6rem auto 0;display:grid;grid-template-columns:1fr 1fr;gap:1.4rem 2.8rem}
.faq-item{padding-bottom:1.3rem;border-bottom:1px solid var(--line)}
.faq-item h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.35rem;line-height:1.2;color:var(--ink)}
.faq-item p{margin-top:.5rem;color:var(--ink-soft);line-height:1.65}

/* ---- content pages (about, commissions, pricing, legal, gift vouchers) ---- */
.page-wrap{max-width:860px;margin:0 auto;padding:5rem 1.5rem}
.page-wrap.wide{max-width:var(--max)}
.prose{color:var(--ink-soft);font-size:1.05rem;line-height:1.8}
.prose>p:first-of-type{font-size:1.18rem;color:var(--ink);line-height:1.7}
.prose h2{font-family:'Cormorant Garamond',Georgia,serif;color:var(--ink);font-size:clamp(1.6rem,3vw,2.1rem);font-weight:600;margin:2.4rem 0 .5rem;line-height:1.15}
.prose h3{font-family:'Cormorant Garamond',Georgia,serif;color:var(--ink);font-size:1.3rem;font-weight:600;margin:1.6rem 0 .3rem}
.prose p{margin:0 0 1.1rem}
.prose strong{color:var(--ink);font-weight:600}
.prose ul{margin:0 0 1.2rem;padding-left:1.2rem}.prose li{margin:.35rem 0}
.prose a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px}
.prose .signature{margin-top:1.6rem;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.4rem;color:var(--accent-deep)}
.note-line{font-size:.84rem;color:var(--ink-soft);opacity:.85;margin-top:2.5rem;border-top:1px solid var(--line);padding-top:1.2rem}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;margin:2.4rem 0}
.price-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:1.4rem 1.5rem;box-shadow:0 14px 30px rgba(20,15,8,.06)}
.price-card h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;color:var(--ink);margin:0 0 .15rem}
.price-card .pc-sub{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:.9rem;display:block}
.price-row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.5rem 0;border-bottom:1px dashed var(--line)}
.price-row:last-child{border-bottom:0}
.price-row .pr-size{color:var(--ink-soft);font-size:.96rem}
.price-row .pr-amt{font-weight:600;color:var(--ink);font-size:1.05rem;white-space:nowrap}
.price-note{background:var(--cream);border-radius:10px;padding:1.2rem 1.4rem;color:var(--ink-soft);font-size:.98rem;line-height:1.7}

/* testimonials grid */
.tgrid{columns:2;column-gap:1.4rem;margin-top:2.4rem}
.tcard{break-inside:avoid;background:#fff;border:1px solid var(--line);border-radius:10px;padding:1.15rem 1.3rem;margin:0 0 1.4rem;box-shadow:0 10px 24px rgba(20,15,8,.05)}
.tcard blockquote{margin:0;font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-style:italic;color:var(--ink);line-height:1.5}
.tcard cite{display:block;margin-top:.65rem;font-style:normal;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}

/* gift voucher feature */
.gv-card{background:linear-gradient(135deg,var(--cream),var(--cream-2));border:1px solid var(--line);border-radius:14px;padding:2.4rem 2rem;margin:2.4rem 0;text-align:center;box-shadow:0 18px 40px rgba(20,15,8,.08)}
.gv-card .gv-amt{font-family:'Cormorant Garamond',serif;font-size:2.6rem;color:var(--accent-deep);line-height:1}
.gv-points{list-style:none;padding:0;margin:1.6rem 0;display:grid;gap:.6rem;max-width:520px;margin-inline:auto;text-align:left}
.gv-points li{position:relative;padding-left:1.6rem;color:var(--ink-soft)}
.gv-points li::before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}

@media (max-width:680px){
  .price-grid{grid-template-columns:1fr}
  .tgrid{columns:1}
}

/* responsive */
@media (max-width:980px){
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;gap:0;padding:1rem 1.5rem 1.5rem;border-bottom:1px solid var(--line);box-shadow:0 20px 30px -20px rgba(0,0,0,.2)}
  .menu.open{display:flex}
  .menu li{border-bottom:1px solid rgba(217,207,187,.5)}
  .menu li:last-child{border-bottom:0}
  .menu a{display:block;padding:.9rem 0}
  .nav .cta{display:none}
  .burger{display:block}
  .intro-grid{grid-template-columns:1fr;gap:3rem}
  .cards{grid-template-columns:1fr;gap:1.6rem}
  .bento-grid{grid-auto-rows:120px;gap:10px}
  .b1,.b2,.b3,.b4,.b5,.b6,.b7,.b8{grid-column:span 12;grid-row:span 2}
  .b1{grid-row:span 3}
  .bm-thumb{width:36px;height:36px}
  .bespoke-inner{grid-template-columns:1fr;padding:5rem 1.5rem}
  .contact-grid{grid-template-columns:1fr;gap:2.5rem}
  .foot-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .masonry{column-count:2}
  .journey-track{grid-template-columns:repeat(2,1fr);gap:2.6rem 1.4rem}
  .journey-track::before{display:none}
  .faq-list{grid-template-columns:1fr;gap:1.2rem}
}
@media (max-width:560px){
  .topbar-inner{font-size:.7rem}
  .topbar .phone{display:none}
  .hero{min-height:78vh}
  .hero-content{padding:5rem 1.25rem 4rem}
  .foot-grid{grid-template-columns:1fr}
  form .row{grid-template-columns:1fr}
  .masonry{column-count:1}
  .journey-track{grid-template-columns:1fr;gap:2.2rem}
}
