:root{
  --paper:#EDE4D3;
  --paper-2:#F6F0E4;
  --ink:#17130D;
  --ink-soft:#4A4235;
  --rust:#D6421A;
  --rust-deep:#A83112;
  --forest:#1E3A2A;
  --sand:#C6B18A;
  --line:rgba(23,19,13,.16);
  --serif:"Fraunces",Georgia,serif;
  --sans:"Instrument Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",monospace;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
@media (hover:none){body{cursor:auto}}
::selection{background:var(--rust);color:var(--paper-2)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---- grain + vignette overlays ---- */
.grain{
  position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.vignette{position:fixed;inset:0;z-index:9997;pointer-events:none;box-shadow:inset 0 0 220px rgba(23,19,13,.14)}

/* ---- custom cursor ---- */
.cursor{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;background:var(--rust);z-index:10000;pointer-events:none;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),background .25s,opacity .3s}
.cursor-ring{position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--ink);border-radius:50%;z-index:10000;pointer-events:none;transform:translate(-50%,-50%);transition:transform .18s var(--ease),width .3s var(--ease),height .3s var(--ease),border-color .3s;mix-blend-mode:difference;opacity:.6}
body.hovering .cursor{width:0;height:0}
body.hovering .cursor-ring{width:64px;height:64px;border-color:var(--rust)}
@media (hover:none){.cursor,.cursor-ring{display:none}}

/* ---- nav ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:900;display:flex;justify-content:space-between;align-items:center;padding:20px clamp(18px,4vw,54px);mix-blend-mode:normal;transition:padding .4s var(--ease)}
nav.shrink{padding:12px clamp(18px,4vw,54px);background:rgba(237,228,211,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.brand{font-family:var(--serif);font-weight:600;font-size:22px;letter-spacing:-.02em;display:flex;align-items:center;gap:9px}
.brand .dot{width:9px;height:9px;background:var(--rust);border-radius:50%;display:inline-block;animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}}
.nav-right{display:flex;align-items:center;gap:clamp(14px,2.4vw,34px)}
.nav-links{display:flex;gap:26px;font-family:var(--mono);font-size:12.5px;text-transform:uppercase;letter-spacing:.06em}
.nav-links a{position:relative;padding:4px 0}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--rust);transition:width .35s var(--ease)}
.nav-links a:hover::after{width:100%}
.lang{display:flex;font-family:var(--mono);font-size:12px;border:1px solid var(--line);border-radius:40px;overflow:hidden}
.lang button{cursor:none;background:none;border:none;padding:6px 11px;font:inherit;color:var(--ink-soft);transition:.25s;text-transform:uppercase}
.lang button.on{background:var(--ink);color:var(--paper-2)}
@media (hover:none){.lang button{cursor:pointer}}
.menu-btn{display:none}
@media(max-width:860px){.nav-links{display:none}}

/* ---- marquee ---- */
.ticker{position:relative;z-index:5;background:var(--ink);color:var(--paper);overflow:hidden;border-top:1px solid var(--rust);border-bottom:1px solid var(--rust)}
.ticker-track{display:inline-flex;white-space:nowrap;animation:scroll 34s linear infinite;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;padding:11px 0}
.ticker-track span{padding:0 28px;display:inline-flex;align-items:center;gap:28px}
.ticker-track span::before{content:"✷";color:var(--rust)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---- images / warm duotone ---- */
.img-warm{filter:grayscale(1) contrast(1.05) brightness(1.04) sepia(.34) saturate(1.7) hue-rotate(-13deg)}

/* full-width editorial band */
.band{position:relative;height:60vh;min-height:400px;overflow:hidden;border-top:1px solid var(--rust);border-bottom:1px solid var(--rust);background:var(--ink)}
.band img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.06);transition:transform 1.6s var(--ease)}
.band:hover img{transform:scale(1)}
.band::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(23,19,13,.9) 0%,rgba(23,19,13,.5) 42%,rgba(214,66,26,.4) 100%)}
.band-inner{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(34px,6vw,72px)}
.band-inner .eyebrow{color:var(--sand)}
.band-inner .eyebrow::before{background:var(--sand)}
.band-inner h3{font-family:var(--serif);font-weight:340;color:var(--paper);font-size:clamp(1.7rem,4.6vw,3.7rem);line-height:1.02;letter-spacing:-.02em;max-width:17ch;margin-top:16px}
.band-inner h3 em{font-style:italic;color:var(--rust)}

/* service hover thumbnails */
.svc-img{position:absolute;top:50%;right:clamp(18px,4vw,54px);transform:translate(34px,-50%);width:min(34vw,290px);height:clamp(92px,13vw,150px);object-fit:cover;z-index:4;opacity:0;transition:opacity .5s var(--ease),transform .55s var(--ease);pointer-events:none;box-shadow:0 22px 46px rgba(0,0,0,.4);border-radius:2px}
.svc:hover .svc-img{opacity:1;transform:translate(0,-50%)}
@media(max-width:760px){.svc-img{display:none}}

/* layout helpers */
section{position:relative}
.wrap{padding:0 clamp(18px,4vw,54px)}
.eyebrow{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.2em;color:var(--rust);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--rust)}

/* ---- HERO ---- */
.hero{min-height:100vh;padding:150px clamp(18px,4vw,54px) 60px;display:grid;grid-template-columns:1fr;align-content:center;position:relative}
.hero-meta{position:absolute;top:150px;right:clamp(18px,4vw,54px);text-align:right;font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;color:var(--ink-soft);line-height:2;opacity:0;animation:fade 1s var(--ease) 1.3s forwards}
.hero-meta b{color:var(--ink)}
.h-line{overflow:hidden;display:block}
.h-line span{display:block;transform:translateY(105%);transition:transform 1s var(--ease)}
.loaded .h-line span{transform:translateY(0)}
.h-line:nth-child(1) span{transition-delay:.15s}
.h-line:nth-child(2) span{transition-delay:.3s}
.h-line:nth-child(3) span{transition-delay:.45s}
h1{font-family:var(--serif);font-weight:340;font-size:clamp(3rem,10.5vw,10.2rem);line-height:.92;letter-spacing:-.03em}
h1 em{font-style:italic;font-weight:500;color:var(--rust)}
h1 .thin{font-weight:300}
.hero-sub{max-width:520px;margin-top:34px;font-size:clamp(16px,1.5vw,20px);color:var(--ink-soft);opacity:0;animation:fade 1s var(--ease) 1s forwards}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:38px;opacity:0;animation:fade 1s var(--ease) 1.2s forwards}
@keyframes fade{to{opacity:1}}
.btn{cursor:none;font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.05em;padding:15px 26px;border-radius:44px;border:1px solid var(--ink);display:inline-flex;align-items:center;gap:10px;transition:.4s var(--ease);background:transparent}
.btn .arw{transition:transform .4s var(--ease)}
.btn:hover .arw{transform:translateX(5px)}
.btn.solid{background:var(--ink);color:var(--paper-2);border-color:var(--ink)}
.btn.solid:hover{background:var(--rust);border-color:var(--rust)}
.btn.ghost:hover{background:var(--ink);color:var(--paper-2)}
@media(hover:none){.btn{cursor:pointer}}
.scroll-hint{position:absolute;bottom:32px;left:clamp(18px,4vw,54px);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--ink-soft);display:flex;align-items:center;gap:12px;opacity:0;animation:fade 1s 1.6s forwards}
.scroll-hint .bar{width:1px;height:40px;background:var(--ink-soft);position:relative;overflow:hidden}
.scroll-hint .bar::after{content:"";position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--rust);animation:drop 2s var(--ease) infinite}
@keyframes drop{to{top:100%}}
.orbit{position:absolute;right:6vw;bottom:14vh;width:clamp(120px,15vw,200px);height:clamp(120px,15vw,200px);pointer-events:none;opacity:0;animation:fade 1.4s 1.5s forwards}
.orbit svg{width:100%;height:100%;animation:spin 26s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.orbit .core{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.6vw,34px)}
@media(max-width:860px){.hero-meta{display:none}.orbit{display:none}}

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

/* ---- section head ---- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:20px}
.sec-title{font-family:var(--serif);font-weight:360;font-size:clamp(2rem,5vw,4rem);line-height:1;letter-spacing:-.02em}
.sec-title em{font-style:italic;color:var(--rust)}
.sec-idx{font-family:var(--mono);font-size:12px;color:var(--ink-soft);letter-spacing:.1em}

/* ---- SERVICES index ---- */
.services{padding:120px 0 80px;border-top:1px solid var(--line)}
.svc-list{margin-top:30px;border-top:1px solid var(--line)}
.svc{position:relative;border-bottom:1px solid var(--line);overflow:hidden}
.svc-row{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:24px;padding:34px clamp(18px,4vw,54px);position:relative;z-index:2;transition:color .45s var(--ease),padding .45s var(--ease)}
.svc-num{font-family:var(--mono);font-size:13px;color:var(--rust)}
.svc-name{font-family:var(--serif);font-weight:360;font-size:clamp(1.7rem,4.4vw,3.3rem);line-height:1;letter-spacing:-.02em;transition:transform .45s var(--ease)}
.svc-desc{font-size:14.5px;color:var(--ink-soft);max-width:340px;justify-self:end;text-align:right;transition:color .45s var(--ease)}
.svc .fill{position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:1}
.svc:nth-child(2) .fill{background:var(--forest)}
.svc:nth-child(3) .fill{background:var(--rust-deep)}
.svc:nth-child(4) .fill{background:var(--rust)}
.svc:hover .fill{transform:translateY(0)}
.svc:hover .svc-row{color:var(--paper-2);padding-left:clamp(28px,5vw,74px)}
.svc:hover .svc-name{color:var(--paper-2)}
.svc:hover .svc-desc{color:rgba(246,240,228,.7)}
.svc:hover .svc-num{color:var(--paper-2)}
.svc-tags{margin-top:8px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);opacity:0;max-height:0;transition:.45s var(--ease)}
.svc:hover .svc-tags{opacity:.8;max-height:30px;color:rgba(246,240,228,.7)}
@media(max-width:760px){
  .svc-row{grid-template-columns:44px 1fr;padding:24px 18px}
  .svc-desc{display:none}
}

/* ---- WHY / stats ---- */
.why{padding:110px 0;background:var(--ink);color:var(--paper)}
.why .sec-title{color:var(--paper)}
.why .eyebrow{color:var(--sand)}
.why .eyebrow::before{background:var(--sand)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:56px;border-top:1px solid rgba(246,240,228,.2)}
.stat{padding:34px 26px 34px 0;border-right:1px solid rgba(246,240,228,.14)}
.stat:last-child{border-right:none}
.stat .num{font-family:var(--serif);font-weight:340;font-size:clamp(2.6rem,5vw,4.4rem);line-height:1;color:var(--rust)}
.stat .lab{font-size:13.5px;color:rgba(246,240,228,.65);margin-top:12px;max-width:180px}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:2px;margin-top:64px}
.why-card{padding:34px;background:rgba(246,240,228,.04);border:1px solid rgba(246,240,228,.1);transition:.4s var(--ease)}
.why-card:hover{background:rgba(246,240,228,.08);transform:translateY(-4px)}
.why-card .k{font-family:var(--mono);font-size:12px;color:var(--sand);letter-spacing:.1em}
.why-card h4{font-family:var(--serif);font-weight:400;font-size:1.5rem;margin:14px 0 10px;letter-spacing:-.01em}
.why-card p{font-size:14.5px;color:rgba(246,240,228,.62)}
@media(max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2){border-right:none}.stat{border-bottom:1px solid rgba(246,240,228,.14)}}

/* ---- PROCESS ---- */
.process{padding:120px 0}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:50px;counter-reset:s}
.step{padding:0 28px 0 0;position:relative}
.step:not(:last-child)::after{content:"";position:absolute;top:14px;right:14px;width:calc(100% - 28px);height:1px;background:var(--line)}
.step .ring{width:30px;height:30px;border-radius:50%;border:1px solid var(--ink);display:grid;place-items:center;font-family:var(--mono);font-size:12px;background:var(--paper);position:relative;z-index:2;transition:.4s var(--ease)}
.step:hover .ring{background:var(--rust);border-color:var(--rust);color:var(--paper-2);transform:scale(1.15)}
.step h4{font-family:var(--serif);font-weight:400;font-size:1.5rem;margin:22px 0 10px;letter-spacing:-.01em}
.step p{font-size:14.5px;color:var(--ink-soft);max-width:230px}
@media(max-width:760px){.steps{grid-template-columns:1fr;gap:34px}.step::after{display:none}}

/* ---- ABOUT / registry card ---- */
.about{padding:120px 0;border-top:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,6vw,90px);align-items:center}
.about-text p{font-size:clamp(17px,1.8vw,21px);line-height:1.55;color:var(--ink-soft);margin-top:22px;max-width:520px}
.about-text p em{font-style:italic;color:var(--ink);font-family:var(--serif)}
.about-img{width:100%;max-width:540px;height:clamp(220px,26vw,300px);object-fit:cover;margin-top:36px;border:1px solid var(--ink);box-shadow:12px 12px 0 var(--rust);border-radius:3px}
.doc{background:var(--paper-2);border:1px solid var(--ink);border-radius:4px;padding:34px;position:relative;box-shadow:14px 14px 0 var(--ink);transform:rotate(-1.4deg);transition:transform .5s var(--ease)}
.doc:hover{transform:rotate(0)}
.doc::before{content:"KRS";position:absolute;top:26px;right:30px;font-family:var(--serif);font-style:italic;font-size:44px;color:var(--rust);opacity:.16}
.doc h5{font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--line);padding-bottom:16px}
.doc-row{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px dotted var(--line);font-size:14px}
.doc-row .lab{font-family:var(--mono);font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.doc-row .val{font-weight:600;text-align:right}
.stamp{margin-top:24px;display:inline-flex;align-items:center;gap:12px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--forest)}
.stamp .s-dot{width:8px;height:8px;border-radius:50%;background:var(--forest);box-shadow:0 0 0 4px rgba(30,58,42,.16)}
@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:50px}.doc{transform:rotate(0);box-shadow:8px 8px 0 var(--ink)}}

/* ---- CONTACT ---- */
.contact{padding:120px 0 40px;background:var(--forest);color:var(--paper)}
.contact .sec-title{color:var(--paper)}
.contact .eyebrow{color:var(--sand)}
.contact .eyebrow::before{background:var(--sand)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,80px);margin-top:50px}
.c-info a.big{font-family:var(--serif);font-weight:340;font-size:clamp(1.6rem,3.4vw,2.6rem);letter-spacing:-.02em;color:var(--paper);display:inline-block;position:relative;transition:color .3s}
.c-info a.big:hover{color:var(--sand)}
.c-block{margin-top:34px}
.c-block .k{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--sand)}
.c-block p{margin-top:8px;font-size:16px;color:rgba(246,240,228,.85);line-height:1.6}
form{display:flex;flex-direction:column;gap:2px}
.field{position:relative;border-bottom:1px solid rgba(246,240,228,.3)}
.field input,.field textarea,.field select{cursor:none;width:100%;background:transparent;border:none;padding:20px 2px 12px;font-family:var(--sans);font-size:16px;color:var(--paper);outline:none}
@media(hover:none){.field input,.field textarea,.field select{cursor:auto}}
.field select option{color:var(--ink)}
.field label{position:absolute;left:2px;top:20px;font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:rgba(246,240,228,.55);pointer-events:none;transition:.3s var(--ease)}
.field input:focus+label,.field input:not(:placeholder-shown)+label,
.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label,
.field.filled label{top:2px;font-size:10px;color:var(--sand)}
.field textarea{resize:none;min-height:70px}
form .btn{margin-top:26px;align-self:flex-start;border-color:var(--paper);color:var(--paper)}
form .btn:hover{background:var(--rust);border-color:var(--rust)}
.form-note{font-family:var(--mono);font-size:11px;color:rgba(246,240,228,.5);margin-top:14px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;gap:50px}}

/* ---- FOOTER ---- */
footer{background:var(--ink);color:var(--paper);padding:70px clamp(18px,4vw,54px) 34px}
.foot-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;padding-bottom:44px;border-bottom:1px solid rgba(246,240,228,.16)}
.foot-brand{font-family:var(--serif);font-size:clamp(3rem,9vw,7rem);font-weight:340;letter-spacing:-.03em;line-height:.9}
.foot-brand em{font-style:italic;color:var(--rust)}
.foot-legal{font-family:var(--mono);font-size:11.5px;color:rgba(246,240,228,.55);line-height:2;text-align:right}
.foot-legal b{color:var(--paper)}
.foot-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:26px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:rgba(246,240,228,.5)}
@media(max-width:640px){.foot-legal{text-align:left}}

/* ============ SUBPAGES ============ */
.svc-link{position:absolute;inset:0;z-index:6}
.svc{cursor:none}

.sub-hero{padding:150px clamp(18px,4vw,54px) 60px;display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:center;min-height:90vh}
.kicker{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--accent,var(--rust));display:inline-flex;align-items:center;gap:10px}
.kicker::before{content:"";width:26px;height:1px;background:var(--accent,var(--rust))}
.sub-hero h1{font-family:var(--serif);font-weight:340;font-size:clamp(2.6rem,7vw,6rem);line-height:.95;letter-spacing:-.03em;margin-top:22px}
.sub-hero h1 em{font-style:italic;color:var(--accent,var(--rust))}
.sub-lead{max-width:520px;margin-top:26px;font-size:clamp(16px,1.55vw,20px);color:var(--ink-soft)}
.sub-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.sub-figure{position:relative}
.sub-hero-img{position:relative;height:min(64vh,560px);border:1px solid var(--ink);box-shadow:16px 16px 0 var(--accent,var(--rust));overflow:hidden;border-radius:3px;transform:translateY(24px);opacity:0;transition:transform 1s var(--ease),opacity 1s var(--ease)}
.loaded .sub-hero-img{transform:none;opacity:1}
.sub-hero-img img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);transition:transform 8s var(--ease)}
.loaded .sub-hero-img img{transform:scale(1)}
.sub-badge{position:absolute;top:-26px;left:-14px;font-family:var(--serif);font-style:italic;font-size:clamp(4rem,9vw,7rem);color:var(--accent,var(--rust));opacity:.9;z-index:2;line-height:1;text-shadow:0 2px 20px rgba(0,0,0,.15)}
@media(max-width:860px){.sub-hero{grid-template-columns:1fr;min-height:auto;padding-top:120px}.sub-hero-img{height:46vh;box-shadow:9px 9px 0 var(--accent,var(--rust))}.sub-badge{font-size:3.4rem;top:-18px}}

.sub-what{padding:100px 0;border-top:1px solid var(--line)}
.what-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:40px;background:var(--line);border:1px solid var(--line)}
.what-item{background:var(--paper);padding:34px 30px;transition:background .4s var(--ease)}
.what-item:hover{background:var(--paper-2)}
.what-item .n{font-family:var(--mono);font-size:12px;color:var(--accent,var(--rust));letter-spacing:.08em}
.what-item h4{font-family:var(--serif);font-weight:400;font-size:1.45rem;margin:14px 0 9px;letter-spacing:-.01em}
.what-item p{font-size:14.5px;color:var(--ink-soft)}
@media(max-width:900px){.what-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.what-grid{grid-template-columns:1fr}}

.gallery2{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--rust);border-bottom:1px solid var(--rust)}
.gal-item{position:relative;height:clamp(300px,42vw,540px);overflow:hidden;background:var(--ink)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease)}
.gal-item:hover img{transform:scale(1.06)}
.gal-item:first-child{border-right:1px solid var(--rust)}
.gal-cap{position:absolute;left:22px;bottom:18px;z-index:2;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--paper);background:rgba(23,19,13,.55);padding:6px 12px;backdrop-filter:blur(4px)}
@media(max-width:560px){.gallery2{grid-template-columns:1fr}.gal-item:first-child{border-right:none;border-bottom:1px solid var(--rust)}}

.sub-cta{position:relative;padding:clamp(80px,12vw,120px) clamp(18px,4vw,54px);text-align:center;background:var(--ink);color:var(--paper);overflow:hidden}
.sub-cta h2{font-family:var(--serif);font-weight:340;font-size:clamp(2rem,5vw,4rem);letter-spacing:-.02em;max-width:18ch;margin:0 auto;line-height:1.02}
.sub-cta h2 em{font-style:italic;color:var(--rust)}
.sub-cta .btn{margin-top:32px;border-color:var(--paper);color:var(--paper)}
.sub-cta .btn:hover{background:var(--rust);border-color:var(--rust);color:var(--paper-2)}
.sub-cta .kicker{color:var(--sand);justify-content:center;margin-bottom:8px}
.sub-cta .kicker::before{background:var(--sand)}
.backlink{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);margin-top:22px;transition:color .3s}
.backlink:hover{color:var(--rust)}

.what-cta{background:var(--accent,var(--rust));color:var(--paper-2);display:flex;flex-direction:column;justify-content:space-between;text-decoration:none;transition:background .4s var(--ease)}
.what-cta:hover{background:var(--ink)}
.what-cta .n{color:rgba(246,240,228,.65)}
.what-cta h4{color:var(--paper-2);margin:14px 0 0}
.what-cta .ar{font-size:1.9rem;margin-top:auto;line-height:1;transition:transform .4s var(--ease)}
.what-cta:hover .ar{transform:translateX(6px)}
