:root{--color-bg-base: #050916;--color-bg-deep: #090f24;--color-surface: rgba(10, 20, 44, .72);--color-surface-strong: rgba(12, 24, 52, .9);--color-border: rgba(106, 235, 255, .26);--color-text-primary: #eef6ff;--color-text-secondary: #b8c7da;--color-accent: #6aebff;--color-accent-strong: #2dd8f2;--color-accent-alt: #ffbe55;--color-shadow: rgba(3, 8, 24, .55);--color-shadow-glow: rgba(106, 235, 255, .22);--font-heading: "Orbitron", "Segoe UI", sans-serif;--font-body: "Manrope", "Segoe UI", sans-serif;--radius-sm: .75rem;--radius-md: 1.1rem;--radius-lg: 1.8rem;--space-2xs: .35rem;--space-xs: .65rem;--space-sm: .9rem;--space-md: 1.2rem;--space-lg: 1.8rem;--space-xl: 2.4rem;--space-2xl: 3.4rem;--space-3xl: 4.8rem;--max-width: 72rem;--ring-soft: 0 0 0 1px var(--color-border), 0 18px 30px -22px var(--color-shadow);--ring-focus: 0 0 0 2px rgba(106, 235, 255, .36), 0 0 0 5px rgba(106, 235, 255, .15);--duration-fast: .16s;--duration-medium: .28s;--duration-slow: 12s;--ease-smooth: cubic-bezier(.2, .7, .2, 1)}*,*:before,*:after{box-sizing:border-box}html{color-scheme:dark;scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:var(--font-body);color:var(--color-text-primary);background:radial-gradient(circle at 12% 18%,rgba(45,216,242,.16),transparent 34%),radial-gradient(circle at 84% 16%,rgba(255,190,85,.08),transparent 28%),linear-gradient(165deg,var(--color-bg-base),var(--color-bg-deep));line-height:1.65}main{position:relative;z-index:1;padding-bottom:var(--space-3xl)}a{color:inherit}img{display:block;width:100%;height:auto}.skip-link{position:absolute;left:.75rem;top:-3rem;z-index:100;padding:.6rem .9rem;color:#00131e;background:var(--color-accent);border-radius:var(--radius-sm);font-weight:700;transition:top var(--duration-fast) var(--ease-smooth)}.skip-link:focus{top:.75rem}.site-bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}.site-bg>div{position:absolute;inset:0}.site-bg__stars{background-image:radial-gradient(circle at 10% 14%,rgba(255,255,255,.72) 0,rgba(255,255,255,.72) 1px,transparent 1.5px),radial-gradient(circle at 80% 30%,rgba(255,255,255,.45) 0,rgba(255,255,255,.45) 1px,transparent 1.5px),radial-gradient(circle at 24% 68%,rgba(106,235,255,.5) 0,rgba(106,235,255,.5) 1px,transparent 1.5px),radial-gradient(circle at 64% 80%,rgba(255,190,85,.35) 0,rgba(255,190,85,.35) 1px,transparent 1.5px);background-size:260px 260px,320px 320px,280px 280px,360px 360px;opacity:.55;animation:starDrift var(--duration-slow) linear infinite}.site-bg__nebula{background:radial-gradient(circle at 20% 22%,rgba(45,216,242,.2),transparent 45%),radial-gradient(circle at 76% 72%,rgba(255,190,85,.14),transparent 42%);filter:blur(12px);opacity:.6}.site-bg__rings{background:radial-gradient(circle at 16% -12%,rgba(106,235,255,.16),transparent 42%),radial-gradient(circle at 90% 110%,rgba(255,190,85,.14),transparent 50%)}.section{position:relative;padding:clamp(var(--space-2xl),7vw,7rem) var(--space-md) 0}.section__inner{width:min(var(--max-width),100%);margin-inline:auto;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--ring-soft);backdrop-filter:blur(8px);padding:clamp(var(--space-lg),4vw,var(--space-2xl))}.section__title{margin:0;font-family:var(--font-heading);font-size:clamp(1.55rem,3vw,2.3rem);letter-spacing:.02em}.section__lead{margin:var(--space-sm) 0 var(--space-lg);color:var(--color-text-secondary);max-width:60ch}.eyebrow{margin:0 0 var(--space-sm);color:var(--color-accent);letter-spacing:.22em;text-transform:uppercase;font-size:.73rem;font-weight:700}.hero{min-height:min(100vh,52rem);display:grid;align-items:center;padding-top:clamp(var(--space-xl),6vw,4.8rem)}.hero__inner{position:relative;overflow:hidden}.hero h1{margin:0;font-family:var(--font-heading);font-size:clamp(2.4rem,9vw,4.25rem);line-height:1.05;letter-spacing:.03em}.hero__subtitle{margin:var(--space-md) 0 var(--space-sm);font-size:clamp(1.05rem,2.5vw,1.45rem);color:var(--color-accent-alt);max-width:42ch}.hero__summary{margin:0;max-width:62ch;color:var(--color-text-secondary)}.hero__actions{margin-top:var(--space-xl);display:flex;flex-wrap:wrap;gap:var(--space-sm)}.hero__orbits{position:absolute;inset:0;width:min(var(--max-width),100%);margin-inline:auto;pointer-events:none;z-index:-1}.orbit{position:absolute;border:1px solid rgba(106,235,255,.28);border-radius:999px}.orbit--one{width:24rem;height:24rem;right:-5rem;top:1rem;animation:spinClockwise 20s linear infinite}.orbit--two{width:16rem;height:16rem;right:2rem;top:5rem;border-color:#ffbe553d;animation:spinCounterClockwise 16s linear infinite}.orbit--three{width:10rem;height:10rem;right:5rem;top:8rem;border-color:#6aebff6b;animation:pulse 4.6s ease-in-out infinite}.button{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border-radius:999px;border:1px solid transparent;padding:.65rem 1.05rem;font-weight:700;font-size:.92rem;letter-spacing:.015em;text-decoration:none;cursor:pointer;transition:transform var(--duration-fast) var(--ease-smooth),box-shadow var(--duration-fast) var(--ease-smooth),border-color var(--duration-fast) var(--ease-smooth),background-color var(--duration-fast) var(--ease-smooth)}.button:hover{transform:translateY(-1px)}.button:focus-visible{outline:none;box-shadow:var(--ring-focus)}.button--primary{color:#04111f;background:linear-gradient(120deg,var(--color-accent),var(--color-accent-strong));box-shadow:0 10px 20px -14px var(--color-shadow-glow)}.button--primary:hover{box-shadow:0 14px 28px -14px var(--color-shadow-glow)}.button--ghost{color:var(--color-text-primary);background-color:#0810228c;border-color:var(--color-border)}.button--ghost:hover{border-color:#6aebff8c}#about p:last-child{margin-bottom:0;max-width:64ch}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(14rem,1fr));gap:var(--space-md);margin:0;padding:0;list-style:none}.skill-card{background:var(--color-surface-strong);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.skill-card h3{margin:0 0 var(--space-sm);font-family:var(--font-heading);font-size:.93rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-alt)}.chip-list{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:var(--space-xs)}.chip-list--tight{margin-top:var(--space-sm)}.chip{border:1px solid rgba(106,235,255,.34);background:#071126c7;border-radius:999px;padding:.26rem .66rem;font-size:.74rem;font-weight:600;color:var(--color-text-secondary)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(17.6rem,1fr));gap:var(--space-md)}.project-card{position:relative;background:var(--color-surface-strong);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:transform var(--duration-medium) var(--ease-smooth),border-color var(--duration-medium) var(--ease-smooth),box-shadow var(--duration-medium) var(--ease-smooth)}.project-card:hover{transform:translateY(-3px);border-color:#6aebff73;box-shadow:0 18px 28px -20px var(--color-shadow-glow)}.project-card__image{aspect-ratio:16 / 9;object-fit:cover;border-bottom:1px solid rgba(106,235,255,.2)}.project-card__body{padding:var(--space-md);display:grid;gap:var(--space-sm)}.project-card__body h3{margin:0;font-size:1.08rem;font-family:var(--font-heading);letter-spacing:.02em}.project-card__body p{margin:0;color:var(--color-text-secondary)}.project-card__actions{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.project-modal{width:min(52rem,calc(100% - 1.5rem));max-height:calc(100% - 2rem);border:none;padding:0;color:var(--color-text-primary);background:transparent}.project-modal::backdrop{background:#01050eb8;backdrop-filter:blur(4px)}.project-modal__surface{position:relative;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(180deg,#08142af5,#060e1ff5);box-shadow:0 24px 48px -32px var(--color-shadow);padding:var(--space-lg);overflow:auto;max-height:calc(100vh - 2.5rem)}.project-modal__close{position:sticky;top:0;margin-left:auto;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(106,235,255,.34);background:#071024d9;color:var(--color-text-primary);padding:.35rem .8rem;font-weight:700;cursor:pointer}.project-modal__close:focus-visible{outline:none;box-shadow:var(--ring-focus)}.project-modal__gallery{margin-top:var(--space-sm);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-sm)}.project-modal__image{border-radius:var(--radius-md);aspect-ratio:16 / 9;object-fit:cover;border:1px solid rgba(106,235,255,.24)}.project-modal__image--primary{grid-column:1 / -1}.project-modal__header{margin-top:var(--space-lg)}.project-modal__header h3{margin:0;font-size:clamp(1.3rem,3vw,1.7rem);font-family:var(--font-heading)}.project-modal__header p{margin:var(--space-xs) 0 0;color:var(--color-text-secondary)}.project-modal__content{margin-top:var(--space-md);color:var(--color-text-secondary)}.project-modal__content :global(h2),.project-modal__content :global(h3){color:var(--color-text-primary);margin:var(--space-lg) 0 var(--space-xs);font-size:1rem;font-family:var(--font-heading);letter-spacing:.03em}.project-modal__content :global(p),.project-modal__content :global(ul){margin:0 0 var(--space-sm)}.project-modal__content :global(ul){padding-left:1.1rem}.project-modal__links{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-lg)}.contact{display:grid;justify-items:start;gap:var(--space-sm)}.contact__note{margin:0;color:var(--color-text-secondary);font-size:.9rem}code{padding:.08rem .34rem;background:#091326d1;border:1px solid rgba(106,235,255,.34);border-radius:.34rem}@media(max-width:48rem){.section{padding-inline:var(--space-sm)}.hero{min-height:auto}.hero__actions{width:100%}.hero__actions .button{flex:1}.orbit{opacity:.45}.project-modal__surface{padding:var(--space-md)}.project-modal__gallery{grid-template-columns:1fr}.project-modal__image--primary{grid-column:auto}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important}}@keyframes starDrift{0%{transform:translateZ(0)}to{transform:translate3d(-80px,30px,0)}}@keyframes spinClockwise{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spinCounterClockwise{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.04)}}
