*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #1e293b;--bg-card-hover: #273548;--bg-code: #0d1117;--bg-tag: rgba(99, 102, 241, .15);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent: #6366f1;--accent-hover: #818cf8;--accent-glow: rgba(99, 102, 241, .3);--accent-secondary: #06b6d4;--accent-secondary-glow: rgba(6, 182, 212, .2);--border: #334155;--border-light: rgba(148, 163, 184, .1);--gradient-hero: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a78bfa 100%);--gradient-card: linear-gradient(145deg, #1e293b 0%, #0f172a 100%);--gradient-text: linear-gradient(135deg, #6366f1, #a78bfa);--cat-spfx: #3b82f6;--cat-power: #f59e0b;--cat-sharepoint: #10b981;--cat-m365: #ec4899;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--fs-xs: .75rem;--fs-sm: .875rem;--fs-base: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--fs-2xl: 1.5rem;--fs-3xl: 1.875rem;--fs-4xl: 2.25rem;--fs-5xl: 3rem;--fw-normal: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800;--lh-tight: 1.25;--lh-normal: 1.5;--lh-relaxed: 1.75;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px var(--accent-glow);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--max-width: 1200px;--max-width-content: 800px;--header-height: 64px}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--fs-base);line-height:var(--lh-normal);color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}img{max-width:100%;height:auto;display:block}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.header{position:sticky;top:0;z-index:100;height:var(--header-height);background:#0f172acc;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);border-bottom:1px solid rgba(99,102,241,.08);transition:background var(--transition-base),box-shadow var(--transition-base)}.header__inner{display:flex;align-items:center;justify-content:space-between;height:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.header__logo{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary);text-decoration:none;display:flex;align-items:center;gap:var(--space-2)}.header__logo-accent{background:var(--gradient-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header__nav{display:flex;align-items:center;gap:var(--space-8)}.header__link{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast);position:relative}.header__link:hover,.header__link--active{color:var(--text-primary)}.header__link--active:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--gradient-text);border-radius:var(--radius-full);animation:slideIn .3s ease}@keyframes slideIn{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.header__link:after{content:"";position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--gradient-text);border-radius:var(--radius-full);transform:scaleX(0);transition:transform .3s ease}.header__link:hover:after{transform:scaleX(1)}.header__burger{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:var(--space-2)}.header__burger-icon{display:block;width:24px;height:2px;background:currentColor;position:relative;transition:background var(--transition-fast)}.header__burger-icon:before,.header__burger-icon:after{content:"";position:absolute;left:0;width:100%;height:2px;background:currentColor;transition:transform var(--transition-base)}.header__burger-icon:before{top:-7px}.header__burger-icon:after{bottom:-7px}@media (max-width: 768px){.header__nav{position:fixed;top:var(--header-height);left:0;right:0;background:var(--bg-primary);flex-direction:column;padding:var(--space-8) var(--space-6);gap:var(--space-6);border-bottom:1px solid var(--border);transform:translateY(-100%);opacity:0;pointer-events:none;transition:transform var(--transition-base),opacity var(--transition-base)}.header__nav--open{transform:translateY(0);opacity:1;pointer-events:auto}.header__burger{display:block}}.hero{padding:var(--space-20) 0 var(--space-16);text-align:center;position:relative;overflow:hidden;min-height:70vh;display:flex;align-items:center}.hero:before{content:"";position:absolute;top:-30%;left:-20%;width:60%;height:60%;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);pointer-events:none;animation:blobFloat 8s ease-in-out infinite;filter:blur(40px)}.hero:after{content:"";position:absolute;bottom:-20%;right:-15%;width:50%;height:55%;background:radial-gradient(circle,rgba(6,182,212,.12) 0%,transparent 70%);pointer-events:none;animation:blobFloat 10s ease-in-out infinite reverse;filter:blur(40px)}@keyframes blobFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}}.hero__badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-tag);color:var(--accent);border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:var(--fw-medium);margin-bottom:var(--space-8);border:1px solid rgba(99,102,241,.2)}.hero__badge-dot{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.hero__title{font-size:clamp(2.5rem,5vw,4rem);font-weight:var(--fw-extrabold);line-height:1.1;margin-bottom:var(--space-6);position:relative;letter-spacing:-.02em;animation:fadeInUp .8s ease both}.hero__title-gradient{background:linear-gradient(135deg,#6366f1,#8b5cf6 40%,#06b6d4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% auto;animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{background-position:0% center}50%{background-position:100% center}}.hero__subtitle{font-size:var(--fs-lg);color:var(--text-secondary);max-width:580px;margin:0 auto var(--space-10);line-height:var(--lh-relaxed);animation:fadeInUp .8s ease .2s both}.hero__actions{display:flex;gap:var(--space-4);justify-content:center;flex-wrap:wrap;animation:fadeInUp .8s ease .4s both}.hero__cta{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border-radius:var(--radius-full);font-weight:var(--fw-semibold);font-size:var(--fs-base);text-decoration:none;transition:all var(--transition-base);border:none;cursor:pointer;box-shadow:0 4px 15px #6366f14d}.hero__cta:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6366f166;color:#fff}.hero__cta--secondary{background:transparent;border:1px solid var(--border);color:var(--text-primary);box-shadow:none}.hero__cta--secondary:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 4px 15px var(--accent-glow)}@media (max-width: 768px){.hero{padding:var(--space-12) 0}.hero__title{font-size:var(--fs-3xl)}.hero__subtitle{font-size:var(--fs-base)}}.section{padding:var(--space-16) 0}.section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-10)}.section__title{font-size:var(--fs-2xl);font-weight:var(--fw-bold)}.section__link{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--accent);display:flex;align-items:center;gap:var(--space-1)}.section__link:hover{color:var(--accent-hover)}.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-8)}@media (max-width: 768px){.blog-grid{grid-template-columns:1fr;gap:var(--space-6)}}.blog-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-base);text-decoration:none;color:inherit;display:flex;flex-direction:column}.blog-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:0 20px 40px #0003,0 0 0 1px var(--accent);border-color:var(--accent);color:inherit}.blog-card__image{width:100%;height:140px;object-fit:cover;background:var(--gradient-card)}.blog-card__image--placeholder{display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff;background:linear-gradient(135deg,#6366f133,#8b5cf626,#06b6d41a);height:140px;position:relative;overflow:hidden}.blog-card__image--placeholder:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(99,102,241,.08) 100%);transition:opacity var(--transition-base)}.blog-card:hover .blog-card__image--placeholder:before{opacity:.5}.blog-card__body{padding:var(--space-6);flex:1;display:flex;flex-direction:column}.blog-card__meta{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.blog-card__category{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.05em}.blog-card__category--spfx{background:#3b82f626;color:var(--cat-spfx)}.blog-card__category--power-platform{background:#f59e0b26;color:var(--cat-power)}.blog-card__category--sharepoint{background:#10b98126;color:var(--cat-sharepoint)}.blog-card__category--microsoft-365{background:#ec489926;color:var(--cat-m365)}.blog-card__date{font-size:var(--fs-xs);color:var(--text-muted)}.blog-card__title{font-size:var(--fs-lg);font-weight:var(--fw-semibold);line-height:var(--lh-tight);margin-bottom:var(--space-3);color:var(--text-primary)}.blog-card__excerpt{font-size:var(--fs-sm);color:var(--text-secondary);line-height:var(--lh-relaxed);flex:1}.blog-card__footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light)}.blog-card__read-time{font-size:var(--fs-xs);color:var(--text-muted)}.blog-card__arrow{color:var(--accent);font-size:var(--fs-sm);transition:transform var(--transition-fast)}.blog-card:hover .blog-card__arrow{transform:translate(4px)}.filters{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-10)}.filter-btn{padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-body)}.filter-btn:hover{border-color:var(--accent);color:var(--text-primary)}.filter-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.post{max-width:var(--max-width-content);margin:0 auto;padding:var(--space-10) var(--space-6)}.post__back{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--fs-sm);margin-bottom:var(--space-8);transition:color var(--transition-fast)}.post__back:hover{color:var(--accent)}.post__header{margin-bottom:var(--space-10)}.post__meta{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.post__title{font-size:var(--fs-4xl);font-weight:var(--fw-extrabold);line-height:var(--lh-tight);margin-bottom:var(--space-4)}.post__excerpt{font-size:var(--fs-lg);color:var(--text-secondary);line-height:var(--lh-relaxed)}.post__image{width:100%;border-radius:var(--radius-xl);margin-bottom:var(--space-10);border:1px solid var(--border)}.post__content h2{font-size:var(--fs-2xl);font-weight:var(--fw-bold);margin:var(--space-12) 0 var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--border-light)}.post__content h3{font-size:var(--fs-xl);font-weight:var(--fw-semibold);margin:var(--space-8) 0 var(--space-3)}.post__content p{margin-bottom:var(--space-6);line-height:var(--lh-relaxed);color:var(--text-secondary)}.post__content ul,.post__content ol{margin:var(--space-4) 0 var(--space-6);padding-left:var(--space-8);color:var(--text-secondary)}.post__content li{margin-bottom:var(--space-2);line-height:var(--lh-relaxed)}.post__content code{font-family:var(--font-mono);font-size:var(--fs-sm);background:var(--bg-code);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);color:var(--accent-hover)}.post__content pre{background:var(--bg-code);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);overflow-x:auto;margin:var(--space-6) 0}.post__content pre code{background:none;padding:0;font-size:var(--fs-sm);color:var(--text-primary)}.post__content blockquote{border-left:3px solid var(--accent);padding:var(--space-4) var(--space-6);margin:var(--space-6) 0;background:#6366f10d;border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);font-style:italic}.post__content img{border-radius:var(--radius-lg);border:1px solid var(--border);margin:var(--space-6) 0}.post__content table{width:100%;border-collapse:collapse;margin:var(--space-6) 0}.post__content th,.post__content td{padding:var(--space-3) var(--space-4);border:1px solid var(--border);text-align:left}.post__content th{background:var(--bg-secondary);font-weight:var(--fw-semibold)}.post__content td{color:var(--text-secondary)}.post__content strong{color:var(--text-primary);font-weight:var(--fw-semibold)}.post__content a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}.post__content a:hover{color:var(--accent-hover)}@media (max-width: 768px){.post__title{font-size:var(--fs-2xl)}.post__excerpt{font-size:var(--fs-base)}}.about{max-width:var(--max-width-content);margin:0 auto;padding:var(--space-16) var(--space-6)}.about__header{text-align:center;margin-bottom:var(--space-12)}.about__avatar{width:120px;height:120px;border-radius:50%;background:var(--gradient-hero);display:flex;align-items:center;justify-content:center;font-size:var(--fs-4xl);font-weight:var(--fw-bold);color:#fff;margin:0 auto var(--space-6);border:3px solid var(--accent)}.about__name{font-size:var(--fs-3xl);font-weight:var(--fw-bold);margin-bottom:var(--space-2)}.about__role{font-size:var(--fs-lg);color:var(--text-secondary)}.about__content p{color:var(--text-secondary);line-height:var(--lh-relaxed);margin-bottom:var(--space-6)}.about__skills{display:flex;flex-wrap:wrap;gap:var(--space-3);margin:var(--space-8) 0}.about__skill{padding:var(--space-2) var(--space-4);background:var(--bg-tag);color:var(--accent);border-radius:var(--radius-full);font-size:var(--fs-sm);font-weight:var(--fw-medium);border:1px solid rgba(99,102,241,.2)}.about__links{display:flex;gap:var(--space-6);margin-top:var(--space-8);justify-content:center}.about__social-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);transition:all var(--transition-fast)}.about__social-link:hover{border-color:var(--accent);color:var(--text-primary);transform:translateY(-2px)}.footer{padding:var(--space-12) 0 var(--space-8);border-top:2px solid transparent;border-image:linear-gradient(90deg,transparent,var(--accent),var(--accent-secondary),transparent) 1;text-align:center;background:var(--bg-secondary)}.footer__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6)}.footer__grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-8);text-align:left;margin-bottom:var(--space-8)}.footer__brand{font-size:var(--fs-lg);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.footer__tagline{font-size:var(--fs-sm);color:var(--text-muted);line-height:var(--lh-relaxed)}.footer__col-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.05em}.footer__col-links{display:flex;flex-direction:column;gap:var(--space-2)}.footer__copyright{font-size:var(--fs-sm);color:var(--text-muted);text-align:center;padding-top:var(--space-6);border-top:1px solid var(--border-light)}@media (max-width: 768px){.footer__grid{grid-template-columns:1fr 1fr;gap:var(--space-6)}}@media (max-width: 480px){.footer__grid{grid-template-columns:1fr}}.footer__links{display:flex;justify-content:center;gap:var(--space-6);margin-top:var(--space-4)}.footer__link{font-size:var(--fs-sm);color:var(--text-muted);transition:color var(--transition-fast)}.footer__link:hover{color:var(--accent);transform:translateY(-1px)}.ad-slot{display:flex;align-items:center;justify-content:center;margin:var(--space-8) auto;padding:var(--space-4);max-width:728px;min-height:90px;background:var(--bg-secondary);border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:var(--fs-xs)}.ad-slot--rectangle{max-width:300px;min-height:250px}.loading{display:flex;align-items:center;justify-content:center;padding:var(--space-20) 0}.loading__spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-16) var(--space-6)}.empty-state__icon{font-size:3rem;margin-bottom:var(--space-4)}.empty-state__title{font-size:var(--fs-xl);font-weight:var(--fw-semibold);margin-bottom:var(--space-2)}.empty-state__text{color:var(--text-secondary);font-size:var(--fs-sm)}.page-title{padding:var(--space-12) 0 var(--space-6);text-align:center}.page-title h1{font-size:var(--fs-3xl);font-weight:var(--fw-bold)}.page-title p{color:var(--text-secondary);margin-top:var(--space-3)}[data-theme=light]{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f1f5f9;--bg-code: #f1f5f9;--bg-tag: rgba(99, 102, 241, .08);--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #4f46e5;--accent-hover: #6366f1;--accent-glow: rgba(79, 70, 229, .15);--border: #e2e8f0;--border-light: rgba(148, 163, 184, .15);--gradient-hero: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #8b5cf6 100%);--gradient-card: linear-gradient(145deg, #ffffff 0%, #f8fafc 100%);--gradient-text: linear-gradient(135deg, #4f46e5, #7c3aed);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px var(--accent-glow)}[data-theme=light] .header{background:#f8fafccc;backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8)}[data-theme=light] .blog-card{box-shadow:var(--shadow-sm)}[data-theme=light] .blog-card:hover{box-shadow:var(--shadow-lg)}.theme-toggle{background:none;border:1px solid var(--border);border-radius:var(--radius-full);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:var(--fs-base);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.theme-toggle:hover{border-color:var(--accent);transform:rotate(15deg)}.search-bar{display:flex;align-items:center;gap:var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);padding:var(--space-3) var(--space-6);margin-bottom:var(--space-6);transition:border-color var(--transition-fast)}.search-bar:focus-within{border-color:var(--accent)}.search-bar__icon{font-size:var(--fs-base);flex-shrink:0}.search-bar__input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:var(--fs-sm);font-family:var(--font-body)}.search-bar__input::placeholder{color:var(--text-muted)}.search-bar__clear{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:var(--fs-sm);padding:var(--space-1);transition:color var(--transition-fast)}.search-bar__clear:hover{color:var(--text-primary)}.tag-pill{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--bg-tag);color:var(--accent);border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-medium);text-decoration:none;transition:all var(--transition-fast);border:1px solid transparent}.tag-pill:hover{border-color:var(--accent);color:var(--accent-hover)}.tag-pill--sm{font-size:.65rem;padding:2px var(--space-2)}.blog-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-3)}.post__tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-4)}.post-layout{display:flex;gap:var(--space-10);position:relative}.post-layout .post__content{flex:1;min-width:0}.toc{position:sticky;top:calc(var(--header-height) + var(--space-8));align-self:flex-start;width:220px;flex-shrink:0;max-height:calc(100vh - var(--header-height) - var(--space-16));overflow-y:auto}.toc__title{font-size:var(--fs-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-4)}.toc__list{list-style:none;padding:0;margin:0;border-left:2px solid var(--border)}.toc__item{padding-left:var(--space-4)}.toc__item--sub{padding-left:var(--space-8)}.toc__link{display:block;padding:var(--space-1) 0;font-size:var(--fs-xs);color:var(--text-muted);text-decoration:none;transition:color var(--transition-fast);line-height:var(--lh-normal)}.toc__link:hover{color:var(--text-primary)}.toc__item--active .toc__link{color:var(--accent);font-weight:var(--fw-medium)}.toc__item--active{border-left:2px solid var(--accent);margin-left:-2px}@media (max-width: 1024px){.toc{display:none}.post-layout{display:block}}.copy-btn{position:absolute;top:var(--space-2);right:var(--space-2);padding:var(--space-1) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:var(--fs-xs);font-family:var(--font-body);cursor:pointer;opacity:0;transition:all var(--transition-fast);z-index:2}pre:hover .copy-btn{opacity:1}.copy-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.copy-btn--copied{background:#10b981;color:#fff;border-color:#10b981;opacity:1}.related-posts{margin-top:var(--space-12);padding-top:var(--space-8);border-top:1px solid var(--border-light)}.related-posts__title{font-size:var(--fs-xl);font-weight:var(--fw-semibold);margin-bottom:var(--space-6)}.related-posts__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-4)}.related-posts__card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:all var(--transition-fast)}.related-posts__card:hover{border-color:var(--accent);transform:translateY(-2px);color:inherit}.related-posts__category{font-size:var(--fs-xs);color:var(--accent);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.05em}.related-posts__name{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary);line-height:var(--lh-tight)}.related-posts__meta{font-size:var(--fs-xs);color:var(--text-muted)}.share-buttons{margin-top:var(--space-10);padding-top:var(--space-6);border-top:1px solid var(--border-light)}.share-buttons__label{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-muted);display:block;margin-bottom:var(--space-4)}.share-buttons__row{display:flex;gap:var(--space-3);flex-wrap:wrap}.share-buttons__btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--fs-sm);font-weight:var(--fw-medium);text-decoration:none;transition:all var(--transition-fast)}.share-buttons__btn:hover{border-color:var(--accent);color:var(--text-primary);transform:translateY(-2px)}.share-buttons__icon{font-size:var(--fs-base)}.newsletter{margin:var(--space-8) 0}.newsletter__inner{background:linear-gradient(135deg,#6366f114,#8b5cf60f,#06b6d40a);border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-xl);padding:var(--space-12) var(--space-8);text-align:center;position:relative;overflow:hidden}.newsletter__inner:before{content:"";position:absolute;top:-50%;right:-30%;width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);pointer-events:none;animation:blobFloat 10s ease-in-out infinite}.newsletter__title{font-size:var(--fs-2xl);font-weight:var(--fw-bold);margin-bottom:var(--space-3)}.newsletter__desc{color:var(--text-secondary);font-size:var(--fs-sm);margin-bottom:var(--space-6);max-width:500px;margin-left:auto;margin-right:auto}.newsletter__form{display:flex;gap:var(--space-3);max-width:460px;margin:0 auto}.newsletter__input{flex:1;padding:var(--space-3) var(--space-5);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--fs-sm);font-family:var(--font-body);outline:none;transition:border-color var(--transition-fast)}.newsletter__input:focus{border-color:var(--accent)}.newsletter__btn{padding:var(--space-3) var(--space-6);background:var(--accent);color:#fff;border:none;border-radius:var(--radius-full);font-weight:var(--fw-semibold);font-size:var(--fs-sm);font-family:var(--font-body);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.newsletter__btn:hover{background:var(--accent-hover)}.newsletter__btn:disabled{opacity:.6;cursor:not-allowed}.newsletter__success{padding:var(--space-4);color:#10b981;font-weight:var(--fw-medium)}.newsletter__msg{font-size:var(--fs-sm);margin-top:var(--space-3)}.newsletter__msg--info{color:var(--accent)}.newsletter__msg--error{color:#ef4444}@media (max-width: 480px){.newsletter__form{flex-direction:column}}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-6);padding-bottom:var(--space-16)}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);text-decoration:none;color:inherit;transition:all var(--transition-base);display:flex;flex-direction:column;gap:var(--space-3)}.project-card:hover{border-color:var(--accent);transform:translateY(-6px) scale(1.01);box-shadow:0 20px 40px #00000026,0 0 0 1px var(--accent);color:inherit}.project-card__emoji{font-size:2rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#6366f126,#06b6d41a);border-radius:var(--radius-lg);border:1px solid rgba(99,102,241,.1)}.project-card__name{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary)}.project-card__desc{font-size:var(--fs-sm);color:var(--text-secondary);line-height:var(--lh-relaxed);flex:1}.project-card__stack{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.project-card__tech{padding:var(--space-1) var(--space-3);background:var(--bg-tag);color:var(--accent);border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-medium)}.project-card__link{font-size:var(--fs-sm);color:var(--accent);font-weight:var(--fw-medium);margin-top:var(--space-2);transition:color var(--transition-fast)}.project-card:hover .project-card__link{color:var(--accent-hover)}@media (max-width: 768px){.projects-grid{grid-template-columns:1fr}}.contact{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-6) var(--space-16)}.contact__grid{display:grid;grid-template-columns:300px 1fr;gap:var(--space-10);align-items:flex-start}.contact__info{display:flex;flex-direction:column;gap:var(--space-4)}.contact__info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.contact__info-icon{font-size:var(--fs-2xl)}.contact__info-card h3{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary)}.contact__info-card a{font-size:var(--fs-sm);color:var(--accent);word-break:break-all}.contact__form{display:flex;flex-direction:column;gap:var(--space-5)}.contact__field{display:flex;flex-direction:column;gap:var(--space-2)}.contact__field label{font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-secondary)}.contact__field input,.contact__field textarea{padding:var(--space-3) var(--space-5);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);font-family:var(--font-body);outline:none;transition:border-color var(--transition-fast);resize:vertical}.contact__field input:focus,.contact__field textarea:focus{border-color:var(--accent)}.contact__msg{font-size:var(--fs-sm);margin-top:var(--space-2)}.contact__msg--success{color:#10b981}.contact__msg--error{color:#ef4444}@media (max-width: 768px){.contact__grid{grid-template-columns:1fr}}.about__social-link--primary{background:var(--accent);color:#fff;border-color:var(--accent)}.about__social-link--primary:hover{background:var(--accent-hover);color:#fff;border-color:var(--accent-hover)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.reveal.revealed{opacity:1;transform:translateY(0)}.reveal-stagger>.reveal:nth-child(1){transition-delay:0s}.reveal-stagger>.reveal:nth-child(2){transition-delay:.1s}.reveal-stagger>.reveal:nth-child(3){transition-delay:.2s}.reveal-stagger>.reveal:nth-child(4){transition-delay:.3s}.reveal-stagger>.reveal:nth-child(5){transition-delay:.4s}.reveal-stagger>.reveal:nth-child(6){transition-delay:.5s}.contact__field input:focus,.contact__field textarea:focus,.newsletter__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.about__content{text-align:left}.about__skill{transition:all var(--transition-fast)}.about__skill:hover{background:#6366f140;border-color:var(--accent);transform:translateY(-2px)}.about__social-link{transition:all var(--transition-base)}@media (max-width: 640px){.about__links{flex-direction:column;align-items:center}}.tasks-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-5);border-radius:var(--radius-md);font-size:var(--fs-sm);font-weight:var(--fw-medium);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;white-space:nowrap}.tasks-btn--primary{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border:none;box-shadow:0 2px 10px #6366f14d}.tasks-btn--primary:hover{transform:translateY(-1px);box-shadow:0 4px 15px #6366f166}.tasks-btn--primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.tasks-btn--ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.tasks-btn--ghost:hover{border-color:var(--accent);color:var(--text-primary)}.tasks-btn--sm{padding:var(--space-1) var(--space-2);font-size:var(--fs-xs);background:transparent;border:none;cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.tasks-btn--sm:hover{background:#ffffff14}.tasks-btn--danger:hover{background:#ef444426}.tasks-priority{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:.05em}.tasks-priority--low{background:#94a3b826;color:#94a3b8}.tasks-priority--medium{background:#3b82f626;color:#60a5fa}.tasks-priority--high{background:#f59e0b26;color:#fbbf24}.tasks-priority--critical{background:#ef444426;color:#f87171}.tasks-result{display:inline-block;padding:2px 10px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-semibold)}.tasks-result--pass{background:#10b98126;color:#34d399}.tasks-result--fail{background:#ef444426;color:#f87171}.tasks-result--partial{background:#f59e0b26;color:#fbbf24}.tasks-result--none{color:var(--text-muted)}.tasks-app-badge{display:inline-block;padding:2px 8px;background:var(--bg-tag);color:var(--accent);border-radius:var(--radius-sm);font-size:var(--fs-xs);font-weight:var(--fw-medium)}.tasks-loading,.tasks-empty{text-align:center;padding:var(--space-16) 0;color:var(--text-muted);font-size:var(--fs-lg)}.tasks-page{padding:var(--space-10) 0;min-height:calc(100vh - var(--header-height))}.tasks-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-8);flex-wrap:wrap;gap:var(--space-4)}.tasks-title{font-size:var(--fs-3xl);font-weight:var(--fw-bold);color:var(--text-primary)}.tasks-subtitle{color:var(--text-secondary);font-size:var(--fs-sm);margin-top:var(--space-1)}.tasks-stats{display:flex;gap:var(--space-4);margin-bottom:var(--space-8);flex-wrap:wrap}.tasks-stat{flex:1;min-width:120px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);text-align:center;transition:border-color var(--transition-fast)}.tasks-stat:hover{border-color:var(--accent)}.tasks-stat__count{display:block;font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--text-primary)}.tasks-stat__label{font-size:var(--fs-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.tasks-stat--todo{border-left:3px solid #94a3b8}.tasks-stat--in_progress{border-left:3px solid #60a5fa}.tasks-stat--testing{border-left:3px solid #a78bfa}.tasks-stat--done{border-left:3px solid #34d399}.tasks-stat--blocked{border-left:3px solid #f87171}.tasks-form-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-6);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.tasks-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:560px;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.tasks-form__title{font-size:var(--fs-xl);font-weight:var(--fw-bold);margin-bottom:var(--space-6);color:var(--text-primary)}.tasks-form__field{margin-bottom:var(--space-5)}.tasks-form__field label{display:block;font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--text-secondary);margin-bottom:var(--space-2)}.tasks-form__field input,.tasks-form__field textarea,.tasks-form__field select{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);font-family:var(--font-body);transition:border-color var(--transition-fast)}.tasks-form__field input:focus,.tasks-form__field textarea:focus,.tasks-form__field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.tasks-form__field textarea{resize:vertical;min-height:80px}.tasks-form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.tasks-form__actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-6)}.tasks-table-wrapper{overflow-x:auto;border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-card)}.tasks-table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}.tasks-table th{text-align:left;padding:var(--space-4) var(--space-5);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:var(--fs-xs);border-bottom:1px solid var(--border);white-space:nowrap}.tasks-table td{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-light);vertical-align:middle}.tasks-row:last-child td{border-bottom:none}.tasks-row:hover{background:#6366f10a}.tasks-row--done{opacity:.6}.tasks-row__title{font-weight:var(--fw-medium);color:var(--text-primary)}.tasks-row__desc{font-size:var(--fs-xs);color:var(--text-muted);margin-top:2px}.tasks-status-select{padding:4px 8px;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:var(--fs-xs);font-family:var(--font-body);cursor:pointer}.tasks-status-select--done{border-color:#10b9814d;color:#34d399}.tasks-status-select--blocked{border-color:#ef44444d;color:#f87171}.tasks-actions{display:flex;gap:var(--space-1)}.board-page{min-height:calc(100vh - var(--header-height));padding-bottom:var(--space-10)}.board-header{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-10);padding-bottom:var(--space-8);flex-wrap:wrap;gap:var(--space-4)}.board-title{font-size:var(--fs-3xl);font-weight:var(--fw-bold);color:var(--text-primary)}.board-subtitle{color:var(--text-secondary);font-size:var(--fs-sm);margin-top:var(--space-1)}.board-controls{display:flex;gap:var(--space-3);align-items:center}.board-filter{padding:var(--space-2) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);font-family:var(--font-body)}.board-kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-4);align-items:start}@media (max-width: 1200px){.board-kanban{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.board-kanban{grid-template-columns:1fr}}.board-column{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);min-height:200px}.board-column__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-light)}.board-column__title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary)}.board-column__count{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);background:#6366f126;color:var(--accent);font-size:var(--fs-xs);font-weight:var(--fw-bold)}.board-column--todo .board-column__header{border-top:3px solid #94a3b8;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.board-column--in_progress .board-column__header{border-top:3px solid #60a5fa;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.board-column--testing .board-column__header{border-top:3px solid #a78bfa;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.board-column--done .board-column__header{border-top:3px solid #34d399;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.board-column--blocked .board-column__header{border-top:3px solid #f87171;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.board-column__cards{padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.board-column__empty{text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-muted);font-size:var(--fs-xs)}.board-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:all var(--transition-fast)}.board-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #6366f126;transform:translateY(-2px)}.board-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.board-card__title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-primary);margin-bottom:var(--space-2);line-height:var(--lh-tight)}.board-card__desc{font-size:var(--fs-xs);color:var(--text-muted);line-height:var(--lh-normal);margin-top:var(--space-2)}.board-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-6);animation:fadeIn .2s ease}.board-panel{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s ease}.board-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6) var(--space-8);border-bottom:1px solid var(--border-light)}.board-panel__header h2{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary)}.board-panel__close{background:none;border:none;color:var(--text-muted);font-size:var(--fs-xl);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.board-panel__close:hover{background:#ffffff14;color:var(--text-primary)}.board-panel__body{padding:var(--space-6) var(--space-8);overflow-y:auto;flex:1}.board-panel__meta{display:flex;gap:var(--space-3);margin-bottom:var(--space-6)}.board-panel__section{margin-bottom:var(--space-6)}.board-panel__section h3{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text-secondary);margin-bottom:var(--space-3)}.board-panel__text{font-size:var(--fs-sm);color:var(--text-secondary);line-height:var(--lh-relaxed);background:var(--bg-primary);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--border-light)}.board-panel__status-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}@media (max-width: 480px){.board-panel__status-grid{grid-template-columns:repeat(2,1fr)}}.board-panel__status-btn{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:var(--fs-xs);font-weight:var(--fw-medium);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.board-panel__status-btn:hover{border-color:var(--accent);color:var(--text-primary)}.board-panel__status-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.board-panel__status-btn--active.board-panel__status-btn--done{background:#10b981;border-color:#10b981}.board-panel__status-btn--active.board-panel__status-btn--blocked{background:#ef4444;border-color:#ef4444}.board-panel__result-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2)}@media (max-width: 480px){.board-panel__result-grid{grid-template-columns:repeat(2,1fr)}}.board-panel__result-btn{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:var(--fs-xs);font-weight:var(--fw-medium);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast)}.board-panel__result-btn:hover{border-color:var(--accent)}.board-panel__result-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.board-panel__result-btn--active.board-panel__result-btn--pass{background:#10b981;border-color:#10b981}.board-panel__result-btn--active.board-panel__result-btn--fail{background:#ef4444;border-color:#ef4444}.board-panel__result-btn--active.board-panel__result-btn--partial{background:#f59e0b;border-color:#f59e0b}.board-panel__textarea{width:100%;padding:var(--space-4);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-sm);font-family:var(--font-body);line-height:var(--lh-relaxed);resize:vertical;transition:border-color var(--transition-fast)}.board-panel__textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.board-panel__textarea::placeholder{color:var(--text-muted)}.board-panel__footer{display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-5) var(--space-8);border-top:1px solid var(--border-light)}@media (max-width: 768px){.tasks-header{flex-direction:column;align-items:flex-start}.tasks-form__row{grid-template-columns:1fr}.tasks-table th:nth-child(5),.tasks-table td:nth-child(5){display:none}.board-header{flex-direction:column;align-items:flex-start}.board-panel{max-height:95vh;margin:var(--space-2)}.board-panel__header,.board-panel__body,.board-panel__footer{padding-left:var(--space-5);padding-right:var(--space-5)}}.pin-gate{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-height));padding:var(--space-6)}.pin-gate__box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-10) var(--space-8);text-align:center;max-width:380px;width:100%;animation:slideUp .3s ease}.pin-gate__icon{font-size:2.5rem;margin-bottom:var(--space-4)}.pin-gate__title{font-size:var(--fs-xl);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.pin-gate__desc{font-size:var(--fs-sm);color:var(--text-muted);margin-bottom:var(--space-6)}.pin-gate__input{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--fs-base);font-family:var(--font-body);text-align:center;letter-spacing:.1em;margin-bottom:var(--space-4);transition:border-color var(--transition-fast)}.pin-gate__input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.pin-gate__input--error{border-color:#ef4444;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.pin-gate__btn{width:100%;justify-content:center;padding:var(--space-3)}.pin-gate__error{margin-top:var(--space-3);color:#f87171;font-size:var(--fs-sm)}
