/* ============================================================
   CAFFEINA SWITZERLAND — premium landing system
   Dark / lime-forward. Cool tones live inside the glass only.
   ============================================================ */

@font-face{
  font-family:'Plus Jakarta Sans';
  src:url('assets/fonts/Plus_Jakarta_Sans/PlusJakartaSans-VariableFont_wght.ttf') format('truetype-variations'),
      url('assets/fonts/Plus_Jakarta_Sans/PlusJakartaSans-VariableFont_wght.ttf') format('truetype');
  font-weight:200 800;font-style:normal;font-display:swap;
}

:root{
  --bg:#070709;
  --bg-2:#0b0c0f;
  --panel:#101114;
  --panel-2:#15161b;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.14);
  --ink:#f4f5f7;
  --grey:#9b9da6;
  --grey-2:#62646d;
  --lime:#EBFE50;
  --lime-dim:#c2d63f;
  /* cool spectrum — used only inside glass / faint blooms */
  --blue:#2a6bff;
  --violet:#7a4dff;
  --cyan:#27e6ff;

  --display:'Plus Jakarta Sans',sans-serif;
  --body:'Plus Jakarta Sans',sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --maxw:1280px;
  --pad:clamp(20px,4vw,40px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  text-wrap:pretty;        /* avoid widows/orphans in body copy */
}
html.modal-open,
html.modal-open body{overflow:hidden;height:100%}
body.lenis-stopped{overflow:hidden}

h1,h2,h3,h4,h5,h6,.hero-title{text-wrap:balance}   /* headings: balanced lines, no lone last word */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);position:relative}
section{position:relative}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--lime);color:#0a0a0a}

h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:1.0;letter-spacing:-.02em}
.lime{color:var(--lime)}
.muted{color:var(--grey-2)}

/* fine film grain over everything */
.grain{
  position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================== custom cursor ============================== */
.cursor-ring,.cursor-dot{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;border-radius:50%;will-change:transform;mix-blend-mode:difference}
.cursor-ring{width:42px;height:42px;margin:-21px 0 0 -21px;border:1.4px solid rgba(255,255,255,.7);transition:width .3s var(--ease),height .3s var(--ease),margin .3s var(--ease),border-color .3s,opacity .3s,background .3s}
.cursor-dot{width:6px;height:6px;margin:-3px 0 0 -3px;background:#fff}
.cursor-ring.is-hover{width:64px;height:64px;margin:-32px 0 0 -32px;border-color:rgba(255,255,255,.95)}
.cursor-ring.is-hover.is-lime{background:rgba(255,255,255,.0)}
.cursor-ring.is-press{width:34px;height:34px;margin:-17px 0 0 -17px}
@media (hover:none),(pointer:coarse){.cursor-ring,.cursor-dot{display:none}}

/* ============================== buttons ============================== */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--body);font-weight:500;font-size:15px;letter-spacing:-.01em;
  padding:14px 26px;border-radius:100px;cursor:pointer;border:1px solid transparent;
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),transform .5s var(--ease);
  will-change:transform;white-space:nowrap;
}
.btn .arr{transition:transform .4s var(--ease)}
.btn:hover .arr{transform:translateX(4px)}
.btn-lime{background:var(--lime);color:#08090a;font-weight:600}
.btn-lime:hover{box-shadow:0 18px 50px -18px rgba(235,254,80,.55)}
.btn-ghost{background:rgba(255,255,255,.02);color:var(--ink);border-color:var(--line-2)}
.btn-sm{padding:11px 20px;font-size:14px}
/* hero primary: ghost by default, fills lime on hover */
.hero-start{background:rgba(255,255,255,.02);color:var(--ink);border-color:var(--line-2)}
.hero-start:hover{background:var(--lime);color:#08090a;border-color:var(--lime);font-weight:600;box-shadow:0 18px 50px -18px rgba(235,254,80,.55)}

.bolt-mark{display:block;height:1em;width:auto}
.brand-logo{display:block;width:122px;height:23px;background:var(--ink);
  -webkit-mask:url('assets/logo-caffeina.svg') center/contain no-repeat;
  mask:url('assets/logo-caffeina.svg') center/contain no-repeat}

/* ============================== nav ============================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;transition:transform .5s var(--ease),background .4s,border-color .4s,backdrop-filter .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(7,7,9,.6);backdrop-filter:blur(18px) saturate(140%);border-bottom-color:var(--line)}
.nav.hide{transform:translateY(-105%)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center;color:var(--ink)}
.logo .bolt-mark{height:24px;color:var(--lime)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-size:14.5px;color:var(--grey);font-weight:500;position:relative;letter-spacing:-.01em}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1px;background:var(--lime);transition:width .4s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}
.nav-lang{font-size:12px;color:var(--lime);border:1px solid var(--line-2);padding:5px 11px;border-radius:100px;letter-spacing:.04em}
.nav-right{display:flex;align-items:center;gap:22px}
@media(max-width:880px){.nav-links{display:none}}

/* ============================== hero ============================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;padding:0 0 clamp(56px,7vh,82px);overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.glow{position:absolute;border-radius:50%;filter:blur(100px);opacity:.5}
.glow.g-lime{width:48vw;height:42vw;top:8%;left:50%;transform:translateX(-50%);background:radial-gradient(circle,rgba(235,254,80,.20),transparent 65%)}
.glow.g-blue{width:40vw;height:38vw;top:2%;left:8%;background:radial-gradient(circle,rgba(42,107,255,.16),transparent 68%);opacity:.6;animation:float1 20s var(--ease) infinite alternate}
.glow.g-violet{width:38vw;height:36vw;bottom:-6%;right:4%;background:radial-gradient(circle,rgba(122,77,255,.15),transparent 68%);animation:float2 26s var(--ease) infinite alternate}
@keyframes float1{to{transform:translate(40px,30px)}}
@keyframes float2{to{transform:translate(-40px,-30px)}}

/* glass sculpture — centered backdrop of the hero */
.glass-stage{position:absolute;z-index:1;top:50%;left:50%;transform:translate(-50%,-54%);width:min(82vw,720px);height:min(78vh,680px);pointer-events:none;
  -webkit-mask:radial-gradient(ellipse 64% 60% at 50% 46%,#000 52%,transparent 78%);
  mask:radial-gradient(ellipse 64% 60% at 50% 46%,#000 52%,transparent 78%)}
.glass-stage canvas{display:block;width:100%!important;height:100%!important}
.no-webgl .glass-stage{display:none}
.stage-fallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--lime);opacity:.0}

/* bottom row: text left, CTA right */
.hero-foot{position:relative;z-index:3;width:100%;display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:16px}
.hero-text{max-width:60ch;line-height:1.3}
.eyebrow{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;color:var(--lime);font-weight:600;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--lime);box-shadow:0 0 10px var(--lime);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

.hero-title{font-size:clamp(1.5rem,2.9vw,2.5rem);font-weight:700;max-width:24ch;letter-spacing:-.025em;line-height:1.22}
.hero-title .lead{color:var(--ink)}
.hero-title .rest{color:var(--grey-2)}
.hero-start{flex:0 0 auto;margin-bottom:2px;font-size:20px;gap:11px;padding:19px 35px}
.hero-start .arr{transition:transform .4s var(--ease)}
.hero-start .hs-play{display:inline-flex;align-items:center;justify-content:center;width:1.05em;height:1.05em}
.hero-start .hs-play svg{width:100%;height:100%;fill:currentColor}
/* reveal disabled during programmatic (non-manual) scroll */
.reveal-instant{transition:none!important;animation:none!important}

.scroll-hint{position:absolute;bottom:26px;left:0;right:0;margin-inline:auto;width:max-content;max-width:100%;z-index:4;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--grey);font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.scroll-hint .chev{display:inline-block;position:relative;top:-3px;line-height:1;animation:bob 2s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

/* slim stats band below hero */
.stats-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg-2)}
.stats-band .wrap{display:flex;gap:clamp(24px,6vw,80px);flex-wrap:wrap;padding-top:26px;padding-bottom:26px}
.stat{display:flex;align-items:baseline;gap:12px}
.stat .n{font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,2.2vw,1.9rem);color:var(--ink);letter-spacing:-.02em;line-height:1}
.stat .l{font-size:12px;color:var(--grey-2);text-transform:uppercase;letter-spacing:.08em}
@media(max-width:680px){.hero-foot{flex-direction:column;align-items:flex-start;gap:26px}.hero-text{width:100%;max-width:100%}.hero-start{align-self:stretch;justify-content:center}}

/* ============================== section base ============================== */
.sec{padding:clamp(90px,12vw,160px) 0;position:relative;z-index:2}
.sec-head{max-width:60ch;margin-bottom:clamp(48px,6vw,76px)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-tag{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--lime);font-weight:500;margin-bottom:22px}
.sec-tag::before{content:"";width:24px;height:1px;background:var(--lime);opacity:.6}
.sec-head.center .sec-tag::before{display:none}
.sec h2{font-size:clamp(2rem,4.6vw,3.7rem);font-weight:700;letter-spacing:-.03em;max-width:18ch}
.sec-head.center h2{margin-inline:auto}
.sec h2 .lime{color:var(--lime)}
.sec .intro,.hero-text .intro{color:var(--grey);font-size:clamp(1rem,1.3vw,1.18rem);max-width:54ch;margin-top:24px;line-height:1.6}
.sec-head.center .intro{margin-inline:auto}

.divider{height:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}

/* ============================== services ============================== */
.services{background:linear-gradient(180deg,var(--bg),var(--bg-2))}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:38px 34px 34px;overflow:hidden;transition:border-color .7s var(--ease),transform .95s cubic-bezier(.22,1,.36,1),background .7s var(--ease)}
.svc-card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% -20%,rgba(235,254,80,.08),transparent 60%);opacity:0;transition:opacity .7s var(--ease)}
.svc-card:hover{border-color:rgba(235,254,80,.4);transform:translateY(-6px);background:var(--panel-2)}
.svc-card:hover::before{opacity:1}
.svc-num{font-family:var(--display);font-size:13px;color:var(--grey-2);letter-spacing:.06em;margin-bottom:26px;display:flex;align-items:center;gap:10px}
.svc-num::after{content:"";flex:1;height:1px;background:var(--line)}
.svc-role{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--lime);margin-bottom:24px;font-weight:500;display:flex;align-items:center;gap:10px}
.svc-role::after{content:"";flex:1;height:1px;background:var(--line)}
.svc-list{list-style:none;position:relative;z-index:1}
.svc-list li{font-size:15.5px;color:var(--grey);padding:8px 0;border-top:1px solid var(--line);transition:color .35s}
.svc-list li:first-child{border-top:none}
.svc-card:hover .svc-list li{color:var(--ink)}
@media(max-width:880px){.svc-grid{grid-template-columns:1fr}}

/* ============================== method ============================== */
.method-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.mcard{position:relative;border:1px solid var(--line);border-radius:22px;padding:40px 34px;background:var(--panel);overflow:hidden;transition:transform .95s cubic-bezier(.22,1,.36,1),border-color .7s var(--ease),background .7s var(--ease)}
.mcard::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% -20%,rgba(235,254,80,.08),transparent 60%);opacity:0;transition:opacity .7s var(--ease);pointer-events:none}
.mcard>*{position:relative;z-index:1}
.mcard:hover{transform:translateY(-6px);border-color:rgba(235,254,80,.4);background:var(--panel-2)}
.mcard:hover::before{opacity:1}
.mcard .ic{width:54px;height:54px;border-radius:15px;background:rgba(235,254,80,.1);border:1px solid rgba(235,254,80,.2);display:flex;align-items:center;justify-content:center;margin-bottom:30px}
.mcard .ic svg{width:26px;height:26px;stroke:var(--lime);fill:none;stroke-width:1.6}
.mcard h3{font-size:1.5rem;font-weight:600;margin-bottom:14px;letter-spacing:-.02em}
.mcard p{font-size:14.5px;color:var(--grey);line-height:1.6}
.mcard .mindex{position:absolute;top:30px;right:34px;font-family:var(--display);font-size:13px;color:var(--grey-2)}
@media(max-width:880px){.method-grid{grid-template-columns:1fr}}

/* ============================== work ============================== */
/* ============================== scroll-expand showcase ============================== */
.showcase{position:relative;background:var(--bg)}
.showcase-pin{height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden}
.showcase-box{position:relative;width:min(360px,74vw);height:min(470px,62svh);border-radius:22px;overflow:hidden;border:1px solid var(--line);box-shadow:0 50px 130px -50px rgba(0,0,0,.95);will-change:width,height,border-radius}
.sc-cycle{position:absolute;inset:0}
.sc-frame{position:absolute;inset:0;opacity:0;background-size:cover;background-position:center;transition:opacity .5s var(--ease)}
.sc-frame.on{opacity:1}
.sc-frame::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 55% at 64% 22%,rgba(255,255,255,.10),transparent 60%);mix-blend-mode:screen;pointer-events:none}
.sc1{background:radial-gradient(130% 120% at 24% 8%,#27568a,#13294a 50%,#0a1322 82%,#070b16)}
.sc2{background:radial-gradient(130% 120% at 76% 8%,#7a283f,#451522 50%,#1d0c14 82%,#120710)}
.sc3{background:radial-gradient(130% 120% at 24% 92%,#1d6a47,#114029 50%,#0a2116 82%,#06100b)}
.sc4{background:radial-gradient(130% 120% at 76% 92%,#6e5018,#3f2e10 50%,#1c1409 82%,#100b05)}
.sc5{background:radial-gradient(130% 120% at 30% 18%,#5a3c7a,#2c1d44 50%,#150e22 82%,#0a0710)}
.sc6{background:radial-gradient(130% 120% at 70% 18%,#1f5f74,#103642 50%,#091c22 82%,#060f12)}

/* ============================== work — horizontal split cards (Lesse) ============================== */
.work-list{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2.4vw,30px)}
.wproj{position:relative;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:22px;overflow:hidden;transition:transform .3s var(--ease),border-color .7s var(--ease),background .7s var(--ease)}
.wproj::before{content:"";position:absolute;inset:0;z-index:5;pointer-events:none;background:radial-gradient(120% 80% at 50% -20%,rgba(235,254,80,.08),transparent 60%);opacity:0;transition:opacity .7s var(--ease)}
.wproj:hover{background:var(--panel-2)}
.wproj:hover::before{opacity:1}
.wproj .w-media{position:relative;display:block;overflow:hidden;isolation:isolate;aspect-ratio:16/10}
.wproj .w-parallax{position:absolute;inset:-7% 0;z-index:1;will-change:transform}
.wproj .w-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.wproj.w4 .w-photo{transform:translateY(18px)}
.w-grad{position:absolute;inset:0;z-index:0;pointer-events:none}
.w1 .w-grad{background:radial-gradient(130% 110% at 22% 8%,#27568a,#13294a 48%,#0a1322 78%,#070b16)}
.w2 .w-grad{background:radial-gradient(130% 110% at 78% 8%,#7a283f,#451522 48%,#1d0c14 78%,#120710)}
.w3 .w-grad{background:radial-gradient(130% 110% at 22% 92%,#1d6a47,#114029 48%,#0a2116 78%,#06100b)}
.w4 .w-grad{background:radial-gradient(130% 110% at 78% 92%,#6e5018,#3f2e10 48%,#1c1409 78%,#100b05)}
.w-grad::after{content:"";position:absolute;inset:0;background:radial-gradient(58% 50% at 68% 22%,rgba(255,255,255,.16),transparent 60%),radial-gradient(40% 40% at 30% 80%,rgba(255,255,255,.05),transparent 60%);mix-blend-mode:screen}

.wproj .w-info{display:flex;flex-direction:column;flex:1;padding:clamp(32px,3vw,52px)}
.wproj .w-brand{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.4vw,3rem);letter-spacing:-.025em;line-height:1;margin-bottom:22px}
.wproj .w-desc{font-size:15px;color:var(--grey);line-height:1.65;max-width:52ch}
.wproj .w-meta{display:flex;gap:clamp(28px,4vw,56px);margin-top:auto;padding-top:40px}
.wproj .w-meta div{display:flex;flex-direction:column;gap:8px}
.wproj .w-meta dt{font-size:13px;color:var(--grey-2);font-weight:400}
.wproj .w-meta dd{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);font-weight:600}
.work-foot{display:flex;justify-content:center;margin-top:clamp(48px,6vw,72px)}
@media(max-width:820px){
  .work-list{grid-template-columns:1fr}
  .wproj .w-meta{padding-top:48px}
}

/* ============================== showreel — video bg + overlay ============================== */
.reel{position:relative;width:100vw;left:50%;transform:translateX(-50%);height:clamp(460px,82svh,880px);overflow:hidden;background:#05060a url('assets/images/showcase/paramount.webp') center/cover no-repeat}
.reel-bg{position:absolute;inset:0;overflow:hidden}
.reel-bg iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-width:177.78vh;min-height:100vh;pointer-events:none;border:0}
.reel-shade{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,9,.86) 0%,rgba(7,7,9,.28) 38%,rgba(7,7,9,.18) 70%,rgba(7,7,9,.5) 100%)}
.reel-fg{position:absolute;left:0;right:0;bottom:clamp(30px,5vw,58px);z-index:3;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:flex;justify-content:center}
.reel-play{display:inline-flex;align-items:center;gap:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:12px 24px 12px 12px;border-radius:100px;cursor:pointer;color:#fff;transition:background .4s var(--ease),border-color .4s,transform .5s var(--ease)}
.reel-play:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.4)}
.reel-play-ic{width:54px;height:54px;flex:0 0 auto;border-radius:50%;background:var(--lime);color:#08090a;display:flex;align-items:center;justify-content:center;transition:transform .5s var(--ease)}
.reel-play-ic svg{width:22px;height:22px;margin-left:2px}
.reel-play:hover .reel-play-ic{transform:scale(1.06)}
.reel-play-txt{display:flex;flex-direction:column;gap:3px;text-align:left;padding-right:6px}
.reel-play-txt .rp-t{font-family:var(--display);font-weight:600;font-size:1.05rem;letter-spacing:-.01em;line-height:1}
.reel-play-txt .rp-m{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.66)}

/* overlay */
.reel-modal{position:fixed;inset:0;z-index:1000;background:rgba(4,4,6,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,60px);opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s}
.reel-modal.open{opacity:1;visibility:visible}
.reel-modal-inner{width:min(1200px,100%);transform:scale(.96);transition:transform .6s var(--ease)}
.reel-modal.open .reel-modal-inner{transform:none}
.reel-modal .ratio{position:relative;padding-top:56.25%;border-radius:16px;overflow:hidden;box-shadow:0 50px 130px -40px rgba(0,0,0,.9);background:#000}
.reel-modal .ratio iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.reel-close{position:absolute;top:clamp(16px,2.5vw,30px);right:clamp(16px,2.5vw,30px);z-index:2;width:50px;height:50px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.05);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .35s,border-color .35s,transform .4s var(--ease)}
.reel-close svg{width:22px;height:22px}
.reel-close:hover{background:var(--lime);color:#08090a;border-color:var(--lime);transform:rotate(90deg)}
@media(max-width:600px){.reel-play-txt .rp-t{font-size:.95rem}.reel-play-ic{width:46px;height:46px}}

/* ============================== clients ============================== */
.clients{background:var(--bg-2)}
.client-grid{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.client-cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);min-height:120px;display:flex;align-items:center;justify-content:center;padding:20px;transition:background .4s;position:relative;overflow:hidden}
.client-cell::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,rgba(235,254,80,.1),transparent 70%);opacity:0;transition:opacity .4s}
.client-cell:hover::before{opacity:1}
.client-cell span{font-family:var(--display);font-weight:600;font-size:1.15rem;color:var(--grey);letter-spacing:-.01em;transition:color .4s,transform .5s var(--ease);position:relative}
.client-cell:hover span{color:var(--ink);transform:translateY(-2px)}
.client-cell .client-logo{display:block;position:relative;background:#c5c7cd;opacity:.85;
  -webkit-mask:var(--lg) center/contain no-repeat;mask:var(--lg) center/contain no-repeat;
  transition:opacity .4s,background .4s,transform .5s var(--ease)}
.client-cell:hover .client-logo{opacity:1;background:var(--ink);transform:translateY(-2px)}
.client-cell .client-img{width:auto;object-fit:contain;position:relative;filter:grayscale(1) brightness(.58);transition:filter .45s var(--ease),transform .5s var(--ease)}
.client-cell:hover .client-img{filter:none;transform:translateY(-2px)}
.client-cell .client-img.dark-base{filter:grayscale(1) brightness(2.1)}
.client-cell:hover .client-img.dark-base{filter:grayscale(1) brightness(3.4)}
@media(max-width:880px){.client-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.client-grid{grid-template-columns:repeat(2,1fr)}}

/* ============================== partners ============================== */
.part-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.pcol{position:relative;overflow:hidden;background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:34px 32px;transition:transform .95s cubic-bezier(.22,1,.36,1),border-color .7s var(--ease),background .7s var(--ease)}
.pcol::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% -20%,rgba(235,254,80,.08),transparent 60%);opacity:0;transition:opacity .7s var(--ease);pointer-events:none}
.pcol>*{position:relative;z-index:1}
.pcol:hover{transform:translateY(-6px);border-color:rgba(235,254,80,.4);background:var(--panel-2)}
.pcol:hover::before{opacity:1}
.pcol h4{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--lime);margin-bottom:24px;font-weight:500;display:flex;align-items:center;gap:10px}
.pcol h4::after{content:"";flex:1;height:1px;background:var(--line)}
.pitems{display:flex;flex-wrap:wrap;align-items:center;gap:24px 40px}
.pchip{font-size:13.5px;color:var(--grey);border:1px solid var(--line);padding:9px 15px;border-radius:100px;transition:color .3s,border-color .3s,background .3s,transform .4s var(--ease)}
.pchip:hover{color:#0a0a0a;background:var(--lime);border-color:var(--lime);transform:translateY(-2px)}
.plogo{display:inline-block;flex:none;background:#c5c7cd;opacity:1;
  -webkit-mask-image:var(--lg);mask-image:var(--lg);
  -webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;
  -webkit-mask-position:center;mask-position:center;
  transition:opacity .35s var(--ease),background .35s var(--ease),transform .45s var(--ease)}
.pcol:hover .plogo{opacity:1}
.plogo:hover{opacity:1;background:var(--ink);transform:translateY(-2px)}
@media(max-width:880px){.part-cols{grid-template-columns:1fr}}

/* ============================== closing ============================== */
.closing{min-height:44svh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:clamp(48px,6vw,76px) 0;text-align:center;position:relative;overflow:hidden}
.closing .inner{transform:translateY(-80px)}
@media(max-width:680px){.closing .inner{transform:none}}
.closing .glow-floor{position:absolute;bottom:-40%;left:50%;transform:translateX(-50%);width:90vw;height:70vh;background:radial-gradient(ellipse at center,rgba(235,254,80,.16),transparent 62%);z-index:0;pointer-events:none}
.closing .glow-cool{position:absolute;top:0;left:50%;transform:translateX(-50%);width:60vw;height:40vh;background:radial-gradient(ellipse at center,rgba(122,77,255,.1),transparent 65%);z-index:0;pointer-events:none}
.closing .inner{position:relative;z-index:2}
.closing h2{font-size:clamp(2.6rem,8vw,6rem);font-weight:700;letter-spacing:-.04em;margin-bottom:22px;line-height:.98}
.closing .ins{font-family:var(--display);font-weight:400;letter-spacing:.2em;color:var(--grey-2);text-transform:uppercase;font-size:13px;margin-bottom:46px}
.closing .btn{font-size:16px;padding:18px 40px}

/* ============================== footer ============================== */
footer{border-top:1px solid var(--line);padding:clamp(60px,8vw,90px) 0 44px;background:var(--bg)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:44px;margin-bottom:60px}
.foot-brand .logo{margin-bottom:20px}
.foot-brand p{color:var(--grey-2);font-size:14.5px;max-width:32ch;line-height:1.6}
.foot-col h5{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-2);margin-bottom:20px;font-weight:500}
.foot-col .addr{font-size:14px;color:var(--grey);line-height:1.55;margin-bottom:16px}
.foot-col .addr b{color:var(--ink);font-weight:500}
.foot-col a{display:block;font-size:14px;color:var(--grey);padding:6px 0;transition:color .3s,transform .3s var(--ease)}
.foot-col a:hover{color:var(--lime);transform:translateX(3px)}
.foot-bottom{border-top:1px solid var(--line);padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:13px;color:var(--grey-2)}
.foot-bottom .socials{display:flex;gap:20px}
.foot-bottom .socials a{transition:color .3s}
.foot-bottom .socials a:hover{color:var(--lime)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ============================== reveal (JS adds .has-motion to <html>) ============================== */
.has-motion [data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.has-motion [data-reveal].is-in{opacity:1;transform:none}
.has-motion [data-stagger-item]{opacity:0;transform:translateY(40px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.has-motion [data-stagger-item].is-in{opacity:1;transform:none}

/* work card image-reveal + body */
.has-motion .wcard .w-media{clip-path:inset(0 0 100% 0);transition:clip-path 1.15s var(--ease)}
.has-motion .wcard.is-in .w-media{clip-path:inset(0 0 0% 0)}
.has-motion .wcard .w-body{opacity:0;transform:translateY(22px);transition:opacity .9s var(--ease) .28s,transform .9s var(--ease) .28s}
.has-motion .wcard.is-in .w-body{opacity:1;transform:none}

/* lime title highlight: softly fades + de-blurs in, a beat after the heading */
.has-motion [data-reveal] .lime{opacity:0;filter:blur(8px);transition:opacity 1.1s var(--ease) .35s,filter 1.1s var(--ease) .35s}
.has-motion [data-reveal].is-in .lime{opacity:1;filter:blur(0)}
.has-motion [data-reveal] .reveal-late{opacity:0;transform:translateY(12px);transition:opacity .8s var(--ease) 1s,transform .8s var(--ease) 1s}
.has-motion [data-reveal].is-in .reveal-late{opacity:1;transform:none}

.glass-stage{transition:opacity .8s var(--ease)}

/* hero background glows fade in softly, AFTER the glass object (object-first intro) */
.has-motion .hero-bg{opacity:0;transition:opacity 1.7s var(--ease)}
.has-motion .hero-bg.bg-in{opacity:1}

/* hero load intro (transition-based — robust) — fires ~1s after load, once the hero + 3D object are in */
.has-motion .intro-up{opacity:0;transform:translateY(42px);transition:opacity 1.35s var(--ease),transform 1.35s var(--ease)}
.has-motion .intro-up.is-in{opacity:1;transform:none}

@media (prefers-reduced-motion:reduce){
  .has-motion [data-reveal],
  .has-motion [data-stagger-item]{opacity:1!important;transform:none!important}
  .has-motion [data-reveal] .lime{opacity:1!important;filter:none!important}
  .has-motion [data-reveal] .reveal-late{opacity:1!important;transform:none!important}
  .has-motion .wcard .w-media{clip-path:none!important}
  .has-motion .wcard .w-body{opacity:1!important;transform:none!important}
  .has-motion .intro-up{opacity:1!important;transform:none!important}
  .has-motion .hero-bg{opacity:1!important}
  *{scroll-behavior:auto!important}
}

/* ============================== contact overlay ============================== */
.cmodal{position:fixed;inset:0;z-index:1100;background:var(--bg);transform:translateY(101%);visibility:hidden;transition:transform 1.15s cubic-bezier(.19,1,.22,1),visibility 1.15s}
.cmodal.open{transform:none;visibility:visible;display:flex;flex-direction:column;height:100dvh;max-height:100dvh;overflow:hidden}
.cmodal-scroll{position:relative;flex:1 1 auto;min-height:0;width:100%;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;padding:clamp(86px,13vh,150px) 0 clamp(60px,9vh,100px)}
.cmodal-glow{position:absolute;top:-12%;right:-6%;width:54vw;height:54vw;max-width:760px;max-height:760px;border-radius:50%;background:radial-gradient(circle,rgba(235,254,80,.12),transparent 64%);pointer-events:none;z-index:0;opacity:0;transition:opacity 1.7s var(--ease)}
.cmodal.open .cmodal-glow{opacity:1;transition-delay:2.2s}
.cmodal-close{position:fixed;top:clamp(16px,2.4vw,28px);right:clamp(16px,2.4vw,30px);z-index:3;width:50px;height:50px;border-radius:50%;border:1px solid var(--line-2);background:rgba(255,255,255,.05);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .35s,border-color .35s,color .35s,transform .45s var(--ease)}
.cmodal-close svg{width:22px;height:22px}
.cmodal-close:hover{background:var(--lime);color:#08090a;border-color:var(--lime);transform:rotate(90deg)}
.cmodal-grid{position:relative;z-index:1;display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(40px,6vw,96px);align-items:start;opacity:0;transform:translateY(34px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.cmodal.open .cmodal-grid{opacity:1;transform:none;transition-delay:1.02s}
.cmodal.open .cm-form-wrap{transition-delay:1.14s}

.cm-intro .sec-tag{margin-bottom:20px}
.cm-intro h2{font-size:clamp(2.2rem,4.4vw,3.6rem);font-weight:700;letter-spacing:-.03em;line-height:1.02}
.cm-lead{color:var(--grey);font-size:clamp(1rem,1.25vw,1.15rem);line-height:1.6;max-width:42ch;margin-top:24px}
.cm-contacts{margin-top:clamp(36px,5vw,60px);display:flex;flex-direction:column;gap:26px;border-top:1px solid var(--line);padding-top:34px}
.cm-block h5{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-2);margin-bottom:9px;font-weight:500}
.cm-block a,.cm-block p{font-size:15px;color:var(--grey)}
.cm-block a{transition:color .3s}
.cm-block a:hover{color:var(--lime)}
.cm-social{display:flex;gap:18px}

/* pipedrive embed */
.cm-form-wrap[data-type="pipedrive"]{width:100%}
.cm-pipedrive{display:block;width:100%;height:1230px;border:1px solid var(--line);border-radius:13px;background:var(--panel)}

@media(max-width:920px){
  .cmodal-grid{grid-template-columns:1fr;gap:46px}
  .cm-intro h2 br{display:none}
}

/* ============================== preloader ============================== */
.preload{position:fixed;inset:0;z-index:99999;background:#000;display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease)}
.preload.done{opacity:0;pointer-events:none}
.preload-inner{display:flex;flex-direction:column;align-items:center;gap:24px}
.preload-mark{height:42px;width:auto;color:#fff;filter:drop-shadow(0 0 11px rgba(255,255,255,.4));animation:preloadPulse 1.6s var(--ease) infinite}
@keyframes preloadPulse{0%,100%{opacity:1}50%{opacity:.45}}
.preload-bar{width:min(220px,52vw);height:2px;background:rgba(255,255,255,.13);border-radius:2px;overflow:hidden}
.preload-bar span{display:block;height:100%;width:0;background:#EBFE50;border-radius:2px;animation:preloadFill 1.2s var(--ease) forwards}
@keyframes preloadFill{0%{width:0}65%{width:70%}100%{width:90%}}
.preload.done .preload-bar span{width:100%;transition:width .35s var(--ease)}
@media (prefers-reduced-motion:reduce){.preload-mark{animation:none}.preload-bar span{animation:none;width:90%}}
