*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%}:root{--color-bg: #f5f3ee;--color-bg-alt: #ece8de;--color-paper: #fdfbf6;--color-text: #111827;--color-text-muted: #6b7280;--color-border-subtle: #e5e5e0;--color-accent: #16a34a;--color-accent-soft: #bbf7d0;--color-accent-alt: #f97316;--font-display: "Space Grotesk", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-body: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 18px;--shadow-soft: 0 18px 35px rgba(15, 23, 42, .18);--container-width: 1120px;--gutter: 1.5rem;--transition-fast: .15s ease-out;--transition-med: .2s ease-out}body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--color-text);background:radial-gradient(circle at 0% 0%,rgba(22,163,74,.08),transparent 55%),radial-gradient(circle at 100% 100%,rgba(249,115,22,.08),transparent 55%),var(--color-bg)}html{scroll-behavior:smooth}a{color:inherit;text-decoration:none}a:focus-visible,button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;margin:0;letter-spacing:-.03em}p{margin:0}strong{font-weight:600}.container{width:min(var(--container-width),100% - 2 * var(--gutter));margin-inline:auto}.section{padding-block:clamp(3rem,6vw,4.5rem);border-bottom:1px solid var(--color-border-subtle)}.section.section--no-border{border-bottom:none}.section-header{margin-bottom:1.75rem}.section-eyebrow{font-family:var(--font-display);font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:.25rem}.section-title{font-size:clamp(1.5rem,2.4vw,2rem)}.text-muted{color:var(--color-text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.4rem;border-radius:999px;font-size:.85rem;font-weight:500;border:1px solid transparent;cursor:pointer;background:none;color:var(--color-text);transition:background-color var(--transition-med),color var(--transition-med),border-color var(--transition-med),transform var(--transition-fast),box-shadow var(--transition-fast)}@media(max-width:768px){:root{--gutter: 1.25rem}body{font-size:15px}}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:20;background:#f5f3eef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border-subtle)}.app-header-inner{display:flex;align-items:flex-start;justify-content:center;height:5.5rem;padding-top:.6rem}@media(max-width:768px){.app-header-inner{gap:1rem}}.app-main{flex:1}.hero{min-height:calc(100vh - 5.5rem);display:flex;align-items:center;background:radial-gradient(circle at 0% 0%,rgba(22,163,74,.08),transparent 55%),radial-gradient(circle at 100% 100%,rgba(249,115,22,.08),transparent 55%),var(--color-bg)}.hero-inner{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,2fr);gap:2.5rem;align-items:center}.hero-title-block{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.9rem}.hero-title-line{position:relative;width:100%;height:5rem}.hero-title-line--primary{height:6rem}.hero-subtitle{font-family:var(--font-display);font-size:1.05rem;margin-bottom:1.4rem;color:var(--color-text-muted)}.hero-body{font-size:.95rem;max-width:34rem;color:var(--color-text-muted)}.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1.75rem}.btn-primary{background:var(--color-text);color:#f9fafb;border-color:var(--color-text);box-shadow:var(--shadow-soft)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 20px 30px #0f172a59}.btn-ghost{border-color:#94a3b8b3;background:#fff6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn-ghost:hover{border-color:var(--color-accent);color:var(--color-accent)}.hero-aside{align-self:stretch;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem}.hero-aside-card{width:100%;border-radius:var(--radius-lg);padding:1.4rem 1.6rem;background:var(--color-paper);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:.75rem}.hero-aside-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-muted)}.hero-aside-row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;font-size:.85rem}.hero-aside-label{color:var(--color-text-muted)}.hero-aside-value{font-family:var(--font-display)}@media(max-width:900px){.hero-inner{grid-template-columns:minmax(0,1fr);gap:2rem}.hero-aside{order:-1}}.projects{background:var(--color-bg-alt)}.project-list{display:flex;flex-direction:column;gap:1.2rem}.project-card{display:grid;grid-template-columns:minmax(0,2.4fr) minmax(0,2fr) minmax(0,1fr);gap:1.5rem;padding-block:.9rem;border-top:1px solid rgba(209,213,219,.7);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.project-card:last-child{border-bottom:1px solid rgba(209,213,219,.7)}.project-title{font-family:var(--font-display);font-size:1rem}.project-meta{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted)}.project-description{font-size:.85rem;color:var(--color-text-muted)}.project-link{justify-self:flex-end;align-self:center;font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;color:var(--color-accent)}.project-card:hover{background:#ffffffb3;transform:translateY(-1px)}@media(max-width:900px){.project-card{grid-template-columns:minmax(0,1fr);gap:.4rem}.project-link{justify-self:flex-start}}.about-inner{display:grid;grid-template-columns:minmax(0,3fr) minmax(0,2fr);gap:2.5rem}.about-text{font-size:.95rem;color:var(--color-text-muted);max-width:36rem}.about-text p+p{margin-top:1rem}.about-aside{align-self:flex-start}.about-card{border-radius:var(--radius-lg);padding:1.3rem 1.5rem;border:1px solid var(--color-border-subtle);background:var(--color-paper);box-shadow:0 12px 24px #0f172a14}.about-card-title{font-family:var(--font-display);font-size:.9rem;margin-bottom:.6rem}.about-card-list{list-style:none;padding:0;margin:0}.about-card-list li{font-size:.85rem;color:var(--color-text-muted);padding-block:.3rem}@media(max-width:900px){.about-inner{grid-template-columns:minmax(0,1fr)}}.contact{background:var(--color-bg)}.contact-inner{display:flex;flex-direction:column;gap:1.5rem}.contact-title{font-size:1.4rem;font-family:var(--font-display)}.contact-body{font-size:.95rem;color:var(--color-text-muted);max-width:30rem}.contact-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.contact-links{display:flex;flex-wrap:wrap;gap:.9rem;font-size:.8rem;text-transform:uppercase;letter-spacing:.12em}.contact-link{position:relative;padding-bottom:.1rem}.contact-link:after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:#94a3b8e6;transform-origin:left;transform:scaleX(.4);transition:transform var(--transition-fast),background-color var(--transition-fast)}.contact-link:hover:after{transform:scaleX(1);background:var(--color-text)}.footer{padding-block:1.5rem;font-size:.75rem;color:var(--color-text-muted);border-top:1px solid var(--color-border-subtle)}.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:1rem}.footer-meta{display:flex;gap:.75rem;flex-wrap:wrap}@media(max-width:768px){.footer-inner{flex-direction:column;align-items:flex-start}}.dock-outer{margin:0 .5rem;display:flex;max-width:100%;align-items:flex-end;justify-content:center}.dock-panel{position:relative;display:flex;align-items:flex-end;width:fit-content;gap:.75rem;border-radius:1rem;background-color:var(--color-paper);border:1px solid var(--color-border-subtle);padding:.4rem 1rem .6rem;box-shadow:0 8px 20px #0f172a0f}.dock-item{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background-color:var(--color-bg-alt);border:1px solid var(--color-border-subtle);box-shadow:0 2px 4px #0f172a0a;cursor:pointer;outline:none;color:var(--color-text);padding:0 1.5rem;font-family:var(--font-display);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;white-space:nowrap;min-width:3rem}.dock-icon{display:flex;align-items:center;justify-content:center}.dock-label{position:absolute;top:-1.75rem;left:50%;width:fit-content;white-space:pre;border-radius:.375rem;border:1px solid var(--color-border-subtle);background-color:var(--color-paper);padding:.125rem .5rem;font-size:.75rem;color:var(--color-text);transform:translate(-50%);box-shadow:0 4px 10px #0f172a14}.tilted-card-figure{position:relative;width:100%;height:100%;perspective:800px;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0}.tilted-card-mobile-alert{position:absolute;top:1rem;text-align:center;font-size:.75rem;display:block}@media(min-width:640px){.tilted-card-mobile-alert{display:none}}.tilted-card-inner{position:relative;transform-style:preserve-3d}.tilted-card-img{position:absolute;top:0;left:0;object-fit:cover;border-radius:15px;will-change:transform;transform:translateZ(0)}.tilted-card-overlay{position:absolute;top:0;left:0;z-index:2;width:100%;height:100%;will-change:transform;transform:translateZ(30px)}.tilted-card-caption{pointer-events:none;position:absolute;left:0;top:0;border-radius:4px;background-color:#fff;padding:4px 10px;font-size:10px;color:#2d2d2d;opacity:0;z-index:3;display:none}@media(min-width:640px){.tilted-card-caption{display:block}}
