﻿/* Landing v3 — Premium AI Portfolio with Mega Joule Orb */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f8f7ff;--surface:#fff;--surface-2:#f5f3ff;
  --glass:rgba(255,255,255,.62);--glass-strong:rgba(255,255,255,.82);
  --glass-bd:rgba(140,150,200,.20);--glass-bd-strong:rgba(140,150,200,.32);
  --ink:#0a0e27;--ink-2:#1e2540;--slate:#3a4262;--muted:#565e7a;
  --blue:#3b82f6;--indigo:#6366f1;--violet:#8b5cf6;--pink:#ec4899;
  --coral:#ff7a8a;--mint:#10e0a0;--teal:#06b6d4;--sun:#ffd66b;
  --shadow-sm:0 2px 8px rgba(40,50,100,.06),0 1px 3px rgba(40,50,100,.04);
  --shadow-md:0 12px 30px rgba(40,50,100,.10),0 4px 12px rgba(40,50,100,.05);
  --shadow-lg:0 30px 80px rgba(80,90,180,.18),0 10px 30px rgba(60,70,150,.10);
  --ease-out:cubic-bezier(.22,1,.36,1);
  --pad-section:clamp(4.5rem,9vw,8rem);
  --pad-x:clamp(1.2rem,4vw,3rem);
  --maxw:1320px;
}
html{font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--ink);cursor:none;overflow-x:hidden;position:relative;line-height:1.5}
body.menu-open{overflow:hidden}

body::before{content:'';position:fixed;inset:0;z-index:-3;background:
  linear-gradient(135deg, #ffffff 0%, #f5f3ff 25%, #ede9fe 45%, #f0f9ff 65%, #faf5ff 80%, #ffffff 100%);
pointer-events:none;transform:translateZ(0)}

/* Soft colour blobs layered on top of the base gradient */
body::after{content:'';position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 10% 0%,   rgba(139,92,246,.10) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 10%,  rgba(59,130,246,.09) 0%, transparent 55%),
    radial-gradient(ellipse 70% 60% at 80% 55%,  rgba(236,72,153,.07) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 15% 80%,  rgba(16,224,160,.07) 0%, transparent 55%),
    radial-gradient(ellipse 50% 40% at 50% 100%, rgba(99,102,241,.08) 0%, transparent 60%);
  transform:translateZ(0)}

/* ==== PREMIUM JOULE MEGA-ORB ==== */
.joule-stage{position:fixed;top:0;left:0;right:0;bottom:0;z-index:0;pointer-events:none;perspective:1400px;perspective-origin:50% 50%;contain:layout paint;--orb-hue:0deg;--orb-glow:0;--orb-blur:0px;--orb-stretchY:1}
.joule-mega{position:absolute;left:50%;top:50%;width:min(85vw,880px);aspect-ratio:1;transform:translate(-50%,-50%);will-change:transform,filter;filter:hue-rotate(var(--orb-hue))}
.joule-halo{display:none}
.joule-mid{display:none}
.joule-core{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transform-style:preserve-3d;contain:layout style;isolation:isolate;transform:scaleY(var(--orb-stretchY));filter:drop-shadow(0 4px 8px rgba(76,29,149,.18)) drop-shadow(0 18px 28px rgba(76,29,149,.20)) drop-shadow(0 40px 60px rgba(124,58,237,.18)) blur(var(--orb-blur));will-change:transform,filter}
.joule-plasma{position:absolute;inset:0;transform:translateZ(0);will-change:transform;isolation:isolate;background-color:#7c3aed;background-image:radial-gradient(circle at 35% 30%,rgba(196,181,253,.85) 0%,transparent 55%),radial-gradient(circle at 65% 70%,rgba(147,197,253,.6) 0%,transparent 60%),linear-gradient(135deg,#8b5cf6 0%,#6366f1 50%,#7c3aed 100%);background-size:140% 140%,160% 160%,100% 100%;background-position:0% 0%,100% 100%,0% 0%;animation:plasmaFlow 28s ease-in-out infinite;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><path d='M30 50C30 35,45 25,60 25L140 25C155 25,170 35,170 50L170 78C170 88,168 96,162 104L110 172C105 180,95 180,90 172L38 104C32 96,30 88,30 78Z' fill='black'/></svg>") center/100% 100% no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><path d='M30 50C30 35,45 25,60 25L140 25C155 25,170 35,170 50L170 78C170 88,168 96,162 104L110 172C105 180,95 180,90 172L38 104C32 96,30 88,30 78Z' fill='black'/></svg>") center/100% 100% no-repeat}
.joule-shape{position:absolute;inset:0;width:100%;height:100%;color:transparent;pointer-events:none;z-index:2;transform:translateZ(0)}
.joule-shape svg{width:100%;height:100%}
.joule-spec{position:absolute;inset:0;transform:translateZ(0);will-change:transform;background:radial-gradient(ellipse 25% 20% at 28% 20%,rgba(255,255,255,.95) 0%,rgba(255,255,255,.4) 30%,transparent 60%),radial-gradient(ellipse 50% 35% at 75% 80%,rgba(40,12,80,.55) 0%,rgba(76,29,149,.30) 35%,transparent 65%),linear-gradient(160deg,transparent 40%,rgba(40,12,80,.18) 100%);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><path d='M30 50C30 35,45 25,60 25L140 25C155 25,170 35,170 50L170 78C170 88,168 96,162 104L110 172C105 180,95 180,90 172L38 104C32 96,30 88,30 78Z' fill='black'/></svg>") center/100% 100% no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><path d='M30 50C30 35,45 25,60 25L140 25C155 25,170 35,170 50L170 78C170 88,168 96,162 104L110 172C105 180,95 180,90 172L38 104C32 96,30 88,30 78Z' fill='black'/></svg>") center/100% 100% no-repeat;mix-blend-mode:screen;pointer-events:none;animation:specShift 16s ease-in-out infinite;z-index:3}
.joule-ghost{position:absolute;inset:0;width:100%;height:100%;color:rgba(139,92,246,.55);pointer-events:none;filter:blur(8px);will-change:transform,opacity}
.joule-ghost svg{width:100%;height:100%}
.joule-ghost.g1{transform:translateY(-30px) scale(.96);opacity:calc(var(--orb-glow) * 0.55)}
.joule-ghost.g2{transform:translateY(-60px) scale(.92);opacity:calc(var(--orb-glow) * 0.32)}

@media (max-width:860px){
  .joule-mega{width:min(85vw,520px);left:50%;top:50%}
  .joule-halo{display:none}
  .joule-mid{display:none}
  .joule-spec{display:none}
  .joule-ghost{display:none}
}
/* Second orb — mobile only */
.joule-mega2{display:none}
@media (max-width:860px){
  .joule-mega2{
    display:block;
    width:min(55vw,260px);
    pointer-events:none;
  }
  .joule-mega2 .joule-plasma{
    background-color:#4f46e5;
    background-image:
      radial-gradient(circle at 60% 25%,rgba(165,180,252,.9) 0%,transparent 55%),
      radial-gradient(circle at 30% 75%,rgba(96,165,250,.65) 0%,transparent 60%),
      linear-gradient(135deg,#6366f1 0%,#3b82f6 50%,#4f46e5 100%);
    animation-delay:-14s;
  }
}
@media (max-width:640px){
  .joule-mega{opacity:0.12;filter:hue-rotate(var(--orb-hue)) saturate(0.3) blur(8px)}
  .joule-core{filter:drop-shadow(0 4px 8px rgba(76,29,149,.06)) blur(var(--orb-blur))}
}
@media (max-width:480px){
  .joule-mega{width:min(85vw,420px);left:50%;top:50%;opacity:0.09;filter:hue-rotate(var(--orb-hue)) saturate(0.2) blur(12px)}
  .joule-core{filter:drop-shadow(0 4px 8px rgba(76,29,149,.04)) blur(var(--orb-blur))}
}

/* ==== Animations ==== */
@keyframes sheenSweep{from{transform:translateX(-100%) rotate(20deg)}to{transform:translateX(250%) rotate(20deg)}}
@keyframes haloBreath{0%,100%{transform:scale(1) rotate(0deg);filter:blur(60px)}50%{transform:scale(1.08) rotate(8deg);filter:blur(75px)}}
@keyframes midSpin{to{transform:rotate(360deg)}}
@keyframes midBreath{0%,100%{filter:blur(34px) brightness(1)}50%{filter:blur(42px) brightness(1.15)}}
@keyframes plasmaFlow{0%{background-position:0% 0%,100% 100%,0% 0%}50%{background-position:30% 30%,70% 70%,0% 0%}100%{background-position:0% 0%,100% 100%,0% 0%}}
@keyframes specShift{0%,100%{transform:translate(0,0) rotate(0deg);opacity:.85}50%{transform:translate(8%,4%) rotate(6deg);opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
@keyframes slideUp{to{transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes spinReverse{to{transform:rotate(-360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes floatPortrait{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes scrollDot{0%,100%{opacity:0;transform:translate(-50%,0)}50%{opacity:1;transform:translate(-50%,8px)}}
@keyframes scrollMq{0%{transform:translate3d(0,0,0)}100%{transform:translate3d(-50%,0,0)}}
@keyframes orbit1{0%{transform:rotate(0deg) translateX(68%) rotate(0deg)}100%{transform:rotate(360deg) translateX(68%) rotate(-360deg)}}
@keyframes orbit2{0%{transform:rotate(90deg) translateX(72%) rotate(-90deg)}100%{transform:rotate(450deg) translateX(72%) rotate(-450deg)}}
@keyframes orbit3{0%{transform:rotate(180deg) translateX(66%) rotate(-180deg)}100%{transform:rotate(540deg) translateX(66%) rotate(-540deg)}}
@keyframes orbit4{0%{transform:rotate(270deg) translateX(74%) rotate(-270deg)}100%{transform:rotate(630deg) translateX(74%) rotate(-630deg)}}
@keyframes auroraBreath{0%,100%{transform:scale(1) rotate(0deg);opacity:.55}50%{transform:scale(1.12) rotate(15deg);opacity:.85}}

#gl{display:none}

#cursor{position:fixed;z-index:9999;pointer-events:none;top:0;left:0}
#c-dot{position:absolute;width:7px;height:7px;background:var(--violet);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 14px rgba(139,92,246,.7)}
#c-ring{position:absolute;width:36px;height:36px;border:1.5px solid rgba(99,102,241,.55);border-radius:50%;transform:translate(-50%,-50%);transition:width .35s var(--ease-out),height .35s var(--ease-out),border-color .35s,background .35s,opacity .25s}
body.hov #c-ring{width:64px;height:64px;border-color:var(--violet);background:rgba(139,92,246,.10)}
body.click #c-ring{width:28px;height:28px}

#progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:200;pointer-events:none}
#progress>div{height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--violet),var(--mint),var(--coral));background-size:200% 100%;box-shadow:0 2px 12px rgba(99,102,241,.4);will-change:width}

#nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.4rem var(--pad-x);display:flex;align-items:center;justify-content:space-between;transition:padding .4s var(--ease-out),background .4s,box-shadow .4s,border-color .4s}
#nav.small{padding:.7rem var(--pad-x);background:var(--glass-strong);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--glass-bd);box-shadow:var(--shadow-sm)}
.n-logo{font-family:'Instrument Serif',serif;font-size:1.55rem;background:linear-gradient(135deg,var(--blue),var(--violet) 60%,var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;font-style:italic}
.n-links{display:flex;gap:2.2rem;align-items:center}
.n-links a{font-size:.78rem;letter-spacing:.05em;color:var(--slate);text-decoration:none;transition:color .25s;font-weight:500;position:relative}
.n-links a::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:1px;background:linear-gradient(90deg,var(--blue),var(--violet));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease-out)}
.n-links a:hover{color:var(--violet)}
.n-links a:hover::after{transform:scaleX(1)}
.n-hire-wrap{display:inline-block}
.n-hire{font-size:.78rem;color:#fff;background:linear-gradient(135deg,var(--blue),var(--violet) 70%,var(--pink));padding:.6rem 1.4rem;border-radius:999px;text-decoration:none;font-weight:600;transition:box-shadow .3s var(--ease-out),filter .3s;box-shadow:0 8px 22px rgba(99,102,241,.32);display:inline-flex;align-items:center;gap:.5rem;will-change:transform}
.n-hire:hover{filter:brightness(1.06);box-shadow:0 14px 34px rgba(99,102,241,.5)}
.n-hire .dot{width:6px;height:6px;border-radius:50%;background:var(--mint);box-shadow:0 0 10px var(--mint);animation:pulse 2s infinite}
.n-burger{display:none;width:42px;height:42px;border-radius:10px;background:var(--glass);border:1px solid var(--glass-bd);align-items:center;justify-content:center;cursor:none;backdrop-filter:blur(10px);touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.n-burger i{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;position:relative;transition:transform .35s var(--ease-out),background .25s}
.n-burger i::before,.n-burger i::after{content:'';position:absolute;left:0;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .35s var(--ease-out)}
.n-burger i::before{top:-6px}
.n-burger i::after{top:6px}
body.menu-open .n-burger i{background:transparent}
body.menu-open .n-burger i::before{transform:translateY(6px) rotate(45deg)}
body.menu-open .n-burger i::after{transform:translateY(-6px) rotate(-45deg)}
.n-mobile{position:fixed;top:0;right:0;bottom:0;width:min(86vw,360px);z-index:99;background:rgba(255,255,255,.96);backdrop-filter:blur(24px) saturate(180%);border-left:1px solid var(--glass-bd);box-shadow:-20px 0 60px rgba(40,50,100,.18);padding:6rem 2rem 2rem;display:flex;flex-direction:column;gap:.4rem;transform:translateX(100%);transition:transform .5s var(--ease-out);pointer-events:none}
body.menu-open .n-mobile{transform:translateX(0);pointer-events:auto}
.n-mobile a{font-family:'Instrument Serif',serif;font-size:1.55rem;color:var(--ink);text-decoration:none;padding:.8rem 0;border-bottom:1px solid rgba(140,150,200,.12);transition:color .25s,padding .35s var(--ease-out);touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.n-mobile a:hover{color:var(--violet);padding-left:.5rem}

section{position:relative;z-index:2;width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}/* ==== Hero ==== */
#s-hero{min-height:100vh;display:flex;align-items:center;padding:7rem var(--pad-x) 4rem;position:relative;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:5rem;align-items:center;max-width:var(--maxw);margin:0 auto;width:100%;position:relative;z-index:3}
.hero-pill{display:inline-flex;align-items:center;gap:.6rem;padding:.45rem 1rem;border-radius:999px;background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--glass-bd);font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--ink-2);letter-spacing:.04em;box-shadow:var(--shadow-sm);margin-bottom:1.6rem}
.hero-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--mint);box-shadow:0 0 12px var(--mint);animation:pulse 2s infinite}
.hero-pill b{color:var(--violet);font-weight:600}
.hero-h1{font-family:'Instrument Serif',serif;font-size:clamp(2.4rem,5.8vw,5.2rem);line-height:1.06;letter-spacing:-.015em;color:var(--ink);font-weight:400;margin-bottom:1.6rem}
.hero-h1 .line{display:block;overflow:hidden;padding-bottom:.08em}
.hero-h1 .line>span{display:inline-block;transform:translateY(110%);animation:slideUp 1s var(--ease-out) forwards}
.hero-h1 .line.d1>span{animation-delay:.1s}
.hero-h1 .line.d2>span{animation-delay:.28s}
.hero-h1 .line.d3>span{animation-delay:.46s}
.hero-h1 em{font-style:italic;background:linear-gradient(120deg,var(--blue) 0%,var(--violet) 55%,var(--pink) 100%);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 6s linear infinite;padding-right:.04em}
.hero-sub{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;font-size:1rem;color:var(--slate);margin-bottom:2.2rem;opacity:0;animation:fadeUp .8s .85s forwards}
.hero-role{font-family:'JetBrains Mono',monospace;font-size:.92rem;color:var(--ink);font-weight:500;padding:.45rem .95rem;border-radius:8px;background:rgba(255,255,255,.78);backdrop-filter:blur(8px);border:1px solid var(--glass-bd);box-shadow:var(--shadow-sm);min-width:0;max-width:100%}
.hero-role::before{content:'❯ ';color:var(--violet);font-weight:700}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;opacity:0;animation:fadeUp .8s 1s forwards}

.btn-wrap{display:inline-block}
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.95rem 1.8rem;border-radius:999px;font-weight:600;font-size:.88rem;text-decoration:none;transition:box-shadow .35s var(--ease-out),filter .3s;cursor:none;border:none;letter-spacing:.01em;will-change:transform;touch-action:manipulation;-webkit-tap-highlight-color:transparent}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--violet) 60%,var(--pink));color:#fff;box-shadow:0 12px 30px rgba(99,102,241,.32)}
.btn-primary:hover{filter:brightness(1.06);box-shadow:0 18px 44px rgba(99,102,241,.5)}
.btn-ghost{background:var(--glass);backdrop-filter:blur(10px);color:var(--ink);border:1px solid var(--glass-bd);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{background:#fff;box-shadow:var(--shadow-md)}
.btn .arrow{display:inline-block;transition:transform .3s var(--ease-out)}
.btn:hover .arrow{transform:translateX(3px)}

.hero-stats{display:flex;gap:2.5rem;margin-top:3rem;opacity:0;animation:fadeUp .8s 1.15s forwards}
.stat-n{font-family:'Instrument Serif',serif;font-size:2.4rem;line-height:1;background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:400}
.stat-l{font-size:.7rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-top:.4rem;font-weight:500}

.scroll-hint{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;opacity:0;animation:fadeUp 1s 1.6s forwards;z-index:5;pointer-events:none}
.scroll-hint .mouse{width:22px;height:34px;border:1.5px solid rgba(99,102,241,.45);border-radius:12px;position:relative}
.scroll-hint .mouse::after{content:'';position:absolute;left:50%;top:7px;width:2px;height:6px;background:var(--violet);border-radius:2px;transform:translateX(-50%);animation:scrollDot 1.8s ease-in-out infinite}

/* ==== Premium Portrait ==== */
.portrait-wrap{position:relative;display:flex;justify-content:center;align-items:center;perspective:900px;opacity:0;animation:fadeUp 1s .55s forwards}
.portrait{position:relative;width:min(420px,90%);aspect-ratio:1;transform-style:preserve-3d;will-change:transform;animation:floatPortrait 6s ease-in-out infinite;cursor:none}

.portrait-aurora{display:none}
.portrait-glow{display:none}

/* Outer rotating conic ring (gradient border) */
.portrait-ring{position:absolute;inset:-14px;border-radius:50%;background:conic-gradient(from 0deg,var(--blue),var(--violet),var(--pink),var(--coral),var(--mint),var(--teal),var(--blue));animation:spin 14s linear infinite;filter:blur(2px);opacity:.9}
.portrait-ring::after{content:'';position:absolute;inset:8px;background:var(--bg);border-radius:50%}

/* Inner counter-rotating subtle ring (depth) */
.portrait-ring2{position:absolute;inset:-3px;border-radius:50%;
  background:conic-gradient(from 180deg, transparent 0%, rgba(139,92,246,.5) 25%, transparent 50%, rgba(59,130,246,.5) 75%, transparent 100%);
  animation:spinReverse 22s linear infinite;
  filter:blur(1px);
  z-index:0;
}
.portrait-ring2::after{content:'';position:absolute;inset:3px;background:var(--bg);border-radius:50%}

/* Photo frame */
.portrait-img{position:relative;width:100%;height:100%;border-radius:50%;overflow:hidden;box-shadow:inset 0 0 0 2px rgba(255,255,255,.4);border:3px solid #fff;z-index:1;backface-visibility:hidden;-webkit-backface-visibility:hidden}
.portrait-img img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.06) contrast(1.02)}

/* Edge sheen — diagonal light sweep across the portrait */
.portrait-sheen{position:absolute;inset:0;border-radius:50%;pointer-events:none;overflow:hidden;opacity:0;transition:opacity .4s ease}
.portrait-sheen::before{content:'';position:absolute;top:-20%;left:-30%;width:40%;height:140%;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.45) 50%,transparent 70%);transform:translateX(0) rotate(20deg);filter:blur(4px);will-change:transform}
.portrait:hover .portrait-sheen{opacity:1}
.portrait:hover .portrait-sheen::before{animation:sheenSweep 1.2s cubic-bezier(.4,0,.2,1) forwards}

/* Orbiting accent particles — premium floating dots */
.orbit-dot{position:absolute;left:50%;top:50%;width:10px;height:10px;border-radius:50%;margin:-5px 0 0 -5px;pointer-events:none;z-index:-1;
  box-shadow:0 0 14px currentColor, 0 0 28px currentColor;
  will-change:transform;
}
.orbit-dot.d1{color:var(--violet);background:var(--violet);animation:orbit1 11s linear infinite}
.orbit-dot.d2{color:var(--blue);background:var(--blue);animation:orbit2 13s linear infinite}
.orbit-dot.d3{color:var(--pink);background:var(--pink);animation:orbit3 15s linear infinite;width:7px;height:7px;margin:-3.5px 0 0 -3.5px}
.orbit-dot.d4{color:var(--mint);background:var(--mint);animation:orbit4 17s linear infinite;width:8px;height:8px;margin:-4px 0 0 -4px}

/* ==== Marquee ==== */
#s-marquee{padding:1.6rem 0;border-top:1px solid var(--glass-bd);border-bottom:1px solid var(--glass-bd);overflow:hidden;background:linear-gradient(90deg,rgba(255,255,255,.5),rgba(255,255,255,.7),rgba(255,255,255,.5));backdrop-filter:blur(10px)}
.marquee-inner{display:flex;gap:0;white-space:nowrap;animation:scrollMq 40s linear infinite;will-change:transform}
.m-item{display:inline-flex;align-items:center;gap:1.4rem;padding:0 2rem;font-family:'Instrument Serif',serif;font-size:1.5rem;font-style:italic;color:var(--ink-2)}
.m-item .star{color:var(--violet);font-size:.7rem;font-style:normal}
.m-item:nth-child(3n) .star{color:var(--mint)}
.m-item:nth-child(3n+1) .star{color:var(--blue)}
.m-item:nth-child(3n+2) .star{color:var(--coral)}

/* ==== Common ==== */
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--violet);letter-spacing:.18em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1.4rem;font-weight:600}
.eyebrow::before{content:'';width:24px;height:1px;background:linear-gradient(90deg,var(--blue),var(--violet))}
.h2{font-family:'Instrument Serif',serif;font-size:clamp(2.2rem,4.8vw,4.4rem);line-height:1.06;letter-spacing:-.01em;font-weight:400;color:var(--ink)}
.h2 em{font-style:italic;background:linear-gradient(120deg,var(--blue),var(--violet) 50%,var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ==== About ==== */
#s-about{padding:var(--pad-section) var(--pad-x)}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:5rem;align-items:start;max-width:var(--maxw);margin:0 auto}
.about-body{margin-top:2rem}
.about-body p{color:var(--slate);line-height:1.75;font-size:1.02rem;margin-bottom:1rem;font-weight:400}
.about-body strong{color:var(--ink);font-weight:600}
.about-body .grad{background:linear-gradient(120deg,var(--blue),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}
.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:1rem}

/* Spotlight cards */
.spot{position:relative;overflow:hidden}
.spot::before{content:'';position:absolute;inset:0;border-radius:inherit;background:radial-gradient(280px circle at var(--mx,50%) var(--my,50%),rgba(139,92,246,.18),transparent 60%);opacity:0;transition:opacity .35s var(--ease-out);pointer-events:none;z-index:1}
.spot:hover::before{opacity:1}
.spot>*{position:relative;z-index:2}

.info-card{background:var(--surface);border:1px solid var(--glass-bd);border-radius:16px;padding:1.4rem;box-shadow:var(--shadow-sm);transition:transform .45s var(--ease-out),box-shadow .45s,border-color .45s}
.info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:rgba(139,92,246,.35)}
.info-label{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-bottom:.5rem;font-weight:600}
.info-val{font-size:.95rem;color:var(--ink);font-weight:600;word-break:break-word}
.info-card.full{grid-column:span 2}

.cert-row{display:flex;align-items:center;gap:1rem;padding:1.2rem;border-radius:14px;background:var(--surface);border:1px solid var(--glass-bd);box-shadow:var(--shadow-sm);transition:transform .45s var(--ease-out),box-shadow .45s,border-color .45s}
.cert-row:hover{transform:translateX(6px);box-shadow:var(--shadow-md);border-color:rgba(59,130,246,.3)}
.cert-icon{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--violet));display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;box-shadow:0 6px 16px rgba(99,102,241,.3)}
.cert-name strong{display:block;color:var(--ink);font-size:.95rem;margin-bottom:.15rem;font-weight:600}
.cert-name span{font-size:.78rem;color:var(--muted)}
.about-cert-list{display:flex;flex-direction:column;gap:.7rem;margin-top:1rem}

/* ==== Focus ==== */
#s-focus{padding:var(--pad-section) 0;position:relative}
.focus-head{max-width:900px;margin:0 auto 4rem;padding:0 var(--pad-x);text-align:center}
.focus-head .h2{margin-top:1rem}
.focus-head p{color:var(--slate);font-size:1.05rem;line-height:1.7;margin-top:1.5rem;max-width:680px;margin-left:auto;margin-right:auto}
.focus-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.focus-card{position:relative;background:var(--surface);border:1px solid var(--glass-bd);border-radius:24px;padding:2.2rem;box-shadow:var(--shadow-sm);transition:transform .55s var(--ease-out),box-shadow .55s,border-color .55s;overflow:hidden;cursor:none}
.focus-card::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--c1,rgba(59,130,246,.08)),var(--c2,rgba(139,92,246,.08)) 50%,transparent);opacity:0;transition:opacity .55s;pointer-events:none}
.focus-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:rgba(139,92,246,.4)}
.focus-card:hover::after{opacity:.6}
.focus-card>*{position:relative;z-index:2}
.focus-icon{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,var(--c1,#2563eb),var(--c2,#6d28d9));display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:1.4rem;box-shadow:0 10px 24px rgba(99,102,241,.32);transition:transform .55s var(--ease-out)}
.focus-card:hover .focus-icon{transform:rotate(-6deg) scale(1.08)}
.focus-num{position:absolute;top:1.6rem;right:1.8rem;font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--muted);letter-spacing:.12em;font-weight:600;z-index:3}
.focus-title{font-family:'Instrument Serif',serif;font-size:1.6rem;color:var(--ink);font-weight:400;margin-bottom:.6rem;line-height:1.2}
.focus-title em{font-style:italic;color:var(--violet)}
.focus-desc{color:var(--slate);font-size:.92rem;line-height:1.65;margin-bottom:1.2rem}
.focus-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.focus-tag{font-family:'JetBrains Mono',monospace;font-size:.65rem;padding:.3rem .7rem;border-radius:6px;background:#ede9fe;color:#4c1d95;font-weight:500;letter-spacing:.02em}
.focus-tag::before{content:'> ';opacity:.6}

/* ==== Skills — Centred Tabbed Switcher + Marquee ==== */
#s-skills{padding:var(--pad-section) var(--pad-x);text-align:center}
.skills-head{display:flex;flex-direction:column;align-items:center;gap:.6rem;max-width:var(--maxw);margin:0 auto 3rem;text-align:center}
.skills-head .eyebrow{justify-content:center}
/* Per-category palette: each tab[data-sk] carries --sk-a / --sk-b for the gradient pair */
.sk-tabs{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;max-width:var(--maxw);margin:0 auto 2.8rem;list-style:none}
.sk-tab{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.06em;font-weight:600;padding:.6rem 1.2rem;border-radius:999px;border:1px solid var(--glass-bd);background:var(--glass);color:var(--slate);cursor:none;transition:all .3s var(--ease-out);display:inline-flex;align-items:center;gap:.5rem;position:relative;overflow:hidden}
.sk-tab::before{content:'';position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,var(--sk-a,var(--blue)),var(--sk-b,var(--violet)));opacity:0;transition:opacity .35s var(--ease-out)}
.sk-tab::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--sk-a,var(--blue)),var(--sk-b,var(--violet)));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease-out)}
.sk-tab:hover{color:var(--ink);border-color:rgba(99,102,241,.3);background:#fff}
.sk-tab:hover::before{opacity:.06}
.sk-tab.active{color:#fff;border-color:transparent;box-shadow:0 8px 22px color-mix(in srgb,var(--sk-a,#6366f1) 40%,transparent)}
.sk-tab.active::before{opacity:1}
.sk-tab.active::after{transform:scaleX(1)}
.sk-tab-num{opacity:.7;font-size:.62rem;transition:opacity .3s}
.sk-tab.active .sk-tab-num{opacity:.9}
/* Marquee track — two rows, opposite directions */
.sk-marquee-wrap{overflow:hidden;position:relative;max-width:100%;margin:0 auto}
/* Fade masks left + right */
.sk-marquee-wrap::before,.sk-marquee-wrap::after{content:'';position:absolute;top:0;bottom:0;width:clamp(60px,8vw,120px);z-index:2;pointer-events:none}
.sk-marquee-wrap::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.sk-marquee-wrap::after{right:0;background:linear-gradient(-90deg,var(--bg),transparent)}
.sk-mrow{display:flex;gap:.7rem;padding:.45rem 0;white-space:nowrap}
/* Row 1 scrolls left, Row 2 scrolls right */
.sk-mrow-inner{display:inline-flex;gap:.7rem;animation:scrollMq 22s linear infinite}
.sk-mrow.rev .sk-mrow-inner{animation-direction:reverse;animation-duration:26s}
/* Pill styling */
@keyframes pillIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
.sk-pill{display:inline-flex;font-size:.78rem;padding:.45rem 1rem;border-radius:999px;background:linear-gradient(135deg,color-mix(in srgb,var(--sk-a,#3b82f6) 10%,transparent),color-mix(in srgb,var(--sk-b,#8b5cf6) 10%,transparent));border:1px solid color-mix(in srgb,var(--sk-a,#6366f1) 22%,transparent);color:var(--ink-2);font-weight:500;white-space:nowrap;cursor:default;transition:background .25s,box-shadow .25s,transform .25s var(--ease-out)}
.sk-pill:hover{background:linear-gradient(135deg,color-mix(in srgb,var(--sk-a,#3b82f6) 22%,transparent),color-mix(in srgb,var(--sk-b,#8b5cf6) 22%,transparent));box-shadow:0 0 14px color-mix(in srgb,var(--sk-a,#6366f1) 28%,transparent);transform:scale(1.04)}

/* ==== Services — Accordion List ==== */
@keyframes svcShimmer{0%{transform:translateX(-100%) skewX(-15deg)}100%{transform:translateX(250%) skewX(-15deg)}}
@keyframes svcLineGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
#s-services{padding:var(--pad-section) 0;position:relative}
.svc-list{list-style:none;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x);border-top:1px solid var(--glass-bd)}
.svc-row{border-bottom:1px solid var(--glass-bd);cursor:none;transition:background .4s var(--ease-out),border-left-color .3s,box-shadow .4s;border-left:3px solid transparent;padding-left:1rem;position:relative;overflow:hidden}
.svc-row::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--c1,var(--blue)),var(--c2,var(--violet)));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-out)}
.svc-row.open{border-left-color:var(--violet);background:rgba(139,92,246,.028);box-shadow:inset 0 0 60px rgba(139,92,246,.03)}
.svc-row.open::after{transform:scaleX(1)}
.svc-row-top{display:flex;align-items:center;gap:1.8rem;padding:1.4rem 0;user-select:none;position:relative;overflow:hidden}
/* Shimmer flash on open */
.svc-row.open .svc-row-top::before{content:'';position:absolute;top:0;left:0;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);animation:svcShimmer .6s var(--ease-out) forwards;pointer-events:none;z-index:1}
.svc-num{font-family:'Instrument Serif',serif;font-size:3.2rem;font-style:italic;line-height:1;flex-shrink:0;width:64px;background:linear-gradient(135deg,var(--c1,var(--blue)),var(--c2,var(--violet)));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:transform .4s var(--ease-out),filter .4s}
.svc-row.open .svc-num{transform:scale(1.12);filter:drop-shadow(0 2px 12px color-mix(in srgb,var(--c1,var(--blue)) 40%,transparent))}
.svc-header{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}
.svc-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--c1,#3b82f6),var(--c2,#8b5cf6));display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:transform .4s var(--ease-out),box-shadow .4s;box-shadow:0 6px 16px rgba(99,102,241,.22)}
.svc-row.open .svc-icon{transform:rotate(-8deg) scale(1.1);box-shadow:0 10px 28px rgba(99,102,241,.36)}
.svc-title{font-family:'Instrument Serif',serif;font-size:1.55rem;color:var(--ink);font-weight:400;line-height:1.2;transition:color .3s}
.svc-title em{font-style:italic;color:var(--violet)}
.svc-row.open .svc-title{color:var(--ink-2)}
.svc-toggle{font-family:'JetBrains Mono',monospace;font-size:1.4rem;color:var(--muted);margin-left:auto;flex-shrink:0;line-height:1;transition:transform .4s var(--ease-out),color .3s,text-shadow .4s;width:28px;text-align:center}
.svc-row.open .svc-toggle{transform:rotate(45deg);color:var(--violet);text-shadow:0 0 16px rgba(139,92,246,.6)}
.svc-body{max-height:0;overflow:hidden;transition:max-height .5s var(--ease-out),padding .5s var(--ease-out)}
.svc-row.open .svc-body{max-height:260px;padding-bottom:1.6rem}
.svc-desc{color:var(--slate);font-size:.95rem;line-height:1.7;margin-bottom:.9rem;padding-left:calc(64px + 1.8rem + 40px + 1rem)}
.svc-outcomes{list-style:none;padding-left:calc(64px + 1.8rem + 40px + 1rem);display:flex;flex-direction:column;gap:.45rem}
.svc-outcomes li{font-size:.875rem;color:var(--muted);line-height:1.55;display:flex;align-items:baseline;gap:.6rem}
.svc-outcomes li::before{content:'→';font-size:.75rem;color:var(--c1,var(--blue));flex-shrink:0;font-weight:600}

/* ==== Why Choose Me — Editorial Columns ==== */
@keyframes barGrow{from{width:0}to{width:100%}}
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.8);opacity:.6}}
@keyframes iconEntry{from{transform:scale(.7) rotate(-12deg);opacity:0}to{transform:scale(1) rotate(0deg);opacity:1}}
#s-why{padding:var(--pad-section) var(--pad-x)}
.why-head{max-width:900px;margin:0 auto 4rem;padding:0;text-align:center}
.why-head .h2{margin-top:1rem}
.why-head p{color:var(--slate);font-size:1.05rem;line-height:1.7;margin-top:1.5rem;max-width:680px;margin-left:auto;margin-right:auto}
.why-list{display:grid;grid-template-columns:1fr 1fr;gap:0 5rem;max-width:var(--maxw);margin:0 auto}
.why-item{padding:2.4rem 0;border-bottom:1px solid var(--glass-bd);display:flex;flex-direction:column;gap:.8rem;transition:transform .4s var(--ease-out)}
.why-item:nth-child(5),.why-item:nth-child(6){border-bottom:none}
.why-item:hover{transform:translateY(-3px)}
.why-icon{width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg,var(--c1,#2563eb),var(--c2,#6d28d9));display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 20px rgba(99,102,241,.22);transition:transform .45s var(--ease-out),box-shadow .45s;opacity:0}
.why-item.on .why-icon{animation:iconEntry .55s var(--ease-out) forwards}
.why-item:hover .why-icon{transform:rotate(-6deg) scale(1.08);box-shadow:0 12px 28px color-mix(in srgb,var(--c1,#3b82f6) 40%,transparent)}
.why-title{font-family:'Instrument Serif',serif;font-size:1.55rem;color:var(--ink);font-weight:400;line-height:1.2}
.why-title em{font-style:italic;color:var(--violet)}
/* Bar with leading glow dot */
.why-bar-wrap{display:grid;grid-template-columns:8px 1fr;align-items:center;gap:.55rem;height:10px}
.why-bar-dot{width:8px;height:8px;border-radius:50%;background:var(--c1,var(--blue));opacity:0;transition:opacity .2s}
.why-item.on .why-bar-dot{opacity:1;animation:dotPulse 1.6s var(--ease-out) 0.9s infinite}
.why-bar{height:3px;width:0;background:linear-gradient(90deg,var(--c1,var(--blue)),var(--c2,var(--violet)));border-radius:2px;box-shadow:0 0 8px color-mix(in srgb,var(--c1,var(--blue)) 50%,transparent);animation:barGrow .9s var(--ease-out) paused forwards}
.why-item.on .why-bar{animation-play-state:running}
.why-body{color:var(--slate);font-size:.95rem;line-height:1.7}


/* ==== Experience ==== */
#s-exp{padding:var(--pad-section) var(--pad-x);position:relative}
.exp-head{display:flex;justify-content:space-between;align-items:flex-end;margin:0 auto 4rem;flex-wrap:wrap;gap:1.5rem;max-width:var(--maxw)}
.exp-list{position:relative;max-width:var(--maxw);margin:0 auto}
.exp-list::before{content:'';position:absolute;left:200px;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--blue),var(--violet) 40%,var(--pink) 80%,transparent);opacity:.3}
.job{display:grid;grid-template-columns:200px 1fr;gap:3rem;padding:2.5rem 0;position:relative;transition:padding .5s var(--ease-out)}
.job::after{content:'';position:absolute;left:194px;top:3rem;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--violet);box-shadow:0 0 0 4px rgba(139,92,246,.12);transition:all .35s var(--ease-out)}
.job.current::after{background:var(--mint);border-color:var(--mint);box-shadow:0 0 0 4px rgba(16,224,160,.2),0 0 16px rgba(16,224,160,.4);animation:pulse 2.5s infinite}
.job:hover::after{transform:scale(1.3)}
.job-meta .job-date{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--violet);letter-spacing:.05em;margin-bottom:.8rem;font-weight:600;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.job.current .job-date{color:var(--mint)}
.job.current .job-date .live{display:inline-flex;align-items:center;gap:.35rem;background:rgba(16,224,160,.12);padding:.18rem .55rem;border-radius:5px;font-size:.65rem;color:var(--mint);border:1px solid rgba(16,224,160,.3)}
.job.current .job-date .live::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--mint);box-shadow:0 0 8px var(--mint);animation:pulse 1.5s infinite}
.job-co{font-family:'Instrument Serif',serif;font-size:1.4rem;color:var(--ink);font-style:italic;margin-bottom:.3rem;font-weight:400}
.job-loc{font-size:.78rem;color:var(--muted);font-weight:500}
.job-role{font-family:'Instrument Serif',serif;font-size:1.7rem;color:var(--ink);font-weight:400;margin-bottom:1rem;line-height:1.2}
.job-role em{font-style:italic;background:linear-gradient(120deg,var(--blue),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.job-bullets{list-style:none;margin-bottom:1.4rem}
.job-bullets li{position:relative;padding:.3rem 0 .3rem 1.3rem;font-size:.92rem;color:var(--slate);line-height:1.7}
.job-bullets li::before{content:'';position:absolute;left:0;top:.85em;width:5px;height:5px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--violet));box-shadow:0 0 6px rgba(99,102,241,.4)}
.job-chips{display:flex;flex-wrap:wrap;gap:.45rem}
.chip{font-size:.7rem;padding:.35rem .8rem;border-radius:6px;background:#fff;border:1px solid var(--glass-bd);color:var(--ink-2);font-weight:500;font-family:'JetBrains Mono',monospace;transition:all .25s var(--ease-out)}
.chip:hover{border-color:var(--violet);color:var(--violet);box-shadow:0 4px 12px rgba(139,92,246,.18)}

/* ==== Education ==== */
#s-edu{padding:var(--pad-section) var(--pad-x)}
.edu-head{margin:0 auto 3rem;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;max-width:var(--maxw)}
.edu-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;max-width:var(--maxw);margin:0 auto}
.edu-card{background:var(--surface);border:1px solid var(--glass-bd);border-radius:20px;padding:2.2rem;box-shadow:var(--shadow-sm);transition:all .55s var(--ease-out);position:relative;overflow:hidden}
.edu-card::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--violet),var(--pink));transition:width .6s var(--ease-out)}
.edu-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(99,102,241,.3)}
.edu-card:hover::after{width:100%}
.edu-year{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--violet);letter-spacing:.1em;margin-bottom:1rem;font-weight:600}
.edu-deg{font-family:'Instrument Serif',serif;font-size:1.55rem;color:var(--ink);font-weight:400;margin-bottom:.7rem;line-height:1.2}
.edu-inst{font-size:.92rem;color:var(--slate);line-height:1.55;margin-bottom:1rem}
.edu-score{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--ink-2);font-weight:600;padding:.45rem .85rem;background:rgba(99,102,241,.08);border-radius:6px;display:inline-block}

/* ==== Contact ==== */
#s-contact{padding:var(--pad-section) var(--pad-x);text-align:center;min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}
.contact-h{font-family:'Instrument Serif',serif;font-size:clamp(3rem,8.5vw,7.5rem);line-height:1.04;letter-spacing:-.02em;color:var(--ink);font-weight:400;margin-bottom:2rem}
.contact-h em{font-style:italic;background:linear-gradient(120deg,var(--blue) 0%,var(--violet) 35%,var(--pink) 65%,var(--coral) 100%);background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 5s linear infinite}
.contact-sub{color:var(--slate);font-size:1.05rem;line-height:1.7;max-width:640px;margin:0 auto 2.5rem}
.contact-links{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:2.5rem}
.c-link{display:inline-flex;align-items:center;gap:.65rem;padding:.95rem 1.6rem;border-radius:999px;background:var(--glass);backdrop-filter:blur(10px);border:1px solid var(--glass-bd);color:var(--ink);font-size:.9rem;text-decoration:none;font-weight:500;transition:all .35s var(--ease-out);box-shadow:var(--shadow-sm)}
.c-link:hover{transform:translateY(-3px);background:#fff;border-color:rgba(139,92,246,.4);box-shadow:var(--shadow-md);color:var(--violet)}
.c-link svg{opacity:.6;transition:opacity .3s}
.c-link:hover svg{opacity:1}

/* ==== Footer ==== */
footer{position:relative;z-index:2;padding:2.5rem var(--pad-x);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;border-top:1px solid var(--glass-bd);background:rgba(255,255,255,.4);backdrop-filter:blur(10px)}
.f-brand{font-family:'Instrument Serif',serif;font-size:1rem;font-style:italic;color:var(--ink-2)}
.f-right{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--muted);letter-spacing:.05em}

/* ==== Reveal ==== */
.reveal{opacity:0;transform:translate3d(0,22px,0);will-change:opacity,transform;transition:opacity .85s cubic-bezier(.16,1,.3,1),transform .85s cubic-bezier(.16,1,.3,1)}
.reveal.d1{transition-delay:.07s}
.reveal.d2{transition-delay:.14s}
.reveal.d3{transition-delay:.21s}
.reveal.d4{transition-delay:.28s}
.reveal.on{opacity:1;transform:translate3d(0,0,0);will-change:auto}/* ==== Responsive ==== */
@media (max-width:1024px){
  .focus-grid{grid-template-columns:repeat(2,1fr)}
  .hero-grid{gap:3.5rem}
  .about-grid{gap:3rem}
}
@media (max-width:860px){
  body{cursor:auto}
  #cursor{display:none}
  .hero-grid{grid-template-columns:1fr;gap:3rem}
  .hero-content{text-align:center}
  .hero-pill{justify-content:center;flex-wrap:wrap}
  .hero-actions{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-sub{justify-content:center}
  .portrait-wrap{order:-1;margin-bottom:.5rem}
  .portrait{width:min(280px,72%)}
  .orbit-dot{display:none}
  .portrait-sheen{display:none}
  .portrait-aurora{display:none}
  .about-grid{grid-template-columns:1fr;gap:2.5rem}
  .about-left{text-align:center}
  .about-left .eyebrow{justify-content:center}
  .skills-head{margin-bottom:2rem}
  .exp-head{justify-content:center;text-align:center}
  .edu-head{justify-content:center;text-align:center}
  .focus-grid{grid-template-columns:1fr 1fr}
  .why-head{text-align:center}
  .why-list{grid-template-columns:1fr;gap:0}
  .why-item:nth-child(5),.why-item:nth-child(6){border-bottom:1px solid var(--glass-bd)}
  .why-item:last-child{border-bottom:none}
  .svc-num{font-size:2.4rem;width:48px}
  .edu-grid{grid-template-columns:1fr}
  .exp-list::before{left:0}
  .job{grid-template-columns:1fr;gap:.8rem;padding:1.6rem 0 1.6rem 1.4rem}
  .job::after{left:-7px;top:2rem}
  .scroll-hint{display:none}
  .n-links{display:none}
  .n-burger{display:inline-flex}
  .n-hire{display:none}
  .skills-head,.exp-head,.edu-head{margin-bottom:2rem}
  .hero-pill{flex-wrap:wrap}
}
@media (max-width:640px){
  .btn{cursor:pointer}
  .focus-card,.edu-card,.cert-row,.info-card,.c-link,.chip,.sk-tab,.why-item,.n-burger{cursor:pointer}
  .focus-grid{grid-template-columns:1fr}
  .sk-tabs{gap:.4rem}
  .sk-tab{font-size:.68rem;padding:.5rem .9rem}
  .svc-num{font-size:2rem;width:40px}
  .svc-desc{padding-left:0}
  .svc-outcomes{padding-left:0}
  .hero-stats{gap:1.5rem;flex-wrap:wrap}
  .stat-n{font-size:1.85rem}
  footer{padding:2rem var(--pad-x);flex-direction:column;text-align:center}
  .hero-h1{font-size:clamp(2.1rem,9vw,3.2rem)}
  .h2{font-size:clamp(1.9rem,7vw,2.6rem)}
  .focus-card{padding:1.6rem}
  .edu-card{padding:1.6rem}
  .m-item{font-size:1.15rem;padding:0 1.2rem}
  .marquee-inner{animation-duration:55s}
  .info-card{padding:1.1rem}
  .cert-row{padding:1rem}
  .focus-num{top:1.2rem;right:1.4rem}
  .about-cards{grid-template-columns:1fr}
  .info-card.full{grid-column:span 1}
  #s-contact{min-height:unset;padding:4rem var(--pad-x)}
  .contact-h{font-size:clamp(2.2rem,10vw,3.6rem)}
  .contact-links{flex-direction:column;align-items:stretch}
  .contact-links .c-link{justify-content:center}
  .job-meta{text-align:left}
  .job-chips{justify-content:flex-start}
  .focus-head{text-align:center}
  .focus-head .eyebrow{justify-content:center}

  /* ── Mobile readability: bump font sizes + weight ── */
  body{line-height:1.65;font-weight:450;--ink-2:#0e1220;--slate:#1a2035;--muted:#3a4055}
  .info-label{font-size:.75rem;letter-spacing:.08em;font-weight:700}
  .info-val{font-size:1rem;line-height:1.5;font-weight:600}
  .eyebrow{font-size:.75rem;font-weight:700}
  .stat-l{font-size:.73rem;font-weight:600}
  .stat-n{font-weight:500}
  .focus-tag{font-size:.73rem;font-weight:600}
  .chip{font-size:.78rem;padding:.38rem .9rem;font-weight:600}
  .sk-t{font-size:.8rem;padding:.38rem .88rem;font-weight:600}
  .focus-desc{font-size:1rem;line-height:1.7;font-weight:450}
  .focus-title{font-size:1.4rem}
  .job-bullets li{font-size:1rem;line-height:1.75;font-weight:450;color:var(--ink-2)}
  .job-role{font-size:1.45rem}
  .job-co{font-size:1.25rem;font-weight:600}
  .job-loc,.cert-name span{font-size:.83rem;font-weight:500}
  .cert-name strong{font-size:1rem;font-weight:700}
  .hero-role{font-size:.95rem;font-weight:600}
  .edu-deg{font-size:1.4rem}
  .edu-inst{font-size:1rem;font-weight:500;color:var(--ink-2)}
  .about-body p{font-size:1.02rem;line-height:1.8;font-weight:450}
  .about-body strong{font-weight:700}
  .contact-sub{font-size:1rem;line-height:1.75;font-weight:450}
  .c-link{font-size:.95rem;font-weight:600}
  .n-mobile a{font-size:1.65rem}
  .n-links a,.hero-sub{font-weight:500}
  .edu-score{font-weight:700}
  .job-date{font-weight:700 !important}
  .why-title{font-size:1.35rem}
  .why-body{font-size:1rem;line-height:1.7;font-weight:450}
}
@media (max-width:480px){
  .hero-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn-wrap,.hero-actions .btn{width:100%;justify-content:center}
  .hero-pill{font-size:.73rem;gap:.4rem}
  .portrait{width:min(240px,80%)}
  .hero-stats{justify-content:space-around}
  .job-date{font-size:.76rem !important}
  .edu-score{font-size:.82rem}
  .f-right{font-size:.73rem}
}

/* ==== Reduced motion ==== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.1s !important;scroll-behavior:auto !important}
  body::before{animation:none}
  .portrait-ring,.portrait-ring2{animation:none;opacity:.4}
  .portrait-aurora{display:none}
  .marquee-inner{animation:none}
  .joule-halo,.joule-mid,.joule-plasma,.joule-spec{animation:none}
  .orbit-dot{display:none}
  #gl{display:none}
}
/* Smooth touch scrolling + mobile shadow fix */
@media (max-width:860px){
  html,body{-webkit-overflow-scrolling:touch}
  .joule-core{filter:blur(var(--orb-blur)) !important}
  .btn,.n-burger,.focus-card,.edu-card,.cert-row,.info-card,.c-link,.chip,.sk-tab,.svc-row,.why-item{cursor:pointer}
}
/* Portrait full-3D spin: front + back face setup — backface merged into base rules above */
.portrait-back{
  position:absolute;
  inset:0;
  border-radius:50%;
  border:3px solid #fff;
  background:radial-gradient(circle at 30% 30%, #8b5cf6 0%, #6366f1 50%, #1e1b4b 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:'Instrument Serif',serif;
  font-style:italic;
  font-size:5rem;
  color:rgba(255,255,255,.85);
  letter-spacing:.05em;
  transform:rotateY(180deg);
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  box-shadow:inset 0 0 40px rgba(255,255,255,.15), inset 0 0 0 2px rgba(255,255,255,.3);
  z-index:1;
}
.portrait-back span{
  background:linear-gradient(135deg,#fff,#c4b5fd 50%,#fff);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  text-shadow:0 4px 20px rgba(0,0,0,.3);
}

/* ==== Accessibility ==== */
:focus-visible{outline:2px solid var(--violet);outline-offset:3px;border-radius:4px}

/* ==== Marquee pause on hover ==== */
.marquee-inner:hover{animation-play-state:paused}

/* ==== Nav active section ==== */
.n-links a.active{color:var(--violet)}
.n-links a.active::after{transform:scaleX(1)}

/* Default-hide mobile-portrait-only elements (visible only inside the MP media query below) */
.mp-portrait-hint{display:none}

/* ====================================================================
   ╔══════════════════════════════════════════════════════════════════╗
   ║   MOBILE PREMIUM LAYER  —  applies to BOTH orientations          ║
   ║   Every rule inside this media query.                            ║
   ║   PC (>=861px) is 100% untouched.                                ║
   ╚══════════════════════════════════════════════════════════════════╝
   ==================================================================== */
@media (max-width:860px){

  /* ── T0: foundations ─────────────────────────────────────────────── */
  html,body{overscroll-behavior-y:contain}
  body{-webkit-tap-highlight-color:transparent}

  /* ── T1.1: Joule orb — un-mute & make alive ──────────────────────── */
  .joule-mega{opacity:1 !important;filter:hue-rotate(var(--orb-hue)) saturate(1) blur(0) !important;will-change:transform,opacity,filter}
  .joule-core{filter:drop-shadow(0 6px 14px rgba(76,29,149,.18)) drop-shadow(0 18px 40px rgba(124,58,237,.22)) drop-shadow(0 40px 80px rgba(99,102,241,.18)) blur(var(--orb-blur)) !important}
  .joule-mega2{opacity:1 !important;filter:saturate(.95) !important}
  .joule-mega2 .joule-core{filter:drop-shadow(0 4px 10px rgba(30,64,175,.18)) drop-shadow(0 14px 30px rgba(59,130,246,.20)) blur(var(--orb-blur)) !important}

  /* ── T1.2: Portrait — keep clean. NO aurora, NO backdrop glow.
     Just the rings around the photo + subtle sheen on the photo. */
  .portrait{width:min(300px,76%);transform-style:preserve-3d}
  .portrait-aurora{display:none !important}
  .portrait-glow{display:none !important}
  .portrait-sheen{display:block;opacity:.85}
  .portrait-sheen::before{animation:mp-sheenSweep 5.5s ease-in-out infinite}
  @keyframes mp-sheenSweep{0%,15%{transform:translateX(-100%) rotate(20deg)}45%,100%{transform:translateX(250%) rotate(20deg)}}
  /* Hide orbit dots on mobile portrait too — clean photo */
  .orbit-dot{display:none !important}
  /* Drag-to-spin hint pill */
  .portrait-wrap{position:relative}
  .mp-portrait-hint{display:inline-flex;align-items:center;gap:.4rem;justify-content:center;margin:1rem auto 0;padding:.4rem .8rem;border-radius:999px;background:rgba(255,255,255,.7);backdrop-filter:blur(10px) saturate(160%);-webkit-backdrop-filter:blur(10px) saturate(160%);border:1px solid var(--glass-bd);font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--violet);font-weight:600;box-shadow:var(--shadow-sm);width:fit-content;animation:mp-hintBob 2.4s ease-in-out infinite;transition:opacity .5s ease,transform .5s ease}
  .mp-portrait-hint.mp-hide{opacity:0;transform:translateY(-6px) scale(.95);pointer-events:none}
  @keyframes mp-hintBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}

  /* ── T0.4: Frosted glass cards (the BIG premium upgrade) ─────────── */
  .info-card,.cert-row,.focus-card,.edu-card,.c-link,.hero-pill,.hero-role,.chip{
    background:rgba(255,255,255,.62) !important;
    backdrop-filter:blur(16px) saturate(170%);
    -webkit-backdrop-filter:blur(16px) saturate(170%);
    border-color:rgba(255,255,255,.55) !important;
    box-shadow:0 1px 0 rgba(255,255,255,.6) inset, 0 8px 24px rgba(40,50,100,.06), 0 1px 3px rgba(40,50,100,.04) !important;
  }
  .focus-card{background:rgba(255,255,255,.55) !important}
  .edu-card{background:rgba(255,255,255,.58) !important}
  /* Section base bg subtly tinted so blur picks up colour */
  body::after{
    background:
      radial-gradient(ellipse 80% 60% at 10% 0%,   rgba(139,92,246,.16) 0%, transparent 60%),
      radial-gradient(ellipse 60% 50% at 90% 10%,  rgba(59,130,246,.14) 0%, transparent 55%),
      radial-gradient(ellipse 70% 60% at 80% 55%,  rgba(236,72,153,.11) 0%, transparent 60%),
      radial-gradient(ellipse 60% 50% at 15% 80%,  rgba(16,224,160,.11) 0%, transparent 55%),
      radial-gradient(ellipse 50% 40% at 50% 100%, rgba(99,102,241,.13) 0%, transparent 60%) !important;
  }

  /* ── T1.4: H2 word stagger reveal ────────────────────────────────── */
  .h2 .mp-word{display:inline-block;opacity:0;transform:translateY(28px) scale(.96);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);will-change:transform,opacity}
  .h2 .mp-word.on{opacity:1;transform:translateY(0) scale(1)}

  /* ── T1.5: Card scroll-lift with shadow elevation ────────────────── */
  .focus-card,.edu-card,.info-card,.cert-row,.why-item,.job{
    transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1),border-color .4s ease;
    will-change:auto;
  }
  .focus-card.mp-lift,.edu-card.mp-lift,.info-card.mp-lift,.cert-row.mp-lift{
    transform:translate3d(0,-4px,0);
    box-shadow:0 18px 50px rgba(99,102,241,.18), 0 6px 18px rgba(40,50,100,.08), 0 1px 0 rgba(255,255,255,.6) inset !important;
    border-color:rgba(139,92,246,.30) !important;
  }

  /* ── T1.6: Marquee perspective tilt + edge fades ─────────────────── */
  #s-marquee{perspective:600px}
  .marquee-inner{transform:rotateX(-3deg);transform-origin:50% 50%}
  #s-marquee{position:relative}
  #s-marquee::before,#s-marquee::after{content:'';position:absolute;top:0;bottom:0;width:60px;z-index:3;pointer-events:none}
  #s-marquee::before{left:0;background:linear-gradient(90deg,var(--bg) 0%,transparent 100%)}
  #s-marquee::after{right:0;background:linear-gradient(-90deg,var(--bg) 0%,transparent 100%)}

  /* ── T2.1: Touch-tilt cards ──────────────────────────────────────── */
  .focus-card,.edu-card{transform-style:preserve-3d}
  .focus-card.mp-tilt,.edu-card.mp-tilt{
    transform:perspective(900px) rotateX(var(--mp-tx,0deg)) rotateY(var(--mp-ty,0deg)) translate3d(0,var(--mp-lift,0px),0);
    transition:transform .12s ease-out, box-shadow .3s ease;
  }
  .focus-card.mp-tilt-release,.edu-card.mp-tilt-release{
    transition:transform .55s cubic-bezier(.34,1.56,.64,1), box-shadow .4s ease;
  }
  /* Specular sheen that follows finger on tilted card */
  .focus-card .mp-spec,.edu-card .mp-spec{
    position:absolute;inset:0;border-radius:inherit;pointer-events:none;
    background:radial-gradient(180px circle at var(--mp-spx,50%) var(--mp-spy,50%),rgba(255,255,255,.45),transparent 55%);
    opacity:0;transition:opacity .25s ease;mix-blend-mode:screen;z-index:3;
  }
  .focus-card.mp-tilt .mp-spec,.edu-card.mp-tilt .mp-spec{opacity:.7}

  /* ── T2.2: Pressure-style tap on CTAs ────────────────────────────── */
  .btn,.n-hire,.c-link,.sk-tab,.mp-hire-fab{
    transition:transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease, filter .25s ease;
    -webkit-user-select:none;user-select:none;
  }
  .btn:active,.n-hire:active,.c-link:active,.sk-tab:active,.mp-hire-fab:active{
    transform:scale(.95) translateZ(0);
    filter:brightness(.97);
  }
  .btn.mp-press-rebound,.c-link.mp-press-rebound,.sk-tab.mp-press-rebound,.mp-hire-fab.mp-press-rebound{
    animation:mp-pressRebound .55s cubic-bezier(.34,1.56,.64,1);
  }
  @keyframes mp-pressRebound{
    0%{transform:scale(.95)}
    55%{transform:scale(1.04)}
    100%{transform:scale(1)}
  }

  /* ── T2.4: Service accordion polish ──────────────────────────────── */
  .svc-row.open{background:linear-gradient(135deg,color-mix(in srgb,var(--c1,#3b82f6) 8%,transparent),color-mix(in srgb,var(--c2,#8b5cf6) 6%,transparent),transparent 70%) !important}
  .svc-body{transition:max-height .55s cubic-bezier(.16,1,.3,1),padding .55s cubic-bezier(.16,1,.3,1)}
  .svc-row.open .svc-body{max-height:520px}
  .svc-desc,.svc-outcomes{padding-left:0}

  /* ── T2.5: Skills tab — active lift + glow ───────────────────────── */
  .sk-tab.active{transform:translateY(-2px);box-shadow:0 10px 26px color-mix(in srgb,var(--sk-a,#6366f1) 50%,transparent),0 2px 8px color-mix(in srgb,var(--sk-b,#8b5cf6) 35%,transparent)}
  .sk-marquee-wrap::before{background:linear-gradient(90deg,var(--bg) 0%,rgba(248,247,255,.7) 50%,transparent 100%)}
  .sk-marquee-wrap::after{background:linear-gradient(-90deg,var(--bg) 0%,rgba(248,247,255,.7) 50%,transparent 100%)}

  /* ── T3.1: Section dividers between mobile sections ──────────────── */
  #s-about::before,#s-focus::before,#s-skills::before,#s-services::before,#s-why::before,#s-exp::before,#s-edu::before,#s-contact::before{
    content:'✦';
    display:block;
    text-align:center;
    color:var(--violet);
    font-size:.8rem;
    opacity:.5;
    margin-bottom:1.4rem;
    position:relative;
    z-index:3;
  }
  #s-about::before{
    background:linear-gradient(90deg,transparent 0%,transparent 38%,var(--violet) 50%,transparent 62%,transparent 100%);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
  }

  /* ── T3.2: Mini-orb scroll progress (top-right) ──────────────────── */
  .mp-mini-orb{
    position:fixed;
    top:calc(env(safe-area-inset-top,0) + .9rem);
    right:.9rem;
    width:38px;height:38px;
    border-radius:50%;
    z-index:101;
    pointer-events:auto;
    cursor:pointer;
    background:conic-gradient(from -90deg,var(--violet) calc(var(--mp-prog,0) * 1%),rgba(140,150,200,.18) 0);
    padding:2.5px;
    opacity:0;transform:translateY(-10px) scale(.85);
    transition:opacity .45s var(--ease-out),transform .45s var(--ease-out);
    box-shadow:0 8px 22px rgba(99,102,241,.28),0 1px 4px rgba(40,50,100,.10);
    -webkit-tap-highlight-color:transparent;
  }
  .mp-mini-orb.mp-show{opacity:1;transform:translateY(0) scale(1)}
  .mp-mini-orb-inner{
    width:100%;height:100%;border-radius:50%;
    background:radial-gradient(circle at 30% 30%,#a78bfa 0%,#6366f1 55%,#1e1b4b 100%);
    display:flex;align-items:center;justify-content:center;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.4),inset 0 -8px 16px rgba(30,12,80,.5);
    color:#fff;font-size:.7rem;
  }
  .mp-mini-orb-inner svg{width:14px;height:14px;opacity:.85}

  /* ── T3.3: Typography rhythm — premium feel ──────────────────────── */
  body{line-height:1.7}
  .hero-h1{letter-spacing:-.018em}
  .h2{letter-spacing:-.012em}
  .focus-title,.svc-title,.why-title,.edu-deg{letter-spacing:-.005em}

  /* ── T3.4: Tap ripple ────────────────────────────────────────────── */
  .mp-ripple{
    position:fixed;
    pointer-events:none;
    width:60px;height:60px;
    border-radius:50%;
    background:radial-gradient(circle,rgba(139,92,246,.45) 0%,rgba(99,102,241,.20) 40%,transparent 70%);
    transform:translate(-50%,-50%) scale(0);
    z-index:9998;
    animation:mp-rippleOut .65s cubic-bezier(.22,1,.36,1) forwards;
    will-change:transform,opacity;
  }
  @keyframes mp-rippleOut{
    0%{transform:translate(-50%,-50%) scale(0);opacity:1}
    100%{transform:translate(-50%,-50%) scale(2.2);opacity:0}
  }

  /* ── T3.6: Floating Hire Me FAB ──────────────────────────────────── */
  .mp-hire-fab{
    position:fixed;
    bottom:calc(env(safe-area-inset-bottom,0) + 1.1rem);
    left:50%;
    transform:translateX(-50%) translateY(20px);
    z-index:98;
    display:inline-flex;align-items:center;gap:.55rem;
    padding:.78rem 1.4rem;
    border-radius:999px;
    background:linear-gradient(135deg,var(--blue),var(--violet) 65%,var(--pink));
    color:#fff;
    font-weight:600;
    font-size:.82rem;
    text-decoration:none;
    box-shadow:0 14px 36px rgba(99,102,241,.45),0 4px 12px rgba(236,72,153,.22),0 1px 0 rgba(255,255,255,.25) inset;
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border:1px solid rgba(255,255,255,.22);
    opacity:0;
    pointer-events:none;
    transition:opacity .45s var(--ease-out),transform .55s cubic-bezier(.34,1.56,.64,1);
    -webkit-tap-highlight-color:transparent;
  }
  .mp-hire-fab.mp-show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
  .mp-hire-fab .mp-fab-dot{
    width:7px;height:7px;border-radius:50%;
    background:var(--mint);
    box-shadow:0 0 10px var(--mint);
    animation:pulse 1.8s infinite;
  }
  .mp-hire-fab svg{flex-shrink:0;opacity:.95}

  /* ── Hero exit pull-back: subtle camera move ─────────────────────── */
  #s-hero{will-change:transform;transition:transform .15s linear}
  .hero-content,.portrait-wrap{will-change:transform,opacity,filter}

  /* ── Reveal upgrade for mobile portrait ──────────────────────────── */
  .reveal{transform:translate3d(0,30px,0) scale(.97);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
  .reveal.on{transform:translate3d(0,0,0) scale(1)}

  /* ── Progress bar glow on mobile ─────────────────────────────────── */
  #progress>div{box-shadow:0 0 16px rgba(99,102,241,.55),0 2px 12px rgba(99,102,241,.4)}

  /* ── Smooth-lift portrait wrapper to make room for hint ──────────── */
  .portrait-wrap{flex-direction:column}

}
/* ════ END MOBILE-PORTRAIT PREMIUM LAYER ════ */

/* ====================================================================
   ╔══════════════════════════════════════════════════════════════════╗
   ║   JOULE CINEMA — MOBILE (portrait + landscape)                   ║
   ║   Joule (SAP AI agent) becomes the protagonist of the page on    ║
   ║   any mobile viewport. PC (>=861px) is 100% untouched.           ║
   ╚══════════════════════════════════════════════════════════════════╝
   ==================================================================== */
@media (max-width:860px){

  /* ── 3D JOULE — mobile portrait only ─────────────────────────────
     Joule becomes a real 3D object: depth, perspective, lighting,
     surface highlight, grounded shadow. Cinematic + masks any jitter. */
  .joule-stage{
    perspective:1200px !important;
    perspective-origin:50% 40% !important;
  }
  .joule-mega{
    filter:saturate(1.1) !important;
    transform-style:preserve-3d !important;
  }
  .joule-core{
    transition:none;
    transform-style:preserve-3d;
    /* Layer is pushed back slightly to give room for sparkle in front */
    transform:translateZ(0);
    /* Stronger drop shadow for grounding the 3D object */
    filter:
      drop-shadow(0 8px 14px rgba(76,29,149,.28))
      drop-shadow(0 24px 40px rgba(124,58,237,.32))
      drop-shadow(0 50px 80px rgba(99,102,241,.22))
      blur(var(--orb-blur)) !important;
  }
  /* Plasma body sits on the back plane */
  .joule-mega .joule-plasma{
    transform:translateZ(-12px) !important;
  }
  /* SVG shape (the iconic Joule mark with the inner sparkle) sits in front */
  .joule-mega .joule-shape{
    transform:translateZ(8px) !important;
    filter:drop-shadow(0 4px 12px rgba(255,255,255,.25));
  }
  /* Re-enable .joule-spec on mobile portrait — this is our specular
     highlight layer. Floats farther forward, mix-blend lights up.
     Already exists in DOM, just was hidden on mobile. */
  .joule-mega .joule-spec{
    display:block !important;
    transform:translateZ(20px) !important;
    /* Stronger highlight to read as 3D lighting */
    background:
      radial-gradient(ellipse 30% 22% at var(--mp-spec-x,28%) var(--mp-spec-y,20%),
        rgba(255,255,255,1) 0%,
        rgba(255,255,255,.55) 28%,
        transparent 60%),
      radial-gradient(ellipse 55% 38% at 75% 82%,
        rgba(40,12,80,.6) 0%,
        rgba(76,29,149,.35) 35%,
        transparent 65%),
      linear-gradient(160deg,transparent 38%,rgba(40,12,80,.22) 100%) !important;
    mix-blend-mode:screen !important;
    transition:background .15s linear;
  }

  /* 3D ground shadow — tilts and stretches with rotation
     This is a separate plane behind Joule that fakes a contact shadow. */
  .joule-mega::after{
    content:'';
    position:absolute;
    left:50%;
    bottom:-8%;
    width:65%;
    height:20px;
    background:radial-gradient(ellipse,
      rgba(76,29,149,.45) 0%,
      rgba(76,29,149,.20) 40%,
      transparent 75%);
    filter:blur(14px);
    transform:translateX(-50%) translateZ(-30px) rotateX(78deg) scale(var(--mp-shadow-scale,1));
    pointer-events:none;
    z-index:-1;
    opacity:.7;
    transition:transform .15s linear, opacity .25s ease;
    will-change:transform,opacity;
  }

  /* Ghost trails stay hidden on mobile portrait — Joule stays calm. */
  .joule-mega .joule-ghost{ display:none !important; }

  /* ── Hero spawn: cinematic fly-in + overshoot settle ───────────────
     Orb 1 enters from top-left off-screen, overshoots hero pose,
     then springs back to rest. Orb 2 enters from bottom-right with
     a delay. JS tick is locked out while mp-joule-spawn class is set. */
  .joule-mega.mp-joule-spawn{
    animation:mp-jouleSpawn 4.5s cubic-bezier(0.25,0.46,0.45,0.94) both;
    will-change:transform,opacity;
  }
  @keyframes mp-jouleSpawn{
    0%   {opacity:0;
          transform:translate(-50%,-50%)
                   translate3d(-60vw,-65vh,0)
                   scale(0.06)
                   rotateZ(-45deg)}
    8%   {opacity:.25;
          transform:translate(-50%,-50%)
                   translate3d(-52vw,-56vh,0)
                   scale(0.12)
                   rotateZ(-36deg)}
    25%  {opacity:.6;
          transform:translate(-50%,-50%)
                   translate3d(-28vw,-30vh,0)
                   scale(0.32)
                   rotateZ(-20deg)}
    50%  {opacity:.9;
          transform:translate(-50%,-50%)
                   translate3d(-6vw,-8vh,0)
                   scale(0.54)
                   rotateZ(-6deg)}
    68%  {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(calc(var(--mp-spawn-final-x,0px) * 1.20), calc(var(--mp-spawn-final-y,0px) * 1.14), 0)
                   scale(0.70)
                   rotateZ(5deg)}
    80%  {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(calc(var(--mp-spawn-final-x,0px) * 0.93), calc(var(--mp-spawn-final-y,0px) * 0.95), 0)
                   scale(0.59)
                   rotateZ(-2deg)}
    91%  {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(calc(var(--mp-spawn-final-x,0px) * 1.04), calc(var(--mp-spawn-final-y,0px) * 1.02), 0)
                   scale(0.63)
                   rotateZ(0.5deg)}
    100% {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(var(--mp-spawn-final-x,0px), var(--mp-spawn-final-y,0px), 0)
                   scale(.62)
                   rotateZ(0deg)}
  }

  /* Orb 2 cinematic fly-in — bottom-right to its resting position */
  .joule-mega2.mp-joule-spawn2{
    animation:mp-jouleSpawn2 4.0s cubic-bezier(0.25,0.46,0.45,0.94) both;
    will-change:transform,opacity;
  }
  @keyframes mp-jouleSpawn2{
    0%   {opacity:0;
          transform:translate(-50%,-50%)
                   translate3d(55vw, 60vh, 0)
                   scale(0.05)
                   rotateZ(38deg)}
    10%  {opacity:.2;
          transform:translate(-50%,-50%)
                   translate3d(46vw, 50vh, 0)
                   scale(0.10)
                   rotateZ(28deg)}
    28%  {opacity:.55;
          transform:translate(-50%,-50%)
                   translate3d(24vw, 28vh, 0)
                   scale(0.20)
                   rotateZ(16deg)}
    52%  {opacity:.85;
          transform:translate(-50%,-50%)
                   translate3d(5vw, 8vh, 0)
                   scale(0.30)
                   rotateZ(5deg)}
    70%  {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(calc(var(--mp-spawn2-final-x,0px) * 1.16), calc(var(--mp-spawn2-final-y,0px) * 1.12), 0)
                   scale(0.40)
                   rotateZ(-4deg)}
    83%  {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(calc(var(--mp-spawn2-final-x,0px) * 0.95), calc(var(--mp-spawn2-final-y,0px) * 0.96), 0)
                   scale(0.32)
                   rotateZ(1deg)}
    93%  {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(calc(var(--mp-spawn2-final-x,0px) * 1.02), calc(var(--mp-spawn2-final-y,0px) * 1.01), 0)
                   scale(0.35)
                   rotateZ(0deg)}
    100% {opacity:1;
          transform:translate(-50%,-50%)
                   translate3d(var(--mp-spawn2-final-x,0px), var(--mp-spawn2-final-y,0px), 0)
                   scale(.34)
                   rotateZ(0deg)}
  }

  /* Portrait pulse during spawn — like the photo is "giving birth" to Joule */
  .portrait.mp-portrait-pulse{
    animation:mp-portraitPulse .9s cubic-bezier(.22,1,.36,1);
  }
  @keyframes mp-portraitPulse{
    0%   {transform:scale(1)}
    35%  {transform:scale(1.04)}
    65%  {transform:scale(.99)}
    100% {transform:scale(1)}
  }

  /* Sparkle burst at portrait centre during spawn */
  .mp-spawn-burst{
    position:fixed;
    width:60vw;height:60vw;max-width:420px;max-height:420px;
    border-radius:50%;
    background:radial-gradient(circle,
      rgba(255,255,255,.9) 0%,
      rgba(196,181,253,.6) 20%,
      rgba(139,92,246,.35) 40%,
      transparent 70%);
    transform:translate(-50%,-50%) scale(0);
    pointer-events:none;
    z-index:1;
    mix-blend-mode:screen;
    animation:mp-spawnBurst 1.0s cubic-bezier(.22,1,.36,1) forwards;
    will-change:transform,opacity;
  }
  @keyframes mp-spawnBurst{
    0%  {opacity:0;transform:translate(-50%,-50%) scale(0)}
    20% {opacity:.95;transform:translate(-50%,-50%) scale(.6)}
    50% {opacity:.6;transform:translate(-50%,-50%) scale(1.4)}
    100%{opacity:0;transform:translate(-50%,-50%) scale(2.0)}
  }

  /* Experience timeline walker — light dot when Joule passes it */
  .job::after{
    transition:transform .35s ease, box-shadow .35s ease, background .35s ease, border-color .35s ease;
  }
  .job.mp-pass::after{
    transform:scale(1.5);
    background:var(--violet);
    border-color:#fff;
    box-shadow:0 0 0 5px rgba(139,92,246,.25), 0 0 20px rgba(139,92,246,.7);
  }

  /* Subtle hero h1 em breathing — keeps the page feeling alive on idle */
  .hero-h1 em{animation:shimmer 6s linear infinite, mp-emBreath 3.6s ease-in-out infinite}
  @keyframes mp-emBreath{
    0%,100%{transform:scale(1)}
    50%    {transform:scale(1.03)}
  }

  /* Focus cards cascade-in entrance */
  .focus-card.mp-cascade{
    animation:mp-cardCascade .7s cubic-bezier(.22,1,.36,1) both;
  }
  @keyframes mp-cardCascade{
    0%{opacity:0;transform:translateY(40px) scale(.94)}
    100%{opacity:1;transform:translateY(0) scale(1)}
  }

}
/* ════ END JOULE CINEMA LAYER ════ */
