@font-face {
  font-family: 'Rollcage';
  src: url('../Rollcage.otf') format('opentype');
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  width:100%;
  min-height:100svh;
  overflow-x:hidden;
  -webkit-font-smoothing: antialiased;
}
:root{
  --bg:#fcfcfc;--surface:#ffffff;--surface2:#fbfbfd;--surface3:#f5f5f7;
  --border:rgba(0,0,0,0.06);--border2:rgba(0,0,0,0.11);--border3:rgba(0,0,0,0.18);
  --text:#1d1d1f;--text2:rgba(29,29,31,0.7);--text3:rgba(29,29,31,0.45);
  --blue:#0071e3;--blue-dim:rgba(0,113,227,0.12);--purple:#af52de;
  --green:#34c759;--warm:#ff6b35;--yellow:#ff9500;
  --serif:'Instrument Serif',Georgia,serif;--sans:'Geist',-apple-system,sans-serif;
  --spring:cubic-bezier(0.34,1.56,0.64,1);
  --spring-sm:cubic-bezier(0.34,1.3,0.64,1);
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --tap:44px;
  --tarku: #f5926f;
  --tarku-muted: #f8ece8;
}

body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;}
body.modal-open { overflow: hidden !important; }

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

/* CURSOR */
@media(pointer:fine){body,a,button,[role=button],.wcard,.svc,.hstat{cursor:none}}
#cur{position:fixed;z-index:999999;pointer-events:none;top:0;left:0;width:10px;height:10px;border-radius:50%;background:#fff;transform:translate(-50%,-50%);transition:width .25s var(--spring),height .25s var(--spring),opacity .2s,background .2s,border-radius .25s;mix-blend-mode:difference}
#cur.h{width:38px;height:38px}
#cur.c{width:6px;height:6px;transition:width .08s,height .08s}
#cur.peek{width:280px;height:160px;background:#fff;mix-blend-mode:normal;border-radius:20px;border:1px solid rgba(0,0,0,0.1);box-shadow:0 30px 80px rgba(0,0,0,0.2);overflow:hidden;z-index:1000000;transition:width .4s var(--spring),height .4s var(--spring),border-radius .4s,transform .1s ease-out}
.cur-img{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;scale:1.1;transition:opacity .4s ease,scale .6s var(--ease-out)}
#cur.peek .cur-img{opacity:1;scale:1}

/* SCENE */
.scene{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;will-change:transform;backface-visibility:hidden;transform:translateZ(0)}
.o1{width:700px;height:700px;background:radial-gradient(circle, #f5926f 0%, rgba(245,146,111,0) 70%);opacity:.16;top:-180px;left:-100px;animation:breathe 16s ease-in-out infinite}
.o2{width:500px;height:500px;background:radial-gradient(circle, #0071e3 0%, rgba(0,113,227,0) 70%);opacity:.18;top:80px;right:-80px;animation:breathe 20s ease-in-out infinite 4s reverse}
.o3{width:550px;height:550px;background:radial-gradient(circle, #1a6fff 0%, rgba(26,111,255,0) 70%);opacity:.14;bottom:-120px;left:35%;animation:breathe 18s ease-in-out infinite 8s}
@keyframes breathe{0%,100%{transform:scale(1) translate(0,0)}50%{transform:scale(1.18) translate(15px,-20px)}}

/* Animated geometry */
.arc-group{transform-origin:180px 210px;animation:arcSpin 32s linear infinite}
.arc-group-r{transform-origin:1270px 170px;animation:arcSpin 44s linear infinite reverse}
@keyframes arcSpin{to{transform:rotate(360deg)}}

.curve1{stroke-dasharray:2200;stroke-dashoffset:2200;animation:curveDraw 5s ease-out .2s forwards, curvePulse 10s ease-in-out 6s infinite}
.curve2{stroke-dasharray:2200;stroke-dashoffset:2200;animation:curveDraw 6s ease-out .6s forwards, curvePulse 12s ease-in-out 7s infinite}
.curve3{stroke-dasharray:2200;stroke-dashoffset:2200;animation:curveDraw 6s ease-out 1s forwards, curvePulse 14s ease-in-out 8s infinite}
@keyframes curveDraw{to{stroke-dashoffset:0}}
@keyframes curvePulse{0%,100%{opacity:1}50%{opacity:.35}}

.dot-center1{animation:dotPulse 4s ease-in-out infinite}
.dot-center2{animation:dotPulse 5.5s ease-in-out infinite 1.8s}
.dot-mid{animation:dotPulse 7s ease-in-out infinite 3.2s}
@keyframes dotPulse{0%,100%{r:3.5;opacity:.4}50%{r:6.5;opacity:.95}}

.diamond1{animation:spinD 22s linear infinite;transform-origin:390px 147px}
.diamond2{animation:spinD 30s linear infinite reverse 4s;transform-origin:1050px 295px}
.diamond3{animation:spinD 19s linear infinite 7s;transform-origin:860px 91px}
@keyframes spinD{to{transform:rotate(360deg)}}

.cross1{animation:crossFade 4.5s ease-in-out infinite}
.cross2{animation:crossFade 4.5s ease-in-out infinite 2.2s}
@keyframes crossFade{0%,100%{opacity:.28}50%{opacity:.72}}
.geo{position:absolute;inset:0;width:100%;height:100%}
.grain{position:absolute;inset:0;background-image:url('data:image/svg+xml,%3Csvg viewBox=%220 0 512 512%22 xmlns=%22http://www.w3.org/2000/svg%22%3E%3Cfilter id=%22n%22%3E%3CfeTurbulence type=%22fractalNoise%22 baseFrequency=%220.75%22 numOctaves=%224%22 stitchTiles=%22stitch%22/%3E%3C/filter%3E%3Crect width=%22100%25%22 height=%22100%25%22 filter=%22url(%23n)%22/%3E%3C/svg%3E');opacity:.025}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(1.5rem,5vw,3rem);background:rgba(252,252,252,0);backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px);border-bottom:1px solid transparent;transition:all 0.4s var(--ease-out);transform:translateY(-100%);animation:navIn .6s var(--ease-out) .1s forwards}

nav.scrolled{height:54px;top:12px;margin:0 24px;border-radius:100px;background:rgba(255,255,255,0.72);backdrop-filter:blur(24px) saturate(1.8);-webkit-backdrop-filter:blur(24px) saturate(1.8);border:1px solid rgba(0,0,0,0.06);box-shadow:0 8px 32px rgba(0,0,0,0.04);padding:0 1.5rem}

@keyframes navIn{to{transform:translateY(0)}}

.nav-logo{font-family:var(--serif);font-size:1.25rem;color:var(--text);text-decoration:none;letter-spacing:-.02em;font-weight:600;display:flex;align-items:center;gap:.6rem;transition:all 0.3s var(--ease-out)}
.nav-logo::before{content:'';width:8px;height:8px;background:var(--blue);border-radius:50%;opacity:0;transform:scale(0);transition:all 0.3s var(--ease-out)}
nav.scrolled .nav-logo::before{opacity:1;transform:scale(1)}

.nav-links{display:flex;align-items:center;gap:.5rem}
.nav-link{font-size:.85rem;font-weight:600;color:var(--text2);text-decoration:none;padding:.5rem 1rem;border-radius:100px;transition:all .2s var(--ease-out);letter-spacing:-0.01em}
.nav-link:hover{color:var(--text);background:rgba(0,0,0,0.04)}
.nav-link.active{color:var(--blue);background:var(--blue-dim)}

@media(max-width:768px){.nav-link{display:none}.nav-links{gap:0}}

.nav-cta{display:flex;align-items:center;background:var(--text);color:var(--bg);font-size:.85rem;font-weight:700;height:40px;padding:0 1.25rem;border-radius:100px;text-decoration:none;letter-spacing:-.01em;border:none;cursor:pointer;transition:all .3s var(--spring-sm);-webkit-tap-highlight-color:transparent;box-shadow:0 2px 8px rgba(0,0,0,0.05)}
nav.scrolled .nav-cta{height:34px;padding:0 1.1rem;font-size:0.8rem}
.nav-cta:hover{transform:translateY(-1px) scale(1.025);box-shadow:0 8px 20px rgba(0,0,0,0.12)}
.nav-cta:active{transform:translateY(0) scale(0.96)}

.nav-progress{position:absolute;bottom:-1px;left:0;height:1px;background:var(--blue);width:0%;transition:width 0.1s linear;border-radius:0 2px 2px 0;opacity:0.3}
nav.scrolled .nav-progress{bottom:0;left:20px;right:20px;width:calc(var(--scroll-p, 0%) - 40px);border-radius:100px}
.nav-cta.inline { background: none; color: var(--text3); padding: 0; height: auto; border-radius: 0; font-weight: 500; font-size: inherit; }
.nav-cta.inline:hover { transform: none; box-shadow: none; color: var(--text); }

/* HERO */
.hero{position:relative;z-index:10;min-height:100svh;display:flex;align-items:center;padding:120px clamp(1.25rem,5vw,3rem) 60px;max-width:1440px;margin:0 auto}
.hero-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:4rem;align-items:center;width:100%}
.hero-content > * { opacity: 0; animation: heroIn .8s var(--ease-out) forwards; }
.hero-brand { animation-delay: .1s; }
.hero-h1 { animation-delay: .22s; }
.hero-sub { animation-delay: .34s; }
.hero-actions { animation-delay: .44s; }
.hero-stats { animation-delay: .54s; }
.hero-visual { opacity: 0; animation: heroIn 1s var(--ease-out) forwards .64s; }

@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:3rem;text-align:center}
  .hero-content{display:flex;flex-direction:column;align-items:center}
  .hero-visual{height:400px}
}

.hero-brand{font-size:clamp(1.4rem,3.5vw,2rem);font-weight:800;letter-spacing:-.04em;color:var(--text);margin-bottom:2rem;display:flex;align-items:center;gap:.5rem}
.hero-brand span{opacity:1}

.hero-h1{font-family:var(--serif);font-size:clamp(2.8rem,7.5vw,6rem);line-height:1.1;letter-spacing:0;color:var(--text);margin-bottom:1.5rem;max-width:100%}
.hero-h1 em{font-style:italic;color:var(--text3)}

.hero-sub{font-size:clamp(1.05rem,2vw,1.2rem);font-weight:300;line-height:1.75;color:var(--text2);max-width:580px;margin-bottom:2.5rem}

.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:4rem}

.hero-stats{display:flex;width:100%;max-width:800px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-top:2rem}
.hstat{flex:1;min-width:130px;padding:clamp(1.2rem,2.5vw,1.8rem) clamp(1rem,3vw,2rem);border-right:1px solid var(--border);position:relative;overflow:hidden;transition:background .3s var(--ease-out)}
.hstat:last-child{border-right:none}
.hstat::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.02),transparent);opacity:0;transition:opacity .3s}
.hstat:hover::after{opacity:1}
.hstat:hover{background:rgba(0,0,0,0.01)}
.hstat-num{font-family:var(--serif);font-size:clamp(1.6rem,4vw,2.4rem);color:var(--text);line-height:1;letter-spacing:0;margin-bottom:.35rem;display:block}
.hstat-lbl{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text3)}

/* HERO VISUAL - BITMOJI */
.hero-visual {
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden; /* Clips drifting bitmoji badges and prevents overflow */
}

.bitmoji-container {
  position: relative;
  width: 100%;
  max-width: 440px;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: bitmojiFloat 6s ease-in-out infinite;
}

.hero-bitmoji {
  width: 100%;
  height: auto;
  z-index: 5;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.15));
}

.bitmoji-glow {
  position: absolute;
  width: 140%;
  height: 140%;
  background: radial-gradient(circle, rgba(79,158,255,0.08) 0%, transparent 70%);
  z-index: 1;
}

.bitmoji-ring {
  position: absolute;
  border: 1px solid rgba(79,158,255,0.15);
  border-radius: 50%;
  z-index: 2;
}

.bitmoji-ring.r1 {
  width: 90%;
  height: 90%;
  border-style: dashed;
  animation: bitmojiSpin 40s linear infinite;
}

.bitmoji-ring.r2 {
  width: 115%;
  height: 115%;
  opacity: 0.5;
  animation: bitmojiSpin 60s linear infinite reverse;
}

.bitmoji-badge {
  position: absolute;
  background: white;
  border: 1px solid var(--border2);
  padding: 10px 18px;
  border-radius: 100px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.08);
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text);
  z-index: 6;
  white-space: nowrap;
}

.bitmoji-badge.b1 { top: 15%; left: -5%; animation: badgeFloat 5s ease-in-out infinite; }
.bitmoji-badge.b2 { bottom: 20%; right: -5%; animation: badgeFloat 5s ease-in-out infinite 1s reverse; }

@media (max-width: 600px) {
  .bitmoji-badge.b1 { left: 0; }
  .bitmoji-badge.b2 { right: 0; }
}

@keyframes bitmojiFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-20px); } }
@keyframes bitmojiSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes badgeFloat { 0%,100% { transform: translateY(0) rotate(2deg); } 50% { transform: translateY(-10px) rotate(-2deg); } }

.btn-p{display:inline-flex;align-items:center;gap:.45rem;height:46px;padding:0 1.65rem;border-radius:100px;background:var(--text);color:var(--bg);font-family:var(--sans);font-size:.88rem;font-weight:700;text-decoration:none;border:none;cursor:pointer;letter-spacing:-.01em;transition:transform .22s var(--spring-sm),box-shadow .22s,opacity .15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative;overflow:hidden}
.btn-p::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);transform:translateX(-100%);transition:transform 0s}
.btn-p:hover{transform:scale(1.03);box-shadow:0 0 0 5px rgba(0,0,0,.15)}
.btn-p:hover::after{transform:translateX(100%);transition:transform .45s ease}
.btn-p:active{transform:scale(0.95);opacity:.85;transition-duration:.08s}
.btn-p .arr{display:inline-block;transition:transform .22s var(--spring-sm)}
.btn-p:hover .arr{transform:translateX(3px)}

.btn-g{display:inline-flex;align-items:center;gap:.45rem;height:46px;padding:0 1.65rem;border-radius:100px;background:rgba(0,0,0,.04);color:var(--text2);border:1px solid var(--border2);font-family:var(--sans);font-size:.88rem;font-weight:500;text-decoration:none;cursor:pointer;letter-spacing:-.01em;transition:transform .22s var(--spring-sm),background .2s,border-color .2s,color .2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.btn-g:hover{background:rgba(0,0,0,.07);border-color:var(--border3);color:var(--text)}
.btn-g:active{transform:scale(0.95);transition-duration:.08s}

.hero-div{width:100%;height:1px;background:var(--border)}

/* MARQUEE */
.mwrap{position:relative;z-index:10;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent 0%,black 8%,black 92%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0%,black 8%,black 92%,transparent 100%)}
.mrow{display:flex;padding:.85rem 0;overflow:hidden}
.mtrack{display:flex;width:max-content;animation:scroll 40s linear infinite;will-change:transform}
.mrow:nth-child(2) .mtrack{animation-direction:reverse;animation-duration:32s}
.mtrack:hover{animation-play-state:paused}
@keyframes scroll{
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-33.33%, 0, 0); } /* Adjusting for 3 sets of clones */
}
.mi{display:flex;align-items:center;gap:1.5rem;padding:0 2rem;font-size:.71rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--text3);white-space:nowrap;transition:color .2s}
.mi:hover{color:var(--text2)}
.tarku-brand {
  font-family: 'Rollcage', var(--sans);
  color: var(--tarku) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-weight: 400 !important;
  font-style: normal !important;
  display: inline-block;
}
.mdot{width:3px;height:3px;border-radius:50%;background:var(--border3);flex-shrink:0}

/* SHARED */
.section{position:relative;z-index:10}
.wrap{max-width:1080px;margin:0 auto;padding:clamp(4rem,9vw,7rem) clamp(1.25rem,5vw,3rem)}
.nav-logo{font-size:.92rem;font-weight:700;letter-spacing:-.025em;text-decoration:none;color:var(--text)}
.nav-back{display:flex;align-items:center;gap:.35rem;font-size:.78rem;font-weight:600;color:var(--text3);text-decoration:none;transition:color .2s, transform .2s var(--spring-sm);padding:.5rem .8rem;background:rgba(0,0,0,0.03);border-radius:8px}
.nav-back:hover{color:var(--text);background:rgba(0,0,0,0.05);transform:translateX(-2px)}
.nav-links{display:flex;align-items:center;gap:clamp(1rem,3vw,2.5rem)}
.eyebrow{font-size:.67rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);display:flex;align-items:center;gap:.5rem;margin-bottom:.85rem}
.eyebrow::before{content:'';width:12px;height:1.5px;background:var(--blue);border-radius:1px;flex-shrink:0}
.sec-h{font-family:var(--serif);font-size:clamp(1.85rem,4vw,3.4rem);line-height:1.1;letter-spacing:-.01em;color:var(--text);margin-bottom:.8rem}
.sec-h em{font-style:italic;color:var(--text3)}
.sec-sub{font-size:.93rem;font-weight:300;color:var(--text2);line-height:1.72;max-width:460px}

/* SERVICES */
.svc-wrap{background:var(--surface);border-top:1px solid var(--border)}
.svc-hd{margin-bottom:clamp(2rem,4vw,3.5rem)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:22px;overflow:hidden}
@media(max-width:700px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--surface);padding:clamp(1.4rem,3.5vw,2.2rem);position:relative;overflow:hidden;transition:background .25s;-webkit-tap-highlight-color:transparent}
.svc::before{content:'';position:absolute;inset:-1px;background:radial-gradient(300px circle at var(--mx,50%) var(--my,50%),rgba(79,158,255,.08),transparent 60%);opacity:0;transition:opacity .35s;pointer-events:none}
.svc:hover{background:var(--surface2)}
.svc:hover::before{opacity:1}
.svc:active{background:var(--surface3)}
.pull-quote{background:rgba(0,0,0,0.02);border-left:2px solid var(--text);padding:32px;border-radius:0 16px 16px 0;margin:64px 0;position:relative}
.pull-quote p{font-family:var(--serif);font-size:clamp(1.4rem,3vw,1.8rem);line-height:1.4;color:var(--text);margin-bottom:24px;font-style:italic}
.pull-quote cite{display:block;font-style:normal;font-weight:600;font-size:0.9rem;color:var(--text2)}

/* Review Style */
.review-card{background:#fff;border:1px solid var(--border);border-radius:24px;padding:40px;margin:64px 0;box-shadow:0 4px 20px rgba(0,0,0,0.02)}
.rev-hd{display:flex;align-items:center;gap:16px;margin-bottom:24px}
.rev-avatar{width:48px;height:48px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text3);font-size:1.2rem;overflow:hidden}
.rev-avatar img{width:100%;height:100%;object-fit:cover}
.rev-meta{flex:1}
.rev-name{font-weight:700;color:var(--text);font-size:1rem;margin-bottom:2px}
.rev-stats{font-size:0.75rem;color:var(--text3);font-weight:500}
.rev-stars{color:#fbbc04;font-size:0.9rem;margin:12px 0 8px;display:flex;gap:2px}
.rev-date{font-size:0.75rem;color:var(--text3);margin-left:8px;font-weight:400}
.rev-body{font-size:1.05rem;line-height:1.7;color:var(--text2);font-weight:400}

/* The Archive - List Style */
.archive-wrap { 
  padding: 0 0 40px; 
}

.arch-hd {
  margin-bottom: 24px;
}

.arch-list {
  display: flex;
  flex-direction: column;
}

.arch-card {
  display: grid;
  grid-template-columns: 48px 1fr auto 24px;
  align-items: center;
  gap: 20px;
  padding: 20px 0;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: all 0.4s var(--ease-out);
  position: relative;
  background: none;
  border-radius: 0;
  text-decoration: none;
}

.arch-card:hover {
  background: var(--surface2);
  padding-left: 20px;
  padding-right: 20px;
  border-radius: 16px;
  border-bottom-color: transparent;
  transform: scale(1.01);
}

.arch-card:hover + .arch-card {
  border-top-color: transparent;
}

.arch-icon {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  padding: 6px;
  flex-shrink: 0;
}

.arch-icon img { width: 100%; height: 100%; object-fit: contain; }

.arch-content { 
  display: flex; 
  align-items: center; 
  gap: 12px;
}

.arch-title {
  font-weight: 600;
  font-size: 1rem;
  color: var(--text);
  margin-bottom: 0;
}

.arch-sub { display: none; } /* Kept clean in list view */

.arch-tag {
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 4px 10px;
  background: var(--surface3);
  border-radius: 6px;
  margin-top: 0 !important;
}

.arch-card::after {
  content: '→';
  justify-self: end;
  font-size: 1.1rem;
  color: var(--text3);
  opacity: 0.4;
  transition: all 0.3s var(--spring-sm);
}

.arch-card:hover::after {
  opacity: 1;
  color: var(--blue);
  transform: translateX(4px);
}

@media (max-width: 768px) {
  .arch-card {
    grid-template-columns: 36px 1fr auto;
    gap: 16px;
    padding: 16px 0;
  }
  .arch-card::after { display: none; }
}

/* Quick Look Modal */
.ql-overlay{position:fixed;inset:0;background:rgba(255,255,255,0.7);backdrop-filter:blur(10px);z-index:10000;display:flex;align-items:flex-start;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s ease;padding:20px;overflow-y:auto;scroll-behavior:smooth}
.ql-overlay.active{opacity:1;pointer-events:all}
.ql-modal{background:white;width:100%;max-width:600px;border-radius:32px;box-shadow:0 30px 100px rgba(0,0,0,0.15);overflow:hidden;transform:scale(0.95) translateY(40px);transition:all .5s var(--spring);margin:auto}
.ql-overlay.active .ql-modal{transform:scale(1) translateY(0)}
.ql-img{width:100%;max-height:60vh;background:var(--surface2);overflow-y:auto;position:relative;border-bottom:1px solid var(--border)}
.ql-scroll{display:grid;grid-template-columns:1fr;gap:12px;padding:24px}
.ql-scroll img{width:100%;height:auto;border-radius:18px;box-shadow:0 12px 32px rgba(0,0,0,0.08);background:white;display:block;margin-bottom:12px}
.ql-scroll::-webkit-scrollbar{width:6px}
.ql-scroll::-webkit-scrollbar-track{background:transparent}
.ql-scroll::-webkit-scrollbar-thumb{background:var(--border2);border-radius:10px}
.ql-body{padding:40px}
.ql-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,0.05);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}
.ql-close:hover{background:rgba(0,0,0,0.1)}
.ql-title{font-size:1.8rem;font-weight:700;margin-bottom:12px;color:var(--text)}
.ql-desc{color:var(--text2);line-height:1.7;margin-bottom:24px;font-size:1.05rem}
.ql-btns{display:flex;gap:12px}
.ql-btn{padding:12px 24px;border-radius:14px;font-weight:600;font-size:0.95rem;text-decoration:none;transition:all .2s}
.ql-btn-p{background:var(--blue);color:white}
.ql-btn-p:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,122,255,0.3)}
.ql-btn-s{background:var(--surface2);color:var(--text)}
.ql-btn-s:hover{background:var(--surface3)}

@media (max-width: 600px) {
  .ql-overlay { padding: 12px; }
  .ql-modal { border-radius: 24px; }
  .ql-img { max-height: 40vh; }
  .ql-body { padding: 24px; }
  .ql-title { font-size: 1.5rem; }
  .ql-desc { font-size: 0.95rem; }
  .ql-btns { flex-direction: column; width: 100%; }
  .ql-btn { width: 100%; text-align: center; }
}
/* SERVICES REDESIGN - BESPOKE FLOW */
.svc-wrap { padding: 80px 0; border-top: 1px solid var(--border); }
.svc-list { display: flex; flex-direction: column; }
.svc-item { 
  display: grid; 
  grid-template-columns: 1fr 1fr; 
  gap: clamp(2rem, 6vw, 5rem);
  padding: 48px 24px; 
  border-bottom: 1px solid var(--border);
  transition: all 0.4s var(--ease-out);
  position: relative;
  align-items: flex-start;
}
@media (max-width: 900px) {
  .svc-item { grid-template-columns: 1fr; gap: 16px; padding: 40px 16px; }
  .svc-body { margin-top: 0; }
}
@media (max-width: 600px) {
  .svc-item { grid-template-columns: 1fr; gap: 12px; padding: 24px 0; }
  .svc-body { grid-column: 1; }
  .svc-n { display: none; }
}
.svc-item:hover { 
  background: var(--surface2); 
  border-radius: 20px;
  border-bottom-color: transparent;
}
.svc-n { 
  font-family: var(--serif); 
  font-size: 1.2rem; 
  font-style: italic; 
  color: var(--text3); 
  opacity: 0.5;
}
.svc-title { 
  font-family: var(--serif); 
  font-size: clamp(1.8rem, 4vw, 2.8rem); 
  line-height: 1; 
  color: var(--text); 
  margin: 0;
}
.svc-body { 
  font-size: 1.05rem; 
  color: var(--text2); 
  line-height: 1.6; 
  max-width: 500px;
}
.svc-tools { 
  display: flex; 
  gap: 8px; 
  margin-top: 12px;
  opacity: 1;
  transform: translateY(0);
}
.tool-tag { 
  font-size: 0.65rem; 
  font-weight: 700; 
  text-transform: uppercase; 
  letter-spacing: 0.08em; 
  padding: 6px 12px; 
  background: var(--surface); 
  border: 1px solid var(--border); 
  border-radius: 100px;
  color: var(--text3);
}
.svc-arr { 
  display: none;
}

@media (max-width: 960px) {
  .svc-item { grid-template-columns: 1fr; gap: 20px; padding: 40px 0; }
  .svc-item:hover { 
    background: var(--surface2);
  }
  .svc-n { display: none; }
  .svc-arr { display: none; }
}

/* WORK */
.work-wrap{border-top:1px solid var(--border)}
.work-hd{margin-bottom:clamp(2rem,4vw,3.5rem)}
.wgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.75rem,1.8vw,1.2rem)}
@media(max-width:620px){.wgrid{grid-template-columns:1fr}}
.wcard{background:var(--surface);border:1px solid var(--border);border-radius:22px;padding:clamp(1.4rem,4vw,2rem);text-decoration:none;color:inherit;display:flex;flex-direction:column;position:relative;overflow:hidden;will-change:transform;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:border-color .4s,box-shadow .4s var(--ease-out),transform .4s var(--spring-sm)}
.wcard::before{content:'';position:absolute;inset:-1px;border-radius:22px;background:linear-gradient(135deg,var(--cc,var(--blue)),var(--purple));opacity:0;z-index:-1;transition:opacity .3s}
.wcard::after{content:'';position:absolute;inset:1px;border-radius:21px;background:var(--surface);z-index:-1;transition:background .3s}
.wcard:hover{border-color:transparent;box-shadow:0 32px 80px rgba(0,0,0,.08);}
@media (hover: hover) {
  .wcard:hover { transform: translateY(-8px); }
}
.wcard:hover .wcard-img img{transform:scale(1.05)}
.wcard:hover::before{opacity:1}
.wcard:hover::after{background:var(--surface2)}
.wcard:active{transform:scale(.97) translateY(0);transition-duration:.1s}
.wcard {
  perspective: 2000px;
}
.wcard-inner {
  height: 100%;
  width: 100%;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
  transform-style: preserve-3d;
}
.wcard:hover .wcard-inner {
  transform: rotateX(2deg) rotateY(-2deg) translateZ(10px);
}
.wcard.feat{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.25rem,3vw,2rem);align-items:center}
@media(max-width:620px){.wcard.feat{grid-column:span 1;grid-template-columns:1fr}}
.wcard-img{width:100%;height:220px;border-radius:18px;overflow:hidden;background:var(--surface2);position:relative;margin-bottom:1.5rem;border:1px solid var(--border);flex-shrink:0}
.wcard.feat .wcard-img{margin-bottom:0;height:100%;min-height:300px}
.wcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.wcard:hover .wcard-img img{transform:scale(1.04)}
.wcard-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.2rem}
.wcard-ico{width:50px;height:50px;border-radius:14px;background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;transition:transform .4s var(--spring),box-shadow .3s}
.wcard:hover .wcard-ico{transform:rotate(-8deg) scale(1.12);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.wcard-arr{font-size:1.1rem;color:var(--text3);line-height:1;transition:color .2s,transform .35s var(--spring-sm)}
.wcard:hover .wcard-arr{color:var(--text);transform:translate(4px,-4px)}
.wcard-title{font-family:var(--serif);font-size:clamp(1rem,2.5vw,1.18rem);color:var(--text);margin-bottom:.5rem;letter-spacing:0}
.wcard-body{font-size:.82rem;color:var(--text2);line-height:1.72;font-weight:300;flex-grow:1}
.wtags{display:flex;gap:.38rem;flex-wrap:wrap;margin-top:auto;padding-top:1.5rem}
.wtag{font-size:.63rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:.26rem .7rem;border-radius:100px;background:var(--blue-dim);color:var(--blue);border:1px solid rgba(79,158,255,.18)}
.feat-metric{background:var(--surface2);border-radius:16px;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;min-height:155px;padding:2rem;text-align:center;transition:background .3s}
.wcard:hover .feat-metric{background:var(--surface3)}
.feat-num{font-family:var(--serif);font-size:clamp(3rem,6vw,4.5rem);letter-spacing:-.02em;color:var(--text);line-height:1}
.feat-lbl{font-size:.74rem;color:var(--text3);margin-top:.4rem}

/* BENTO */
.about-wrap{background:var(--surface);border-top:1px solid var(--border)}
.bento{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:180px;gap:20px;margin-top:clamp(2.5rem,5.5vw,4.5rem)}
@media(max-width:960px){.bento{display:flex!important;flex-direction:column!important}.bc{width:100%!important;min-height:220px!important;margin-bottom:12px}}
.bc{border:1px solid var(--border);border-radius:36px;padding:2rem;overflow:hidden;position:relative;background:var(--bg);transition:border-color .5s var(--ease-out),transform .5s var(--spring-sm),box-shadow .5s var(--ease-out);display:flex;flex-direction:column;justify-content:space-between;-webkit-tap-highlight-color:transparent;box-shadow:0 0 0 rgba(0,0,0,0)}
.bc:hover{border-color:var(--border3);box-shadow:0 30px 60px rgba(0,0,0,0.06)}
@media (hover: hover) {
  .bc:hover { transform: translateY(-10px); }
}
.bc-selfie{grid-column:span 4;grid-row:span 2;padding:0!important;background:var(--surface2)}
.bc-selfie img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out)}
.bc-selfie:hover img{transform:scale(1.08)}
.bc-bio{grid-column:span 8;grid-row:span 2;background:var(--surface2);justify-content:space-between}
.bc-social{grid-column:span 4;grid-row:span 1;flex-direction:row;align-items:center;justify-content:space-between;padding:0 2rem!important;background:linear-gradient(to bottom right, var(--bg), var(--surface2))}
.bc-rev{grid-column:span 4;grid-row:span 1;text-align:center;background:#fff}
.bc-npm{grid-column:span 4;grid-row:span 1;text-align:center;background:#fff}
.bc-yt{grid-column:span 3;grid-row:span 2;background:linear-gradient(135deg,#cc0000,#a00000);color:white;border-color:rgba(255,255,255,0.15);text-align:center}
.bc-sk{grid-column:span 3;grid-row:span 2;background:var(--surface2)}
.bc-disc{grid-column:span 3;grid-row:span 2;background:linear-gradient(135deg,#5865F2,#3b45a0);color:white;border-color:rgba(255,255,255,0.15);text-align:center}
.bc-edu{grid-column:span 3;grid-row:span 2;text-align:center;background:var(--surface3);justify-content:center}
.soc-link{font-size:0.75rem;font-weight:700;letter-spacing:0.05em;color:var(--text3);transition:all .3s var(--ease-out);text-decoration:none;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:var(--surface2);border:1px solid var(--border)}
.soc-link:hover{color:white;transform:translateY(-3px) scale(1.1);border-color:transparent;box-shadow:0 10px 20px rgba(0,0,0,0.1)}
.soc-gh:hover{background:#24292e}
.soc-li:hover{background:#0077b5}
.soc-x:hover{background:#000000}
.soc-ig:hover{background:linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%)}
.soc-sp:hover{background:#1DB954}
.soc-am:hover{background:#fa243c}
.bc-lbl{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:8px;margin-bottom:0}
.bc-num{font-family:var(--serif);font-size:clamp(2.4rem,4.5vw,2.8rem);letter-spacing:-.04em;line-height:1;color:var(--text);margin:0.5rem 0}
.bc-sub{font-size:.82rem;font-weight:400;color:var(--text2);line-height:1.45;margin-top:0}
.bc-social .soc-link{width:46px;height:46px;font-size:1.3rem;border-radius:16px}
.bc-bio .bc-body{font-family:var(--sans);font-weight:300;font-size:clamp(1rem,2vw,1.15rem);color:var(--text2);line-height:1.65;margin-top:1.5rem}
.bc-bio .bc-body strong{color:var(--text);font-weight:600}
.bc-npm .bc-num{color:var(--warm)}
.bc-disc .bc-lbl,.bc-yt .bc-lbl{color:rgba(255,255,255,0.7);margin-bottom:0}
.bc-disc .bc-num,.bc-yt .bc-num{color:white;font-size:clamp(2.8rem,6vw,4rem)}
.bc-disc .bc-sub,.bc-yt .bc-sub{color:rgba(255,255,255,0.85);font-weight:400;max-width:100%}
.bc-sk .spills{margin-top:1.2rem;gap:.6rem;display:grid;grid-template-columns:1fr 1fr}
.sp{font-size:.7rem;font-weight:600;padding:.45rem .6rem;border-radius:12px;background:var(--bg);border:1px solid var(--border);color:var(--text2);display:flex;align-items:center;justify-content:center;text-align:center}
.bc-sk .bc-lbl{margin-bottom:0}
.bc-edu .bc-body{font-size:.85rem;color:var(--text2);line-height:1.5;margin-top:0.8rem}
.bc-status{display:flex;align-items:center;gap:6px;font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--green)}
.bc-status::before{content:'';width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 10px var(--green)}
.bc-bio-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:0;width:100%}
.bc-bio-hd .bc-lbl{margin-bottom:0}
.bc-edu .bc-body{font-size:.8rem;color:var(--text2);line-height:1.5;margin-top:0.6rem}
.bc-edu .bc-body strong{color:var(--text);font-weight:500}

/* CTA */
.cta-wrap{border-top:1px solid var(--border);padding:clamp(5rem,11vw,9rem) clamp(1.25rem,5vw,3rem);text-align:center;position:relative;overflow:hidden}
.cta-orb{position:absolute;border-radius:50%;filter:blur(130px);pointer-events:none}
.co1{width:600px;height:600px;background:var(--blue);opacity:.1;top:-200px;left:50%;transform:translateX(-50%);will-change:transform}
.co2{width:350px;height:350px;background:var(--purple);opacity:.09;bottom:-80px;right:8%;will-change:transform}
.cta-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}
.cta-ey{font-size:.67rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:1.4rem}
.cta-h{font-family:var(--serif);font-size:clamp(2.75rem,8vw,6.5rem);line-height:1.15;letter-spacing:-.01em;color:var(--text);margin-bottom:1.5rem}
.cta-h em{font-style:italic;color:var(--text3)}
.cta-sub{font-size:clamp(1.05rem,2.2vw,1.25rem);color:var(--text2);font-weight:300;line-height:1.8;margin-bottom:clamp(2.5rem,4vw,3.5rem);max-width:540px;margin-left:auto;margin-right:auto}
.cta-acts{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

#cc{position:fixed;inset:0;pointer-events:none;z-index:9999}

footer{position:relative;z-index:10;border-top:1px solid var(--border);padding:1.6rem clamp(1.25rem,5vw,3rem);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;background:var(--bg)}
.fc{font-size:.73rem;color:var(--text3)}
.fl{display:flex;gap:1.5rem}
.fl a{font-size:.73rem;color:var(--text3);text-decoration:none;transition:color .2s;padding:.4rem 0;-webkit-tap-highlight-color:transparent}
.fl a:hover{color:var(--text)}

/* REVEAL SYSTEM - APPLE INSPIRED */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  filter: blur(4px);
  will-change: transform, opacity, filter;
  transition: opacity 1.2s cubic-bezier(0.25, 1, 0.5, 1),
              transform 1.2s cubic-bezier(0.25, 1, 0.5, 1),
              filter 1.2s cubic-bezier(0.25, 1, 0.5, 1);
}

.reveal.rev-left { transform: translateX(-40px); }
.reveal.rev-right { transform: translateX(40px); }
.reveal.rev-up { transform: translateY(40px); }
.reveal.rev-scale { transform: scale(0.92) translateY(20px); }

.reveal.in {
  opacity: 1;
  transform: translate(0, 0) scale(1);
  filter: blur(0);
}

.d0 { transition-delay: 0s; }
.d1 { transition-delay: 0.1s; }
.d2 { transition-delay: 0.2s; }
.d3 { transition-delay: 0.3s; }
.d4 { transition-delay: 0.4s; }
.d5 { transition-delay: 0.5s; }

/* Parallax Background Orbs */
.scene {
  will-change: transform;
}

.page-fade{position:fixed;inset:0;background:var(--bg);z-index:9990;pointer-events:none;animation:pf .5s ease forwards}
@keyframes pf{to{opacity:0}}

/* The old modal code from line 283-499 is replaced by the refined modal section at the end of the file */

.arch-card:hover {
  transform: translateY(-8px);
  border-color: var(--border3);
  background: #ffffff;
  box-shadow: 0 20px 40px rgba(0,0,0,0.04);
}
.arch-card:hover .arch-icon {
  transform: scale(1.15) rotate(-5deg);
}
.arch-title { font-weight: 600; font-size: 1.05rem; margin-bottom: 4px; transition: color 0.3s; }
.arch-card:hover .arch-title { color: var(--blue); }
.project-hero {
  padding: 160px 24px 80px;
  background: var(--surface-hover);
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

.project-hero .subtitle {
  margin: 1.5rem 0 2rem;
  max-width: 800px;
}

.project-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 32px;
  margin-top: 48px;
}

.meta-item label {
  display: block;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text-light);
  margin-bottom: 8px;
  letter-spacing: 0.05em;
}

.meta-item span {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--text);
}

.project-container {
  max-width: 800px;
  margin: 0 auto;
  padding: 80px 24px;
}

.project-body {
  font-size: 1.1rem;
  line-height: 1.7;
  color: var(--text);
}

.project-body h2 {
  margin: 3rem 0 1.5rem;
  font-size: 2rem;
}

.project-body p {
  margin-bottom: 1.5rem;
  color: #424245; /* Slightly softer black for long reading */
}

.project-body ul, .project-body ol {
  margin-bottom: 1.5rem;
  padding-left: 20px;
}

.project-body li {
  margin-bottom: 0.5rem;
}

.project-image-large {
  width: 100%;
  margin-top: 2rem;
  margin-bottom: 4rem;
  max-width: 1200px;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(0,0,0,0.1);
  border: 1px solid var(--border);
}
.project-image-large img {
  width: 100%;
  height: auto;
  display: block;
}
.case-img {
  width: 100%;
  border-radius: 24px;
  overflow: hidden;
  margin: 3rem 0;
  border: 1px solid var(--border);
  box-shadow: 0 30px 60px rgba(0,0,0,0.08);
}
.case-top-img {
  max-width: 1200px;
  margin: 2rem auto 4rem;
  padding: 0 clamp(1.25rem, 5vw, 3rem);
  position: relative;
  z-index: 20;
}
.case-top-img img {
  width: 100%;
  border-radius: 28px;
  box-shadow: 0 40px 100px rgba(0,0,0,0.12);
  border: 1px solid var(--border);
}
.case-img img {
  width: 100%;
  height: auto;
  display: block;
}

.project-footer-nav {
  border-top: 1px solid var(--border);
  padding: 80px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 80px;
}

@media (max-width: 768px) {
  .project-hero { padding-top: 100px; }
  .project-container { padding: 40px 24px; }
}


/* PROJECT PAGE STYLES */
.case-hero{position:relative;z-index:10;min-height:75vh;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(5rem,12vw,9rem) clamp(1.25rem,5vw,3rem) clamp(2.5rem,5vw,4rem)}
.case-hero-inner{max-width:1080px;margin:0 auto;width:100%}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.72rem;color:var(--text3);margin-bottom:clamp(1.5rem,3vw,2rem);opacity:0;animation:heroIn .7s var(--ease-out) .2s forwards}
.breadcrumb a{color:var(--text3);text-decoration:none;transition:color .2s}
.breadcrumb a:hover{color:var(--text2)}
.breadcrumb span{color:var(--border3)}
.case-tag{display:inline-flex;align-items:center;gap:.5rem;border:1px solid var(--tag-color,rgba(79,158,255,.25));border-radius:100px;padding:.38rem .9rem .38rem .55rem;margin-bottom:clamp(1rem,2.5vw,1.5rem);background:var(--tag-bg,rgba(79,158,255,.06));width:fit-content;opacity:0;animation:heroIn .7s var(--ease-out) .28s forwards}
.tag-dot{width:6px;height:6px;border-radius:50%;background:var(--tag-accent,var(--blue));animation:pip 2.8s ease infinite}
@keyframes pip{0%,100%{box-shadow:0 0 0 3px var(--tag-color,rgba(79,158,255,.25))}50%{box-shadow:0 0 0 6px var(--tag-bg,rgba(79,158,255,.06))}}
.case-tag span{font-size:.73rem;font-weight:500;color:var(--tag-accent,var(--blue))}
.case-h1{font-family:var(--serif);font-size:clamp(2.6rem,7.5vw,6rem);line-height:1.1;letter-spacing:-.01em;color:var(--text);margin-bottom:clamp(1rem,2vw,1.5rem);max-width:900px;opacity:0;animation:heroIn .9s var(--ease-out) .35s forwards}
.case-h1 em{font-style:italic;color:var(--text3)}
.case-sub{font-size:clamp(.92rem,1.9vw,1.05rem);font-weight:300;color:var(--text2);line-height:1.78;max-width:580px;margin-bottom:clamp(2rem,4vw,3rem);opacity:0;animation:heroIn .8s var(--ease-out) .48s forwards}
.case-meta-row{display:flex;gap:clamp(1.5rem,4vw,3rem);flex-wrap:wrap;padding-top:clamp(1.5rem,3vw,2rem);border-top:1px solid var(--border);opacity:0;animation:heroIn .7s var(--ease-out) .6s forwards}
.case-meta{display:flex;flex-direction:column;gap:.25rem}
.case-meta-label{font-size:.65rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--text3)}
.case-meta-val{font-size:.88rem;color:var(--text2)}
@keyframes heroIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.stat-banner{position:relative;z-index:10;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap}
.stat-cell{flex:1;min-width:130px;padding:clamp(1.1rem,3vw,1.75rem) clamp(1rem,3vw,2rem);border-right:1px solid var(--border);position:relative;overflow:hidden;transition:background .25s}
.stat-cell:last-child{border-right:none}
.stat-cell:hover{background:rgba(0,0,0,.02)}
.stat-num{font-family:var(--serif);font-size:clamp(1.8rem,4.5vw,2.8rem);letter-spacing:-.02em;line-height:1;color:var(--text);margin-bottom:.3rem;display:block}
.stat-lbl{font-size:.69rem;color:var(--text3);line-height:1.4}
.case-body{position:relative;z-index:10;max-width:1080px;margin:0 auto;padding:clamp(3rem,7vw,5.5rem) clamp(1.25rem,5vw,3rem)}
.prose-section{display:grid;grid-template-columns:1fr 2.4fr;gap:clamp(2rem,5vw,5rem);margin-bottom:clamp(2.5rem,6vw,5rem);align-items:start}
@media(max-width:680px){.prose-section{grid-template-columns:1fr}}
.prose-sidebar{position:sticky;top:80px}
.section-label{font-size:.67rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent,var(--blue));display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}
.section-label::before{content:'';width:12px;height:1.5px;background:var(--accent,var(--blue));border-radius:1px;flex-shrink:0}
.section-num{font-family:var(--serif);font-size:clamp(2.8rem,5.5vw,4.5rem);font-style:italic;line-height:1;letter-spacing:-.03em;color:var(--border2);margin-top:.5rem}
.prose-content h2{font-family:var(--serif);font-size:clamp(1.55rem,3.2vw,2.25rem);line-height:1.15;letter-spacing:-.02em;color:var(--text);margin-bottom:.95rem}
.prose-content h3{font-family:var(--serif);font-size:clamp(1.1rem,2.3vw,1.4rem);line-height:1.25;letter-spacing:-.015em;color:var(--text);margin-bottom:.6rem;margin-top:2rem}
.prose-content p{font-size:clamp(.88rem,1.7vw,.98rem);font-weight:300;color:var(--text2);line-height:1.85;margin-bottom:1.2rem}
.prose-content p strong{color:var(--text);font-weight:500}
.prose-content ul{margin-bottom:1.2rem;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:.55rem}
.prose-content ul li{font-size:clamp(.86rem,1.7vw,.96rem);font-weight:300;color:var(--text2);line-height:1.7;padding-left:1.5rem;position:relative}
.prose-content ul li::before{content:'→';position:absolute;left:0;color:var(--accent,var(--blue));font-size:.78rem;top:.18em;font-weight:700}
.pull-quote{border-left:2px solid var(--accent,var(--blue));padding:1.15rem 1.4rem;margin:1.75rem 0;background:rgba(79,158,255,.04);border-radius:0 8px 8px 0}
.pull-quote p{font-family:var(--serif);font-size:clamp(.98rem,2.3vw,1.25rem)!important;font-style:italic;color:var(--text)!important;line-height:1.6!important;margin-bottom:0!important}
.pull-quote cite{font-size:.73rem;color:var(--text3);margin-top:.45rem;display:block;font-style:normal}
.metric-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem;margin:1.6rem 0}
.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.1rem 1.15rem;transition:border-color .25s,transform .3s var(--spring-sm)}
.metric-card:hover{border-color:var(--border2);transform:translateY(-3px)}
.metric-card-num{font-family:var(--serif);font-size:1.8rem;letter-spacing:-.03em;line-height:1;margin-bottom:.22rem}
.metric-card-lbl{font-size:.68rem;color:var(--text3);line-height:1.4}
.mc-blue{color:var(--blue)}.mc-green{color:var(--green)}.mc-purple{color:var(--purple)}.mc-warm{color:var(--warm)}.mc-yellow{color:var(--yellow)}
.step-list{display:flex;flex-direction:column;margin:1.6rem 0}
.step{display:grid;grid-template-columns:40px 1fr;gap:.9rem;padding:1rem 0;border-bottom:1px solid var(--border)}
.step:last-child{border-bottom:none}
.step-num{width:32px;height:32px;border-radius:50%;background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.82rem;color:var(--text3);flex-shrink:0;margin-top:.1rem}
.step-title{font-size:.9rem;font-weight:600;color:var(--text);margin-bottom:.28rem;letter-spacing:-.01em}
.step-desc{font-size:.82rem;font-weight:300;color:var(--text2);line-height:1.65}
.stack-row{display:flex;flex-wrap:wrap;gap:.42rem;margin:1.15rem 0}
.stag{font-size:.67rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;padding:.28rem .72rem;border-radius:100px;background:rgba(79,158,255,.07);color:var(--blue);border:1px solid rgba(79,158,255,.16)}
.code-block{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:1.1rem 1.35rem;margin:1.35rem 0;overflow-x:auto}
.code-block pre{font-family:'Geist Mono','Fira Code',monospace;font-size:.78rem;line-height:1.72;color:var(--text2)}
.kw{color:var(--purple)}.str{color:var(--green)}.fn{color:var(--blue)}.cm{color:var(--text3);font-style:italic}
.divider{height:1px;background:var(--border);margin:clamp(2rem,4.5vw,3.5rem) 0}
.next-case{position:relative;z-index:10;background:var(--surface);border-top:1px solid var(--border);padding:clamp(2.5rem,6vw,4.5rem) clamp(1.25rem,5vw,3rem)}
.next-inner{max-width:1080px;margin:0 auto;display:flex;justify-content:space-between;align-items:stretch;gap:2rem;flex-wrap:wrap}
.nc-col{flex:1;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding:1rem 0;min-width:300px}
.nc-prev{border-right:1px solid var(--border);padding-right:2rem}
.nc-next{padding-left:2rem;flex-direction:row-reverse;text-align:right}
@media(max-width:768px){.nc-col{flex-direction:column;text-align:center;justify-content:center;gap:1rem}.nc-next{flex-direction:column}.nc-prev{border-right:none;border-bottom:1px solid var(--border);padding-right:0;padding-bottom:2rem}.nc-next{padding-left:0;padding-top:2rem}}
.next-label{font-size:.67rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:.45rem}
.next-title{font-family:var(--serif);font-size:clamp(1.3rem,3vw,2.4rem);color:var(--text);letter-spacing:-.02em;margin-bottom:.5rem}
.next-sub{font-size:.85rem;color:var(--text3);margin-top:.3rem;font-style:italic;font-family:var(--serif);opacity:0.8}
.next-case::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 4px;
  background: var(--accent, var(--text));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.6s var(--spring-sm);
}
.next-case:hover::after { transform: scaleX(1); }
.btn-p{display:inline-flex;align-items:center;gap:.45rem;height:var(--tap);padding:0 1.5rem;border-radius:100px;background:var(--text);color:var(--bg);font-family:var(--sans);font-size:.86rem;font-weight:700;text-decoration:none;flex-shrink:0;transition:transform .22s var(--spring-sm),box-shadow .22s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.btn-p:hover{transform:scale(1.04);box-shadow:0 0 0 5px rgba(242,242,240,.1)}
.btn-p:active{transform:scale(.95);transition-duration:.08s}
.btn-g{display:inline-flex;align-items:center;gap:.42rem;height:var(--tap);padding:0 1.3rem;border-radius:100px;background:transparent;border:1px solid var(--border2);color:var(--text2);font-family:var(--sans);font-size:.86rem;font-weight:500;text-decoration:none;transition:border-color .2s,color .2s,transform .2s var(--spring-sm);-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.btn-g:hover{border-color:var(--border3);color:var(--text)}
.btn-g:active{transform:scale(.95);transition-duration:.08s}
.reveal {
  opacity: 0;
  transform: translateY(40px) scale(0.96);
  transition: opacity 0.85s var(--ease-out), transform 0.85s var(--spring-sm);
  will-change: transform, opacity;
}
.reveal.in {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.d1 { transition-delay: 0.05s; }
.d2 { transition-delay: 0.1s; }
.d3 { transition-delay: 0.15s; }
.d4 { transition-delay: 0.2s; }
.d5 { transition-delay: 0.25s; }
.d6 { transition-delay: 0.3s; }
.d7 { transition-delay: 0.35s; }
.d8 { transition-delay: 0.4s; }
footer{
  position:relative;
  z-index:10;
  border-top:1px solid var(--border);
  padding: 60px 40px;
  background: var(--bg);
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 40px;
  flex-wrap: wrap;
}
.fc{font-size:.78rem;color:var(--text3);line-height:1.6}
.fl{display:flex;gap:32px;align-items:center}
.fl a{font-size:.78rem;color:var(--text2);text-decoration:none;transition:color .2s;font-weight:500}
.fl a:hover{color:var(--text)}

@media (max-width: 900px) {
  footer { flex-direction: column; align-items: flex-start; padding: 48px 24px; text-align: left; }
  .fl { flex-direction: column; align-items: flex-start; gap: 16px; }
  .fc { order: 2; width: 100%; }
  .fl { order: 1; }
}

.magnetic-wrap { display: inline-block; transition: transform 0.4s var(--ease-out); }
.nav-cta.inline { 
  display: inline-block; 
  transition: color 0.2s, transform 0.2s cubic-bezier(0.23, 1, 0.32, 1); 
  transform-origin: center;
}

.section-label,.section-label::before{color:var(--accent);background:var(--accent)}
:root{
  --bg:#fcfcfc;--surface:#ffffff;--surface2:#fbfbfd;--surface3:#f5f5f7;
  --border:rgba(0,0,0,0.06);--border2:rgba(0,0,0,0.11);--border3:rgba(0,0,0,0.18);
  --text:#1d1d1f;--text2:rgba(29,29,31,0.7);--text3:rgba(29,29,31,0.45);
  --blue:#0071e3;--blue-dim:rgba(0,113,227,0.12);--purple:#af52de;
  --green:#34c759;--warm:#ff6b35;--yellow:#ff9500;
  --serif:'Instrument Serif',Georgia,serif;--sans:'Geist',-apple-system,sans-serif;
  --spring:cubic-bezier(0.34,1.56,0.64,1);
  --spring-sm:cubic-bezier(0.34,1.3,0.64,1);
  --ease-out:cubic-bezier(0.22,1,0.36,1);
  --tap:44px;
}
.stag{background:color-mix(in srgb,var(--accent) 8%,transparent);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 20%,transparent)}
.pull-quote{border-left-color:var(--accent);background:color-mix(in srgb,var(--accent) 4%,transparent)}
.prose-content ul li::before{color:var(--accent)}


/* COMET ANIMATIONS */
.comet1,.comet2,.comet3{
  stroke-dasharray: 100 2400;
  stroke-dashoffset: 2500;
  stroke-linecap: round;
  filter: drop-shadow(0 0 8px currentColor);
  opacity: 0.8;
}
.comet1 { color: var(--blue); animation: cometAnim 8s cubic-bezier(0.4, 0, 0.2, 1) infinite; }
.comet2 { color: var(--blue); animation: cometAnim 12s cubic-bezier(0.4, 0, 0.2, 1) infinite 4s; }
.comet3 { color: var(--purple); animation: cometAnim 10s cubic-bezier(0.4, 0, 0.2, 1) infinite 2s; }

@keyframes cometAnim {
  0% { stroke-dashoffset: 2500; opacity: 0; }
  10% { opacity: 1; }
  70% { opacity: 1; }
  100% { stroke-dashoffset: -100; opacity: 0; }
}

/* PAGE TRANSITIONS */
.pt-curtain {
  position: fixed;
  inset: 0;
  z-index: 10000;
  pointer-events: none;
  display: flex;
  flex-direction: column;
}
.pt-panel {
  flex: 1;
  background: #0b0b0a;
  transform: translateX(-100%);
  transition: transform 0.6s cubic-bezier(0.82, 0, 0.18, 1);
  will-change: transform;
}
.pt-panel:nth-child(2) { transition-delay: 0.04s; }
.pt-panel:nth-child(3) { transition-delay: 0.08s; }

.pt-curtain.active .pt-panel {
  transform: translateX(0);
  pointer-events: auto;
}
.pt-curtain.reveal-pt .pt-panel {
  transform: translateX(100%);
}
/* MODAL REFINEMENTS */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(12px);
  z-index: 10000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal-overlay.active { opacity: 1; pointer-events: auto; }

.modal-content {
  background: #ffffff;
  width: 100%;
  max-width: 500px;
  border-radius: 32px;
  padding: 40px;
  position: relative;
  box-shadow: 0 40px 100px rgba(0,0,0,0.25);
  transform: translateY(30px) scale(0.96);
  transition: transform 0.5s var(--spring-sm);
}
.modal-overlay.active .modal-content { transform: translateY(0) scale(1); }

.modal-header { margin-bottom: 32px; }
.modal-tag { font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--blue); margin-bottom: 12px; }
.modal-title { font-family: var(--serif); font-size: 2.2rem; line-height: 1.1; margin-bottom: 12px; }
.modal-desc { font-size: 0.95rem; color: var(--text2); line-height: 1.6; font-weight: 300; }

.booking-options { display: grid; grid-template-columns: 1fr; gap: 12px; }
.modal-btn-option {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  background: #f8f8f7;
  border: 1px solid var(--border);
  border-radius: 16px;
  text-align: left;
  cursor: pointer;
  transition: transform 0.2s, background 0.2s, border-color 0.2s;
}
.modal-btn-option:hover { transform: scale(1.02); background: #ffffff; border-color: var(--blue); }
.opt-icon { font-size: 1.5rem; }
.opt-text strong { display: block; font-size: 0.95rem; margin-bottom: 2px; }
.opt-text span { font-size: 0.75rem; color: var(--text3); }

.booking-step { display: none; }
.booking-step.active { display: block; animation: stepFade .4s ease forwards; }
@keyframes stepFade { from { opacity: 0; transform: translateX(10px); } to { opacity: 1; transform: translateX(0); } }

.modal-back {
  background: none; border: none; padding: 0; margin-bottom: 24px;
  font-size: 0.75rem; font-weight: 600; color: var(--text3);
  display: flex; align-items: center; gap: 4px; cursor: pointer;
}
.modal-back:hover { color: var(--text); }

.calendar-wrap { margin-bottom: 24px; border: 1px solid var(--border); border-radius: 16px; padding: 16px; }
.days-grid { display: grid; grid-template-columns: repeat(7, 1fr); text-align: center; font-size: 0.65rem; color: var(--text3); margin-bottom: 12px; }
.dates-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; align-items: stretch; }
.date-btn {
  border: none; background: none; padding: 12px 0; border-radius: 12px;
  display: flex; flex-direction: column; align-items: center; justify-content: center; cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.date-btn:hover:not(:disabled) { background: rgba(0,0,0,0.05); }
.date-btn.active { background: var(--blue); color: #fff; }
.date-btn strong { font-size: 0.95rem; font-weight: 600; }

.time-slots { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; height: 0; overflow: hidden; transition: height 0.3s; }
.time-slots.active { height: auto; margin-top: 16px; }
.time-slot {
  padding: 10px; background: #fff; border: 1px solid var(--border);
  border-radius: 10px; font-size: 0.85rem; font-weight: 500; cursor: pointer;
}
.time-slot:hover { border-color: var(--blue); color: var(--blue); }

.booking-form .form-group { margin-bottom: 16px; }
.booking-form label { display: block; font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text3); margin-bottom: 6px; }
.booking-form input, .booking-form textarea {
  width: 100%; padding: 12px 16px; border-radius: 12px; border: 1px solid var(--border); background: #f8f8f7;
  font-family: inherit; font-size: 0.95rem; transition: border-color 0.2s, background 0.2s;
}
.booking-form input:focus, .booking-form textarea:focus { outline: none; border-color: var(--blue); background: #fff; }

.success-wrap { text-align: center; padding: 20px 0; }
.success-icon { font-size: 3rem; margin-bottom: 20px; }

.modal-close {
  position: absolute; top: 20px; right: 20px; background: none; border: none;
  color: var(--text3); cursor: pointer; transition: color 0.2s;
}
.modal-close:hover { color: var(--text); }

/* YouTube Card Enhancements */
.bc-yt .yt-content { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.bc-yt .yt-row { display: flex; gap: 24px; align-items: baseline; }
.counter { display: inline-block; font-variant-numeric: tabular-nums; }

@media (max-width: 480px) {
  .bc-yt .yt-row { flex-direction: column; gap: 4px; }
}


