/* ============================================================
   Canyon Icon — Worldwide
   Ultra-modern editorial system
   ============================================================ */

:root{
  --ink:#0c0a08;
  --ink-2:#141210;
  --paper:#f3f0ea;
  --paper-2:#e9e4da;
  --line:rgba(12,10,8,.14);
  --line-d:rgba(243,240,234,.16);
  --muted:#7a7164;
  --accent:#c9a06a;
  --accent-2:#e7c89a;

  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Jost","Helvetica Neue",Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --pad:clamp(1.15rem,5vw,5.5rem);
  --e:cubic-bezier(.19,1,.22,1);
  --e2:cubic-bezier(.65,.05,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html.lenis{scroll-behavior:auto}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:auto;
}
body.cursor-on{cursor:none}
body.cursor-on a,body.cursor-on button,body.cursor-on [data-cursor-hover]{cursor:none}
body.lock{overflow:hidden}
img{display:block;width:100%;height:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
ul{list-style:none}
section{position:relative}
em{font-style:italic}
::selection{background:var(--accent);color:var(--ink)}

/* ---------- Grain ---------- */
.grain{
  position:fixed;inset:-8%;width:116%;height:116%;z-index:9998;
  pointer-events:none;opacity:.32;mix-blend-mode:overlay;
  will-change:transform;contain:strict;
  animation:grain 6s steps(6) infinite;
}
@keyframes grain{
  0%{transform:translate(0,0)}10%{transform:translate(-4%,-2%)}
  30%{transform:translate(3%,-3%)}50%{transform:translate(-2%,4%)}
  70%{transform:translate(4%,2%)}90%{transform:translate(-3%,-4%)}
  100%{transform:translate(0,0)}
}

/* ---------- Scroll progress ---------- */
.progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:9997;background:transparent}
.progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));box-shadow:0 0 14px rgba(201,160,106,.6)}

/* ---------- Custom cursor ---------- */
.cursor{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;mix-blend-mode:difference;opacity:0;transition:opacity .4s}
.cursor.on{opacity:1}
.cursor__dot{position:absolute;width:6px;height:6px;border-radius:50%;background:#fff;transform:translate(-50%,-50%)}
.cursor__ring{
  position:absolute;width:42px;height:42px;border:1px solid rgba(255,255,255,.7);border-radius:50%;
  transform:translate(-50%,-50%) scale(1);transition:width .35s var(--e),height .35s var(--e),background .35s;
  display:grid;place-items:center;
}
.cursor__label{font-family:var(--mono);font-size:.55rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;opacity:0;transform:scale(.6);transition:opacity .3s,transform .3s}
.cursor.hover .cursor__ring{width:96px;height:96px;background:rgba(255,255,255,.06)}
.cursor.view .cursor__ring{width:104px;height:104px;background:rgba(255,255,255,.1)}
.cursor.view .cursor__label{opacity:1;transform:scale(1)}
.cursor.hover .cursor__dot{opacity:0}

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:10000;background:var(--ink);color:var(--paper);display:grid;place-items:center;overflow:hidden}
.preloader.done{pointer-events:none}
.preloader::after{content:"";position:absolute;inset:0;background:var(--ink);transform-origin:top;transition:transform 1s var(--e)}
.preloader.done::after{transform:scaleY(0)}
.preloader__inner{text-align:center;transition:opacity .5s,transform .8s var(--e)}
.preloader.done .preloader__inner{opacity:0;transform:translateY(-30px)}
.preloader__logo{width:clamp(2.6rem,7vw,4rem);height:clamp(2.6rem,7vw,4rem);display:block;margin:0 auto 1.4rem;color:var(--paper);animation:logoPulse 1.8s var(--e) infinite alternate}
@keyframes logoPulse{from{opacity:.4;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.preloader__mark{display:block;font-family:var(--serif);font-size:clamp(2rem,7vw,4rem);letter-spacing:.18em;text-transform:uppercase;overflow:hidden}
.preloader__sub{display:block;margin-top:.6rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.5em;text-transform:uppercase;opacity:.6}
.preloader__count{position:absolute;right:var(--pad);bottom:var(--pad);font-family:var(--serif);font-size:clamp(3rem,12vw,9rem);line-height:1;font-weight:300}
.preloader__count i{font-family:var(--mono);font-size:1rem;font-style:normal;vertical-align:super;opacity:.5}
.preloader__bar{position:absolute;left:var(--pad);right:var(--pad);bottom:calc(var(--pad) - 12px);height:1px;background:rgba(243,240,234,.2)}
.preloader__bar span{display:block;height:100%;width:0;background:var(--accent)}
.preloader.done .preloader__count,.preloader.done .preloader__bar{opacity:0;transition:opacity .4s}

.boot [data-split] .w__i,
.boot .fade-up,
.boot .line span,
.boot .split-lines .ln__i{transform:translateY(110%)}
.boot .reveal-img{clip-path:inset(100% 0 0 0)}

/* ---------- Eyebrow / shared ---------- */
.section-head{padding:0 var(--pad);margin-bottom:clamp(2rem,5vw,4rem)}
.section-head--center{text-align:center}
.section-head__num{font-family:var(--mono);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:1rem}
.section-head__title{font-family:var(--serif);font-size:clamp(2.4rem,8vw,6rem);font-weight:400;line-height:.98;text-transform:uppercase;letter-spacing:.005em}

/* split text */
.split .w{display:inline-block;overflow:hidden;vertical-align:top}
.split .w__i{display:inline-block;transform:translateY(110%);transition:transform 1s var(--e)}
.split.in .w__i{transform:translateY(0)}
.split-lines .ln{display:block;overflow:hidden}
.split-lines .ln__i{display:block;transform:translateY(110%);transition:transform 1.1s var(--e)}
.split-lines.in .ln__i{transform:translateY(0)}
.line{display:inline-block;overflow:hidden}
.line span{display:inline-block;transform:translateY(110%);transition:transform 1s var(--e) .2s}
.line.in span,.in .line span{transform:translateY(0)}
.fade-up{opacity:0;transform:translateY(34px);transition:opacity 1s var(--e),transform 1s var(--e)}
.fade-up.in{opacity:1;transform:none}
.reveal-img{clip-path:inset(100% 0 0 0);transition:clip-path 1.2s var(--e)}
.reveal-img.in{clip-path:inset(0 0 0 0)}
.reveal-img img{transform:scale(1.25);transition:transform 1.6s var(--e)}
.reveal-img.in img{transform:scale(1)}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;align-items:center;justify-content:space-between;padding:1.4rem var(--pad);color:#fff;transition:transform .5s var(--e),background .5s,color .5s,padding .5s,backdrop-filter .5s}
.site-header.hide{transform:translateY(-110%)}
.site-header.solid{background:rgba(243,240,234,.7);backdrop-filter:saturate(180%) blur(18px);color:var(--ink);border-bottom:1px solid var(--line);padding-top:1rem;padding-bottom:1rem}
.brand{display:flex;align-items:center;gap:.6rem;line-height:1}
.brand__mark{width:1.7rem;height:1.7rem;display:block;flex:none;transition:transform .6s var(--e)}
.brand:hover .brand__mark{transform:rotate(-8deg) scale(1.05)}
.brand__name{font-family:var(--serif);font-size:1.45rem;letter-spacing:.14em;text-transform:uppercase}
.brand__tag{font-size:.7rem;opacity:.6}
.nav__list{display:flex;gap:2.4rem}
.nav__list a{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;position:relative;padding:.3rem 0;opacity:.85;transition:opacity .3s}
.nav__list a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:currentColor;transition:width .5s var(--e)}
.nav__list a:hover,.nav__list a.active{opacity:1}
.nav__list a:hover::after,.nav__list a.active::after{width:100%}
.header__actions{display:flex;align-items:center;gap:1.3rem}
.clock{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;opacity:.7}
.pill{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;border:1px solid currentColor;border-radius:999px;padding:.55rem 1.2rem;overflow:hidden;position:relative}
.pill span{position:relative;z-index:1;display:block;transition:color .45s var(--e)}
.pill::before{content:"";position:absolute;inset:0;background:#fff;transform:translateY(101%);transition:transform .5s var(--e)}
.site-header.solid .pill::before{background:var(--ink)}
.pill:hover::before{transform:translateY(0)}
.pill:hover span{color:var(--ink)}
.site-header.solid .pill:hover span{color:var(--paper)}
.burger{display:none;background:none;border:0;width:30px;height:16px;position:relative;color:inherit}
.burger span{position:absolute;left:0;height:1.5px;width:100%;background:currentColor;transition:transform .45s var(--e),opacity .3s}
.burger span:nth-child(1){top:1px}.burger span:nth-child(2){bottom:1px}
.burger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.burger.open span:nth-child(2){transform:translateY(-7px) rotate(-45deg)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:80;background:var(--ink);color:var(--paper);display:flex;flex-direction:column;justify-content:center;padding:var(--pad);clip-path:circle(0 at calc(100% - 3rem) 3rem);transition:clip-path .8s var(--e);pointer-events:none}
.mobile-menu.open{clip-path:circle(160% at calc(100% - 3rem) 3rem);pointer-events:auto}
.mobile-menu nav{display:flex;flex-direction:column;gap:.2rem}
.mobile-menu nav a{font-family:var(--serif);font-size:clamp(2.2rem,11vw,4rem);text-transform:uppercase;opacity:0;transform:translateY(30px);transition:opacity .6s var(--e),transform .6s var(--e);display:flex;align-items:baseline;gap:1rem}
.mobile-menu nav a i{font-family:var(--mono);font-size:.8rem;font-style:normal;opacity:.5}
.mobile-menu.open nav a{opacity:1;transform:none}
.mobile-menu.open nav a:nth-child(1){transition-delay:.2s}
.mobile-menu.open nav a:nth-child(2){transition-delay:.28s}
.mobile-menu.open nav a:nth-child(3){transition-delay:.36s}
.mobile-menu.open nav a:nth-child(4){transition-delay:.44s}
.mobile-menu__foot{margin-top:3rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;opacity:.45}

/* ---------- Hero ---------- */
.hero{height:100svh;min-height:620px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end}
.hero__layer{position:absolute;inset:0;z-index:0;will-change:transform}
.hero__layer--img{inset:-8% -4%}
.hero__layer--img img{transform:scale(1.12);animation:heroIn 1.6s var(--e) .3s both}
@keyframes heroIn{from{transform:scale(1.28)}to{transform:scale(1.12)}}
.hero__glow{z-index:1;background:radial-gradient(closest-side at 74% 26%,rgba(231,200,154,.28),transparent 70%);mix-blend-mode:screen}
.hero__vignette{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,8,7,.62) 0%,rgba(10,8,7,.32) 28%,rgba(10,8,7,.34) 50%,rgba(10,8,7,.86) 100%),linear-gradient(90deg,rgba(10,8,7,.5) 0%,transparent 42%)}
.hero__inner{position:relative;z-index:3;color:#fff;padding:0 var(--pad) clamp(2rem,6vh,4rem);width:100%;max-width:1500px}
.hero__eyebrow{font-family:var(--mono);font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;color:rgba(255,255,255,.78);margin-bottom:1rem}
.hero__title{font-family:var(--serif);font-weight:400;font-size:clamp(3.4rem,15.5vw,15rem);line-height:.86;letter-spacing:-.015em;text-transform:uppercase;margin-bottom:1.6rem}
.hero__row{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.hero__sub{font-size:clamp(1rem,1.5vw,1.3rem);max-width:40ch;color:rgba(255,255,255,.85);font-weight:300}
.btn{display:inline-flex;align-items:center;gap:1rem;font-family:var(--mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:#fff;padding:1rem 1.6rem 1rem 0;position:relative}
.btn__icon{width:46px;height:46px;border:1px solid rgba(255,255,255,.55);border-radius:50%;display:grid;place-items:center;transition:background .45s var(--e),border-color .45s}
.btn__icon svg{width:22px;height:22px;transition:transform .5s var(--e)}
.btn:hover .btn__icon{background:#fff;border-color:#fff}
.btn:hover .btn__icon svg{transform:translateX(5px);stroke:var(--ink);color:var(--ink)}
.btn::before{content:"";position:absolute;left:0;right:46px;bottom:0;height:1px;background:rgba(255,255,255,.35)}
.hero__foot{position:relative;z-index:3;display:flex;justify-content:space-between;align-items:center;padding:1.4rem var(--pad);border-top:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.7);font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}
.hero__scroll{display:flex;align-items:center;gap:.7rem}
.hero__scroll i{width:46px;height:1px;background:rgba(255,255,255,.4);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;inset:0;background:#fff;transform:translateX(-100%);animation:scrollX 2s var(--e) infinite}
@keyframes scrollX{0%{transform:translateX(-100%)}55%{transform:translateX(0)}100%{transform:translateX(100%)}}

/* ---------- Statement ---------- */
.statement{padding:clamp(5rem,15vh,12rem) var(--pad);max-width:1400px;margin:auto}
.statement__text{font-family:var(--serif);font-size:clamp(1.8rem,5.4vw,4.4rem);line-height:1.14;font-weight:300}

/* ---------- Stats ---------- */
.stats{padding:0 var(--pad) clamp(4rem,10vh,8rem)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.stat{padding:2.4rem 1rem;border-right:1px solid var(--line)}
.stat:last-child{border-right:0}
.stat__num{font-family:var(--serif);font-size:clamp(2.8rem,7vw,5.5rem);line-height:1;display:block;font-weight:400}
.stat__label{font-family:var(--mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.6rem;display:block}

/* ---------- Work ---------- */
.work{padding:clamp(3rem,8vh,6rem) 0 clamp(4rem,10vh,9rem)}
.grid{padding:0 var(--pad);display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,1.6vw,1.5rem);perspective:1400px}
.tile{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--ink);border-radius:3px;transform-style:preserve-3d;transition:transform .5s var(--e)}
.tile--tall{grid-row:span 2;aspect-ratio:3/4}
.tile--wide{grid-column:1/-1;aspect-ratio:21/9}
.tile__media{position:absolute;inset:0;transform:translateZ(0)}
.tile__media img{transition:transform 1.1s var(--e),filter 1.1s var(--e);filter:grayscale(100%) brightness(.78) contrast(1.05)}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(12,10,8,.82) 100%)}
.tile:hover img{transform:scale(1.07);filter:grayscale(0) brightness(.95)}
.tile__body{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(1.4rem,3vw,2.8rem);color:#fff;transform:translateZ(40px)}
.tile__index{font-family:var(--mono);font-size:.7rem;letter-spacing:.3em;opacity:.7;display:block;margin-bottom:.7rem}
.tile__title{font-family:var(--serif);font-size:clamp(1.8rem,3.6vw,3.2rem);font-weight:400;text-transform:uppercase;line-height:1}
.tile__desc{font-size:.94rem;max-width:40ch;color:rgba(255,255,255,.8);margin-top:.7rem;max-height:0;opacity:0;overflow:hidden;transition:max-height .6s var(--e),opacity .5s,margin .6s}
.tile:hover .tile__desc{max-height:130px;opacity:1}
.tile__cta{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;margin-top:1.1rem}
.tile__cta i{width:30px;height:1px;background:#fff;display:block;transition:width .5s var(--e)}
.tile:hover .tile__cta i{width:58px}

/* ---------- Marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.4rem 0;overflow:hidden;margin-bottom:clamp(3rem,8vh,6rem)}
.marquee__track{display:flex;gap:2.4rem;white-space:nowrap;width:max-content;font-family:var(--serif);font-size:clamp(1.6rem,3.4vw,3rem);text-transform:uppercase;letter-spacing:.04em;will-change:transform}
.marquee__track i{color:var(--accent);font-style:normal}

/* ---------- Gallery ---------- */
.gallery{padding:0 var(--pad);display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(.8rem,1.6vw,1.6rem);align-items:start}
.gallery__item{will-change:transform}
.gallery__item--down{margin-top:clamp(2rem,7vw,5rem)}
.gallery__mask{aspect-ratio:3/4;overflow:hidden;border-radius:3px}
.gallery__mask img{filter:grayscale(100%);transition:transform 1.4s var(--e),filter .8s}
.gallery__item:hover .gallery__mask img{transform:scale(1.06);filter:grayscale(0)}
.gallery figcaption{display:flex;justify-content:space-between;align-items:baseline;margin-top:1rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase}
.gallery figcaption i{color:var(--muted);font-style:normal}

/* ---------- Ethos ---------- */
.ethos{padding:clamp(5rem,13vh,11rem) var(--pad);background:var(--ink);color:var(--paper);overflow:hidden}
.aurora{position:absolute;inset:0;z-index:0;pointer-events:none;filter:blur(52px);opacity:.5;contain:strict}
.aurora span{position:absolute;width:46vw;height:46vw;border-radius:50%;mix-blend-mode:screen;will-change:transform}
.aurora span:nth-child(1){background:#6b5436;top:-10%;left:-5%;animation:au1 16s ease-in-out infinite alternate}
.aurora span:nth-child(2){background:#34506b;bottom:-15%;right:-8%;animation:au2 19s ease-in-out infinite alternate}
.aurora span:nth-child(3){background:#5a3a5c;top:30%;left:45%;animation:au3 22s ease-in-out infinite alternate}
.aurora--warm span:nth-child(1){background:#7a5a32}.aurora--warm span:nth-child(2){background:#8a4f2e}
@keyframes au1{to{transform:translate(18vw,12vh) scale(1.2)}}
@keyframes au2{to{transform:translate(-16vw,-10vh) scale(1.15)}}
@keyframes au3{to{transform:translate(-10vw,14vh) scale(.85)}}
.ethos__grid{position:relative;z-index:1;max-width:1400px;margin:auto;display:grid;gap:clamp(2.5rem,6vw,5rem)}
.ethos__lead .section-head__num{color:rgba(243,240,234,.55)}
.ethos__lead h2{font-family:var(--serif);font-weight:300;font-style:italic;font-size:clamp(2rem,5.6vw,4.4rem);line-height:1.1;max-width:18ch;margin-top:1.2rem;text-transform:none}
.ethos__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(2rem,4vw,3.5rem);border-top:1px solid var(--line-d);padding-top:clamp(2rem,4vw,3rem)}
.ethos__k{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;color:var(--accent);display:block;margin-bottom:1rem}
.ethos__col h4{font-size:.95rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;margin-bottom:.9rem}
.ethos__col p{color:rgba(243,240,234,.7);font-size:.96rem;font-weight:300}

/* ---------- Contact ---------- */
.contact{padding:clamp(6rem,18vh,14rem) var(--pad);text-align:center;background:var(--ink);color:var(--paper);overflow:hidden}
.contact .aurora{opacity:.4}
.contact__eyebrow{position:relative;z-index:1;font-family:var(--mono);font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;color:var(--accent)}
.contact__title{position:relative;z-index:1;font-family:var(--serif);font-weight:400;font-size:clamp(2.6rem,10vw,9rem);line-height:.95;margin:1.4rem 0 2.4rem;text-transform:uppercase}
.contact__mail{position:relative;z-index:1;font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,3.6vw,2.6rem);border-bottom:1px solid rgba(243,240,234,.4);padding-bottom:.25rem;transition:color .4s,border-color .4s}
.contact__mail:hover{color:var(--accent);border-color:var(--accent)}
.contact__meta{position:relative;z-index:1;margin-top:2.8rem;display:flex;justify-content:center;flex-wrap:wrap;gap:.9rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(243,240,234,.55)}
.contact__meta i{opacity:.4}

/* ---------- Footer ---------- */
.site-footer{padding:clamp(2.5rem,5vw,4rem) var(--pad);background:var(--ink);color:var(--paper);border-top:1px solid var(--line-d)}
.site-footer__top{display:flex;justify-content:space-between;align-items:center;padding-bottom:2.6rem;flex-wrap:wrap;gap:1rem}
.brand--footer{color:var(--paper)}
.brand--footer .brand__mark{width:clamp(1.8rem,4vw,2.6rem);height:clamp(1.8rem,4vw,2.6rem)}
.site-footer__top .brand__name{font-size:clamp(1.8rem,7vw,3.4rem)}
.to-top{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;display:inline-flex;gap:.6rem;border-bottom:1px solid var(--paper);padding-bottom:.25rem}
.site-footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(243,240,234,.5);border-top:1px solid var(--line-d);padding-top:1.6rem}

/* ---------- Sub-pages ---------- */
.hero--page{height:auto;min-height:80svh}
.hero--page .hero__title{font-size:clamp(3rem,13vw,12rem)}
.hero__back{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.82);margin-bottom:1.6rem}
.hero__back i{width:30px;height:1px;background:currentColor;display:block;transition:width .5s var(--e)}
.hero__back:hover i{width:54px}
.caps{padding:clamp(2rem,5vh,4rem) var(--pad) clamp(4rem,10vh,8rem)}
.caps__grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.caps__item{padding:2.4rem 1.4rem 2.4rem 0;border-right:1px solid var(--line)}
.caps__item:last-child{border-right:0;padding-right:0}
.caps__k{font-family:var(--mono);font-size:.7rem;letter-spacing:.2em;color:var(--accent);display:block;margin-bottom:1rem}
.caps__item h3{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,2rem);font-weight:400;text-transform:uppercase;margin-bottom:.7rem;line-height:1}
.caps__item p{color:var(--muted);font-size:.94rem;font-weight:300}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .nav,.pill,.clock{display:none}
  .burger{display:block}
  .grid{grid-template-columns:1fr}
  .tile--tall,.tile--wide{grid-row:auto;grid-column:auto;aspect-ratio:4/3}
  .tile__desc{max-height:130px;opacity:1}
  .ethos__cols{grid-template-columns:1fr;gap:2.2rem}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .stats__grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:0}
  .hero__row{align-items:flex-start;flex-direction:column;gap:1.6rem}
  .caps__grid{grid-template-columns:1fr}
  .caps__item{border-right:0;border-bottom:1px solid var(--line);padding:1.8rem 0}
  .caps__item:last-child{border-bottom:0}
}
@media (max-width:560px){
  .gallery{grid-template-columns:1fr}
  .gallery__item--down{margin-top:0}
  .stats__grid{grid-template-columns:1fr}
  .stat{border-right:0;border-bottom:1px solid var(--line)}
  .site-footer__bottom{flex-direction:column}
  .hero__foot{font-size:.62rem}
}

@media (hover:none){
  .cursor{display:none}body.cursor-on{cursor:auto}
  .grain{display:none}
  .site-header.solid{backdrop-filter:none;background:rgba(243,240,234,.94)}
  .aurora{filter:blur(38px);opacity:.4}
  .aurora span:nth-child(3){display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  .fade-up,.split .w__i,.split-lines .ln__i,.line span{opacity:1!important;transform:none!important}
  .reveal-img{clip-path:none!important}
  .grain{display:none}
}
