/* ============================================================
   FARAZ SAEIDI — PORTFOLIO
   "Living Terminal" — dark, technical, alive.
   ============================================================ */

:root{
  --bg-base:       #0D0D0F;
  --bg-surface:    #111113;
  --bg-elevated:   #161618;
  --bg-warm:       #161208;

  --accent:        #E8A020;
  --accent-dim:    #A06D10;
  --accent-glow:   rgba(232,160,32,0.20);
  --accent-soft:   rgba(232,160,32,0.08);

  --text-primary:  #F0EDE8;
  --text-body:     #C4C0BB;
  --text-muted:    #6B6966;
  --text-faint:    #45433F;

  --border:        #2A2A2E;
  --border-soft:   #1C1C1F;

  --term-green:    #4ADE80;
  --term-red:      #EF4444;
  --term-yellow:   #FBBF24;

  --font-display:  "Barlow Condensed", system-ui, sans-serif;
  --font-mono:     "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --r-sm: 4px;
  --r-md: 8px;
  --r-lg: 14px;

  --pad-section: clamp(80px, 10vw, 160px);
  --pad-x:       clamp(20px, 4vw, 56px);

  --shadow-lift: 0 24px 60px -20px rgba(0,0,0,0.7), 0 4px 16px -4px rgba(0,0,0,0.5);
  --shadow-glow: 0 0 28px var(--accent-glow);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  background:var(--bg-base);
}
body{
  font-family:var(--font-mono);
  font-size:15px;
  line-height:1.65;
  color:var(--text-body);
  background:var(--bg-base);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  cursor:none; /* custom cursor */
}
@media (pointer:coarse){
  body{cursor:auto;}
  .cursor{display:none!important;}
}

::selection{background:var(--accent);color:var(--bg-base);}

/* scrollbar */
html::-webkit-scrollbar{width:10px;}
html::-webkit-scrollbar-track{background:var(--bg-base);}
html::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,var(--accent-dim),var(--accent));
  border-radius:8px;
  border:2px solid var(--bg-base);
}
html::-webkit-scrollbar-thumb:hover{background:var(--accent);}
html{scrollbar-color:var(--accent) var(--bg-base);scrollbar-width:thin;}

h1,h2,h3,h4,h5,h6{margin:0;font-family:var(--font-display);letter-spacing:0.02em;color:var(--text-primary);font-weight:600;}
p{margin:0;}
ul{margin:0;padding:0;list-style:none;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:none;}
img,svg{display:block;max-width:100%;}

.container{
  width:100%;
  max-width:1240px;
  margin:0 auto;
  padding:0 var(--pad-x);
  position:relative;
  z-index:2;
}

/* ============================================================
   BACKGROUND STACK
   ============================================================ */
.bg-stack{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
}
.bg-canvas{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
}
.bg-canvas--rain{opacity:0.85;}
.bg-canvas--particles{opacity:0;transition:opacity 1s ease;}
.bg-canvas--particles.is-ready{opacity:1;}

.bg-grid{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  transition:opacity 1.4s ease 0.1s;
}
.bg-grid.is-ready{opacity:0.55;}

.bg-mesh{
  position:absolute;
  inset:-15%;
  filter:blur(110px);
  opacity:0.55;
}
.bg-mesh__blob{position:absolute;border-radius:50%;mix-blend-mode:screen;}
.bg-mesh__blob--a{
  width:60vw;height:60vw;
  background:radial-gradient(circle,rgba(232,160,32,0.20) 0%,rgba(232,160,32,0) 70%);
  top:-15%;left:-10%;
  animation:meshA 42s ease-in-out infinite;
}
.bg-mesh__blob--b{
  width:50vw;height:50vw;
  background:radial-gradient(circle,rgba(160,109,16,0.22) 0%,rgba(160,109,16,0) 70%);
  bottom:-15%;right:-10%;
  animation:meshB 56s ease-in-out infinite;
}
.bg-mesh__blob--c{
  width:42vw;height:42vw;
  background:radial-gradient(circle,rgba(232,160,32,0.10) 0%,rgba(232,160,32,0) 70%);
  top:35%;left:35%;
  animation:meshC 48s ease-in-out infinite;
}
@keyframes meshA{
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(8vw,4vw) scale(1.1);}
  66%{transform:translate(-4vw,10vw) scale(0.95);}
}
@keyframes meshB{
  0%,100%{transform:translate(0,0) scale(1);}
  50%{transform:translate(-10vw,-6vw) scale(1.15);}
}
@keyframes meshC{
  0%,100%{transform:translate(0,0) scale(1);}
  40%{transform:translate(6vw,-8vw) scale(0.9);}
  70%{transform:translate(-8vw,6vw) scale(1.05);}
}

.bg-scanlines{
  position:absolute;
  inset:0;
  background:repeating-linear-gradient(
    0deg,
    rgba(255,255,255,0.012) 0,
    rgba(255,255,255,0.012) 1px,
    transparent 1px,
    transparent 3px
  );
  pointer-events:none;
  mix-blend-mode:overlay;
  opacity:0.6;
}
.bg-vignette{
  position:absolute;
  inset:0;
  background:radial-gradient(ellipse at center,transparent 30%,rgba(0,0,0,0.55) 100%);
  pointer-events:none;
}

/* ============================================================
   BOOT SCREEN
   ============================================================ */
.boot{
  position:fixed;
  inset:0;
  z-index:1000;
  background:var(--bg-base);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:opacity 0.6s ease,visibility 0.6s ease;
}
.boot.is-done{opacity:0;visibility:hidden;pointer-events:none;}
.boot__inner{
  width:min(560px,90vw);
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--text-body);
}
.boot__line{margin-bottom:6px;opacity:0;animation:bootIn 0.4s ease forwards;}
.boot__line:nth-child(1){animation-delay:0.05s;}
.boot__line:nth-child(2){animation-delay:0.25s;}
.boot__line:nth-child(3){animation-delay:0.45s;}
.boot__line:nth-child(4){animation-delay:0.65s;}
.boot__line--muted{color:var(--text-muted);}
.boot__prompt{color:var(--term-green);}
.boot__cmd{color:var(--accent);}
@keyframes bootIn{from{opacity:0;transform:translateY(4px);}to{opacity:1;transform:translateY(0);}}

.boot__bar{
  margin-top:18px;
  height:6px;
  background:var(--bg-elevated);
  border-radius:6px;
  overflow:hidden;
  border:1px solid var(--border);
}
.boot__bar-fill{
  height:100%;
  width:0%;
  background:linear-gradient(90deg,var(--accent-dim),var(--accent));
  box-shadow:0 0 12px var(--accent-glow);
  transition:width 0.18s ease;
}
.boot__status{
  display:flex;
  justify-content:space-between;
  margin-top:10px;
  font-size:12px;
  color:var(--text-muted);
}
.boot__compile{color:var(--accent);}
.boot__dots::after{
  content:"";
  animation:dots 1.4s steps(4,end) infinite;
}
@keyframes dots{
  0%{content:"";}
  25%{content:".";}
  50%{content:"..";}
  75%{content:"...";}
}

/* ============================================================
   CURSOR
   ============================================================ */
.cursor{
  position:fixed;
  top:0;left:0;
  width:18px;height:18px;
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
}
.cursor__block{
  font-family:var(--font-mono);
  font-size:18px;
  color:var(--accent);
  line-height:1;
  display:block;
  animation:cursorBlink 1.1s steps(2) infinite;
}
.cursor.is-hover .cursor__block{
  color:var(--text-primary);
  animation:none;
}
@keyframes cursorBlink{
  0%,49%{opacity:1;}
  50%,100%{opacity:0.3;}
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;
  top:20px;
  left:50%;
  transform:translateX(-50%) translateY(-160%);
  z-index:100;
  background:rgba(13,13,15,0.72);
  border:1px solid var(--border);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-radius:999px;
  padding:8px 14px;
  display:flex;
  align-items:center;
  gap:18px;
  transition:transform 0.5s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 12px 40px -10px rgba(0,0,0,0.6);
}
.nav.is-visible{transform:translateX(-50%) translateY(0);}
.nav__brand{
  display:flex;align-items:center;gap:8px;
  padding-right:10px;
  border-right:1px solid var(--border);
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-primary);
}
.nav__brand-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--term-green);
  box-shadow:0 0 8px var(--term-green);
  animation:pulseDot 1.8s ease-in-out infinite;
}
.nav__brand-accent{color:var(--accent);}
.nav__list{
  position:relative;
  display:flex;
  align-items:center;
  gap:2px;
  list-style:none;
}
.nav__link{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:8px 12px;
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-muted);
  border-radius:999px;
  transition:color 0.25s ease;
}
.nav__num{font-size:10px;color:var(--text-faint);}
.nav__link:hover{color:var(--text-primary);}
.nav__link.is-active{color:var(--accent);}
.nav__link.is-active .nav__num{color:var(--accent-dim);}
.nav__underline{
  position:absolute;
  bottom:6px;
  height:2px;
  background:var(--accent);
  box-shadow:0 0 8px var(--accent-glow);
  border-radius:2px;
  pointer-events:none;
  transition:left 0.4s cubic-bezier(.2,.7,.2,1),width 0.4s cubic-bezier(.2,.7,.2,1);
}
@media (max-width:900px){
  .nav{
    top:auto;
    bottom:14px;
    padding:6px 10px;
    width:calc(100vw - 28px);
    max-width:520px;
    overflow:hidden;
  }
  .nav__list{
    overflow-x:auto;
    flex-wrap:nowrap;
    scrollbar-width:none;
  }
  .nav__list::-webkit-scrollbar{display:none;}
  .nav__brand{display:none;}
}

@keyframes pulseDot{
  0%,100%{box-shadow:0 0 8px var(--term-green);}
  50%{box-shadow:0 0 14px var(--term-green),0 0 24px rgba(74,222,128,0.5);}
}

/* ============================================================
   SECTION COMMONS
   ============================================================ */
.section{
  position:relative;
  padding:var(--pad-section) 0;
  z-index:2;
  overflow:hidden;
}
.section__head{
  display:flex;
  align-items:baseline;
  gap:14px;
  margin-bottom:48px;
  flex-wrap:wrap;
}
.section__num{
  font-family:var(--font-mono);
  font-size:14px;
  color:var(--accent);
  font-weight:500;
}
.section__title{
  font-family:var(--font-display);
  font-size:clamp(40px,5.5vw,72px);
  font-weight:700;
  line-height:0.95;
  letter-spacing:-0.01em;
  color:var(--text-primary);
  text-transform:lowercase;
}
.section__title-thin{
  color:var(--text-muted);
  font-weight:300;
  font-style:italic;
}
.section__rule{
  flex:1;
  height:1px;
  background:linear-gradient(90deg,var(--border),transparent);
  min-width:60px;
  margin-bottom:6px;
}

/* horizontal scan line on section enter */
.section::before{
  content:"";
  position:absolute;
  top:0;left:-100%;
  width:100%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:0;
  pointer-events:none;
}
.section.is-revealed::before{
  animation:scanSweep 1.2s ease-out forwards;
}
@keyframes scanSweep{
  0%{left:-100%;opacity:0.9;}
  100%{left:100%;opacity:0;}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:120px 0 80px;
  overflow:hidden;
  z-index:2;
}
.hero__meta{
  position:absolute;
  top:24px;
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-muted);
  display:flex;
  align-items:center;
  gap:8px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  opacity:0;
}
.hero__meta--tl{left:var(--pad-x);}
.hero__meta--tr{right:var(--pad-x);}
.hero__meta-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--term-green);
  box-shadow:0 0 6px var(--term-green);
  animation:pulseDot 1.8s ease-in-out infinite;
}

.hero__inner{
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.hero__tag{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-muted);
  margin-bottom:20px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  opacity:0;
}
.hero__tag-bracket{color:var(--accent);}
.hero__tag-num{color:var(--text-primary);margin:0 4px;}

.hero__name{
  font-family:var(--font-display);
  font-weight:900;
  font-size:clamp(76px,15vw,220px);
  line-height:0.84;
  letter-spacing:-0.02em;
  color:var(--text-primary);
  margin:0 0 24px;
  text-transform:uppercase;
  position:relative;
}
.hero__line{display:flex;justify-content:center;overflow:hidden;}
.hero__letter{
  display:inline-block;
  transform:translateY(120%) scaleY(1.4);
  opacity:0;
  filter:blur(8px);
}
.hero__line--bot{
  filter:drop-shadow(0 0 28px rgba(232,160,32,0.35));
}
.hero__line--bot .hero__letter{
  transform:translateY(-120%) scaleY(1.4);
  background:linear-gradient(180deg,#FFD580 0%,#F4B840 45%,#E8A020 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}

.hero__role{
  font-family:var(--font-mono);
  font-size:clamp(14px,1.4vw,18px);
  color:var(--text-body);
  margin-bottom:32px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:1.6em;
}
.hero__prompt{color:var(--term-green);}
.hero__typewriter{color:var(--text-primary);}
.hero__cursor{
  color:var(--accent);
  animation:blink 1s steps(2) infinite;
  font-family:var(--font-mono);
}
@keyframes blink{0%,49%{opacity:1;}50%,100%{opacity:0;}}

.hero__badges{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin-bottom:28px;
  opacity:0;
}
.hero__badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:7px 14px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(17,17,19,0.6);
  backdrop-filter:blur(6px);
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-body);
}
.hero__badge--status{color:var(--term-green);border-color:rgba(74,222,128,0.25);}
.hero__status-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--term-green);
  box-shadow:0 0 8px var(--term-green);
  animation:pulseDot 1.8s ease-in-out infinite;
}

.hero__links{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:6px 24px;
  margin-bottom:48px;
  opacity:0;
}
.hero__link{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-mono);
  font-size:15px;
  font-weight:600;
  color:var(--text-body);
  padding:4px 0;
  transition:color 0.3s ease;
}
.hero__link::after{
  content:"";
  position:absolute;
  bottom:0;left:0;
  width:100%;
  height:1px;
  background:var(--accent);
  transform-origin:left;
  transform:scaleX(0);
  transition:transform 0.4s cubic-bezier(.2,.7,.2,1);
}
.hero__link:hover{color:var(--accent);}
.hero__link:hover::after{transform:scaleX(1);}
.hero__link-arrow{color:var(--accent-dim);transition:transform 0.3s ease;}
.hero__link:hover .hero__link-arrow{transform:translateX(2px);color:var(--accent);}

.hero__stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:8px;
  width:min(900px,100%);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  background:rgba(17,17,19,0.5);
  backdrop-filter:blur(8px);
  padding:18px;
  opacity:0;
}
.hero__stat{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  padding:6px 12px;
  border-left:1px solid var(--border-soft);
}
.hero__stat:first-child{border-left:0;}
.hero__stat-num{
  font-family:var(--font-display);
  font-size:36px;
  font-weight:700;
  color:var(--accent);
  line-height:1;
  margin-bottom:4px;
}
.hero__stat-label{
  font-family:var(--font-mono);
  font-size:10.5px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:0.08em;
}
@media (max-width:640px){
  .hero__stats{grid-template-columns:repeat(2,1fr);}
  .hero__stat:nth-child(3){border-left:0;}
}

.hero__scroll{
  position:absolute;
  bottom:30px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  font-family:var(--font-mono);
  font-size:10px;
  color:var(--text-muted);
  letter-spacing:0.2em;
  text-transform:uppercase;
  opacity:0;
}
.hero__scroll-label{}
.hero__scroll-line{
  width:1px;height:30px;
  background:linear-gradient(180deg,var(--accent),transparent);
}
.hero__scroll-arrow{
  color:var(--accent);
  animation:bounceY 2s ease-in-out infinite;
}
@keyframes bounceY{
  0%,100%{transform:translateY(0);opacity:0.7;}
  50%{transform:translateY(6px);opacity:1;}
}

/* ============================================================
   ABOUT
   ============================================================ */
.about__grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
  gap:40px;
  align-items:start;
}
@media (max-width:900px){.about__grid{grid-template-columns:1fr;}}

.about__lede{
  font-family:var(--font-mono);
  font-size:clamp(15px,1.4vw,17px);
  line-height:1.75;
  color:var(--text-primary);
  margin-bottom:24px;
}
.about__lede strong{color:var(--accent);font-weight:500;}
.about__lede-mark{
  color:var(--accent-dim);
  font-style:italic;
  margin:0 4px;
}
.about__body{
  font-family:var(--font-mono);
  font-size:14px;
  color:var(--text-body);
  line-height:1.7;
  margin-bottom:30px;
}
.about__values{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
.about__value{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 14px;
  background:rgba(17,17,19,0.55);
  border:1px solid var(--border-soft);
  border-radius:var(--r-md);
  font-family:var(--font-mono);
  font-size:12px;
}
.about__value-key{color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;font-size:10.5px;}
.about__value-val{color:var(--text-primary);}

/* ============================================================
   CARD WINDOW (terminal/IDE)
   ============================================================ */
.card-window{
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lift);
  position:relative;
}
.card-window__bar{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  background:var(--bg-elevated);
  border-bottom:1px solid var(--border);
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--text-muted);
}
.card-window__dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--border);
}
.card-window__dot--r{background:#ff5f57;}
.card-window__dot--y{background:#febc2e;}
.card-window__dot--g{background:#28c840;}
.card-window__title{
  margin-left:10px;
  display:flex;
  align-items:center;
  gap:8px;
  flex:1;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.card-window__file{color:var(--text-body);}
.card-window__file--muted{color:var(--text-muted);}
.card-window__sep{color:var(--text-faint);}
.card-window__badge{
  margin-left:auto;
  padding:2px 8px;
  background:rgba(232,160,32,0.12);
  color:var(--accent);
  border:1px solid rgba(232,160,32,0.25);
  border-radius:4px;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:0.06em;
}
.card-window__badge--muted{
  background:rgba(107,105,102,0.1);
  color:var(--text-muted);
  border-color:var(--border);
}
.card-window__body{
  margin:0;
  padding:18px 20px;
  font-family:var(--font-mono);
  font-size:12.5px;
  line-height:1.75;
  color:var(--text-body);
  white-space:pre;
  overflow-x:auto;
}
.syn-k{color:var(--accent);}
.syn-s{color:#a3c9b5;}
.syn-b{color:#e8a020;font-weight:500;}
.syn-p{color:var(--text-muted);}

/* ============================================================
   SKILLS
   ============================================================ */
.skills{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:24px;
}
@media (max-width:760px){.skills{grid-template-columns:1fr;}}

.skill-group{
  padding:24px;
  background:rgba(17,17,19,0.6);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  position:relative;
  overflow:hidden;
  backdrop-filter:blur(6px);
}
.skill-group--wide{grid-column:1/-1;}
.skill-group::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,transparent,var(--accent-dim),transparent);
  opacity:0;
  transition:opacity 0.4s ease;
}
.skill-group:hover::before{opacity:1;}

.skill-group__title{
  font-family:var(--font-mono);
  font-size:13px;
  font-weight:500;
  color:var(--text-primary);
  text-transform:uppercase;
  letter-spacing:0.06em;
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:6px;
  clip-path:inset(0 100% 0 0);
  transition:clip-path 0.8s cubic-bezier(.2,.7,.2,1);
}
.skill-group.is-revealed .skill-group__title{clip-path:inset(0 0 0 0);}
.skill-group__chev{color:var(--accent);}

.skill-group__list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  background:var(--bg-elevated);
  border:1px solid var(--border);
  border-radius:999px;
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-body);
  transform:scale(0);
  transition:transform 0.3s ease,background 0.3s ease,border-color 0.3s ease,color 0.3s ease,box-shadow 0.3s ease;
  cursor:none;
}
.skill-group.is-revealed .pill{transform:scale(1);}
.pill:hover{
  color:var(--accent);
  border-color:var(--accent);
  background:rgba(232,160,32,0.08);
  box-shadow:0 0 0 4px var(--accent-soft),0 6px 18px -8px var(--accent-glow);
  transform:translateY(-2px) scale(1);
}
.pill__ver{
  color:var(--text-muted);
  font-size:10.5px;
  padding-left:6px;
  border-left:1px solid var(--border);
  margin-left:2px;
}

/* ============================================================
   EXPERIENCE
   ============================================================ */
.section--exp{
  position:relative;
}
.exp__easter{
  position:absolute;
  top:120px;
  right:-30px;
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-primary);
  opacity:0.04;
  pointer-events:none;
  white-space:pre;
  max-width:60%;
  transform:rotate(-1deg);
}
.exp__easter span{color:var(--accent);}

.gitlog{
  margin-bottom:60px;
  padding:18px 22px;
  background:rgba(13,13,15,0.65);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  font-family:var(--font-mono);
  font-size:12.5px;
  overflow-x:auto;
  backdrop-filter:blur(6px);
}
.gitlog__pre{margin:0;font-family:inherit;color:var(--text-muted);line-height:1.85;}
.gitlog__dot{color:var(--accent);}
.gitlog__hash{color:var(--term-yellow);}
.gitlog__msg{color:var(--text-primary);}
.gitlog__date{color:var(--text-muted);font-style:italic;}

.exp__timeline{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:48px;
}
.exp-card{position:relative;}
.exp-card__pin{
  position:absolute;
  left:-12px;
  top:24px;
  width:10px;height:10px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px var(--bg-base),0 0 16px var(--accent-glow);
  z-index:3;
  opacity:0;
  transform:scale(0);
  transition:opacity 0.4s ease,transform 0.4s ease;
}
@media (max-width:760px){.exp-card__pin{display:none;}}
.exp-card.is-revealed .exp-card__pin{opacity:1;transform:scale(1);}

.exp-card__window{
  overflow:hidden;
  clip-path:inset(0 0 100% 0);
  transition:clip-path 0.9s cubic-bezier(.2,.7,.2,1);
}
.exp-card.is-revealed .exp-card__window{clip-path:inset(0 0 0 0);}

.exp__line{
  width:3px;
  height:80px;
  margin-left:-7px;
  display:block;
  overflow:visible;
}
.exp__line-path{
  animation:none;
}
.exp-card.is-revealed + .exp__line .exp__line-path{
  animation:drawLine 1.4s ease-out forwards;
}
@keyframes drawLine{to{stroke-dashoffset:0;}}

.exp-card__body{
  padding:24px 26px 26px;
  position:relative;
}
.exp-card__head{
  display:flex;
  justify-content:space-between;
  gap:24px;
  margin-bottom:18px;
  padding-bottom:16px;
  border-bottom:1px dashed var(--border);
  flex-wrap:wrap;
}
.exp-card__company{
  font-family:var(--font-display);
  font-size:clamp(24px,2.4vw,30px);
  font-weight:700;
  color:var(--text-primary);
  letter-spacing:-0.005em;
  margin-bottom:2px;
}
.exp-card__slash{color:var(--accent);}
.exp-card__role{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--text-body);
}
.exp-card__meta{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:4px;
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-muted);
}
.exp-card__time{color:var(--accent-dim);}
@media (max-width:600px){
  .exp-card__meta{align-items:flex-start;}
}

.exp-card__bullets{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin-bottom:18px;
  font-family:var(--font-mono);
  font-size:13.5px;
  line-height:1.7;
}
.exp-card__bullets li{
  position:relative;
  padding-left:22px;
  color:var(--text-body);
  opacity:0;
  transform:translateY(6px);
  transition:opacity 0.6s ease,transform 0.6s ease;
}
.exp-card.is-revealed .exp-card__bullets li{
  opacity:1;
  transform:translateY(0);
}
.exp-card.is-revealed .exp-card__bullets li:nth-child(1){transition-delay:0.20s;}
.exp-card.is-revealed .exp-card__bullets li:nth-child(2){transition-delay:0.35s;}
.exp-card.is-revealed .exp-card__bullets li:nth-child(3){transition-delay:0.50s;}
.exp-card.is-revealed .exp-card__bullets li:nth-child(4){transition-delay:0.65s;}
.exp-card.is-revealed .exp-card__bullets li:nth-child(5){transition-delay:0.80s;}
.exp-card.is-revealed .exp-card__bullets li:nth-child(6){transition-delay:0.95s;}
.exp-card__bullets li::before{
  content:"›";
  position:absolute;
  left:6px;top:-1px;
  color:var(--accent);
  font-weight:700;
}
.exp-card__bullets li:last-child::after{
  content:"█";
  display:inline-block;
  color:var(--accent);
  margin-left:4px;
  animation:blink 1s steps(2) infinite;
  vertical-align:baseline;
  font-size:0.85em;
}
.exp-card__bullets em{
  color:var(--accent);
  font-style:normal;
  font-weight:500;
}
.exp-card__bullets code{
  font-family:var(--font-mono);
  background:rgba(232,160,32,0.10);
  border:1px solid rgba(232,160,32,0.20);
  color:var(--accent);
  padding:0 5px;
  border-radius:3px;
  font-size:0.94em;
}

.exp-card__stack{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  padding-top:14px;
  border-top:1px dashed var(--border);
}
.chip{
  font-family:var(--font-mono);
  font-size:11px;
  padding:3px 9px;
  border:1px solid var(--border);
  background:var(--bg-elevated);
  color:var(--text-muted);
  border-radius:4px;
  transition:color 0.25s ease,border-color 0.25s ease;
}
.chip:hover{color:var(--accent);border-color:var(--accent-dim);}

/* ============================================================
   PROJECTS
   ============================================================ */
.section--projects{position:relative;}

.proj__grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:24px;
}

.proj-card{
  display:block;
  text-decoration:none;
  color:inherit;
  cursor:none;
  transition:transform 0.35s cubic-bezier(.2,.7,.2,1);
}
.proj-card:hover{transform:translateY(-4px);}
.proj-card:hover .card-window{
  border-color:var(--accent-dim);
  box-shadow:0 16px 40px -16px rgba(0,0,0,0.7),0 0 24px var(--accent-glow);
}
.proj-card:hover .proj-card__name{color:var(--accent);}
.proj-card:hover .proj-card__cta{color:var(--accent);transform:translateX(2px);}

.proj-card .card-window{
  height:100%;
  display:flex;
  flex-direction:column;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  background:rgba(17,17,19,0.55);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  overflow:hidden;
  transition:border-color 0.3s ease,box-shadow 0.4s ease;
}

.proj-card__body{
  padding:20px 22px 22px;
  display:flex;
  flex-direction:column;
  gap:14px;
  flex:1;
}

.proj-card__name{
  font-family:var(--font-display);
  font-size:24px;
  font-weight:700;
  letter-spacing:-0.01em;
  color:var(--text-primary);
  text-transform:lowercase;
  transition:color 0.3s ease;
}

.proj-card__desc{
  font-family:var(--font-mono);
  font-size:13.5px;
  line-height:1.6;
  color:var(--text-body);
  flex:1;
}
.proj-card__desc code{
  font-family:var(--font-mono);
  font-size:0.92em;
  padding:1px 5px;
  border-radius:3px;
  background:var(--bg-elevated);
  color:var(--accent);
}

.proj-card__stack{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.proj-card__stack li{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.04em;
  text-transform:uppercase;
  padding:3px 8px;
  border:1px solid var(--border);
  border-radius:3px;
  color:var(--text-muted);
  background:var(--accent-soft);
}

.proj-card__meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding-top:12px;
  border-top:1px dashed var(--border-soft);
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-muted);
}
.proj-card__lang{display:inline-flex;align-items:center;gap:6px;}
.proj-card__dot{
  width:9px;height:9px;
  border-radius:50%;
  display:inline-block;
}
.proj-card__dot--py{background:#3776AB;}
.proj-card__dot--ts{background:#3178C6;}
.proj-card__dot--c{background:#A8B9CC;}
.proj-card__dot--html{background:#E34F26;}

.proj-card__cta{
  color:var(--text-body);
  font-weight:500;
  transition:color 0.3s ease,transform 0.3s ease;
}

@media (max-width:720px){
  .proj__grid{grid-template-columns:1fr;gap:16px;}
  .proj-card__body{padding:16px 18px 18px;}
  .proj-card__name{font-size:22px;}
}

/* ============================================================
   CERTIFICATES
   ============================================================ */
.certs{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  perspective:1400px;
}
@media (max-width:900px){.certs{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.certs{grid-template-columns:1fr;}}

.cert{
  perspective:1400px;
  transform-style:preserve-3d;
  transform:rotateY(90deg);
  opacity:0;
  transition:transform 0.9s cubic-bezier(.2,.7,.2,1),opacity 0.5s ease;
}
.cert.is-revealed{transform:rotateY(0deg);opacity:1;}

.cert__inner{
  position:relative;
  padding:24px 22px;
  background:linear-gradient(165deg,rgba(22,18,8,0.55) 0%,rgba(17,17,19,0.85) 100%);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  height:100%;
  display:flex;
  flex-direction:column;
  gap:8px;
  transition:transform 0.5s cubic-bezier(.2,.7,.2,1),border-color 0.4s ease,box-shadow 0.4s ease;
  overflow:hidden;
  animation:floatCard 6s ease-in-out infinite;
}
.cert:nth-child(2) .cert__inner{animation-delay:-1.5s;}
.cert:nth-child(3) .cert__inner{animation-delay:-3s;}
.cert:nth-child(4) .cert__inner{animation-delay:-2s;}
.cert:nth-child(5) .cert__inner{animation-delay:-4s;}
.cert:nth-child(6) .cert__inner{animation-delay:-5s;}
@keyframes floatCard{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-4px);}
}
.cert__inner:hover{
  transform:translateY(-8px) translateZ(20px);
  border-color:var(--accent-dim);
  box-shadow:0 30px 50px -20px rgba(0,0,0,0.7),0 0 0 1px rgba(232,160,32,0.2),0 0 30px rgba(232,160,32,0.1);
  animation-play-state:paused;
}
.cert__inner::after{
  content:"";
  position:absolute;
  inset:auto auto -50% -50%;
  width:160%;
  height:160%;
  background:radial-gradient(circle,rgba(232,160,32,0.06) 0%,transparent 60%);
  opacity:0;
  transition:opacity 0.5s ease;
  pointer-events:none;
}
.cert__inner:hover::after{opacity:1;}

.cert__index{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-faint);
  letter-spacing:0.1em;
}
.cert__icon{
  width:42px;
  height:42px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--accent);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  background:rgba(232,160,32,0.05);
  margin-bottom:4px;
}
.cert__icon svg{width:22px;height:22px;}
.cert__title{
  font-family:var(--font-display);
  font-size:22px;
  font-weight:600;
  color:var(--text-primary);
  line-height:1.15;
}
.cert__org{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:0.08em;
}
.cert__desc{
  font-family:var(--font-mono);
  font-size:12.5px;
  color:var(--text-body);
  line-height:1.6;
  margin-top:4px;
}
.cert__tags{
  margin-top:auto;
  padding-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:5px;
}
.cert__tags span{
  font-family:var(--font-mono);
  font-size:10.5px;
  padding:2px 8px;
  background:var(--bg-elevated);
  color:var(--text-muted);
  border-radius:3px;
  border:1px solid var(--border-soft);
}
.cert--highlight .cert__inner{
  border-color:rgba(232,160,32,0.3);
  box-shadow:inset 0 0 0 1px rgba(232,160,32,0.1);
}

/* ============================================================
   LANGUAGES — circular progress
   ============================================================ */
.langs{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:24px;
}
@media (max-width:900px){.langs{grid-template-columns:repeat(3,1fr);}}
@media (max-width:520px){.langs{grid-template-columns:repeat(2,1fr);}}

.lang{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  padding:24px 12px;
  background:rgba(17,17,19,0.5);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  transition:transform 0.4s ease,border-color 0.4s ease;
}
.lang:hover{
  transform:translateY(-4px);
  border-color:var(--accent-dim);
}
.lang__ring-wrap{
  position:relative;
  width:120px;
  height:120px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.lang__ring{
  width:100%;
  height:100%;
  transform:rotate(-90deg);
}
.lang__ring-track{
  fill:none;
  stroke:var(--border);
  stroke-width:6;
}
.lang__ring-prog{
  fill:none;
  stroke:url(#langGrad);
  stroke:var(--accent);
  stroke-width:6;
  stroke-linecap:round;
  stroke-dasharray:327;
  stroke-dashoffset:327;
  transition:stroke-dashoffset 2s cubic-bezier(.2,.7,.2,1);
  filter:drop-shadow(0 0 6px var(--accent-glow));
}
.lang__pct{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-size:34px;
  font-weight:700;
  color:var(--text-primary);
  line-height:1;
}
.lang__pct-sym{
  position:absolute;
  top:50%;
  left:calc(50% + 28px);
  transform:translateY(-50%);
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-muted);
}
.lang__name{
  font-family:var(--font-display);
  font-size:18px;
  font-weight:600;
  color:var(--text-primary);
}
.lang__level{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:0.08em;
}

/* ============================================================
   EDUCATION
   ============================================================ */
.edu{
  display:grid;
  grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);
  gap:32px;
}
@media (max-width:860px){.edu{grid-template-columns:1fr;}}

.edu__body{padding:24px 26px;}
.edu__school{
  font-family:var(--font-display);
  font-size:28px;
  font-weight:700;
  color:var(--text-primary);
}
.edu__degree{
  font-family:var(--font-mono);
  font-size:13px;
  color:var(--accent);
  margin-bottom:8px;
}
.edu__meta{
  display:flex;
  gap:14px;
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--text-muted);
  padding-bottom:18px;
  margin-bottom:18px;
  border-bottom:1px dashed var(--border);
}
.edu__sub{
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:0.08em;
  margin-bottom:10px;
}
.edu__list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:6px 14px;
  font-family:var(--font-mono);
  font-size:13px;
}
.edu__list li{
  position:relative;
  padding-left:18px;
  color:var(--text-body);
}
.edu__list li::before{
  content:"$";
  position:absolute;
  left:0;
  color:var(--accent);
}
.edu__side{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.edu__quote{
  position:relative;
  padding:22px 24px;
  background:rgba(17,17,19,0.5);
  border:1px solid var(--border);
  border-left:3px solid var(--accent);
  border-radius:var(--r-md);
  font-family:var(--font-mono);
  font-size:13px;
  line-height:1.65;
  color:var(--text-body);
}
.edu__quote-mark{
  position:absolute;
  top:0;left:14px;
  font-family:var(--font-display);
  font-size:60px;
  color:var(--accent-dim);
  line-height:1;
  opacity:0.5;
}
.edu__interests{
  padding:18px 20px;
  background:rgba(17,17,19,0.5);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  font-family:var(--font-mono);
  font-size:13px;
  line-height:1.65;
  color:var(--text-body);
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{
  display:flex;
  flex-direction:column;
  gap:36px;
}
.contact__lead{
  padding:22px 24px;
  background:rgba(17,17,19,0.6);
  border:1px solid var(--border);
  border-radius:var(--r-md);
}
.contact__big{
  font-family:var(--font-mono);
  font-size:clamp(14px,1.6vw,18px);
  color:var(--text-body);
  margin-bottom:8px;
  line-height:1.6;
}
.contact__prompt{color:var(--term-green);}
.contact__text{color:var(--text-primary);}
.contact__sub{
  font-family:var(--font-mono);
  font-size:12.5px;
  color:var(--text-muted);
}
.contact__grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
@media (max-width:760px){.contact__grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.contact__grid{grid-template-columns:1fr;}}

.contact__card{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:18px 20px;
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:transform 0.4s ease,border-color 0.4s ease,box-shadow 0.4s ease,background 0.4s ease;
  overflow:hidden;
}
.contact__card::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(232,160,32,0.08),transparent 50%);
  opacity:0;
  transition:opacity 0.4s ease;
  pointer-events:none;
}
.contact__card:hover{
  transform:translateY(-3px);
  border-color:var(--accent-dim);
  box-shadow:0 14px 36px -16px rgba(0,0,0,0.8),0 0 0 1px rgba(232,160,32,0.18);
}
.contact__card:hover::before{opacity:1;}
.contact__card-key{
  font-family:var(--font-mono);
  font-size:10.5px;
  color:var(--text-muted);
  text-transform:uppercase;
  letter-spacing:0.1em;
}
.contact__card-val{
  font-family:var(--font-mono);
  font-size:14px;
  color:var(--text-primary);
  word-break:break-all;
}
.contact__card-copy{
  margin-top:8px;
  font-family:var(--font-mono);
  font-size:11px;
  color:var(--accent);
  display:flex;
  align-items:center;
  gap:4px;
}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-form{
  margin-top:48px;
  display:flex;
  flex-direction:column;
  gap:18px;
  max-width:720px;
}

.contact-form__row{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.contact-form__label{
  font-family:var(--font-mono);
  font-size:13px;
  font-weight:500;
  color:var(--text-body);
}

.contact-form__input{
  width:100%;
  font-family:var(--font-mono);
  font-size:14px;
  color:var(--text-primary);
  background:var(--bg-surface);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  padding:13px 16px;
  outline:none;
  transition:border-color 0.25s ease,box-shadow 0.25s ease,background 0.25s ease;
}
.contact-form__input::placeholder{color:var(--text-faint);}
.contact-form__input:hover{border-color:var(--accent-dim);}
.contact-form__input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
}
.contact-form__input:invalid:not(:placeholder-shown){
  border-color:var(--term-red);
}

.contact-form__textarea{
  resize:vertical;
  min-height:140px;
  line-height:1.6;
}

.contact-form__submit{
  width:100%;
  margin-top:8px;
  padding:14px 22px;
  font-family:var(--font-mono);
  font-size:15px;
  font-weight:600;
  text-align:center;
  color:var(--bg-base);
  background:linear-gradient(90deg,var(--accent-dim),var(--accent));
  border:1px solid var(--accent);
  border-radius:var(--r-md);
  cursor:none;
  transition:transform 0.25s ease,box-shadow 0.3s ease,filter 0.25s ease;
}
.contact-form__submit:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 24px -8px var(--accent-glow),0 0 24px var(--accent-glow);
  filter:brightness(1.08);
}
.contact-form__submit:active{transform:translateY(0);}
.contact-form__submit[disabled]{opacity:0.55;cursor:not-allowed;filter:grayscale(0.4);}

.contact-form__status{
  min-height:1.2em;
  font-family:var(--font-mono);
  font-size:13px;
  margin-top:4px;
  color:var(--text-muted);
  transition:color 0.25s ease;
}
.contact-form__status[data-state="pending"]{color:var(--text-body);}
.contact-form__status[data-state="success"]{color:var(--term-green);}
.contact-form__status[data-state="error"]{color:var(--term-red);}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  position:relative;
  padding:56px 0 40px;
  border-top:1px solid var(--border);
  background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,0.4) 100%);
  z-index:2;
  overflow:hidden;
}
.footer__inner{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:24px;
  align-items:start;
}
@media (max-width:760px){
  .footer__inner{grid-template-columns:1fr;text-align:center;}
  .footer__col--right{align-items:center;}
}
.footer__col{display:flex;flex-direction:column;gap:6px;}
.footer__col--center{text-align:center;}
.footer__col--right{align-items:flex-end;}
.footer__brand{
  font-family:var(--font-display);
  font-size:28px;
  font-weight:700;
  color:var(--text-primary);
}
.footer__brand span{color:var(--accent);}
.footer__sub{
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--text-muted);
}
.footer__motto{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--text-muted);
  font-style:italic;
}
.footer__line{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-mono);
  font-size:11.5px;
  color:var(--text-muted);
}
.footer__line span:first-child{color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;font-size:10.5px;}
.footer__line span:last-child{color:var(--text-primary);}
.footer__dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--term-green);
  box-shadow:0 0 6px var(--term-green);
  animation:pulseDot 1.8s ease-in-out infinite;
  display:inline-block;
}
.footer__sig{
  position:absolute;
  bottom:-40px;
  right:-10px;
  font-family:var(--font-display);
  font-size:200px;
  font-weight:900;
  color:var(--text-primary);
  opacity:0.025;
  letter-spacing:-0.04em;
  line-height:1;
  pointer-events:none;
}

/* ============================================================
   TOAST
   ============================================================ */
.toast{
  position:fixed;
  bottom:30px;
  left:50%;
  transform:translateX(-50%) translateY(20px);
  padding:12px 22px;
  background:var(--bg-surface);
  border:1px solid var(--accent);
  border-radius:999px;
  font-family:var(--font-mono);
  font-size:12.5px;
  color:var(--accent);
  box-shadow:0 8px 24px -8px rgba(0,0,0,0.6),0 0 24px var(--accent-glow);
  z-index:200;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.4s ease,transform 0.4s cubic-bezier(.2,.7,.2,1);
}
.toast.is-visible{
  opacity:1;
  transform:translateX(-50%) translateY(0);
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
    scroll-behavior:auto!important;
  }
  .bg-canvas--rain,.bg-canvas--particles,.bg-grid,.bg-mesh{display:none;}
  .hero__letter{transform:none!important;opacity:1!important;filter:none!important;}
  .cert{transform:none!important;opacity:1!important;}
  .exp-card__window{clip-path:inset(0 0 0 0)!important;}
  body{cursor:auto;}
  .cursor{display:none;}
}
