/* ── RESET & ROOT ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#0b0800;
  --surface:#1a1208;
  --border:#3d2e1a;
  --border-bright:#6b4e28;
  --text:#e8dcc8;
  --muted:#b09878;
  --accent:#c8912a;
  --accent-glow:rgba(200,145,42,0.25);
  --danger:#8b1a1a;
  --rye:'Rye',Georgia,serif;
  --fell:'IM Fell English',Georgia,serif;
  --elite:'Special Elite',monospace;
}

html{scroll-behavior:smooth}

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--fell);
  font-size:15px;
  line-height:1.7;
  overflow-x:hidden;
  cursor:none;
}

/* ── PARCHMENT TEXTURE ── */
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none;z-index:996;
  mix-blend-mode:overlay;opacity:0.5;
}

/* ── VIGNETTE ── */
body::before{
  content:'';
  position:fixed;inset:0;
  background:radial-gradient(ellipse 90% 90% at 50% 50%,transparent 55%,rgba(0,0,0,0.6) 100%);
  pointer-events:none;z-index:995;
}

/* ── VIDEO INTRO OVERLAY ── */
#intro-overlay{
  position:fixed;inset:0;z-index:10000;
  background:#000;
  display:flex;align-items:center;justify-content:center;
  transition:opacity 0.9s ease;
}
#intro-overlay.fade-out{opacity:0;pointer-events:none;}
#intro-video{width:100%;height:100%;object-fit:cover;}
#skip-btn{
  position:absolute;bottom:2.5rem;right:2.5rem;
  background:transparent;
  border:1px solid rgba(200,145,42,0.4);
  color:rgba(200,145,42,0.7);
  font-family:var(--elite);font-size:0.7rem;
  letter-spacing:0.18em;text-transform:uppercase;
  padding:0.5rem 1.3rem;cursor:none;
  transition:border-color 0.2s,color 0.2s;
}
#skip-btn:hover{border-color:var(--accent);color:var(--accent);}

/* ── GUN CURSOR ── */
#gun-cursor{
  position:fixed;
  pointer-events:none;
  z-index:9999;
  transform:translate(0,-50%);
  will-change:left,top;
}
#gun-cursor.recoil{
  animation:gun-recoil 0.18s ease-out forwards;
}
#gun-cursor.reloading{
  animation:gun-reload 0.85s ease-in-out forwards;
}
@keyframes gun-recoil{
  0%{transform:translate(0,-50%) translateX(0)}
  35%{transform:translate(0,-50%) translateX(10px)}
  100%{transform:translate(0,-50%) translateX(0)}
}
@keyframes gun-reload{
  0%{transform:translate(0,-50%) rotate(0deg) translateY(0)}
  25%{transform:translate(0,-50%) rotate(-25deg) translateY(-6px)}
  65%{transform:translate(0,-50%) rotate(-25deg) translateY(-6px)}
  100%{transform:translate(0,-50%) rotate(0deg) translateY(0)}
}

/* ── MUZZLE FLASH ── */
.muzzle-flash{
  position:fixed;width:36px;height:36px;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle,#fff 0%,#ffee44 20%,#ff8800 50%,transparent 72%);
  animation:flash-out 0.1s ease-out forwards;
}
@keyframes flash-out{
  0%{opacity:1;transform:translate(-50%,-50%) scale(0.6)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(2.8)}
}

/* ── BULLET HOLE ── */
.bullet-hole{
  position:fixed;
  width:14px;height:14px;
  pointer-events:none;z-index:9990;
  transform:translate(-50%,-50%);
  border-radius:50%;
  background:radial-gradient(circle,#000 30%,#1a0800 60%,transparent 100%);
  box-shadow:0 0 0 1.5px rgba(40,20,0,0.9),0 0 8px rgba(0,0,0,0.7);
}
.bullet-hole::after{
  content:'';
  position:absolute;inset:-8px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cline x1='15' y1='0' x2='15' y2='6' stroke='%23221000' stroke-width='1.2'/%3E%3Cline x1='15' y1='24' x2='15' y2='30' stroke='%23221000' stroke-width='1.2'/%3E%3Cline x1='0' y1='15' x2='6' y2='15' stroke='%23221000' stroke-width='1.2'/%3E%3Cline x1='24' y1='15' x2='30' y2='15' stroke='%23221000' stroke-width='1.2'/%3E%3Cline x1='4' y1='4' x2='8' y2='8' stroke='%23221000' stroke-width='0.9'/%3E%3Cline x1='22' y1='22' x2='26' y2='26' stroke='%23221000' stroke-width='0.9'/%3E%3Cline x1='26' y1='4' x2='22' y2='8' stroke='%23221000' stroke-width='0.9'/%3E%3Cline x1='8' y1='22' x2='4' y2='26' stroke='%23221000' stroke-width='0.9'/%3E%3C/svg%3E") no-repeat center;
}
.bullet-hole.vanish{
  animation:hole-fade 0.5s ease-out forwards;
}
@keyframes hole-fade{
  to{opacity:0;transform:translate(-50%,-50%) scale(0.4)}
}

/* ── SCREEN SHAKE ── */
@keyframes screen-shake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-4px)}
  40%{transform:translateX(4px)}
  60%{transform:translateX(-2px)}
  80%{transform:translateX(2px)}
}
body.shake{animation:screen-shake 0.13s ease-out}

/* ── SHELL CASING ── */
.shell{
  position:fixed;
  width:9px;height:4px;border-radius:1px 3px 3px 1px;
  background:linear-gradient(to bottom,#d4a030,#8a5a10);
  pointer-events:none;z-index:9995;
}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.5rem 3rem;
  border-bottom:1px solid transparent;
  transition:border-color 0.3s,background 0.3s;
}
nav.scrolled{
  background:rgba(11,8,0,0.94);
  border-color:var(--border);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.nav-logo{
  font-family:var(--rye);font-size:1.15rem;
  color:var(--accent);text-decoration:none;
  display:flex;align-items:center;gap:0.6rem;
  text-shadow:0 0 20px rgba(200,145,42,0.5);
  letter-spacing:0.04em;
}
.nav-logo::before{content:'✦';font-size:0.65rem;opacity:0.75}
.nav-links{display:flex;gap:2.5rem;list-style:none}
.nav-links a{
  font-family:var(--elite);font-size:0.7rem;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--muted);
  text-decoration:none;transition:color 0.2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--accent)}

/* ── BG VIDEO (hero only) ── */
#bg-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;z-index:0;
}

/* ── HERO ── */
#hero{
  position:sticky;
  top:0;
  z-index:5;
  min-height:100vh;
  display:flex;flex-direction:column;
  justify-content:center;align-items:flex-start;
  padding:8rem 5rem 5rem;
  overflow:hidden;
}
#hero > *:not(#bg-video){
  position:relative;z-index:2;
}

/* ── HERO FRAME ── */
.hero-frame{
  position:relative;
  padding:2.5rem 3rem;
  max-width:680px;
  background:rgba(0,0,0,0.28);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
}
.hero-frame::before{
  content:'';position:absolute;inset:0;
  border:1px solid var(--accent);pointer-events:none;
}
.hero-frame::after{
  content:'';position:absolute;inset:8px;
  border:1px solid rgba(200,145,42,0.3);pointer-events:none;
}
.corner{
  position:absolute;color:var(--accent);
  font-size:0.9rem;line-height:1;
  text-shadow:0 0 12px rgba(200,145,42,0.9);
  z-index:3;
}
.corner-tl{top:-0.55rem;left:-0.55rem}
.corner-tr{top:-0.55rem;right:-0.55rem}
.corner-bl{bottom:-0.55rem;left:-0.55rem}
.corner-br{bottom:-0.55rem;right:-0.55rem}

/* ── HERO CONTENT ── */
.hero-tag{
  font-family:var(--elite);font-size:0.65rem;
  letter-spacing:0.28em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.25rem;
  opacity:0;animation:fadeUp 0.8s 0.2s forwards;
  text-shadow:0 1px 12px rgba(0,0,0,0.95),0 0 20px rgba(200,145,42,0.45);
}
.hero-name{
  font-family:var(--rye);
  font-size:clamp(3.5rem,9vw,8rem);
  line-height:1;letter-spacing:0.02em;
  color:#fff;margin-bottom:1.2rem;
  opacity:0;animation:fadeUp 0.9s 0.35s forwards;
  text-shadow:0 2px 24px rgba(0,0,0,0.98),0 4px 16px rgba(0,0,0,0.85),0 0 60px rgba(200,145,42,0.12);
}
.hero-name em{
  font-style:italic;color:var(--accent);
  text-shadow:0 2px 16px rgba(0,0,0,0.98),0 0 24px rgba(200,145,42,0.35);
}
.hero-role{
  font-family:var(--fell);font-style:italic;font-size:1rem;
  color:var(--text);margin-bottom:2rem;
  opacity:0;animation:fadeUp 0.9s 0.5s forwards;
  max-width:460px;line-height:2;
  text-shadow:0 1px 20px rgba(0,0,0,0.98),0 2px 8px rgba(0,0,0,0.85);
}
.hero-role span{color:#fff;font-style:normal;font-weight:bold;}
.terminal-line{
  display:inline-flex;align-items:center;gap:0.5rem;
  font-family:var(--elite);font-size:0.72rem;
  color:rgba(232,220,200,0.75);margin-top:0.75rem;font-style:normal;
  text-shadow:0 1px 8px rgba(0,0,0,0.9);
}
.terminal-line::before{content:'⟩';color:var(--accent);font-size:0.85rem}
.typed{border-right:2px solid var(--accent);padding-right:2px;animation:blink 1s infinite}
@keyframes blink{0%,100%{border-color:var(--accent)}50%{border-color:transparent}}
.hero-actions{
  display:flex;gap:1rem;align-items:center;
  opacity:0;animation:fadeUp 0.9s 0.65s forwards;
}

/* ── BUTTONS ── */
.btn-primary{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.75rem 2rem;
  background:var(--accent);color:#0b0800;
  font-family:var(--elite);font-size:0.72rem;font-weight:700;
  letter-spacing:0.18em;text-decoration:none;text-transform:uppercase;
  box-shadow:inset 0 -2px 0 rgba(0,0,0,0.25),0 2px 16px rgba(200,145,42,0.35);
  transition:opacity 0.2s,transform 0.2s,box-shadow 0.2s;
}
.btn-primary:hover{opacity:0.85;transform:translateY(-2px);box-shadow:0 6px 24px rgba(200,145,42,0.45)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.75rem 2rem;
  border:1px solid rgba(232,220,200,0.30);color:rgba(232,220,200,0.85);
  font-family:var(--elite);font-size:0.72rem;
  letter-spacing:0.18em;text-decoration:none;text-transform:uppercase;
  transition:border-color 0.2s,color 0.2s;
  text-shadow:0 1px 8px rgba(0,0,0,0.85);
}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

.scroll-hint{
  position:absolute;bottom:2.5rem;left:5rem;
  display:flex;align-items:center;gap:0.6rem;
  font-family:var(--elite);font-size:0.65rem;letter-spacing:0.22em;
  text-transform:uppercase;color:rgba(232,220,200,0.65);
  opacity:0;animation:fadeUp 1s 1.1s forwards;
  text-shadow:0 1px 8px rgba(0,0,0,0.9);
}
.scroll-hint::before,.scroll-hint::after{content:'✦';color:var(--accent);font-size:0.6rem;}

/* ── STATS ROW ── */
.stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative;z-index:1;
}
.stats-row::before{
  content:'── FRONTIER DISPATCH ──';
  position:absolute;top:-0.72rem;left:50%;transform:translateX(-50%);
  font-family:var(--elite);font-size:0.58rem;letter-spacing:0.32em;
  color:var(--accent);background:var(--bg);padding:0 1rem;
  white-space:nowrap;
}
.stat{
  padding:2.5rem 2rem;border-right:1px solid var(--border);
  position:relative;overflow:hidden;text-align:center;
}
.stat:last-child{border-right:none}
.stat-num{
  font-family:var(--rye);font-size:2.8rem;
  color:var(--accent);line-height:1;margin-bottom:0.4rem;
  text-shadow:0 0 24px rgba(200,145,42,0.3);
}
.stat-label{
  font-family:var(--elite);font-size:0.62rem;
  letter-spacing:0.22em;text-transform:uppercase;color:var(--muted);
}

/* ── SECTIONS ── */
.section{max-width:1200px;margin:0 auto;padding:8rem 3rem;position:relative;z-index:1;}
.section-header{margin-bottom:4rem;}
.section-num{
  font-family:var(--elite);font-size:0.62rem;
  letter-spacing:0.18em;color:var(--accent);display:block;
  margin-bottom:0.5rem;text-transform:uppercase;
}
.section-title{
  font-family:var(--rye);font-size:clamp(2rem,4vw,3rem);
  color:var(--text);line-height:1.1;letter-spacing:0.03em;
}
.section-rule{
  width:64px;height:1px;margin-top:1rem;
  background:linear-gradient(to right,var(--accent),transparent);
}

/* ── STACK PANELS ── */
.panel-track{
  position:relative;
}
.panel-track + .panel-track{
  margin-top:calc(-100vh);
}
.panel-inner{
  will-change:transform;
  text-shadow:0 1px 12px rgba(0,0,0,0.75);
}
.stack-panel{
  position:sticky;
  top:0;
  height:100vh;
  background:var(--bg);
  border-radius:24px 24px 0 0;
  border:8px solid #4a2e14;
  border-bottom:none;
  overflow:hidden;
  box-shadow:
    0 -28px 64px rgba(0,0,0,0.92),
    0 -8px 20px rgba(0,0,0,0.7),
    inset 0 2px 0 rgba(200,145,42,0.18),
    inset 4px 0 0 rgba(200,145,42,0.06),
    inset -4px 0 0 rgba(200,145,42,0.06),
    0 0 0 1px rgba(200,145,42,0.1);
}
.stack-panel::before{
  content:'';
  position:absolute;top:14px;left:14px;right:14px;
  border-top:1.5px dashed rgba(200,145,42,0.32);
  pointer-events:none;z-index:100;
}
.stack-panel::after{
  content:'';
  position:absolute;top:0;left:0;right:0;height:80px;
  background:linear-gradient(to bottom,rgba(74,46,20,0.22),transparent);
  pointer-events:none;z-index:99;
  border-radius:24px 24px 0 0;
}
#panel-about{
  z-index:10;
  background:
    linear-gradient(rgba(11,8,0,0.58),rgba(11,8,0,0.58)),
    url('/static/images/bg/bg1.png') center/cover no-repeat;
}
#panel-skills{
  z-index:20;
  background:
    linear-gradient(rgba(11,8,0,0.53),rgba(11,8,0,0.53)),
    url('/static/images/bg/bg2.png') center/cover no-repeat;
}
#panel-projects{
  z-index:30;
  background:
    linear-gradient(rgba(11,8,0,0.65),rgba(11,8,0,0.65)),
    url('/static/images/bg/bg3.png') center/cover no-repeat;
}
#panel-writing{
  z-index:40;
  background:
    linear-gradient(rgba(11,8,0,0.65),rgba(11,8,0,0.65)),
    url('/static/images/bg/bg4.png') center/cover no-repeat;
}
#panel-contact{
  z-index:50;
  background:
    linear-gradient(rgba(11,8,0,0.73),rgba(11,8,0,0.73)),
    url('/static/images/bg/bg5.png') center/cover no-repeat;
}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;}
.about-text p{color:rgba(232,220,200,0.85);line-height:2;margin-bottom:1.5rem;font-size:0.95rem;}
.about-text p:first-child{
  font-family:var(--fell);font-size:1.15rem;font-style:italic;
  color:var(--text);line-height:1.9;
}
.about-text p:first-child::first-letter{
  font-family:var(--rye);font-size:3.5rem;
  float:left;line-height:0.75;margin:0.08em 0.08em 0 0;
  color:var(--accent);
}
.about-card{
  border:1px solid rgba(74,46,20,0.7);
  border-top:2px solid var(--accent);
  padding:1.2rem 1.4rem;margin-bottom:0.9rem;
  position:relative;
  background:rgba(26,18,8,0.30);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  box-shadow:0 4px 18px rgba(0,0,0,0.45),inset 0 1px 0 rgba(200,145,42,0.1);
  transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;
}
.about-card:hover{
  border-color:rgba(107,78,40,0.9);
  transform:translateX(3px);
  box-shadow:0 4px 24px rgba(0,0,0,0.55),inset 0 1px 0 rgba(200,145,42,0.18);
}
.about-card::after{
  content:'✦';
  position:absolute;bottom:0.7rem;right:1rem;
  font-size:0.9rem;color:rgba(139,26,26,0.25);pointer-events:none;
}
.about-card-label{
  font-family:var(--elite);font-size:0.65rem;letter-spacing:0.28em;
  text-transform:uppercase;color:var(--muted);margin-bottom:0.4rem;
}
.about-card-label::before{content:'[ '}
.about-card-label::after{content:' ]'}
.about-card-val{font-family:var(--fell);font-size:0.92rem;color:var(--text);}

/* ── SKILLS ── */
.skills-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:rgba(61,46,26,0.18);
  border:1px solid rgba(74,46,20,0.6);
}
.skill-item{
  background:rgba(26,18,8,0.30);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  padding:2rem 2rem 2.5rem;
  position:relative;overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(200,145,42,0.08);
  transition:background 0.3s,box-shadow 0.3s;
  cursor:none;
}
.skill-item:hover{
  background:rgba(31,21,8,0.88);
  box-shadow:inset 0 1px 0 rgba(200,145,42,0.15),0 0 24px rgba(200,145,42,0.06);
}
.skill-item::after{
  content:attr(data-num);position:absolute;bottom:-0.5rem;right:1rem;
  font-family:var(--rye);font-size:4.5rem;
  color:rgba(200,145,42,0.05);line-height:1;pointer-events:none;
}
.skill-icon{
  width:36px;height:36px;
  clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);
  background:var(--border);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.5rem;font-size:0.9rem;
  transition:background 0.3s;
}
.skill-item:hover .skill-icon{background:var(--accent)}
.skill-name{font-family:var(--rye);font-size:1.15rem;color:var(--accent);margin-bottom:0.75rem;}
.skill-desc{font-family:var(--fell);font-size:0.84rem;color:rgba(232,220,200,0.88);line-height:1.85;}
.skill-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:1rem;}
.skill-tag{
  font-family:var(--elite);font-size:0.65rem;letter-spacing:0.1em;
  padding:0.2rem 0.6rem;border:1px solid var(--border);
  color:var(--muted);text-transform:uppercase;
  background:rgba(200,145,42,0.04);
}

/* ── PROJECTS ── */
.project-list{display:flex;flex-direction:column;}
.project-item{
  border:1px solid rgba(74,46,20,0.7);
  border-top:1px solid rgba(74,46,20,0.7);
  padding:2rem 1.5rem;
  margin-bottom:0.6rem;
  display:grid;grid-template-columns:80px 1fr auto;
  gap:2rem;align-items:start;
  background:rgba(26,18,8,0.45);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  box-shadow:0 4px 18px rgba(0,0,0,0.45),inset 0 1px 0 rgba(200,145,42,0.1);
  transition:padding-left 0.3s,box-shadow 0.2s;
  position:relative;cursor:none;
}
.project-item:last-child{margin-bottom:0;}
.project-item:hover{
  padding-left:2.5rem;
  box-shadow:0 4px 24px rgba(0,0,0,0.55),inset 0 1px 0 rgba(200,145,42,0.18);
}
.project-num{
  font-family:var(--rye);font-size:1.1rem;
  color:var(--accent);opacity:0.7;padding-top:0.3rem;
  letter-spacing:0.05em;
}
.project-name{font-family:var(--rye);font-size:1.45rem;color:var(--text);margin-bottom:0.5rem;transition:color 0.2s;}
.project-item:hover .project-name{color:var(--accent)}
.project-desc{font-family:var(--fell);font-size:0.84rem;color:rgba(232,220,200,0.85);line-height:1.85;max-width:600px;}
.project-meta{text-align:right;padding-top:0.3rem;}
.project-year{font-family:var(--elite);font-size:0.62rem;color:var(--muted);letter-spacing:0.18em;display:block;margin-bottom:0.5rem;}
.project-arrow{font-size:1.2rem;color:var(--border-bright);transition:color 0.2s,transform 0.2s;}
.project-item:hover .project-arrow{color:var(--accent);transform:translate(4px,-4px)}

/* ── PROJECT DIVIDER ── */
.project-item + .project-item::before{
  content:'✦ ─────────────── ✦';
  position:absolute;top:-0.4rem;left:50%;transform:translateX(-50%);
  font-family:var(--elite);font-size:0.48rem;
  color:var(--border-bright);letter-spacing:0.1em;
  white-space:nowrap;
  background:transparent;padding:0 0.5rem;
}

/* ── WRITING ── */
.writing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;}
.writing-card{
  border:1px solid rgba(74,46,20,0.7);
  padding:1.75rem;
  background:rgba(26,18,8,0.30);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  position:relative;overflow:hidden;
  box-shadow:0 4px 18px rgba(0,0,0,0.45),inset 0 1px 0 rgba(200,145,42,0.1);
  transition:border-color 0.25s,transform 0.25s,box-shadow 0.25s;
  cursor:none;
}
.writing-card:nth-child(odd){transform:rotate(-0.4deg)}
.writing-card:nth-child(even){transform:rotate(0.35deg)}
.writing-card:hover{
  border-color:rgba(200,145,42,0.6);
  transform:rotate(0deg) translateY(-5px);
  box-shadow:0 10px 36px rgba(0,0,0,0.55),0 0 24px rgba(200,145,42,0.12),inset 0 1px 0 rgba(200,145,42,0.18);
}
.writing-card::after{
  content:'';
  position:absolute;bottom:0;right:0;
  width:22px;height:22px;
  background:linear-gradient(225deg,var(--bg) 50%,var(--border) 50%);
}
.writing-date{
  font-family:var(--elite);font-size:0.65rem;letter-spacing:0.18em;
  color:var(--muted);margin-bottom:1rem;text-transform:uppercase;
}
.writing-title{
  font-family:var(--fell);font-size:1.02rem;font-style:italic;
  color:var(--text);line-height:1.55;margin-bottom:0.75rem;
}
.writing-excerpt{font-family:var(--fell);font-size:0.8rem;color:rgba(232,220,200,0.85);line-height:1.85;}
.writing-tag{
  display:inline-block;margin-top:1rem;
  font-family:var(--elite);font-size:0.65rem;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--accent);
}

/* ── CONTACT ── */
#contact{position:relative;z-index:1;}
.contact-inner{
  max-width:1200px;margin:0 auto;padding:8rem 3rem;
  display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;
}
.contact-big{
  font-family:var(--rye);
  font-size:clamp(2.5rem,5vw,4.5rem);
  color:var(--text);line-height:1.15;letter-spacing:0.03em;
}
.contact-big em{font-style:italic;color:var(--accent);}
.contact-sub{
  font-family:var(--fell);font-style:italic;
  font-size:0.9rem;color:rgba(232,220,200,0.80);
  margin-top:1rem;line-height:1.8;
}
.contact-hint{
  font-family:var(--fell);font-size:0.88rem;
  color:rgba(232,220,200,0.60);margin-top:0.6rem;line-height:1.8;
  text-shadow:0 1px 8px rgba(0,0,0,0.8);
}
.contact-links{display:flex;flex-direction:column;gap:0.7rem;}
.contact-link{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem 1.5rem;
  border:1px solid rgba(74,46,20,0.7);
  border-left:3px solid var(--accent);
  color:var(--muted);text-decoration:none;
  font-family:var(--elite);font-size:0.72rem;
  letter-spacing:0.16em;text-transform:uppercase;
  background:rgba(26,18,8,0.30);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  box-shadow:0 4px 18px rgba(0,0,0,0.4),inset 0 1px 0 rgba(200,145,42,0.08);
  transition:color 0.2s,border-color 0.2s,transform 0.2s,box-shadow 0.2s;
}
.contact-link:hover{
  border-color:var(--accent);
  border-left-color:var(--accent);
  color:var(--accent);
  transform:translateX(5px);
  box-shadow:0 4px 24px rgba(0,0,0,0.5),inset 0 1px 0 rgba(200,145,42,0.2);
}

/* ── FOOTER ── */
footer{
  border-top:1px solid var(--border);padding:2rem 3rem;
  display:flex;justify-content:center;align-items:center;gap:1.5rem;
  font-family:var(--elite);font-size:0.65rem;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--muted);
  position:relative;z-index:1;
}
footer::before,footer::after{content:'✦';color:var(--accent);font-size:0.65rem}

/* ── ANIMATIONS ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.7s,transform 0.7s}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.12s}
.reveal-delay-2{transition-delay:0.24s}
.reveal-delay-3{transition-delay:0.36s}

/* ── CANVAS LAYERS ── */
#dust{position:fixed;inset:0;z-index:100;pointer-events:none;opacity:0.6}
#glow-canvas{position:fixed;inset:0;z-index:101;pointer-events:none;}
#ember-canvas{position:fixed;inset:0;z-index:5001;pointer-events:none;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}



/* ── RESPONSIVE ── */
@media(max-width:900px){
  .about-grid,.contact-inner{grid-template-columns:1fr;gap:3rem}
  .skills-grid{grid-template-columns:1fr}
  .writing-grid{grid-template-columns:1fr}
  .project-item{grid-template-columns:50px 1fr auto}
  nav{padding:1rem 1.5rem}
  #hero{padding:6rem 1.5rem 4rem}
  .hero-frame{padding:1.5rem}
  .section,.contact-inner{padding-left:1.5rem;padding-right:1.5rem}
  .nav-links{display:none}
  .scroll-hint{left:1.5rem}
}
