:root{--primary-color: #2563eb;--primary-dark: #1d4ed8;--secondary-color: #64748b;--accent-color: #f59e0b;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--border-color: #e2e8f0;--border-light: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--font-family-base: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;--font-family-mono: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;--font-size-xs: 0.75rem;--font-size-sm: 0.875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--spacing-xs: 0.25rem;--spacing-sm: 0.5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--border-radius-sm: 0.25rem;--border-radius-md: 0.375rem;--border-radius-lg: 0.5rem;--border-radius-xl: 0.75rem;--transition-fast: 150ms ease;--transition-normal: 300ms ease;--transition-slow: 500ms ease;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px}*{box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{margin:0;padding:0;font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{margin:0 0 var(--spacing-md) 0;font-weight:600;line-height:var(--line-height-tight);color:var(--text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin:0 0 var(--spacing-md) 0;color:var(--text-secondary)}.lead{font-size:var(--font-size-lg);font-weight:400;line-height:var(--line-height-relaxed);color:var(--text-secondary);margin-bottom:var(--spacing-lg)}a{color:var(--primary-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-dark);text-decoration:underline}img{max-width:100%;height:auto;border-radius:var(--border-radius-md)}code{font-family:var(--font-family-mono);font-size:var(--font-size-sm);background-color:var(--bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm);border:1px solid var(--border-color)}pre{font-family:var(--font-family-mono);font-size:var(--font-size-sm);background-color:var(--bg-tertiary);padding:var(--spacing-md);border-radius:var(--border-radius-md);border:1px solid var(--border-color);overflow-x:auto}pre code{background:none;padding:0;border:none}blockquote{margin:var(--spacing-lg) 0;padding:var(--spacing-md) var(--spacing-lg);border-left:4px solid var(--primary-color);background-color:var(--bg-secondary);border-radius:0 var(--border-radius-md) var(--border-radius-md) 0}blockquote p{margin-bottom:0;font-style:italic}ul,ol{margin:0 0 var(--spacing-md) 0;padding-left:var(--spacing-lg);color:var(--text-secondary)}li{margin-bottom:var(--spacing-sm)}hr{border:none;height:1px;background-color:var(--border-color);margin:var(--spacing-2xl) 0}input,textarea,select{font-family:inherit;font-size:var(--font-size-base);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-primary);color:var(--text-primary);transition:border-color var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(37,99,235,0.1)}table{width:100%;border-collapse:collapse;margin:var(--spacing-lg) 0}table th,table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}table th{font-weight:600;background-color:var(--bg-secondary);color:var(--text-primary)}table td{color:var(--text-secondary)}.wrapper{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}@media (min-width: 768px){.wrapper{padding:0 var(--spacing-lg)}}.container{max-width:1000px;margin:0 auto;padding:0 var(--spacing-md)}@media (min-width: 768px){.container{padding:0 var(--spacing-lg)}}.site-header{background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;backdrop-filter:blur(8px);background-color:rgba(255,255,255,0.95)}.site-header-content{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) 0}.site-brand{display:flex;align-items:center}.site-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);text-decoration:none}.site-title:hover{text-decoration:none;color:var(--primary-color)}.site-logo{width:32px;height:32px;border-radius:50%}.site-nav{position:relative}.site-nav .nav-trigger{display:none}.site-nav .menu-icon{display:none;cursor:pointer;padding:var(--spacing-sm);border-radius:var(--border-radius-md);transition:all var(--transition-fast);outline:none;background:none;border:none;min-width:44px;min-height:44px}.site-nav .menu-icon:hover,.site-nav .menu-icon:focus{background-color:var(--bg-secondary)}.site-nav .menu-icon:focus-visible{box-shadow:0 0 0 2px var(--primary-color)}.site-nav .menu-icon span{display:block;width:24px;height:2px;background-color:var(--text-primary);transition:all var(--transition-fast);border-radius:1px;position:relative}.site-nav .menu-icon span:before,.site-nav .menu-icon span:after{content:'';display:block;width:24px;height:2px;background-color:var(--text-primary);transition:all var(--transition-fast);border-radius:1px;position:absolute;left:0}.site-nav .menu-icon span:before{top:-8px}.site-nav .menu-icon span:after{top:8px}.site-nav .trigger{display:flex;align-items:center;gap:var(--spacing-lg)}.site-nav .page-link{color:var(--text-secondary);font-weight:500;font-size:var(--font-size-base);transition:color var(--transition-fast);text-decoration:none;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-sm)}.site-nav .page-link:hover,.site-nav .page-link:focus,.site-nav .page-link.current{color:var(--primary-color);text-decoration:none}.site-nav .page-link:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.site-nav .theme-toggle{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--border-radius-md);transition:all var(--transition-fast);min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.site-nav .theme-toggle:hover,.site-nav .theme-toggle:focus{color:var(--primary-color);background-color:var(--bg-secondary)}.site-nav .theme-toggle:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.site-nav .theme-switch{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none;-webkit-user-select:none}.site-nav .switch{width:44px;height:24px;position:relative;display:inline-block}.site-nav .switch-track{position:absolute;inset:0;border-radius:999px;background:var(--border-light);transition:background-color var(--transition-fast)}.site-nav .switch-thumb{position:absolute;width:18px;height:18px;border-radius:50%;background:var(--bg-primary);top:3px;left:3px;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),background var(--transition-fast)}.site-nav .switch.on .switch-track{background:var(--primary-color)}.site-nav .switch.on .switch-thumb{transform:translateX(20px);background:#fff}.site-nav .visually-hidden{position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px, 1px, 1px, 1px);white-space:nowrap}.site-nav .persistent-theme-toggle{display:none;position:absolute;right:56px;top:14px;z-index:1100;background:none;border:none;color:var(--text-secondary)}@media screen and (max-width: 767px){.site-nav{position:relative}.site-nav .menu-icon{display:flex !important;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;position:relative;z-index:1000;cursor:pointer;background:none;border:none;padding:8px;border-radius:6px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.site-nav .menu-icon:hover{background-color:rgba(37,99,235,0.1)}.site-nav .menu-icon:active{background-color:rgba(37,99,235,0.2)}.site-nav .trigger{display:flex !important;position:absolute;top:calc(100% + 10px);right:0;background-color:#ffffff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 25px -5px rgba(0,0,0,0.1);padding:16px;min-width:200px;flex-direction:column;gap:8px;z-index:999;opacity:0;visibility:hidden;transform:translateY(-10px);pointer-events:none;transition:all 0.3s cubic-bezier(0.4, 0, 0.2, 1)}.site-nav .page-link{display:block !important;padding:12px 16px;border-radius:6px;width:100%;text-align:left;min-height:44px;line-height:1.3;color:#475569;text-decoration:none}.site-nav .page-link:hover,.site-nav .page-link:focus{background-color:#f8fafc;color:#2563eb}.site-nav .page-link.current{background-color:rgba(37,99,235,0.1);color:#2563eb}.site-nav .theme-toggle{display:flex !important;margin-top:8px;padding:12px 16px;border-top:1px solid #e2e8f0;width:100%;justify-content:flex-start;align-items:center;gap:8px;text-align:left;background:none;border-radius:6px;color:#475569;cursor:pointer}.site-nav .theme-toggle:hover{background-color:#f8fafc;color:#2563eb}.site-nav .theme-toggle::after{content:'Toggle theme';font-size:14px}.site-nav .trigger.menu-open{opacity:1 !important;visibility:visible !important;transform:translateY(0) !important;pointer-events:auto !important;display:flex !important}.site-nav .menu-icon.menu-open span{background-color:transparent !important}.site-nav .menu-icon.menu-open span:before{transform:rotate(45deg) !important;top:0 !important}.site-nav .menu-icon.menu-open span:after{transform:rotate(-45deg) !important;top:0 !important}.site-nav .nav-trigger:checked ~ .trigger{opacity:1 !important;visibility:visible !important;transform:translateY(0) !important;pointer-events:auto !important;display:flex !important}.site-nav .nav-trigger:checked ~ .menu-icon span{background-color:transparent !important}.site-nav .nav-trigger:checked ~ .menu-icon span:before{transform:rotate(45deg) !important;top:0 !important}.site-nav .nav-trigger:checked ~ .menu-icon span:after{transform:rotate(-45deg) !important;top:0 !important}.site-nav .persistent-theme-toggle{display:inline-flex !important;right:56px;top:10px;color:#475569}.site-nav .theme-switch{margin-top:0}.site-nav .theme-switch .switch-track{background:#e6e9ef}.site-nav .theme-switch .switch.on .switch-track{background:#2563eb}}.page-content{min-height:calc(100vh - 140px);padding:var(--spacing-2xl) 0}.site-footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);margin-top:var(--spacing-3xl);padding:var(--spacing-3xl) 0 var(--spacing-xl) 0}.footer-content{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.footer-section h2,.footer-section h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--text-primary)}.footer-section p{font-size:var(--font-size-sm);color:var(--text-muted)}.footer-links{list-style:none;padding:0;margin:0}.footer-links li{margin-bottom:var(--spacing-sm)}.footer-links a{color:var(--text-secondary);font-size:var(--font-size-sm)}.footer-links a:hover{color:var(--primary-color)}.social-links{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.social-links a{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);color:var(--text-secondary);transition:all var(--transition-fast)}.social-links a:hover{background-color:var(--primary-color);border-color:var(--primary-color);color:white;transform:translateY(-2px);text-decoration:none}.rss-link{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--text-secondary);font-size:var(--font-size-sm)}.rss-link:hover{color:var(--primary-color)}.footer-bottom{border-top:1px solid var(--border-color);padding-top:var(--spacing-lg);text-align:center}.footer-bottom p{font-size:var(--font-size-xs);color:var(--text-muted);margin-bottom:var(--spacing-sm)}.footer-bottom p:last-child{margin-bottom:0}.posts-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:var(--spacing-xl)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));gap:var(--spacing-xl)}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:var(--spacing-lg);margin-top:var(--spacing-xl)}.hero-section{padding:var(--spacing-3xl) 0;background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%)}.hero-content{display:grid;grid-template-columns:1fr auto;gap:var(--spacing-2xl);align-items:center}@media (max-width: 768px){.hero-content{grid-template-columns:1fr;text-align:center}}.hero-title{font-size:var(--font-size-5xl);margin-bottom:var(--spacing-md)}.hero-title .highlight{color:var(--primary-color)}@media (max-width: 768px){.hero-title{font-size:var(--font-size-4xl)}}.hero-subtitle{font-size:var(--font-size-xl);color:var(--text-secondary);margin-bottom:var(--spacing-md)}.hero-description{font-size:var(--font-size-lg);color:var(--text-muted);margin-bottom:var(--spacing-xl);max-width:600px}.hero-buttons{display:flex;gap:var(--spacing-md)}@media (max-width: 480px){.hero-buttons{flex-direction:column}}.hero-image .avatar{width:200px;height:200px;border-radius:50%;object-fit:cover;border:4px solid var(--primary-color)}@media (max-width: 768px){.hero-image .avatar{width:150px;height:150px}}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:500;text-decoration:none;border-radius:var(--border-radius-lg);transition:all var(--transition-fast);cursor:pointer;border:2px solid transparent}.btn:hover{text-decoration:none;transform:translateY(-1px)}.btn-primary{background-color:var(--primary-color);color:white}.btn-primary:hover{background-color:var(--primary-dark);color:white}.btn-secondary{background-color:transparent;color:var(--primary-color);border-color:var(--primary-color)}.btn-secondary:hover{background-color:var(--primary-color);color:white}.btn-outline{background-color:transparent;color:var(--text-secondary);border-color:var(--border-color)}.btn-outline:hover{background-color:var(--bg-secondary);color:var(--text-primary);border-color:var(--text-secondary)}.post-card,.project-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);transition:all var(--transition-fast)}.post-card:hover,.project-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.post-card h3,.project-card h3{margin-bottom:var(--spacing-md)}.post-card h3 a,.project-card h3 a{color:var(--text-primary);text-decoration:none}.post-card h3 a:hover,.project-card h3 a:hover{color:var(--primary-color)}.post-meta{font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--spacing-md);display:flex;gap:var(--spacing-md);align-items:center;flex-wrap:wrap}.post-excerpt,.project-description{color:var(--text-secondary);margin-bottom:var(--spacing-lg);line-height:var(--line-height-relaxed)}.read-more,.read-more-link{color:var(--primary-color);font-weight:500;font-size:var(--font-size-sm)}.read-more:hover,.read-more-link:hover{color:var(--primary-dark)}.category-tag,.tech-tag,.tag{display:inline-block;font-size:var(--font-size-xs);font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);text-transform:uppercase;letter-spacing:0.05em}.category-tag{background-color:var(--primary-color);color:white}.tech-tag{background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color)}.tag{background-color:var(--accent-color);color:white}.post-categories,.post-tags{margin-top:var(--spacing-md)}.post-categories .category-tag,.post-categories .tag,.post-tags .category-tag,.post-tags .tag{margin-right:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.project-technologies,.project-tech{margin:var(--spacing-md) 0}.project-technologies .tech-tag,.project-tech .tech-tag{margin-right:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.project-links{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-lg);flex-wrap:wrap}.project-link{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:500;text-decoration:none;border-radius:var(--border-radius-md);border:1px solid var(--border-color);color:var(--text-secondary);transition:all var(--transition-fast)}.project-link:hover{color:var(--primary-color);border-color:var(--primary-color);text-decoration:none}.project-link.github:hover{background-color:#24292e;border-color:#24292e;color:white}.project-link.demo:hover{background-color:var(--primary-color);border-color:var(--primary-color);color:white}.status-badge{font-size:var(--font-size-xs);font-weight:600;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);text-transform:uppercase;letter-spacing:0.05em}.status-badge.status-completed{background-color:#10b981;color:white}.status-badge.status-in-progress{background-color:var(--accent-color);color:white}.status-badge.status-planned{background-color:var(--text-muted);color:white}.skill-category h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--primary-color)}.skill-category ul{list-style:none;padding:0;margin:0}.skill-category li{padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border-light);color:var(--text-secondary)}.skill-category li:last-child{border-bottom:none}.pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-sm);margin:var(--spacing-3xl) 0}.pagination-link{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 var(--spacing-md);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-secondary);text-decoration:none;font-weight:500;transition:all var(--transition-fast)}.pagination-link:hover{background-color:var(--primary-color);border-color:var(--primary-color);color:white;text-decoration:none}.pagination-link.current{background-color:var(--primary-color);border-color:var(--primary-color);color:white}.post-navigation{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg);margin:var(--spacing-2xl) 0}@media (max-width: 768px){.post-navigation{grid-template-columns:1fr}}.nav-previous,.nav-next{padding:var(--spacing-lg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);transition:all var(--transition-fast)}.nav-previous:hover,.nav-next:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md)}.nav-previous a,.nav-next a{text-decoration:none;color:inherit}.nav-previous a:hover,.nav-next a:hover{text-decoration:none}.nav-next{text-align:right}.nav-label{display:block;font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--spacing-xs)}.nav-title{display:block;font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary)}.post-share{margin:var(--spacing-xl) 0}.post-share h4{margin-bottom:var(--spacing-md);color:var(--text-primary)}.share-buttons{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.share-btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:500;text-decoration:none;border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.share-btn:hover{text-decoration:none;transform:translateY(-1px)}.share-btn.twitter{background-color:#1da1f2;color:white}.share-btn.twitter:hover{background-color:#0d8bd4;color:white}.share-btn.linkedin{background-color:#0077b5;color:white}.share-btn.linkedin:hover{background-color:#005885;color:white}.share-btn.facebook{background-color:#1877f2;color:white}.share-btn.facebook:hover{background-color:#166fe5;color:white}.related-posts{margin:var(--spacing-3xl) 0;padding:var(--spacing-xl);background-color:var(--bg-secondary);border-radius:var(--border-radius-xl)}.related-posts h3{margin-bottom:var(--spacing-xl);text-align:center}.related-posts-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:var(--spacing-lg)}.related-post h4{margin-bottom:var(--spacing-sm)}.related-post h4 a{color:var(--text-primary);text-decoration:none}.related-post h4 a:hover{color:var(--primary-color)}.related-post time{font-size:var(--font-size-sm);color:var(--text-muted)}.related-post p{margin-top:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--text-secondary)}.contact-method{display:flex;align-items:flex-start;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.contact-method i{width:24px;color:var(--primary-color);margin-top:var(--spacing-xs)}.contact-method h3{margin-bottom:var(--spacing-xs);font-size:var(--font-size-lg)}.contact-method p,.contact-method a{margin:0;color:var(--text-secondary)}.contact-cta{margin:var(--spacing-xl) 0}.contact-note{margin-top:var(--spacing-2xl);padding:var(--spacing-lg);background-color:var(--bg-secondary);border-radius:var(--border-radius-lg);border-left:4px solid var(--primary-color)}.about-section,.recent-posts,.recent-projects{padding:var(--spacing-3xl) 0}.about-section h2,.recent-posts h2,.recent-projects h2{text-align:center;margin-bottom:var(--spacing-2xl)}.about-content{max-width:800px;margin:0 auto}.about-content p{font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);text-align:center;margin-bottom:var(--spacing-xl)}.no-projects{text-align:center;padding:var(--spacing-3xl);color:var(--text-muted)}.reading-time{font-size:var(--font-size-sm);color:var(--text-muted)}.github-stats{padding:var(--spacing-3xl) 0;background-color:var(--bg-secondary)}.github-stats h2{text-align:center;margin-bottom:var(--spacing-2xl)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl)}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}.stat-card{display:flex;align-items:center;gap:var(--spacing-lg);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);transition:all var(--transition-fast)}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.stat-icon{display:flex;align-items:center;justify-content:center;width:60px;height:60px;background-color:var(--primary-color);border-radius:var(--border-radius-lg);color:white;font-size:24px;flex-shrink:0}.stat-content{flex:1}.stat-number{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0;line-height:1}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0;font-weight:500}.books-section{padding:var(--spacing-3xl) 0}.books-section h2{text-align:center;margin-bottom:var(--spacing-3xl)}.book-subsection{margin-bottom:var(--spacing-3xl)}.book-subsection:last-child{margin-bottom:var(--spacing-2xl)}.subsection-title{display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xl)}.subsection-title i{color:var(--primary-color);font-size:var(--font-size-lg)}@media (max-width: 768px){.subsection-title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-lg)}}.books-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}@media (max-width: 768px){.books-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.book-card{display:flex;gap:var(--spacing-lg);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);transition:all var(--transition-fast)}.book-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}@media (max-width: 480px){.book-card{flex-direction:column}}.book-cover{flex-shrink:0;width:80px;height:120px;border-radius:var(--border-radius-md);overflow:hidden;position:relative}@media (max-width: 480px){.book-cover{width:60px;height:90px;align-self:center}}.reading-progress .book-cover::after{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg, rgba(37,99,235,0.1), rgba(37,99,235,0.2));pointer-events:none}.progress-overlay{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,0.8);padding:var(--spacing-xs);backdrop-filter:blur(4px)}.progress-bar{width:100%;height:4px;background-color:rgba(255,255,255,0.3);border-radius:2px;overflow:hidden;margin-bottom:var(--spacing-xs)}.progress-fill{height:100%;background:linear-gradient(90deg, var(--primary-color), var(--accent-color));border-radius:2px;transition:width 0.3s ease}.progress-text{font-size:var(--font-size-xs);color:white;font-weight:500}.wishlist{opacity:0.8}.wishlist:hover{opacity:1}.wishlist .book-placeholder{background:linear-gradient(135deg, var(--accent-color), var(--primary-color));color:white}.wishlist-badge{font-size:var(--font-size-xs);color:var(--accent-color);background-color:rgba(var(--accent-color-rgb), 0.1);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);border:1px solid var(--accent-color)}.book-image{width:100%;height:100%;object-fit:cover}.book-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background-color:var(--bg-tertiary);color:var(--text-muted);font-size:24px;border:1px solid var(--border-color);border-radius:var(--border-radius-md)}.book-content{flex:1;min-width:0}.book-title{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin:0 0 var(--spacing-xs) 0;line-height:var(--line-height-tight)}.book-author{font-size:var(--font-size-base);color:var(--text-secondary);margin:0 0 var(--spacing-sm) 0;font-style:italic}.book-rating{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.book-rating .fas.fa-star,.book-rating .far.fa-star{color:#fbbf24;font-size:var(--font-size-sm)}.book-rating .far.fa-star{color:var(--text-muted)}.rating-text{font-size:var(--font-size-sm);color:var(--text-muted);margin-left:var(--spacing-xs)}.book-review{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed);margin:0 0 var(--spacing-md) 0}.book-category{display:inline-block;font-size:var(--font-size-xs);font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--accent-color);color:white;border-radius:var(--border-radius-md);text-transform:uppercase;letter-spacing:0.05em}.books-page .books-intro{text-align:center;margin-bottom:var(--spacing-3xl)}.books-page .books-intro p{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:var(--line-height-relaxed)}.books-page .books-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(350px, 1fr));gap:var(--spacing-xl)}@media (max-width: 768px){.books-page .books-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.books-page .book-meta{display:flex;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-md);flex-wrap:wrap}.books-page .date-read{font-size:var(--font-size-xs);color:var(--text-muted);background-color:var(--bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);border:1px solid var(--border-color)}.books-page .book-isbn{margin-top:var(--spacing-sm)}.books-page .book-isbn small{color:var(--text-muted);font-size:var(--font-size-xs)}.books-page .no-books{text-align:center;padding:var(--spacing-3xl);color:var(--text-muted)}.books-page .no-books i{font-size:48px;margin-bottom:var(--spacing-md);color:var(--text-muted)}.books-page .no-books h3{margin-bottom:var(--spacing-sm);color:var(--text-secondary)}.blog-header{text-align:center;margin-bottom:var(--spacing-3xl)}.blog-header h1{margin-bottom:var(--spacing-md)}.blog-header p{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:600px;margin:0 auto var(--spacing-xl);line-height:var(--line-height-relaxed)}.blog-cta{display:flex;justify-content:center;gap:var(--spacing-lg);flex-wrap:wrap;margin-top:var(--spacing-xl)}.substack-cta{background:linear-gradient(135deg, #ff6719, #ff8a4a)}.substack-cta:hover{background:linear-gradient(135deg, #e55a16, #ff7a3a);transform:translateY(-2px)}.substack-posts{margin:var(--spacing-4xl) 0}.substack-posts h2{text-align:center;margin-bottom:var(--spacing-2xl);color:var(--text-primary)}.substack-posts .posts-intro{text-align:center;margin-bottom:var(--spacing-3xl)}.substack-posts .posts-intro p{font-size:var(--font-size-lg);color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:var(--line-height-relaxed)}.posts-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:var(--spacing-lg)}@media (max-width: 768px){.posts-grid{grid-template-columns:1fr;gap:var(--spacing-md)}}.post-embed-container{background-color:var(--bg-primary);border-radius:var(--border-radius-xl);padding:var(--spacing-md);transition:all var(--transition-fast)}.post-embed-container:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.post-embed-container .substack-post-embed p{margin-bottom:var(--spacing-md)}.post-embed-container .substack-post-embed p:first-child{font-weight:600;font-size:var(--font-size-lg);color:var(--text-primary);line-height:var(--line-height-tight)}.post-embed-container .substack-post-embed p:nth-child(2){color:var(--text-secondary);font-size:var(--font-size-base);line-height:var(--line-height-relaxed)}.post-embed-container .substack-post-embed a[data-post-link]{display:inline-flex;align-items:center;gap:var(--spacing-sm);color:var(--primary-color);text-decoration:none;font-weight:500;font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:0.5px;margin-top:var(--spacing-md)}.post-embed-container .substack-post-embed a[data-post-link]:hover{color:var(--primary-dark);text-decoration:underline}.post-embed-container .substack-post-embed a[data-post-link]::after{content:"↗";font-size:var(--font-size-lg);transition:transform var(--transition-fast)}.post-embed-container .substack-post-embed a[data-post-link]:hover::after{transform:translateX(2px) translateY(-2px)}.featured-topics{margin:var(--spacing-4xl) 0}.featured-topics h2{text-align:center;margin-bottom:var(--spacing-2xl)}.topics-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:var(--spacing-xl)}@media (max-width: 768px){.topics-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.topic-card{text-align:center;padding:var(--spacing-xl);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);transition:all var(--transition-fast)}.topic-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.topic-icon{width:60px;height:60px;background-color:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--spacing-lg);color:white;font-size:24px}.recent-highlights{margin:var(--spacing-4xl) 0}.recent-highlights h2{text-align:center;margin-bottom:var(--spacing-2xl)}.highlights-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));gap:var(--spacing-xl)}@media (max-width: 768px){.highlights-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.highlight-card{padding:var(--spacing-xl);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);transition:all var(--transition-fast)}.highlight-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.highlight-card h3{margin-bottom:var(--spacing-md);color:var(--text-primary)}.highlight-meta{font-size:var(--font-size-sm);color:var(--text-muted);margin-bottom:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.highlight-meta i{color:var(--primary-color)}.highlight-excerpt{color:var(--text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-lg)}.highlight-tags{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.newsletter-signup{background:linear-gradient(135deg, var(--primary-color), var(--accent-color));color:white;padding:var(--spacing-3xl);border-radius:var(--border-radius-xl);text-align:center;margin:var(--spacing-4xl) 0}.newsletter-signup h2{margin-bottom:var(--spacing-md);color:white}.newsletter-signup p{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xl);opacity:0.9;max-width:500px;margin-left:auto;margin-right:auto}.newsletter-signup .btn-primary{background-color:white;color:var(--primary-color)}.newsletter-signup .btn-primary:hover{background-color:var(--bg-secondary);color:var(--primary-color);transform:translateY(-2px)}.substack-link{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg, #ff6719, #ff8a4a);color:white;text-decoration:none;border-radius:var(--border-radius-md);font-weight:500;transition:all var(--transition-fast)}.substack-link:hover{background:linear-gradient(135deg, #e55a16, #ff7a3a);transform:translateY(-1px);text-decoration:none;color:white}.github-stats-section{padding:var(--spacing-2xl) 0 var(--spacing-3xl) 0;width:100%}.github-stats-section h2{text-align:left;margin-bottom:var(--spacing-sm);color:var(--text-primary);font-size:var(--font-size-2xl);font-weight:600;max-width:1200px;margin-left:auto;margin-right:auto;padding:0 2rem}.github-stats-section .section-content{width:100%;max-width:100%;margin:0;padding:0 2rem;display:flex;flex-direction:column}.github-stats-section .section-content>p{text-align:center;color:var(--text-secondary);font-size:var(--font-size-lg);margin-bottom:var(--spacing-xl);max-width:600px;margin-left:auto;margin-right:auto}.stats-row{display:flex;justify-content:flex-start;align-items:stretch;gap:var(--spacing-md);width:100%;max-width:calc(1200px - 4rem);margin:0 auto;padding:0}@media (max-width: 900px){.stats-row{flex-direction:column;align-items:stretch;max-width:calc(100% - 4rem)}}.stat-card-inline{display:flex;flex-direction:column;border-radius:var(--border-radius-md);padding:0;transition:all var(--transition-fast);text-align:center;background-color:#000000;border:1px solid #30363d;overflow:hidden;min-width:0}.stat-card-inline:hover{transform:translateY(-2px)}.stat-card-inline img{width:100%;height:auto;border-radius:0;transition:all var(--transition-fast);flex-shrink:0;margin:0;display:block;object-fit:contain;max-height:clamp(120px, 40vh, 480px)}.stat-card-inline img:hover{transform:scale(1.01)}.stat-card-inline:first-child{flex:1 1 0;min-width:320px;justify-content:center}.stat-card-inline.calendar-card{flex:1 1 0;min-width:0;display:flex;flex-direction:column}.stat-card-inline.calendar-card .calendar-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;flex:1;padding:var(--spacing-sm);min-width:0;overflow:hidden}.stat-card-inline.calendar-card .calendar-container .calendar-title{font-size:var(--font-size-sm);font-weight:500;color:#ffffff;margin:0 0 var(--spacing-xs) 0;text-align:center;text-transform:uppercase;letter-spacing:0.05em;flex-shrink:0}.stat-card-inline.calendar-card .calendar-container img{width:100%;max-width:100%;height:auto;margin:0;object-fit:contain;aspect-ratio:auto;flex:1;min-height:0;max-height:clamp(120px, 42vh, 560px)}.stat-card-inline.calendar-card .calendar-container .calendar-legend{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:#ffffff;margin:var(--spacing-xs) 0 0 0;padding:0;flex-shrink:0}.stat-card-inline.calendar-card .calendar-container .calendar-legend .legend-squares{display:flex;gap:2px}.stat-card-inline.calendar-card .calendar-container .calendar-legend .legend-text{font-size:var(--font-size-xs);color:#ffffff}@media (max-width: 900px){.stat-card-inline:first-child,.stat-card-inline.calendar-card{flex:none;width:100%;max-width:500px;justify-content:flex-start;min-width:0}}.stat-card,.stat-card-inline{min-width:0}.stat-card img{max-width:100%;height:auto;object-fit:contain;max-height:clamp(120px, 40vh, 520px);display:block}.stats-header{margin-bottom:var(--spacing-lg)}.stats-header p{margin:0 auto;color:var(--text-secondary);font-size:var(--font-size-base);max-width:500px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));gap:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.stat-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);transition:all var(--transition-fast);text-align:center}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.stat-card h3{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.stat-card h3::before{content:'';width:20px;height:20px;background-color:var(--primary-color);border-radius:50%;display:inline-block}.stat-card img{max-width:100%;height:auto;border-radius:var(--border-radius-md);transition:all var(--transition-fast)}.stat-card img:hover{transform:scale(1.02)}.stat-card.streak-card{grid-column:span 2}@media (max-width: 1024px){.stat-card.streak-card{grid-column:span 1}}.stat-card.activity-card{grid-column:span 2}@media (max-width: 1024px){.stat-card.activity-card{grid-column:span 1}}.stat-card.activity-card img{width:100%;max-width:none}.stat-card.calendar-card{grid-column:span 2}@media (max-width: 1024px){.stat-card.calendar-card{grid-column:span 1}}.stat-card.calendar-card img{width:100%;max-width:none;border-radius:var(--border-radius-md)}.stats-footer{text-align:center;padding:var(--spacing-xl);background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);margin-top:var(--spacing-lg)}.stats-footer p{margin:0;color:var(--text-secondary);font-size:var(--font-size-base)}.stats-footer p a{color:var(--primary-color);text-decoration:none;font-weight:500}.stats-footer p a:hover{color:var(--primary-dark);text-decoration:underline}.stat-card img{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-secondary) 50%, var(--bg-tertiary) 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:200% 0}100%{background-position:-200% 0}}.legend-squares{display:flex;gap:var(--spacing-xs)}.legend-square{width:8px;height:8px;border-radius:1px}.legend-square.level-0{background-color:#161b22;border:1px solid #30363d}.legend-square.level-1{background-color:#0e4429}.legend-square.level-2{background-color:#006d32}.legend-square.level-3{background-color:#26a641}.legend-square.level-4{background-color:#39d353}.monthly-breakdown{margin-top:var(--spacing-3xl)}.monthly-breakdown h3{text-align:center;font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-2xl)}.monthly-stats-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:var(--spacing-xl)}@media (max-width: 768px){.monthly-stats-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}}.monthly-stat-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);padding:var(--spacing-xl);transition:all var(--transition-fast)}.monthly-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary-color)}.monthly-stat-card h4{font-size:var(--font-size-lg);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-lg);text-align:center}.monthly-stat-card img{max-width:100%;height:auto;border-radius:var(--border-radius-md)}.commit-pattern{display:flex;justify-content:space-between;align-items:flex-end;height:120px;padding:var(--spacing-lg) 0;margin-bottom:var(--spacing-md)}.pattern-day{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);flex:1}.day-label{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:500}.day-bar{width:20px;background:linear-gradient(to top, var(--primary-color), var(--accent-color));border-radius:var(--border-radius-sm);min-height:10px;transition:all var(--transition-fast)}.day-bar:hover{transform:scaleX(1.2);filter:brightness(1.1)}.pattern-note{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:center;margin:0;font-style:italic}.productivity-card{text-align:center}.productivity-metrics{display:grid;grid-template-columns:repeat(3, 1fr);gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.metric{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.metric-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--primary-color);line-height:1}.metric-label{font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:0.05em}.best-streak{padding:var(--spacing-md);background-color:var(--bg-secondary);border-radius:var(--border-radius-md);border-left:4px solid var(--primary-color);font-size:var(--font-size-sm);color:var(--text-secondary)}.best-streak strong{color:var(--text-primary)}[data-theme="dark"] .stat-card,[data-theme="dark"] .monthly-stat-card{background-color:rgba(22,27,34,0.8);border-color:rgba(48,54,61,0.5)}[data-theme="dark"] .stat-card:hover,[data-theme="dark"] .monthly-stat-card:hover{border-color:var(--primary-color);background-color:#161b22}[data-theme="dark"] .stats-footer{background-color:rgba(22,27,34,0.8);border-color:rgba(48,54,61,0.5)}[data-theme="dark"] .best-streak{background-color:rgba(13,17,23,0.8)}.music-section .soundcloud-player{margin-top:var(--spacing-md);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all var(--transition-fast)}.music-section .soundcloud-player:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.music-section .soundcloud-player iframe{border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0;transition:all var(--transition-fast)}.music-section .soundcloud-player div{background-color:#333;padding:var(--spacing-xs) var(--spacing-sm);border-radius:0 0 var(--border-radius-lg) var(--border-radius-lg)}@media (max-width: 768px){.music-section .soundcloud-player{margin-top:var(--spacing-sm)}.music-section .soundcloud-player iframe{height:150px}}.text-center{text-align:center}@media (max-width: 767px){.site-nav .menu-icon{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:rgba(37,99,235,0.1);touch-action:manipulation;user-select:none}.site-nav .menu-icon:active{background-color:var(--primary-color);color:white}.site-nav .menu-icon:active span,.site-nav .menu-icon:active span:before,.site-nav .menu-icon:active span:after{background-color:white}.site-nav .page-link,.site-nav .theme-toggle{min-height:44px;display:flex;align-items:center;justify-content:flex-start;-webkit-tap-highlight-color:rgba(37,99,235,0.1);touch-action:manipulation;user-select:none}.site-nav .page-link:active,.site-nav .theme-toggle:active{background-color:var(--primary-color);color:white;transform:scale(0.98)}.site-nav .theme-toggle{justify-content:flex-start;gap:var(--spacing-sm)}.site-nav .theme-toggle::after{content:'Toggle theme';font-size:var(--font-size-sm);font-family:inherit}input[type="text"],input[type="email"],input[type="search"],textarea{font-size:16px}}@media (prefers-reduced-motion: reduce){.site-nav .trigger,.site-nav .menu-icon span,.site-nav .menu-icon span:before,.site-nav .menu-icon span:after{transition:none}}@media (prefers-contrast: high){.site-nav .menu-icon{border:2px solid currentColor}.site-nav .trigger{border:2px solid currentColor}.site-nav .page-link:focus,.site-nav .theme-toggle:focus{outline:3px solid currentColor;outline-offset:2px}}.about-hero{background:linear-gradient(135deg, #667eea 0%, #764ba2 100%);color:white;padding:4rem 0;margin-bottom:3rem}.about-hero .about-hero-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;max-width:1200px;margin:0 auto;padding:0 2rem}@media (max-width: 768px){.about-hero .about-hero-content{grid-template-columns:1fr;gap:2rem;text-align:center}}.about-hero .hero-text h1{font-size:3rem;font-weight:700;margin-bottom:1rem;line-height:1.2}@media (max-width: 768px){.about-hero .hero-text h1{font-size:2.5rem}}.about-hero .hero-text .lead{font-size:1.25rem;margin-bottom:2rem;opacity:0.9;line-height:1.6}.about-hero .hero-stats{display:flex;gap:2rem}@media (max-width: 768px){.about-hero .hero-stats{justify-content:center;gap:1.5rem}}@media (max-width: 520px){.about-hero .hero-stats{flex-direction:column;gap:1rem}}.about-hero .stat-item{text-align:center}.about-hero .stat-item .stat-number{display:block;font-size:2.5rem;font-weight:700;color:#fff}.about-hero .stat-item .stat-label{font-size:0.9rem;opacity:0.8;text-transform:uppercase;letter-spacing:0.5px}.about-hero .hero-image{display:flex;flex-direction:column;align-items:center;gap:1rem}.about-hero .hero-image .profile-photo{width:300px;height:300px;border-radius:50%;object-fit:cover;border:5px solid rgba(255,255,255,0.2);transition:transform 0.3s ease}.about-hero .hero-image .profile-photo:hover{transform:scale(1.05)}@media (max-width: 768px){.about-hero .hero-image .profile-photo{width:250px;height:250px}}.about-hero .hero-image .profile-gallery{display:flex;gap:0.5rem}.about-hero .hero-image .profile-gallery .gallery-thumb{width:60px;height:60px;border-radius:8px;object-fit:cover;border:2px solid rgba(255,255,255,0.3);cursor:pointer;transition:all 0.3s ease;opacity:0.7}.about-hero .hero-image .profile-gallery .gallery-thumb:hover{opacity:1;transform:translateY(-2px);border-color:rgba(255,255,255,0.8)}.about-section{max-width:1200px;margin:0 auto 4rem;padding:0 2rem}.about-section h2{font-size:2.5rem;color:var(--text-color);margin-bottom:2rem;text-align:center;position:relative}.about-section h2::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:linear-gradient(90deg, #667eea, #764ba2);border-radius:2px}.about-section .section-content{font-size:1.1rem;line-height:1.8;color:var(--text-secondary);max-width:800px;margin:0 auto;text-align:center}.interests-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:2rem;margin-top:3rem}.interest-card{background:var(--card-bg);border-radius:12px;padding:2rem;box-shadow:0 4px 20px rgba(0,0,0,0.1);transition:all 0.3s ease;border:1px solid var(--border-color)}.interest-card:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,0.15)}.interest-card .interest-icon{font-size:3rem;margin-bottom:1rem;display:block}.interest-card h3{color:var(--text-color);margin-bottom:1rem;font-size:1.3rem}.interest-card p{color:var(--text-secondary);line-height:1.6;margin:0}.interest-card a{color:var(--accent-color);text-decoration:none}.interest-card a:hover{text-decoration:underline}.experience-section{margin-top:3rem}.experience-filters{display:flex;justify-content:center;gap:1rem;margin-bottom:3rem;flex-wrap:wrap}.filter-btn{background:var(--card-bg);border:2px solid var(--border-color);color:var(--text-color);padding:0.75rem 1.5rem;border-radius:25px;font-weight:500;cursor:pointer;transition:all 0.3s ease}.filter-btn:hover,.filter-btn.active{background:var(--accent-color);color:white;border-color:var(--accent-color)}.experience-timeline{display:grid;grid-template-columns:repeat(auto-fit, minmax(350px, 1fr));gap:2rem;margin-top:2rem}.experience-item{background:var(--card-bg);border-radius:12px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,0.1);transition:all 0.3s ease;border:1px solid var(--border-color);opacity:0;transform:translateY(20px)}.experience-item.animate-in{opacity:1;transform:translateY(0)}.experience-item:hover{transform:translateY(-5px);box-shadow:0 8px 30px rgba(0,0,0,0.15)}.experience-item.featured{border:2px solid var(--accent-color)}.experience-item.featured .experience-header::before{content:'⭐';position:absolute;top:1rem;right:1rem;font-size:1.2rem}.experience-item .experience-image{width:100%;height:200px;object-fit:cover;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-style:italic}.experience-item .experience-content{padding:1.5rem}.experience-item .experience-header{position:relative;margin-bottom:1rem}.experience-item .experience-header .experience-title{font-size:1.3rem;font-weight:600;color:var(--text-color);margin-bottom:0.5rem}.experience-item .experience-header .experience-org{color:var(--accent-color);font-weight:500;margin-bottom:0.25rem}.experience-item .experience-header .experience-meta{display:flex;justify-content:space-between;align-items:center;font-size:0.9rem;color:var(--text-secondary);margin-bottom:0.5rem}@media (max-width: 480px){.experience-item .experience-header .experience-meta{flex-direction:column;align-items:flex-start;gap:0.25rem}}.experience-item .experience-header .experience-category{background:var(--accent-color);color:white;padding:0.25rem 0.75rem;border-radius:12px;font-size:0.8rem;font-weight:500}.experience-item .experience-description{color:var(--text-secondary);line-height:1.6;margin-bottom:1rem}.experience-item .experience-highlights ul{list-style:none;padding:0;margin:0 0 1rem 0}.experience-item .experience-highlights ul li{position:relative;padding-left:1.5rem;margin-bottom:0.5rem;color:var(--text-secondary)}.experience-item .experience-highlights ul li::before{content:'▶';position:absolute;left:0;color:var(--accent-color);font-size:0.8rem}.experience-item .experience-tech{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1rem}.experience-item .experience-tech .tech-tag{background:var(--bg-secondary);color:var(--text-secondary);padding:0.25rem 0.75rem;border-radius:15px;font-size:0.8rem;border:1px solid var(--border-color)}.experience-item .experience-links{display:flex;gap:1rem;margin-top:1rem}.experience-item .experience-links a{color:var(--accent-color);text-decoration:none;font-weight:500;font-size:0.9rem}.experience-item .experience-links a:hover{text-decoration:underline}.experience-item .experience-links a i{margin-right:0.5rem}.skills-container{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:2rem;margin-top:3rem}.skill-category h3{color:var(--text-color);margin-bottom:1rem;font-size:1.3rem}.skill-tags{display:flex;flex-wrap:wrap;gap:0.75rem}.skill-tag{background:var(--accent-color);color:white;padding:0.5rem 1rem;border-radius:20px;font-weight:500;font-size:0.9rem;transition:all 0.3s ease}.skill-tag:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(0,0,0,0.2)}.connect-content{text-align:center;max-width:800px;margin:0 auto}.connect-content p{font-size:1.1rem;line-height:1.8;color:var(--text-secondary);margin-bottom:3rem}.contact-links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:2rem}@media (max-width: 768px){.contact-links{flex-direction:column;align-items:center;gap:0.75rem}}.contact-link{display:flex;align-items:center;gap:0.5rem;background:var(--card-bg);padding:0.75rem 1.5rem;border-radius:8px;text-decoration:none;color:var(--text-color);border:1px solid var(--border-color);transition:all 0.3s ease;font-size:0.9rem}.contact-link:hover{transform:translateY(-2px);box-shadow:0 4px 15px rgba(0,0,0,0.1);border-color:var(--accent-color);color:var(--accent-color)}.contact-link i{font-size:1rem}.contact-link span{font-weight:500}.current-status{margin-top:3rem}.status-card{background:var(--card-bg);border-radius:12px;padding:2rem;border:1px solid var(--border-color);max-width:600px;margin:0 auto}.status-card h4{color:var(--text-color);margin-bottom:1rem;font-size:1.2rem}.status-card p{color:var(--text-secondary);line-height:1.6;margin:0}.status-card p em{color:var(--accent-color);font-weight:500}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 0}.loading-spinner .spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--accent-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-spinner p{color:var(--text-secondary);font-style:italic}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes countUp{from{opacity:0}to{opacity:1}}.cv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;padding:2rem 0;border-bottom:2px solid var(--border-color)}@media (max-width: 768px){.cv-header{flex-direction:column;gap:2rem}}.cv-header .cv-info h1{font-size:2.5rem;color:var(--text-color);margin-bottom:0.5rem;font-weight:700}@media (max-width: 768px){.cv-header .cv-info h1{font-size:2rem}}.cv-header .cv-info .cv-title{color:var(--accent-color);font-size:1.2rem;font-weight:500;margin-bottom:1rem}.cv-header .cv-info .cv-contact{display:flex;gap:2rem;color:var(--text-secondary)}@media (max-width: 768px){.cv-header .cv-info .cv-contact{flex-direction:column;gap:0.5rem}}.cv-header .cv-info .cv-contact span{display:flex;align-items:center;gap:0.5rem}.cv-header .cv-info .cv-contact span i{width:16px;color:var(--accent-color)}.cv-header .cv-info .cv-contact span a{color:var(--text-secondary);text-decoration:none}.cv-header .cv-info .cv-contact span a:hover{color:var(--accent-color);text-decoration:underline}.cv-header .cv-actions .btn{background:var(--accent-color);color:white;padding:0.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:500;transition:all 0.3s ease;border:none;cursor:pointer}.cv-header .cv-actions .btn:hover{background:var(--accent-color-dark, #4338ca);transform:translateY(-2px)}.cv-header .cv-actions .btn i{margin-right:0.5rem}.cv-section{margin-bottom:3rem}.cv-section h2{color:var(--text-color);font-size:1.8rem;margin-bottom:2rem;display:flex;align-items:center;gap:0.75rem}.cv-section h2 i{color:var(--accent-color);font-size:1.5rem}.cv-timeline{position:relative;padding-left:2rem}.cv-timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--border-color)}.cv-timeline .timeline-item{position:relative;margin-bottom:2.5rem}.cv-timeline .timeline-item::before{content:'';position:absolute;left:-2rem;top:0.5rem;width:12px;height:12px;background:var(--accent-color);border-radius:50%;border:3px solid var(--bg-color);box-shadow:0 0 0 2px var(--border-color)}.cv-timeline .timeline-item .timeline-date{color:var(--accent-color);font-weight:600;font-size:0.9rem;margin-bottom:0.5rem;text-transform:uppercase;letter-spacing:0.5px}.cv-timeline .timeline-item .timeline-content{background:var(--card-bg);padding:1.5rem;border-radius:8px;border:1px solid var(--border-color)}.cv-timeline .timeline-item .timeline-content h3{color:var(--text-color);font-size:1.3rem;font-weight:600;margin-bottom:0.5rem}.cv-timeline .timeline-item .timeline-content h4{color:var(--text-secondary);font-size:1rem;font-weight:500;margin-bottom:1rem}.cv-timeline .timeline-item .timeline-content h4 a{color:var(--accent-color);text-decoration:none}.cv-timeline .timeline-item .timeline-content h4 a:hover{text-decoration:underline}.cv-timeline .timeline-item .timeline-content ul{list-style:none;padding:0;margin:0 0 1rem 0}.cv-timeline .timeline-item .timeline-content ul li{position:relative;padding-left:1.5rem;margin-bottom:0.5rem;color:var(--text-secondary);line-height:1.5}.cv-timeline .timeline-item .timeline-content ul li::before{content:'•';position:absolute;left:0;color:var(--accent-color);font-weight:bold}.cv-timeline .timeline-item .timeline-content .tech-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1rem}.cv-timeline .timeline-item .timeline-content .tech-tags span{background:var(--bg-secondary);color:var(--text-secondary);padding:0.25rem 0.75rem;border-radius:12px;font-size:0.8rem;font-weight:500;border:1px solid var(--border-color)}.cv-skills{display:grid;grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));gap:2rem}.cv-skills .skill-group h3{color:var(--text-color);font-size:1.1rem;margin-bottom:1rem;font-weight:600}.cv-skills .skill-group .skill-list{display:flex;flex-wrap:wrap;gap:0.5rem}.cv-skills .skill-group .skill-list .skill-item{background:var(--accent-color);color:white;padding:0.4rem 0.8rem;border-radius:15px;font-size:0.85rem;font-weight:500;transition:all 0.3s ease}.cv-skills .skill-group .skill-list .skill-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.15)}.cv-additional{display:grid;grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));gap:2rem}.cv-additional .additional-item{background:var(--card-bg);padding:1.5rem;border-radius:8px;border:1px solid var(--border-color)}.cv-additional .additional-item h3{color:var(--text-color);font-size:1.1rem;margin-bottom:0.75rem;font-weight:600}.cv-additional .additional-item p{color:var(--text-secondary);line-height:1.6;margin:0}.cv-additional .additional-item p a{color:var(--accent-color);text-decoration:none}.cv-additional .additional-item p a:hover{text-decoration:underline}.home-section{max-width:1200px;margin:0 auto 2rem;padding:0 1.5rem}.home-section h2{font-size:2.5rem;color:var(--text-color);margin-bottom:2rem;text-align:center;position:relative}.home-section h2::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:80px;height:3px;background:linear-gradient(90deg, #667eea, #764ba2);border-radius:2px}.home-section .section-content{font-size:1.1rem;line-height:1.8;color:var(--text-secondary);max-width:800px;margin:0 auto;text-align:center}.home-section .philosophy-content{max-width:800px;margin:0 auto}.home-section .philosophy-content p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:1.5rem;text-align:center}.home-section .philosophy-content .philosophy-list{list-style:none;padding:0}.home-section .philosophy-content .philosophy-list li{background:var(--card-bg);margin-bottom:1rem;padding:1.5rem;border-radius:8px;border:1px solid var(--border-color);color:var(--text-secondary);line-height:1.6}.home-section .philosophy-content .philosophy-list li strong{color:var(--text-color)}.home-content{display:grid;grid-template-columns:2fr 1fr;gap:3rem;align-items:center;max-width:1200px;margin:0 auto;padding:2rem}@media (max-width: 768px){.home-content{grid-template-columns:1fr;gap:2rem;text-align:center}}.home-text-container{display:flex;flex-direction:column;gap:1.5rem}.home-text-container .contact-links{margin-top:0;gap:1rem;justify-content:flex-start}@media (max-width: 768px){.home-text-container .contact-links{gap:0.75rem;justify-content:center}}.home-text-container .contact-link{padding:0.5rem 1rem;font-size:0.9rem}@media (max-width: 768px){.home-text-container .contact-link{padding:0.4rem 0.8rem;font-size:0.85rem}}.home-text-container .contact-link i{font-size:1rem}@media (max-width: 768px){.home-text-container .contact-link i{font-size:0.9rem}}.home-text h1{font-size:3rem;font-weight:700;margin-bottom:1.5rem;line-height:1.2;color:var(--text-primary);text-align:left}@media (max-width: 768px){.home-text h1{font-size:2.5rem;text-align:center}}.home-text p{text-align:left;margin-bottom:1.5rem}@media (max-width: 768px){.home-text p{text-align:center}}.home-text .lead{font-size:1.25rem;margin-bottom:2rem;color:var(--text-secondary);line-height:1.6}.home-image{display:flex;justify-content:center;align-items:center}.home-image .profile-photo{width:min(30vw, 320px);height:min(30vw, 320px);max-width:320px;max-height:320px;min-width:200px;min-height:200px;border-radius:50%;object-fit:cover;border:4px solid var(--border-color);transition:transform 0.3s ease, box-shadow 0.3s ease;box-shadow:var(--shadow-lg);aspect-ratio:1}.home-image .profile-photo:hover{transform:scale(1.05);box-shadow:0 20px 40px rgba(0,0,0,0.1)}@media (max-width: 768px){.home-image .profile-photo{width:min(40vw, 280px);height:min(40vw, 280px);max-width:280px;max-height:280px;min-width:180px;min-height:180px}}@media (max-width: 480px){.home-image .profile-photo{width:min(50vw, 220px);height:min(50vw, 220px);max-width:220px;max-height:220px;min-width:160px;min-height:160px}}@media print{.cv-actions{display:none}.cv-header,.cv-section{break-inside:avoid}.timeline-item{break-inside:avoid;margin-bottom:1.5rem}.cv-timeline::before{background:#333}.timeline-item::before{background:#333;border-color:white}body{font-size:12pt;line-height:1.4}h1{font-size:20pt}h2{font-size:16pt}h3{font-size:14pt}h4{font-size:12pt}}@media (prefers-color-scheme: dark){.about-hero{background:linear-gradient(135deg, #4c51bf 0%, #553c9a 100%)}.interest-card,.experience-item,.status-card,.contact-link,.cv-additional .additional-item,.timeline-content{box-shadow:0 4px 20px rgba(0,0,0,0.3)}.interest-card:hover,.experience-item:hover,.status-card:hover,.contact-link:hover,.cv-additional .additional-item:hover,.timeline-content:hover{box-shadow:0 8px 30px rgba(0,0,0,0.4)}}.cv-container{max-width:900px;margin:0 auto;padding:2rem 1rem}.cv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid var(--border-color)}@media (max-width: 768px){.cv-header{flex-direction:column;gap:1.5rem}}.cv-info{flex:1}.cv-info h1{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem 0}@media (max-width: 768px){.cv-info h1{font-size:2rem}}.cv-title{font-size:1.2rem;color:var(--text-secondary);margin-bottom:1rem;font-weight:500}.cv-contact{display:flex;flex-wrap:wrap;gap:1.5rem}.cv-contact span{display:flex;align-items:center;gap:0.5rem;font-size:0.95rem;color:var(--text-secondary)}.cv-contact span i{color:var(--accent-color);width:16px}.cv-contact span a{color:var(--text-secondary);text-decoration:none}.cv-contact span a:hover{color:var(--accent-color);text-decoration:underline}@media (max-width: 768px){.cv-contact{gap:1rem}}.cv-actions .btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.75rem 1.5rem;border:none;border-radius:8px;text-decoration:none;font-weight:600;font-size:0.95rem;transition:all 0.3s ease;cursor:pointer}.cv-actions .btn.btn-primary{background:var(--primary-color);color:white}.cv-actions .btn.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.cv-section{margin-bottom:3rem}.cv-section h2{display:flex;align-items:center;gap:0.75rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border-color)}.cv-section h2 i{color:var(--accent-color);width:20px}.cv-timeline{position:relative;padding-left:2rem}.cv-timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom, var(--accent-color), #fbbf24)}@media (max-width: 768px){.cv-timeline{padding-left:1.5rem}}.timeline-item{position:relative;margin-bottom:2.5rem;padding-left:2rem}.timeline-item::before{content:'';position:absolute;left:-8px;top:8px;width:16px;height:16px;border-radius:50%;background:var(--accent-color);border:3px solid var(--bg-primary);box-shadow:0 0 0 3px #fef3c7}.timeline-item:last-child{margin-bottom:0}@media (max-width: 768px){.timeline-item{padding-left:1.5rem}.timeline-item::before{left:-6px;width:12px;height:12px}}.timeline-date{display:inline-block;background:#fef3c7;color:var(--accent-color);padding:0.25rem 0.75rem;border-radius:12px;font-size:0.85rem;font-weight:600;margin-bottom:0.75rem}.timeline-content h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0 0 0.5rem 0}.timeline-content h4{font-size:1rem;font-weight:500;color:var(--text-secondary);margin:0 0 1rem 0}.timeline-content h4 a{color:var(--accent-color);text-decoration:none}.timeline-content h4 a:hover{text-decoration:underline}.timeline-content .role-description{font-style:italic;color:var(--text-secondary);margin-bottom:1rem;font-size:0.95rem;line-height:1.5}.timeline-content ul{margin:1rem 0;padding-left:1.5rem}.timeline-content ul li{margin-bottom:0.5rem;color:var(--text-primary);line-height:1.6}.experience-header{display:flex;align-items:flex-start;gap:1rem}@media (max-width: 768px){.experience-header{flex-direction:column;gap:0.75rem}}.company-logo{flex-shrink:0}.company-logo .logo-placeholder{width:48px;height:48px;border-radius:8px;background:var(--accent-color);color:white;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700}@media (max-width: 768px){.company-logo .logo-placeholder{width:40px;height:40px;font-size:1rem}}.experience-details{flex:1}.experience-details .company-description{font-size:0.85rem;color:var(--text-secondary);margin:0 0 0.25rem 0;text-transform:uppercase;letter-spacing:0.5px;font-weight:500}.tech-tags{display:flex;flex-wrap:wrap;gap:0.5rem;margin-top:1rem}.tech-tags span{background:var(--bg-secondary);color:var(--text-secondary);padding:0.25rem 0.75rem;border-radius:16px;font-size:0.8rem;font-weight:500;border:1px solid var(--border-color);transition:all 0.2s ease}.tech-tags span:hover{background:#fef3c7;color:var(--accent-color);border-color:var(--accent-color)}.cv-skills{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));gap:2rem}@media (max-width: 768px){.cv-skills{grid-template-columns:1fr;gap:1.5rem}}.skill-group h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;padding-bottom:0.5rem;border-bottom:1px solid var(--border-color)}.skill-list{display:flex;flex-wrap:wrap;gap:0.75rem}.skill-item{background:var(--bg-secondary);color:var(--text-primary);padding:0.5rem 1rem;border-radius:20px;font-size:0.9rem;font-weight:500;border:1px solid var(--border-color);transition:all 0.3s ease;position:relative}.skill-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.skill-item.skill-advanced{background:var(--accent-color);color:white;border-color:var(--accent-color)}.skill-item.skill-advanced:hover{background:#d97706}.skill-item.skill-intermediate{background:#fef3c7;color:var(--accent-color);border-color:var(--accent-color)}.skill-item.skill-intermediate:hover{background:var(--accent-color);color:white}.skill-item.skill-basic{background:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border-color)}.skill-item.skill-basic:hover{background:#fef3c7;color:var(--accent-color);border-color:var(--accent-color)}.cv-additional{display:grid;gap:1.5rem}.additional-item h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:0.5rem}.additional-item p{color:var(--text-secondary);line-height:1.6;margin:0}@media print{.cv-container{max-width:none;padding:0;margin:0}.cv-actions{display:none}.cv-section{break-inside:avoid;margin-bottom:2rem}.timeline-item{break-inside:avoid;margin-bottom:1.5rem}.tech-tags span,.skill-item{background:#f5f5f5 !important;color:#333 !important;border:1px solid #ddd !important}}.hidden{display:none !important}.block{display:block !important}.inline{display:inline !important}.inline-block{display:inline-block !important}.flex{display:flex !important}.inline-flex{display:inline-flex !important}.grid{display:grid !important}.flex-row{flex-direction:row !important}.flex-col{flex-direction:column !important}.flex-wrap{flex-wrap:wrap !important}.flex-nowrap{flex-wrap:nowrap !important}.items-start{align-items:flex-start !important}.items-center{align-items:center !important}.items-end{align-items:flex-end !important}.justify-start{justify-content:flex-start !important}.justify-center{justify-content:center !important}.justify-end{justify-content:flex-end !important}.justify-between{justify-content:space-between !important}.m-0{margin:0 !important}.mt-0{margin-top:0 !important}.mr-0{margin-right:0 !important}.mb-0{margin-bottom:0 !important}.ml-0{margin-left:0 !important}.m-1{margin:var(--spacing-xs) !important}.mt-1{margin-top:var(--spacing-xs) !important}.mr-1{margin-right:var(--spacing-xs) !important}.mb-1{margin-bottom:var(--spacing-xs) !important}.ml-1{margin-left:var(--spacing-xs) !important}.m-2{margin:var(--spacing-sm) !important}.mt-2{margin-top:var(--spacing-sm) !important}.mr-2{margin-right:var(--spacing-sm) !important}.mb-2{margin-bottom:var(--spacing-sm) !important}.ml-2{margin-left:var(--spacing-sm) !important}.m-4{margin:var(--spacing-md) !important}.mt-4{margin-top:var(--spacing-md) !important}.mr-4{margin-right:var(--spacing-md) !important}.mb-4{margin-bottom:var(--spacing-md) !important}.ml-4{margin-left:var(--spacing-md) !important}.m-6{margin:var(--spacing-lg) !important}.mt-6{margin-top:var(--spacing-lg) !important}.mr-6{margin-right:var(--spacing-lg) !important}.mb-6{margin-bottom:var(--spacing-lg) !important}.ml-6{margin-left:var(--spacing-lg) !important}.m-8{margin:var(--spacing-xl) !important}.mt-8{margin-top:var(--spacing-xl) !important}.mr-8{margin-right:var(--spacing-xl) !important}.mb-8{margin-bottom:var(--spacing-xl) !important}.ml-8{margin-left:var(--spacing-xl) !important}.p-0{padding:0 !important}.pt-0{padding-top:0 !important}.pr-0{padding-right:0 !important}.pb-0{padding-bottom:0 !important}.pl-0{padding-left:0 !important}.p-1{padding:var(--spacing-xs) !important}.pt-1{padding-top:var(--spacing-xs) !important}.pr-1{padding-right:var(--spacing-xs) !important}.pb-1{padding-bottom:var(--spacing-xs) !important}.pl-1{padding-left:var(--spacing-xs) !important}.p-2{padding:var(--spacing-sm) !important}.pt-2{padding-top:var(--spacing-sm) !important}.pr-2{padding-right:var(--spacing-sm) !important}.pb-2{padding-bottom:var(--spacing-sm) !important}.pl-2{padding-left:var(--spacing-sm) !important}.p-4{padding:var(--spacing-md) !important}.pt-4{padding-top:var(--spacing-md) !important}.pr-4{padding-right:var(--spacing-md) !important}.pb-4{padding-bottom:var(--spacing-md) !important}.pl-4{padding-left:var(--spacing-md) !important}.p-6{padding:var(--spacing-lg) !important}.pt-6{padding-top:var(--spacing-lg) !important}.pr-6{padding-right:var(--spacing-lg) !important}.pb-6{padding-bottom:var(--spacing-lg) !important}.pl-6{padding-left:var(--spacing-lg) !important}.p-8{padding:var(--spacing-xl) !important}.pt-8{padding-top:var(--spacing-xl) !important}.pr-8{padding-right:var(--spacing-xl) !important}.pb-8{padding-bottom:var(--spacing-xl) !important}.pl-8{padding-left:var(--spacing-xl) !important}.text-left{text-align:left !important}.text-center{text-align:center !important}.text-right{text-align:right !important}.text-justify{text-align:justify !important}.text-uppercase{text-transform:uppercase !important}.text-lowercase{text-transform:lowercase !important}.text-capitalize{text-transform:capitalize !important}.font-light{font-weight:300 !important}.font-normal{font-weight:400 !important}.font-medium{font-weight:500 !important}.font-semibold{font-weight:600 !important}.font-bold{font-weight:700 !important}.text-primary{color:var(--text-primary) !important}.text-secondary{color:var(--text-secondary) !important}.text-muted{color:var(--text-muted) !important}.text-blue{color:var(--primary-color) !important}.text-amber{color:var(--accent-color) !important}.bg-primary{background-color:var(--bg-primary) !important}.bg-secondary{background-color:var(--bg-secondary) !important}.bg-tertiary{background-color:var(--bg-tertiary) !important}.border{border:1px solid var(--border-color) !important}.border-t{border-top:1px solid var(--border-color) !important}.border-r{border-right:1px solid var(--border-color) !important}.border-b{border-bottom:1px solid var(--border-color) !important}.border-l{border-left:1px solid var(--border-color) !important}.border-none{border:none !important}.rounded-none{border-radius:0 !important}.rounded-sm{border-radius:var(--border-radius-sm) !important}.rounded{border-radius:var(--border-radius-md) !important}.rounded-lg{border-radius:var(--border-radius-lg) !important}.rounded-xl{border-radius:var(--border-radius-xl) !important}.rounded-full{border-radius:50% !important}.shadow-none{box-shadow:none !important}.shadow-sm{box-shadow:var(--shadow-sm) !important}.shadow{box-shadow:var(--shadow-md) !important}.shadow-lg{box-shadow:var(--shadow-lg) !important}.w-full{width:100% !important}.w-auto{width:auto !important}.max-w-none{max-width:none !important}.max-w-xs{max-width:320px !important}.max-w-sm{max-width:384px !important}.max-w-md{max-width:448px !important}.max-w-lg{max-width:512px !important}.max-w-xl{max-width:576px !important}.max-w-2xl{max-width:672px !important}.max-w-3xl{max-width:768px !important}.max-w-4xl{max-width:896px !important}.max-w-5xl{max-width:1024px !important}.max-w-6xl{max-width:1152px !important}.max-w-full{max-width:100% !important}.relative{position:relative !important}.absolute{position:absolute !important}.fixed{position:fixed !important}.sticky{position:sticky !important}.z-0{z-index:0 !important}.z-10{z-index:10 !important}.z-20{z-index:20 !important}.z-30{z-index:30 !important}.z-40{z-index:40 !important}.z-50{z-index:50 !important}.overflow-hidden{overflow:hidden !important}.overflow-auto{overflow:auto !important}.overflow-scroll{overflow:scroll !important}.overflow-visible{overflow:visible !important}.cursor-pointer{cursor:pointer !important}.cursor-default{cursor:default !important}.cursor-not-allowed{cursor:not-allowed !important}.opacity-0{opacity:0 !important}.opacity-25{opacity:0.25 !important}.opacity-50{opacity:0.5 !important}.opacity-75{opacity:0.75 !important}.opacity-100{opacity:1 !important}.transition{transition:all var(--transition-fast) !important}.transition-none{transition:none !important}@media (max-width: 639px){.sm\:hidden{display:none !important}.sm\:block{display:block !important}.sm\:flex{display:flex !important}.sm\:text-center{text-align:center !important}.sm\:text-left{text-align:left !important}}@media (min-width: 640px) and (max-width: 767px){.md\:hidden{display:none !important}.md\:block{display:block !important}.md\:flex{display:flex !important}}@media (min-width: 768px){.lg\:hidden{display:none !important}.lg\:block{display:block !important}.lg\:flex{display:flex !important}.lg\:text-left{text-align:left !important}}@media print{.print\:hidden{display:none !important}}[data-theme="dark"]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: #334155;--border-light: #475569;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.3), 0 2px 4px -2px rgb(0 0 0 / 0.3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.3), 0 4px 6px -4px rgb(0 0 0 / 0.3)}@media (prefers-color-scheme: dark){:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: #334155;--border-light: #475569;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.3);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.3), 0 2px 4px -2px rgb(0 0 0 / 0.3);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.3), 0 4px 6px -4px rgb(0 0 0 / 0.3)}}[data-theme="light"]{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #64748b;--border-color: #e2e8f0;--border-light: #f1f5f9;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1)}[data-theme="dark"] .site-header{background-color:rgba(15,23,42,0.95)}[data-theme="dark"] .hero-section{background:linear-gradient(135deg, var(--bg-primary) 0%, var(--bg-secondary) 100%)}[data-theme="dark"] .post-card:hover,[data-theme="dark"] .project-card:hover{box-shadow:var(--shadow-lg)}[data-theme="dark"] code{background-color:var(--bg-tertiary);color:var(--text-primary)}[data-theme="dark"] pre{background-color:var(--bg-tertiary);color:var(--text-primary)}[data-theme="dark"] blockquote{background-color:var(--bg-secondary);color:var(--text-secondary)}[data-theme="dark"] input,[data-theme="dark"] textarea,[data-theme="dark"] select{background-color:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}[data-theme="dark"] input:focus,[data-theme="dark"] textarea:focus,[data-theme="dark"] select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(37,99,235,0.2)}[data-theme="dark"] table th{background-color:var(--bg-secondary);color:var(--text-primary)}[data-theme="dark"] table td{color:var(--text-secondary)}[data-theme="dark"] table th,[data-theme="dark"] table td{border-bottom-color:var(--border-color)}.theme-toggle i{transition:transform var(--transition-fast)}[data-theme="dark"] .theme-toggle #theme-icon:before{content:"\f185"}[data-theme="light"] .theme-toggle #theme-icon:before{content:"\f186"}*{transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}
