/* ============================================================
   SHAALAM — Sections
   ============================================================ */

/* ===========================================================
   HERO  (shared)
   =========================================================== */
.hero{position:relative;height:100svh;min-height:660px;overflow:hidden;color:var(--cream);background:var(--green-900)}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media video,.hero__media img{
  position:absolute;inset:-2% ;width:104%;height:104%;object-fit:cover;
  will-change:transform;
}
.hero__scrim{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(120% 90% at 50% 8%,rgba(21,23,15,.10),transparent 55%),
    linear-gradient(180deg,rgba(21,23,15,.46) 0%,rgba(21,23,15,.12) 32%,rgba(21,23,15,.16) 62%,rgba(21,23,15,.74) 100%);
}
.hero__grain{position:absolute;inset:0;z-index:2;opacity:.5;pointer-events:none;mix-blend-mode:soft-light}
.hero__inner{position:relative;z-index:3;height:100%;width:100%}

.scrollcue{
  position:absolute;left:50%;bottom:clamp(22px,3.4vh,40px);transform:translateX(-50%);
  z-index:5;display:flex;flex-direction:column;align-items:center;gap:12px;
  font-size:10px;letter-spacing:.34em;text-transform:uppercase;opacity:.85;
}
.scrollcue .bar{width:1px;height:46px;background:linear-gradient(var(--cream),transparent);position:relative;overflow:hidden}
.scrollcue .bar::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--cream);animation:cue 2.1s var(--ease-inout) infinite}
@keyframes cue{0%{top:-55%}60%,100%{top:120%}}

.hero__corner{position:absolute;z-index:5;font-size:var(--fs-label);letter-spacing:.26em;text-transform:uppercase;opacity:.9}
.hero__corner.tl{top:auto;bottom:clamp(22px,4vh,46px);left:var(--pad)}
.hero__corner.br{bottom:clamp(22px,4vh,46px);right:var(--pad);text-align:right}

/* word reveal mask */
.reveal-line{display:block;overflow:hidden;padding-top:.04em;margin-top:-.04em}
.reveal-line>span{display:block;transform:translateY(110%);transition:transform 1.15s var(--ease-out)}
.is-lit .reveal-line>span{transform:none}
.reveal-line.d1>span{transition-delay:.06s}
.reveal-line.d2>span{transition-delay:.14s}
.reveal-line.d3>span{transition-delay:.22s}
.reveal-line.d4>span{transition-delay:.3s}

/* ---- Hero v1 : Editorial centred ---- */
.hero[data-hero="1"] .h-v1{display:grid}
.hero .h-v1{display:none;place-items:center;height:100%;text-align:center;padding-inline:var(--pad)}
.h-v1 .kicker{margin-bottom:clamp(20px,3vh,34px);opacity:.92}
.h-v1 .word{font-family:"Channe",serif;font-size:var(--fs-mega);line-height:1.06;letter-spacing:-.02em;padding-top:.04em;text-shadow:0 8px 60px rgba(21,23,15,.34)}
.h-v1 .tag{max-width:42ch;margin:clamp(22px,3.4vh,40px) auto 0;font-weight:200;font-size:var(--fs-lead);line-height:1.45;opacity:.94}
.h-v1 .emblem{margin-top:26px;display:inline-flex;gap:16px;align-items:center;font-size:var(--fs-label);letter-spacing:.36em;text-transform:uppercase;opacity:.8}
.h-v1 .emblem .sym{width:20px;height:20px}
.h-v1 .emblem .sym .c-stroke{stroke:currentColor;stroke-width:1.5;fill:none;vector-effect:non-scaling-stroke}

/* ---- Hero v2 : Type-driven split / emblema ---- */
.hero[data-hero="2"] .h-v2{display:grid}
.hero .h-v2{display:none;height:100%;grid-template-rows:1fr auto;padding:0 var(--pad) clamp(34px,6vh,72px)}
.h-v2 .v2-top{align-self:start;padding-top:clamp(120px,16vh,180px);display:flex;justify-content:space-between;gap:30px}
.h-v2 .v2-vert{writing-mode:vertical-rl;transform:rotate(180deg);font-size:var(--fs-label);letter-spacing:.4em;text-transform:uppercase;opacity:.84}
.h-v2 .v2-mani{max-width:30ch;font-weight:200;font-size:clamp(17px,1.6vw,23px);line-height:1.45;opacity:.95;align-self:start}
.h-v2 .v2-word{font-family:"Channe",serif;font-size:var(--fs-h1);line-height:1.02;letter-spacing:-.02em;padding-top:.04em}
.h-v2 .v2-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.h-v2 .v2-emblem{font-size:var(--fs-label);letter-spacing:.32em;text-transform:uppercase;opacity:.82;text-align:right;line-height:2}

/* ---- Hero v3 : Clip-text immersive (knockout) ---- */
.hero[data-hero="3"]{background:var(--cream);color:var(--green-800)}
.hero[data-hero="3"] .hero__scrim{display:none}
.hero[data-hero="3"] .hero__media{opacity:0}
.hero[data-hero="3"] .h-v3{display:flex}
.hero[data-hero="3"] .scrollcue,.hero[data-hero="3"] .hero__corner{color:var(--green-700)}
.hero[data-hero="3"] .scrollcue .bar{background:linear-gradient(var(--green-700),transparent)}
.hero[data-hero="3"] .scrollcue .bar::after{background:var(--green-700)}
.hero .h-v3{display:none;flex-direction:column;justify-content:space-between;height:100%;padding:clamp(96px,13vh,150px) var(--pad) clamp(34px,5vh,70px)}
.h-v3 .v3-top{display:flex;justify-content:space-between;align-items:baseline;gap:20px;flex-wrap:wrap}
.h-v3 .v3-top .kicker{color:var(--green-700)}
.h-v3 .v3-cliprow{position:relative;width:100%;height:clamp(150px,30vh,360px);margin:auto 0}
.h-v3 .v3-vid{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.h-v3 .v3-knock{position:absolute;inset:0;width:100%;height:100%}
.h-v3 .v3-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.h-v3 .v3-bottom .lead{max-width:34ch;color:var(--green-700)}
.h-v3 .v3-frame{width:clamp(132px,15vw,220px);aspect-ratio:4/5;overflow:hidden;border-radius:2px;flex:none}
.h-v3 .v3-frame video{width:100%;height:100%;object-fit:cover}
@media(max-width:640px){.h-v3 .v3-frame{display:none}}

/* hero switcher chip */
.heroswitch{
  position:fixed;z-index:210;right:var(--pad);bottom:clamp(20px,3vh,34px);
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:999px;
  background:rgba(21,23,15,.34);backdrop-filter:blur(10px);
  border:1px solid rgba(244,241,235,.26);color:var(--cream);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  transition:opacity .6s var(--ease),transform .6s var(--ease-out);
}
.heroswitch.is-gone{opacity:0;transform:translateY(14px);pointer-events:none}
.heroswitch span{opacity:.6;margin-right:2px}
.heroswitch button{width:24px;height:24px;border-radius:50%;border:1px solid rgba(244,241,235,.4);font-size:10px;letter-spacing:0;transition:all .35s var(--ease)}
.heroswitch button.is-on{background:var(--cream);color:var(--green-800);border-color:var(--cream)}

/* ===========================================================
   MARQUEE
   =========================================================== */
.marquee{overflow:hidden;white-space:nowrap;border-block:1px solid currentColor;padding-block:clamp(14px,1.7vw,26px)}
.marquee.thin{border-color:rgba(47,51,36,.18)}
.marquee__track{display:inline-flex;gap:56px;will-change:transform}
.marquee__track>span{font-family:"Channe",serif;font-size:clamp(28px,4.6vw,72px);line-height:1;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:56px}
.marquee__track .sym{width:.5em;height:.5em;opacity:.6;transform:translateY(-0.04em)}
.marquee__track .sym .c-stroke{stroke:currentColor;stroke-width:2.4;fill:none;vector-effect:non-scaling-stroke}

/* ===========================================================
   MANIFESTO
   =========================================================== */
.manifesto{background:var(--green-700);color:var(--sand);position:relative;overflow:hidden}
.manifesto .wrap{position:relative;z-index:2}
.manifesto__eyebrow{display:flex;align-items:center;gap:18px;margin-bottom:clamp(40px,7vh,90px);opacity:.7}
.manifesto__eyebrow .ln{flex:1;height:1px;background:currentColor;opacity:.4}
.manifesto__text{
  font-family:"Channe",serif;font-weight:400;
  font-size:clamp(30px,4.7vw,80px);line-height:1.07;letter-spacing:-.012em;
  max-width:21ch;
}
.manifesto__text .w{display:inline-block;opacity:.26;transition:opacity .5s var(--ease)}
.manifesto__text .w.lit{opacity:1}
.manifesto__sub{margin-top:clamp(36px,5vh,64px);max-width:52ch;font-weight:200;opacity:.78;font-size:var(--fs-lead);line-height:1.5}
.manifesto__credit{margin-top:40px;font-size:var(--fs-label);letter-spacing:.24em;text-transform:uppercase;opacity:.6}

/* concepts row — image tiles */
.concepts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:clamp(70px,11vh,140px);background:rgba(231,220,200,.18)}
.concept{position:relative;overflow:hidden;min-height:clamp(370px,48vh,580px);display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(24px,2.3vw,40px);background:var(--green-800)}
.concept__img{position:absolute;inset:0;z-index:0;overflow:hidden}
.concept__img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease-out),filter 1s var(--ease);will-change:transform}
.concept__veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(28,31,21,.12) 0%,rgba(28,31,21,.04) 30%,rgba(31,35,24,.6) 70%,rgba(21,23,15,.92) 100%);transition:opacity .6s var(--ease)}
.concept:hover .concept__veil{opacity:.8}
.concept .sym{position:relative;z-index:2;width:40px;height:40px;margin-bottom:18px;opacity:.95;transition:transform .6s var(--ease-out)}
.concept:hover .sym{transform:translateY(-4px) rotate(90deg)}
.concept .sym .c-stroke{fill:none;stroke:var(--sand);stroke-width:1.8;vector-effect:non-scaling-stroke;filter:drop-shadow(0 1px 4px rgba(21,23,15,.5))}
.concept__b{position:relative;z-index:2}
.concept h4{font-family:"Channe",serif;font-size:clamp(24px,2.1vw,34px);color:var(--cream);margin-bottom:10px;text-shadow:0 2px 14px rgba(21,23,15,.4)}
.concept p{font-size:var(--fs-body);color:var(--sand);opacity:.82;font-weight:300;max-width:24ch}
.concept .idx{position:absolute;top:18px;right:20px;z-index:2;font-size:var(--fs-label);letter-spacing:.2em;color:var(--cream);opacity:.66}
/* per-photo effects */
.fx-cuerpo .concept__img img{filter:saturate(.92) sepia(.1) brightness(.96)}
.fx-cuerpo:hover .concept__img img{filter:none;transform:scale(1.07)}
.fx-conciencia .concept__img img{filter:grayscale(.55) contrast(1.05) brightness(.98)}
.fx-conciencia:hover .concept__img img{filter:none;transform:scale(1.05)}
.fx-tierra .concept__img img{animation:kenburns 18s var(--ease-inout) infinite alternate}
@keyframes kenburns{from{transform:scale(1.05) translate(0,0)}to{transform:scale(1.16) translate(-2.5%,-2%)}}
.fx-cielo .concept__img img{filter:brightness(1.03) contrast(1.05)}
.fx-cielo .concept__img::after{content:"";position:absolute;inset:0;background:linear-gradient(115deg,transparent 40%,rgba(244,241,235,.16) 50%,transparent 60%);transform:translateX(-30%);animation:sweep 7s var(--ease-inout) infinite}
@keyframes sweep{0%,100%{transform:translateX(-60%)}50%{transform:translateX(60%)}}
.fx-cielo:hover .concept__img img{transform:scale(1.07)}
@media (prefers-reduced-motion:reduce){.fx-tierra .concept__img img,.fx-cielo .concept__img::after{animation:none}}
@media(max-width:880px){.concepts{grid-template-columns:repeat(2,1fr)}.concept{min-height:clamp(320px,40vh,420px)}}
@media(max-width:520px){.concepts{grid-template-columns:1fr}}

/* ===========================================================
   ARCHITECTURE — symbol == building (pinned scroll)
   =========================================================== */
.arch{background:var(--cream);color:var(--green-700)}
.arch__pin{position:relative;height:300vh}
.arch__stage{position:sticky;top:0;height:100svh;overflow:hidden;display:grid;place-items:center}
.arch__photo{position:absolute;inset:0;z-index:0}
.arch__photo img{width:100%;height:100%;object-fit:cover;clip-path:circle(0% at 50% 50%);will-change:clip-path,transform}
.arch__photo::after{content:"";position:absolute;inset:0;background:rgba(21,23,15,.34);opacity:0;transition:opacity .6s var(--ease)}
.arch__bigsym{position:relative;z-index:2;width:min(74vh,640px);height:min(74vh,640px)}
.arch__bigsym svg{width:100%;height:100%;overflow:visible}
.arch__bigsym .draw{fill:none;stroke:var(--green-700);stroke-width:3.4;vector-effect:non-scaling-stroke;
  stroke-linecap:round;stroke-dasharray:var(--len);stroke-dashoffset:var(--len);}
.arch__cap{position:absolute;z-index:3;left:var(--pad);bottom:clamp(34px,7vh,80px);max-width:30ch;mix-blend-mode:difference;color:#fff}
.arch__cap .kicker{opacity:.8}
.arch__cap h3{font-family:"Channe",serif;font-size:var(--fs-h3);margin-top:14px;line-height:1.02}
.arch__steps{position:absolute;z-index:3;right:var(--pad);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:14px;mix-blend-mode:difference;color:#fff}
.arch__steps span{font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase;opacity:.4;transition:opacity .4s var(--ease)}
.arch__steps span.on{opacity:1}

/* ===========================================================
   PLACE / location
   =========================================================== */
.place{background:var(--green-900);color:var(--cream);overflow:hidden;position:relative}
.place>.wrap{position:relative;z-index:3}
.place__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.place__bg video{position:absolute;inset:-4%;width:108%;height:108%;object-fit:cover;opacity:.16}
.place__bg-scrim{position:absolute;inset:0;background:linear-gradient(100deg,var(--green-900) 22%,rgba(28,31,21,.6) 60%,rgba(28,31,21,.78))}
.place__sigil{position:absolute;z-index:1;top:50%;right:-12vw;width:min(82vh,760px);height:min(82vh,760px);transform:translateY(-50%);opacity:.5;pointer-events:none;animation:sigilspin 120s linear infinite}
.place__sigil svg{width:100%;height:100%;overflow:visible;animation:sigilbreathe 9s var(--ease-inout) infinite}
.place__sigil .sigil-line{fill:none;stroke:var(--sage-soft);stroke-width:1.1;vector-effect:non-scaling-stroke;opacity:.55}
@keyframes sigilspin{to{transform:translateY(-50%) rotate(360deg)}}
@keyframes sigilbreathe{0%,100%{transform:scale(1);opacity:.9}50%{transform:scale(1.04);opacity:1}}
@media(max-width:980px){.place__sigil{right:-30vw;top:88%;width:min(70vh,520px);height:min(70vh,520px);opacity:.32}}
.place__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,90px);align-items:center}
@media(max-width:980px){.place__grid{grid-template-columns:1fr;gap:48px}}
.place__media{position:relative;aspect-ratio:5/6;overflow:hidden;border-radius:2px}
.place__media video,.place__media img{position:absolute;inset:0;width:100%;height:108%;object-fit:cover;will-change:transform}
.place__media .tag{position:absolute;left:18px;bottom:16px;z-index:2;font-size:var(--fs-label);letter-spacing:.24em;text-transform:uppercase;background:rgba(21,23,15,.4);backdrop-filter:blur(6px);padding:8px 13px;border-radius:999px}
.place h2{font-family:"Channe",serif;font-size:var(--fs-h2);line-height:.98;margin:18px 0 26px}
.place__body{max-width:44ch;font-weight:200;opacity:.82;font-size:var(--fs-lead);line-height:1.5}
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(40px,5vh,64px);border-top:1px solid rgba(244,241,235,.2);padding-top:34px}
.stat .n{font-family:"Channe",serif;font-size:clamp(34px,4vw,62px);line-height:1}
.stat .l{font-size:var(--fs-label);letter-spacing:.18em;text-transform:uppercase;opacity:.6;margin-top:8px}
@media(max-width:560px){.stats{grid-template-columns:1fr;gap:22px}}
.maplink{display:inline-flex;align-items:center;gap:12px;margin-top:36px;font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase}
.maplink .ring{width:38px;height:38px;border:1px solid currentColor;border-radius:50%;display:grid;place-items:center;transition:background .4s var(--ease),color .4s var(--ease)}
.maplink:hover .ring{background:var(--sand);color:var(--green-800)}

/* ===========================================================
   AMENITIES — sticky hover list
   =========================================================== */
.amen{background:var(--cream);color:var(--green-700)}
.amen__head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:clamp(40px,6vh,72px)}
.amen__head h2{font-family:"Channe",serif;font-size:var(--fs-h2);line-height:.96;max-width:14ch}
.amen__grid{display:grid;grid-template-columns:1fr clamp(280px,30vw,460px);gap:clamp(30px,5vw,80px);align-items:start}
@media(max-width:900px){.amen__grid{grid-template-columns:1fr}}
.amen__list{display:flex;flex-direction:column}
.amen__item{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:22px;
  padding:clamp(20px,2.4vw,30px) 0;border-top:1px solid rgba(47,51,36,.16);
  position:relative;transition:padding-left .5s var(--ease-out);
}
.amen__list .amen__item:last-child{border-bottom:1px solid rgba(47,51,36,.16)}
.amen__item .num{font-size:var(--fs-label);letter-spacing:.16em;opacity:.45}
.amen__item h3{font-family:"Channe",serif;font-size:clamp(26px,3.1vw,50px);line-height:1;transition:transform .5s var(--ease-out),opacity .4s var(--ease)}
.amen__item .meta{font-size:var(--fs-label);letter-spacing:.14em;text-transform:uppercase;opacity:.5;text-align:right}
.amen__item::before{content:"";position:absolute;left:-2px;top:50%;transform:translateY(-50%) scale(0);width:7px;height:7px;border-radius:50%;background:var(--terracotta);transition:transform .45s var(--ease-out)}
.amen__item:hover{padding-left:26px}
.amen__item:hover::before{transform:translateY(-50%) scale(1)}
.amen__item:hover h3{opacity:1}
.amen__item.dimmed h3{opacity:.34}
.amen__preview{position:sticky;top:18vh;aspect-ratio:4/5;border-radius:2px;overflow:hidden;background:var(--sand)}
@media(max-width:900px){.amen__preview{display:none}}
.amen__preview .ph{position:absolute;inset:0;opacity:0;transform:scale(1.06);transition:opacity .7s var(--ease),transform 1.1s var(--ease-out)}
.amen__preview .ph.on{opacity:1;transform:none}
.amen__preview .ph img{width:100%;height:100%;object-fit:cover}
.amen__preview .cap{position:absolute;left:16px;bottom:14px;z-index:3;color:var(--cream);font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase;mix-blend-mode:difference}

/* ===========================================================
   GALLERY — horizontal immersive
   =========================================================== */
.gallery{background:var(--green-850);color:var(--cream);padding-block:clamp(80px,11vh,150px);overflow:hidden}
.gallery__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:clamp(36px,5vh,60px)}
.gallery__head h2{font-family:"Channe",serif;font-size:var(--fs-h2)}
.gallery__scroller{display:flex;gap:clamp(16px,2vw,30px);padding-inline:var(--pad);overflow-x:auto;scroll-snap-type:x mandatory;-ms-overflow-style:none;scrollbar-width:none;cursor:none}
.gallery__scroller::-webkit-scrollbar{display:none}
.gcard{position:relative;flex:none;width:clamp(280px,40vw,620px);aspect-ratio:16/11;scroll-snap-align:center;overflow:hidden;border-radius:2px;background:var(--green-800)}
.gcard.tall{aspect-ratio:3/4;width:clamp(240px,28vw,440px)}
.gcard video,.gcard img{position:absolute;inset:0;width:100%;height:108%;object-fit:cover;transition:transform 1.4s var(--ease-out);will-change:transform}
.gcard:hover video,.gcard:hover img{transform:scale(1.05)}
.gcard .gc-meta{position:absolute;left:18px;bottom:16px;z-index:2;mix-blend-mode:difference}
.gcard .gc-meta .t{font-family:"Channe",serif;font-size:clamp(20px,2vw,30px);line-height:1}
.gcard .gc-meta .s{font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin-top:6px}
.gcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(21,23,15,.5))}
.gallery__drag{display:flex;align-items:center;gap:12px;margin-top:24px;padding-inline:var(--pad);font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase;opacity:.5}

/* ===========================================================
   CONTACT / footer
   =========================================================== */
.contact{background:var(--green-700);color:var(--cream);position:relative;overflow:hidden}
.contact__media{position:absolute;inset:0;z-index:0;opacity:.22}
.contact__media video{width:100%;height:100%;object-fit:cover}
.contact .wrap{position:relative;z-index:2}
.contact__top{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(40px,6vw,100px);align-items:end}
@media(max-width:900px){.contact__top{grid-template-columns:1fr;gap:44px}}
.contact h2{font-family:"Channe",serif;font-size:clamp(40px,7vw,120px);line-height:.92;letter-spacing:-.01em}
.contact__lead{max-width:40ch;font-weight:200;font-size:var(--fs-lead);opacity:.84;line-height:1.5;margin-bottom:30px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:22px}
.field label{font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase;opacity:.66}
.field input,.field textarea{
  background:transparent;border:0;border-bottom:1px solid rgba(244,241,235,.3);
  color:var(--cream);font-family:inherit;font-size:var(--fs-lead);font-weight:200;
  padding:10px 0;outline:none;transition:border-color .4s var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:rgba(244,241,235,.4)}
.field input:focus,.field textarea:focus{border-color:var(--sand)}
.contact__form .btn{margin-top:10px}

.foot{border-top:1px solid rgba(244,241,235,.2);margin-top:clamp(70px,10vh,130px);padding-top:48px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
@media(max-width:820px){.foot{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot{grid-template-columns:1fr}}
.foot__brand .sym{width:54px;height:54px;margin-bottom:18px}
.foot__brand .sym .c-stroke{stroke:var(--sand);stroke-width:2;fill:none;vector-effect:non-scaling-stroke}
.foot__brand .word{font-family:"Channe",serif;font-size:34px;line-height:1}
.foot h5{font-size:var(--fs-label);letter-spacing:.22em;text-transform:uppercase;opacity:.6;margin:0 0 18px;font-weight:600}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.foot a{opacity:.84;transition:opacity .35s var(--ease)}
.foot a:hover{opacity:1}
.foot__legal{margin-top:54px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;font-size:var(--fs-label);letter-spacing:.14em;text-transform:uppercase;opacity:.5}

/* ===========================================================
   PAGE INTRO loader
   =========================================================== */
.loader{position:fixed;inset:0;z-index:1000;background:var(--green-900);display:grid;place-items:center;transition:opacity .9s var(--ease),visibility .9s}
.loader.done{opacity:0;visibility:hidden}
.loader__sym{width:120px;height:120px}
.loader__sym .c-stroke{fill:none;stroke:var(--sand);stroke-width:4;vector-effect:non-scaling-stroke;
  stroke-dasharray:var(--len);stroke-dashoffset:var(--len);animation:draw 1.7s var(--ease-out) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.loader__word{position:absolute;bottom:14vh;left:0;right:0;text-align:center;font-family:"Channe",serif;color:var(--sand);font-size:22px;letter-spacing:.04em;overflow:hidden}
.loader__word span{display:inline-block;transform:translateY(110%);animation:rise .9s .7s var(--ease-out) forwards}
@keyframes rise{to{transform:none}}

/* anchor offset */
section[id]{scroll-margin-top:90px}
