/* ==========================================================================
   Serhii Lozovskyi — CV. Dark canvas, signal-yellow accent, editorial type.
   ========================================================================== */

:root{
  /* canvas */
  --void:#0a0a0a;
  --ink:#050505;
  --surface:#131313;
  --surface-2:#181818;

  /* type */
  --bone:#f4f4ef;
  --ash:#a3a39c;
  --smoke:#6c6c66;
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);

  /* accent */
  --accent:#ffd60a;
  --accent-2:#ffe24d;
  --accent-deep:#caa700;
  --accent-glow:rgba(255,214,10,.16);

  /* type families */
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --mono:"Space Mono","JetBrains Mono",ui-monospace,monospace;

  /* layout */
  --maxw:1240px;
  --gutter:clamp(20px,5vw,72px);
  --radius:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--void);
  color:var(--bone);
  font-family:var(--sans);
  font-weight:400;
  line-height:1.55;
  letter-spacing:-.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.no-scroll{overflow:hidden}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}
::selection{background:var(--accent);color:#000}

/* faint dotted texture on the whole page */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:34px 34px;mask-image:radial-gradient(120% 80% at 50% 0%,#000 35%,transparent 78%);
}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);position:relative;z-index:1}

/* ---------- shared type ---------- */
.eyebrow{
  font-family:var(--mono);font-size:12px;font-weight:400;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:.7em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);opacity:.8}
.section{padding-block:clamp(72px,11vw,140px);position:relative}
.section-head{margin-bottom:clamp(36px,6vw,68px)}
.section-title{
  font-size:clamp(30px,5.4vw,58px);font-weight:600;letter-spacing:-.03em;line-height:1.02;
  margin-top:18px;
}
.section-sub{color:var(--ash);max-width:46ch;margin-top:16px;font-size:clamp(15px,1.6vw,17px)}
.divider{height:1px;background:var(--line);border:0}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px var(--gutter);
  background:rgba(10,10,10,.55);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.nav.scrolled{border-bottom-color:var(--line);background:rgba(10,10,10,.82)}
.brand{display:flex;align-items:center;gap:12px;font-weight:600;letter-spacing:-.02em}
.brand .mono-tag{
  font-family:var(--mono);font-size:13px;border:1px solid var(--line-strong);
  width:34px;height:34px;display:grid;place-items:center;border-radius:9px;color:var(--accent);
}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{
  font-size:14px;color:var(--ash);letter-spacing:0;position:relative;transition:color .2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--bone)}
.nav-links a.active::after{
  content:"";position:absolute;left:0;bottom:-6px;width:100%;height:1px;background:var(--accent);
}
.nav-right{display:flex;align-items:center;gap:14px}

/* language toggle */
.lang{
  display:inline-flex;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden;
  font-family:var(--mono);font-size:12px;
}
.lang button{
  background:transparent;color:var(--smoke);border:0;cursor:pointer;
  padding:7px 13px;letter-spacing:.06em;transition:.2s;
}
.lang button.active{background:var(--accent);color:#000;font-weight:700}

.menu-btn{display:none;background:none;border:1px solid var(--line-strong);border-radius:9px;
  width:38px;height:38px;cursor:pointer;color:var(--bone);align-items:center;justify-content:center}
.menu-btn svg{width:18px;height:18px}

/* ---------- hero ---------- */
.hero{
  min-height:100vh;display:flex;flex-direction:column;justify-content:center;
  padding-top:120px;padding-bottom:60px;position:relative;
}
.hero::after{ /* radial yellow glow */
  content:"";position:absolute;z-index:0;top:-10%;right:-5%;width:60vw;height:60vw;max-width:760px;max-height:760px;
  background:radial-gradient(circle,var(--accent-glow),transparent 62%);pointer-events:none;
}
.hero-inner{position:relative;z-index:1}
.hero h1{
  font-size:clamp(48px,11vw,150px);font-weight:600;line-height:.92;letter-spacing:-.045em;
  margin:22px 0 0;
}
.hero h1 .accent{color:var(--accent)}
.hero .tagline{
  color:var(--ash);font-size:clamp(17px,2.3vw,25px);max-width:30ch;margin-top:28px;line-height:1.4;
  font-weight:300;letter-spacing:-.02em;
}
.role-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px}
.chip{
  font-family:var(--mono);font-size:12.5px;letter-spacing:.02em;color:var(--bone);
  border:1px solid var(--line-strong);border-radius:999px;padding:8px 15px;background:rgba(255,255,255,.02);
}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:42px}
.btn{
  display:inline-flex;align-items:center;gap:10px;font-size:15px;font-weight:500;
  padding:14px 26px;border-radius:999px;cursor:pointer;transition:.22s;border:1px solid transparent;
}
.btn-primary{background:var(--accent);color:#000}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line-strong);color:var(--bone)}
.btn-ghost:hover{border-color:var(--bone);transform:translateY(-2px)}
.btn svg{width:16px;height:16px}
.scroll-hint{
  position:absolute;bottom:26px;left:var(--gutter);font-family:var(--mono);font-size:11px;
  letter-spacing:.2em;text-transform:uppercase;color:var(--smoke);display:flex;align-items:center;gap:10px;z-index:1;
}
.scroll-hint .bar{width:1px;height:34px;background:linear-gradient(var(--accent),transparent);animation:drop 1.8s infinite}
@keyframes drop{0%{opacity:0;transform:scaleY(.2)}50%{opacity:1}100%{opacity:0;transform:translateY(10px) scaleY(.2)}}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{padding:30px 22px;border-left:1px solid var(--line)}
.stat:first-child{border-left:0}
.stat .num{font-size:clamp(30px,4.4vw,52px);font-weight:600;letter-spacing:-.03em;line-height:1}
.stat .num .accent{color:var(--accent)}
.stat .lbl{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--smoke);margin-top:10px}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.5fr 1fr;gap:clamp(30px,6vw,90px)}
.about-sticky{position:sticky;top:120px;align-self:start}
.about-body p{color:var(--ash);font-size:clamp(16px,1.8vw,19px);margin-bottom:22px;max-width:64ch}
.about-body p strong{color:var(--bone);font-weight:500}
.langs{margin-top:40px;display:flex;flex-direction:column;gap:14px}
.lang-row{display:flex;align-items:baseline;justify-content:space-between;border-top:1px solid var(--line);padding-top:14px;max-width:420px}
.lang-row .l-name{font-weight:500}
.lang-row .l-lvl{font-family:var(--mono);font-size:12.5px;color:var(--accent)}

/* ---------- skills ---------- */
.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,4vw,52px)}
.skill-group h3{
  font-family:var(--mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--bone);
  padding-bottom:14px;margin-bottom:18px;border-bottom:1px solid var(--line-strong);
}
.skill-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:9px 0}
.skill-row .s-name{font-size:15.5px;color:var(--bone)}
.meter{display:flex;gap:6px}
.dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.13);transition:background .4s,transform .4s}
.dot.on{background:var(--accent)}
.skill-row.reveal .dot{transform:scale(0)}
.skill-row.reveal.in .dot{transform:scale(1)}

/* ---------- work ---------- */
.project{
  display:grid;grid-template-columns:64px 1fr;gap:clamp(16px,3vw,40px);
  padding:clamp(28px,4vw,44px) 0;border-top:1px solid var(--line);
}
.project:hover .p-name{color:var(--accent)}
.p-index{font-family:var(--mono);font-size:14px;color:var(--smoke);padding-top:6px}
.p-name{
  font-size:clamp(24px,3.4vw,38px);font-weight:600;letter-spacing:-.03em;transition:color .25s;
  display:inline-flex;align-items:center;gap:14px;
}
.p-name .ext{width:16px;height:16px;color:var(--smoke);transition:color .2s,transform .2s}
.p-name:hover .ext{color:var(--accent);transform:translate(2px,-2px)}
.p-meta{display:flex;flex-wrap:wrap;gap:8px 26px;margin:18px 0 16px}
.p-meta .m{display:flex;flex-direction:column;gap:3px}
.p-meta .m .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--smoke)}
.p-meta .m .v{font-size:14px;color:var(--bone)}
.p-desc{color:var(--ash);font-size:clamp(15px,1.7vw,17px);max-width:74ch;margin-bottom:18px}
.tool-chips{display:flex;flex-wrap:wrap;gap:8px}
.tool{font-family:var(--mono);font-size:11.5px;color:var(--ash);border:1px solid var(--line);border-radius:7px;padding:5px 10px}

/* ---------- media gallery ---------- */
.media-grid{column-count:3;column-gap:14px}
@media(min-width:1400px){.media-grid{column-count:4}}
.media-card{
  position:relative;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  background:var(--surface);aspect-ratio:3/4;break-inside:avoid;margin-bottom:14px;width:100%;
}
/* editorial scatter: slight tilt per frame, settles straight on hover */
.media-grid .media-card{
  --tilt:0deg;opacity:0;transform:translateY(30px) rotate(var(--tilt)) scale(.985);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .85s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .45s;
}
.media-grid .media-card.in{opacity:1;transform:translateY(0) rotate(var(--tilt)) scale(1)}
.media-grid .media-card:nth-child(5n+1){--tilt:-1.2deg}
.media-grid .media-card:nth-child(5n+2){--tilt:.8deg}
.media-grid .media-card:nth-child(5n+3){--tilt:-.5deg}
.media-grid .media-card:nth-child(5n+4){--tilt:1.1deg}
.media-grid .media-card:nth-child(5n+5){--tilt:-.9deg}
.media-grid .media-card:nth-child(3n+2){transition-delay:.07s}
.media-grid .media-card:nth-child(3n+3){transition-delay:.14s}
.media-grid .media-card:hover{
  transform:translateY(-7px) rotate(0deg) scale(1.015);transition-delay:0s;z-index:6;
  border-color:rgba(255,214,10,.55);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.7),0 0 0 1px rgba(255,214,10,.22);
}
/* diagonal light sweep on hover */
.media-card::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(115deg,transparent 32%,rgba(255,255,255,.12) 48%,transparent 64%);
  transform:translateX(-130%);transition:transform .9s ease}
.media-card:hover::after{transform:translateX(130%)}
.media-card .loader{
  position:absolute;inset:0;display:grid;place-items:center;background:var(--surface);z-index:2;transition:opacity .4s;
}
.media-card.loaded .loader{opacity:0;pointer-events:none}
.spinner{width:30px;height:30px;border:2px solid var(--line-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.media-card img,.media-card video{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s,transform .9s cubic-bezier(.16,1,.3,1)}
.media-card.loaded img,.media-card.loaded video{opacity:1}
.media-card .rot-layer{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1);will-change:opacity}
.media-card.loaded .rot-layer{opacity:0}
.media-card.loaded .rot-layer.show{opacity:1}
.media-card:hover img,.media-card:hover video,.media-card:hover .rot-layer{transform:scale(1.06)}
.media-card .cap{
  position:absolute;left:0;right:0;bottom:0;z-index:3;padding:30px 16px 14px;
  background:linear-gradient(transparent,rgba(8,8,8,.86));font-size:13px;font-weight:500;letter-spacing:-.01em;
  transform:translateY(0);opacity:.92;transition:.35s;
}
.media-card:hover .cap{opacity:1;padding-bottom:18px}
.media-card .play{
  position:absolute;inset:0;z-index:3;display:grid;place-items:center;cursor:pointer;
}
.media-card .play span{
  position:relative;width:54px;height:54px;border-radius:50%;background:var(--accent);color:#000;display:grid;place-items:center;
  transition:transform .25s;box-shadow:0 6px 22px rgba(255,214,10,.28);
}
.media-card .play span::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:1px solid var(--accent);
  opacity:.55;animation:pulseRing 2.6s ease-out infinite}
@keyframes pulseRing{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.55);opacity:0}}
.media-card:hover .play span{transform:scale(1.12)}
.media-card .play svg{width:20px;height:20px;margin-left:3px}
.media-empty{
  border:1px dashed var(--line-strong);border-radius:var(--radius);padding:60px 24px;text-align:center;
  color:var(--smoke);font-family:var(--mono);font-size:14px;letter-spacing:.04em;
}

/* ---------- contact ---------- */
.contact{position:relative}
.contact-grid{display:grid;grid-template-columns:1fr .7fr;gap:clamp(34px,6vw,80px);align-items:center}
.contact h2{font-size:clamp(34px,6.5vw,76px);font-weight:600;letter-spacing:-.04em;line-height:.98}
.contact h2 .accent{color:var(--accent)}
.contact-links{margin-top:38px;display:flex;flex-direction:column;gap:2px;max-width:520px}
.c-link{
  display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 4px;
  border-top:1px solid var(--line);transition:padding .25s,color .25s;
}
.c-link:last-child{border-bottom:1px solid var(--line)}
.c-link:hover{padding-left:16px}
.c-link .c-k{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--smoke)}
.c-link .c-v{font-size:clamp(16px,2vw,21px);font-weight:500;display:flex;align-items:center;gap:12px}
.c-link:hover .c-v{color:var(--accent)}
.c-link .arrow{transition:transform .2s}
.c-link:hover .arrow{transform:translate(3px,-3px)}
.photo-wrap{position:relative;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;aspect-ratio:4/5;background:var(--surface)}
.photo-wrap img{width:100%;height:100%;object-fit:cover}
.photo-placeholder{
  position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:var(--smoke);
  font-family:var(--mono);font-size:12px;letter-spacing:.05em;padding:20px;
  background:repeating-linear-gradient(45deg,var(--surface),var(--surface) 12px,var(--surface-2) 12px,var(--surface-2) 24px);
}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);padding:40px var(--gutter);display:flex;
  align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;color:var(--smoke);font-size:13px}
.footer .mono{font-family:var(--mono)}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- mobile menu panel ---------- */
.mobile-panel{
  position:fixed;inset:0;z-index:49;background:rgba(10,10,10,.97);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:var(--gutter);
  transform:translateX(100%);transition:transform .35s cubic-bezier(.5,0,.2,1);
}
.mobile-panel.open{transform:none}
.mobile-panel a{font-size:30px;font-weight:600;letter-spacing:-.03em;padding:12px 0;border-bottom:1px solid var(--line)}
.mobile-panel a .idx{font-family:var(--mono);font-size:13px;color:var(--accent);margin-right:14px}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .nav-links{display:none}
  .menu-btn{display:inline-flex}
  .about-grid{grid-template-columns:1fr;gap:30px}
  .about-sticky{position:static}
  .skills-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(odd){border-left:0}
  .stat:nth-child(3),.stat:nth-child(4),.stat:nth-child(5){border-top:1px solid var(--line)}
  .media-grid{column-count:2}
  .contact-grid{grid-template-columns:1fr}
  .photo-wrap{max-width:340px;order:-1}
}
@media(max-width:560px){
  .project{grid-template-columns:1fr;gap:8px}
  .p-index{padding-top:0}
  .media-grid{column-count:1}
  .stats{grid-template-columns:1fr}
  .stat{border-left:0!important;border-top:1px solid var(--line)}
  .stat:first-child{border-top:0}
  .hero .tagline{max-width:100%}
}

/* ==========================================================================
   ANIMATIONS — integrated from the 3 reference DESIGN.md files
   · Particle field         -> DESIGN.md     (Dala — "particle constellation on a void")
   · Iridescent orb glow     -> DESIGN (1).md (ThoughtLab — "iridescent 3D orb hero")
   · Headline "etched" reveal-> Dala (wt-200 etched type) + ThoughtLab (architectural)
   · Eyebrow tick draw       -> DESIGN (2).md (NewForm — "accent tick mark")
   · (SCROLL) bracket label  -> ThoughtLab ("scroll indicator, bracketed uppercase")
   ========================================================================== */

#heroCanvas{position:absolute;inset:0;z-index:0;width:100%;height:100%;pointer-events:none}
.hero-orb{
  position:absolute;z-index:0;top:18%;right:-6%;width:46vw;height:46vw;max-width:620px;max-height:620px;
  border-radius:50%;pointer-events:none;opacity:.9;
  background:
    radial-gradient(circle at 38% 34%, rgba(255,226,77,.20), rgba(255,214,10,.10) 36%, transparent 60%),
    conic-gradient(from 210deg, rgba(255,214,10,.16), rgba(128,82,255,.10), rgba(252,28,70,.10), rgba(255,214,10,.16));
  filter:blur(34px);
  animation:orbDrift 16s ease-in-out infinite;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
@keyframes orbDrift{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(-3%,3%) scale(1.06)}
}
.hero-inner{position:relative;z-index:2}
.hero .scroll-hint{z-index:2}

.h-line{display:block;overflow:hidden;padding-bottom:.04em}
.h-word{display:inline-block;will-change:transform,opacity}
.reveal-head .h-word{transform:translateY(108%);opacity:0}
.reveal-head.in .h-word{animation:wordRise .9s cubic-bezier(.16,1,.3,1) forwards}
@keyframes wordRise{
  0%{transform:translateY(108%);opacity:0;letter-spacing:.04em}
  60%{opacity:1}
  100%{transform:translateY(0);opacity:1;letter-spacing:-.045em}
}

.eyebrow::before{width:0;transition:width .7s cubic-bezier(.2,.7,.2,1) .15s}
.reveal.in .eyebrow::before,.eyebrow.in::before{width:26px}

.scroll-hint .br{font-family:var(--mono);font-size:11px;letter-spacing:.2em}

.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{
  content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-18deg);transition:left .6s ease;
}
.btn-primary:hover::after{left:140%}

.project{transition:background .3s}
.project .p-body{transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.project:hover .p-body{transform:translateX(6px)}
.project:hover .p-index{color:var(--accent)}
.project:hover{border-top-color:var(--line-strong)}

.tool{transition:border-color .2s,color .2s,transform .2s}
.tool:hover{border-color:var(--accent);color:var(--bone);transform:translateY(-2px)}

.stat .num{transition:transform .6s cubic-bezier(.2,.7,.2,1),opacity .6s}
.stat.reveal .num{transform:translateY(12px);opacity:0}
.stat.reveal.in .num{transform:none;opacity:1}

@media(max-width:900px){ .hero-orb{opacity:.6;filter:blur(26px)} }

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  .reveal-head .h-word{transform:none;opacity:1}
  .hero-orb{animation:none}
  #heroCanvas{display:none}
}

/* ---------- site-wide particle field + hero photo ---------- */
#bgCanvas{position:fixed;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.nav,.wrap,.footer{position:relative;z-index:1}
.nav{z-index:50}

.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(24px,5vw,60px);align-items:center;position:relative;z-index:2}
.hero-media{position:relative;display:flex;align-items:center;justify-content:center;min-height:62vh}
.hero-media .hero-orb{top:50%;left:50%;right:auto;width:132%;height:132%;max-width:none;max-height:none;margin-left:-66%;margin-top:-66%}
.hero-photo{position:relative;z-index:2;width:100%;max-width:360px;aspect-ratio:4/5;border:1px solid var(--line-strong);border-radius:18px;overflow:hidden;background:var(--surface)}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo .photo-placeholder{position:absolute;inset:0}
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-media{min-height:0;order:2;justify-content:flex-start}
  .hero-photo{max-width:230px}
}

/* ---------- custom cursor: yellow dot; mix-blend-difference keeps it visible
   over yellow text/surfaces (it inverts the overlap) ---------- */
@media (pointer:fine){
  html,body{cursor:none}
  a,button,.btn,.lang button,.menu-btn,.c-link,.project,.tool,.chip,.media-card,[role="button"]{cursor:none}
  .cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:99999;
    transform:translate(-50%,-50%);mix-blend-mode:difference;will-change:transform}
  .cursor-dot{width:13px;height:13px;background:#ffd60a;transition:width .18s,height .18s,opacity .2s}
  .cursor-ring{width:34px;height:34px;border:1.5px solid #ffd60a;transition:width .22s,height .22s,opacity .22s,background .22s}
  .cursor-dot.hover{width:7px;height:7px}
  .cursor-ring.hover{width:54px;height:54px;background:rgba(255,214,10,.12)}
  .cursor-hidden{opacity:0!important}
}

/* ---------- penguin logo (no background) + always-readable pinned header ---------- */
.brand .logo{width:36px;height:36px;display:grid;place-items:center;flex:0 0 auto}
.brand .logo img{width:100%;height:100%;display:block}
/* keep the fixed header legible from the very top */
.nav{background:rgba(10,10,10,.7)}
.nav.scrolled{background:rgba(10,10,10,.9)}

/* ---------- automation section ---------- */
.auto-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.auto-card{border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,3vw,30px);
  background:rgba(255,255,255,.015);transition:border-color .25s,transform .25s,background .25s}
.auto-card:hover{border-color:var(--line-strong);transform:translateY(-3px);background:rgba(255,214,10,.035)}
.auto-idx{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.12em}
.auto-name{font-size:clamp(19px,2.2vw,24px);font-weight:600;letter-spacing:-.02em;margin:12px 0}
.auto-desc{color:var(--ash);font-size:15px;line-height:1.62;margin-bottom:18px}
.auto-more{font-family:var(--mono);font-size:13px;color:var(--smoke);letter-spacing:.04em;margin-top:28px}
.auto-cta{margin-top:44px;border:1px solid var(--line-strong);border-radius:20px;padding:clamp(28px,4vw,48px);
  display:flex;align-items:center;justify-content:space-between;gap:34px;flex-wrap:wrap;
  background:radial-gradient(130% 180% at 100% 0,var(--accent-glow),transparent 58%)}
.auto-cta-text{max-width:62ch}
.auto-cta-text h3{font-size:clamp(22px,3vw,33px);font-weight:600;letter-spacing:-.03em;line-height:1.12}
.auto-cta-text p{color:var(--ash);margin-top:14px;font-size:clamp(15px,1.7vw,17px);line-height:1.55}
.auto-cta-actions{display:flex;flex-direction:column;gap:12px;flex:0 0 auto}
.auto-cta-actions .btn{justify-content:center}
@media(max-width:760px){
  .auto-grid{grid-template-columns:1fr}
  .auto-cta{flex-direction:column;align-items:flex-start}
  .auto-cta-actions{flex-direction:row;flex-wrap:wrap;width:100%}
}

/* ---------- booking modal (Google Calendar iframe) ---------- */
.modal{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(5,5,5,.8);backdrop-filter:blur(6px)}
.modal-card{position:relative;z-index:1;width:min(860px,100%);max-height:94vh;background:var(--surface);
  border:1px solid var(--line-strong);border-radius:20px;padding:14px;display:flex;flex-direction:column;
  animation:modalIn .3s cubic-bezier(.16,1,.3,1)}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:-14px;right:-14px;width:40px;height:40px;border-radius:50%;background:var(--accent);
  color:#000;border:0;cursor:pointer;font-size:15px;font-weight:700;display:grid;place-items:center;z-index:2;transition:.2s}
.modal-close:hover{background:var(--accent-2);transform:scale(1.06)}
.modal-title{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--smoke);padding:4px 4px 12px}
.modal-frame{border-radius:12px;overflow:hidden;background:#fff;flex:1;min-height:0}
.modal-frame iframe{display:block;width:100%;height:74vh;max-height:680px;border:0}
@media(max-width:560px){.modal-frame iframe{height:72vh}}

/* ---------- inline calendar in Contact ---------- */
.contact-cal{margin-top:clamp(42px,6vw,76px)}
.contact-cal .cal-label{margin-bottom:18px}
.cal-frame{border:1px solid var(--line-strong);border-radius:18px;overflow:hidden;background:#fff;width:100%}
.cal-frame iframe{display:block;width:100%;height:860px;border:0;overflow:hidden}
@media(max-width:560px){.cal-frame iframe{height:780px}}

/* keep the header pinned (override an earlier position:relative rule) */
.nav{position:fixed;top:0;left:0;right:0;z-index:50}

/* project responsibilities list */
.p-resp{margin:0 0 18px}
.p-resp-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--smoke);display:block;margin-bottom:10px}
.p-resp ul{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:7px 28px}
.p-resp li{position:relative;padding-left:16px;color:var(--ash);font-size:13.5px;line-height:1.5}
.p-resp li::before{content:"";position:absolute;left:0;top:9px;width:5px;height:5px;background:var(--accent);border-radius:1px}
@media(max-width:760px){.p-resp ul{grid-template-columns:1fr}}

/* ---------- AI content studio grid ---------- */
.ai-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(258px,1fr));gap:18px}

/* ---------- service / case glyph icons (line draw-in + hover) ---------- */
.svc-icon{width:40px;height:40px;color:var(--accent);margin-bottom:16px;display:block;transition:transform .25s cubic-bezier(.2,.7,.2,1)}
.svc-icon svg{width:100%;height:100%;overflow:visible;display:block}
.svc-icon svg :where(path,line,circle,rect,polyline,polygon){fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.svc-icon [data-draw]{stroke-dasharray:1;stroke-dashoffset:1;transition:stroke-dashoffset .85s ease}
.svc-icon.drawn [data-draw]{stroke-dashoffset:0}
.auto-card:hover .svc-icon,.project:hover .svc-icon{color:var(--accent-2)}
.project .p-index{display:flex;flex-direction:column;gap:14px}
.project .p-index .svc-icon{width:34px;height:34px;margin:0}
@media(max-width:560px){.project .p-index{flex-direction:row;align-items:center;gap:12px}}

/* hero headline: show descenders (y/j/g) after the rise animation */
.h-line{padding-bottom:.12em}
.reveal-head.unclipped .h-line{overflow:visible}

/* ---------- video: streaming player + buffering loader ---------- */
.media-card.is-video{aspect-ratio:16/9}
.media-card video,.media-card .vid-frame{width:100%;height:100%}
.vid-frame{position:relative}
.vid-frame iframe{width:100%;height:100%;display:block;border:0}
.vid-loading{position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;background:rgba(10,10,10,.72);backdrop-filter:blur(2px);transition:opacity .35s}
.vid-loading.hide{opacity:0;pointer-events:none}
.vid-pct{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.06em}
.vid-bar{width:62%;max-width:200px;height:3px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
.vid-bar i{display:block;height:100%;width:0;background:var(--accent);transition:width .25s ease}

/* clickable role chips + About paragraph highlight */
.chip-link{transition:border-color .2s,color .2s,background .2s}
.chip-link:hover{border-color:var(--accent);color:var(--accent);background:rgba(255,214,10,.06)}
.about-body p{transition:background .45s ease,color .45s ease,box-shadow .45s ease}
.about-body p.hl{background:rgba(255,214,10,.10);color:var(--bone);box-shadow:inset 4px 0 0 var(--accent);border-radius:8px}

/* ---------- media lightbox ---------- */
.media-card{cursor:pointer}
.media-card .zoom{position:absolute;inset:0;z-index:3;display:grid;place-items:center;opacity:0;transition:opacity .3s}
.media-card:hover .zoom{opacity:1}
.media-card .zoom span{width:48px;height:48px;border-radius:50%;background:rgba(255,214,10,.92);color:#000;display:grid;place-items:center;transform:scale(.78);transition:transform .3s cubic-bezier(.16,1,.3,1);box-shadow:0 6px 22px rgba(255,214,10,.3)}
.media-card:hover .zoom span{transform:scale(1)}
.media-card .zoom svg{width:18px;height:18px}
.mlb{position:fixed;inset:0;z-index:1000;display:none;align-items:center;justify-content:center;padding:20px}
.mlb.open{display:flex}
.mlb-backdrop{position:absolute;inset:0;background:rgba(5,5,5,.82);backdrop-filter:blur(6px)}
.mlb-card{position:relative;z-index:1;width:min(1040px,100%);max-height:92vh;background:var(--surface);border:1px solid var(--line-strong);
  border-radius:20px;overflow:hidden;display:grid;grid-template-columns:1.05fr .8fr;animation:modalIn .3s cubic-bezier(.16,1,.3,1)}
.mlb-media{position:relative;background:#000;display:flex;align-items:center;justify-content:center;min-height:0;min-width:0}
.mlb-media img,.mlb-media video,.mlb-media iframe{width:100%;height:100%;max-height:92vh;object-fit:contain;display:block;border:0}
.mlb-info{padding:clamp(22px,3vw,34px);overflow-y:auto;max-height:92vh}
.mlb-info h3{font-size:clamp(20px,2.4vw,27px);font-weight:600;letter-spacing:-.02em;margin-bottom:16px;line-height:1.15}
.mlb-info p{color:var(--ash);font-size:14.5px;line-height:1.65;white-space:pre-line}
.mlb .modal-close{position:absolute;top:12px;right:12px}
@media(max-width:760px){
  .mlb-card{grid-template-columns:1fr;max-height:94vh}
  .mlb-media{max-height:48vh}
  .mlb-media img,.mlb-media video,.mlb-media iframe{max-height:48vh}
  .mlb-info{max-height:46vh}
}

/* ---------- media slider (grouped numbered photos) ---------- */
.media-card .mcount{position:absolute;top:11px;right:11px;z-index:3;font-family:var(--mono);font-size:11px;letter-spacing:.02em;
  background:rgba(8,8,8,.5);color:#fff;border:1px solid rgba(255,255,255,.28);padding:4px 9px;border-radius:999px;
  backdrop-filter:blur(6px);transition:.3s}
.media-card:hover .mcount{border-color:var(--accent);color:var(--accent)}
.mlb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;
  background:rgba(0,0,0,.5);color:#fff;border:1px solid rgba(255,255,255,.25);font-size:24px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:.2s}
.mlb-nav.prev{left:12px}
.mlb-nav.next{right:12px}
.mlb-nav:hover{background:var(--accent);color
@media(prefers-reduced-motion:reduce){
  .media-grid .media-card,.media-grid .media-card.in{transform:none!important;opacity:1;transition-delay:0s}
  .media-card::after{display:none}
  .media-card .play span::after{animation:none}
  .media-card:hover img,.media-card:hover video,.media-card:hover .rot-layer{transform:none}
}

/* deter casual saving of media (not bulletproof) */
.media-card img,.media-card video,.media-card .rot-layer,.mlb-media img,.mlb-media video{
  -webkit-user-drag:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
.media-card img,.media-card .rot-layer,.mlb-media img{pointer-events:none}
.media-card,.mlb-media{ -webkit-touch-callout:none }
