/* ===========================================================
   The Timber Residence
   Display: Fraunces (warm old-style serif, craft character)
   Body/UI: DM Sans
   Palette: warm stone paper, near-black ink, taupe, bronze rule
   Photography carries colour; type stays quiet.
   =========================================================== */

:root{
  --paper:#F7F4EF;
  --paper-2:#F1ECE3;
  --ink:#1C1A17;
  --taupe:#6B655C;
  --hair:#DDD5C8;
  --bronze:#9A7B4F;
  --maxw:1240px;
  --narrow:760px;
  --pad:24px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:"DM Sans",-apple-system,Helvetica,Arial,sans-serif;
  font-size:17px;
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;width:100%;height:auto}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--bronze);outline-offset:3px}

.display{
  font-family:"Fraunces",Georgia,serif;
  font-weight:360;
  font-optical-sizing:auto;
  letter-spacing:-.01em;
}

/* ---- shared layout ---- */
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.wrap.narrow{max-width:var(--narrow)}
.band{padding:84px 0}
.eyebrow{
  margin:0 0 26px;
  font-size:12px;
  font-weight:500;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--taupe);
}
.eyebrow.light{color:rgba(255,255,255,.94)}
.rule{width:64px;height:1px;background:var(--bronze);margin:0 0 30px}
h2.display{margin:0;font-size:30px;line-height:1.18}
.lead{font-size:21px;line-height:1.6;color:var(--ink)}
p{margin:0 0 22px}
p:last-child{margin-bottom:0}

/* ---- masthead ---- */
.masthead{
  position:sticky;top:0;z-index:30;
  height:62px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--pad);
  background:rgba(247,244,239,.86);
  border-bottom:1px solid var(--hair);
  backdrop-filter:blur(10px);
}
.wordmark{
  font-family:"Fraunces",Georgia,serif;
  font-weight:420;
  font-size:18px;
  letter-spacing:.01em;
}
.menu-button{
  display:flex;flex-direction:column;gap:6px;justify-content:center;
  width:40px;height:40px;border:0;background:transparent;cursor:pointer;padding:0;
}
.menu-button span{display:block;width:24px;height:1.5px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s}
.menu-button[aria-expanded="true"] span:first-child{transform:translateY(3.75px) rotate(45deg)}
.menu-button[aria-expanded="true"] span:last-child{transform:translateY(-3.75px) rotate(-45deg)}
.nav{
  position:fixed;left:0;right:0;top:62px;
  display:none;flex-direction:column;
  background:var(--paper);border-bottom:1px solid var(--hair);
  padding:8px var(--pad) 18px;
}
.nav.open{display:flex}
.nav a{
  padding:14px 0;font-size:13px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--taupe);border-bottom:1px solid var(--hair);
}
.nav a:last-child{border-bottom:0}

/* ---- hero ---- */
.hero{position:relative;height:92vh;min-height:560px;max-height:920px;background:#100f0d;overflow:hidden}
.hero picture,.hero img{position:absolute;inset:0;height:100%}
.hero img{object-fit:cover;object-position:center 60%}
.hero-veil{position:absolute;inset:0;background:linear-gradient(180deg,
  rgba(10,10,13,.42) 0%,
  rgba(10,10,13,.04) 24%,
  rgba(10,10,13,.10) 46%,
  rgba(10,10,13,.40) 64%,
  rgba(10,10,13,.72) 82%,
  rgba(10,10,13,.92) 100%)}
.hero-text{
  position:absolute;left:0;right:0;bottom:0;
  padding:0 var(--pad) clamp(40px,9vh,90px);
  max-width:var(--maxw);margin:0 auto;color:#fff;
  text-shadow:0 1px 30px rgba(0,0,0,.40);
}
.hero-text h1{
  font-family:"Fraunces",Georgia,serif;font-weight:300;font-optical-sizing:auto;
  margin:0 0 18px;font-size:clamp(48px,13vw,108px);line-height:.94;letter-spacing:.005em;
}
.hero-text h1 .at{
  display:block;font-size:.42em;font-weight:360;font-style:italic;
  letter-spacing:.005em;margin-top:.18em;color:rgba(255,255,255,.92);
}
.wordmark span{font-style:italic;font-weight:360}
.hero-sub{margin:0;font-size:16px;color:rgba(255,255,255,.9);max-width:30ch}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);width:26px;height:42px}
.scroll-cue span{position:absolute;inset:0;border:1px solid rgba(255,255,255,.55);border-radius:13px}
.scroll-cue span::after{
  content:"";position:absolute;left:50%;top:8px;width:2px;height:7px;border-radius:2px;
  background:rgba(255,255,255,.85);transform:translateX(-50%);animation:cue 1.8s var(--ease) infinite;
}
@keyframes cue{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}100%{opacity:0;transform:translate(-50%,12px)}}

/* ---- overview ---- */
.overview{padding-top:92px}
.overview .lead{margin-bottom:26px}

/* ---- full bleed images ---- */
.bleed{margin:0}
.bleed img{height:clamp(320px,62vh,640px);object-fit:cover}
.bleed.tall img{height:clamp(420px,82vh,860px)}

/* ---- at a glance ---- */
/* ---- sale details + spec badges (Oliver Road-inspired) ---- */
.residence{background:var(--paper-2);border-block:1px solid var(--hair)}
.sale{display:flex;flex-direction:column;gap:30px;padding-bottom:18px;margin-bottom:60px;border-bottom:1px solid var(--hair)}
.price{font-size:34px;line-height:1;margin:0}
.sale-list{margin:0;display:grid;gap:0}
.sale-list div{display:grid;grid-template-columns:120px 1fr;gap:14px;padding:9px 0}
.sale-list dt{margin:0;color:var(--taupe);font-size:15px;letter-spacing:.02em}
.sale-list dd{margin:0;font-size:16px}

.spec-badges{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);gap:46px 12px;text-align:center}
.spec-badges li{display:flex;flex-direction:column;align-items:center;gap:12px}
.badge{width:82px;height:82px;border-radius:50%;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center}
.badge svg{width:38px;height:38px}
.spec-badges b{font-size:30px;font-weight:360;line-height:1;letter-spacing:0}
.spec-badges li>span:last-child{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--taupe);line-height:1.4}

.dl-row{margin-top:62px}
.btn-wide{
  display:block;width:100%;text-align:center;
  border:1px solid var(--ink);border-radius:2px;
  padding:21px 18px;font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink);
  transition:background .25s,color .25s
}
.btn-wide:hover{background:var(--ink);color:var(--paper)}

/* ---- editorial ---- */
.editorial h2{margin-bottom:22px}

/* ---- gallery ---- */
.gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gallery-grid button{padding:0;border:0;background:none;cursor:pointer;overflow:hidden}
.gallery-grid img{height:210px;object-fit:cover;transition:transform .9s var(--ease)}
.gallery-grid button:hover img{transform:scale(1.045)}

/* ---- specifications ---- */
.accordion{border-top:1px solid var(--ink)}
.acc-row{border-bottom:1px solid var(--ink)}
.acc-row>button{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:24px 2px;border:0;background:transparent;color:var(--ink);cursor:pointer;
  font-family:"Fraunces",Georgia,serif;font-size:20px;font-weight:360;text-align:left;
}
.acc-row>button i{position:relative;width:15px;height:15px;flex:none}
.acc-row>button i::before,.acc-row>button i::after{
  content:"";position:absolute;background:var(--bronze);transition:transform .35s var(--ease),opacity .35s
}
.acc-row>button i::before{left:0;top:7px;width:15px;height:1.5px}
.acc-row>button i::after{left:7px;top:0;width:1.5px;height:15px}
.acc-row.open>button i::after{transform:scaleY(0)}
.panel{max-height:0;overflow:hidden;transition:max-height .42s var(--ease)}
.panel>*:first-child{margin-top:2px}
.panel>*:last-child{margin-bottom:26px}
.spec-list{margin:0;display:grid;gap:0}
.spec-list div{display:grid;grid-template-columns:42% 1fr;gap:14px;padding:11px 0;border-bottom:1px solid var(--hair)}
.spec-list div:last-child{border-bottom:0}
.spec-list dt{margin:0;color:var(--taupe);font-size:15px}
.spec-list dd{margin:0;font-size:16px}
.panel-note{color:var(--taupe);font-size:14px;margin:4px 0 16px}
.plain-list{margin:0;padding:0;list-style:none}
.plain-list li{padding:9px 0;border-bottom:1px solid var(--hair);font-size:16px}
.plain-list li:last-child{border-bottom:0}

/* ---- setting / map ---- */
.setting .wrap+.wrap{margin-top:30px}
.map-frame{height:360px;border:1px solid var(--hair);overflow:hidden;background:var(--paper-2)}
.map-frame iframe{width:100%;height:100%;border:0;filter:grayscale(.25) contrast(.96)}
.map-caption{margin:14px 0 0;color:var(--taupe);font-size:13.5px}

/* ---- enquire / form ---- */
.enquire{background:var(--paper-2);border-top:1px solid var(--hair)}
.enquire-intro{color:var(--taupe);margin-bottom:32px;max-width:52ch}
form{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
label{font-size:13px;letter-spacing:.06em;color:var(--taupe)}
label em{font-style:normal;opacity:.8}
input,select,textarea{
  width:100%;font:inherit;font-size:16px;color:var(--ink);
  background:var(--paper);border:1px solid var(--hair);border-radius:2px;
  padding:13px 14px;transition:border-color .2s
}
input:focus,select:focus,textarea:focus{border-color:var(--ink);outline:none}
textarea{resize:vertical;min-height:84px}
select{appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,var(--ink) 50%),linear-gradient(135deg,var(--ink) 50%,transparent 50%);
  background-position:calc(100% - 20px) center,calc(100% - 14px) center;
  background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:40px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.btn{
  grid-column:1/-1;justify-self:start;margin-top:4px;
  border:1px solid var(--ink);background:var(--ink);color:var(--paper);
  font-family:"DM Sans",sans-serif;font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  padding:15px 30px;border-radius:2px;cursor:pointer;transition:background .25s,color .25s
}
.btn:hover{background:transparent;color:var(--ink)}
.btn:disabled{opacity:.55;cursor:default}
.form-status{grid-column:1/-1;margin:6px 0 0;font-size:15px;min-height:1.2em}
.form-status.ok{color:var(--ink)}
.form-status.err{color:#9a3a2a}

/* ---- footer ---- */
.footer{background:var(--ink);color:var(--paper);padding:72px 0}
.foot-mark{font-size:26px;margin:0 0 12px;color:var(--paper)}
.foot-line{margin:0 0 22px;color:rgba(247,244,239,.66);font-size:15px;letter-spacing:.02em}
.foot-contact{display:flex;gap:14px;align-items:center;margin:0 0 28px;font-size:14px;letter-spacing:.14em;text-transform:uppercase}
.foot-contact span{color:rgba(247,244,239,.4)}
.foot-contact a{padding-bottom:3px;border-bottom:1px solid rgba(247,244,239,.4)}
.foot-fine{margin:0;color:rgba(247,244,239,.42);font-size:12.5px;max-width:54ch;line-height:1.6}

/* ---- lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;
  background:rgba(16,15,13,.95);padding:clamp(16px,5vw,64px)}
.lightbox[hidden]{display:none}
.lightbox img{max-width:100%;max-height:88vh;width:auto;object-fit:contain}
.lightbox button{position:absolute;border:0;background:transparent;color:#fff;cursor:pointer}
.lb-close{top:18px;right:20px;font-size:34px;line-height:1;width:46px;height:46px}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);font-size:46px;width:60px;height:60px;opacity:.8}
.lb-prev{left:6px}.lb-next{right:6px}
.lb-prev:hover,.lb-next:hover{opacity:1}

/* ---- reveal animation ---- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---- desktop ---- */
@media (min-width:860px){
  body{font-size:18px}
  .band{padding:120px 0}
  .masthead{height:74px;padding:0 40px}
  .wordmark{font-size:21px}
  .menu-button{display:none}
  .nav{position:static;display:flex;flex-direction:row;gap:34px;padding:0;border:0;background:transparent}
  .nav a{padding:0;border:0;font-size:12px}
  .eyebrow{margin-bottom:34px}
  h2.display{font-size:44px;line-height:1.1}
  .lead{font-size:25px}
  .price{font-size:46px}
  .sale{flex-direction:row;justify-content:space-between;align-items:flex-end;gap:60px;padding-bottom:30px}
  .sale-list div{grid-template-columns:130px 1fr}
  .spec-badges{grid-template-columns:repeat(6,1fr);gap:24px}
  .badge{width:94px;height:94px}
  .badge svg{width:42px;height:42px}
  .spec-badges b{font-size:34px}
  .gallery-grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .gallery-grid img{height:340px}
  .acc-row>button{font-size:24px;padding:30px 2px}
  .spec-list div{grid-template-columns:32% 1fr}
  .map-frame{height:460px}
  .foot-mark{font-size:34px}
}

@media (min-width:1100px){
  .overview .wrap.narrow,.editorial .wrap.narrow,.specs .wrap.narrow,
  .setting .wrap.narrow,.enquire .wrap.narrow{max-width:860px}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .scroll-cue span::after{animation:none}
  .gallery-grid img{transition:none}
}
