*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #0b0b0b;--color-bg-card: #121210;--color-bg-card-hover: #171714;--color-text: #ede8e0;--color-text-dim: #6b665e;--color-accent: #c4956a;--color-accent-hover: #d9ac82;--color-border: #1e1e1c;--color-border-hover: #3a3530;--font-display: "Instrument Serif", Georgia, serif;--font-body: "Outfit", system-ui, sans-serif;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-smooth: cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-weight:300;background-color:var(--color-bg);color:var(--color-text);line-height:1.6;overflow-x:hidden}a{color:inherit;text-decoration:none}::selection{background:var(--color-accent);color:var(--color-bg)}.grain{position:fixed;inset:0;pointer-events:none;z-index:1000;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}.nav{position:fixed;top:0;left:0;right:0;padding:32px 48px;z-index:100;mix-blend-mode:difference}.nav-brand{font-family:var(--font-display);font-size:1.05rem;letter-spacing:-.01em;color:var(--color-text)}.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:120px 48px}.hero-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:600px;background:radial-gradient(ellipse at center,rgba(196,149,106,.05) 0%,transparent 70%);pointer-events:none}.hero-content{position:relative;text-align:center}.hero-title{font-family:var(--font-display);font-size:clamp(3.2rem,9vw,7.5rem);font-weight:400;font-style:italic;letter-spacing:-.04em;line-height:1;color:var(--color-text);animation:fadeInUp 1s var(--ease-out) both}.hero-at{color:var(--color-accent)}.hero-divider{width:56px;height:1px;background:var(--color-accent);margin:36px auto;opacity:.5;animation:fadeInUp 1s var(--ease-out) .2s both}.hero-subtitle{font-family:var(--font-body);font-size:.85rem;font-weight:300;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-dim);animation:fadeInUp 1s var(--ease-out) .4s both}.scroll-indicator{position:absolute;bottom:48px;display:flex;flex-direction:column;align-items:center;gap:12px;animation:fadeInUp 1s var(--ease-out) .7s both}.scroll-indicator span{font-size:.65rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--color-text-dim)}.scroll-line{width:1px;height:40px;background:linear-gradient(to bottom,var(--color-accent),transparent);animation:pulse 2.4s var(--ease-smooth) infinite}.projects{padding:100px 48px 160px;max-width:1100px;margin:0 auto}.section-header{display:flex;align-items:center;gap:20px;margin-bottom:72px}.section-label{font-size:.72rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-dim);flex-shrink:0}.section-rule{flex:1;height:1px;background:var(--color-border)}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}[data-project=geo]{--card-accent: #5ea89a;--card-accent-hover: #7ec4b6;--card-glow: rgba(94, 168, 154, .1);--card-glow-strong: rgba(94, 168, 154, .18)}[data-project=calendar]{--card-accent: #c4956a;--card-accent-hover: #d9ac82;--card-glow: rgba(196, 149, 106, .1);--card-glow-strong: rgba(196, 149, 106, .18)}.project-card{position:relative;display:flex;flex-direction:column;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:14px;cursor:pointer;overflow:hidden;opacity:0;transform:translateY(36px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.project-card.visible{opacity:1;transform:translateY(0);transition:opacity .8s var(--ease-out),transform .45s var(--ease-smooth),border-color .4s var(--ease-smooth),background-color .4s var(--ease-smooth)}.project-card.visible:nth-child(2){transition-delay:.12s}.project-card:hover{transform:translateY(-5px);border-color:var(--color-border-hover);background-color:var(--color-bg-card-hover)}.project-visual{position:relative;height:200px;display:flex;align-items:center;justify-content:center;overflow:hidden;border-bottom:1px solid var(--color-border);background:linear-gradient(180deg,rgba(255,255,255,.015) 0%,transparent 100%)}.visual-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 80%,var(--card-glow) 0%,transparent 65%);transition:background .6s var(--ease-smooth)}.project-card:hover .visual-glow{background:radial-gradient(ellipse at 50% 75%,var(--card-glow-strong) 0%,transparent 65%)}.card-illustration{position:relative;z-index:1;width:240px;height:auto;color:var(--card-accent);opacity:.65;transition:opacity .5s var(--ease-smooth),transform .6s var(--ease-out)}.project-card:hover .card-illustration{opacity:1;transform:scale(1.06)}.ping-ring{opacity:.3;animation:pingPulse 2.8s var(--ease-smooth) infinite}.ping-ring-outer{opacity:.1;animation:pingPulse 2.8s var(--ease-smooth) .4s infinite}.cal-ring{opacity:.35;animation:calRingPulse 2.6s var(--ease-smooth) infinite}.project-body{padding:36px 44px 44px;display:flex;flex-direction:column;flex:1}.project-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.project-number{font-family:var(--font-display);font-size:.85rem;font-style:italic;color:var(--card-accent);opacity:.5}.project-tags{display:flex;gap:6px}.project-tag{font-size:.62rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;padding:3px 10px;border:1px solid var(--color-border);border-radius:100px;color:var(--color-text-dim);transition:border-color .35s var(--ease-smooth)}.project-card:hover .project-tag{border-color:var(--color-border-hover)}.project-title{font-family:var(--font-display);font-size:clamp(2rem,3.2vw,2.8rem);font-weight:400;font-style:italic;letter-spacing:-.025em;line-height:1.1;margin-bottom:14px;transition:color .35s var(--ease-smooth)}.project-card:hover .project-title{color:var(--card-accent-hover)}.project-description{font-size:.92rem;font-weight:300;line-height:1.75;color:var(--color-text-dim);flex:1;margin-bottom:32px}.project-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--color-border)}.project-domain{font-size:.78rem;font-weight:400;letter-spacing:.02em;color:var(--color-text-dim);transition:color .35s var(--ease-smooth)}.project-card:hover .project-domain{color:var(--card-accent)}.project-arrow{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;border:1px solid var(--color-border);color:var(--color-text-dim);transition:color .35s var(--ease-smooth),border-color .35s var(--ease-smooth),transform .35s var(--ease-smooth),background-color .35s var(--ease-smooth)}.project-card:hover .project-arrow{color:var(--color-bg);background-color:var(--card-accent);border-color:var(--card-accent);transform:translate(2px,-2px)}.footer{padding:44px 48px;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--color-border)}.footer-left{font-size:.78rem;font-weight:300;color:var(--color-text-dim);letter-spacing:.02em}.footer-right{font-family:var(--font-display);font-style:italic;font-size:.85rem;color:var(--color-text-dim)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:.25}50%{opacity:.8}}@keyframes pingPulse{0%,to{opacity:.3}50%{opacity:.08}}@keyframes calRingPulse{0%,to{opacity:.35}50%{opacity:.12}}@media(max-width:768px){.nav{padding:24px}.hero{padding:80px 24px}.hero-title{letter-spacing:-.03em}.hero-divider{margin:28px auto}.scroll-indicator{bottom:32px}.projects{padding:72px 24px 100px}.section-header{margin-bottom:48px}.projects-grid{grid-template-columns:1fr;gap:16px}.project-visual{height:160px}.project-body{padding:28px 32px 32px}.project-top{margin-bottom:20px}.project-description{margin-bottom:24px}.project-bottom{padding-top:16px}.footer{padding:32px 24px;flex-direction:column;gap:6px;text-align:center}}@media(max-width:480px){.hero-subtitle{font-size:.72rem;letter-spacing:.12em}.project-visual{height:140px}.card-illustration{width:200px}.project-body{padding:24px}.project-title{font-size:1.6rem}}
