*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--page: #f5f0e6;--page-deep: #ebe3d6;--surface: rgba(255, 251, 245, .8);--surface-strong: rgba(255, 250, 243, .94);--surface-border: rgba(43, 57, 74, .12);--ink: #1e2936;--ink-soft: #4d5b6b;--ink-muted: #6e7a88;--accent: #2f6c63;--accent-soft: #6f9471;--signal: #b46b3c;--signal-soft: rgba(180, 107, 60, .12);--particle-fill-rgb: 47, 108, 99;--particle-line-rgb: 111, 148, 113;--particle-fill: rgba(var(--particle-fill-rgb), .42);--particle-line: rgba(var(--particle-line-rgb), .18);--font-sans: "Manrope", "Segoe UI", sans-serif;--font-display: "Instrument Serif", Georgia, serif;--font-mono: "IBM Plex Mono", "SF Mono", monospace;--font-signature: "Great Vibes", cursive;--radius-sm: 12px;--radius-md: 22px;--radius-lg: 34px;--shadow-soft: 0 30px 70px rgba(40, 47, 55, .08);--shadow-card: 0 20px 45px rgba(55, 52, 46, .08)}html{scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{font-family:var(--font-sans);color:var(--ink);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;background:radial-gradient(circle at top left,rgba(111,148,113,.18),transparent 34%),radial-gradient(circle at 85% 20%,rgba(180,107,60,.12),transparent 28%),linear-gradient(180deg,#f8f4eb 0%,var(--page) 42%,var(--page-deep) 100%)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(30,41,54,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(30,41,54,.04) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(circle at center,black 40%,transparent 88%);-webkit-mask-image:radial-gradient(circle at center,black 40%,transparent 88%);pointer-events:none;z-index:0}.skip-link{position:absolute;left:-9999px;top:.75rem;padding:.6rem 1rem;background:var(--accent);color:#fff;border-radius:var(--radius-sm);font-weight:700;z-index:20000}.skip-link:focus{left:.75rem;outline:2px solid var(--signal);outline-offset:3px}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:#ffffff40}::-webkit-scrollbar-thumb{background:#1e29362e;border-radius:999px}::-webkit-scrollbar-thumb:hover{background:#1e29364d}#particles{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;opacity:.8}.loader{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.9rem;background:radial-gradient(circle at 20% 20%,rgba(111,148,113,.12),transparent 32%),linear-gradient(180deg,#fbf7ef,#efe5d7);transition:opacity .7s ease,visibility .7s ease}.loader.loaded{opacity:0;visibility:hidden;pointer-events:none}.loader-text{font-family:var(--font-mono);font-size:clamp(1rem,3vw,1.25rem);letter-spacing:.22em;color:var(--ink)}.loader-bar-container{width:min(280px,72vw);height:4px;border-radius:999px;overflow:hidden;background:#1e29361a}.loader-bar{width:0%;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent-soft),var(--signal))}.loader-status{font-family:var(--font-mono);font-size:.74rem;color:var(--ink-muted);letter-spacing:.06em;text-transform:uppercase}.nav{position:fixed;top:0;left:0;right:0;z-index:1000;background:#f8f4ebb3;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid transparent;transition:background .25s ease,border-color .25s ease}.nav.scrolled{background:#f8f4ebeb;border-bottom-color:var(--surface-border)}.nav-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}.nav-logo{text-decoration:none;color:var(--ink);font-family:var(--font-mono);font-weight:600;letter-spacing:.14em;font-size:.92rem}.nav-logo-dot{color:var(--signal)}.nav-links{display:flex;align-items:center;gap:1.8rem}.nav-link{text-decoration:none;color:var(--ink-soft);font-size:.92rem;font-weight:600;position:relative;padding-bottom:.15rem}.nav-link:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}.nav-link:hover,.nav-link:focus-visible{color:var(--ink)}.nav-link:hover:after,.nav-link:focus-visible:after{transform:scaleX(1)}.menu-toggle{display:none;border:none;background:transparent;color:var(--ink);cursor:pointer;padding:.35rem;border-radius:10px}.menu-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.hero{min-height:100vh;padding:7.5rem 2rem 3rem;position:relative;overflow:hidden}.hero-shell{position:relative;z-index:2;max-width:1200px;margin:0 auto;width:100%;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);gap:2rem;align-items:center}.hero:before{content:"";position:absolute;inset:10% auto auto 58%;width:min(30rem,42vw);height:min(30rem,42vw);border-radius:38% 62% 59% 41%/42% 39% 61% 58%;background:linear-gradient(145deg,#6f94712e,#b46b3c1a);filter:blur(18px);z-index:0}.hero-glow{position:absolute;inset:auto auto 8% 8%;width:min(28rem,52vw);height:min(18rem,40vw);border-radius:999px;background:radial-gradient(circle,rgba(47,108,99,.12),transparent 70%);filter:blur(18px);z-index:0}.hero-content{position:relative;max-width:860px}.hero-visual{position:relative;display:grid;grid-template-columns:minmax(0,1fr) .72fr;gap:1rem;align-items:end}.hero-tag{display:inline-block;margin-bottom:1rem;padding:.45rem .9rem;border-radius:999px;background:#ffffff80;border:1px solid rgba(43,57,74,.1);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.05em;color:var(--ink-soft);opacity:0;animation:fadeInDown .7s ease forwards .2s}.typewriter-container{min-height:1.6em;margin-bottom:1.2rem;font-family:var(--font-mono);font-size:.88rem;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}.cursor{display:inline-block;width:8px;height:1.1em;margin-left:.3rem;background:var(--signal);animation:blink 1s step-end infinite}.hero-title{font-family:var(--font-display);font-size:clamp(3.3rem,8vw,6.2rem);font-weight:400;line-height:.94;letter-spacing:-.03em;opacity:0;animation:fadeInUp .7s ease forwards .35s}.gradient-text{color:var(--accent);font-style:italic}.hero-description{max-width:42rem;margin-top:1.5rem;font-size:clamp(1rem,2.4vw,1.16rem);color:var(--ink-soft);opacity:0;animation:fadeInUp .7s ease forwards .5s}.btn-container{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.1rem;opacity:0;animation:fadeInUp .7s ease forwards .65s}.btn{display:inline-flex;align-items:center;justify-content:center;min-width:160px;padding:.9rem 1.35rem;border-radius:999px;text-decoration:none;font-family:var(--font-mono);font-size:.8rem;font-weight:500;letter-spacing:.04em;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease}.btn-primary{background:var(--ink);color:#fffdf9;box-shadow:0 14px 28px #1e293629}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 34px #1e29362e}.btn-secondary{color:var(--ink);background:#ffffff70;border:1px solid rgba(43,57,74,.12)}.btn-secondary:hover{transform:translateY(-2px);background:#ffffffb3}.photo-stack{display:grid;gap:1rem}.photo-card{position:relative}.photo-card--primary{padding-top:1rem}.photo-card--secondary{margin-top:1.2rem}.photo-card--accent{margin-left:1.2rem}.photo-frame{position:relative;overflow:hidden;border-radius:30px;background:#ffffff9e;border:1px solid rgba(43,57,74,.12);box-shadow:0 26px 56px #37342e24;padding:.7rem}.photo-frame:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(180deg,rgba(255,255,255,.38),transparent 24%);pointer-events:none}.photo-frame--tilted{transform:rotate(-3deg)}.photo-frame--soft{transform:rotate(2.5deg)}.photo-image{display:block;width:100%;height:100%;min-height:250px;object-fit:cover;border-radius:22px}.photo-card--primary .photo-image{aspect-ratio:4 / 5}.photo-card--secondary .photo-image,.photo-card--accent .photo-image{aspect-ratio:5 / 4}.photo-meta{display:flex;align-items:center;justify-content:space-between;gap:.7rem;padding:.85rem .4rem 0}.photo-caption{color:var(--ink);font-family:var(--font-display);font-size:1.1rem;font-style:italic}.photo-detail{color:var(--ink-muted);font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase}.container{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:5.2rem 2rem}.section-header{margin-bottom:2.5rem}.section-label{display:block;margin-bottom:.5rem;color:var(--signal);font-family:var(--font-mono);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase}.section-title{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.3rem);font-weight:400;line-height:1;letter-spacing:-.02em}.section-intro{max-width:42rem;margin-top:1rem;color:var(--ink-soft);font-size:1rem}.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.5,0,0,1),transform .7s cubic-bezier(.5,0,0,1)}.reveal.active{opacity:1;transform:translateY(0)}.about{padding-top:2rem}.about-layout{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(280px,.7fr);gap:1.4rem}.about-intro{padding:2rem;border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--surface-border);box-shadow:var(--shadow-card)}.about-lead{margin-top:1.15rem;margin-bottom:1.2rem;max-width:42rem;font-size:1.12rem;color:var(--ink-soft)}.about-body p{margin-bottom:1rem;max-width:42rem;color:var(--ink-muted)}.about-body p:last-child{margin-bottom:0}.about-panel{display:grid;gap:1rem}.about-stat{padding:1.25rem;border-radius:var(--radius-md);background:var(--surface-strong);border:1px solid var(--surface-border);box-shadow:var(--shadow-card)}.about-stat-label{display:block;margin-bottom:.4rem;color:var(--ink-muted);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase}.about-stat-value{color:var(--ink);font-weight:700;font-size:.98rem}.skills-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}.skill-card{grid-column:span 6;min-height:190px;padding:1.5rem;border-radius:var(--radius-md);background:linear-gradient(180deg,#fffbf5d1,#f4ede2f2);border:1px solid var(--surface-border);box-shadow:var(--shadow-card);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.skill-card:hover{transform:translateY(-3px);border-color:#2f6c6333;box-shadow:0 25px 50px #37342e1f}.skill-category{display:flex;align-items:center;gap:.7rem;margin-bottom:1rem;color:var(--ink-soft);font-size:.84rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.skill-category span{display:inline-flex;align-items:center;justify-content:center;min-width:2rem;padding:.2rem .45rem;border-radius:999px;background:var(--signal-soft);color:var(--signal);font-family:var(--font-mono);font-size:.72rem}.skill-list{display:flex;flex-wrap:wrap;gap:.6rem}.skill-item{padding:.44rem .78rem;border-radius:999px;background:#ffffff85;border:1px solid rgba(43,57,74,.08);color:var(--ink);font-family:var(--font-mono);font-size:.78rem}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,290px),1fr));gap:1.2rem}.project-card{position:relative;overflow:hidden;border-radius:var(--radius-md);background:linear-gradient(180deg,#fffdf9e0,#f1e9ddf5);border:1px solid rgba(43,57,74,.1);box-shadow:var(--shadow-card)}.project-card--featured{background:radial-gradient(circle at top right,rgba(111,148,113,.18),transparent 30%),linear-gradient(180deg,#f9fcf6f5,#ecf4e9fa);border-color:#2f6c6338;box-shadow:0 24px 54px #2f6c631f}.project-card--featured:after{content:"";position:absolute;inset:0 auto 0 0;width:5px;background:linear-gradient(180deg,var(--accent),var(--accent-soft))}.project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;padding:1px;background:radial-gradient(700px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(47,108,99,.3),transparent 35%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;opacity:0;transition:opacity .35s ease;pointer-events:none}.project-card:hover:before{opacity:1}.project-content{position:relative;z-index:1;display:flex;flex-direction:column;height:100%;padding:1.6rem}.project-badge{align-self:flex-start;margin-bottom:.95rem;padding:.36rem .72rem;border-radius:999px;background:#2f6c631f;color:var(--accent);border:1px solid rgba(47,108,99,.18);font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.project-icon{margin-bottom:.8rem;font-size:1.7rem}.project-title{margin-bottom:.45rem;font-size:1.28rem;font-weight:800}.project-desc{flex-grow:1;margin-bottom:1.15rem;color:var(--ink-soft);font-size:.94rem}.project-tech{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1rem}.tech-pill{padding:.24rem .54rem;border-radius:999px;background:#2f6c6314;color:var(--accent);border:1px solid rgba(47,108,99,.12);font-family:var(--font-mono);font-size:.72rem}.project-link{display:inline-flex;align-items:center;gap:.45rem;text-decoration:none;color:var(--ink);font-weight:700;font-size:.88rem;transition:gap .2s ease,color .2s ease}.project-link:hover{gap:.65rem;color:var(--accent)}.project-link--small{margin-top:.45rem;font-size:.78rem;font-weight:600;color:var(--ink-soft)}.github-activity{display:grid;gap:1rem}.github-headline{color:var(--ink);font-size:clamp(1.55rem,3vw,2rem);font-weight:800}.github-summary{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:1rem}.signal-card{padding:1.3rem;border-radius:var(--radius-lg);background:#fffbf5d1;border:1px solid rgba(43,57,74,.12);box-shadow:var(--shadow-card)}.signal-card--wide{max-width:360px}.signal-label{display:block;margin-bottom:.45rem;color:var(--ink-muted);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase}.signal-value{color:var(--ink);font-size:clamp(1.35rem,3vw,1.75rem);font-weight:800}.signal-value--small{font-size:1rem}.heatmap-card{padding:1.5rem;border-radius:var(--radius-lg);background:#fffbf5d1;border:1px solid rgba(43,57,74,.12);box-shadow:var(--shadow-card)}.heatmap-months{min-height:1.2rem;display:grid;gap:.35rem;margin-left:3.4rem;margin-bottom:.55rem}.heatmap-month{color:var(--ink-muted);font-family:var(--font-mono);font-size:.68rem;white-space:nowrap}.heatmap-body{display:grid;grid-template-columns:auto 1fr;gap:.85rem;align-items:start}.heatmap-day-labels{display:grid;grid-template-rows:repeat(7,12px);gap:.3rem;padding-top:.15rem}.heatmap-day-labels span{color:var(--ink-muted);font-family:var(--font-mono);font-size:.65rem;line-height:12px}.heatmap-day-labels span:nth-child(1){grid-row:2}.heatmap-day-labels span:nth-child(2){grid-row:4}.heatmap-day-labels span:nth-child(3){grid-row:6}.heatmap-grid{display:grid;grid-template-rows:repeat(7,12px);grid-auto-flow:column;gap:.3rem}.heatmap-cell{width:12px;height:12px;border-radius:3px;background:#2b394a14;border:1px solid rgba(43,57,74,.03)}.heatmap-cell--out{opacity:.32}.heatmap-cell--1{background:#d8ead6;border-color:#6f94712e}.heatmap-cell--2{background:#a7d59f;border-color:#6f947140}.heatmap-cell--3{background:#67b76d;border-color:#2f6c6347}.heatmap-cell--4{background:#2f6c63;border-color:#2f6c6352}.heatmap-footer{margin-top:1rem;display:flex;flex-wrap:wrap;justify-content:space-between;gap:.9rem;align-items:center}.heatmap-link{color:var(--accent);text-decoration:none;font-weight:700}.heatmap-legend{display:inline-flex;align-items:center;gap:.45rem;color:var(--ink-muted);font-family:var(--font-mono);font-size:.68rem}.legend-scale{display:inline-flex;gap:.3rem}.legend-cell{width:12px;height:12px;border-radius:3px;border:1px solid rgba(43,57,74,.05)}.legend-cell--0{background:#2b394a14}.legend-cell--1{background:#d8ead6}.legend-cell--2{background:#a7d59f}.legend-cell--3{background:#67b76d}.legend-cell--4{background:#2f6c63}.activity-breakdown{display:grid}.activity-empty{color:var(--ink-muted);font-family:var(--font-mono);font-size:.82rem}.activity-repos{display:grid;gap:.8rem;grid-template-columns:repeat(2,minmax(0,1fr))}.activity-repo{display:grid;gap:.55rem;padding:1.1rem 1.15rem;text-decoration:none;border-radius:var(--radius-md);background:#fffbf5d1;border:1px solid rgba(43,57,74,.12);box-shadow:var(--shadow-card);transition:transform .2s ease,border-color .2s ease}.activity-repo:hover{transform:translateY(-2px);border-color:#2f6c6338}.activity-repo-top{display:flex;justify-content:space-between;gap:.75rem;align-items:baseline}.activity-repo-name{color:var(--ink);font-weight:800}.activity-repo-count{color:var(--accent);font-family:var(--font-mono);font-size:.72rem;white-space:nowrap}.activity-repo-bar{width:100%;height:10px;border-radius:999px;background:#2b394a14;overflow:hidden}.activity-repo-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent-soft),var(--accent))}.activity-repo-meta{color:var(--ink-soft);font-family:var(--font-mono);font-size:.72rem}.github-note{max-width:46rem;color:var(--ink-muted);font-size:.92rem}.contact-card{display:flex;flex-direction:column;gap:1rem;max-width:760px;margin:0 auto;padding:1.5rem;border-radius:var(--radius-lg);background:#fffbf5e0;border:1px solid rgba(43,57,74,.12);box-shadow:var(--shadow-soft)}.contact-copy{color:var(--ink-soft);font-size:1rem}.contact-actions{display:flex;flex-wrap:wrap;gap:.9rem}.contact-meta{display:flex;flex-wrap:wrap;gap:.9rem 1.5rem;color:var(--ink-muted);font-family:var(--font-mono);font-size:.74rem}.contact-meta a{color:inherit}.footer{position:relative;z-index:1;padding:2.5rem 0 3rem;border-top:1px solid rgba(43,57,74,.08)}.footer-content{display:flex;flex-direction:column;align-items:center;gap:1.2rem}.social-links{display:flex;gap:.9rem}.social-link{width:48px;height:48px;display:flex;align-items:center;justify-content:center;color:var(--ink-soft);text-decoration:none;border-radius:50%;background:#ffffff6b;border:1px solid rgba(43,57,74,.1);transition:transform .2s ease,color .2s ease,border-color .2s ease}.social-link svg{width:18px;height:18px;fill:currentColor}.social-link:hover{transform:translateY(-2px);color:var(--accent);border-color:#2f6c6333}.social-link:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.copyright{max-width:44rem;text-align:center;color:var(--ink-muted);font-family:var(--font-mono);font-size:.76rem;line-height:1.8}.footer-signature{color:var(--accent);font-family:var(--font-signature);font-size:clamp(2.3rem,5vw,3.4rem);line-height:.9;letter-spacing:.02em;text-align:center;transform:rotate(-4deg);text-shadow:0 6px 18px rgba(47,108,99,.1)}.status-online{color:var(--accent)}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.hero-tag,.hero-title,.hero-description,.btn-container{opacity:1!important;animation:none!important}.cursor{animation:none;opacity:.7}.reveal{opacity:1;transform:none;transition:none}.photo-frame--tilted,.photo-frame--soft,.footer-signature{transform:none}}@media(max-width:980px){.hero-shell,.about-layout{grid-template-columns:1fr}.github-summary{grid-template-columns:repeat(3,minmax(0,1fr))}.skill-card{grid-column:span 12}.hero{min-height:auto}.hero-content{max-width:none}.hero-visual{max-width:760px}.activity-repos{grid-template-columns:1fr}}@media(max-width:768px){.nav-links{position:fixed;top:0;right:-100%;width:min(82vw,320px);height:100vh;background:#f8f4ebf7;border-left:1px solid rgba(43,57,74,.08);box-shadow:-14px 0 40px #37342e14;display:flex;flex-direction:column;justify-content:center;align-items:center;transition:right .3s ease}.nav-links.active{right:0}.menu-toggle{display:block}.hero{padding-top:6.5rem;min-height:auto}.hero-shell{gap:1.6rem}.hero-visual,.github-summary{grid-template-columns:1fr}.heatmap-card{overflow-x:auto}.heatmap-body{min-width:760px}.photo-stack{grid-template-columns:1fr 1fr;align-items:start}.photo-card--secondary{margin-top:0}.photo-card--accent{margin-left:0;margin-top:1.25rem}.container,.nav-container{padding-left:1.25rem;padding-right:1.25rem}.container{padding-top:4.3rem;padding-bottom:4.3rem}.about-intro,.project-content,.skill-card,.photo-frame,.contact-card,.activity-repo,.signal-card{padding:1.25rem}.photo-image{min-height:220px}.contact-actions .btn{width:100%}}@media(max-width:560px){.photo-stack{grid-template-columns:1fr}.photo-card--accent{margin-top:0}.photo-meta{padding-left:.1rem;padding-right:.1rem}}
