/* ════════════════════════════════════════
   DESIGN TOKENS — Blue theme
   ════════════════════════════════════════ */
:root {
  /* Surfaces */
  --bg:           #07090f;
  --surface:      #0d1117;
  --surface-2:    #131920;
  --surface-3:    #1a2130;
  --surface-4:    #202a3a;
  --divider:      #1e2d42;
  --border:       #2a3d56;

  /* Text */
  --text:         #e8edf5;
  --text-muted:   #8fa3bc;
  --text-faint:   #5a7290;
  --text-inverse: #07090f;

  /* Blue accent */
  --blue:         #4f8ef7;
  --blue-hover:   #3b7ef5;
  --blue-active:  #2563eb;
  --blue-hl:      rgba(79,142,247,0.10);
  --blue-border:  rgba(79,142,247,0.22);

  /* Type scale */
  --xs:   clamp(0.75rem,  0.70rem + 0.25vw, 0.875rem);
  --sm:   clamp(0.875rem, 0.80rem + 0.35vw, 1rem);
  --base: clamp(1rem,     0.95rem + 0.25vw, 1.125rem);
  --lg:   clamp(1.125rem, 1rem    + 0.75vw, 1.5rem);
  --xl:   clamp(1.5rem,   1.2rem  + 1.25vw, 2.25rem);
  --2xl:  clamp(2rem,     1.2rem  + 2.5vw,  3.5rem);
  --3xl:  clamp(2.5rem,   1rem    + 4vw,    5rem);
  --hero: clamp(3rem,     0.5rem  + 7vw,    8rem);

  /* Spacing */
  --s1:.25rem; --s2:.5rem;  --s3:.75rem; --s4:1rem;
  --s5:1.25rem;--s6:1.5rem; --s8:2rem;   --s10:2.5rem;
  --s12:3rem;  --s16:4rem;  --s20:5rem;  --s32:8rem;

  /* Radii */
  --r-sm:.375rem; --r-md:.5rem; --r-lg:.75rem;
  --r-xl:1rem;    --r-2xl:1.5rem; --r-full:9999px;

  --ease: 200ms cubic-bezier(.16,1,.3,1);
  --shadow-md: 0 4px 16px rgba(0,0,0,.45);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.6);

  --font-display: "Clash Display","Helvetica Neue",sans-serif;
  --font-body:    "Satoshi","Helvetica Neue",sans-serif;
  --max-w: 1200px;
}

[data-theme="light"] {
  --bg:           #f0f4fb;
  --surface:      #ffffff;
  --surface-2:    #eaf0fa;
  --surface-3:    #dde6f5;
  --surface-4:    #cdd9ee;
  --divider:      #c8d8ef;
  --border:       #b0c5e2;
  --text:         #0a1020;
  --text-muted:   #3a5070;
  --text-faint:   #7090b0;
  --text-inverse: #f0f4fb;
  --blue:         #1d4ed8;
  --blue-hover:   #1e40af;
  --blue-active:  #1e3a8a;
  --blue-hl:      rgba(29,78,216,0.10);
  --blue-border:  rgba(29,78,216,0.22);
  --shadow-md:    0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:    0 12px 40px rgba(0,0,0,.16);
}

/* ════════════════════════════════════════
   BASE RESET
   ════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:68px; -webkit-font-smoothing:antialiased; }
body { font-family:var(--font-body); font-size:var(--base); color:var(--text); background:var(--bg); line-height:1.65; overflow-x:hidden; }
img,svg { display:block; max-width:100%; }
button { cursor:pointer; background:none; border:none; font:inherit; color:inherit; }
a { text-decoration:none; color:inherit; }
h1,h2,h3,h4 { font-family:var(--font-display); line-height:1.06; text-wrap:balance; }
p { text-wrap:pretty; }
ul[role="list"] { list-style:none; }
::selection { background:var(--blue-hl); color:var(--text); }
:focus-visible { outline:2px solid var(--blue); outline-offset:3px; border-radius:var(--r-sm); }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:var(--r-full); }

/* ════════════════════════════════════════
   SKIP LINK
   ════════════════════════════════════════ */
.skip-link { position:absolute; top:-48px; left:var(--s4); z-index:999; background:var(--blue); color:var(--text-inverse); padding:var(--s2) var(--s5); border-radius:var(--r-md); font-size:var(--sm); font-weight:700; transition:top var(--ease); }
.skip-link:focus { top:var(--s3); }

/* ════════════════════════════════════════
   NAVBAR
   ════════════════════════════════════════ */
.site-nav { position:fixed; top:0; left:0; right:0; z-index:100; display:flex; align-items:center; justify-content:space-between; padding:0 var(--s8); height:64px; background:color-mix(in srgb,var(--bg) 85%,transparent); backdrop-filter:blur(14px) saturate(1.4); border-bottom:1px solid rgba(79,142,247,0.08); }
[data-theme="light"] .site-nav { border-bottom:1px solid var(--divider); }
.brand-logo { display:flex; align-items:center; gap:var(--s2); font-family:var(--font-display); font-size:var(--lg); font-weight:700; letter-spacing:-.02em; }
.brand-dot { color:var(--blue); }
.nav-menu { display:flex; align-items:center; gap:var(--s6); list-style:none; }
.nav-menu a { font-size:var(--sm); font-weight:500; color:var(--text-muted); transition:color var(--ease); }
.nav-menu a:hover { color:var(--text); }
.nav-controls { display:flex; align-items:center; gap:var(--s3); }
.theme-toggle { display:flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:var(--r-full); background:var(--surface-2); border:1px solid var(--border); color:var(--text-muted); transition:all var(--ease); }
.theme-toggle:hover { color:var(--text); background:var(--surface-3); }
.contact-cta { display:inline-flex; align-items:center; padding:var(--s2) var(--s5); border-radius:var(--r-full); background:var(--blue); color:var(--text-inverse); font-size:var(--sm); font-weight:700; transition:all var(--ease); }
.contact-cta:hover { background:var(--blue-hover); transform:translateY(-1px); }
.mobile-menu-btn { display:none; flex-direction:column; justify-content:center; gap:5px; width:40px; height:40px; padding:var(--s2); border-radius:var(--r-md); }
.mobile-menu-btn span { display:block; height:2px; background:var(--text); border-radius:var(--r-full); transition:all var(--ease); }
.mobile-menu { display:none; position:fixed; top:64px; left:0; right:0; z-index:98; background:var(--surface); border-bottom:1px solid var(--border); padding:var(--s4) var(--s8); }
.mobile-menu.open { display:block; }
.mobile-menu a { display:block; padding:var(--s3) 0; font-size:var(--base); color:var(--text-muted); border-bottom:1px solid var(--divider); transition:color var(--ease); }
.mobile-menu a:last-child { border-bottom:none; }
.mobile-menu a:hover { color:var(--text); }
@media(max-width:768px) { .nav-menu,.contact-cta{display:none} .mobile-menu-btn{display:flex} .site-nav{padding:0 var(--s4)} }

/* ════════════════════════════════════════
   SHARED
   ════════════════════════════════════════ */
.page-wrap { max-width:var(--max-w); margin-inline:auto; width:100%; }
.section-eyebrow { font-size:var(--xs); font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--blue); margin-bottom:var(--s3); }
.section-title { font-size:var(--2xl); font-weight:700; letter-spacing:-.025em; margin-bottom:var(--s4); }
.section-subtitle { font-size:var(--base); color:var(--text-muted); max-width:52ch; line-height:1.75; }
.btn-primary { display:inline-flex; align-items:center; gap:var(--s2); padding:var(--s3) var(--s8); border-radius:var(--r-full); background:var(--blue); color:var(--text-inverse); font-size:var(--sm); font-weight:700; transition:all var(--ease); }
.btn-primary:hover { background:var(--blue-hover); transform:translateY(-2px); box-shadow:0 8px 28px rgba(79,142,247,.35); }
.btn-outline { display:inline-flex; align-items:center; gap:var(--s2); padding:var(--s3) var(--s8); border-radius:var(--r-full); border:1px solid var(--border); color:var(--text-muted); font-size:var(--sm); font-weight:600; transition:all var(--ease); }
.btn-outline:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-hl); }

/* ════════════════════════════════════════
   INTRO SECTION  (hero + about merged)
   ════════════════════════════════════════ */
.intro-section { position:relative; overflow:hidden; padding:calc(64px + var(--s20)) var(--s8) var(--s20); }
.intro-glow { position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 80% 70% at 75% 40%,rgba(79,142,247,.08) 0%,transparent 65%),radial-gradient(ellipse 40% 40% at 20% 75%,rgba(30,64,175,.06) 0%,transparent 55%); }
.intro-grid-bg { position:absolute; inset:0; pointer-events:none; background-image:linear-gradient(rgba(79,142,247,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(79,142,247,.04) 1px,transparent 1px); background-size:56px 56px; mask-image:radial-gradient(ellipse 85% 85% at 50% 40%,black 0%,transparent 100%); }
[data-theme="light"] .intro-grid-bg { background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px); }

.intro-layout { position:relative; z-index:1; display:grid; grid-template-columns:1fr 420px; gap:var(--s16); align-items:start; padding-top:var(--s8); }

/* Bio column */
.intro-heading { font-size:var(--hero); font-weight:700; letter-spacing:-.035em; line-height:.92; margin-bottom:var(--s5); margin-top:var(--s2); }
.name-accent { color:var(--blue); }
.intro-tagline { font-size:var(--lg); color:var(--text-muted); max-width:48ch; margin-bottom:var(--s8); line-height:1.65; }
.bio-paragraph { font-size:var(--base); color:var(--text-muted); line-height:1.85; margin-bottom:var(--s5); max-width:56ch; }
.bio-paragraph strong { color:var(--text); }
.social-links { display:flex; gap:var(--s3); flex-wrap:wrap; margin-bottom:var(--s8); }
.social-link { display:inline-flex; align-items:center; gap:var(--s2); padding:var(--s2) var(--s4); border-radius:var(--r-lg); border:1px solid var(--border); font-size:var(--sm); color:var(--text-muted); transition:all var(--ease); }
.social-link:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-hl); }
.education-list { display:flex; flex-direction:column; gap:var(--s3); margin-bottom:var(--s8); }
.education-item { padding:var(--s4) var(--s5); border-radius:var(--r-xl); background:var(--surface-2); border:1px solid var(--border); transition:border-color var(--ease); }
.education-item:hover { border-color:var(--blue-border); }
.school-name  { font-family:var(--font-display); font-size:var(--base); font-weight:600; margin-bottom:2px; }
.degree-name  { font-size:var(--sm); color:var(--text-muted); margin-bottom:var(--s2); }
.school-location { font-size:var(--xs); color:var(--blue); font-weight:700; letter-spacing:.05em; }
.intro-actions { display:flex; align-items:center; gap:var(--s4); flex-wrap:wrap; }

/* Visual column */
.intro-visual { display:flex; flex-direction:column; gap:var(--s8); }
.profile-photo-wrap { position:relative; }
.profile-photo { width:100%; height:auto; border-radius:var(--r-2xl); object-fit:cover; aspect-ratio:5/6; box-shadow:var(--shadow-lg),0 0 0 1px var(--blue-border); display:block; }
.profile-badge { position:absolute; bottom:calc(-1 * var(--s5)); left:calc(-1 * var(--s5)); display:inline-flex; align-items:center; gap:var(--s2); padding:var(--s2) var(--s4); border-radius:var(--r-full); background:var(--surface); border:1px solid var(--blue-border); box-shadow:var(--shadow-md); font-size:var(--xs); font-weight:700; color:var(--blue); letter-spacing:.06em; text-transform:uppercase; white-space:nowrap; }

/* Skills panel */
.skills-panel { display:flex; flex-direction:column; gap:var(--s6); padding-top:var(--s6); }
.skill-group { display:flex; flex-direction:column; gap:var(--s2); }
.skill-group-title { font-size:var(--xs); font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--text-faint); margin-bottom:var(--s2); }
.skill-tags { display:flex; flex-wrap:wrap; gap:var(--s2); }
.skill-tag { padding:var(--s2) var(--s4); border-radius:var(--r-lg); background:var(--surface-2); border:1px solid var(--border); font-size:var(--sm); color:var(--text-muted); font-weight:500; transition:all var(--ease); }
.skill-tag:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-hl); }
.skill-tag.highlight { background:var(--blue-hl); border-color:var(--blue-border); color:var(--blue); }

.scroll-hint { position:absolute; bottom:var(--s6); left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:var(--s2); color:var(--text-faint); font-size:var(--xs); letter-spacing:.1em; text-transform:uppercase; animation:bob 2.2s ease-in-out infinite; }
@keyframes bob { 0%,100%{transform:translateX(-50%) translateY(0)} 50%{transform:translateX(-50%) translateY(7px)} }

@media(max-width:960px) { .intro-layout { grid-template-columns:1fr; gap:var(--s12); } .intro-visual { max-width:480px; } }
@media(max-width:640px) { .intro-section { padding:calc(64px + var(--s12)) var(--s4) var(--s16); } .intro-heading { font-size:clamp(3rem,12vw,5rem); } .profile-badge { bottom:calc(-1 * var(--s4)); left:50%; transform:translateX(-50%); } }

/* ════════════════════════════════════════
   PORTFOLIO SECTION
   ════════════════════════════════════════ */
.portfolio-section { background:var(--surface); padding:clamp(var(--s16),8vw,var(--s32)) var(--s8); }
.portfolio-header { display:flex; align-items:flex-end; justify-content:space-between; flex-wrap:wrap; gap:var(--s8); margin-bottom:var(--s12); }
.category-filters { display:flex; gap:var(--s2); flex-wrap:wrap; }
.filter-btn { padding:var(--s2) var(--s4); border-radius:var(--r-full); background:var(--surface-2); border:1px solid var(--border); font-size:var(--sm); font-weight:600; color:var(--text-muted); transition:all var(--ease); }
.filter-btn:hover { color:var(--text); }
.filter-btn.active { background:var(--blue); color:var(--text-inverse); border-color:var(--blue); }

/* Work category rows */
.work-category { margin-bottom:var(--s16); }
.work-category:last-child { margin-bottom:0; }
.work-category.hidden { display:none; }
.category-header { display:flex; align-items:center; gap:var(--s4); margin-bottom:var(--s8); }
.category-title { font-size:var(--xs); font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--text-faint); white-space:nowrap; }
.category-divider { flex:1; height:1px; background:var(--divider); }

/* Grids */
.projects-grid { display:grid; gap:var(--s6); }
.projects-grid--two-col { grid-template-columns:repeat(2,1fr); }
.projects-grid--one-col  { grid-template-columns:1fr; }
@media(max-width:640px) { .projects-grid--two-col { grid-template-columns:1fr; } }

/* Project cards */
.project-card { border-radius:var(--r-2xl); overflow:hidden; background:var(--surface-2); border:1px solid rgba(79,142,247,.06); transition:all var(--ease); }
[data-theme="light"] .project-card { border-color:var(--border); }
.project-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg),0 0 0 1px var(--blue-hl); border-color:var(--blue-border); }
.project-card--wide:hover { transform:none; box-shadow:0 0 0 2px var(--blue-border),var(--shadow-md); }

/* Project image containers */
.project-image { width:100%; aspect-ratio:4/3; position:relative; overflow:hidden; background:var(--surface-3); }
.project-image img { width:100%; height:100%; object-fit:cover; object-position:center; display:block; transition:transform 500ms cubic-bezier(.16,1,.3,1); }
.project-card:not(.project-card--wide):hover .project-image img { transform:scale(1.05); }

.project-image--contain { background:#f8f8f8; padding:var(--s8); }
.project-image--contain img { object-fit:contain; object-position:center; }
.project-card:hover .project-image--contain img { transform:scale(1.03); }

.project-image--poster { background:#0d0e1a; }
.project-image--poster img { object-fit:contain; object-position:center; }
.project-card:hover .project-image--poster img { transform:scale(1.03); }

.project-image--natural { aspect-ratio:unset; background:var(--surface-3); }
.project-image--natural img { width:100%; height:auto; object-fit:fill; display:block; transition:opacity var(--ease); }
.project-card--wide:hover .project-image--natural img { opacity:.92; }

/* Expand overlay */
.image-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(79,142,247,0); transition:background var(--ease); }
.project-card:hover .image-overlay { background:rgba(79,142,247,.07); }
.expand-btn { opacity:0; transform:scale(.88); padding:var(--s2) var(--s5); border-radius:var(--r-full); background:var(--blue); color:var(--text-inverse); font-size:var(--sm); font-weight:700; transition:all 260ms cubic-bezier(.16,1,.3,1); }
.project-card:hover .expand-btn { opacity:1; transform:scale(1); }

/* Project info */
.project-details { padding:var(--s5); }
.project-category-tag { display:inline-block; margin-bottom:var(--s2); padding:3px var(--s3); border-radius:var(--r-full); font-size:var(--xs); font-weight:700; letter-spacing:.05em; text-transform:uppercase; }
.tag--logo   { background:var(--blue-hl); color:var(--blue); border:1px solid var(--blue-border); }
.tag--poster { background:rgba(168,85,247,.12); color:#c084fc; border:1px solid rgba(168,85,247,.22); }
.tag--web    { background:rgba(34,197,94,.12);  color:#4ade80; border:1px solid rgba(34,197,94,.22); }
.tag--3d     { background:rgba(251,146,60,.12); color:#fb923c; border:1px solid rgba(251,146,60,.22); }
.project-title { font-family:var(--font-display); font-size:var(--lg); font-weight:600; letter-spacing:-.01em; margin-bottom:var(--s1); }
.project-description { font-size:var(--sm); color:var(--text-muted); line-height:1.6; }

/* Wide card layout */
.project-card--wide .project-details { display:flex; flex-wrap:wrap; align-items:flex-start; gap:var(--s4); padding:var(--s5) var(--s6); }
.project-card--wide .project-category-tag { flex-shrink:0; }
.project-card--wide .project-title { width:100%; margin-bottom:0; }
.project-card--wide .project-description { flex:1; min-width:200px; margin-bottom:0; }
.card-footer { flex-shrink:0; display:flex; align-items:center; }
.visit-website-btn { display:inline-flex; align-items:center; gap:var(--s2); padding:var(--s2) var(--s4); border-radius:var(--r-full); background:var(--blue-hl); border:1px solid var(--blue-border); color:var(--blue); font-size:var(--xs); font-weight:700; letter-spacing:.04em; text-transform:uppercase; transition:all var(--ease); }
.visit-website-btn:hover { background:var(--blue); color:var(--text-inverse); transform:translateY(-1px); box-shadow:0 4px 14px rgba(79,142,247,.3); }
@media(max-width:640px) { .project-card--wide .project-details { flex-direction:column; } .project-card--wide .project-description { min-width:unset; } }

/* ════════════════════════════════════════
   CONTACT SECTION
   ════════════════════════════════════════ */
.contact-section { text-align:center; position:relative; overflow:hidden; padding:clamp(var(--s16),8vw,var(--s32)) var(--s8); }
.contact-glow { position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 60% 55% at 50% 50%,rgba(79,142,247,.07) 0%,transparent 70%); }
.contact-section .page-wrap { position:relative; z-index:1; }
.contact-heading { font-size:var(--3xl); font-weight:700; letter-spacing:-.035em; margin-bottom:var(--s4); }
.contact-tagline { font-size:var(--base); color:var(--text-muted); max-width:40ch; margin:0 auto var(--s10); line-height:1.75; }
.contact-actions { display:flex; gap:var(--s4); justify-content:center; flex-wrap:wrap; }

/* ════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════ */
.site-footer { padding:var(--s8); border-top:1px solid var(--divider); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:var(--s4); }
.footer-brand { font-family:var(--font-display); font-weight:700; font-size:var(--base); }
.footer-brand em { font-style:normal; color:var(--blue); }
.footer-copy { font-size:var(--xs); color:var(--text-faint); }
.footer-links { display:flex; gap:var(--s5); }
.footer-links a { font-size:var(--xs); color:var(--text-faint); transition:color var(--ease); }
.footer-links a:hover { color:var(--blue); }

/* ════════════════════════════════════════
   LIGHTBOX
   ════════════════════════════════════════ */
.lightbox { position:fixed; inset:0; z-index:900; display:flex; align-items:center; justify-content:center; background:rgba(0,0,0,.90); backdrop-filter:blur(14px); opacity:0; pointer-events:none; transition:opacity 280ms cubic-bezier(.16,1,.3,1); padding:var(--s8); }
.lightbox.open { opacity:1; pointer-events:all; }
.lb-inner { display:flex; flex-direction:column; align-items:center; gap:var(--s4); max-width:min(90vw,1100px); transform:scale(.93) translateY(12px); transition:transform 320ms cubic-bezier(.16,1,.3,1); }
.lightbox.open .lb-inner { transform:scale(1) translateY(0); }
.lb-photo { max-width:100%; max-height:82vh; width:auto; height:auto; border-radius:var(--r-xl); box-shadow:0 32px 80px rgba(0,0,0,.7),0 0 0 1px rgba(255,255,255,.07); display:block; object-fit:contain; }
.lb-caption { font-family:var(--font-display); font-size:var(--base); font-weight:600; color:rgba(255,255,255,.72); text-align:center; }
.lb-close { position:fixed; top:var(--s5); right:var(--s5); width:44px; height:44px; display:flex; align-items:center; justify-content:center; border-radius:var(--r-full); background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15); color:#fff; transition:background var(--ease),transform var(--ease); z-index:910; }
.lb-close:hover { background:rgba(255,255,255,.2); transform:rotate(90deg); }
@media(max-width:640px) { .lightbox{padding:var(--s4)} .lb-photo{max-height:75vh} .lb-close{top:var(--s3);right:var(--s3)} }

/* ════════════════════════════════════════
   SCROLL REVEAL
   ════════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(22px); transition:opacity 600ms cubic-bezier(.16,1,.3,1),transform 600ms cubic-bezier(.16,1,.3,1); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal.delay-1 { transition-delay:100ms; }
.reveal.delay-2 { transition-delay:200ms; }
.reveal.delay-3 { transition-delay:300ms; }
.reveal.delay-4 { transition-delay:400ms; }
@media(prefers-reduced-motion:reduce) { *,*::before,*::after { animation-duration:.01ms !important; transition-duration:.01ms !important; } }
