/* =========================================================
   ANN WANJIKU — Premium Portfolio
   Light Editorial system · warm off-white / near-black / electric blue
   ========================================================= */

:root{
  --bg:        #FAF8F3;
  --bg-deep:   #F2EEE5;
  --ink:       #111111;
  --ink-2:     #5d5b54;
  --ink-3:     #8f8d85;
  --line:      rgba(17,17,17,0.12);
  --line-2:    rgba(17,17,17,0.07);
  --blue:      #1B36F2;
  --blue-deep: #1126C9;
  --blue-soft: rgba(27,54,242,0.10);

  --serif: "Instrument Serif", Georgia, "Times New Roman", serif;
  --sans:  "Schibsted Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;

  --ease: cubic-bezier(0.22,1,0.36,1);
  --ease-soft: cubic-bezier(0.4,0,0.2,1);

  --gut: clamp(20px, 5vw, 96px);
  --maxw: 1640px;
}

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

html{ -webkit-text-size-adjust:100%; }
html.lenis, html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-stopped{ overflow:hidden; }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
}

::selection{ background:var(--blue); color:#fff; }

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; }

/* hide native cursor on fine pointers */
@media (hover:hover) and (pointer:fine){
  html.cursor-on, html.cursor-on *{ cursor:none !important; }
}

/* ---------- scroll progress ---------- */
#progress{
  position:fixed; top:0; left:0; height:2px; width:0%;
  background:var(--blue); z-index:120; transition:width .1s linear;
}

/* ---------- custom cursor ---------- */
#cursor-ring,#cursor-dot{
  position:fixed; top:0; left:0; z-index:130; pointer-events:none;
  border-radius:50%; transform:translate(-50%,-50%);
}
#cursor-ring{
  width:38px; height:38px; border:1px solid var(--ink);
  transition:width .35s var(--ease), height .35s var(--ease),
             background .35s var(--ease), border-color .35s var(--ease), opacity .3s;
}
#cursor-dot{ width:5px; height:5px; background:var(--blue); }
html.cursor-hot #cursor-ring{ width:64px; height:64px; background:var(--blue-soft); border-color:var(--blue); }
html.cursor-hot #cursor-dot{ opacity:0; }
@media (hover:none),(pointer:coarse){ #cursor-ring,#cursor-dot{ display:none; } }

/* ---------- 3D mascot canvas ---------- */
#mascot-canvas{
  position:fixed; inset:0; width:100vw; height:100vh;
  z-index:60; pointer-events:none;
}
html.no-3d .mascot-slot{ position:relative; }
html.no-3d .mascot-slot::after{
  content:""; position:absolute; inset:18%;
  border-radius:50%; background:radial-gradient(circle at 38% 32%, #cfd6e6, #9aa6c4);
  box-shadow:0 30px 60px -20px rgba(27,54,242,.4);
}

/* ---------- layout helpers ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
section{ position:relative; }

.kicker{
  font-size:clamp(.7rem,.95vw,.82rem);
  letter-spacing:.22em; text-transform:uppercase; font-weight:600;
  color:var(--ink-2);
}
.kicker .i{ color:var(--blue); }

/* ---------- nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px var(--gut);
  transition:transform .5s var(--ease), padding .4s var(--ease);
}
.nav.hide{ transform:translateY(-130%); }
.wordmark{ display:flex; align-items:center; gap:10px; font-weight:600; font-size:1.02rem; letter-spacing:-.01em; }
.wordmark .dot{ width:7px; height:7px; border-radius:50%; background:var(--blue); display:inline-block; }
.nav-cta{
  display:inline-flex; align-items:center; gap:9px;
  font-size:.9rem; font-weight:500; padding:11px 20px;
  border:1px solid var(--ink); border-radius:100px;
  transition:background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
}
.nav-cta:hover{ background:var(--ink); color:var(--bg); }
.nav-cta .dotb{ width:6px; height:6px; border-radius:50%; background:var(--blue); }
.nav-cta:hover .dotb{ background:var(--bg); }

/* ---------- HERO ---------- */
#hero{ min-height:100svh; display:flex; align-items:center; padding-top:120px; padding-bottom:60px; }
.hero-grid{
  width:100%; max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut);
  display:grid; grid-template-columns:minmax(0,1.18fr) minmax(0,.82fr); align-items:center; gap:40px;
}
.eyebrow{ display:flex; align-items:center; gap:14px; font-size:.86rem; letter-spacing:.05em; color:var(--ink-2); margin-bottom:26px; }
.eyebrow .bar{ width:46px; height:1px; background:var(--ink); }
.hero-title{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(3.3rem, 10.4vw, 11rem);
  line-height:.92; letter-spacing:-.025em;
  text-wrap:balance;
}
.hero-title em{ font-style:italic; color:var(--blue); }
.hero-sub{
  max-width:30ch; margin-top:34px;
  font-size:clamp(1.05rem,1.45vw,1.35rem); line-height:1.5; color:var(--ink-2);
}
.hero-actions{ display:flex; align-items:center; gap:28px; margin-top:42px; flex-wrap:wrap; }

.hero-stage{ position:relative; min-height:46vh; }
.mascot-slot{ width:100%; height:100%; min-height:340px; }
.hero-stage .mascot-slot{ position:absolute; inset:0; }

.hero-foot{
  position:absolute; left:var(--gut); right:var(--gut); bottom:30px;
  display:flex; align-items:flex-end; justify-content:flex-end; gap:20px;
}
.scrollcue{ display:flex; align-items:center; gap:12px; font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; color:var(--ink-3); }
.scrollcue .ln{ width:1px; height:46px; background:var(--line); position:relative; overflow:hidden; }
.scrollcue .ln::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--ink); animation:cue 2.2s var(--ease) infinite; }
@keyframes cue{ 0%{ top:-50% } 60%,100%{ top:100% } }
@media (max-width:880px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-stage{ order:-1; min-height:38vh; }
  .hero-foot{ position:static; margin-top:40px; padding-inline:0; }
}

/* ---------- generic section heads ---------- */
.section-head{ display:flex; flex-direction:column; gap:18px; margin-bottom:clamp(40px,6vw,92px); }
.section-title{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(2.1rem,5.2vw,4.6rem); line-height:1.0; letter-spacing:-.02em; max-width:18ch;
}

/* ---------- SERVICES ---------- */
#services{ padding:clamp(90px,12vw,180px) 0; }
.service-list{ list-style:none; border-top:1px solid var(--line); }
.service-row{
  position:relative; display:grid;
  grid-template-columns:90px minmax(0,1fr) minmax(0,1.1fr) 60px;
  align-items:center; gap:24px;
  padding:clamp(20px,2.4vw,34px) 0; border-bottom:1px solid var(--line);
  transition:padding .5s var(--ease);
}
.service-row .s-num{ font-size:.85rem; color:var(--ink-3); font-variant-numeric:tabular-nums; }
.service-row .s-name{
  font-family:var(--serif); font-weight:400; letter-spacing:-.02em;
  font-size:clamp(1.9rem,4.6vw,3.7rem); line-height:1; transition:color .4s var(--ease), transform .5s var(--ease);
}
.service-row .s-desc{
  color:var(--ink-2); font-size:clamp(.95rem,1.15vw,1.08rem); max-width:42ch;
  opacity:.55; transition:opacity .45s var(--ease), transform .5s var(--ease);
}
.service-row .s-arrow{ justify-self:end; color:var(--ink-3); transition:color .4s var(--ease), transform .5s var(--ease); }
.service-row::after{ content:""; position:absolute; left:0; bottom:-1px; height:1px; width:0; background:var(--blue); transition:width .6s var(--ease); }
.service-row:hover{ padding-left:clamp(8px,1.5vw,26px); }
.service-row:hover .s-name{ color:var(--blue); }
.service-row:hover .s-desc{ opacity:1; }
.service-row:hover .s-arrow{ color:var(--blue); transform:translate(4px,-4px); }
.service-row:hover::after{ width:100%; }
@media (max-width:760px){
  .service-row{ grid-template-columns:48px 1fr 34px; }
  .service-row .s-desc{ grid-column:1 / -1; max-width:none; opacity:1; font-size:.95rem; }
}

/* ---------- PHILOSOPHY ---------- */
#philosophy{ padding:clamp(100px,16vw,260px) 0; background:var(--bg-deep); }
.manifesto{ display:flex; flex-direction:column; gap:clamp(28px,5vw,80px); }
.mani-line{
  font-family:var(--serif); font-weight:400; line-height:.98; letter-spacing:-.025em;
  font-size:clamp(2.3rem,7.4vw,6.6rem); max-width:20ch; text-wrap:balance;
}
.mani-line:nth-child(2){ align-self:flex-end; text-align:right; }
.mani-line em{ font-style:italic; color:var(--blue); }
.mani-note{
  margin-top:clamp(40px,6vw,90px); max-width:46ch; align-self:flex-start;
  color:var(--ink-2); font-size:clamp(1rem,1.2vw,1.15rem); line-height:1.6;
}
.mani-note .lead{ color:var(--ink); }

/* ---------- PROCESS ---------- */
#process{ padding-top:clamp(90px,12vw,160px); }
#process .section-head{ padding-inline:var(--gut); max-width:var(--maxw); margin-inline:auto; }
.process-pin{ height:100svh; display:flex; align-items:center; overflow:hidden; }
.process-track{ display:flex; gap:clamp(40px,7vw,140px); padding-inline:var(--gut); will-change:transform; }
.p-step{ flex:0 0 auto; width:min(74vw,520px); }
.p-step .p-idx{ display:flex; align-items:center; gap:16px; margin-bottom:26px; }
.p-step .p-idx .n{ font-size:.85rem; color:var(--blue); font-weight:600; letter-spacing:.1em; }
.p-step .p-idx .ln{ flex:1; height:1px; background:var(--line); }
.p-word{ font-family:var(--serif); font-weight:400; font-size:clamp(3rem,8vw,7rem); line-height:.95; letter-spacing:-.02em; }
.p-desc{ margin-top:22px; color:var(--ink-2); font-size:clamp(1rem,1.3vw,1.2rem); line-height:1.5; max-width:30ch; }
/* fallback for reduced motion / no GSAP: stack vertically */
html.reduce .process-pin{ height:auto; display:block; padding:20px 0 80px; }
html.reduce .process-track{ flex-direction:column; gap:60px; max-width:var(--maxw); margin-inline:auto; transform:none !important; }
html.reduce .p-step{ width:auto; max-width:640px; }

/* ---------- WORK ---------- */
#work{ padding:clamp(90px,12vw,180px) 0; }

.work-split{
  display:grid;
  grid-template-columns:200px minmax(0,1fr);
  gap:0 clamp(40px,6vw,100px);
  align-items:start;
}

.work-nav{
  position:sticky;
  top:140px;
}

.work-index{ list-style:none; }

.wi-item{
  display:flex; flex-direction:column; gap:5px;
  padding:clamp(14px,1.8vw,22px) 0 clamp(14px,1.8vw,22px) 16px;
  border-left:2px solid var(--line);
  color:var(--ink-3);
  transition:color .4s var(--ease), border-color .4s var(--ease);
  cursor:default;
}
.wi-item.active{ border-color:var(--blue); color:var(--ink); }

.wi-n{
  font-size:.72rem; letter-spacing:.14em; text-transform:uppercase;
  font-weight:600; color:var(--blue); opacity:0; transition:opacity .4s;
}
.wi-item.active .wi-n{ opacity:1; }

.wi-label{
  font-family:var(--serif); font-weight:400; letter-spacing:-.01em;
  font-size:clamp(.95rem,1.2vw,1.1rem); line-height:1.2;
}

.work-detail{ border-top:1px solid var(--line); }

.w-case{
  position:relative;
  padding:clamp(50px,7vw,110px) 0;
  border-bottom:1px solid var(--line);
  overflow:hidden;
}

.w-case::before{
  content:attr(data-num);
  position:absolute; right:-0.06em; top:50%;
  transform:translateY(-50%);
  font-family:var(--serif); font-weight:400;
  font-size:clamp(10rem,20vw,18rem);
  line-height:1; color:var(--ink); opacity:0.035;
  pointer-events:none; user-select:none; z-index:0;
}

.wc-mascot{
  position:absolute; top:clamp(50px,7vw,90px); right:20px;
  width:clamp(90px,11vw,140px); height:clamp(90px,11vw,140px);
  pointer-events:none; z-index:1;
}
@media (max-width:880px){ .wc-mascot{ display:none; } }

.wc-inner{ position:relative; z-index:1; max-width:640px; }

.wc-head{ margin-bottom:clamp(20px,3vw,36px); }

.wc-co{
  display:block; font-size:.78rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3); margin-bottom:12px;
}

.wc-title{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(2.2rem,5vw,4.6rem);
  line-height:.95; letter-spacing:-.025em; margin-bottom:10px;
}

.wc-role{
  font-size:.82rem; color:var(--blue);
  font-weight:600; letter-spacing:.1em; text-transform:uppercase;
}

.wc-desc{
  font-size:clamp(1rem,1.2vw,1.15rem); color:var(--ink-2);
  line-height:1.6; max-width:52ch;
  margin-bottom:clamp(24px,3.6vw,44px);
}

.wc-metrics{
  display:flex; gap:clamp(20px,4vw,56px);
  margin-bottom:clamp(24px,3.6vw,44px); flex-wrap:wrap;
}

.wm-item{ display:flex; flex-direction:column; gap:4px; }

.wm-num{
  display:flex; align-items:baseline; gap:2px; line-height:1;
}

.wm-val{
  font-family:var(--serif); font-weight:400;
  font-size:clamp(2rem,4.2vw,3.6rem);
  letter-spacing:-.025em; color:var(--ink);
}

.wm-suf{
  font-family:var(--serif); font-size:clamp(1.3rem,2.6vw,2.2rem);
  color:var(--blue); line-height:1;
}

.wm-lbl{
  font-size:.75rem; color:var(--ink-3);
  letter-spacing:.1em; text-transform:uppercase;
}

.wc-tags{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-bottom:clamp(20px,3vw,36px);
}
.wc-tags span{
  font-size:.82rem; color:var(--ink-2); padding:6px 14px;
  border:1px solid var(--line); border-radius:100px;
  transition:border-color .35s, color .35s;
}
.w-case:hover .wc-tags span{ border-color:rgba(17,17,17,0.25); }

.wc-detail{
  font-size:clamp(.92rem,1.05vw,1rem); color:var(--ink-2);
  line-height:1.65; max-width:54ch;
  padding-top:clamp(16px,2.2vw,26px);
  border-top:1px solid var(--line-2);
}

@media (max-width:920px){
  .work-split{ grid-template-columns:1fr; }
  .work-nav{ display:none; }
}

/* ---------- CAPABILITIES ---------- */
#capabilities{ padding:clamp(100px,14vw,200px) 0; }
.cap-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
@media (max-width:900px){ .cap-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .cap-grid{ grid-template-columns:1fr; } }
.cap-cell{ background:var(--bg); padding:clamp(34px,4.4vw,72px); position:relative; overflow:hidden; }
.cap-cell .c-idx{ font-size:.8rem; color:var(--ink-3); }
.cap-cell h3{
  font-family:var(--serif); font-weight:400; letter-spacing:-.02em;
  font-size:clamp(2.4rem,5.2vw,4.4rem); line-height:1; margin:18px 0 24px;
  transition:transform .6s var(--ease);
}
.cap-cell .c-tags{ display:flex; flex-wrap:wrap; gap:10px; }
.cap-cell .c-tags span{
  font-size:.86rem; color:var(--ink-2); padding:6px 14px;
  border:1px solid var(--line); border-radius:100px; transition:border-color .4s, color .4s, background .4s;
}
.cap-cell:hover .c-tags span{ border-color:var(--ink); }
.cap-cell::before{
  content:""; position:absolute; inset:0; background:var(--blue-soft);
  opacity:0; transition:opacity .5s var(--ease);
}
.cap-cell:hover::before{ opacity:1; }
.cap-cell:hover h3{ transform:translateX(8px); }
.cap-cell > *{ position:relative; }
.cap-proof{ margin-top:clamp(30px,4vw,56px); color:var(--ink-2); font-size:clamp(.92rem,1.1vw,1.05rem); max-width:60ch; }
.cap-proof b{ color:var(--ink); font-weight:600; }
@media (max-width:760px){ .cap-grid{ grid-template-columns:1fr; } }

/* ---------- PLAYGROUND ---------- */
#playground{ padding:clamp(90px,12vw,170px) 0; text-align:center; overflow:hidden; }
.play-title{ font-family:var(--serif); font-weight:400; font-size:clamp(2.2rem,5.6vw,4.8rem); line-height:1; letter-spacing:-.02em; margin:0 auto 14px; max-width:16ch; }
.play-sub{ color:var(--ink-2); max-width:40ch; margin:0 auto; font-size:1.05rem; }
.play-stage{ position:relative; height:min(52vh,520px); margin:30px auto 10px; max-width:760px; }
.play-stage .mascot-slot{ position:absolute; inset:0; }
.speech{
  position:absolute; left:50%; top:6%; transform:translate(-50%,-8px) scale(.95);
  background:var(--ink); color:var(--bg); font-size:.95rem; padding:11px 18px; border-radius:14px;
  opacity:0; pointer-events:none; transition:opacity .35s var(--ease), transform .35s var(--ease); white-space:nowrap; z-index:70;
}
.speech::after{ content:""; position:absolute; left:50%; bottom:-6px; width:12px; height:12px; background:var(--ink); transform:translateX(-50%) rotate(45deg); }
.speech.show{ opacity:1; transform:translate(-50%,0) scale(1); }
.play-controls{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:8px; }
.play-btn{
  background:transparent; border:1px solid var(--line); color:var(--ink);
  padding:12px 22px; border-radius:100px; font-size:.92rem; font-weight:500;
  transition:border-color .35s, background .35s, color .35s, transform .35s var(--ease);
}
.play-btn:hover{ border-color:var(--ink); background:var(--ink); color:var(--bg); }
.play-btn:active{ transform:scale(.95); }

/* ---------- CONTACT ---------- */
#contact{ padding:clamp(110px,16vw,240px) 0 clamp(60px,8vw,120px); position:relative; }
.contact-inner{ position:relative; z-index:2; }
.contact-title{
  font-family:var(--serif); font-weight:400; line-height:.94; letter-spacing:-.03em;
  font-size:clamp(3rem,11vw,10rem); max-width:14ch; margin:22px 0 0; text-wrap:balance;
}
.contact-title em{ font-style:italic; color:var(--blue); }
.contact-sub{ margin-top:34px; max-width:46ch; color:var(--ink-2); font-size:clamp(1.05rem,1.4vw,1.3rem); line-height:1.55; }
.cta{
  display:inline-flex; align-items:center; gap:14px; margin-top:46px;
  background:var(--ink); color:var(--bg); border:1px solid var(--ink);
  padding:18px 30px; border-radius:100px; font-size:1.02rem; font-weight:500;
  transition:background .45s var(--ease), color .45s var(--ease);
}
.cta .arc{ width:30px; height:30px; border-radius:50%; background:var(--blue); display:grid; place-items:center; color:#fff; transition:transform .45s var(--ease); }
.cta:hover{ background:var(--blue); border-color:var(--blue); }
.cta:hover .arc{ background:#fff; color:var(--blue); transform:rotate(45deg); }
.cta.big{ font-size:clamp(1.05rem,1.5vw,1.25rem); padding:22px 36px; }
.contact-links{ list-style:none; display:flex; flex-wrap:wrap; gap:14px 40px; margin-top:64px; padding-top:30px; border-top:1px solid var(--line); }
.contact-links a{ display:inline-flex; align-items:center; gap:10px; color:var(--ink-2); font-size:.98rem; transition:color .3s; }
.contact-links a .lbl{ color:var(--ink); }
.contact-links a:hover{ color:var(--ink); }
.contact-links a .ar{ transition:transform .35s var(--ease); }
.contact-links a:hover .ar{ transform:translate(3px,-3px); }
#contact .mascot-slot.foot{ position:absolute; right:6%; bottom:8%; width:300px; height:300px; }

/* ---------- FOOTER ---------- */
.foot{ padding:50px var(--gut) 40px; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; }
.foot .fmark{ font-weight:600; }
.foot .fav{ font-size:.88rem; color:var(--ink-2); display:flex; align-items:center; gap:9px; }
.foot .fav .pip{ width:7px; height:7px; border-radius:50%; background:#27b86a; box-shadow:0 0 0 4px rgba(39,184,106,.18); }
.foot .fcr{ font-size:.82rem; color:var(--ink-3); }

/* ---------- intro overlay ---------- */
.intro-bg{ position:fixed; inset:0; z-index:40; background:var(--bg); }
.intro-bg.done{ opacity:0; transition:opacity .9s var(--ease); pointer-events:none; }
.intro-slot{ position:fixed; inset:0; z-index:50; pointer-events:none; }
.intro-copy{ position:fixed; inset:0; z-index:70; display:grid; place-items:center; pointer-events:none; }
.intro-copy.done{ opacity:0; transition:opacity .6s var(--ease); }
.intro-line{
  grid-area:1/1; justify-self:center; align-self:center; margin-top:78px;
  width:max-content; font-family:var(--serif); font-style:italic;
  font-size:clamp(1.6rem,3.6vw,2.8rem); color:var(--ink); opacity:0;
}
.intro-skip{
  position:fixed; bottom:26px; right:26px; z-index:71; pointer-events:auto;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3);
  background:none; border:none; transition:color .3s;
}
.intro-skip:hover{ color:var(--ink); }
html.intro-active{ overflow:hidden; }
html.intro-active body{ overflow:hidden; height:100svh; }
html.intro-active .nav{ opacity:0; pointer-events:none; transition:opacity .4s; }

/* ---------- mascot rail anchors ---------- */
.mascot-rail{
  position:absolute; top:clamp(84px,11vw,150px); right:var(--gut);
  width:clamp(120px,15vw,190px); height:clamp(120px,15vw,190px);
  pointer-events:none; z-index:1;
}
.mascot-rail.left{ right:auto; left:var(--gut); }
html.no-3d .mascot-rail::after{ display:none; }
@media (max-width:880px){ .mascot-rail{ display:none; } }

/* ---------- reveal animations ---------- */
@keyframes wordIn{ from{ opacity:0; transform:translateY(0.5em); } to{ opacity:1; transform:none; } }
@keyframes revealUp{ from{ opacity:0; transform:translateY(26px); } to{ opacity:1; transform:none; } }
.reveal{ opacity:0; transform:translateY(26px); }
.reveal.is-in{ animation:revealUp .9s var(--ease) both; }
.w{ display:inline-block; vertical-align:top; }
.wi{ display:inline-block; opacity:0; transform:translateY(0.5em); will-change:transform,opacity; }
[data-split].is-in .wi{ animation:wordIn .85s var(--ease) both; animation-delay:var(--d,0s); }
.reveal.shown{ opacity:1 !important; transform:none !important; animation:none !important; }
[data-split].shown .wi{ opacity:1 !important; transform:none !important; animation:none !important; }
html.anim-off .reveal,
html.anim-off .reveal.is-in{ opacity:1 !important; transform:none !important; animation:none !important; }
html.anim-off .wi{ opacity:1 !important; transform:none !important; animation:none !important; }

@media (prefers-reduced-motion:reduce){
  .scrollcue .ln::after{ animation:none; }
}
