/* Y&S Joinery Ltd — warm walnut + oak craft */
:root{
  --walnut:#3a2716;
  --walnut-deep:#251607;
  --oak:#a07744;
  --oak-2:#8b5e2d;
  --gold:#c89149;
  --cream:#f4ecd8;
  --paper:#fdfaf2;
  --paper-2:#f3eada;
  --line:#dccdb1;
  --line-soft:#ebe0c8;
  --ink:#1d140b;
  --ink-soft:#3a2f23;
  --mute:#6a5f4f;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--paper);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--oak-2);text-decoration:none}
a:hover{color:var(--gold)}
.container{width:100%;max-width:1220px;margin:0 auto;padding:0 28px}

/* Header */
.site-header{background:var(--paper);border-bottom:1px solid var(--line-soft);position:sticky;top:0;z-index:50}
.hd{display:flex;align-items:center;justify-content:space-between;min-height:88px;gap:28px}
.bm{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink)}
.bm .mark{display:grid;place-items:center;width:54px;height:54px;background:var(--walnut);color:var(--gold);font-family:'Newsreader',serif;font-weight:600;font-style:italic;font-size:1.5rem;border-radius:50%}
.bm .name{font-family:'Newsreader',serif;font-weight:500;font-size:1.34rem;line-height:1.05;color:var(--walnut-deep);letter-spacing:-.005em}
.bm .name em{color:var(--oak-2);font-style:italic}
.bm .sub{display:block;font-family:'Inter',sans-serif;font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--mute);margin-top:6px;font-weight:600}
.nv{display:flex;list-style:none;gap:2px;margin:0;padding:0}
.nv a{display:inline-block;padding:10px 14px;font-size:.94rem;font-weight:500;color:var(--ink-soft);letter-spacing:.02em;border-radius:3px;white-space:nowrap}
.nv a:hover, .nv a[aria-current]{background:var(--walnut);color:var(--cream);text-decoration:none}
.menu-btn{display:none;background:none;border:0;width:46px;height:42px;cursor:pointer;flex-direction:column;gap:6px;justify-content:center;align-items:center}
.menu-btn span{width:24px;height:2px;background:var(--walnut)}
.mn{display:none;border-top:1px solid var(--line-soft);background:var(--paper)}
.mn.open{display:block}
.mn ul{list-style:none;margin:0;padding:14px 24px}
.mn li a{display:block;padding:12px 0;color:var(--ink);border-bottom:1px solid var(--line-soft);font-size:1rem}

.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;font-family:'Inter',sans-serif;font-weight:600;letter-spacing:.04em;font-size:.96rem;border:0;cursor:pointer;text-decoration:none;border-radius:3px;transition:.18s}
.btn-primary{background:var(--walnut);color:var(--cream)}
.btn-primary:hover{background:var(--walnut-deep);text-decoration:none}
.btn-gold{background:var(--gold);color:var(--walnut-deep)}
.btn-gold:hover{background:#d8a05a;text-decoration:none}
.btn-outline{background:transparent;border:1.5px solid var(--walnut);color:var(--walnut)}
.btn-outline:hover{background:var(--walnut);color:var(--cream);text-decoration:none}

/* Hero */
.hero{position:relative;background:var(--paper)}
.hero-grid{display:grid;grid-template-columns:1fr 1.05fr;min-height:640px;gap:0;border-bottom:1px solid var(--line)}
.hero-copy{padding:96px 60px 96px 0;display:flex;flex-direction:column;justify-content:center}
.hero-copy .est{display:inline-flex;align-items:center;gap:12px;font-family:'Inter',sans-serif;font-size:.74rem;letter-spacing:.32em;text-transform:uppercase;color:var(--oak-2);font-weight:700;margin-bottom:28px}
.hero-copy .est::before{content:"";width:36px;height:1px;background:var(--oak-2)}
.hero-copy h1{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(2.6rem,5.2vw,4.4rem);line-height:1.02;letter-spacing:-.01em;margin:0 0 22px;color:var(--walnut-deep)}
.hero-copy h1 em{font-style:italic;color:var(--oak-2)}
.hero-copy p{font-size:1.1rem;color:var(--ink-soft);max-width:520px;margin:0 0 36px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-photo{position:relative;overflow:hidden;background:var(--walnut-deep)}
.hero-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(37,22,7,.35) 0%,rgba(37,22,7,0) 50%);pointer-events:none}
.hero-stamp{position:absolute;left:30px;bottom:30px;background:var(--cream);color:var(--walnut-deep);padding:18px 26px;border-radius:3px;border-left:4px solid var(--gold);max-width:280px}
.hero-stamp .l{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--oak-2);font-weight:700;margin-bottom:6px}
.hero-stamp .v{font-family:'Newsreader',serif;font-weight:500;font-size:1.34rem;font-style:italic}

/* Strip */
.strip{background:var(--walnut);color:var(--cream);padding:30px 0}
.strip .container{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.strip .item{display:flex;flex-direction:column;align-items:center;gap:6px}
.strip .item .n{font-family:'Newsreader',serif;font-style:italic;font-size:2.2rem;color:var(--gold);line-height:1;font-weight:500}
.strip .item .l{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#cfc1a5}

/* Page hero */
.page-hero{background:var(--cream);border-bottom:1px solid var(--line);padding:88px 0 56px}
.page-hero .crumbs{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:22px}
.page-hero .crumbs a{color:var(--oak-2)}
.page-hero h1{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(2.4rem,4.6vw,3.8rem);line-height:1.04;letter-spacing:-.01em;color:var(--walnut-deep);margin:0 0 18px}
.page-hero h1 em{color:var(--oak-2);font-style:italic}
.page-hero p{max-width:680px;color:var(--ink-soft);font-size:1.08rem;margin:0}

/* Intro */
.intro{padding:104px 0}
.intro-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}
.intro .label{font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--oak-2);font-weight:700;margin-bottom:20px}
.intro h2{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(1.9rem,3.2vw,2.6rem);line-height:1.12;color:var(--walnut-deep);margin:0 0 18px;letter-spacing:-.005em}
.intro h2 em{color:var(--oak-2);font-style:italic}
.intro .body p{margin:0 0 18px;color:var(--ink-soft);font-size:1.04rem;line-height:1.75}

/* Products */
.prod{padding:104px 0;background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.prod h2{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(1.9rem,3.4vw,2.8rem);color:var(--walnut-deep);text-align:center;margin:0 0 14px;letter-spacing:-.005em}
.prod h2 em{color:var(--oak-2);font-style:italic}
.prod .sub{text-align:center;color:var(--ink-soft);max-width:580px;margin:0 auto 56px;font-size:1.06rem}
.prod-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line)}
.prod-card{padding:46px 36px;border-bottom:1px solid var(--line);background:var(--paper);transition:.22s}
.prod-card:hover{background:var(--cream)}
.prod-card:nth-child(odd){border-right:1px solid var(--line)}
.prod-card .num{font-family:'Newsreader',serif;font-style:italic;color:var(--oak-2);font-size:1.1rem;font-weight:500;margin-bottom:14px}
.prod-card h3{font-family:'Newsreader',serif;font-weight:500;font-size:1.6rem;color:var(--walnut-deep);margin:0 0 14px;letter-spacing:-.005em}
.prod-card p{color:var(--ink-soft);margin:0 0 12px;font-size:1.02rem;line-height:1.7}
.prod-card ul{list-style:none;padding:0;margin:14px 0 0;display:flex;flex-wrap:wrap;gap:8px}
.prod-card ul li{font-size:.84rem;padding:5px 12px;background:var(--cream);color:var(--walnut-deep);border-radius:50px;letter-spacing:.04em}

/* Approach */
.approach{padding:112px 0;background:var(--walnut-deep);color:#e6d9b9}
.approach h2{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(2rem,3.4vw,2.8rem);color:#fff;text-align:center;margin:0 0 14px;letter-spacing:-.005em}
.approach h2 em{color:var(--gold);font-style:italic}
.approach .sub{text-align:center;color:#b7a989;max-width:600px;margin:0 auto 60px;font-size:1.04rem}
.approach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px}
.app-cell{}
.app-cell .n{font-family:'Newsreader',serif;font-style:italic;font-size:2.6rem;color:var(--gold);line-height:1;margin-bottom:14px;font-weight:500}
.app-cell h3{font-family:'Newsreader',serif;font-weight:500;font-size:1.24rem;color:#fff;margin:0 0 10px}
.app-cell p{color:#b7a989;font-size:.96rem;margin:0;line-height:1.65}

/* Workshop band */
.workshop{padding:112px 0;background:var(--paper)}
.workshop-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:center}
.workshop .label{font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--oak-2);font-weight:700;margin-bottom:20px}
.workshop h2{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(1.9rem,3.2vw,2.6rem);color:var(--walnut-deep);margin:0 0 22px;letter-spacing:-.005em}
.workshop h2 em{color:var(--oak-2);font-style:italic}
.workshop .body p{margin:0 0 16px;color:var(--ink-soft);font-size:1.04rem;line-height:1.75}
.workshop-side{padding:48px;background:var(--cream);border-radius:3px;border-top:4px solid var(--gold)}
.workshop-side h3{font-family:'Newsreader',serif;font-weight:500;font-style:italic;font-size:1.4rem;color:var(--walnut-deep);margin:0 0 18px}
.workshop-side dl{margin:0}
.workshop-side dt{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--oak-2);font-weight:700;margin-top:18px}
.workshop-side dd{margin:4px 0 0;font-size:1rem;color:var(--walnut-deep)}
.workshop-side dd a{color:var(--walnut-deep);border-bottom:1px solid var(--gold)}

/* Gallery */
.gal{padding:104px 0;background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.gal h2{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(1.9rem,3.4vw,2.8rem);color:var(--walnut-deep);text-align:center;margin:0 0 14px;letter-spacing:-.005em}
.gal h2 em{color:var(--oak-2);font-style:italic}
.gal .sub{text-align:center;color:var(--ink-soft);max-width:600px;margin:0 auto 56px;font-size:1.06rem}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:16px}
.gal-tile{background:var(--cream);border:1px solid var(--line-soft);padding:28px;display:flex;flex-direction:column;justify-content:flex-end;transition:.2s}
.gal-tile:hover{transform:translateY(-2px);border-color:var(--gold)}
.gal-tile.lg{grid-column:span 2;grid-row:span 2}
.gal-tile.gold{background:var(--gold);color:var(--walnut-deep)}
.gal-tile.walnut{background:var(--walnut);color:var(--cream)}
.gal-tile .cat{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;margin-bottom:8px;opacity:.85}
.gal-tile .title{font-family:'Newsreader',serif;font-weight:500;font-style:italic;font-size:1.4rem;letter-spacing:-.005em;line-height:1.2}

/* Find us page */
.findus{padding:96px 0}
.findus-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start}
.findus h2{font-family:'Newsreader',serif;font-weight:500;font-size:1.9rem;color:var(--walnut-deep);margin:0 0 18px}
.findus h2 em{color:var(--oak-2);font-style:italic}
.findus-card{background:var(--cream);padding:36px;border-radius:3px}
.findus-card h3{font-family:'Newsreader',serif;font-weight:500;font-size:1.3rem;color:var(--walnut-deep);margin:0 0 18px}
.findus-card dl{margin:0}
.findus-card dt{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--oak-2);font-weight:700;margin-top:18px}
.findus-card dd{margin:4px 0 0;color:var(--walnut-deep);font-size:1rem}
.findus-map{border-radius:3px;overflow:hidden;border:1px solid var(--line)}
.findus-map iframe{display:block;width:100%;border:0}

/* CTA */
.cta-band{padding:96px 0;background:var(--walnut);color:var(--cream);text-align:center}
.cta-band h2{font-family:'Newsreader',serif;font-weight:500;font-size:clamp(1.9rem,3.4vw,2.8rem);color:#fff;margin:0 0 14px;letter-spacing:-.005em}
.cta-band h2 em{color:var(--gold);font-style:italic}
.cta-band p{max-width:600px;margin:0 auto 36px;color:#cfc1a5;font-size:1.06rem}

/* Contact */
.contact{padding:80px 0 96px}
.c-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:start}
.c-form label{display:block;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--walnut-deep);font-weight:700;margin-bottom:8px}
.c-form input,.c-form textarea,.c-form select{width:100%;padding:14px 16px;background:var(--paper-2);border:1px solid var(--line);border-radius:3px;font-family:inherit;font-size:1rem;color:var(--ink);margin-bottom:18px}
.c-form input:focus,.c-form textarea:focus,.c-form select:focus{outline:none;border-color:var(--oak-2);box-shadow:0 0 0 4px rgba(139,94,45,.12)}
.c-form textarea{min-height:140px;resize:vertical}
.c-form .row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.c-form .row>div{margin-bottom:0}
.c-form .promise{margin-top:14px;font-family:'Newsreader',serif;font-style:italic;color:var(--mute);font-size:1rem}
.c-info h3{font-family:'Newsreader',serif;font-weight:500;font-size:1.6rem;color:var(--walnut-deep);margin:0 0 22px}
.c-info h3 em{color:var(--oak-2);font-style:italic}
.c-info dl{margin:0}
.c-info dt{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--oak-2);font-weight:700;margin-top:18px}
.c-info dd{margin:6px 0 0;font-size:1.04rem;color:var(--walnut-deep)}
.c-info dd a{color:var(--walnut-deep);border-bottom:1px solid var(--gold)}
.c-map{margin-top:32px;border:1px solid var(--line);border-radius:3px;overflow:hidden}
.c-map iframe{display:block;width:100%;border:0}

/* Footer */
.site-footer{background:var(--walnut-deep);color:#a39581;padding:64px 0 24px}
.fg{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.foot-mark{font-family:'Newsreader',serif;font-weight:500;font-size:1.4rem;color:#fff}
.foot-mark em{color:var(--gold);font-style:italic}
.foot-tag{font-size:.66rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-top:6px}
.site-footer h4{font-family:'Newsreader',serif;font-style:italic;font-weight:500;font-size:1.1rem;color:#fff;margin:0 0 16px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{padding:5px 0;font-size:.94rem}
.site-footer ul li a{color:#a39581}
.site-footer ul li a:hover{color:var(--gold);text-decoration:none}
.foot-bottom{display:flex;justify-content:space-between;font-size:.82rem;color:#766b58;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);flex-wrap:wrap;gap:8px}

@media (max-width:1180px){
  .nv{display:none}
  .menu-btn{display:flex}
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-copy{padding:64px 0}
  .hero-photo{height:360px}
  .strip .container{grid-template-columns:1fr 1fr;gap:24px}
  .intro-grid{grid-template-columns:1fr;gap:40px}
  .prod-grid{grid-template-columns:1fr}
  .prod-card:nth-child(odd){border-right:0}
  .approach-grid{grid-template-columns:1fr 1fr}
  .workshop-grid{grid-template-columns:1fr;gap:40px}
  .findus-grid{grid-template-columns:1fr;gap:32px}
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:200px}
  .gal-tile.lg{grid-column:span 2;grid-row:span 1}
  .c-grid{grid-template-columns:1fr;gap:48px}
  .fg{grid-template-columns:1fr 1fr;gap:32px}
}
@media (max-width:640px){
  .container{padding:0 22px}
  .strip .container{grid-template-columns:1fr;gap:18px}
  .approach-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr;grid-auto-rows:200px}
  .gal-tile.lg{grid-column:span 1}
  .c-form .row{grid-template-columns:1fr;gap:0}
  .fg{grid-template-columns:1fr}
}
