:root{
  --ink:#1a1510;
  --ink-soft:#3a3128;
  --cream:#f5ede0;
  --cream-warm:#ebdfc7;
  --silk:#fbf7ef;
  --thread-gold:#b8893b;
  --thread-gold-deep:#8a6420;
  --thread-rose:#9c3a3a;
  --thread-indigo:#2b3a5e;
  --stitch:#5a4a35;
  --line:#d9c9a8;
  --line-soft:#e8dcc2;
  --hover-gold:#d4a656;
  --shadow-sm:0 1px 0 rgba(138,100,32,.15);
  --serif:"Cormorant Garamond","EB Garamond",Georgia,serif;
  --display:"Cormorant Garamond",Georgia,serif;
  --body:"Nunito Sans","Helvetica Neue",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --w-full:min(1280px,94vw);
  --w-read:min(780px,92vw);
  --stitch-dash:6px 4px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}

body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--silk);
  line-height:1.65;
  font-size:16px;
  font-weight:400;
  overflow-x:hidden;
}

img{max-width:100%;display:block;height:auto}

a{color:var(--thread-indigo);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--thread-gold-deep)}

button{font-family:inherit;cursor:pointer;border:none;background:none}

h1,h2,h3,h4,h5{
  font-family:var(--display);
  font-weight:500;
  line-height:1.15;
  color:var(--ink);
  letter-spacing:-.01em;
}

h1{font-size:clamp(2.4rem,5.5vw,4.6rem);font-weight:400}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:500}
h3{font-size:clamp(1.3rem,2vw,1.6rem);font-weight:500}
h4{font-size:1.1rem;font-weight:600;font-family:var(--body);letter-spacing:.04em;text-transform:uppercase}

p{margin-bottom:1rem}

.eyebrow{
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--thread-gold-deep);
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  margin-bottom:1rem;
}
.eyebrow::before{
  content:"";
  width:28px;
  height:1px;
  background:var(--thread-gold);
}

.eyebrow--center{justify-content:center;display:inline-flex}

.benefits-head-wrap{width:var(--w-full);margin:0 auto}

.stitched-rule{
  height:1px;
  background-image:linear-gradient(to right,var(--stitch) 50%,transparent 50%);
  background-size:8px 1px;
  background-repeat:repeat-x;
  margin:2rem 0;
  opacity:.5;
}

.nav-bar{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--silk);
  border-bottom:1px solid var(--line);
  backdrop-filter:saturate(1.1);
}

.nav-inner{
  width:var(--w-full);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1rem 0;
  gap:2rem;
}

.brand-mark{
  display:flex;
  align-items:center;
  gap:.75rem;
  font-family:var(--display);
  font-size:1.4rem;
  font-weight:500;
  color:var(--ink);
  letter-spacing:.02em;
}

.brand-mark img{width:38px;height:38px;object-fit:contain}

.primary-menu{
  display:flex;
  gap:2rem;
  list-style:none;
  align-items:center;
}

.primary-menu a{
  color:var(--ink-soft);
  font-size:.9rem;
  font-weight:500;
  letter-spacing:.03em;
  position:relative;
  padding:.4rem 0;
}

.primary-menu a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:0;
  height:1px;
  background:var(--thread-gold);
  transition:width .3s ease;
}

.primary-menu a:hover{color:var(--ink)}
.primary-menu a:hover::after{width:100%}

.nav-cta{
  padding:.65rem 1.4rem;
  border:1px solid var(--ink);
  color:var(--ink);
  font-size:.85rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:600;
  transition:all .25s ease;
  background:transparent;
}
.nav-cta:hover{background:var(--ink);color:var(--silk)}

.menu-toggle{
  display:none;
  width:40px;
  height:40px;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  padding:0 9px;
  background:none;
  border:1px solid var(--line);
}
.menu-toggle span{height:1.5px;background:var(--ink);display:block;transition:all .3s ease}

.hero-canvas{
  width:var(--w-full);
  margin:0 auto;
  padding:5rem 0 4rem;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:4rem;
  align-items:center;
  position:relative;
}

.hero-canvas::before{
  content:"";
  position:absolute;
  top:10%;
  right:45%;
  width:340px;
  height:340px;
  border:1px dashed var(--line);
  border-radius:50%;
  opacity:.4;
  z-index:-1;
}

.hero-text h1{
  margin-bottom:1.8rem;
}

.hero-text h1 em{
  font-style:italic;
  color:var(--thread-gold-deep);
  font-weight:400;
}

.hero-lede{
  font-size:1.15rem;
  color:var(--ink-soft);
  max-width:520px;
  margin-bottom:2.2rem;
  line-height:1.7;
}

.hero-actions{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  align-items:center;
}

.btn-primary{
  display:inline-flex;
  align-items:center;
  gap:.7rem;
  padding:.95rem 1.8rem;
  background:var(--ink);
  color:var(--silk);
  font-size:.88rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:600;
  border:1px solid var(--ink);
  transition:all .25s ease;
}
.btn-primary:hover{background:var(--thread-gold-deep);border-color:var(--thread-gold-deep);color:var(--silk)}
.btn-primary i{font-size:.85rem}

.btn-ghost{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.95rem 0;
  color:var(--ink);
  font-size:.88rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:600;
  border-bottom:1px solid var(--ink);
  transition:all .25s ease;
}
.btn-ghost:hover{color:var(--thread-gold-deep);border-color:var(--thread-gold-deep)}

.hero-image-frame{
  position:relative;
  aspect-ratio:4/5;
}

.hero-image-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  position:relative;
  z-index:2;
}

.hero-image-frame::after{
  content:"";
  position:absolute;
  top:20px;
  right:-20px;
  width:100%;
  height:100%;
  border:1px solid var(--thread-gold);
  z-index:1;
}

.hero-image-frame .thread-tag{
  position:absolute;
  bottom:-24px;
  left:-24px;
  background:var(--silk);
  padding:1rem 1.4rem;
  z-index:3;
  border:1px solid var(--line);
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--stitch);
}

.craft-quote{
  width:var(--w-full);
  margin:4rem auto;
  padding:3rem 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  text-align:center;
  background-image:radial-gradient(circle at 50% 0,var(--cream-warm) 0,transparent 60%);
}

.craft-quote blockquote{
  font-family:var(--display);
  font-size:clamp(1.5rem,2.6vw,2.2rem);
  font-style:italic;
  font-weight:400;
  max-width:820px;
  margin:0 auto;
  color:var(--ink-soft);
  line-height:1.4;
}

.craft-quote cite{
  display:block;
  margin-top:1.5rem;
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--thread-gold-deep);
  font-style:normal;
}

.atelier-story{
  width:var(--w-full);
  margin:0 auto;
  padding:6rem 0;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:5rem;
  align-items:center;
}

.atelier-visual{
  position:relative;
}

.atelier-visual img{
  aspect-ratio:3/4;
  object-fit:cover;
  width:100%;
}

.atelier-visual .detail-shot{
  position:absolute;
  width:45%;
  aspect-ratio:1;
  bottom:-40px;
  right:-40px;
  border:6px solid var(--silk);
  object-fit:cover;
}

.atelier-copy h2{margin-bottom:1.5rem}

.atelier-copy p{
  color:var(--ink-soft);
  font-size:1.02rem;
  line-height:1.75;
  margin-bottom:1.2rem;
}

.atelier-values{
  list-style:none;
  margin-top:2rem;
  display:grid;
  gap:1.2rem;
}

.atelier-values li{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1.2rem;
  align-items:start;
  padding-bottom:1.2rem;
  border-bottom:1px dashed var(--line);
}

.atelier-values li:last-child{border-bottom:none}

.atelier-values .val-num{
  font-family:var(--mono);
  font-size:.78rem;
  color:var(--thread-gold-deep);
  letter-spacing:.15em;
  padding-top:.3rem;
}

.atelier-values .val-body strong{
  font-family:var(--display);
  font-size:1.2rem;
  font-weight:500;
  display:block;
  margin-bottom:.3rem;
}

.atelier-values .val-body span{
  color:var(--ink-soft);
  font-size:.95rem;
}

.services-row{
  width:var(--w-full);
  margin:0 auto;
  padding:6rem 0;
  border-top:1px solid var(--line);
}

.services-head{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  margin-bottom:4rem;
  align-items:end;
}

.services-head p{
  color:var(--ink-soft);
  font-size:1.05rem;
  max-width:440px;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
}

.service-cell{
  padding:2.5rem 1.8rem;
  border-left:1px solid var(--line);
  transition:background .3s ease;
  position:relative;
}

.service-cell:last-child{border-right:1px solid var(--line)}

.service-cell:hover{background:var(--cream)}

.service-cell i{
  font-size:2.4rem;
  color:var(--thread-gold-deep);
  margin-bottom:1.6rem;
  display:block;
}

.service-cell h3{
  margin-bottom:.8rem;
  font-size:1.35rem;
}

.service-cell p{
  color:var(--ink-soft);
  font-size:.94rem;
  line-height:1.6;
  margin-bottom:1.2rem;
}

.service-cell .cell-num{
  position:absolute;
  top:1.5rem;
  right:1.5rem;
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.15em;
  color:var(--thread-gold-deep);
}

.process-loom{
  width:var(--w-full);
  margin:0 auto;
  padding:6rem 0;
  background:var(--cream);
  position:relative;
}

.process-loom::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background-image:repeating-linear-gradient(90deg,var(--thread-gold) 0,var(--thread-gold) 8px,transparent 8px,transparent 14px);
}

.process-loom::after{
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:1px;
  background-image:repeating-linear-gradient(90deg,var(--thread-gold) 0,var(--thread-gold) 8px,transparent 8px,transparent 14px);
}

.process-inner{
  width:var(--w-full);
  margin:0 auto;
  padding:0 2rem;
}

.process-inner > h2{text-align:center;margin-bottom:1rem}
.process-inner > .lede{text-align:center;color:var(--ink-soft);max-width:560px;margin:0 auto 4rem}

.steps-track{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:0;
  position:relative;
}

.steps-track::before{
  content:"";
  position:absolute;
  top:42px;
  left:10%;
  right:10%;
  height:1px;
  border-top:1px dashed var(--stitch);
  opacity:.4;
}

.step-node{
  text-align:center;
  padding:0 1rem;
  position:relative;
}

.step-node .node-mark{
  width:84px;
  height:84px;
  border:1px solid var(--stitch);
  background:var(--silk);
  margin:0 auto 1.5rem;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--display);
  font-size:1.8rem;
  color:var(--thread-gold-deep);
  position:relative;
  z-index:2;
  transform:rotate(45deg);
}

.step-node .node-mark span{transform:rotate(-45deg)}

.step-node h3{margin-bottom:.7rem;font-size:1.25rem}

.step-node p{
  color:var(--ink-soft);
  font-size:.92rem;
  line-height:1.6;
}

.portfolio-wall{
  width:var(--w-full);
  margin:0 auto;
  padding:6rem 0;
}

.portfolio-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  margin-bottom:3rem;
  gap:2rem;
  flex-wrap:wrap;
}

.portfolio-head p{
  color:var(--ink-soft);
  max-width:440px;
}

.work-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1.2rem;
}

.work-tile{
  position:relative;
  overflow:hidden;
  aspect-ratio:1;
}

.work-tile:nth-child(1){grid-column:span 3;grid-row:span 2;aspect-ratio:1}
.work-tile:nth-child(2){grid-column:span 3}
.work-tile:nth-child(3){grid-column:span 2}
.work-tile:nth-child(4){grid-column:span 2}
.work-tile:nth-child(5){grid-column:span 2}

.work-tile img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .7s ease;
}

.work-tile:hover img{transform:scale(1.05)}

.work-tile .work-meta{
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  padding:1.4rem;
  background:linear-gradient(to top,rgba(26,21,16,.85),transparent);
  color:var(--silk);
  opacity:0;
  transition:opacity .3s ease;
}

.work-tile:hover .work-meta{opacity:1}

.work-tile .work-meta h4{color:var(--silk);margin-bottom:.3rem}
.work-tile .work-meta span{font-family:var(--mono);font-size:.75rem;letter-spacing:.1em;color:var(--cream-warm)}

.voices-panel{
  width:var(--w-full);
  margin:0 auto;
  padding:6rem 0;
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.voices-panel > h2{text-align:center;margin-bottom:3.5rem}

.voices-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
}

.voice-card{
  padding:2.5rem 2rem;
  border-right:1px solid var(--line);
  position:relative;
}

.voice-card:last-child{border-right:none}

.voice-card .mark-q{
  font-family:var(--display);
  font-size:4rem;
  line-height:1;
  color:var(--thread-gold);
  margin-bottom:1rem;
}

.voice-card blockquote{
  font-family:var(--display);
  font-style:italic;
  font-size:1.15rem;
  line-height:1.55;
  color:var(--ink-soft);
  margin-bottom:1.5rem;
}

.voice-card .voice-who{
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--thread-gold-deep);
  padding-top:1rem;
  border-top:1px dashed var(--line);
}

.voice-card .voice-who strong{
  display:block;
  font-family:var(--display);
  font-size:1rem;
  text-transform:none;
  letter-spacing:0;
  color:var(--ink);
  margin-bottom:.2rem;
  font-weight:500;
}

.reach-block{
  width:var(--w-full);
  margin:0 auto;
  padding:6rem 0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:5rem;
}

.reach-info h2{margin-bottom:1.5rem}

.reach-info p{
  color:var(--ink-soft);
  margin-bottom:2.5rem;
  max-width:440px;
}

.reach-points{
  list-style:none;
  display:grid;
  gap:1.5rem;
}

.reach-points li{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1.2rem;
  align-items:start;
}

.reach-points i{
  width:44px;
  height:44px;
  border:1px solid var(--thread-gold);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--thread-gold-deep);
  font-size:1.1rem;
}

.reach-points strong{
  display:block;
  font-family:var(--display);
  font-size:1.15rem;
  font-weight:500;
  margin-bottom:.2rem;
}

.reach-points span{
  color:var(--ink-soft);
  font-size:.95rem;
}

.reach-points a{color:var(--ink-soft)}

.form-panel{
  background:var(--silk);
  border:1px solid var(--line);
  padding:2.8rem;
  position:relative;
}

.form-panel::before{
  content:"";
  position:absolute;
  inset:8px;
  border:1px dashed var(--line-soft);
  pointer-events:none;
}

.form-panel form{
  position:relative;
  display:grid;
  gap:1.4rem;
}

.field-group{display:grid;gap:.5rem}

.field-group label{
  font-family:var(--mono);
  font-size:.72rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--stitch);
}

.field-group input,
.field-group textarea,
.field-group select{
  font-family:var(--body);
  font-size:.95rem;
  padding:.8rem 0;
  background:transparent;
  border:none;
  border-bottom:1px solid var(--line);
  color:var(--ink);
  transition:border-color .2s ease;
  width:100%;
}

.field-group input:focus,
.field-group textarea:focus,
.field-group select:focus{
  outline:none;
  border-bottom-color:var(--thread-gold-deep);
}

.field-group textarea{resize:vertical;min-height:110px}

.field-error{
  color:var(--thread-rose);
  font-size:.78rem;
  font-family:var(--mono);
  min-height:1rem;
}

.form-panel button[type="submit"]{
  margin-top:.6rem;
  justify-self:start;
}

.thankyou-modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(26,21,16,.75);
  z-index:100;
  align-items:center;
  justify-content:center;
  padding:2rem;
}

.thankyou-modal.is-open{display:flex}

.thankyou-inner{
  background:var(--silk);
  padding:3.5rem 3rem;
  max-width:460px;
  width:100%;
  text-align:center;
  position:relative;
  border:1px solid var(--line);
}

.thankyou-inner::before{
  content:"";
  position:absolute;
  inset:10px;
  border:1px dashed var(--thread-gold);
  pointer-events:none;
}

.thankyou-inner i{
  font-size:2.8rem;
  color:var(--thread-gold-deep);
  margin-bottom:1rem;
  display:block;
}

.thankyou-inner h3{margin-bottom:.8rem}

.thankyou-inner p{color:var(--ink-soft);margin-bottom:1.8rem}

.thankyou-close{
  padding:.8rem 2rem;
  background:var(--ink);
  color:var(--silk);
  font-size:.82rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:600;
}

.site-footer{
  background:var(--ink);
  color:var(--cream-warm);
  padding:5rem 0 0;
  margin-top:4rem;
}

.footer-inner{
  width:var(--w-full);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:3rem;
  padding-bottom:4rem;
}

.footer-brand img{width:44px;margin-bottom:1.2rem;filter:brightness(0) invert(1)}

.footer-brand h4{
  font-family:var(--display);
  font-size:1.5rem;
  font-weight:500;
  color:var(--silk);
  text-transform:none;
  letter-spacing:.02em;
  margin-bottom:1rem;
}

.footer-brand p{
  color:var(--cream-warm);
  font-size:.92rem;
  max-width:340px;
  opacity:.75;
  line-height:1.7;
}

.footer-col h5{
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--thread-gold);
  margin-bottom:1.5rem;
}

.footer-col ul{list-style:none;display:grid;gap:.7rem}

.footer-col a{
  color:var(--cream-warm);
  opacity:.8;
  font-size:.92rem;
  transition:opacity .2s ease,color .2s ease;
}

.footer-col a:hover{opacity:1;color:var(--thread-gold)}

.footer-col p{
  color:var(--cream-warm);
  opacity:.8;
  font-size:.92rem;
  margin-bottom:.7rem;
}

.footer-bottom{
  border-top:1px solid rgba(245,237,224,.12);
  padding:1.8rem 0;
}

.footer-bottom-inner{
  width:var(--w-full);
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:.82rem;
  color:var(--cream-warm);
  opacity:.7;
  flex-wrap:wrap;
  gap:1rem;
}

.footer-bottom-inner .legal-links{display:flex;gap:1.8rem;list-style:none}
.footer-bottom-inner a{color:var(--cream-warm)}
.footer-bottom-inner a:hover{color:var(--thread-gold);opacity:1}

.page-hero{
  width:var(--w-full);
  margin:0 auto;
  padding:5rem 0 3rem;
  border-bottom:1px solid var(--line);
  text-align:center;
}

.page-hero .eyebrow{justify-content:center}

.page-hero h1{margin-bottom:1.2rem}

.page-hero p{
  color:var(--ink-soft);
  max-width:620px;
  margin:0 auto;
  font-size:1.08rem;
}

.page-breadcrumb{
  width:var(--w-full);
  margin:1.5rem auto 0;
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--stitch);
}
.page-breadcrumb a{color:var(--stitch)}
.page-breadcrumb span{margin:0 .6rem;color:var(--line)}

.legal-body{
  width:var(--w-read);
  margin:0 auto;
  padding:4rem 0 5rem;
}

.legal-body h2{
  margin:2.5rem 0 1rem;
  font-size:1.6rem;
  padding-top:1.5rem;
  border-top:1px dashed var(--line);
}

.legal-body h2:first-child{border-top:none;padding-top:0;margin-top:0}

.legal-body h3{
  margin:1.8rem 0 .8rem;
  font-size:1.2rem;
  color:var(--thread-gold-deep);
}

.legal-body p{
  color:var(--ink-soft);
  font-size:1rem;
  line-height:1.8;
  margin-bottom:1.1rem;
}

.legal-body ul{
  list-style:none;
  padding-left:0;
  margin-bottom:1.2rem;
}

.legal-body ul li{
  padding-left:1.5rem;
  position:relative;
  color:var(--ink-soft);
  margin-bottom:.6rem;
  line-height:1.7;
}

.legal-body ul li::before{
  content:"◆";
  position:absolute;
  left:0;
  color:var(--thread-gold);
  font-size:.7rem;
  top:.4rem;
}

.legal-meta{
  padding:1.2rem 1.5rem;
  background:var(--cream);
  border-left:3px solid var(--thread-gold);
  margin-bottom:2.5rem;
  font-family:var(--mono);
  font-size:.82rem;
  color:var(--stitch);
  letter-spacing:.05em;
}

.article-layout{
  width:var(--w-read);
  margin:0 auto;
  padding:4rem 0 5rem;
}

.article-layout h2{
  margin:2.5rem 0 1.2rem;
  font-size:1.8rem;
}

.article-layout p{
  color:var(--ink-soft);
  font-size:1.05rem;
  line-height:1.85;
  margin-bottom:1.3rem;
}

.article-layout .article-meta{
  display:flex;
  gap:1.5rem;
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--thread-gold-deep);
  margin-bottom:2.5rem;
  padding-bottom:1.5rem;
  border-bottom:1px solid var(--line);
}

.article-layout img.article-visual{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  margin:2rem 0 2.5rem;
}

.article-layout blockquote{
  font-family:var(--display);
  font-style:italic;
  font-size:1.4rem;
  line-height:1.5;
  padding:1.5rem 2rem;
  border-left:2px solid var(--thread-gold);
  margin:2rem 0;
  color:var(--ink);
}

.contact-grid{
  width:var(--w-full);
  margin:0 auto;
  padding:5rem 0;
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:4rem;
}

.contact-info-card{
  padding:2.5rem;
  border:1px solid var(--line);
  background:var(--cream);
}

.contact-info-card h3{
  font-family:var(--display);
  font-size:1.4rem;
  margin-bottom:1.5rem;
  font-weight:500;
}

.contact-info-card ul{list-style:none;display:grid;gap:1.4rem}

.contact-info-card li{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1rem;
  align-items:start;
}

.contact-info-card i{
  color:var(--thread-gold-deep);
  font-size:1.1rem;
  padding-top:.2rem;
}

.contact-info-card strong{
  display:block;
  font-weight:600;
  margin-bottom:.2rem;
  font-size:.9rem;
  color:var(--ink);
}

.contact-info-card span,
.contact-info-card a{
  color:var(--ink-soft);
  font-size:.95rem;
  line-height:1.5;
}

.team-showcase{
  width:var(--w-full);
  margin:0 auto;
  padding:5rem 0;
}

.team-lineup{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2.5rem;
}

.team-member{
  text-align:center;
}

.team-member img{
  aspect-ratio:3/4;
  object-fit:cover;
  margin-bottom:1.5rem;
  width:100%;
  filter:grayscale(.15);
  transition:filter .4s ease;
}

.team-member:hover img{filter:grayscale(0)}

.team-member h3{
  font-size:1.3rem;
  margin-bottom:.3rem;
}

.team-member .role{
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--thread-gold-deep);
  margin-bottom:1rem;
}

.team-member p{
  color:var(--ink-soft);
  font-size:.95rem;
  line-height:1.6;
  text-align:left;
  padding:0 .5rem;
}

.team-philosophy{
  width:var(--w-full);
  margin:0 auto;
  padding:4rem 0 5rem;
  background:var(--cream);
}

.team-philosophy .inner{
  width:var(--w-read);
  margin:0 auto;
  text-align:center;
}

.team-philosophy p{
  color:var(--ink-soft);
  font-size:1.08rem;
  line-height:1.8;
  margin-bottom:1.2rem;
}

.vacancy-intro{
  width:var(--w-read);
  margin:0 auto;
  padding:4rem 0;
  text-align:center;
}

.vacancy-intro p{
  color:var(--ink-soft);
  font-size:1.08rem;
  line-height:1.8;
}

.vacancy-list{
  width:var(--w-full);
  margin:0 auto;
  padding:0 0 5rem;
  display:grid;
  gap:1.5rem;
}

.vacancy-item{
  display:grid;
  grid-template-columns:1fr auto;
  gap:2rem;
  padding:2rem 2.2rem;
  border:1px solid var(--line);
  background:var(--silk);
  align-items:center;
  transition:border-color .3s ease,background .3s ease;
}

.vacancy-item:hover{border-color:var(--thread-gold);background:var(--cream)}

.vacancy-item .role-title{
  font-family:var(--display);
  font-size:1.5rem;
  font-weight:500;
  margin-bottom:.5rem;
  color:var(--ink);
}

.vacancy-item .role-tags{
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  font-family:var(--mono);
  font-size:.75rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--thread-gold-deep);
  margin-bottom:.8rem;
}

.vacancy-item p{
  color:var(--ink-soft);
  font-size:.95rem;
  max-width:620px;
  margin:0;
}

.vacancy-item .apply-link{
  padding:.85rem 1.6rem;
  border:1px solid var(--ink);
  color:var(--ink);
  font-size:.82rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:600;
  white-space:nowrap;
}

.vacancy-item .apply-link:hover{background:var(--ink);color:var(--silk)}

.vacancy-benefits{
  width:var(--w-full);
  margin:0 auto;
  padding:5rem 0;
  border-top:1px solid var(--line);
}

.benefits-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  margin-top:3rem;
}

.benefit-box{
  padding:2.2rem 1.8rem;
  border-left:1px solid var(--line);
}

.benefit-box:last-child{border-right:1px solid var(--line)}

.benefit-box i{
  font-size:1.8rem;
  color:var(--thread-gold-deep);
  margin-bottom:1rem;
  display:block;
}

.benefit-box h4{
  font-family:var(--display);
  font-size:1.2rem;
  text-transform:none;
  letter-spacing:0;
  font-weight:500;
  margin-bottom:.6rem;
}

.benefit-box p{
  color:var(--ink-soft);
  font-size:.94rem;
  line-height:1.6;
  margin:0;
}

@media (max-width:960px){
  .hero-canvas,
  .atelier-story,
  .reach-block,
  .contact-grid{
    grid-template-columns:1fr;
    gap:3rem;
    padding:3.5rem 0;
  }

  .hero-canvas::before{display:none}

  .services-head{grid-template-columns:1fr;align-items:start}

  .services-grid{grid-template-columns:repeat(2,1fr)}

  .service-cell{border-left:none;border-top:1px solid var(--line)}
  .service-cell:nth-child(odd){border-right:1px solid var(--line)}
  .service-cell:last-child{border-right:1px solid var(--line)}

  .steps-track{grid-template-columns:repeat(2,1fr);gap:3rem 1rem}
  .steps-track::before{display:none}

  .work-grid{grid-template-columns:repeat(2,1fr)}
  .work-tile,
  .work-tile:nth-child(1),
  .work-tile:nth-child(2),
  .work-tile:nth-child(3),
  .work-tile:nth-child(4),
  .work-tile:nth-child(5){grid-column:span 1;grid-row:span 1}

  .voices-strip{grid-template-columns:1fr}
  .voice-card{border-right:none;border-bottom:1px solid var(--line)}
  .voice-card:last-child{border-bottom:none}

  .team-lineup{grid-template-columns:repeat(2,1fr)}

  .benefits-row{grid-template-columns:1fr}
  .benefit-box{border-left:none;border-top:1px solid var(--line)}
  .benefit-box:last-child{border-right:none;border-bottom:1px solid var(--line)}

  .footer-inner{grid-template-columns:1fr 1fr;gap:2.5rem}

  .primary-menu{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    background:var(--silk);
    flex-direction:column;
    padding:1.5rem 2rem;
    border-bottom:1px solid var(--line);
    gap:1rem;
    align-items:start;
  }

  .primary-menu.is-open{display:flex}

  .menu-toggle{display:flex}

  .nav-cta{display:none}

  .hero-image-frame::after{right:-10px;top:10px}

  .atelier-visual .detail-shot{width:40%;right:-20px;bottom:-20px}

  .vacancy-item{grid-template-columns:1fr;gap:1rem}
  .vacancy-item .apply-link{justify-self:start}
}

@media (max-width:560px){
  .services-grid{grid-template-columns:1fr}
  .service-cell{border-right:1px solid var(--line) !important;border-left:1px solid var(--line)}

  .steps-track{grid-template-columns:1fr}

  .work-grid{grid-template-columns:1fr}

  .team-lineup{grid-template-columns:1fr}

  .footer-inner{grid-template-columns:1fr;gap:2rem}

  .footer-bottom-inner{flex-direction:column;text-align:center}

  .hero-actions{flex-direction:column;align-items:stretch}
  .btn-primary,.btn-ghost{justify-content:center}

  .form-panel{padding:1.8rem 1.4rem}

  .craft-quote blockquote{font-size:1.3rem}

  .article-layout blockquote{padding:1rem 1.2rem;font-size:1.2rem}
}
