:root{--color-bg-primary: #FAFAF9;--color-bg-secondary: #FFFFFF;--color-bg-tertiary: #F5F5F4;--color-bg-elevated: #FFFFFF;--color-bg-hover: #F0F0EF;--color-bg-cream: #FBF9F6;--color-bg-warm: #FAF8F5;--color-accent-primary: #E54D2E;--color-accent-secondary: #F76B15;--color-accent-tertiary: #FF8B3E;--color-accent-muted: rgba(229, 77, 46, .08);--color-accent-glow: rgba(229, 77, 46, .15);--color-accent-hover: #D13415;--color-text-primary: #1C1917;--color-text-secondary: #57534E;--color-text-tertiary: #A8A29E;--color-text-muted: #D6D3D1;--color-border-primary: #E7E5E4;--color-border-secondary: #D6D3D1;--color-border-accent: rgba(229, 77, 46, .2);--color-border-subtle: #F5F5F4;--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--color-info: #3B82F6;--font-sans: "SF Pro Display", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-serif: "New York", "Palatino", "Georgia", serif;--font-mono: "SF Mono", "JetBrains Mono", "Fira Code", "Consolas", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.5rem;--text-5xl: 3.5rem;--text-6xl: 4.5rem;--text-hero: clamp(3rem, 8vw, 5.5rem);--font-light: 300;--font-regular: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-tight: 1.1;--leading-snug: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.75;--leading-loose: 2;--tracking-tighter: -.04em;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .02em;--tracking-wider: .05em;--tracking-widest: .1em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--space-40: 10rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 8px rgba(0, 0, 0, .04), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 12px 24px rgba(0, 0, 0, .06), 0 4px 8px rgba(0, 0, 0, .04);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .08), 0 12px 24px rgba(0, 0, 0, .04);--shadow-glow: 0 0 0 1px var(--color-border-accent), 0 8px 24px var(--color-accent-glow);--shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 0 0 1px rgba(0, 0, 0, .02);--shadow-card-hover: 0 12px 32px rgba(0, 0, 0, .08), 0 0 0 1px rgba(0, 0, 0, .02);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-spring: .5s cubic-bezier(.34, 1.56, .64, 1);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-tooltip: 600;--container-max: 1200px;--container-wide: 1400px;--container-padding: clamp(1.5rem, 5vw, 4rem)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"kern" 1,"liga" 1}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);overflow-x:hidden;min-height:100vh}::selection{background-color:var(--color-accent-primary);color:#fff}a{color:inherit;text-decoration:none;transition:color var(--transition-fast)}img,video,svg{display:block;max-width:100%;height:auto}ul,ol{list-style:none}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:none;cursor:pointer;outline:none}button:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.text-gradient{background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-mono{font-family:var(--font-mono)}.text-serif{font-family:var(--font-serif)}.text-accent{color:var(--color-accent-primary)}.text-muted{color:var(--color-text-secondary)}.link-underline{position:relative;display:inline-block}.link-underline:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--color-accent-primary);transition:width var(--transition-base)}.link-underline:hover:after{width:100%}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding-left:var(--container-padding);padding-right:var(--container-padding)}.container-wide{max-width:var(--container-wide)}.section{padding-top:var(--space-24);padding-bottom:var(--space-24)}.section-lg{padding-top:var(--space-32);padding-bottom:var(--space-32)}.card{background:var(--color-bg-secondary);border:1px solid var(--color-border-primary);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base);box-shadow:var(--shadow-card)}.card:hover{border-color:var(--color-border-secondary);transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);font-family:var(--font-mono);font-size:11px;font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:var(--tracking-wider);background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:var(--radius-full);border:1px solid var(--color-border-primary)}.badge-accent{background:var(--color-accent-muted);color:var(--color-accent-primary);border-color:var(--color-border-accent)}.badge-skill{background:var(--color-accent-primary);color:#fff;font-weight:var(--font-bold);border:none;padding:var(--space-1) var(--space-4)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-full);transition:all var(--transition-fast);cursor:pointer;border:none}.btn-primary{background:var(--color-text-primary);color:var(--color-bg-primary)}.btn-primary:hover{background:var(--color-text-secondary);transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--color-text-primary);border:1px solid var(--color-border-secondary)}.btn-secondary:hover{border-color:var(--color-text-primary);background:var(--color-bg-tertiary)}.btn-accent{background:var(--color-accent-primary);color:#fff}.btn-accent:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-glow)}.img-scale{overflow:hidden;border-radius:var(--radius-lg)}.img-scale img{transition:transform var(--transition-slow)}.img-scale:hover img{transform:scale(1.03)}.divider{width:100%;height:1px;background:var(--color-border-primary);margin:var(--space-12) 0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--color-border-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.grid-bg{background-image:linear-gradient(rgba(0,0,0,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.015) 1px,transparent 1px);background-size:80px 80px}.dot-pattern{background-image:radial-gradient(rgba(0,0,0,.05) 1px,transparent 1px);background-size:24px 24px}@keyframes fade-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.7}}.animate-fade-up{animation:fade-up .6s ease forwards}.animate-fade-in{animation:fade-in .6s ease forwards}.animate-float{animation:float 4s ease-in-out infinite}.reveal-image{opacity:0;transform:translateY(40px) scale(.98);transition:all .8s cubic-bezier(.25,.46,.45,.94)}.reveal-image.revealed{opacity:1;transform:translateY(0) scale(1)}.photo-frame{background:#fff;padding:8px;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-primary)}.photo-frame img{border-radius:var(--radius-md)}.image-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.image-grid .image-item{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;object-fit:cover}.image-grid .image-item:nth-child(2){aspect-ratio:3/4;margin-top:var(--space-8)}.image-grid .image-item:nth-child(3){aspect-ratio:1/1}.glass{background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--color-border-primary)}.highlight-box{background:linear-gradient(135deg,var(--color-bg-cream),var(--color-bg-warm));border:1px solid var(--color-border-primary);border-radius:var(--radius-xl);padding:var(--space-8)}.section-header{margin-bottom:var(--space-12)}.section-title{font-size:var(--text-4xl);font-weight:var(--font-bold);letter-spacing:var(--tracking-tight);margin-bottom:var(--space-3)}.section-subtitle{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-tertiary)}@media(max-width:768px){:root{--container-padding: 1.25rem}.section{padding-top:var(--space-16);padding-bottom:var(--space-16)}.section-lg{padding-top:var(--space-20);padding-bottom:var(--space-20)}.image-grid{grid-template-columns:repeat(2,1fr)}.image-grid .image-item:nth-child(2){margin-top:0}}
