:root{--color-white:#fff;--color-black:#000;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-300:#d1d5db;--color-gray-500:#6b7280;--color-gray-600:#4b5563;--color-gray-700:#374151;--color-gray-800:#1f2937;--color-gray-900:#111827;--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-primary-light:#dbeafe;--color-bg-primary:var(--color-gray-50);--color-bg-secondary:var(--color-white);--color-bg-tertiary:var(--color-gray-100);--color-text-primary:var(--color-gray-900);--color-text-secondary:var(--color-gray-700);--color-text-tertiary:var(--color-gray-600);--color-text-muted:var(--color-gray-500);--space-1:0.25rem;--space-2:0.5rem;--space-3:0.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;--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;--blog-heading-h1:clamp(2rem,5vw,3rem);--blog-heading-h2:clamp(1.5rem,3.5vw,2rem);--blog-heading-h3:clamp(1.25rem,2.5vw,1.5rem);--blog-body-size:clamp(1rem,1.5vw,1.125rem);--blog-meta-size:clamp(0.8125rem,1.2vw,0.875rem);--blog-card-title:clamp(1.25rem,2.5vw,1.75rem);--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.625;--line-height-loose:1.75;--blog-line-height-heading:1.3;--blog-line-height-body:1.7;--blog-line-height-relaxed:1.8;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-sm:0.25rem;--radius-base:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-full:9999px;--border-width-thin:1px;--border-width-base:2px;--border-width-thick:3px;--border-width-heavy:4px;--shadow-xs:0 1px 2px 0 rgba(0,0,0,.05);--shadow-sm:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:200ms cubic-bezier(0.4,0,0.2,1);--transition-slow:300ms cubic-bezier(0.4,0,0.2,1);--scale-hover:1.05;--scale-active:1.1;--translate-hover:-2px;--translate-hover-lg:-4px;--translate-full:-100%;--opacity-10:0.1;--opacity-20:0.2;--opacity-50:0.5;--opacity-70:0.7;--opacity-90:0.9;--overlay-light:hsla(0,0%,100%,.1);--overlay-medium:hsla(0,0%,100%,.2);--overlay-strong:hsla(0,0%,100%,.3);--overlay-dark:rgba(0,0,0,.5);--container-max-width:1200px;--sidebar-width:20rem;--prose-max-width:65ch;--post-image-height:12rem;--profile-image-size:8rem;--social-link-size:2.5rem;--icon-size-base:1.25rem;--z-base:1;--z-dropdown:10;--z-sticky:20;--z-overlay:30;--z-sidebar:40;--z-modal:50;--z-toast:60;--blur-sm:4px;--blur-md:8px;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-primary);color:var(--color-text-primary)}.sr-only{block-size:1px;inline-size:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;clip:rect(0,0,0,0);border-width:0;white-space:nowrap}.focus\:not-sr-only:focus{block-size:auto;inline-size:auto;margin:0;overflow:visible;padding:var(--space-2)var(--space-4);position:static;clip:auto;white-space:normal}:root{--link-decoration-thickness:var(--border-width-thin);--link-underline-offset:var(--space-1)}a{color:var(--color-primary);cursor:pointer;text-decoration:none;transition:color var(--transition-fast),text-decoration-color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}a:focus-visible{border-radius:var(--radius-sm);outline:var(--border-width-base)solid var(--color-primary);outline-offset:var(--space-1)}.prose a{text-decoration-thickness:var(--link-decoration-thickness);text-underline-offset:var(--link-underline-offset)}.prose{color:var(--color-text-secondary);font-size:var(--blog-body-size);line-height:var(--blog-line-height-body);max-inline-size:var(--prose-max-width)}.prose :is(h1,h2,h3,h4,h5,h6){color:var(--color-text-primary);font-weight:var(--font-weight-bold);line-height:var(--blog-line-height-heading);margin-block-end:var(--space-4);margin-block-start:var(--space-8);scroll-margin-top:var(--space-16)}.prose h1{font-size:var(--blog-heading-h1);letter-spacing:-.03em;margin-block-start:0}.prose h2{border-block-end:var(--border-width-base)solid var(--color-gray-100);font-size:var(--blog-heading-h2);letter-spacing:-.02em;padding-block-end:var(--space-2)}.prose h3{font-size:var(--blog-heading-h3);letter-spacing:-.015em}.prose h4{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.prose p{color:var(--color-text-secondary);line-height:var(--blog-line-height-body);margin-block-end:var(--space-5)}.prose p:last-child{margin-block-end:0}.prose p:first-of-type{color:var(--color-text-primary);font-size:var(--font-size-lg);line-height:var(--blog-line-height-relaxed);margin-block-end:var(--space-6)}.prose :is(ul,ol){margin-block-end:var(--space-5);padding-inline-start:var(--space-8)}.prose li{line-height:var(--blog-line-height-body);margin-block-end:var(--space-3);padding-inline-start:var(--space-2)}.prose li::marker{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.prose ul li{list-style-type:disc}.prose ul li ul li{list-style-type:circle}.prose ol{list-style-type:decimal}.prose ol ol{list-style-type:lower-alpha}.prose strong{font-weight:var(--font-weight-bold)}.prose em,.prose strong{color:var(--color-text-primary)}.prose em{font-style:italic}.prose blockquote{background-color:var(--color-gray-50);border-inline-start:var(--border-width-heavy)solid var(--color-primary);border-radius:var(--radius-base);color:var(--color-text-secondary);font-style:italic;margin:var(--space-6)0;padding:var(--space-5)var(--space-6)}.prose blockquote p{margin-block-end:var(--space-3)}.prose blockquote p:last-child{margin-block-end:0}.prose code{background-color:var(--color-gray-100);border-radius:var(--radius-sm);color:var(--color-primary-dark);font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;font-size:.9em;font-weight:var(--font-weight-medium);padding:var(--space-1)var(--space-2)}.prose pre{background-color:var(--color-gray-900);border-radius:var(--radius-md);line-height:var(--line-height-relaxed);margin:var(--space-6)0;overflow-x:auto;padding:var(--space-5)}.prose pre code{background:0 0;color:var(--color-gray-50);font-size:var(--font-size-sm);padding:0}.prose hr{border:none;border-block-start:var(--border-width-base)solid var(--color-gray-200);margin:var(--space-8)0}.prose img{border-radius:var(--radius-md);height:auto;margin:var(--space-6)0;max-width:100%}.prose figure{margin:var(--space-8)0}.prose figure img{margin:0}.prose figure figcaption{color:var(--color-text-tertiary);font-size:var(--font-size-sm);font-style:italic;margin-block-start:var(--space-3);text-align:center}.prose table{border-collapse:collapse;font-size:var(--font-size-sm);margin:var(--space-6)0;width:100%}.prose thead{border-block-end:var(--border-width-base)solid var(--color-gray-300)}.prose th{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);text-align:left}.prose td,.prose th{padding:var(--space-3)var(--space-4)}.prose td{border-block-end:var(--border-width-thin)solid var(--color-gray-100)}.prose tbody tr:hover{background-color:var(--color-gray-50)}.prose a{color:var(--color-primary);font-weight:var(--font-weight-medium);text-decoration:underline;text-decoration-color:var(--color-primary-light);text-decoration-thickness:var(--border-width-thin);text-underline-offset:var(--space-1);transition:all var(--transition-fast)}.prose a:hover{color:var(--color-primary-dark);text-decoration-color:var(--color-primary-dark);text-decoration-thickness:var(--border-width-base)}.prose-lg{font-size:var(--font-size-lg);line-height:var(--blog-line-height-relaxed)}.prose-lg h1{font-size:calc(var(--blog-heading-h1)*1.1)}.prose-lg h2{font-size:calc(var(--blog-heading-h2)*1.1)}.prose-lg h3{font-size:calc(var(--blog-heading-h3)*1.1)}.prose-sm{font-size:var(--font-size-sm);line-height:var(--blog-line-height-body)}.prose-sm h1{font-size:var(--blog-heading-h2)}.prose-sm h2{font-size:var(--blog-heading-h3)}.prose-sm h3{font-size:var(--font-size-xl)}.max-w-none{max-inline-size:none}.card{background-color:var(--color-bg-secondary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:all var(--transition-base)}@media(min-width:768px){.card{padding:var(--space-8)}}.skill-badge{align-items:center;background-color:var(--color-primary-light);border:var(--border-width-base)solid transparent;border-radius:var(--radius-base);color:var(--color-primary-dark);cursor:default;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);list-style:none;padding:var(--space-2)var(--space-4);transition:all var(--transition-base)}.skill-badge:hover{border-color:var(--color-primary);transform:translateY(0);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.skill-badge:hover:hover{box-shadow:var(--shadow-xs);transform:translateY(calc(var(--translate-hover)/2))}.tag-pill{border-radius:var(--radius-full);display:inline-block;font-size:var(--font-size-sm);padding:var(--space-1)var(--space-2)}.tag-pill.primary{background-color:var(--color-primary);color:var(--color-white)}.tag-pill.gray{background-color:var(--color-gray-100);color:var(--color-gray-800)}.tag-pill.active{box-shadow:0 0 0 var(--border-width-thick)rgba(59,130,246,var(--opacity-10))}.container{inline-size:100%;margin-inline:auto;max-inline-size:var(--container-max-width);padding-inline:var(--space-4)}@media(min-width:768px){.container{padding-inline:var(--space-6)}}.icon{block-size:var(--icon-size-base);display:inline-block;flex-shrink:0;inline-size:var(--icon-size-base);vertical-align:middle}.icon-sm{block-size:var(--space-4);inline-size:var(--space-4)}.icon-lg{block-size:var(--space-6);inline-size:var(--space-6)}.share-bar{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3)}.share-button{align-items:center;background-color:var(--color-white);border:var(--border-width-thin)solid var(--color-gray-300);border-radius:var(--radius-md);color:var(--color-gray-700);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-2);padding:var(--space-2)var(--space-4);text-decoration:none;transition:all var(--transition-base)}.share-button:hover{transform:translateY(0);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.share-button:hover:hover{box-shadow:var(--shadow-sm);transform:translateY(calc(var(--translate-hover)/2))}.share-button .share-label{display:none}@media(min-width:768px){.share-button .share-label{display:inline}}.pagination{justify-content:center;margin-top:var(--space-12)}.pagination,.pagination ul{align-items:center;display:flex;gap:var(--space-1)}.pagination ul{list-style:none;padding:0}.pagination .pagination-btn,.pagination .pagination-number{align-items:center;border:var(--border-width-thin)solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);display:inline-flex;font-weight:var(--font-weight-medium);justify-content:center;min-width:2.5rem;padding:var(--space-2)var(--space-3);transition:all var(--transition-base)}.pagination .pagination-btn svg,.pagination .pagination-number svg{flex-shrink:0}.pagination .pagination-btn:hover:not(.active):not(:disabled),.pagination .pagination-number:hover:not(.active):not(:disabled){background:var(--primary);border-color:var(--primary);color:var(--color-white)}.pagination .pagination-btn:hover:not(:disabled) svg{transform:scale(var(--scale-active))}.pagination .pagination-number{padding:var(--space-2)var(--space-4)}.pagination .pagination-number.active{background:var(--primary);border-color:var(--primary);color:var(--color-white);font-weight:var(--font-weight-semibold)}.pagination .pagination-info{color:var(--text-muted);font-size:var(--font-size-sm);margin-left:var(--space-6)}.reading-progress{background:var(--color-gray-200);height:3px;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity var(--transition-base);z-index:1000}.reading-progress:has(.reading-progress-bar[style*=width]){opacity:1}.reading-progress .reading-progress-bar{background:linear-gradient(90deg,var(--color-primary),var(--color-accent));height:100%;transition:width .1s ease-out;width:0}.post-content pre{border-radius:var(--rounded-md);margin:var(--space-6)0;overflow-x:auto}.post-content table{border-collapse:collapse;font-size:var(--font-size-sm);margin:var(--space-6)0;width:100%}.post-content table td,.post-content table th{border:var(--border-width-base)solid var(--color-gray-200);padding:var(--space-3)var(--space-4);text-align:left}.post-content table th{font-weight:var(--font-semibold)}.post-content table th,.post-content table tr:hover{background:var(--color-gray-50)}.post-content blockquote{border-left:4px solid var(--color-primary);color:var(--text-muted);font-style:italic;margin:var(--space-6)0;padding-left:var(--space-6)}.posts-list .page-header{margin-bottom:var(--space-8)}.posts-list .page-header h1{color:var(--color-text-primary);font-size:var(--blog-heading-h1);font-weight:var(--font-weight-bold);letter-spacing:-.03em;line-height:var(--blog-line-height-heading);margin-bottom:var(--space-3)}.posts-list .page-header .page-description{color:var(--text-muted);font-size:var(--blog-body-size);font-weight:var(--font-weight-normal);line-height:var(--blog-line-height-body);margin-bottom:var(--space-8);max-width:70ch}.posts-list .post-categories{margin-bottom:var(--space-2)}.posts-list .post-categories a{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-normal);text-transform:uppercase}.posts-list .post-image{border-radius:var(--radius-md);margin-bottom:var(--space-4);overflow:hidden}.posts-list .post-image img{height:var(--post-image-height);-o-object-fit:cover;object-fit:cover;transition:transform var(--transition-base);width:100%}.posts-list .post-image img:hover{transform:scale(var(--scale-hover))}.posts-list .post-meta{align-items:center;color:var(--text-muted);display:flex;flex-wrap:wrap;font-size:var(--font-size-sm);gap:var(--space-2)}.posts-list .post-meta :is(.post-author,.post-date,.reading-time){align-items:center;display:flex;gap:var(--space-2)}.posts-list .post-meta .separator{color:var(--border-color)}.posts-list .post-summary{color:var(--text-secondary);line-height:var(--line-height-relaxed);margin:var(--space-4)0}.posts-list .post-footer{border-top:var(--border-width-thin)solid var(--border-color);margin-top:var(--space-4);padding-top:var(--space-4)}.posts-list .post-footer .post-tags{display:flex;flex:1;flex-wrap:wrap;gap:var(--space-2)}.posts-list .post-footer .post-tags .more-tags{color:var(--text-muted);font-size:var(--font-size-xs)}.posts-list .post-footer .read-more{align-items:center;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-1);transition:color var(--transition-base)}.posts-list .post-footer .footer-content{align-items:center;display:flex;gap:var(--space-4);justify-content:space-between}.posts-grid{container-name:posts-grid;container-type:inline-size;display:grid;gap:var(--space-8);grid-template-columns:1fr}@container posts-grid (min-width:48rem){.posts-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.posts-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.posts-grid{gap:var(--space-10)}}.post-card{background-color:var(--color-bg-secondary);border:var(--border-width-base)solid var(--color-gray-200);border-radius:var(--radius-lg);display:flex;flex-direction:column;height:100%;overflow:hidden;transition:all var(--transition-base)}.post-card:hover{transform:translateY(0);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.post-card:hover:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(var(--translate-hover-lg))}.post-card:hover .post-image img{transform:scale(var(--scale-hover))}.post-image{overflow:hidden}.post-image img{transition:transform .4s ease}.post-content{display:flex;flex-direction:column;height:100%;padding:var(--space-6)}.post-header{margin-block-end:var(--space-4)}.post-categories{margin-block-end:var(--space-3)}.post-categories a{font-size:var(--font-size-xs);letter-spacing:var(--letter-spacing-normal);text-transform:uppercase}.post-categories a,.post-title{font-weight:var(--font-weight-bold)}.post-title{font-size:var(--blog-card-title);letter-spacing:-.02em;line-height:var(--blog-line-height-heading);margin-block-end:var(--space-4)}.post-title a{color:var(--color-text-primary)}.post-title a:hover{color:var(--color-primary)}.post-meta{align-items:center;color:var(--color-text-tertiary);display:flex;flex-wrap:wrap;font-size:var(--blog-meta-size);font-weight:var(--font-weight-medium);gap:var(--space-2);line-height:var(--line-height-normal)}.post-meta svg{flex-shrink:0}.post-meta a{color:inherit}.post-meta a:hover{color:var(--color-primary)}.post-summary{color:var(--color-text-secondary);flex-grow:1;font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--blog-line-height-body);margin-block-end:var(--space-6)}@media(max-width:767px){.post-summary{font-size:var(--font-size-sm);line-height:var(--blog-line-height-relaxed)}}.post-footer{border-block-start:var(--border-width-thin)solid var(--color-gray-100);margin-top:auto;padding-block-start:var(--space-4)}.post-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.read-more{flex-shrink:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-tight);white-space:nowrap}.reading-progress-container .reading-progress-bar{background:linear-gradient(90deg,var(--color-primary) 0,var(--color-primary-dark) 100%);box-shadow:0 2px 4px rgba(0,0,0,.1)}.related-posts{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-submenu{border-block-end:var(--border-width-thin)solid var(--color-gray-200);margin-block-end:var(--space-8);padding-block-end:var(--space-6)}.blog-submenu .submenu-header{align-items:center;display:flex;justify-content:space-between;margin-block-end:var(--space-4)}.blog-submenu .submenu-title{align-items:center;display:flex;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);gap:var(--space-2);letter-spacing:-.01em;line-height:var(--blog-line-height-heading)}.blog-submenu .submenu-link{align-items:center;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-1)}.blog-submenu .submenu-grid{display:grid;gap:var(--space-6)}@media(min-width:768px){.blog-submenu .submenu-grid{grid-template-columns:repeat(2,1fr)}}.blog-submenu .filter-section h4{align-items:center;color:var(--color-gray-700);display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-2);letter-spacing:var(--letter-spacing-normal);margin-block-end:var(--space-3);text-transform:uppercase}.blog-submenu .filter-section .filter-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.sidebar{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);block-size:100vh;inline-size:var(--sidebar-width);inset-block-start:0;inset-inline-start:0;overflow-y:auto;position:fixed;transform:translateX(var(--translate-full));transition:transform var(--transition-slow);z-index:var(--z-sidebar)}@media(min-width:1024px){.sidebar{transform:translateX(0)!important}.sidebar-close,.sidebar-overlay,.sidebar-toggle{display:none}}@media(max-width:767px){.sidebar-toggle{display:block}}.sidebar-content{block-size:100%;display:flex;flex-direction:column;min-block-size:100vh;position:relative}.sidebar-close{align-items:center;background:0 0;border:none;border-radius:var(--radius-md);color:var(--color-white);cursor:pointer;display:flex;inset-block-start:var(--space-4);inset-inline-end:var(--space-4);justify-content:center;padding:var(--space-2);position:absolute;transition:background-color var(--transition-base);z-index:var(--z-dropdown)}.sidebar-close:hover{background-color:var(--overlay-medium)}.sidebar-close .icon{block-size:var(--space-6);inline-size:var(--space-6);pointer-events:none}.sidebar-overlay{backdrop-filter:blur(var(--blur-sm));background-color:var(--overlay-dark);inset:0;opacity:0;pointer-events:none;position:fixed;transition:opacity var(--transition-slow),visibility var(--transition-slow);visibility:hidden;z-index:var(--z-overlay)}.sidebar-toggle{background-color:var(--color-primary);border:none;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);color:var(--color-white);cursor:pointer;inset-block-start:var(--space-4);inset-inline-start:var(--space-4);padding:var(--space-3);position:fixed;transition:all var(--transition-base);z-index:var(--z-toast)}.sidebar-toggle:hover{background-color:var(--color-primary-dark);transform:scale(var(--scale-hover))}.sidebar-toggle .icon{block-size:var(--space-6);display:block;inline-size:var(--space-6)}.sidebar-toggle .icon-close{display:none}.sidebar-profile{color:var(--color-white);padding:var(--space-8);text-align:center}.profile-image-wrapper{margin-block-end:var(--space-6)}.profile-image{block-size:var(--profile-image-size);border:var(--border-width-heavy)solid var(--color-white);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);inline-size:var(--profile-image-size);margin-inline:auto;-o-object-fit:cover;object-fit:cover}.profile-name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-block-end:var(--space-2)}.profile-tagline{color:rgba(255,255,255,var(--opacity-90));font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.sidebar-section{color:var(--color-white);padding:var(--space-6)}.sidebar-section.sidebar-flex{flex:1}.sidebar-section.sidebar-footer{padding-block-end:var(--space-8);padding-block-start:var(--space-4)}.sidebar-title{color:var(--color-white);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-block-end:var(--space-4)}.contact-list{flex-direction:column}.contact-item,.contact-list{display:flex;gap:var(--space-3)}.contact-item{align-items:center;color:rgba(255,255,255,var(--opacity-90));transition:color var(--transition-fast)}.contact-item:hover,.contact-item:hover .icon{color:var(--color-white)}.contact-item .icon{block-size:var(--icon-size-base);color:rgba(255,255,255,var(--opacity-70));flex-shrink:0;inline-size:var(--icon-size-base);transition:color var(--transition-fast)}.contact-item .contact-text{font-size:var(--font-size-sm)}.social-links{display:flex;gap:var(--space-4)}.social-link{align-items:center;background-color:var(--overlay-light);block-size:var(--social-link-size);border-radius:var(--radius-full);color:var(--color-white);display:flex;inline-size:var(--social-link-size);justify-content:center;transition:all var(--transition-base)}.social-link:hover{background-color:var(--overlay-medium);color:var(--color-white);transform:scale(var(--scale-active))}.social-link .icon{block-size:var(--icon-size-base);inline-size:var(--icon-size-base)}.language-item{align-items:center;color:rgba(255,255,255,var(--opacity-90));display:flex;justify-content:space-between}.language-level{color:rgba(255,255,255,var(--opacity-70));font-size:var(--font-size-xs)}.language-switcher{display:flex;flex-direction:column;gap:var(--space-2)}.language-link{color:rgba(255,255,255,var(--opacity-90));font-size:var(--font-size-sm);transition:color var(--transition-fast)}.btn-download,.language-link:hover{color:var(--color-white)}.btn-download{background-color:var(--overlay-medium);border:var(--border-width-thin)solid var(--overlay-strong);border-radius:var(--radius-md);display:block;font-weight:var(--font-weight-medium);inline-size:100%;padding:var(--space-3)var(--space-6);text-align:center;transition:all var(--transition-base)}.btn-download:hover{background-color:var(--overlay-strong);box-shadow:var(--shadow-md);color:var(--color-white);transform:translateY(var(--translate-hover))}#main-content{position:relative;z-index:calc(var(--z-overlay) + 5)}@media(max-width:767px){#main-content{padding-block-start:var(--space-16)}}@media(min-width:1024px){#main-content{margin-inline-start:var(--sidebar-width);z-index:calc(var(--z-sidebar) + 5)}}.floating-controls{display:flex;flex-direction:column;gap:var(--space-3);inset-block-start:var(--space-4);inset-inline-end:var(--space-4);position:fixed;z-index:var(--z-toast)}@media(max-width:767px){.floating-controls{gap:var(--space-2);inset-block-start:var(--space-3);inset-inline-end:var(--space-3)}}.floating-control{position:relative}.control-button{align-items:center;backdrop-filter:blur(10px);background:linear-gradient(135deg,var(--color-white) 0,var(--color-gray-50) 100%);border:var(--border-width-base)solid var(--color-gray-300);border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,6%),inset 0 0 0 1px hsla(0,0%,100%,.5);color:var(--color-text-primary);cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--space-2);justify-content:center;min-width:3.5rem;padding:var(--space-3)var(--space-4);text-decoration:none;transition:all var(--transition-base)}.control-button:hover{background:linear-gradient(135deg,var(--color-primary-light) 0,var(--color-white) 100%);border-color:var(--color-primary);box-shadow:0 10px 15px -3px rgba(0,0,0,.15),0 4px 6px -2px rgba(0,0,0,.1),0 0 0 3px var(--color-primary-light);transform:translateY(-2px)scale(1.02)}.control-button:hover .icon{color:var(--color-primary);transform:scale(1.1)}.control-button:active{transform:translateY(0)scale(.98)}.control-button .icon{block-size:var(--space-5);color:var(--color-gray-600);flex-shrink:0;inline-size:var(--space-5);transition:all var(--transition-fast)}.control-button .control-label{font-weight:var(--font-weight-bold);letter-spacing:.05em;min-width:2ch;text-align:center}@media(max-width:767px){.control-button .control-label{display:none}}.page-toggle .control-button{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark) 100%);border-color:var(--color-primary-dark);box-shadow:0 4px 6px -1px rgba(37,99,235,.3),0 2px 4px -1px rgba(37,99,235,.2),inset 0 0 0 1px hsla(0,0%,100%,.2);color:var(--color-white)}.page-toggle .control-button .control-label,.page-toggle .control-button .icon{color:var(--color-white)}.page-toggle .control-button:hover{background:linear-gradient(135deg,var(--color-primary-dark) 0,var(--color-primary) 100%);border-color:var(--color-primary-dark);box-shadow:0 10px 15px -3px rgba(37,99,235,.4),0 4px 6px -2px rgba(37,99,235,.3),0 0 0 3px rgba(37,99,235,.2);transform:translateY(-2px)scale(1.05)}.page-toggle .control-button:hover .icon{color:var(--color-white);transform:scale(1.15)}.control-dropdown{backdrop-filter:blur(10px);background-color:var(--color-white);border:var(--border-width-base)solid var(--color-gray-200);border-radius:var(--radius-lg);box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,4%),inset 0 0 0 1px hsla(0,0%,100%,.5);inset-block-start:calc(100% + var(--space-2));inset-inline-end:0;min-inline-size:12rem;opacity:0;overflow:hidden;pointer-events:none;position:absolute;transform:translateY(-10px)scale(.95);transition:opacity var(--transition-base),visibility var(--transition-base),transform var(--transition-base);visibility:hidden}.control-dropdown.active{opacity:1;pointer-events:auto;transform:translateY(0)scale(1);visibility:visible}.dropdown-item{align-items:center;background:0 0;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--space-3);padding:var(--space-3)var(--space-4);position:relative;text-align:left;text-decoration:none;transition:all var(--transition-fast);width:100%}.dropdown-item:before{background:var(--color-primary);content:"";inset-block-end:0;inset-block-start:0;inset-inline-start:0;position:absolute;transform:scaleY(0);transition:transform var(--transition-fast);width:3px}.dropdown-item:hover{background:linear-gradient(90deg,var(--color-primary-light) 0,transparent 100%);color:var(--color-primary);padding-inline-start:calc(var(--space-4) + var(--space-1))}.dropdown-item:hover:before{transform:scaleY(1)}.dropdown-item:not(:last-child){border-block-end:var(--border-width-thin)solid var(--color-gray-100)}.dropdown-item .item-icon{color:var(--color-gray-600);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);letter-spacing:.1em;min-width:2.5ch;text-align:center;transition:all var(--transition-fast)}.dropdown-item .item-label{flex:1;transition:transform var(--transition-fast)}.dropdown-item:hover .item-icon{color:var(--color-primary);transform:scale(1.1)}.dropdown-item:hover .item-label{transform:translateX(2px)}.theme-selector .theme-color{block-size:var(--space-5);border:var(--border-width-base)solid var(--color-white);border-radius:var(--radius-full);box-shadow:0 0 0 var(--border-width-base)var(--color-gray-300),0 2px 4px rgba(0,0,0,.1);flex-shrink:0;inline-size:var(--space-5);transition:all var(--transition-fast)}.theme-selector .dropdown-item:hover .theme-color{box-shadow:0 0 0 2px var(--color-white),0 0 0 4px var(--color-primary),0 4px 6px rgba(0,0,0,.15);transform:scale(1.2)}@keyframes pulse-glow{0%,to{box-shadow:0 4px 6px -1px rgba(37,99,235,.3),0 2px 4px -1px rgba(37,99,235,.2),inset 0 0 0 1px hsla(0,0%,100%,.2)}50%{box-shadow:0 4px 6px -1px rgba(37,99,235,.4),0 2px 4px -1px rgba(37,99,235,.3),inset 0 0 0 1px hsla(0,0%,100%,.3),0 0 20px rgba(37,99,235,.3)}}.page-toggle .control-button{animation:pulse-glow 3s ease-in-out infinite}@media(max-width:767px){.floating-controls{gap:var(--space-2)}.control-button{min-width:3rem;padding:var(--space-2)var(--space-3)}.control-dropdown{inset-inline-end:0;min-inline-size:10rem}}@media print{.floating-controls{display:none!important}}.cv-container{margin-inline:auto;max-inline-size:1200px;padding-inline:var(--space-6)}@media(max-width:767px){.cv-container{padding-inline:var(--space-4)}}.cv-hero{background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 34%,#fff) 0,color-mix(in srgb,var(--color-primary-dark) 34%,#fff) 100%);border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 10px 10px -5px rgba(0,0,0,5%),inset 0 0 0 1px rgba(0,0,0,5%);color:var(--color-gray-900);margin-block-end:var(--space-12);margin-block-start:var(--space-8);margin-inline:0;overflow:hidden;padding:var(--space-16)var(--space-8)var(--space-12);position:relative;transition:background var(--transition-base)}.cv-hero:before{background:radial-gradient(circle at top right,hsla(0,0%,100%,.4) 0,transparent 50%),radial-gradient(circle at bottom left,hsla(0,0%,100%,.2) 0,transparent 50%);content:"";inset:0;pointer-events:none;position:absolute}.cv-hero:after{background:linear-gradient(90deg,color-mix(in srgb,var(--color-primary) 60%,#fff) 0,color-mix(in srgb,var(--color-primary) 40%,#fff) 50%,color-mix(in srgb,var(--color-primary) 60%,#fff) 100%);block-size:4px;content:"";inset-block-end:0;inset-inline-end:0;inset-inline-start:0;opacity:.8;position:absolute}@media(max-width:767px){.cv-hero{border-radius:var(--radius-lg);margin-block-end:var(--space-8);margin-inline:calc(var(--space-4)*-1);padding:var(--space-8)var(--space-4)}}.cv-hero__content{max-inline-size:1100px;position:relative;z-index:1}.cv-hero__badge{backdrop-filter:blur(10px);background:hsla(0,0%,100%,.6);border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-full);color:var(--color-gray-700);display:inline-block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);letter-spacing:.1em;margin-block-end:var(--space-5);padding:var(--space-2)var(--space-5);text-transform:uppercase}@media(max-width:767px){.cv-hero__badge{font-size:var(--font-size-xs);margin-block-end:var(--space-4)}}.cv-hero__headline{color:var(--color-gray-900);font-size:var(--font-size-5xl);font-weight:var(--font-weight-bold);letter-spacing:-.03em;line-height:var(--line-height-tight);margin-block-end:var(--space-8)}@media(max-width:767px){.cv-hero__headline{font-size:var(--font-size-3xl);margin-block-end:var(--space-6)}}.cv-hero__highlights{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-block-end:var(--space-8)}@media(max-width:767px){.cv-hero__highlights{gap:var(--space-2);margin-block-end:var(--space-6)}}.cv-hero__highlight{align-items:center;backdrop-filter:blur(5px);background:hsla(0,0%,100%,.5);border:1px solid rgba(0,0,0,8%);border-radius:var(--radius-lg);color:var(--color-gray-800);display:flex;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);gap:var(--space-2);padding:var(--space-3)var(--space-5);transition:all var(--transition-base)}.cv-hero__highlight:hover{background:hsla(0,0%,100%,.7);transform:translateY(-2px)}@media(max-width:767px){.cv-hero__highlight{font-size:var(--font-size-sm);padding:var(--space-2)var(--space-3)}}.cv-hero__icon{block-size:var(--space-5);flex-shrink:0;inline-size:var(--space-5)}@media(max-width:767px){.cv-hero__icon{block-size:var(--space-4);inline-size:var(--space-4)}}.cv-hero__description{color:var(--color-gray-700);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);max-inline-size:900px}.cv-hero__description p{color:hsla(0,0%,100%,.9);font-weight:var(--font-weight-normal);margin-block-end:var(--space-4)}.cv-hero__description p:first-child{color:hsla(0,0%,100%,.95);font-size:var(--font-size-xl);font-weight:var(--font-weight-medium);margin-block-end:var(--space-5)}.cv-hero__description p:last-child{margin-block-end:0}.cv-hero__description strong{color:var(--color-white);font-weight:var(--font-weight-bold)}.cv-hero__description *{color:inherit!important}@media(max-width:767px){.cv-hero__description{font-size:var(--font-size-base)}.cv-hero__description p:first-child{font-size:var(--font-size-lg)}}.cv-section{margin-block-end:var(--space-10)}@media(max-width:767px){.cv-section{margin-block-end:var(--space-8)}}.cv-section h2{border-block-end:var(--border-width-heavy)solid var(--color-primary);color:var(--color-text-primary);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-block-end:var(--space-6);padding-block-end:var(--space-3)}@media(max-width:767px){.cv-section h2{font-size:var(--font-size-2xl);margin-block-end:var(--space-4);padding-block-end:var(--space-2)}}.cv-card{background-color:var(--color-bg-secondary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-block-end:var(--space-6);padding:var(--space-6);transition:all var(--transition-base)}@media(min-width:768px){.cv-card{padding:var(--space-8)}}.cv-card:hover{transform:translateY(0);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.cv-card:hover:hover{box-shadow:var(--shadow-md);transform:translateY(var(--translate-hover))}@media(max-width:767px){.cv-card{padding:var(--space-4)}}.cv-card h3{color:var(--color-text-primary);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-block-end:var(--space-3)}.cv-card h4{color:var(--color-text-secondary);margin-block:var(--space-4)var(--space-3)}.cv-card .cv-company,.cv-card h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.cv-card .cv-company{color:var(--color-primary)}.cv-card .cv-date{color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);white-space:nowrap}.cv-card ul{list-style:disc;margin-block:var(--space-4)var(--space-3);padding-inline-start:var(--space-6)}.cv-card ul li{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-block-end:var(--space-3)}.cv-card ul li::marker{color:var(--color-primary)}.cv-card p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-block-end:var(--space-3)}.cv-card p:last-child{margin-block-end:0}.cv-card strong{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.cv-grid{display:grid;gap:var(--space-6)}@media(min-width:768px){.cv-grid{grid-template-columns:repeat(2,1fr)}}.cv-competency{background-color:var(--color-bg-secondary);border:var(--border-width-base)solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:all var(--transition-base)}@media(min-width:768px){.cv-competency{padding:var(--space-8)}}.cv-competency:hover{border-color:var(--color-primary);transform:translateY(0);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.cv-competency:hover:hover{box-shadow:var(--shadow-sm);transform:translateY(calc(var(--translate-hover)/2))}.cv-competency h3{align-items:center;color:var(--color-primary-dark);display:flex;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);gap:var(--space-2);margin-block-end:var(--space-3)}.cv-competency p{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}@media print{.cv-section{margin-block-end:var(--space-4)!important;-moz-column-break-inside:avoid;break-inside:avoid}.cv-section h2{border-block-end-width:2px!important;font-size:1.15rem!important;margin-block-end:var(--space-2)!important;padding-block-end:var(--space-1)!important}.cv-card{border:1px solid var(--color-gray-200);box-shadow:none!important;margin-block-end:var(--space-3)!important;padding:var(--space-3)!important;-moz-column-break-inside:avoid;break-inside:avoid}.cv-card h3{font-size:.95rem!important;margin-block-end:var(--space-1)!important}.cv-card h4{font-size:.9rem!important;margin-block:var(--space-2)var(--space-1)!important}.cv-card .cv-company{font-size:.85rem!important}.cv-card .cv-date{font-size:.75rem!important}.cv-card p{font-size:.8rem!important;line-height:1.35!important;margin-block-end:var(--space-1)!important}.cv-card ul{margin-block:var(--space-2)!important}.cv-card ul li{font-size:.8rem!important;line-height:1.35!important;margin-block-end:.1rem!important}.cv-grid{gap:var(--space-2)!important}.cv-competency{box-shadow:none!important;padding:var(--space-3)!important}.cv-competency h3{font-size:.9rem!important;margin-block-end:var(--space-1)!important}.cv-competency p{font-size:.8rem!important;line-height:1.35!important}.space-y-4>*+*,.space-y-6>*+*{margin-block-start:var(--space-2)!important}.space-y-8>*+*{margin-block-start:var(--space-3)!important}.grid{gap:var(--space-2)!important}@page{margin:1.2cm;size:A4}body{background:var(--color-white)!important;padding-block-start:0!important}main{padding-block:var(--space-1)!important}li,p{orphans:3;widows:3}}.flex{display:flex}.grid{display:grid}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.space-y-4>*+*{margin-block-start:var(--space-4)}.space-y-6>*+*{margin-block-start:var(--space-6)}.space-y-8>*+*{margin-block-start:var(--space-8)}.w-full{inline-size:100%}.min-h-screen{min-block-size:100vh}.mx-auto{margin-inline:auto}.mb-4{margin-block-end:var(--space-4)}.mb-6{margin-block-end:var(--space-6)}.mb-8{margin-block-end:var(--space-8)}.text-center{text-align:center}.font-bold{font-weight:var(--font-weight-bold)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-medium{font-weight:var(--font-weight-medium)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.rounded-full{border-radius:var(--radius-full)}.rounded-lg{border-radius:var(--radius-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.transition-all{transition:all var(--transition-base)}.animate-fade-in{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(calc(var(--space-2)*5))}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translateY(var(--translate-hover-lg))}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(calc(var(--space-2)*5))}to{opacity:1;transform:translateY(0)}}@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media print{.btn-download,.sidebar,.sidebar-overlay,.sidebar-toggle{display:none!important}#main-content{margin-inline-start:0!important;padding-block-start:0!important;z-index:1!important}body{background-color:var(--color-white)}main{padding-block:var(--space-2)}header{padding-block:var(--space-3)}section{-moz-column-break-inside:avoid;break-inside:avoid}.card,section{margin-block-end:var(--space-2)}.card{border:1px solid var(--color-gray-200);box-shadow:none;padding:var(--space-3)}h1{font-size:2.25rem;margin-block-end:var(--space-1)}h2{border-block-end-width:2px;font-size:1.25rem;margin-block-end:var(--space-2);padding-block-end:var(--space-1)}h3{font-size:1rem;margin-block-end:var(--space-1)}h4{font-size:.9rem;margin-block:var(--space-2)var(--space-1)}p{font-size:.8rem;line-height:1.4}p,ul{margin-block-end:var(--space-1)}li{font-size:.8rem;line-height:1.4;margin-block-end:.1rem}.space-y-4>*+*{margin-block-start:var(--space-2)}.space-y-8>*+*{margin-block-start:var(--space-3)}.grid{gap:var(--space-2)}@page{margin:1.2cm;size:A4}}