/* ============================================================
   GATEWAY · roshanamarujala.com
   Modern editorial portfolio hero. A cut-out portrait presented
   as a layered 3D pop-out (colour shape behind, figure in front,
   depth shadow, cursor parallax). Warm, premium palette.
   Locked to one screen (no scroll) on desktop.
   ============================================================ */
:root{
  --bg:#f4f0e8;
  --ink:#1c1815;
  --ink-soft:#4a4138;
  --muted:#6f665a;
  --faint:#736a5d;
  --line:#ddd4c4;
  --accent:#8a1f2b;
  --accent-deep:#6e1620;
  --gold:#b08d57;
  --gold-deep:#8f7039;
  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Inter", -apple-system, "Helvetica Neue", Arial, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);
  height:100vh;display:flex;flex-direction:column;position:relative;overflow-y:auto;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.6}
@supports (height:100dvh){body{height:100dvh}}
a{color:inherit;text-decoration:none}
.skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:10px 16px;z-index:200}
.skip:focus{left:0}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}

/* background texture: warm gradient glow + faint grain */
body::before{content:"";position:fixed;inset:0;z-index:-2;background:
  radial-gradient(80% 60% at 86% -8%, rgba(176,141,87,.18), transparent 60%),
  radial-gradient(70% 60% at -12% 112%, rgba(138,31,43,.10), transparent 60%)}
body::after{content:"";position:fixed;inset:-60%;z-index:-1;opacity:.09;mix-blend-mode:multiply;pointer-events:none;
  background-size:200px 200px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 5.5s steps(7) infinite}
@keyframes grain{0%,100%{transform:translate(0,0)}14%{transform:translate(-3%,-2%)}28%{transform:translate(3%,-3%)}42%{transform:translate(-2%,3%)}57%{transform:translate(2%,2%)}71%{transform:translate(-3%,1%)}85%{transform:translate(2%,-2%)}}

/* ===== TOP BAR ===== */
.top{display:flex;align-items:center;justify-content:space-between;gap:18px;flex:none;
  max-width:1200px;width:100%;margin:0 auto;padding:16px clamp(22px,4vw,46px) 4px}
.brand{font-family:var(--serif);font-weight:700;font-size:1.5rem;letter-spacing:1.5px;color:var(--ink)}
.brand span{color:var(--accent)}
.top-meta{display:flex;align-items:center;gap:18px;font-size:.74rem;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted)}
.top-soc{display:flex;gap:12px}
.top-soc a{color:var(--muted);transition:color .2s;display:inline-flex}
.top-soc a:hover{color:var(--accent)}
.top-soc svg{width:17px;height:17px;display:block}
@media(max-width:720px){.top-meta .loc{display:none}}

/* ===== HERO ===== */
.hero{flex:1;min-height:0;display:grid;grid-template-columns:1.04fr .96fr;align-items:center;gap:clamp(26px,4.5vw,64px);
  max-width:1200px;width:100%;margin:0 auto;padding:clamp(6px,1.6vh,22px) clamp(22px,4vw,46px) clamp(8px,1.6vh,20px)}

/* --- left: text --- */
.hero-name{font-family:var(--serif);font-weight:700;line-height:.94;letter-spacing:.5px;color:var(--ink);
  font-size:clamp(2.8rem,6.4vw,5.2rem);margin:0}
.hero-tag{font-family:var(--serif);font-style:italic;color:var(--accent-deep);font-size:clamp(1.2rem,2.2vw,1.7rem);
  line-height:1.3;margin-top:10px;max-width:30rem}
.hero-desc{font-size:.98rem;color:var(--ink-soft);line-height:1.55;margin-top:11px;max-width:33rem}
.cta-prompt{display:flex;align-items:center;gap:9px;margin-top:18px;margin-bottom:0;
  font-size:.78rem;letter-spacing:1.3px;text-transform:uppercase;color:var(--muted);font-weight:600}
.cta-prompt strong{color:var(--accent);font-weight:700}
.cta-cue{font-size:1.05rem;color:var(--accent);animation:cue 1.5s ease-in-out infinite}
@keyframes cue{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}
.hero-cta{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;max-width:640px}
.btn{display:inline-flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;width:100%;
  padding:14px 16px 14px 20px;border-radius:13px;border:1.5px solid transparent;cursor:pointer;
  transition:.28s cubic-bezier(.2,.7,.2,1)}
.btn-go{display:inline-flex;align-items:center;font-size:.66rem;font-weight:700;letter-spacing:1.5px;
  text-transform:uppercase;opacity:.92;border-left:1px solid rgba(255,255,255,.25);padding-left:12px}
.btn-academic .btn-go{border-left-color:rgba(244,240,232,.22)}
.btn .arr{transition:transform .28s;font-size:1.05rem}
.btn .arr{animation:nudge 1.6s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(3px)}}
.btn:hover .arr{animation:none;transform:translateX(4px)}
.btn-go{flex:none}            /* keep "Enter →" intact; never let it overflow the button */
.btn-academic{background:var(--ink);color:#f4f0e8;border-color:var(--ink)}
.btn-academic:hover{background:#000;transform:translateY(-2px);box-shadow:0 14px 30px rgba(20,15,10,.28)}
.btn-creative{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-creative:hover{background:var(--accent-deep);transform:translateY(-2px);box-shadow:0 14px 30px rgba(138,31,43,.32)}
.btn-col{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1;gap:3px}
.btn-tag{font-size:.62rem;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;opacity:.62}
.btn-lab{font-family:var(--serif);font-size:1.3rem;font-weight:700;letter-spacing:.2px;line-height:1;white-space:nowrap}
.hero-stats{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}
.stat b{display:block;font-family:var(--serif);font-size:1.5rem;font-weight:700;color:var(--accent);line-height:1}
.stat span{font-size:.72rem;letter-spacing:.4px;color:var(--muted)}
.stat + .stat{padding-left:22px;border-left:1px solid var(--line)}

/* --- right: 3D pop-out portrait --- */
.hero-figure{position:relative;display:flex;justify-content:center;align-items:center;min-width:0;perspective:1200px}
.stage{position:relative;width:auto;height:min(60vh,440px);aspect-ratio:1/1;max-width:96%;transform-style:preserve-3d;
  transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));transition:transform .45s cubic-bezier(.2,.7,.2,1);will-change:transform}
.layer{position:absolute;inset:0;display:flex;justify-content:center;align-items:flex-end}
/* colour shape behind */
.l-shape{transform:translateZ(-45px)}
.l-shape i{display:block;width:80%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle at 36% 30%, #a8323f, var(--accent) 46%, var(--accent-deep));
  box-shadow:0 50px 100px rgba(138,31,43,.34), inset 0 2px 30px rgba(255,255,255,.12)}
/* ground shadow */
.l-ground{transform:translateZ(-40px)}
.l-ground i{width:60%;height:40px;margin-bottom:1%;border-radius:50%;background:rgba(35,14,12,.5);filter:blur(24px)}
/* the cut-out figure */
.l-photo{transform:translateZ(18px)}
.l-photo img{width:100%;height:100%;object-fit:contain;object-position:bottom;display:block;filter:drop-shadow(0 26px 32px rgba(30,12,10,.4))}
/* floating award chip */
.l-chip{transform:translateZ(58px);align-items:flex-start;justify-content:flex-end;pointer-events:none}
.l-chip .chip{background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 15px;
  box-shadow:0 18px 40px rgba(40,20,15,.2);max-width:172px;margin:6% -2% 0 0}
.chip b{display:block;font-family:var(--serif);font-size:1rem;color:var(--ink);line-height:1.12}
.chip span{font-size:.6rem;letter-spacing:.7px;text-transform:uppercase;color:var(--gold-deep);font-weight:700}

/* ===== FOOTER ===== */
.foot{max-width:1200px;width:100%;margin:0 auto;padding:8px clamp(22px,4vw,46px) 12px;flex:none;
  display:flex;flex-direction:column;align-items:center;gap:6px;font-size:.74rem;color:var(--faint);letter-spacing:.3px}
.foot-meta{font-size:.72rem;color:var(--faint);text-align:center}
.foot a{color:var(--muted)}.foot a:hover{color:var(--accent)}

/* ===== ENTRANCE ===== */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.hero-name,.hero-tag,.hero-desc,.cta-prompt,.hero-cta,.hero-stats{animation:rise .8s both}
.hero-name{animation-delay:.04s}.hero-tag{animation-delay:.14s}.hero-desc{animation-delay:.22s}
.cta-prompt{animation-delay:.28s}.hero-cta{animation-delay:.34s}.hero-stats{animation-delay:.42s}
@keyframes pop{from{opacity:0;transform:scale(.93) translateY(16px)}to{opacity:1;transform:none}}
.hero-figure{animation:pop 1s .18s both}

/* ===== RESPONSIVE ===== */
@media(max-width:860px){
  /* allow natural scrolling once the layout stacks */
  body{height:auto;min-height:100dvh;overflow:visible;overflow-x:hidden}
  .hero{grid-template-columns:1fr;gap:22px;text-align:center;padding-top:18px;padding-bottom:24px}
  .hero-tag,.hero-desc{margin-left:auto;margin-right:auto}
  .cta-prompt,.hero-stats{justify-content:center}
  .hero-cta{justify-content:center;margin-left:auto;margin-right:auto}
  .hero-stats{display:inline-flex;margin-left:auto;margin-right:auto}
  .hero-figure{order:-1}
  .stage{width:min(72%,300px);height:auto}
  .l-chip .chip{max-width:150px}
}
@media(max-width:480px){
  .hero-name{font-size:clamp(2.6rem,11vw,3.4rem)}
  .hero-cta{grid-template-columns:1fr}
  .btn-lab{font-size:1.45rem}
  .stat + .stat{padding-left:14px}
}

/* ===== REDUCED MOTION ===== */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .hero-name,.hero-tag,.hero-desc,.hero-cta,.hero-stats,.hero-figure{opacity:1;transform:none}
  .stage{transform:none!important}
}
