/* ============================================================
   Taylor & Taylor Designs — "Warm Luxury" design system
   Shared stylesheet for all pages
   ============================================================ */
:root{
  --ivory:#FAF6F0;
  --sand:#F0E9DF;
  --sand-deep:#E7DDCF;
  --ink:#2B2724;
  --stone:#6F665C;
  --brass:#A6814C;
  --brass-deep:#8C6A39;
  --line:#D8CCBC;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',-apple-system,Segoe UI,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ivory);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  font-size:17px;
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
.eyebrow{
  font-family:var(--sans);font-weight:400;font-size:12px;
  letter-spacing:.32em;text-transform:uppercase;color:var(--brass);
}
h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.08;letter-spacing:.01em}
h1{font-size:clamp(46px,7vw,92px)}
h2{font-size:clamp(34px,4.4vw,58px)}
h3{font-size:24px;font-weight:400}
p{color:var(--stone);font-weight:300}
.btn{
  display:inline-block;font-family:var(--sans);font-size:12px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ink);
  padding-bottom:6px;border-bottom:1px solid var(--brass);
  transition:color .4s,border-color .4s,letter-spacing .4s;cursor:pointer;
}
.btn:hover{color:var(--brass);letter-spacing:.3em}
/* disabled / deactivated link */
.btn.is-disabled{color:var(--stone);border-color:var(--line);cursor:default;pointer-events:none;opacity:.7}

/* ---- top bar ---- */
.topbar{background:var(--ink);color:#CFC6B9;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px}
.topbar .tagline{color:var(--brass);font-weight:400}
.topbar .meta{display:flex;gap:30px}
.topbar .meta a:hover{color:#fff}
@media(max-width:820px){.topbar .meta{display:none}}

/* ---- nav ---- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(250,246,240,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;justify-content:space-between;align-items:center;height:88px}
.brand{font-family:var(--serif);font-size:27px;letter-spacing:.04em;color:var(--ink)}
.brand .amp{color:var(--brass);font-style:italic}
.brand small{display:block;font-family:var(--sans);font-size:9.5px;letter-spacing:.45em;color:var(--stone);text-transform:uppercase;margin-top:2px}
nav ul{display:flex;gap:42px;list-style:none}
nav a{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);position:relative;padding:4px 0}
nav a::after{content:'';position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--brass);transition:width .4s}
nav a:hover::after,nav a.active::after{width:100%}
nav a.active{color:var(--brass)}
/* hamburger toggle */
.nav-toggle{display:none;background:none;border:none;width:28px;height:20px;position:relative;cursor:pointer;padding:0;z-index:60}
.nav-toggle span{display:block;position:absolute;left:0;width:100%;height:1.5px;background:var(--ink);transition:transform .3s,opacity .3s,top .3s,bottom .3s}
.nav-toggle span:nth-child(1){top:0}
.nav-toggle span:nth-child(2){top:50%;transform:translateY(-50%)}
.nav-toggle span:nth-child(3){bottom:0}
.nav.open .nav-toggle span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.nav.open .nav-toggle span:nth-child(2){opacity:0}
.nav.open .nav-toggle span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}
@media(max-width:820px){
  .nav .wrap{height:72px}
  .nav-toggle{display:block}
  nav{position:absolute;top:100%;left:0;width:100%;background:rgba(250,246,240,.98);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);max-height:0;overflow:hidden;transition:max-height .4s ease}
  .nav.open nav{max-height:480px}
  nav ul{flex-direction:column;gap:0;padding:6px 40px 22px}
  nav li{border-bottom:1px solid var(--line)}
  nav li:last-child{border-bottom:none}
  nav a{display:block;padding:18px 2px;font-size:14px}
  nav a::after{display:none}
}

/* ---- hero ---- */
.hero{position:relative;height:90vh;min-height:600px;overflow:hidden}
.hero img{position:absolute;inset:0;transform:scale(1.04)}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(43,39,36,.47) 0%,rgba(43,39,36,.55) 45%,rgba(43,39,36,.61) 100%)}
.hero .inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--ivory);padding:0 24px}
.hero .eyebrow{color:#E8D8BC;font-size:13px;text-shadow:0 1px 12px rgba(0,0,0,.45)}
.hero h1{color:var(--ivory);margin:22px 0 0;text-shadow:0 2px 30px rgba(0,0,0,.25)}
.hero .lead{color:#EDE6DB;max-width:560px;margin:26px auto 34px;font-size:20px;text-shadow:0 1px 12px rgba(0,0,0,.45)}
.hero .btn{color:var(--ivory);border-color:#E8D8BC;font-size:13px;text-shadow:0 1px 12px rgba(0,0,0,.45)}
.hero .btn:hover{color:#E8D8BC}

/* ---- page header (interior pages) ---- */
.pagehead{position:relative;height:54vh;min-height:380px;overflow:hidden}
.pagehead img{position:absolute;inset:0;transform:scale(1.03)}
.pagehead::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(43,39,36,.28),rgba(43,39,36,.55))}
.pagehead .inner{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--ivory)}
.pagehead .eyebrow{color:#E8D8BC;margin-bottom:16px}
.pagehead h1{color:var(--ivory);font-size:clamp(40px,6vw,76px)}

/* ---- sections ---- */
section{padding:120px 0}
.intro{text-align:center}
.intro .eyebrow{display:block;margin-bottom:24px}
.intro h2{max-width:880px;margin:0 auto 30px}
.intro p{max-width:620px;margin:0 auto 18px}
.lede{max-width:780px;margin:0 auto;text-align:center}
.lede p{margin-bottom:20px;font-size:18px}

/* ---- feature rows ---- */
.feature{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;background:var(--ivory)}
.feature.sand{background:var(--sand)}
.feature .media{height:640px;overflow:hidden}
.feature .media img{transition:transform 1.2s ease}
.feature:hover .media img{transform:scale(1.05)}
.feature .text{display:flex;flex-direction:column;justify-content:center;padding:0 clamp(40px,6vw,96px)}
.feature .num{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--brass);margin-bottom:14px}
.feature .text h2{margin:10px 0 24px}
.feature .text p{margin-bottom:18px}
.feature .text .btn{margin-top:18px;align-self:flex-start}
.feature.alt .media{order:2}
@media(max-width:880px){.feature{grid-template-columns:1fr}.feature .media{height:380px;order:0!important}.feature .text{padding:56px 32px}}

/* ---- showroom band ---- */
.showroom{position:relative;padding:160px 0;text-align:center;color:var(--ivory);overflow:hidden}
.showroom img{position:absolute;inset:0}
.showroom::after{content:'';position:absolute;inset:0;background:rgba(43,39,36,.62)}
.showroom .inner{position:relative;z-index:2}
.showroom h2{color:var(--ivory);margin:18px 0 30px}
.showroom .eyebrow{color:#E8D8BC}
.showroom .btn{color:var(--ivory);border-color:#E8D8BC}
.showroom .btn.is-disabled{color:#cfc6b9;border-color:rgba(255,255,255,.35)}

/* ---- gallery ---- */
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:28px;max-width:1100px;margin:0 auto}
.gallery figure{overflow:hidden;background:var(--sand-deep)}
.gallery figure{aspect-ratio:3/2}
.gallery img{transition:transform 1.1s ease}
.gallery figure:hover img{transform:scale(1.05)}
@media(max-width:760px){.gallery{grid-template-columns:1fr;gap:18px}}

/* ---- team ---- */
.team{background:var(--sand)}
.team .head{text-align:center;margin-bottom:72px}
.team .head .eyebrow{display:block;margin-bottom:18px}
.member{display:grid;grid-template-columns:380px 1fr;gap:60px;align-items:center;max-width:1040px;margin:0 auto 80px}
.member:last-child{margin-bottom:0}
.member.alt{grid-template-columns:1fr 380px}
.member.alt .portrait{order:2}
.member .portrait{height:460px;overflow:hidden;background:var(--sand-deep)}
.member .role{display:block;margin-bottom:12px}
.member h3{font-size:30px;margin-bottom:18px}
.member p{margin-bottom:16px}
@media(max-width:820px){.member,.member.alt{grid-template-columns:1fr;gap:30px}.member.alt .portrait{order:0}.member .portrait{height:420px}}

/* ---- news ---- */
.news{background:var(--sand)}
.news .head{text-align:center;margin-bottom:70px}
.news .head .eyebrow{display:block;margin-bottom:18px}
.news .grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;max-width:980px;margin:0 auto}
.card .ph{height:420px;overflow:hidden;margin-bottom:28px;background:var(--sand-deep)}
.card .ph img{transition:transform 1s ease}
.card:hover .ph img{transform:scale(1.04)}
.card .eyebrow{display:block;margin-bottom:10px}
.card h3{margin-bottom:12px}
@media(max-width:880px){.news .grid{grid-template-columns:1fr;gap:48px}}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;max-width:1100px;margin:0 auto;align-items:start}
.contact-info .eyebrow{display:block;margin-bottom:8px;margin-top:34px}
.contact-info .eyebrow:first-child{margin-top:0}
.contact-info .big{font-family:var(--serif);font-size:24px;color:var(--ink);line-height:1.4}
.contact-info a:hover{color:var(--brass)}
.contact-info .social{display:flex;gap:24px;margin-top:14px;text-transform:uppercase;letter-spacing:.16em;font-size:12px}
.contact-info .social a:hover{color:var(--brass)}
form .field{margin-bottom:26px}
form label{display:block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);margin-bottom:10px}
form input,form textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);padding:10px 0;font-family:var(--sans);font-size:16px;color:var(--ink);font-weight:300}
form input:focus,form textarea:focus{outline:none;border-color:var(--brass)}
form textarea{resize:vertical;min-height:120px}
form button{margin-top:10px;background:var(--ink);color:var(--ivory);border:none;padding:16px 42px;font-family:var(--sans);font-size:12px;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;transition:background .4s,letter-spacing .4s}
form button:hover{background:var(--brass-deep);letter-spacing:.3em}
.form-success{border:1px solid var(--brass);background:var(--sand);padding:48px 40px;text-align:center}
.form-success h3{font-size:30px;margin-bottom:10px}
.form-success p{font-size:16px}
.map{margin-top:80px;height:420px;overflow:hidden;border:1px solid var(--line)}
.map iframe{width:100%;height:100%;border:0;filter:grayscale(.25) contrast(1.02)}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:48px}}

/* ---- footer ---- */
footer{background:var(--ink);color:#B8AE9F;padding:80px 0 40px}
footer .top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
footer .brand{color:var(--ivory)}
footer .brand small{color:#9b9182}
footer .cols{display:flex;gap:80px;flex-wrap:wrap}
footer h4{font-family:var(--sans);font-weight:400;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);margin-bottom:18px}
footer .cols p,footer .cols a{color:#B8AE9F;font-size:14px;line-height:1.9}
footer .cols a:hover{color:#fff}
footer .bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding-top:28px;font-size:12px;letter-spacing:.1em;color:#8c8273}
footer .social{display:flex;gap:26px;text-transform:uppercase;letter-spacing:.16em}
footer .social a:hover{color:var(--brass)}

/* ---- showroom ---- */
.filterbar{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;max-width:900px;margin:0 auto 26px}
.filter-btn{font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--stone);background:none;border:1px solid var(--line);padding:12px 22px;cursor:pointer;transition:color .35s,border-color .35s,background .35s}
.filter-btn:hover{color:var(--ink);border-color:var(--brass)}
.filter-btn.active{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.shop-count{text-align:center;color:var(--stone);font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:54px}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 32px;max-width:1180px;margin:0 auto}
.shop-card{display:flex;flex-direction:column}
.shop-thumb{aspect-ratio:4/3;background:var(--sand-deep);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:20px}
.shop-thumb .ic{width:60px;height:60px;color:var(--brass);opacity:.9;transition:transform .6s ease}
.shop-card:hover .shop-thumb .ic{transform:scale(1.1)}
.shop-card .cat-tag{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--brass);margin-bottom:8px}
.shop-card h3{font-size:21px;line-height:1.2;margin-bottom:8px}
.shop-card .desc{font-size:14px;color:var(--stone);margin-bottom:14px;flex:1}
.shop-card .price{font-family:var(--serif);font-size:22px;color:var(--ink)}
@media(max-width:900px){.shop-grid{grid-template-columns:repeat(2,1fr);gap:40px 24px}}
@media(max-width:560px){.shop-grid{grid-template-columns:1fr}}

/* ---- scroll reveal ---- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s ease,transform 1s ease}
.reveal.in{opacity:1;transform:none}
