/* ═══════════════════════════════════════════════════════════
   ROCHAA — Roshan Ali · Multidisciplinary Designer
   Dark immersive portfolio · elliptical orbit gallery
   ═══════════════════════════════════════════════════════════ */

:root{
  --bg:      #050505;
  --bg-2:    #0c0c0e;
  --text:    #f3f1ec;
  --muted:   #8a8780;
  --faint:   #3a3a3c;
  --line:    rgba(243,241,236,.10);
  --accent:  #ff5d3b;
  --ff-serif: 'Instrument Serif', Georgia, serif;
  --ff-sans:  'Space Grotesk', system-ui, sans-serif;
}

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

html{ -webkit-font-smoothing:antialiased; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--ff-sans);
  font-weight:400;
  overflow-x:hidden;
  cursor:none;
}
body.menu-open{ overflow:hidden; }

a{ color:inherit; text-decoration:none; }
em{ font-family:var(--ff-serif); font-style:italic; font-weight:400; }
.mono{
  font-family:var(--ff-sans);
  font-size:.66rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
}

/* ─── grain ─────────────────────────────────────────── */
#grain{
  position:fixed; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:9998; opacity:.05; mix-blend-mode:overlay;
}

/* ─── cursor ────────────────────────────────────────── */
.cursor-dot,.cursor-ring{
  position:fixed; top:0; left:0; border-radius:50%;
  pointer-events:none; z-index:9999; transform:translate(-50%,-50%);
}
.cursor-dot{ width:6px; height:6px; background:var(--text); }
.cursor-ring{
  width:40px; height:40px; border:1px solid rgba(243,241,236,.4);
  transition:width .25s, height .25s, background .25s, border-color .25s;
}
.cursor-ring.grow{ width:74px; height:74px; background:rgba(255,93,59,.12); border-color:var(--accent); }
@media (hover:none){ body{cursor:auto;} .cursor-dot,.cursor-ring{display:none;} }

/* ─── preloader ─────────────────────────────────────── */
#loader{
  position:fixed; inset:0; z-index:10000; background:var(--bg);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.4rem;
}
.loader-logo{ width:clamp(160px,26vw,260px); height:auto; opacity:0; }
.loader-bar{ width:min(260px,60vw); height:1px; background:var(--faint); overflow:hidden; }
.loader-bar i{ display:block; height:100%; width:0; background:var(--text); }
.loader-pct{ font-family:var(--ff-sans); font-size:.7rem; letter-spacing:.2em; color:var(--muted); }

/* ─── nav ───────────────────────────────────────────── */
#nav{
  position:fixed; top:0; left:0; right:0; z-index:900;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.5rem clamp(1.2rem,4vw,3rem);
  mix-blend-mode:difference;
}
.brand{ font-family:var(--ff-serif); font-size:1.5rem; letter-spacing:.01em; display:flex; align-items:center; }
.brand sup{ font-size:.5em; font-family:var(--ff-sans); }
.brand-logo{ height:30px; width:auto; display:block; }
.view-toggle{ display:flex; align-items:center; gap:.5rem; }
.vt{
  background:none; border:none; cursor:none; color:var(--muted);
  font-family:var(--ff-sans); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  transition:color .3s;
}
.vt.active{ color:var(--text); }
.vt-sep{ color:var(--faint); }
.menu-btn{
  background:none; border:1px solid var(--line); color:var(--text); cursor:none;
  font-family:var(--ff-sans); font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  padding:.55rem 1rem; border-radius:40px; display:flex; gap:.5rem; align-items:center;
  transition:background .3s,color .3s;
}
.menu-btn span{ transition:transform .3s; }
.menu-btn:hover{ background:var(--text); color:var(--bg); }
.menu-btn:hover span{ transform:rotate(90deg); }

/* ─── menu overlay ──────────────────────────────────── */
.menu-overlay{
  position:fixed; inset:0; z-index:899; background:var(--bg-2);
  display:flex; flex-direction:column; justify-content:center;
  padding:0 clamp(1.5rem,8vw,8rem);
  clip-path:inset(0 0 100% 0); transition:clip-path .8s cubic-bezier(.76,0,.24,1);
}
.menu-overlay.open{ clip-path:inset(0 0 0 0); }
.menu-link{
  font-family:var(--ff-serif); font-size:clamp(2.4rem,9vw,6.5rem); line-height:1.05;
  display:flex; align-items:baseline; gap:1.2rem; color:var(--muted);
  transition:color .4s, padding-left .4s;
}
.menu-link .mono{ font-size:.7rem; }
.menu-link:hover{ color:var(--text); padding-left:1.5rem; }
.menu-foot{ position:absolute; bottom:2.2rem; left:0; right:0; display:flex; justify-content:space-between; padding:0 clamp(1.5rem,8vw,8rem); }

/* ═══ ORBIT SECTION ═════════════════════════════════════ */
.orbit-section{ height:620vh; position:relative; }
.orbit-stage{
  position:sticky; top:0; height:100vh; width:100%;
  overflow:hidden; display:flex; align-items:center; justify-content:center;
}

/* glowing sphere */
.sphere{
  position:absolute; top:8%; left:6%; width:clamp(120px,16vw,260px); aspect-ratio:1; border-radius:50%;
  background:
    radial-gradient(circle at 32% 28%, #fff 0%, #c9c4ff 14%, #6a5cff 42%, #1b1640 78%, #060611 100%);
  box-shadow:0 0 80px 10px rgba(106,92,255,.35), inset -10px -14px 40px rgba(0,0,0,.6);
  filter:saturate(1.05);
  z-index:1;
}

/* line-portrait ghosted behind the name (driven by JS in the orbit module) */
.hero-portrait{
  position:absolute; left:50%; top:40%; transform:translate(-50%,-50%);
  width:clamp(280px, 50vh, 600px); height:auto; aspect-ratio:1; object-fit:contain;
  z-index:1; opacity:0; pointer-events:none; will-change:opacity,transform;
  /* soften the edges so it dissolves into the dark instead of ending in a box */
  -webkit-mask-image:radial-gradient(ellipse 58% 66% at 50% 44%, #000 50%, transparent 78%);
          mask-image:radial-gradient(ellipse 58% 66% at 50% 44%, #000 50%, transparent 78%);
}
@media(max-width:560px){ .hero-portrait{ width:clamp(220px,72vw,360px); top:38%; } }

/* ═══ SOLAR-SYSTEM BACKDROP ════════════════════════════ */
.cosmos{ position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.star-field{
  position:absolute; inset:-10%; opacity:.55;
  background-image:
    radial-gradient(1.4px 1.4px at 12% 18%, #fff, transparent),
    radial-gradient(1px 1px at 28% 72%, rgba(255,255,255,.8), transparent),
    radial-gradient(1.6px 1.6px at 47% 33%, #fff, transparent),
    radial-gradient(1px 1px at 63% 81%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.3px 1.3px at 78% 22%, #fff, transparent),
    radial-gradient(1px 1px at 88% 64%, rgba(255,255,255,.75), transparent),
    radial-gradient(1px 1px at 36% 48%, rgba(255,255,255,.6), transparent),
    radial-gradient(1.5px 1.5px at 7% 88%, #fff, transparent),
    radial-gradient(1px 1px at 95% 40%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.2px 1.2px at 55% 12%, #fff, transparent);
  background-size:340px 340px; background-repeat:repeat;
  animation:twinkle 6s ease-in-out infinite alternate, drift-slow 120s linear infinite;
}
@keyframes twinkle{ 0%{opacity:.35;} 100%{opacity:.7;} }
@keyframes drift-slow{ from{transform:translateY(0);} to{transform:translateY(-40px);} }

.planet{ position:absolute; border-radius:50%; will-change:transform; }
.planet-saturn{
  top:64%; right:9%; width:clamp(70px,9vw,128px); aspect-ratio:1;
  background:radial-gradient(circle at 34% 30%, #ffe7c2 0%, #e8b878 36%, #b87b3e 72%, #4a2c16 100%);
  box-shadow:inset -6px -8px 22px rgba(0,0,0,.5), 0 0 40px rgba(224,170,110,.18);
  animation:float-a 17s ease-in-out infinite;
}
.planet-saturn::before{
  content:""; position:absolute; left:50%; top:50%; width:215%; height:64%;
  transform:translate(-50%,-50%) rotate(-24deg); border-radius:50%;
  border:5px solid rgba(232,205,160,.55); border-top-color:transparent; border-left-color:rgba(232,205,160,.2);
  box-sizing:border-box; box-shadow:0 0 12px rgba(232,205,160,.12);
}
.planet-earth{
  top:19%; right:13%; width:clamp(42px,5.5vw,78px); aspect-ratio:1;
  background:radial-gradient(circle at 32% 28%, #bfe9ff 0%, #4aa3e0 30%, #2e7d57 52%, #1f5fa8 74%, #0a1f3a 100%);
  box-shadow:inset -4px -5px 16px rgba(0,0,0,.55), 0 0 30px rgba(74,163,224,.25);
  animation:float-b 21s ease-in-out infinite;
}
.planet-mars{
  top:73%; left:11%; width:clamp(28px,3.6vw,52px); aspect-ratio:1;
  background:radial-gradient(circle at 34% 30%, #ffb38a 0%, #d3683b 44%, #7e3318 100%);
  box-shadow:inset -3px -4px 12px rgba(0,0,0,.5), 0 0 22px rgba(211,104,59,.2);
  animation:float-a 14s ease-in-out infinite reverse;
}
.planet-moon{
  top:40%; left:8%; width:clamp(16px,2.2vw,30px); aspect-ratio:1;
  background:radial-gradient(circle at 36% 32%, #f2f0ea 0%, #b9b4ab 50%, #6b675f 100%);
  box-shadow:inset -2px -3px 8px rgba(0,0,0,.5);
  animation:float-b 12s ease-in-out infinite;
}
.planet-dwarf{
  top:12%; left:40%; width:clamp(10px,1.4vw,18px); aspect-ratio:1;
  background:radial-gradient(circle at 36% 32%, #d9c7ff 0%, #8b7bd6 60%, #2e2552 100%);
  box-shadow:0 0 16px rgba(139,123,214,.3);
  animation:float-a 19s ease-in-out infinite;
}
@keyframes float-a{ 0%,100%{transform:translate(0,0);} 50%{transform:translate(-14px,-22px);} }
@keyframes float-b{ 0%,100%{transform:translate(0,0);} 50%{transform:translate(16px,-18px);} }
@media(max-width:720px){
  /* tame the cosmos on small screens so it never crowds the nav or skip button */
  .planet-dwarf{ display:none; }
  .planet-earth{ width:44px; opacity:.4; top:23%; right:5%; }
  .planet-mars{ opacity:.5; }
  .planet-saturn{ width:82px; opacity:.78; right:5%; }
  .sphere{ width:96px; opacity:.62; box-shadow:0 0 38px 4px rgba(106,92,255,.18), inset -6px -8px 24px rgba(0,0,0,.6); }
}

/* intro text */
.orbit-intro{
  position:absolute; top:clamp(8%,11vh,13%); left:0; right:0; z-index:6; text-align:center; pointer-events:none;
  display:flex; flex-direction:column; align-items:center; gap:.55rem; padding:0 1rem;
  mix-blend-mode:exclusion; transform-origin:50% 50%; will-change:transform,opacity;
}
.intro-tag{ opacity:0; }
.intro-name{
  font-family:var(--ff-serif); font-size:clamp(2.6rem,7.5vw,6rem); line-height:.9; font-weight:400;
  position:relative; text-shadow:0 0 42px rgba(150,160,255,.18);
}
/* cinematic focus-in reveal — each letter resolves out of a soft blur */
.intro-name .ch{ display:inline-block; will-change:transform,filter,opacity; }
.intro-sub{ font-size:clamp(.85rem,1.5vw,1.1rem); color:var(--text); line-height:1.4; max-width:34ch; opacity:.9; }

/* the orbit */
/* fixed overlay so cards can cross the hero edge and land in the Works grid */
.orbit-wrap{
  position:fixed; inset:0; z-index:40; pointer-events:none;
  perspective:1400px; perspective-origin:50% 46%;
}
.orbit{
  position:absolute; top:0; left:0; width:0; height:0;
  transform-style:preserve-3d;
}
.ocard{
  position:absolute; top:0; left:0; pointer-events:auto;
  width:clamp(150px,16vw,290px); aspect-ratio:3 / 4; height:auto;
  margin:0; transform-style:preserve-3d; will-change:transform;
}
.ocard-inner{
  position:absolute; inset:0; transform-style:preserve-3d;
  transition:transform .85s cubic-bezier(.76,0,.24,1);
}
.ocard:hover .ocard-inner{ transform:rotateY(180deg); }
/* once the cards have landed in the Works grid, no hover-flip */
.orbit.landed .ocard:hover .ocard-inner{ transform:none; }
.orbit.landed .ocard{ cursor:pointer; }
.ocard-face{
  position:absolute; inset:0; border-radius:14px; overflow:hidden;
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  border:1px solid rgba(255,255,255,.09);
  box-shadow:0 30px 80px rgba(0,0,0,.6);
  background:var(--bg-2);
}
.ocard-art{
  position:absolute; inset:0; background-color:#0a0a0c;
  background-image:var(--img); background-size:cover; background-position:center;
}
/* duotone tint so placeholder photos read as a cohesive, art-directed set */
.ocard-art::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(155deg, var(--c1), var(--c2));
  mix-blend-mode:color; opacity:.5;
}
.ocard-art::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(150deg, transparent 35%, rgba(0,0,0,.35));
}
.ocard-meta{
  position:absolute; left:0; right:0; bottom:0; z-index:2;
  padding:1rem 1.1rem; display:flex; flex-direction:column; gap:.1rem;
  background:linear-gradient(to top, rgba(0,0,0,.72), transparent);
}
.ocard-meta .mono{ color:rgba(255,255,255,.72); margin-bottom:.3rem; font-size:.7rem; }
.ocard-meta h3{ font-family:var(--ff-serif); font-size:1.85rem; font-weight:400; line-height:1; }
.ocard-meta p{ font-size:.92rem; color:rgba(255,255,255,.8); letter-spacing:.03em; }

/* back of card — Roshan's profile */
.ocard-back{
  transform:rotateY(180deg);
  display:flex; flex-direction:column; justify-content:space-between;
  padding:1.4rem 1.3rem;
  background:linear-gradient(155deg, color-mix(in srgb, var(--c1) 30%, #0b0b10), #07070c 75%);
}
.ocard-back .mono{ color:rgba(255,255,255,.55); }
.back-id{ margin-top:auto; }
.back-label{ display:block; color:rgba(255,255,255,.55); margin-bottom:.55rem; font-size:.72rem; }
.back-id h3{ font-family:var(--ff-serif); font-size:clamp(1.55rem,2.1vw,2.25rem); font-weight:400; line-height:1.04; word-break:break-word; }
.back-foot{ margin-top:1rem; color:var(--c2); font-size:.72rem; }

/* work-grid title (fades in as cards land in the grid) */
.orbit-worktitle{
  position:absolute; top:clamp(7%,9vh,11%); left:0; right:0; z-index:5;
  text-align:center; pointer-events:none; opacity:0;
}
.orbit-worktitle .mono{ display:block; margin-bottom:.4rem; }
.orbit-worktitle h2{ font-family:var(--ff-serif); font-size:clamp(2rem,5vw,3.6rem); font-weight:400; }

/* hints */
.orbit-hint{ position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); z-index:3; display:flex; flex-direction:column; align-items:center; gap:.6rem; }
.hint-line{ width:1px; height:40px; background:var(--faint); overflow:hidden; }
.hint-line i{ display:block; width:100%; height:40%; background:var(--text); animation:hint 1.8s infinite; }
@keyframes hint{ 0%{transform:translateY(-120%);} 100%{transform:translateY(260%);} }
.orbit-year{ position:absolute; bottom:2rem; left:clamp(1.2rem,4vw,3rem); z-index:3; }

/* ═══ LIST VIEW ═════════════════════════════════════════ */
.list-view{ display:none; padding:8rem clamp(1.2rem,5vw,5rem) 5rem; }
body.list-mode .orbit-section,
body.list-mode #work,
body.list-mode .orbit-wrap{ display:none; }
body.list-mode .list-view{ display:block; }

/* ═══ MY WORKS (cards land here) ═══════════════════════ */
/* pulled up to overlap the end of the hero, so the descending cards
   land onto these slots on-screen as the hero fades away */
/* tall section + sticky pin = the grid holds in place (a dwell) after the
   cards land, so you can look and click before the page scrolls on */
.work{ position:relative; z-index:1; margin-top:-100vh; height:172vh; }
.work-pin{
  position:sticky; top:0; height:100vh;
  display:flex; flex-direction:column; justify-content:center; align-items:center;
  padding:3rem clamp(1rem,3vw,3rem);
}
.work-head{ text-align:center; margin-bottom:clamp(1.5rem,4vh,3rem); }
.work-head .mono{ display:block; margin-bottom:.6rem; }
.work-head h2{ font-family:var(--ff-serif); font-size:clamp(2.4rem,6vw,5rem); font-weight:400; }
.work-grid{ display:flex; flex-wrap:wrap; justify-content:center; gap:clamp(1rem,2vw,2rem); }
.work-slot{
  width:clamp(210px,20vw,360px); aspect-ratio:3 / 4;
  border-radius:14px;   /* invisible position anchor — the cards land on top */
}
.list-head{ display:flex; justify-content:space-between; align-items:flex-end; border-bottom:1px solid var(--line); padding-bottom:1.5rem; margin-bottom:1rem; }
.sec-title{ font-family:var(--ff-serif); font-size:clamp(2.2rem,6vw,4.5rem); font-weight:400; }
.proj-list{ list-style:none; }
.proj-row{
  display:grid; grid-template-columns:48px 1fr auto 80px 40px; align-items:center; gap:1.5rem;
  padding:1.6rem 0; border-bottom:1px solid var(--line); position:relative; cursor:none;
  transition:padding-left .4s;
}
.proj-row::before{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,var(--c1),var(--c2)); opacity:0; transition:opacity .4s; z-index:-1; }
.proj-row:hover{ padding-left:1.5rem; }
.proj-row h3{ font-family:var(--ff-serif); font-size:clamp(1.4rem,3.5vw,2.6rem); font-weight:400; }
.pr-cat{ color:var(--muted); font-size:.82rem; }
.pr-go{ font-size:1.2rem; opacity:.4; transition:opacity .3s,transform .3s; }
.proj-row:hover .pr-go{ opacity:1; transform:translate(4px,-4px); }

/* ═══ MARQUEE ═══════════════════════════════════════════ */
.marquee{ overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:1.4rem 0; }
.marquee-track{ display:flex; gap:2.2rem; white-space:nowrap; width:max-content; will-change:transform; }
.marquee-track span{ font-family:var(--ff-serif); font-size:clamp(1.8rem,4vw,3rem); }
.marquee-track b{ color:var(--accent); font-size:1.4rem; align-self:center; }

/* ═══ ABOUT ═════════════════════════════════════════════ */
.sec-no{ display:block; padding:0 clamp(1.2rem,5vw,5rem); }
.about{ padding:7rem 0 5rem; }
.about-grid{ padding:2rem clamp(1.2rem,5vw,5rem) 0; display:grid; grid-template-columns:1.4fr 1fr; gap:4rem; }
.about-lead{ font-family:var(--ff-serif); font-size:clamp(1.6rem,3.6vw,3rem); line-height:1.2; font-weight:400; }
.about-lead .hl{ color:var(--accent); }
.about-side p{ color:var(--muted); font-size:1rem; line-height:1.7; margin-bottom:2.5rem; }
.about-stats{ display:flex; gap:2.5rem; }
.astat{ display:flex; flex-direction:column; gap:.3rem; }
.astat-n{ font-family:var(--ff-serif); font-size:clamp(2rem,4vw,3.2rem); }
@media(max-width:820px){ .about-grid{ grid-template-columns:1fr; gap:2.5rem; } }

/* ═══ SERVICES ══════════════════════════════════════════ */
.services{ padding:5rem 0; }
.svc-list{ list-style:none; padding:2rem clamp(1.2rem,5vw,5rem) 0; }
.svc{ border-top:1px solid var(--line); }
.svc:last-child{ border-bottom:1px solid var(--line); }
.svc-head{
  width:100%; background:none; border:none; cursor:none; color:var(--text);
  display:grid; grid-template-columns:48px 1fr 40px; align-items:center; gap:1.5rem;
  padding:1.8rem 0; text-align:left;
}
.svc-head h3{ font-family:var(--ff-serif); font-size:clamp(1.6rem,4vw,3rem); font-weight:400; transition:color .3s; }
.svc-plus{ font-size:1.6rem; color:var(--muted); transition:transform .4s,color .3s; justify-self:end; }
.svc.open .svc-plus{ transform:rotate(135deg); color:var(--accent); }
.svc.open .svc-head h3{ color:var(--accent); }
.svc-body{ height:0; overflow:hidden; transition:height .5s cubic-bezier(.76,0,.24,1); }
.svc-inner{ padding:0 0 2rem 0; display:grid; grid-template-columns:48px 1fr; gap:1.5rem; }
.svc-inner p{ grid-column:2; color:var(--muted); max-width:55ch; line-height:1.6; }
.svc-tags{ grid-column:2; display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1rem; }
.svc-tags span{ font-size:.7rem; letter-spacing:.06em; border:1px solid var(--line); border-radius:30px; padding:.35rem .9rem; color:var(--muted); }

/* ═══ CONTACT ═══════════════════════════════════════════ */
.contact{ padding:8rem 0 6rem; text-align:center; }
.contact-big{ font-family:var(--ff-serif); font-size:clamp(2.6rem,9vw,8rem); line-height:.98; font-weight:400; margin:1.5rem 0 3rem; }
.contact-big .cl{ display:block; overflow:hidden; }
.contact-mail{
  display:inline-flex; gap:.6rem; font-family:var(--ff-serif); font-size:clamp(1.4rem,4vw,2.6rem);
  border-bottom:1px solid var(--line); padding-bottom:.3rem; transition:border-color .3s, color .3s;
}
.contact-mail:hover{ color:var(--accent); border-color:var(--accent); }
.contact-mailwrap{ display:flex; flex-direction:column; align-items:flex-start; gap:1.2rem; }
.contact-wa{ display:inline-flex; align-items:center; gap:.6rem; font-size:clamp(1.05rem,2.4vw,1.45rem); color:var(--muted); transition:color .3s; }
.contact-wa svg{ width:1.05em; height:1.05em; flex:none; color:#25d366; }
.contact-wa:hover{ color:var(--text); }
.home-wa{ margin-top:1.4rem; }   /* WhatsApp under the email in the homepage contact section (centered) */
.contact-socials{ display:flex; gap:1.6rem; justify-content:center; flex-wrap:wrap; margin-top:3.5rem; }
.contact-socials a{ font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); transition:color .3s; }
.contact-socials a:hover{ color:var(--text); }

/* ═══ FOOTER ════════════════════════════════════════════ */
.footer{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; padding:2rem clamp(1.2rem,5vw,5rem); border-top:1px solid var(--line); }
.to-top{ background:none; border:none; color:var(--muted); cursor:none; transition:color .3s; }
.to-top:hover{ color:var(--text); }

/* ═══ WORKS "SHOW MORE" BUTTON ═════════════════════════ */
.work-more{ margin-top:clamp(2rem,5vh,3.5rem); display:flex; justify-content:center; }
.work-more a{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--ff-sans); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--text); border:1px solid var(--line); border-radius:40px; padding:.9rem 1.8rem;
  cursor:none; transition:background .35s, color .35s, gap .35s;
}
.work-more a span{ transition:transform .35s; }
.work-more a:hover{ background:var(--text); color:var(--bg); gap:1.1rem; }

/* ═══ SUB-PAGES (works.html / project.html) ════════════ */
body.subpage{ background:var(--bg); }
.subpage #nav{ position:fixed; }

/* — All Works page — */
.works-head{ padding:9rem clamp(1.2rem,5vw,5rem) 3rem; max-width:1100px; }
.works-head .mono{ display:block; margin-bottom:1rem; }
.works-head h1{ font-family:var(--ff-serif); font-size:clamp(3rem,9vw,7rem); font-weight:400; line-height:.95; }
.works-head p{ color:var(--muted); max-width:46ch; margin-top:1.4rem; font-size:1.05rem; line-height:1.6; }
.works-page-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,2vw,1.8rem);
  padding:2rem clamp(1.2rem,5vw,5rem) 6rem;
}
.wcard{ display:block; position:relative; border-radius:16px; overflow:hidden; aspect-ratio:4/5; cursor:none;
  border:1px solid var(--line); transition:transform .5s cubic-bezier(.22,1,.36,1); }
.wcard:hover{ transform:translateY(-8px); }
.wcard-art{ position:absolute; inset:0; background-color:#0a0a0c; background-image:var(--img); background-size:cover; background-position:center; transition:transform .8s cubic-bezier(.22,1,.36,1); }
.wcard:hover .wcard-art{ transform:scale(1.06); }
.wcard-art::before{ content:""; position:absolute; inset:0; background:linear-gradient(155deg,var(--c1),var(--c2)); mix-blend-mode:color; opacity:.5; }
.wcard-art::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.78), transparent 55%); }
.wcard-meta{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.3rem 1.4rem; }
.wcard-meta .mono{ color:rgba(255,255,255,.72); }
.wcard-meta h3{ font-family:var(--ff-serif); font-size:1.9rem; font-weight:400; line-height:1; margin-top:.3rem; }
.wcard-meta p{ font-size:.82rem; color:rgba(255,255,255,.8); margin-top:.15rem; }
@media(max-width:900px){ .works-page-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){ .works-page-grid{ grid-template-columns:1fr; } }

/* — Project detail page — */
.project{ padding-bottom:2rem; }
.proj-hero{ padding:9rem clamp(1.2rem,5vw,5rem) 2.5rem; max-width:1100px; }
.proj-back{ display:inline-block; margin-bottom:2.5rem; color:var(--muted); transition:color .3s; }
.proj-back:hover{ color:var(--text); }
.proj-eyebrow{ display:block; color:var(--c1); margin-bottom:1rem; }
.proj-title{ font-family:var(--ff-serif); font-size:clamp(3rem,10vw,8rem); font-weight:400; line-height:.92; }
.proj-summary{ font-family:var(--ff-serif); font-size:clamp(1.4rem,2.6vw,2.2rem); line-height:1.3; color:var(--text); max-width:24ch; margin-top:1.5rem; }
.proj-meta{ display:flex; flex-wrap:wrap; gap:3rem; margin-top:3rem; border-top:1px solid var(--line); padding-top:2rem; }
.proj-meta .mono{ display:block; margin-bottom:.4rem; }
.proj-meta p{ font-size:1.05rem; }
.proj-cover{ margin:0 clamp(1.2rem,5vw,5rem); border-radius:18px; overflow:hidden; position:relative; aspect-ratio:16/10; }
.proj-cover img{ width:100%; height:100%; object-fit:cover; display:block; }
.proj-cover::after{ content:""; position:absolute; inset:0; background:linear-gradient(155deg,var(--c1),var(--c2)); mix-blend-mode:color; opacity:.32; }
/* ordered content blocks — text, headings & images interleaved */
/* content spans the same width as the cover; only text stays narrow & readable */
.proj-content{ margin:4.5rem clamp(1.2rem,5vw,5rem); display:flex; flex-direction:column; gap:1.8rem; align-items:stretch; }
.proj-content > p{ font-size:clamp(1.1rem,1.8vw,1.4rem); line-height:1.7; color:#cfccc4; max-width:720px; }
.proj-content > .proj-quote{ align-self:flex-start; }
.proj-h2{ font-family:var(--ff-serif); font-size:clamp(1.9rem,4.4vw,3.2rem); font-weight:400; line-height:1.05; margin:1.4rem 0 .2rem; }
.proj-shot{ margin:.8rem 0; border-radius:14px; overflow:hidden; }
.proj-shot img{ width:100%; height:auto; display:block; }
.proj-shot.wide{ width:100vw; max-width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); border-radius:0; }
.proj-shot figcaption{ font-family:var(--ff-sans); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-top:.7rem; }
/* two-up image row */
.proj-pair{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(.7rem,1.4vw,1.3rem); margin:.8rem 0; }
.proj-pair figure{ margin:0; border-radius:14px; overflow:hidden; aspect-ratio:4/5; }
.proj-pair img{ width:100%; height:100%; object-fit:cover; display:block; }
@media(max-width:640px){ .proj-pair{ grid-template-columns:1fr; } }
/* pull-quote */
.proj-quote{ font-family:var(--ff-serif); font-size:clamp(1.6rem,3.2vw,2.6rem); line-height:1.25; font-style:italic; color:var(--text); max-width:760px; margin:1.6rem 0; padding-left:1.4rem; border-left:2px solid var(--accent); }
.proj-next{ display:block; margin:4rem clamp(1.2rem,5vw,5rem) 3rem; padding:3rem 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); text-align:center; transition:padding .4s; }
.proj-next .mono{ color:var(--muted); }
.proj-next h2{ font-family:var(--ff-serif); font-size:clamp(2.4rem,7vw,5.5rem); font-weight:400; margin-top:.6rem; transition:color .35s; }
.proj-next:hover h2{ color:var(--c1); }
.proj-next:hover h2 span{ display:inline-block; transform:translateX(12px); transition:transform .35s; }
.proj-cover.full{ margin-left:0; margin-right:0; border-radius:0; aspect-ratio:16/8; }

/* — About page — */
.about-hero{ padding:9rem clamp(1.2rem,5vw,5rem) 2rem; max-width:1000px; }
.about-hero .mono{ display:block; margin-bottom:1.2rem; }
.about-hero h1{ font-family:var(--ff-serif); font-size:clamp(2.6rem,8vw,6rem); font-weight:400; line-height:1; }
.about-loc{ color:var(--muted); margin-top:1.6rem; font-size:1.05rem; line-height:1.7; }
.about-intro{ max-width:780px; padding:3rem clamp(1.2rem,5vw,5rem); display:flex; flex-direction:column; gap:1.4rem; }
.about-intro p{ font-size:clamp(1.15rem,2vw,1.5rem); line-height:1.65; color:#cfccc4; }
.about-statbar{ display:flex; gap:clamp(2rem,6vw,5rem); flex-wrap:wrap; padding:1rem clamp(1.2rem,5vw,5rem) 4rem; border-bottom:1px solid var(--line); }
.about-statbar .astat{ display:flex; flex-direction:column; gap:.3rem; }
.about-statbar .astat-n{ font-family:var(--ff-serif); font-size:clamp(2.6rem,6vw,4.5rem); line-height:1; }
.about-exp{ padding:4rem clamp(1.2rem,5vw,5rem) 2rem; }
.exp-head{ margin-bottom:2rem; }
.exp-head .mono{ display:block; margin-bottom:.5rem; }
.exp-head h2{ font-family:var(--ff-serif); font-size:clamp(2rem,5vw,3.6rem); font-weight:400; }
.exp-list{ list-style:none; }
.exp{ display:grid; grid-template-columns:190px 1fr 180px; gap:1.5rem; align-items:baseline; padding:1.6rem 0; border-top:1px solid var(--line); }
.exp:last-child{ border-bottom:1px solid var(--line); }
.exp-when{ color:var(--muted); }
.exp-main h3{ font-family:var(--ff-serif); font-size:clamp(1.4rem,3vw,2.1rem); font-weight:400; }
.exp-co{ color:var(--muted); margin-top:.2rem; }
.exp-loc{ color:var(--muted); text-align:right; }
@media(max-width:760px){ .exp{ grid-template-columns:1fr; gap:.35rem; } .exp-loc{ text-align:left; } }

/* — Contact page — */
.contact-hero{ padding:9rem clamp(1.2rem,5vw,5rem) 2rem; max-width:1000px; }
.contact-hero .mono{ display:block; margin-bottom:1.2rem; }
.contact-hero h1{ font-family:var(--ff-serif); font-size:clamp(2.8rem,9vw,7rem); font-weight:400; line-height:.98; }
.contact-blurb{ color:var(--muted); max-width:46ch; margin-top:1.6rem; font-size:1.1rem; line-height:1.6; }
.contact-block{ display:flex; flex-wrap:wrap; align-items:baseline; gap:1rem 3rem; padding:2.2rem clamp(1.2rem,5vw,5rem); border-top:1px solid var(--line); }
.contact-block > .mono{ flex:none; width:120px; color:var(--muted); }
.contact-page .contact-mail{ display:inline-flex; gap:.6rem; font-family:var(--ff-serif); font-size:clamp(1.6rem,5vw,3.2rem); border-bottom:1px solid var(--line); padding-bottom:.2rem; transition:color .3s,border-color .3s; }
.contact-page .contact-mail:hover{ color:var(--accent); border-color:var(--accent); }
.contact-loc{ font-family:var(--ff-serif); font-size:clamp(1.4rem,3.5vw,2.4rem); }

/* About "Read more" / CV buttons on the home page */
.about-more{ grid-column:1 / -1; margin-top:1rem; display:flex; gap:.8rem; flex-wrap:wrap; }
.about-more a{ display:inline-flex; align-items:center; gap:.6rem; font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text); border:1px solid var(--line); border-radius:40px; padding:.85rem 1.7rem; cursor:none; transition:background .35s,color .35s,gap .35s; }
.about-more a span{ transition:transform .35s; }
.about-more a:hover{ background:var(--text); color:var(--bg); gap:1rem; }
.about-more-link[hidden]{ display:none; }

/* Clients / "worked with" logo strip */
.clients-sec{ padding:clamp(3rem,7vh,5rem) clamp(1.2rem,5vw,5rem); text-align:center; border-top:1px solid var(--line); }
.clients-title{ display:block; color:var(--muted); margin-bottom:clamp(1.6rem,4vh,2.6rem); }
.clients-row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(1.4rem,5vw,4rem); }
.client{ color:var(--muted); display:inline-flex; align-items:center; transition:color .3s; }
.client span{ font-family:var(--ff-serif); font-size:clamp(1.25rem,2.4vw,2rem); line-height:1; white-space:nowrap; }
.client img{ height:clamp(26px,4vw,42px); width:auto; opacity:.55; filter:grayscale(1) brightness(1.7); transition:opacity .35s, filter .35s; }
a.client{ cursor:none; }
a.client:hover{ color:var(--text); }
a.client:hover img{ opacity:1; filter:none; }

/* live preview (dashboard) — inline click-to-edit */
body.is-preview{ cursor:auto; }
body.is-preview .cursor-dot, body.is-preview .cursor-ring, body.is-preview #grain{ display:none; }
.is-preview [contenteditable]{ cursor:text; border-radius:6px; transition:box-shadow .2s, background .2s; }
.is-preview [contenteditable]:hover{ box-shadow:0 0 0 1px rgba(255,255,255,.28); }
.is-preview [contenteditable]:focus{ outline:none; box-shadow:0 0 0 2px var(--accent); background:rgba(255,93,59,.06); }
.is-preview [contenteditable]:empty:before{ content:'Type here…'; color:rgba(255,255,255,.3); }
/* visual block builder (preview) */
.is-preview .pv-block{ position:relative; transition:outline .15s; }
.is-preview .pv-block:hover{ outline:1px dashed rgba(255,255,255,.28); outline-offset:10px; border-radius:4px; }
.is-preview .pv-block.drag-over{ outline:2px solid var(--accent); outline-offset:10px; }
.is-preview .pv-tools{ position:absolute; top:-14px; right:0; display:flex; gap:.35rem; opacity:0; transition:opacity .15s; z-index:6; }
.is-preview .pv-block:hover .pv-tools{ opacity:1; }
.is-preview .pv-tools > *{ width:28px; height:28px; display:flex; align-items:center; justify-content:center; background:#16161b; border:1px solid rgba(255,255,255,.18); color:#fff; border-radius:7px; font-size:15px; cursor:pointer; }
.is-preview .pv-grip{ cursor:grab; } .is-preview .pv-grip:active{ cursor:grabbing; }
.is-preview .pv-del:hover{ color:#ff6b6b; border-color:#ff6b6b; }
.is-preview .pv-empty{ padding:1.6rem; border:1px dashed rgba(255,255,255,.22); border-radius:12px; color:var(--muted); text-align:center; font-size:.9rem; }
/* click-to-upload placeholder + replace-on-click for existing images */
.is-preview .pv-upload{ display:block; width:100%; font:inherit; font-size:.9rem; cursor:pointer; padding:2.4rem 1.6rem; background:rgba(255,255,255,.02); border:1.5px dashed rgba(255,255,255,.25); border-radius:12px; color:var(--muted); transition:.2s; }
.is-preview .pv-upload:hover{ color:var(--text); border-color:var(--accent); background:rgba(255,93,59,.07); }
.is-preview .proj-shot[data-upload]{ position:relative; cursor:pointer; }
.is-preview .pv-replace{ position:absolute; top:.7rem; right:.7rem; background:rgba(0,0,0,.72); color:#fff; font-size:.58rem; letter-spacing:.14em; text-transform:uppercase; padding:.4rem .7rem; border-radius:30px; opacity:0; transition:opacity .2s; pointer-events:none; z-index:4; }
.is-preview .proj-shot[data-upload]:hover .pv-replace{ opacity:1; }
.is-preview .proj-shot[data-upload]:hover img{ filter:brightness(.78); transition:filter .2s; }
.is-preview .pv-add{ display:flex; gap:.5rem; align-items:center; justify-content:center; flex-wrap:wrap; margin-top:2.5rem; padding-top:1.6rem; border-top:1px solid var(--line); }
.is-preview .pv-add-label{ color:var(--muted); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; margin-right:.3rem; }
.is-preview .pv-add button{ background:none; border:1px dashed rgba(255,255,255,.25); color:var(--muted); border-radius:9px; padding:.5rem 1rem; cursor:pointer; font:inherit; font-size:.85rem; transition:.2s; }
.is-preview .pv-add button:hover{ border-color:var(--accent); color:var(--accent); }

/* WhatsApp link in the footer (themed, not a floating button) */
.footer-wa{ display:inline-flex; align-items:center; gap:.5rem; color:var(--muted); cursor:none; transition:color .3s; font-family:var(--ff-sans); font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; }
.footer-wa svg{ width:15px; height:15px; flex:none; }
.footer-wa:hover{ color:var(--text); }
.footer-wa[hidden]{ display:none; }

/* Skip-intro button on the hero */
.skip-intro{ position:absolute; bottom:2rem; right:clamp(1.2rem,4vw,3rem); z-index:6; background:none; border:1px solid var(--line); color:var(--muted); border-radius:40px; padding:.55rem 1.1rem; cursor:none; font-family:var(--ff-sans); font-size:.62rem; letter-spacing:.2em; text-transform:uppercase; display:flex; align-items:center; gap:.5rem; transition:color .3s, border-color .3s; }
.skip-intro:hover{ color:var(--text); border-color:var(--text); }
.skip-intro span{ transition:transform .3s; }
.skip-intro:hover span{ transform:translateY(3px); }
@media(max-width:560px){
  /* prominent, bottom-centre, sitting just above "scroll to revolve" */
  .skip-intro{
    top:auto; bottom:6.75rem; right:auto; left:50%; transform:translateX(-50%);
    font-size:.7rem; padding:.72rem 1.5rem;
    color:var(--text); border-color:rgba(255,255,255,.4);
    background:rgba(10,10,13,.45); backdrop-filter:blur(6px);
  }
}

/* ═══ TESTIMONIALS (auto-hidden when empty) ════════════ */
.testi-sec{ padding:clamp(4rem,8vh,6rem) clamp(1.2rem,5vw,5rem); border-top:1px solid var(--line); }
.testi-sec .sec-no{ padding:0; margin-bottom:clamp(2rem,5vh,3rem); }
.testi-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:clamp(1.2rem,2.5vw,2rem); }
.testi{ border:1px solid var(--line); border-radius:18px; padding:clamp(1.6rem,3vw,2.4rem); background:var(--bg-2); display:flex; flex-direction:column; gap:1.4rem; }
.testi blockquote{ font-family:var(--ff-serif); font-size:clamp(1.3rem,2vw,1.7rem); line-height:1.34; }
.testi blockquote:before{ content:'“'; color:var(--accent); }
.testi-by{ margin-top:auto; display:flex; flex-direction:column; gap:.2rem; }
.testi-by .t-name{ font-weight:600; }
.testi-by .t-role{ color:var(--muted); font-size:.84rem; }

/* ═══ 404 PAGE ═════════════════════════════════════════ */
.err404{ min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:1.1rem; padding:6rem clamp(1.2rem,5vw,5rem); }
.err-planet{ width:clamp(110px,16vw,200px); aspect-ratio:1; border-radius:50%; margin-bottom:1.2rem; background:radial-gradient(circle at 34% 30%,#fff 0%,#c9c4ff 14%,#6a5cff 44%,#1b1640 80%,#060611 100%); box-shadow:0 0 80px 10px rgba(106,92,255,.35); }
.err404 .mono{ color:var(--muted); }
.err404 h1{ font-family:var(--ff-serif); font-size:clamp(3rem,12vw,7rem); font-weight:400; line-height:.9; }
.err404 p{ color:var(--muted); max-width:42ch; font-size:1.05rem; line-height:1.6; }
.err-actions{ display:flex; gap:.8rem; flex-wrap:wrap; justify-content:center; margin-top:1.2rem; }
.err-btn{ display:inline-flex; align-items:center; gap:.5rem; font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--bg); background:var(--text); border:1px solid var(--text); border-radius:40px; padding:.85rem 1.7rem; cursor:none; transition:transform .3s; }
.err-btn.ghost{ background:none; color:var(--text); border-color:var(--line); }
.err-btn:hover{ transform:translateY(-2px); }

/* ═══ REDUCED MOTION — accessible static fallback ══════ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
  .reveal-up{ opacity:1 !important; transform:none !important; }
  .marquee-track,.star-field,.planet,.hint-line i,.skip-intro,.orbit-hint{ animation:none !important; }
}
body.reduced-motion .orbit-section{ height:100vh !important; }
body.reduced-motion .orbit-stage{ opacity:1 !important; }
body.reduced-motion .orbit-wrap,
body.reduced-motion .orbit-hint,
body.reduced-motion .skip-intro{ display:none !important; }
body.reduced-motion .work{ margin-top:0 !important; height:auto !important; }
body.reduced-motion .work-pin{ position:static !important; height:auto !important; padding:5rem clamp(1rem,3vw,3rem) !important; }
.work-slot.slot-card{ position:relative; display:block; overflow:hidden; }
.work-slot.slot-card .ocard-art{ position:absolute; inset:0; }
.work-slot.slot-card .ocard-meta{ position:absolute; left:0; right:0; bottom:0; }

/* reveal — slow fade up on scroll (IntersectionObserver adds .in) */
.reveal-up{ opacity:0; transform:translateY(46px); transition:opacity 1s ease, transform 1.1s cubic-bezier(.22,1,.36,1); }
.reveal-up.in{ opacity:1; transform:none; }

/* bigger cards on mobile (sides may crop — intentional) */
@media(max-width:720px){
  .ocard{ width:clamp(150px,46vw,230px); }
  .work-slot{ width:clamp(140px,43vw,210px); }   /* 2×2 grid on mobile */
  /* avoid blend-mode / grain compositing glitches over the 3D cards */
  .orbit-intro{ mix-blend-mode:normal; }
  #grain{ display:none; }
}

@media(max-width:680px){
  .menu-foot{ flex-direction:column; gap:.4rem; }
  .proj-row{ grid-template-columns:32px 1fr 28px; }
  .pr-cat,.pr-yr{ display:none; }
  .sphere{ top:auto; bottom:15%; left:-7%; right:auto; }   /* dim accent, lower-left — clear of the menu button */
}
