/* ===== The Curated Room — shared site styles ===== */
@font-face { font-family:'Noceur'; src:url('fonts/Noceur.otf') format('opentype'); }
@font-face { font-family:'Noceur'; src:url('fonts/Noceur-Italic.otf') format('opentype'); font-style:italic; }
@font-face { font-family:'Josefin Sans'; src:url('fonts/JosefinSans-Light.ttf') format('truetype'); font-weight:300; }
@font-face { font-family:'Josefin Sans'; src:url('fonts/JosefinSans-Regular.ttf') format('truetype'); font-weight:400; }
@font-face { font-family:'Cormorant'; src:url('fonts/Cormorant-Regular.ttf') format('truetype'); }

:root{
  --espresso:#42362C; --mocha:#33291F; --olive:#6B6B4E;  /* brown #42362c per brand */
  --oat:#EDE6DA; --bone:#F7F3EC; --clay:#B08463;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--bone);color:var(--espresso);font-family:'Josefin Sans',sans-serif;font-weight:300;line-height:1.8;-webkit-font-smoothing:antialiased;}
/* .wrap controls width + horizontal gutters ONLY (longhand, so it never
   wipes out the vertical padding that `section` provides). */
.wrap{max-width:1180px;margin:0 auto;padding-left:40px;padding-right:40px;}
.eyebrow{text-transform:uppercase;letter-spacing:.36em;font-size:11px;color:var(--clay);}
h1,h2,h3{font-family:'Noceur',serif;font-weight:400;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.center{text-align:center;}
.rule{display:inline-block;width:48px;height:1px;background:var(--clay);margin-bottom:22px;opacity:.85;}

/* nav */
nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px 40px;background:rgba(247,243,236,.92);backdrop-filter:blur(8px);border-bottom:1px solid rgba(61,50,41,.08);}
nav .brand{display:flex;align-items:center;gap:11px;font-family:'Noceur',serif;font-size:22px;letter-spacing:.06em;color:var(--espresso);}
nav .brand .brandmark{height:50px;width:auto;display:block;}
nav .links{display:flex;gap:30px;align-items:center;font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:400;}
nav .links a{color:var(--espresso);opacity:.92;transition:.2s;}
nav .links a:hover,nav .links a.active{color:var(--clay);opacity:1;}
/* high-specificity so it beats `nav .links a` and keeps light text on the dark pill */
nav .links a.cta{background:var(--espresso);color:var(--bone);opacity:1;padding:11px 22px;border-radius:30px;font-size:11px;letter-spacing:.18em;}
nav .links a.cta:hover{background:var(--clay);color:var(--bone);}
@media(max-width:920px){nav .links{display:none;}}

/* buttons */
.btn{display:inline-block;background:var(--bone);color:var(--espresso);padding:16px 38px;border-radius:34px;text-transform:uppercase;letter-spacing:.22em;font-size:12px;transition:.2s;cursor:pointer;border:none;}
.btn:hover{background:var(--clay);color:var(--bone);}
.btn-dark{background:var(--espresso);color:var(--bone);}
.btn-dark:hover{background:var(--clay);}
.btn-outline{background:transparent;border:1px solid currentColor;color:inherit;}
.btn-outline:hover{background:var(--bone);color:var(--espresso);}

/* hero (full-bleed image) */
.hero{height:92vh;min-height:560px;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--bone);position:relative;background-size:cover;background-position:center;}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(46,42,38,.42),rgba(46,42,38,.5));}
.hero .inner{position:relative;z-index:2;max-width:780px;padding:0 30px;}
.hero .eyebrow{color:var(--oat);margin-bottom:22px;}
.hero h1{font-size:clamp(40px,7vw,78px);line-height:1.04;margin-bottom:20px;}
.hero .sub{font-family:'Cormorant',serif;font-size:clamp(18px,2.4vw,25px);font-style:italic;margin-bottom:14px;}
.hero .loc{text-transform:uppercase;letter-spacing:.3em;font-size:11px;opacity:.85;margin-bottom:34px;}
.hero .row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.hero .hero-mark{height:128px;width:auto;margin:0 auto 24px;display:block;}
@media(max-width:600px){.hero .hero-mark{height:96px;}}

/* page header (interior pages) */
.phead{padding-top:148px;padding-bottom:54px;text-align:center;}
.phead h1{font-size:clamp(38px,5.5vw,64px);margin-top:12px;}
.phead p{max-width:620px;margin:16px auto 0;opacity:.85;font-size:15px;}

/* generic section */
section{padding:74px 0;}
.lead{font-size:clamp(26px,4vw,42px);line-height:1.3;max-width:880px;margin:0 auto;font-family:'Noceur',serif;text-align:center;}
.lead em{font-style:italic;color:var(--clay);}

/* split (two services / about) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:30px;}
.card-img{position:relative;border-radius:8px;overflow:hidden;min-height:440px;display:flex;align-items:flex-end;color:var(--bone);}
.card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.card-img .veil{position:absolute;inset:0;background:linear-gradient(transparent,rgba(46,42,38,.85));}
.card-img .body{position:relative;z-index:2;padding:36px;}
.card-img h3{font-size:28px;margin-bottom:8px;}
.card-img p{font-size:14px;opacity:.92;margin-bottom:14px;}
.card-img .lnk{text-transform:uppercase;letter-spacing:.2em;font-size:11px;border-bottom:1px solid var(--clay);padding-bottom:3px;}
@media(max-width:760px){.split{grid-template-columns:1fr;}}

/* compact + visual quiz CTA */
.quiz-cta{display:grid;grid-template-columns:0.9fr 1.1fr;gap:0;background:var(--oat);border-radius:16px;overflow:hidden;align-items:stretch;}
.quiz-cta-img{position:relative;min-height:260px;}
.quiz-cta-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.quiz-cta-body{padding:clamp(28px,4vw,48px);display:flex;flex-direction:column;align-items:flex-start;justify-content:center;}
.quiz-cta-body h2{font-size:clamp(24px,3.4vw,38px);margin:10px 0 12px;line-height:1.15;}
.quiz-cta-body p{font-size:15px;opacity:.85;margin-bottom:22px;max-width:420px;}
.quiz-cta-body p em{font-style:italic;font-family:'Cormorant',serif;font-size:18px;color:var(--clay);}
@media(max-width:680px){.quiz-cta{grid-template-columns:1fr;}.quiz-cta-img{min-height:200px;}}

/* dark band */
.band{background:var(--espresso);color:var(--bone);text-align:center;}
.band .eyebrow{color:var(--clay);}
.band h2{font-size:clamp(26px,3.6vw,40px);max-width:820px;margin:18px auto 22px;line-height:1.3;}
.band p{max-width:600px;margin:0 auto;font-size:15px;opacity:.85;}

/* portfolio grid */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.pcard{display:block;}
.pcard .ph{position:relative;overflow:hidden;border-radius:6px;aspect-ratio:4/5;background:var(--oat);}
.pcard .ph img{width:100%;height:100%;object-fit:cover;transition:.5s;}
.pcard:hover .ph img{transform:scale(1.05);}
.pcard h3{font-size:22px;margin-top:16px;}
.pcard .meta{text-transform:uppercase;letter-spacing:.2em;font-size:11px;color:var(--clay);margin-top:4px;}
@media(max-width:760px){.pgrid{grid-template-columns:1fr;}}
/* coming-soon placeholder card (construction photo + veil) */
.pcard.soon{cursor:default;}
.pcard.soon .ph::after{content:"";position:absolute;inset:0;background:rgba(46,42,38,.5);z-index:1;}
.pcard.soon .ph img{filter:grayscale(.15);}
.pcard.soon:hover .ph img{transform:none;}
.pcard.soon .badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;color:var(--bone);text-transform:uppercase;letter-spacing:.28em;font-size:12px;border:1px solid rgba(247,243,236,.75);padding:11px 22px;border-radius:30px;white-space:nowrap;}
.pcard.soon h3{opacity:.85;}

/* masonry gallery */
.gallery{column-count:3;column-gap:16px;}
.gallery img{width:100%;margin:0 0 16px;border-radius:5px;display:block;break-inside:avoid;}
@media(max-width:820px){.gallery{column-count:2;}}
@media(max-width:480px){.gallery{column-count:1;}}

/* placeholder tile */
.holder{display:flex;align-items:center;justify-content:center;text-align:center;background:var(--oat);color:var(--clay);font-family:'Cormorant',serif;font-style:italic;font-size:18px;border:1px dashed rgba(176,132,99,.5);}
.holder.tall{aspect-ratio:4/5;border-radius:6px;}

/* before / after */
.ba{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.ba figure{position:relative;border-radius:6px;overflow:hidden;}
.ba figure .tag{position:absolute;top:14px;left:14px;background:rgba(46,42,38,.8);color:var(--bone);font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:6px 12px;border-radius:20px;}
.ba .holder{aspect-ratio:4/3;border-radius:6px;}
@media(max-width:680px){.ba{grid-template-columns:1fr;}}

/* ===== Before / After reveal slider ===== */
.ba-slider{position:relative;width:100%;aspect-ratio:4/3;border-radius:6px;overflow:hidden;user-select:none;touch-action:none;--pos:50%;}
.ba-slider img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;}
.ba-slider .ba-after{z-index:1;}
/* the BEFORE image sits on top and is clipped from the right edge in to --pos */
.ba-slider .ba-before{z-index:2;clip-path:inset(0 calc(100% - var(--pos)) 0 0);}
/* vertical divider riding the split */
.ba-slider .ba-divider{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;transform:translateX(-50%);z-index:3;background:var(--bone);box-shadow:0 0 0 1px rgba(46,42,38,.18);pointer-events:none;}
/* round grab handle */
.ba-slider .ba-handle{position:absolute;top:50%;left:var(--pos);transform:translate(-50%,-50%);z-index:4;width:46px;height:46px;border-radius:50%;background:var(--bone);color:var(--espresso);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px rgba(46,42,38,.28);pointer-events:none;transition:box-shadow .15s;}
.ba-slider .ba-handle::before{content:"\2194";font-size:20px;line-height:1;}
/* corner labels */
.ba-slider .tag{position:absolute;top:14px;z-index:3;background:rgba(46,42,38,.82);color:var(--bone);font-size:11px;letter-spacing:.22em;text-transform:uppercase;padding:8px 16px;border-radius:20px;pointer-events:none;box-shadow:0 2px 8px rgba(46,42,38,.25);}
.ba-slider .tag.before{left:14px;}
.ba-slider .tag.after{right:14px;}
/* invisible native range = the actual drag control (mouse + touch + keyboard) */
.ba-slider .ba-range{position:absolute;inset:0;z-index:5;width:100%;height:100%;margin:0;opacity:0;cursor:ew-resize;-webkit-appearance:none;appearance:none;background:transparent;}
.ba-slider .ba-range::-webkit-slider-thumb{-webkit-appearance:none;width:46px;height:100%;cursor:ew-resize;}
.ba-slider .ba-range::-moz-range-thumb{width:46px;height:100%;border:0;background:transparent;cursor:ew-resize;}
.ba-slider .ba-range:focus-visible{outline:none;}
.ba-slider .ba-range:focus-visible ~ .ba-handle{box-shadow:0 0 0 3px var(--clay),0 4px 14px rgba(46,42,38,.3);}

/* ===== Project: room-by-room tour ===== */
.roomnav{background:var(--oat);text-align:center;}
.roomnav .eyebrow{color:var(--clay);}
.roomnav h2{font-size:clamp(24px,3.4vw,38px);margin:10px 0 0;}
.roomnav-links{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px;}
.roomnav-links a{display:inline-flex;align-items:center;gap:9px;background:var(--bone);color:var(--espresso);border:1px solid rgba(61,50,41,.18);padding:13px 26px;border-radius:30px;text-transform:uppercase;letter-spacing:.16em;font-size:12px;transition:.2s;}
.roomnav-links a::after{content:"\2193";opacity:.45;font-size:13px;}
.roomnav-links a:hover{background:var(--espresso);color:var(--bone);border-color:var(--espresso);}
.room{scroll-margin-top:96px;}
.room-head{max-width:760px;margin:0 auto 30px;text-align:center;}
.room-head h2{font-size:clamp(28px,4vw,46px);margin:10px 0 14px;}
.room-head p{opacity:.86;font-size:15px;}
.room-caption{text-align:center;margin-top:20px;opacity:.7;font-family:'Cormorant',serif;font-style:italic;font-size:18px;}
.room-single{position:relative;max-width:540px;margin:0 auto;border-radius:6px;overflow:hidden;}
.room-single img{width:100%;height:auto;display:block;}
.room-single .tag{position:absolute;top:14px;right:14px;background:rgba(46,42,38,.82);color:var(--bone);font-size:11px;letter-spacing:.22em;text-transform:uppercase;padding:8px 16px;border-radius:20px;box-shadow:0 2px 8px rgba(46,42,38,.25);}
.roomlinks a{border-bottom:1px solid transparent;transition:.2s;}
.roomlinks a:hover{color:var(--clay);border-color:var(--clay);}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;}
.step{padding:30px 18px;border-top:2px solid var(--clay);}
.step .no{font-family:'Cormorant',serif;font-size:42px;color:var(--clay);line-height:1;}
.step h3{font-size:20px;margin:12px 0 8px;}
.step p{font-size:13px;opacity:.8;}
@media(max-width:760px){.steps{grid-template-columns:1fr 1fr;}}

/* process detail rows */
.prow{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;margin-bottom:80px;}
.prow:nth-child(even) .ptext{order:2;}
.prow .pimg{border-radius:8px;overflow:hidden;aspect-ratio:4/3;}
.prow .pimg img{width:100%;height:100%;object-fit:cover;}
.prow .num{font-family:'Cormorant',serif;font-size:46px;color:var(--clay);line-height:1;}
.prow h3{font-size:30px;margin:8px 0 14px;}
.prow p{font-size:15px;opacity:.88;margin-bottom:12px;}
.prow:last-child{margin-bottom:0;}
@media(max-width:760px){.prow{grid-template-columns:1fr;gap:20px;}.prow:nth-child(even) .ptext{order:0;}}

/* "start anywhere" — hire us for any part */
.ways{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:44px;}
.way{background:#fff;border-radius:12px;padding:30px 26px;box-shadow:0 12px 30px rgba(61,50,41,.06);position:relative;}
.way h3{font-size:19px;margin-bottom:10px;}
.way p{font-size:13.5px;opacity:.82;line-height:1.7;}
.way.feature{background:var(--espresso);color:var(--bone);}
.way .pill{position:absolute;top:-11px;left:26px;background:var(--clay);color:var(--bone);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:5px 12px;border-radius:20px;}
@media(max-width:860px){.ways{grid-template-columns:1fr 1fr;}}
@media(max-width:480px){.ways{grid-template-columns:1fr;}}

/* quote */
.quote{background:var(--oat);text-align:center;}
.quote .q{font-family:'Cormorant',serif;font-style:italic;font-size:clamp(24px,3.5vw,38px);line-height:1.4;max-width:880px;margin:0 auto 22px;}
.quote .who{text-transform:uppercase;letter-spacing:.24em;font-size:11px;color:var(--clay);}

/* promise pillars */
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:24px;}
.pillar{background:#fff;border-radius:12px;padding:32px 28px;box-shadow:0 12px 30px rgba(61,50,41,.06);}
.pillar .ico{font-family:'Cormorant',serif;font-style:italic;color:var(--clay);font-size:22px;display:block;margin-bottom:10px;}
.pillar h3{font-size:20px;margin-bottom:10px;}
.pillar p{font-size:13.5px;opacity:.82;line-height:1.7;}

/* pull-quote accent — sprinkle across pages */
.pullquote{text-align:center;}
.pullquote .pq{font-family:'Cormorant',serif;font-style:italic;font-size:clamp(24px,3.6vw,40px);line-height:1.35;max-width:900px;margin:0 auto;color:var(--espresso);}
.pullquote .pq em{color:var(--clay);font-style:italic;}
.pullquote .src{display:block;text-transform:uppercase;letter-spacing:.24em;font-size:11px;color:var(--clay);margin-top:18px;font-family:'Josefin Sans',sans-serif;font-style:normal;}

/* form */
.form{max-width:680px;margin:0 auto;}
.form .field{margin-bottom:22px;}
.form label{display:block;text-transform:uppercase;letter-spacing:.16em;font-size:11px;margin-bottom:8px;color:var(--clay);}
.form input,.form select,.form textarea{width:100%;padding:14px 16px;border:1px solid rgba(61,50,41,.2);background:var(--bone);font-family:inherit;font-size:15px;border-radius:4px;color:var(--espresso);}
.form textarea{min-height:130px;resize:vertical;}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
@media(max-width:600px){.form .two{grid-template-columns:1fr;}}

/* final cta */
.final{position:relative;padding:132px 0;text-align:center;color:var(--bone);background-size:cover;background-position:center;}
.final::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(46,42,38,.58),rgba(46,42,38,.58));}
.final .wrap{position:relative;z-index:2;}
.final h2{font-size:clamp(30px,5vw,52px);margin-bottom:16px;}
.final p{max-width:540px;margin:0 auto 30px;opacity:.92;}

/* footer */
footer{background:var(--mocha);color:var(--bone);padding:64px 0 34px;}
.foot-grid{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;margin-bottom:36px;}
footer .foot-mark{height:78px;width:auto;display:block;margin-bottom:16px;}
footer .fb{font-family:'Noceur',serif;font-size:26px;margin-bottom:6px;}
footer .fsub{font-family:'Cormorant',serif;font-style:italic;opacity:.7;}
footer .col h4{text-transform:uppercase;letter-spacing:.2em;font-size:11px;margin-bottom:14px;opacity:.7;}
footer .col a{display:block;font-size:13px;opacity:.85;margin-bottom:8px;}
footer .col a:hover{opacity:1;color:var(--clay);}
footer .base{border-top:1px solid rgba(247,243,236,.15);padding-top:22px;text-align:center;font-size:11px;letter-spacing:.1em;opacity:.6;}
