/* =========================================================
   Tiltwood Furniture — site styles
   ========================================================= */

:root{
  --paper:#f3ecdc;
  --paper-2:#ebe2cc;
  --paper-3:#e1d5b8;
  --ink:#1c1814;
  --ink-soft:#3a322a;
  --ink-mute:#6a5e4d;
  --rule:#1c1814;
  --rule-soft:#c9bda0;
  --accent:#6b5a3e;          /* warm walnut */
  --moss:#384a2e;            /* deep moss for accent */
  --serif:"Cormorant Garamond", "Times New Roman", serif;
  --display:"Cormorant Garamond", "Times New Roman", serif;
  --sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --gutter: clamp(20px, 4vw, 64px);
  --maxw: 1280px;
}

*{box-sizing:border-box}
html,body{margin:0; padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
p{margin:0 0 1em; max-width:64ch; text-wrap:pretty}
ul{margin:0 0 1em; padding-left:1.1em}
li{margin:.25em 0; max-width:62ch}

/* ============== Type ============== */
h1,h2,h3,h4{font-family:var(--serif); font-weight:500; letter-spacing:-.005em; margin:0 0 .4em; line-height:1.1}
h1{font-size:clamp(40px, 6.4vw, 84px); font-weight:500; line-height:1.02; letter-spacing:-.012em}
h1 em{font-style:italic; color:var(--accent)}
h2{font-size:clamp(30px, 4.2vw, 52px); line-height:1.06}
h3{font-size:clamp(22px, 2.4vw, 30px); line-height:1.2}
h4{font-size:18px; font-weight:600}
.kicker{font-family:var(--sans); font-weight:600; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--accent)}
.subhead{font-family:var(--serif); font-style:italic; font-size:clamp(18px, 1.6vw, 22px); color:var(--ink-soft); line-height:1.45}
.lead{font-size:clamp(17px,1.5vw,20px); line-height:1.55; max-width:60ch; color:var(--ink-soft)}

/* ============== Layout ============== */
.container{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter)}
section{padding:clamp(60px, 9vw, 130px) 0}
section.tight{padding:clamp(40px, 6vw, 80px) 0}
.divider{border:none; border-top:1px solid var(--rule-soft); margin:0}
.row{display:grid; gap:48px}
.row.cols-2{grid-template-columns:repeat(2, minmax(0,1fr))}
.row.cols-3{grid-template-columns:repeat(3, minmax(0,1fr))}
.row.cols-4{grid-template-columns:repeat(4, minmax(0,1fr))}
@media (max-width: 880px){
  .row.cols-2,.row.cols-3,.row.cols-4{grid-template-columns:1fr}
}

/* ============== Header ============== */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(243,236,220,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--rule-soft);
}
.site-header .inner{
  max-width:var(--maxw); margin:0 auto;
  padding:14px var(--gutter);
  display:flex; align-items:center; gap:24px;
}
.brand{display:flex; align-items:center; gap:12px}
.brand img{width:42px; height:42px; object-fit:contain}
.brand-name{font-family:var(--serif); font-size:22px; line-height:1; color:var(--ink); letter-spacing:.005em}
.brand-name span{display:block; font-size:11px; letter-spacing:.32em; text-transform:uppercase; color:var(--ink-mute); margin-top:3px; font-family:var(--sans); font-weight:500}
.site-header nav{margin-left:auto; display:flex; gap:30px; align-items:center; font-size:14px}
.site-header nav a{color:var(--ink-soft); position:relative; padding:6px 0}
.site-header nav a:hover{color:var(--ink)}
.site-header nav a.active{color:var(--ink)}
.site-header nav a.active::after{content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px; background:var(--ink)}
.site-header nav a.cta-link{
  padding:10px 18px; border:1px solid var(--ink); border-radius:999px; color:var(--ink);
  transition:background .2s, color .2s;
}
.site-header nav a.cta-link:hover{background:var(--ink); color:var(--paper)}
@media (max-width: 720px){
  .site-header nav{gap:14px; font-size:13px}
  .site-header nav a:not(.cta-link){display:none}
  .brand-name span{display:none}
}

body.home-page .site-header{
  position:absolute;
  left:0;
  right:0;
  top:0;
  width:100%;
  background:transparent;
  border-bottom:none;
  backdrop-filter:none;
}
body.home-page .site-header .inner{
  max-width:1540px;
  padding:34px clamp(28px, 7vw, 120px);
  display:grid;
  grid-template-columns:minmax(118px, 180px) 1fr minmax(118px, 180px);
  align-items:start;
}
body.home-page .site-header .inner::after{
  content:"";
  width:150px;
  height:1px;
}
body.home-page .brand{justify-self:start}
body.home-page .brand img{
  width:150px;
  height:150px;
  object-fit:contain;
}
body.home-page .brand-name{display:none}
body.home-page .site-header nav{
  margin-left:0;
  justify-self:center;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:clamp(30px, 4vw, 64px);
  padding-top:52px;
  font-size:clamp(17px, 1.25vw, 22px);
  font-weight:600;
  line-height:1;
}
body.home-page .site-header nav a{
  color:#232633;
  padding:0;
}
body.home-page .site-header nav a.active::after{display:none}
body.home-page .site-header nav a.cta-link{
  border:0;
  border-radius:0;
  padding:0;
  color:#232633;
}
body.home-page .site-header nav a.cta-link:hover{
  background:transparent;
  color:var(--accent);
}
@media (max-width: 900px){
  body.home-page .site-header .inner{
    padding:22px var(--gutter);
    display:flex;
    align-items:center;
  }
  body.home-page .site-header .inner::after{display:none}
  body.home-page .brand img{width:86px; height:86px}
  body.home-page .site-header nav{
    padding-top:0;
    margin-left:auto;
    gap:18px;
    font-size:14px;
  }
}
@media (max-width: 620px){
  body.home-page .site-header nav a:not(.cta-link){display:none}
}

/* ============== Buttons / CTAs ============== */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 24px; border-radius:999px;
  font-family:var(--sans); font-weight:600; font-size:14px; letter-spacing:.02em;
  border:1px solid var(--ink); background:transparent; color:var(--ink);
  cursor:pointer; transition:background .2s, color .2s, transform .2s;
}
.btn:hover{transform:translateY(-1px)}
.btn.primary{background:var(--ink); color:var(--paper)}
.btn.primary:hover{background:#000}
.btn.ghost:hover{background:var(--paper-2)}
.btn .arrow{transition:transform .25s}
.btn:hover .arrow{transform:translateX(3px)}

.cta-row{display:flex; flex-wrap:wrap; gap:14px; margin-top:24px}

/* ============== Hero ============== */
.hero{
  padding:clamp(60px, 8vw, 110px) 0 clamp(40px, 6vw, 80px);
  position:relative;
}
.hero .grid{
  display:grid; grid-template-columns: 1.05fr .95fr; gap:64px; align-items:center;
}
@media (max-width:980px){ .hero .grid{grid-template-columns:1fr; gap:32px} }
.hero h1{margin-top:24px}
.hero .lead{margin-top:24px}
.hero-figure{
  aspect-ratio: 4/5;
  background:
    linear-gradient(180deg, rgba(28,24,20,.02), rgba(28,24,20,.12)),
    url("assets/hero-dining-table.jpg") center / cover no-repeat;
  position:relative; overflow:hidden; border-radius:2px;
  box-shadow: 0 30px 60px -30px rgba(28,24,20,.5);
}
.hero-figure::after{
  content:"Project photo"; position:absolute; left:18px; bottom:18px;
  font-family:var(--sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(243,236,220,.7); padding:5px 10px;
  background:rgba(0,0,0,.25); border:1px solid rgba(243,236,220,.18); border-radius:2px;
}
.hero-figure .caption{
  position:absolute; left:18px; right:18px; top:18px;
  font-family:var(--serif); font-style:italic; font-size:18px; color:rgba(243,236,220,.92);
  line-height:1.3;
}

.home-hero{
  min-height:clamp(1500px, 180svh, 1700px);
  padding:0;
  display:flex;
  align-items:flex-start;
  justify-content:center;
  overflow:hidden;
  border-bottom:1px solid var(--rule-soft);
  background:
    linear-gradient(180deg, rgba(245,246,246,.16) 0%, rgba(245,246,246,.08) 52%, rgba(245,246,246,.04) 100%),
    url("assets/slab-table-hero.webp") center bottom / 100% auto no-repeat;
}
.home-hero::after{content:none}
@media (min-width: 1920px){
  .home-hero{
    background-size:1920px auto;
  }
}
.home-hero .hero-copy{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:clamp(175px, 22vh, 260px) var(--gutter) 0;
  text-align:center;
  position:relative;
  z-index:1;
}
.home-hero .kicker{
  color:#5c6471;
  letter-spacing:.2em;
}
.home-hero h1{
  margin:28px auto 0;
  max-width:1100px;
  font-family:var(--sans);
  font-size:clamp(40px, 4.15vw, 64px);
  font-weight:700;
  line-height:1.12;
  letter-spacing:0;
  text-transform:uppercase;
  color:#111827;
}
.home-hero .lead{
  margin:28px auto 0;
  max-width:940px;
  font-size:clamp(18px, 1.7vw, 27px);
  line-height:1.22;
  color:#4b5563;
}
.home-hero .hero-actions{
  justify-content:center;
  gap:28px;
  margin-top:42px;
}
.home-hero .btn{
  border-radius:4px;
  padding:18px 34px;
  min-width:220px;
  justify-content:center;
  font-size:18px;
  letter-spacing:0;
  text-transform:none;
}
.home-hero .btn.primary{
  background:#303030;
  border-color:#303030;
  color:#fff;
}
.home-hero .btn.ghost{
  background:rgba(255,255,255,.08);
  border-color:#1f2933;
  color:#171717;
}
.home-hero .btn.ghost:hover{
  background:rgba(255,255,255,.35);
}
@media (max-width: 900px){
  .home-hero{
    min-height:0;
    flex-direction:column;
    align-items:center;
    justify-content:flex-start;
    background:
      linear-gradient(180deg, rgba(245,246,246,.94), rgba(236,236,234,.98));
  }
  .home-hero::after{
    content:"";
    display:block;
    flex:0 0 auto;
    width:100%;
    height:clamp(420px, 72vw, 620px);
    margin-top:26px;
    background:url("assets/slab-table-responsive.webp") center center / 100% auto no-repeat;
  }
  .home-hero .hero-copy{
    padding-top:170px;
    padding-bottom:0;
    max-width:760px;
  }
  .home-hero h1{
    font-size:clamp(36px, 6.5vw, 54px);
  }
  .home-hero .lead{line-height:1.28}
}
@media (max-width: 620px){
  .home-hero{
    min-height:0;
  }
  .home-hero::after{
    height:clamp(290px, 78vw, 360px);
    margin-top:16px;
    background-size:108% auto;
  }
  .home-hero .hero-copy{
    padding-top:132px;
    padding-bottom:0;
  }
  .home-hero h1{
    margin-top:18px;
    font-size:clamp(30px, 9vw, 40px);
    line-height:1.08;
  }
  .home-hero .lead{
    margin-top:20px;
    font-size:16px;
    line-height:1.32;
  }
  .home-hero .hero-actions{
    gap:12px;
    margin-top:30px;
  }
  .home-hero .btn{
    width:100%;
    min-width:0;
    padding:15px 18px;
    font-size:15px;
  }
}

/* ============== Marquee strip ============== */
.area-strip{
  border-top:1px solid var(--rule-soft); border-bottom:1px solid var(--rule-soft);
  background:var(--paper-2); overflow:hidden;
  font-family:var(--serif); font-size:clamp(20px, 2.4vw, 28px); font-style:italic;
  color:var(--ink);
}
.area-strip .track{
  display:flex; gap:40px; padding:18px 0; white-space:nowrap;
  animation:slide 60s linear infinite;
}
.area-strip .track span{display:inline-flex; align-items:center; gap:40px; color:var(--ink-soft)}
.area-strip .track span::after{content:"·"; color:var(--accent); margin-left:40px}
@keyframes slide{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ============== Section heading ============== */
.section-head{display:flex; flex-direction:column; gap:18px; margin-bottom:48px; max-width:780px}
.section-head .kicker{margin-bottom:6px}
.section-head h2{margin:0}
.section-head p{margin:0; font-size:18px; color:var(--ink-soft); line-height:1.55}

/* ============== What we make grid ============== */
.make-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:0; border-top:1px solid var(--rule-soft); border-left:1px solid var(--rule-soft)}
@media (max-width: 900px){ .make-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width: 560px){ .make-grid{grid-template-columns:1fr} }
.make-card{
  padding:30px 28px; border-right:1px solid var(--rule-soft); border-bottom:1px solid var(--rule-soft);
  background:transparent; transition:background .25s;
  display:flex; flex-direction:column; gap:8px; min-height:200px;
}
.make-card:hover{background:var(--paper-2)}
.make-card .num{font-family:var(--serif); font-style:italic; color:var(--accent); font-size:14px; margin-bottom:6px}
.make-card h4{font-family:var(--serif); font-weight:500; font-size:22px; margin:0 0 4px; line-height:1.15}
.make-card p{font-size:14px; color:var(--ink-mute); margin:0; line-height:1.55}

/* ============== Why grid ============== */
.why-list{display:grid; grid-template-columns:repeat(2,1fr); gap:0}
@media (max-width: 720px){ .why-list{grid-template-columns:1fr} }
.why-list .why{
  padding:24px 28px 24px 0;
  border-top:1px solid var(--rule-soft);
}
.why-list .why:nth-child(odd){padding-right:36px}
.why-list .why h5{font-family:var(--serif); font-size:22px; font-weight:500; margin:0 0 6px; letter-spacing:0}
.why-list .why p{margin:0; color:var(--ink-soft); font-size:15px}

/* ============== Process ============== */
.process{display:grid; grid-template-columns:repeat(5,1fr); gap:0; counter-reset:proc; border-top:1px solid var(--ink)}
@media (max-width: 980px){ .process{grid-template-columns:repeat(2,1fr); border-top:none} }
@media (max-width: 560px){ .process{grid-template-columns:1fr} }
.process .step{padding:32px 24px 32px 0; border-right:1px solid var(--rule-soft); position:relative}
.process .step:last-child{border-right:none}
.process .step .n{font-family:var(--serif); font-style:italic; color:var(--accent); font-size:18px; margin-bottom:10px; display:block}
.process .step h5{font-family:var(--serif); font-weight:500; font-size:22px; margin:0 0 8px; line-height:1.15}
.process .step p{font-size:14px; color:var(--ink-mute); margin:0; line-height:1.5}
@media (max-width: 980px){
  .process .step{border-top:1px solid var(--rule-soft); border-right:none; padding-left:24px}
}

/* ============== Service area module ============== */
.area-block{
  display:grid; grid-template-columns: 1fr 1.2fr; gap:64px; align-items:start;
}
@media (max-width: 880px){ .area-block{grid-template-columns:1fr; gap:32px} }
.area-block .area-list{
  display:grid; grid-template-columns:1fr 1fr; gap:8px 24px;
  font-family:var(--serif); font-size:22px; font-weight:500; line-height:1.4;
}
.area-block .area-list .pin{color:var(--accent); margin-right:6px}
.area-block .area-list a{display:flex; align-items:baseline; padding:6px 0; border-bottom:1px solid var(--rule-soft); color:var(--ink); transition:color .2s}
.area-block .area-list a:hover{color:var(--accent)}
.area-block .area-list span.muted{color:var(--ink-mute)}
.area-block .area-list .more{font-size:14px; font-family:var(--sans); color:var(--ink-mute); align-self:center; padding:6px 0; border-bottom:1px solid var(--rule-soft); font-style:normal}

/* ============== FAQ ============== */
.faq-list{border-top:1px solid var(--rule); max-width:880px}
.faq{border-bottom:1px solid var(--rule-soft); padding:0}
.faq summary{
  list-style:none; cursor:pointer;
  padding:24px 60px 24px 0; position:relative;
  font-family:var(--serif); font-size:clamp(20px,2vw,26px); font-weight:500; line-height:1.25;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+"; position:absolute; right:0; top:50%; transform:translateY(-50%);
  width:36px; height:36px; border:1px solid var(--rule); border-radius:999px;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--serif); font-size:22px; color:var(--ink); transition:transform .3s, background .2s;
}
.faq[open] summary::after{content:"–"; background:var(--ink); color:var(--paper); border-color:var(--ink)}
.faq .a{padding:0 60px 24px 0; color:var(--ink-soft); max-width:62ch; font-size:16px}

/* ============== Footer ============== */
.site-footer{
  background:var(--ink); color:var(--paper);
  padding:80px 0 40px;
  margin-top:60px;
}
.site-footer .top{
  display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap:48px;
  padding-bottom:48px; border-bottom:1px solid #3a322a;
}
@media (max-width: 880px){ .site-footer .top{grid-template-columns:1fr 1fr; gap:32px} }
@media (max-width: 540px){ .site-footer .top{grid-template-columns:1fr} }
.site-footer h6{font-family:var(--sans); font-weight:600; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:#bba572; margin:0 0 16px}
.site-footer ul{list-style:none; padding:0; margin:0}
.site-footer ul li{margin:6px 0}
.site-footer a{color:#d8cdb1; transition:color .2s}
.site-footer a:hover{color:#fff}
.site-footer .word{font-family:var(--serif); font-size:34px; line-height:1.15; max-width:30ch; color:#efe7d6; margin:0 0 24px}
.site-footer .bottom{
  display:flex; flex-wrap:wrap; gap:18px; justify-content:space-between;
  padding-top:32px; font-size:12px; color:#8a7f6a;
}
.site-footer .bottom a{color:#8a7f6a}

/* ============== Page header (inner pages) ============== */
.page-hero{padding:clamp(60px, 8vw, 120px) 0 clamp(30px, 4vw, 60px)}
.page-hero .kicker{margin-bottom:18px}
.page-hero h1{font-size:clamp(40px,5.6vw,72px); margin:0 0 18px}
.page-hero p.lead{margin:0; max-width:64ch}
.crumbs{font-size:12px; color:var(--ink-mute); letter-spacing:.06em; margin-bottom:18px}
.crumbs a{color:var(--ink-mute)}
.crumbs a:hover{color:var(--ink)}
.crumbs span{margin:0 8px; color:var(--rule-soft)}

/* ============== Service blocks ============== */
.service-block{
  display:grid; grid-template-columns: 220px 1fr; gap:48px;
  padding:48px 0; border-top:1px solid var(--rule-soft);
}
@media (max-width: 760px){ .service-block{grid-template-columns:1fr; gap:18px} }
.service-block .label{font-family:var(--serif); font-style:italic; color:var(--accent); font-size:18px}
.service-block h3{margin:0 0 14px; font-size:clamp(26px, 3vw, 36px); letter-spacing:-.005em}
.service-block p{font-size:16.5px; color:var(--ink-soft)}
.service-block .tagline{font-family:var(--serif); font-style:italic; color:var(--ink-mute); margin-top:6px; font-size:15px}

/* ============== Project cards ============== */
.proj-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:48px 40px}
@media (max-width: 760px){ .proj-grid{grid-template-columns:1fr} }
.proj{display:flex; flex-direction:column; gap:18px}
.proj .frame{
  aspect-ratio: 4/3; border-radius:2px; overflow:hidden; position:relative;
  background:linear-gradient(180deg, var(--paper-3), var(--paper-2)) center / cover no-repeat;
  border:1px solid var(--rule-soft);
}
.proj .frame.timber-1{background-image:url("assets/project-dining-table.jpg")}
.proj .frame.timber-2{background-image:url("assets/project-built-in-shelving.jpg")}
.proj .frame.timber-3{background-image:url("assets/project-entertainment-unit.jpg")}
.proj .frame.timber-4{background-image:url("assets/project-vanity.jpg")}
.proj .frame.timber-5{background-image:url("assets/project-cafe-furniture.jpg")}
.proj .frame.timber-6{background-image:url("assets/project-office.jpg")}
.proj .frame::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,.25) 100%);
}
.proj .frame .badge{
  position:absolute; left:14px; bottom:14px; z-index:2;
  font-family:var(--sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(243,236,220,.85); padding:5px 9px;
  background:rgba(0,0,0,.3); border:1px solid rgba(243,236,220,.18); border-radius:2px;
}
.proj .meta{display:flex; gap:14px; align-items:baseline; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent)}
.proj h3{margin:0; font-size:clamp(22px, 2.2vw, 28px); line-height:1.2}
.proj .desc{font-size:15px; color:var(--ink-soft); margin:0; max-width:46ch}
.proj dl.specs{display:grid; grid-template-columns: 110px 1fr; gap:6px 14px; margin:6px 0 0; font-size:13px}
.proj dl.specs dt{color:var(--accent); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; padding-top:3px}
.proj dl.specs dd{margin:0; color:var(--ink-soft)}

/* ============== Form ============== */
.form{display:grid; grid-template-columns:1fr 1fr; gap:18px 24px; max-width:760px}
.form .full{grid-column:1 / -1}
.form label{display:flex; flex-direction:column; gap:6px; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); font-weight:600}
.form input, .form select, .form textarea{
  font-family:var(--sans); font-size:15px; color:var(--ink);
  background:var(--paper-2); border:1px solid var(--rule-soft); border-radius:2px;
  padding:12px 14px; outline:none; transition:border-color .2s, background .2s;
}
.form input:focus, .form select:focus, .form textarea:focus{border-color:var(--ink); background:#fff}
.form textarea{min-height:140px; resize:vertical}
.form .file{padding:14px; border:1px dashed var(--rule-soft); border-radius:2px; background:var(--paper-2); font-size:13px; color:var(--ink-mute); text-align:center; cursor:pointer}
@media (max-width: 600px){ .form{grid-template-columns:1fr} }

/* ============== Quote / pull ============== */
.pullquote{
  font-family:var(--serif); font-size:clamp(28px, 3.6vw, 44px);
  font-style:italic; line-height:1.2;
  color:var(--ink); max-width:22ch;
}
.pullquote::before{content:"“"; color:var(--accent); font-size:1.2em; line-height:0; margin-right:.05em}
.pullquote::after{content:"”"; color:var(--accent); font-size:1.2em; line-height:0; margin-left:.05em}

/* ============== Misc ============== */
.eyebrow{display:flex; align-items:center; gap:14px; margin-bottom:14px}
.eyebrow::before{content:""; width:36px; height:1px; background:var(--accent)}
.eyebrow .kicker{margin:0}

.muted{color:var(--ink-mute)}
.center{text-align:center}
.mt-0{margin-top:0}
.mt-2{margin-top:32px}
.mt-3{margin-top:48px}

.tag-row{display:flex; flex-wrap:wrap; gap:8px; margin-top:16px}
.tag{
  font-family:var(--sans); font-size:12px; letter-spacing:.06em;
  padding:6px 12px; border:1px solid var(--rule-soft); border-radius:999px; color:var(--ink-soft);
}

/* page CTA banner */
.cta-banner{
  background:var(--ink); color:var(--paper);
  padding:clamp(48px, 7vw, 96px) 0;
  margin-top:60px;
}
.cta-banner .container{display:grid; grid-template-columns:1.4fr 1fr; gap:48px; align-items:center}
@media (max-width: 760px){ .cta-banner .container{grid-template-columns:1fr} }
.cta-banner h2{font-size:clamp(32px, 4vw, 56px); color:var(--paper); margin:0 0 12px}
.cta-banner p{color:#d8cdb1; margin:0; max-width:46ch}
.cta-banner .btn{border-color:var(--paper); color:var(--paper)}
.cta-banner .btn.primary{background:var(--paper); color:var(--ink)}
.cta-banner .btn:hover{background:var(--paper); color:var(--ink)}
