@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght,SOFT@0,9..144,300..900,0..100;1,9..144,300..900,0..100&family=Instrument+Sans:ital,wght@0,400..700;1,400..700&family=JetBrains+Mono:wght@300..600&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #0a0908;--bg-card: #14110f;--bg-elev: #1a1612;--ink: #ECE5DA;--ink-dim: #847C70;--ink-faint: #4A4339;--rule: rgba(236, 229, 218, .08);--rule-strong: rgba(236, 229, 218, .16);--accent: #d4a574;--accent2: #b8895a;--glow: rgba(212, 165, 116, .15);--font-display: "Fraunces", "Times New Roman", serif;--font-body: "Instrument Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--maxw: 1140px}html{scroll-behavior:smooth}html,body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}body{min-height:100vh;position:relative;padding-top:80px}a{color:inherit;text-decoration:none}::selection{background:var(--accent);color:var(--bg)}.noise{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background:radial-gradient(1100px circle at 20% 0%,var(--glow),transparent 50%),radial-gradient(900px circle at 100% 100%,var(--glow),transparent 55%),url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");background-size:100% 100%,100% 100%,220px 220px;opacity:.55;mix-blend-mode:overlay}body>*:not(.noise){position:relative;z-index:2}.nav{position:fixed;top:0;left:0;right:0;height:64px;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;background:#0a0908b3;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--rule)}.nav-logo{font-family:var(--font-display);font-variation-settings:"opsz" 144,"wght" 500;font-style:italic;font-size:22px;letter-spacing:-.02em;color:var(--ink);position:relative}.nav-logo:after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .5s cubic-bezier(.2,.8,.2,1)}.nav-logo:hover:after{transform:scaleX(1);transform-origin:left}.nav-links{display:flex;align-items:center;gap:6px}.nav-links a{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);padding:8px 14px;transition:color .3s ease;position:relative}.nav-links a:hover{color:var(--ink)}.nav-links a:not(.nav-btn):before{content:"§";margin-right:6px;color:var(--ink-faint);transition:color .3s ease}.nav-links a:not(.nav-btn):hover:before{color:var(--accent)}.nav-btn{border:1px solid var(--rule-strong);border-radius:4px;margin-left:12px;padding:8px 18px!important;color:var(--ink)!important;transition:all .3s ease!important}.nav-btn:hover{background:var(--accent);color:var(--bg)!important;border-color:var(--accent)}.hero{max-width:var(--maxw);margin:0 auto;padding:80px 40px 120px;display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:center;min-height:calc(100vh - 80px)}.hero-content{position:relative}.hero-badge{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:32px;padding:6px 14px 6px 12px;border-top:1px solid var(--accent);border-bottom:1px solid var(--rule);width:fit-content}.hero-badge:before{content:"◆";font-size:8px;opacity:.6}.hero-title{font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 30,"wght" 500;font-size:clamp(56px,9vw,120px);line-height:.95;letter-spacing:-.04em;margin-bottom:28px;color:var(--ink)}.hero-title:first-letter{font-style:italic;font-variation-settings:"opsz" 144,"SOFT" 100,"wght" 400;color:var(--accent)}.hero-sub{font-family:var(--font-display);font-variation-settings:"opsz" 14,"wght" 400;font-style:italic;font-size:19px;line-height:1.55;color:var(--ink-dim);max-width:38ch;margin-bottom:40px}.hero-links{display:flex;gap:12px;flex-wrap:wrap}.hero-link{display:inline-flex;align-items:center;gap:10px;padding:14px 22px;border:1px solid var(--rule-strong);border-radius:4px;font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);transition:all .4s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden}.hero-link svg{width:14px;height:14px;position:relative;z-index:1}.hero-link span,.hero-link{position:relative;z-index:1}.hero-link:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent);transform:translateY(100%);transition:transform .4s cubic-bezier(.2,.8,.2,1);z-index:0}.hero-link:hover{border-color:var(--accent);color:var(--bg)}.hero-link:hover:before{transform:translateY(0)}.hero-link-accent{background:var(--accent);color:var(--bg);border-color:var(--accent)}.hero-link-accent:before{background:var(--ink)}.hero-visual{position:relative}.hero-visual:before{content:"";position:absolute;top:-24px;right:-24px;bottom:-24px;left:-24px;background:radial-gradient(circle at 50% 50%,var(--glow),transparent 65%);filter:blur(60px);z-index:-1}.code-block{background:var(--bg-card);border:1px solid var(--rule);border-radius:6px;overflow:hidden;box-shadow:0 30px 60px -20px #0009,inset 0 1px #ffffff0a;position:relative}.code-block:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.6;z-index:1}.code-header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--rule);background:#ffffff04}.dot{display:none}.code-header:before{content:"◦";color:var(--accent);font-size:12px}.code-filename{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-dim)}.code-content{font-family:var(--font-mono);font-size:13px;line-height:1.85;padding:24px;color:var(--ink);white-space:pre-wrap;font-weight:400}.kw{color:var(--accent);font-style:italic}.var{color:var(--ink)}.key{color:var(--ink-dim)}.str{color:var(--accent2)}.section{max-width:var(--maxw);margin:0 auto;padding:100px 40px;position:relative}.section+.section{border-top:1px solid var(--rule)}.section-title{font-family:var(--font-display);font-variation-settings:"opsz" 144,"SOFT" 30,"wght" 500;font-size:clamp(40px,5.5vw,64px);line-height:1;letter-spacing:-.03em;margin-bottom:56px;text-transform:lowercase;display:flex;align-items:baseline;gap:24px}.section-title:before{font-family:var(--font-mono);font-size:12px;font-weight:400;letter-spacing:.2em;color:var(--ink-faint);text-transform:uppercase}#about .section-title:before{content:"§ 01"}#skills .section-title:before{content:"§ 02"}#projects .section-title:before{content:"§ 03"}#setup .section-title:before{content:"§ 04"}#palette .section-title:before{content:"§ 05"}.section-title:after{content:"";flex:1;height:1px;background:var(--rule);align-self:center;margin-left:8px}.about-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:80px;align-items:start}.about-text p{font-family:var(--font-display);font-variation-settings:"opsz" 14,"wght" 400;font-size:18px;line-height:1.7;color:var(--ink);margin-bottom:22px;max-width:56ch}.about-text p:nth-child(2){font-style:italic;color:var(--ink-dim)}.about-stats{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--rule)}.about-stat{display:grid;grid-template-columns:1fr auto;align-items:baseline;padding:22px 0;border-bottom:1px solid var(--rule)}.about-stat-num{font-family:var(--font-display);font-variation-settings:"opsz" 144,"wght" 400;font-size:56px;line-height:1;color:var(--accent);letter-spacing:-.03em;font-feature-settings:"lnum"}.about-stat-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim)}.skills-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--rule)}.skill-card{display:grid;grid-template-columns:auto 1fr;gap:24px;align-items:start;padding:28px 16px;border-bottom:1px solid var(--rule);position:relative;transition:background .4s ease,padding-left .4s cubic-bezier(.2,.8,.2,1)}.skill-card:nth-child(odd){border-right:1px solid var(--rule)}.skill-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:var(--accent);transition:width .4s cubic-bezier(.2,.8,.2,1)}.skill-card:hover{padding-left:28px;background:#ffffff04}.skill-card:hover:before{width:2px}.skill-icon{width:36px;height:36px;border:1px solid var(--rule-strong);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.skill-icon svg{width:18px;height:18px}.skill-card h3{font-family:var(--font-display);font-variation-settings:"opsz" 144,"wght" 500;font-size:22px;letter-spacing:-.015em;margin-bottom:6px;color:var(--ink)}.skill-card p{font-family:var(--font-display);font-variation-settings:"opsz" 14,"wght" 400;font-style:italic;font-size:14px;color:var(--ink-dim);line-height:1.55}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.project-card{background:var(--bg-card);border:1px solid var(--rule);border-radius:8px;padding:32px 28px;position:relative;overflow:hidden;transition:border-color .4s ease,transform .4s cubic-bezier(.2,.8,.2,1)}.project-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .4s ease}.project-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;mix-blend-mode:overlay}.project-card:hover{border-color:var(--rule-strong);transform:translateY(-3px)}.project-card:hover:before{opacity:.7}.project-card>*{position:relative;z-index:1}.project-tag{display:inline-block;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);padding:4px 10px;border:1px solid var(--accent);border-radius:2px;margin-bottom:20px}.project-card h3{font-family:var(--font-display);font-variation-settings:"opsz" 144,"wght" 500;font-size:30px;letter-spacing:-.02em;margin-bottom:14px;color:var(--ink)}.project-card p{font-family:var(--font-display);font-variation-settings:"opsz" 14,"wght" 400;font-style:italic;font-size:15px;line-height:1.65;color:var(--ink-dim);margin-bottom:24px}.project-tech{display:flex;flex-wrap:wrap;gap:6px}.project-tech span{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);padding:4px 10px;border:1px solid var(--rule);border-radius:2px}.setup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}.setup-card{padding:36px 28px;border-right:1px solid var(--rule);transition:background .4s ease}.setup-card:last-child{border-right:none}.setup-card:hover{background:#ffffff04}.setup-icon{width:40px;height:40px;border:1px solid var(--rule-strong);border-radius:4px;display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:22px}.setup-icon svg{width:20px;height:20px}.setup-card h3{font-family:var(--font-display);font-variation-settings:"opsz" 144,"wght" 500;font-size:24px;letter-spacing:-.015em;margin-bottom:10px;color:var(--ink)}.setup-card p{font-family:var(--font-display);font-variation-settings:"opsz" 14,"wght" 400;font-style:italic;font-size:14.5px;line-height:1.6;color:var(--ink-dim)}.palette-wrap{display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:start}.palette-avatar{width:140px;height:140px;object-fit:cover;border-radius:8px;border:1px solid var(--rule-strong);filter:contrast(1.04)}.palette-swatches{display:flex;flex-wrap:wrap;gap:6px}.palette-swatch{width:92px;height:92px;border-radius:4px;display:flex;align-items:flex-end;padding:8px;position:relative;transition:transform .4s cubic-bezier(.2,.8,.2,1);border:1px solid rgba(0,0,0,.2);box-shadow:inset 0 1px #ffffff1a}.palette-swatch:hover{transform:translateY(-3px) scale(1.04)}.palette-swatch-dominant{width:188px;position:relative}.palette-swatch-dominant:after{content:"◆";position:absolute;top:8px;right:10px;font-size:10px;color:#00000080}.palette-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}.footer{margin-top:60px;border-top:1px solid var(--rule);padding:48px 40px;background:#0000004d}.footer-content{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px}.footer-logo{font-family:var(--font-display);font-variation-settings:"opsz" 144,"wght" 500;font-style:italic;font-size:20px;color:var(--ink)}.footer-links{display:flex;gap:24px}.footer-links a{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-dim);transition:color .3s ease}.footer-links a:hover{color:var(--accent)}.footer p{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-faint);text-align:right}.fade-in{opacity:0;transform:translateY(20px);transition:opacity .9s cubic-bezier(.2,.8,.2,1),transform .9s cubic-bezier(.2,.8,.2,1)}.fade-in.visible{opacity:1;transform:translateY(0)}@media (max-width: 900px){.hero{grid-template-columns:1fr;gap:48px;padding:60px 24px 80px}.about-grid{grid-template-columns:1fr;gap:40px}.skills-grid,.projects-grid{grid-template-columns:1fr}.skill-card:nth-child(odd){border-right:none}.setup-grid{grid-template-columns:1fr}.setup-card{border-right:none;border-bottom:1px solid var(--rule)}.setup-card:last-child{border-bottom:none}.nav{padding:0 20px}.nav-links a{padding:8px;font-size:10px}.nav-links a:not(.nav-btn):before{display:none}.section{padding:70px 24px}.footer-content{grid-template-columns:1fr;text-align:center;gap:18px}.footer p{text-align:center}.footer-links{justify-content:center}.palette-wrap{grid-template-columns:1fr}}@media (max-width: 520px){body{padding-top:64px}.hero-title{font-size:56px}.nav-links{gap:0}.nav-links a:not(.nav-btn){display:none}}
