@property --nebula-angle{syntax: "<angle>"; inherits: false; initial-value: 0deg;}:root{--color-primary: #002e59;--color-accent: #dbc27d;--color-dark: #1a1a1a;--color-medium: #4a4a4a;--color-light: #e5e5e5;--color-white: #ffffff;--color-black: #000000;--color-primary-dark: #001a33;--color-primary-light: #004080;--color-accent-light: #f0e5c4;--color-accent-dark: #c5a85a;--bg-primary: #0a0a0a;--bg-secondary: #1a1a1a;--bg-card: #202020;--bg-hover: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b0b0b0;--text-muted: #808080;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 2rem;--spacing-lg: 4rem;--spacing-xl: 6rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 16px rgba(0, 0, 0, .2);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .3);--shadow-accent: 0 4px 20px rgba(219, 194, 125, .3);--shadow-gold: 0 10px 34px rgba(219, 194, 125, .22);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--font-primary: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .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;--font-size-6xl: 4rem;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}body{font-family:var(--font-primary);background-color:var(--bg-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;min-height:100vh;min-height:100dvh}body:not(.light-mode){color:var(--text-primary)}body:not(.light-mode) .code-block-enhanced{color:initial}h1:not(.markdown-text),h2:not(.markdown-text),h3:not(.markdown-text),h4:not(.markdown-text),h5:not(.markdown-text),h6:not(.markdown-text){font-weight:700;line-height:1.2;margin-bottom:var(--spacing-sm);color:var(--text-primary)}h1{font-size:var(--font-size-5xl)}h2{font-size:var(--font-size-4xl)}h3{font-size:var(--font-size-3xl)}h4{font-size:var(--font-size-2xl)}h5{font-size:var(--font-size-xl)}h6{font-size:var(--font-size-lg)}p:not(.markdown-text){margin-bottom:var(--spacing-sm);color:var(--text-secondary)}a{color:var(--color-accent);text-decoration:none;transition:all var(--transition-fast)}a:hover{color:var(--color-accent-light)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-md)}.container-fluid{width:100%;padding:0 var(--spacing-md)}.section{padding:var(--spacing-xl) 0}.section-title{text-align:center;margin-bottom:var(--spacing-lg);position:relative}.section-title h2{display:inline-block;position:relative;padding-bottom:var(--spacing-sm)}.section-title h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:var(--radius-full)}.section-subtitle{color:var(--text-muted);font-size:var(--font-size-lg);margin-top:var(--spacing-sm)}.btn{display:inline-block;padding:.75rem 2rem;border-radius:var(--radius-md);font-weight:600;font-size:var(--font-size-base);text-align:center;cursor:pointer;border:2px solid transparent;transition:all var(--transition-normal);text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:var(--color-white);border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-accent{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:var(--color-dark);border-color:var(--color-accent)}.btn-outline{background:transparent;color:var(--color-accent);border-color:var(--color-accent)}.btn-outline:hover{background:var(--color-accent);color:var(--color-dark)}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);transition:all var(--transition-normal);border:1px solid rgba(255,255,255,.05)}.card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--color-accent)}.grid{display:grid;gap:var(--spacing-md)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.flex{display:flex}.flex-center{display:flex;justify-content:center;align-items:center}.flex-between{display:flex;justify-content:space-between;align-items:center}.flex-wrap{flex-wrap:wrap}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.text-center{text-align:center}.text-primary{color:var(--color-primary)}.text-accent{color:var(--color-accent)}.text-muted{color:var(--text-muted)}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.pt-1{padding-top:var(--spacing-sm)}.pt-2{padding-top:var(--spacing-md)}.pt-3{padding-top:var(--spacing-lg)}.pb-1{padding-bottom:var(--spacing-sm)}.pb-2{padding-bottom:var(--spacing-md)}.pb-3{padding-bottom:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.fade-in{animation:fadeIn .8s ease}.fade-in-up{animation:fadeInUp .8s ease}.fade-in-down{animation:fadeInDown .8s ease}.slide-in-left{animation:slideInLeft .8s ease}.slide-in-right{animation:slideInRight .8s ease}.scroll-to-top{--scroll-gap: 1.25rem;--scroll-size: 50px;position:fixed!important;bottom:var(--scroll-gap)!important;right:var(--scroll-gap)!important;width:var(--scroll-size);height:var(--scroll-size);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:var(--color-white);border:none;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:var(--shadow-lg);z-index:9999!important;opacity:0;visibility:hidden;transform:translateY(20px) scale(.8);transition:opacity .3s ease,visibility .3s ease,transform .3s cubic-bezier(.4,0,.2,1);pointer-events:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-width:var(--scroll-size);min-height:var(--scroll-size);flex-shrink:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;will-change:transform,opacity}.scroll-to-top.visible{opacity:1;visibility:visible;transform:translateY(0) scale(1);pointer-events:auto}.scroll-to-top:hover{transform:translateY(-5px);box-shadow:var(--shadow-accent)}.scroll-to-top:active{transform:scale(.95)}.spinner{display:inline-block;width:40px;height:40px;border:4px solid rgba(255,255,255,.1);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px}@media (max-width: 1024px){:root{--font-size-5xl: 2.5rem;--font-size-4xl: 2rem;--font-size-3xl: 1.75rem}.container{padding:0 var(--spacing-sm)}.section{padding:var(--spacing-lg) 0}}@media (max-width: 768px){:root{--font-size-5xl: 2rem;--font-size-4xl: 1.75rem;--font-size-3xl: 1.5rem;--spacing-lg: 3rem;--spacing-xl: 4rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.btn{padding:.625rem 1.5rem;font-size:var(--font-size-sm)}}@media (max-width: 1024px) and (min-width: 769px){.scroll-to-top{--scroll-gap: 1.25rem;bottom:var(--scroll-gap)!important;right:var(--scroll-gap)!important;min-width:var(--scroll-size);min-height:var(--scroll-size)}}@media (max-width: 768px){.scroll-to-top{--scroll-gap: 1.25rem;--scroll-size: 44px;width:var(--scroll-size);height:var(--scroll-size);bottom:var(--scroll-gap)!important;right:var(--scroll-gap)!important;font-size:1.25rem;min-width:var(--scroll-size);min-height:var(--scroll-size)}}@media (max-width: 480px){:root{--font-size-5xl: 1.75rem;--font-size-4xl: 1.5rem;--font-size-3xl: 1.25rem}.scroll-to-top{--scroll-gap: 1rem;--scroll-size: 40px;width:var(--scroll-size);height:var(--scroll-size);bottom:var(--scroll-gap)!important;right:var(--scroll-gap)!important;font-size:1.125rem;min-width:var(--scroll-size);min-height:var(--scroll-size)}}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:var(--radius-full)}::selection{background:var(--color-accent);color:var(--color-dark)}::-moz-selection{background:var(--color-accent);color:var(--color-dark)}.markdown-content h1:not(.markdown-text),.markdown-content h2:not(.markdown-text),.markdown-content h3:not(.markdown-text),.markdown-content h4:not(.markdown-text),.markdown-content h5:not(.markdown-text),.markdown-content h6:not(.markdown-text){font-size:calc(var(--md-scale, 1) * 1rem)!important;line-height:1.2!important;font-weight:700!important;color:var(--text-primary)!important}.markdown-content h1{font-size:calc(var(--md-scale, 1) * 2rem)!important}.markdown-content h2{font-size:calc(var(--md-scale, 1) * 1.5rem)!important}.markdown-content h3{font-size:calc(var(--md-scale, 1) * 1.25rem)!important}.markdown-content h4{font-size:calc(var(--md-scale, 1) * 1.05rem)!important}.markdown-content h5{font-size:calc(var(--md-scale, 1) * .95rem)!important}.markdown-content h6{font-size:calc(var(--md-scale, 1) * .9rem)!important}.mermaid-title{font-size:calc(var(--md-scale, 1) * .9rem)!important;font-weight:600!important;color:var(--color-accent)!important;margin-bottom:calc(var(--md-scale, 1) * .5rem)!important;text-align:center!important}.code-block-enhanced{background:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:12px;margin:1.5rem 0;overflow:hidden;box-shadow:0 8px 32px #0006;position:relative}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#2a2a2a;border-bottom:1px solid rgba(255,255,255,.1);position:relative;border-radius:12px 12px 0 0;gap:1rem}.code-block-header:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(219,194,125,.3),transparent)}.code-language{color:#dbc27d;font-weight:700;font-size:.9rem;text-transform:uppercase;letter-spacing:-.02em;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;flex:1}.copy-btn{background:linear-gradient(135deg,#dbc27d,#c9a96e);border:none;color:#000;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.4rem;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;position:relative;overflow:hidden;flex-shrink:0;box-shadow:0 2px 8px #dbc27d4d}.copy-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.copy-btn:hover:before{left:100%}.copy-btn:hover{background:linear-gradient(135deg,#c9a96e,#b8965f);transform:translateY(-2px);box-shadow:0 4px 16px #dbc27d66}.copy-btn:active{transform:translateY(0);box-shadow:0 2px 8px #dbc27d4d}.code-block-enhanced pre{background:#1a1a1a;border:none;border-radius:0 0 12px 12px;padding:1.5rem;margin:0;overflow-x:auto;position:relative}.code-block-enhanced pre::-webkit-scrollbar{height:8px}.code-block-enhanced pre::-webkit-scrollbar-track{background:#1e2127;border-radius:4px}.code-block-enhanced pre::-webkit-scrollbar-thumb{background:#dbc27d;border-radius:4px}.code-block-enhanced pre::-webkit-scrollbar-thumb:hover{background:#c9a96e}.code-block-enhanced code{background:none;padding:0;border-radius:0;font-size:.9em;line-height:1.6;font-family:Fira Code,JetBrains Mono,Courier New,monospace;display:block;white-space:pre}.mermaid-diagram{margin:2rem 0;text-align:center;background:#1a1a1a;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:0;box-shadow:0 4px 12px #0000004d;overflow:hidden}.mermaid-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#2a2a2a;border-bottom:1px solid rgba(255,255,255,.1);gap:1rem}.mermaid-title{color:#dbc27d;font-weight:700;font-size:1.1rem;letter-spacing:-.02em;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;flex:1;text-align:left}.mermaid-controls{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.mermaid-download-btn,.mermaid-fullscreen-btn{background:linear-gradient(135deg,#dbc27d,#c9a96e);color:#000;border:none;padding:.5rem;border-radius:8px;cursor:pointer;font-size:.75rem;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #dbc27d4d;width:36px;height:36px}.mermaid-download-btn:hover,.mermaid-fullscreen-btn:hover{background:linear-gradient(135deg,#c9a96e,#b8965f);transform:translateY(-1px);box-shadow:0 4px 16px #dbc27d66}.mermaid-download-btn:active,.mermaid-fullscreen-btn:active{transform:translateY(0);background:linear-gradient(135deg,#b8965f,#a68b4f)}.mermaid-content{display:flex;justify-content:center;align-items:center;min-height:200px;padding:1.5rem}.mermaid-content svg{max-width:100%;height:auto}.chat-message-assistant h1,.chat-message-assistant h2,.chat-message-assistant h3,.chat-message-assistant h4,.chat-message-assistant h5,.chat-message-assistant h6{margin:.35rem 0 .25rem!important;font-weight:700!important;color:var(--text-primary)!important;line-height:1.35!important}.chat-message-assistant h1{font-size:.9rem!important}.chat-message-assistant h2{font-size:.87rem!important}.chat-message-assistant h3{font-size:.85rem!important}.chat-message-assistant h4{font-size:.83rem!important}.chat-message-assistant h5{font-size:.82rem!important}.chat-message-assistant h6{font-size:.8rem!important}.chat-message-assistant h1:first-child,.chat-message-assistant h2:first-child,.chat-message-assistant h3:first-child,.chat-message-assistant h4:first-child,.chat-message-assistant h5:first-child,.chat-message-assistant h6:first-child{margin-top:0!important}:root{--color-primary:#002E59;--color-primary-light:#0a4f8f;--color-primary-dark:#001a33;--color-accent:#DBC27D;--color-accent-light:#f0e5c4;--color-accent-dark:#c5a85a;--bg-primary:#0a0a0c;--bg-secondary:#121317;--bg-card:#17181d;--bg-card-2:#1d1f25;--bg-hover:#23252c;--text-primary:#ffffff;--text-secondary:#b6b9c2;--text-muted:#7e828d;--border:rgba(255,255,255,.07);--border-strong:rgba(255,255,255,.13);--border-accent:rgba(219,194,125,.35);--font-primary:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--font-pixel:"Press Start 2P",monospace;--maxw:1240px;--r-sm:8px;--r-md:14px;--r-lg:22px;--r-full:9999px;--shadow-md:0 8px 28px rgba(0,0,0,.35);--shadow-lg:0 22px 60px -18px rgba(0,0,0,.7);--shadow-gold:0 10px 34px rgba(219,194,125,.22);--t-fast:.2s ease;--t:.32s cubic-bezier(.22,1,.36,1)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;scroll-padding-top:90px;overflow-x:hidden;font-size:16px}body{font-family:var(--font-primary);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:var(--color-accent);text-decoration:none;transition:color var(--t-fast)}img,video{display:block;max-width:100%}button{font-family:inherit;cursor:pointer}::selection{background:var(--color-accent);color:#1a1a1a}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent)}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;position:relative;z-index:1}.bg-fx{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}.bg-grad{position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 50% -5%,rgba(0,46,89,.45),transparent 60%),radial-gradient(ellipse 50% 40% at 100% 100%,rgba(219,194,125,.07),transparent 55%)}.bg-stars{position:absolute;inset:0;background-image:radial-gradient(1.5px 1.5px at 20% 30%,rgba(219,194,125,.5),transparent),radial-gradient(1.5px 1.5px at 60% 70%,rgba(219,194,125,.35),transparent),radial-gradient(1px 1px at 50% 50%,rgba(255,255,255,.4),transparent),radial-gradient(1px 1px at 80% 20%,rgba(255,255,255,.3),transparent),radial-gradient(1px 1px at 35% 85%,rgba(219,194,125,.4),transparent),radial-gradient(1px 1px at 90% 60%,rgba(255,255,255,.3),transparent);background-size:200% 200%;animation:particle-float 26s ease-in-out infinite;opacity:.7}@keyframes particle-float{0%,to{background-position:0 0}50%{background-position:100% 100%}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;padding:.8rem 1.6rem;border-radius:var(--r-sm);font-weight:600;font-size:.95rem;border:2px solid transparent;transition:transform var(--t-fast),box-shadow var(--t),background var(--t-fast),color var(--t-fast),border-color var(--t-fast);white-space:nowrap}.btn-accent{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:#1a1a1a;border-color:var(--color-accent)}.btn-accent:hover{transform:translateY(-2px);box-shadow:var(--shadow-gold)}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;border-color:var(--color-primary-light)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-outline{background:transparent;color:var(--color-accent);border-color:var(--border-accent)}.btn-outline:hover{background:#dbc27d14;border-color:var(--color-accent);transform:translateY(-2px)}.btn .ic{transition:transform var(--t-fast);display:inline-flex}.btn:hover .ic{transform:translate(4px)}nav.top{position:fixed;top:0;left:0;right:0;z-index:50;height:72px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0a0cb8;border-bottom:1px solid transparent;transition:border-color var(--t),background var(--t)}nav.top.scrolled{border-bottom:1px solid var(--border);background:#0a0a0cdb}.nav-inner{max-width:var(--maxw);margin:0 auto;height:100%;padding:0 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}.brand{display:flex;align-items:center;gap:11px;font-weight:700;font-size:1.05rem;letter-spacing:-.01em;color:#fff}.brand .mark{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;font-family:var(--font-mono);font-weight:600;font-size:15px}.brand .mark span{background:#0000}.nav-links{display:flex;gap:4px;align-items:center}.nav-links a{font-size:.92rem;color:var(--text-secondary);padding:8px 14px;border-radius:8px;transition:color var(--t-fast),background var(--t-fast);position:relative}.nav-links a:hover{color:#fff;background:var(--bg-card)}.nav-links a.active{color:var(--color-accent)}.nav-right{display:flex;align-items:center;gap:14px}.lang-switch{display:flex;border:1px solid var(--border-strong);border-radius:var(--r-full);overflow:hidden}.lang-switch button{background:none;border:none;color:var(--text-muted);font-size:.78rem;font-weight:600;padding:6px 11px;transition:all var(--t-fast)}.lang-switch button.active{background:var(--color-accent);color:#1a1a1a}.nav-toggle{display:none;background:none;border:1px solid var(--border-strong);color:#fff;width:42px;height:40px;border-radius:9px;font-size:18px}section.block{padding:92px 0;position:relative;z-index:1}.section-title{text-align:center;margin-bottom:50px}.section-title .eyebrow{font-family:var(--font-mono);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);display:block;margin-bottom:14px}.section-title h2{display:inline-block;position:relative;font-size:clamp(2rem,4vw,2.8rem);font-weight:700;letter-spacing:-.02em;padding-bottom:18px}.section-title h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:64px;height:4px;border-radius:var(--r-full);background:linear-gradient(90deg,var(--color-primary),var(--color-accent))}.section-title p{color:var(--text-muted);font-size:1.1rem;margin-top:18px;max-width:620px;margin-left:auto;margin-right:auto}.hero{min-height:calc(100vh - 72px);display:flex;align-items:center;padding:120px 0 70px;position:relative;z-index:1}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;width:100%}.code-line{font-family:var(--font-mono);font-size:.95rem;margin-bottom:18px;color:var(--text-muted)}.code-line .cls{color:#4fc3f7}.code-line .mth{color:var(--color-accent)}.code-line .str{color:#a5d6a7}.code-line .pn{color:var(--text-secondary)}.hero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);line-height:1.16;letter-spacing:-.02em;margin-bottom:14px;font-weight:700;background:linear-gradient(135deg,#fff,var(--text-secondary));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero h1 .accent{-webkit-text-fill-color:var(--color-accent);color:var(--color-accent)}.hero-role{min-height:2rem;display:flex;align-items:center;margin-bottom:20px}.typing{font-family:var(--font-pixel);font-size:clamp(.7rem,1.5vw,.95rem);letter-spacing:1px;line-height:1.5;background:linear-gradient(90deg,#00f0ff,#ff5edb,#00f0ff);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:cyber 3.5s ease infinite;filter:drop-shadow(0 0 8px rgba(0,240,255,.45)) drop-shadow(0 0 16px rgba(255,94,219,.3))}@keyframes cyber{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.typing-cursor{color:var(--color-accent);margin-left:3px;animation:blink 1s steps(1) infinite;font-family:var(--font-primary)}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-tagline{font-size:1.12rem;line-height:1.75;color:var(--text-muted);max-width:560px;margin-bottom:30px}.hero-cta{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:42px}.github-stats-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.4rem;border-radius:var(--r-sm);font-weight:600;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent);border:1px solid var(--border-accent);background:linear-gradient(135deg,#1e083ce6,#0f0523f2);transition:transform var(--t-fast),border-color var(--t-fast),color var(--t-fast),box-shadow var(--t)}.github-stats-btn:hover{transform:translateY(-2px);color:#f0d98a;border-color:var(--color-accent);box-shadow:0 12px 30px #7c3aed40}.github-stats-btn .star{font-size:.6rem;color:#dbc27db3;transition:transform var(--t-fast)}.github-stats-btn:hover .star{transform:rotate(180deg);color:var(--color-accent)}.hero-stats{display:flex;gap:48px;flex-wrap:wrap}.hero-stats .num{font-size:2.6rem;font-weight:700;color:var(--color-accent);line-height:1}.hero-stats .lbl{font-size:.85rem;color:var(--text-muted);margin-top:8px;max-width:120px}.hero-photo{display:flex;justify-content:center}.photo-ring{position:relative;width:min(400px,80vw);aspect-ratio:1}.photo-glow{position:absolute;inset:-10%;border-radius:50%;background:radial-gradient(circle,rgba(219,194,125,.32),transparent 70%);filter:blur(38px);animation:pulse 4s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.85}50%{transform:scale(1.06);opacity:1}}.photo-ring img.profile{width:100%;height:100%;object-fit:cover;object-position:50% 14%;border-radius:50%;border:4px solid var(--color-accent);box-shadow:0 0 50px #dbc27d4d;position:relative;z-index:2}.photo-deco{position:absolute;top:-22px;right:-22px;width:38%;aspect-ratio:1;border:3px solid var(--color-primary);border-radius:50%;z-index:0;box-shadow:0 0 22px #dbc27d66;animation:pulse 3.5s ease-in-out infinite}.octocat{position:absolute;top:-18px;right:-18px;width:35%;aspect-ratio:1;border-radius:50%;overflow:hidden;z-index:3;background:#6c7173;border:2px solid rgba(255,255,255,.1);box-shadow:var(--shadow-md)}.octocat video{width:100%;height:100%;object-fit:cover}.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--text-muted);font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;animation:bob 2s infinite;cursor:pointer}.scroll-hint .arr{color:var(--color-accent);font-size:1.2rem}@keyframes bob{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.about-grid{display:grid;grid-template-columns:1.45fr 1fr;gap:48px;align-items:start}.bio p{font-size:1.08rem;line-height:1.78;color:var(--text-secondary);margin-bottom:20px}.bio p strong{color:#fff;font-weight:600}.bio p strong.gold{color:var(--color-accent)}.soft-title{font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin:30px 0 16px}.chips{display:flex;flex-wrap:wrap;gap:9px}.chip{font-size:.86rem;padding:7px 14px;border-radius:var(--r-full);background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);transition:border-color var(--t-fast),color var(--t-fast)}.chip:hover{border-color:var(--border-accent);color:#fff}.info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:28px}.info-card h4{font-size:1.15rem;font-weight:600;margin-bottom:18px}.info-row{display:flex;justify-content:space-between;gap:14px;padding:13px 0;border-bottom:1px solid var(--border);font-size:.95rem}.info-row:last-child{border-bottom:none}.info-row .k{color:var(--text-muted);font-family:var(--font-mono);font-size:.85rem}.info-row .v{color:#fff;font-weight:500;text-align:right}.info-row .v.ok{color:#7bd88f}.highlights{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:46px}.hl{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:24px;transition:transform var(--t),border-color var(--t)}.hl:hover{transform:translateY(-4px);border-color:var(--border-accent)}.hl .em{font-size:1.6rem;margin-bottom:12px}.hl h5{font-size:1.02rem;font-weight:600;margin-bottom:8px}.hl p{font-size:.88rem;color:var(--text-muted);line-height:1.5}.skill-cats{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.skill-cat{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:28px;transition:border-color var(--t)}.skill-cat:hover{border-color:var(--border-accent)}.skill-cat.full{grid-column:1/-1}.skill-cat-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.skill-cat-head h4{font-size:1.15rem;font-weight:600;display:flex;align-items:center;gap:11px}.cat-dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-accent))}.skill-cat-head .cnum{font-family:var(--font-mono);font-size:.82rem;color:var(--text-muted)}.skill-list{display:flex;flex-wrap:wrap;gap:8px}.skill{font-size:.84rem;padding:6px 12px;border-radius:var(--r-sm);background:var(--bg-card-2);border:1px solid var(--border);color:var(--text-secondary);display:inline-flex;align-items:center;gap:8px;transition:all var(--t-fast)}.skill:hover{color:#fff;border-color:var(--border-accent);background:var(--bg-hover)}.skill .lv{width:6px;height:6px;border-radius:50%;flex-shrink:0}.lv.production{background:#7bd88f}.lv.advanced{background:var(--color-accent)}.lv.intermediate{background:#4fc3f7}.skill-legend{display:flex;gap:22px;flex-wrap:wrap;margin-top:30px;justify-content:center;font-family:var(--font-mono);font-size:.82rem;color:var(--text-muted)}.skill-legend span{display:inline-flex;align-items:center;gap:8px}.skill-legend i{width:9px;height:9px;border-radius:50%;display:inline-block}.timeline{position:relative}.exp-item{display:grid;grid-template-columns:240px 1fr;gap:42px;padding-bottom:48px}.exp-item:last-child{padding-bottom:0}.exp-meta{position:sticky;top:100px;align-self:start}.exp-date{font-family:var(--font-mono);font-size:.85rem;color:var(--color-accent);margin-bottom:8px}.exp-co{font-size:1.12rem;font-weight:600;line-height:1.3}.exp-loc{font-size:.85rem;color:var(--text-muted);margin-top:6px}.exp-now{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:.74rem;color:#7bd88f;margin-top:12px}.exp-now .d{width:7px;height:7px;border-radius:50%;background:#7bd88f;box-shadow:0 0 8px #7bd88f;animation:livedot 1.6s infinite}@keyframes livedot{0%,to{opacity:1}50%{opacity:.4}}.exp-body{border-left:2px solid var(--border);padding-left:42px;position:relative}.exp-body:before{content:"";position:absolute;left:-7px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--color-accent);box-shadow:0 0 0 5px var(--bg-primary),0 0 14px #dbc27d80}.exp-role{font-size:1.22rem;font-weight:600;margin-bottom:20px}.exp-hl{margin-bottom:15px}.exp-hl:last-of-type{margin-bottom:0}.exp-hl .t{font-weight:600;font-size:.98rem;color:#fff;margin-bottom:3px}.exp-hl .t:before{content:"\25b8  ";color:var(--color-accent)}.exp-hl .x{font-size:.92rem;color:var(--text-secondary);line-height:1.55;padding-left:1rem}.exp-tech{display:flex;flex-wrap:wrap;gap:7px;margin-top:22px}.ttag{font-family:var(--font-mono);font-size:.72rem;padding:4px 9px;border-radius:6px;background:#002e5966;color:#9ec5f0;border:1px solid rgba(79,195,247,.2)}.edu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}.edu-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:28px;display:flex;flex-direction:column;gap:12px;transition:transform var(--t),border-color var(--t)}.edu-card:hover{transform:translateY(-4px);border-color:var(--border-accent)}.edu-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.edu-deg{font-family:var(--font-mono);font-size:.78rem;color:var(--color-accent);text-transform:uppercase;letter-spacing:.05em}.edu-status{font-family:var(--font-mono);font-size:.72rem;padding:4px 10px;border-radius:var(--r-full);border:1px solid var(--border);color:var(--text-muted)}.edu-status.prog{color:#4fc3f7;border-color:#4fc3f759}.edu-field{font-size:1.28rem;font-weight:600}.edu-inst{font-size:.95rem;color:var(--text-secondary)}.edu-date{font-family:var(--font-mono);font-size:.82rem;color:var(--text-muted);margin-top:auto}.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.proj-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--t),border-color var(--t),box-shadow var(--t);cursor:pointer}.proj-card:hover{transform:translateY(-5px);border-color:var(--border-accent);box-shadow:var(--shadow-lg)}.proj-head{height:118px;position:relative;overflow:hidden;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--color-primary-dark),var(--bg-card-2));display:grid;place-items:center}.proj-head:before{content:"";position:absolute;inset:0;opacity:.4;background-image:radial-gradient(rgba(219,194,125,.25) 1px,transparent 1px);background-size:16px 16px}.proj-head .pg{position:absolute;width:180px;height:180px;border-radius:50%;filter:blur(36px);opacity:.5;background:radial-gradient(circle,var(--color-accent),transparent 70%);top:-50px;right:-30px}.proj-num{position:relative;font-family:var(--font-mono);font-size:.82rem;color:var(--color-accent);border:1px solid var(--border-accent);background:#dbc27d14;padding:6px 12px;border-radius:var(--r-sm)}.proj-body{padding:24px;display:flex;flex-direction:column;flex:1}.proj-name{font-size:1.15rem;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:8px}.proj-desc{font-size:.92rem;color:var(--text-muted);line-height:1.55;margin-bottom:18px;flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.proj-stack{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:18px}.proj-stack span{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);border:1px solid var(--border);padding:3px 8px;border-radius:6px}.proj-links{display:flex;gap:10px}.proj-links a,.proj-links .det{flex:1;text-align:center;font-size:.84rem;font-weight:600;padding:9px;border-radius:var(--r-sm);transition:all var(--t-fast)}.proj-links .demo{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:#1a1a1a}.proj-links .demo:hover{filter:brightness(1.06)}.proj-links .det{background:var(--bg-card-2);border:1px solid var(--border-strong);color:#fff}.proj-links .det:hover{border-color:var(--border-accent)}.proj-all{text-align:center;margin-top:36px}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}.contact-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.contact-item{display:flex;align-items:center;gap:16px;padding:16px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);transition:transform var(--t-fast),border-color var(--t-fast)}.contact-item:hover{transform:translate(5px);border-color:var(--border-accent)}.contact-item .ic{width:44px;height:44px;border-radius:11px;background:#dbc27d1a;display:grid;place-items:center;color:var(--color-accent);flex-shrink:0}.contact-item .ic svg{width:21px;height:21px}.contact-item .k{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.contact-item .v{font-size:.96rem;color:#fff;font-weight:500}.form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:34px}.form h3{font-size:1.3rem;margin-bottom:6px}.form .fsub{color:var(--text-muted);font-size:.92rem;margin-bottom:24px}.field{margin-bottom:18px}.field label{display:block;font-family:var(--font-mono);font-size:.76rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.field input,.field textarea{width:100%;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:var(--r-sm);padding:13px 15px;color:#fff;font-family:inherit;font-size:.96rem;transition:border-color var(--t-fast)}.field input:focus,.field textarea:focus{outline:none;border-color:var(--color-accent)}.field textarea{resize:vertical;min-height:120px}.form .btn-accent{width:100%}footer{border-top:1px solid var(--border);padding:54px 0 38px;position:relative;z-index:1;background:var(--bg-secondary)}.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap}.foot-brand{max-width:360px}.foot-brand .brand{margin-bottom:16px}.foot-brand p{font-size:.92rem;color:var(--text-muted);line-height:1.6}.foot-social{display:flex;gap:10px;margin-top:20px}.foot-social a{width:42px;height:42px;border-radius:11px;background:var(--bg-card);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-secondary);transition:all var(--t-fast)}.foot-social a:hover{color:var(--color-accent);border-color:var(--border-accent);transform:translateY(-2px)}.foot-social svg{width:19px;height:19px}.foot-links h5{font-family:var(--font-mono);font-size:.76rem;text-transform:uppercase;color:var(--text-muted);margin-bottom:16px;letter-spacing:.04em}.foot-links a{display:block;font-size:.92rem;color:var(--text-secondary);padding:5px 0}.foot-links a:hover{color:var(--color-accent)}.foot-bottom{margin-top:46px;padding-top:24px;border-top:1px solid var(--border);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.85rem;color:var(--text-muted);font-family:var(--font-mono)}.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}.reveal.in{opacity:1;transform:none}@media (prefers-reduced-motion: reduce){.reveal{opacity:1;transform:none;transition:none}}.to-top{position:fixed;bottom:24px;right:24px;width:48px;height:48px;border-radius:var(--r-full);border:none;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;font-size:1.4rem;box-shadow:var(--shadow-md);z-index:60;opacity:0;visibility:hidden;transform:translateY(16px);transition:all var(--t)}.to-top.show{opacity:1;visibility:visible;transform:none}.to-top:hover{transform:translateY(-4px);box-shadow:var(--shadow-gold)}.modal-backdrop{position:fixed;inset:0;z-index:200;background:#000000b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:28px;opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t)}.modal-backdrop.open{opacity:1;visibility:visible}.modal{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-lg);width:100%;max-width:760px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg);transform:translateY(20px) scale(.98);transition:transform var(--t)}.modal-backdrop.open .modal{transform:none}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 26px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-card)}.modal-head h3{font-size:1.3rem;font-weight:700}.modal-head .sub{font-family:var(--font-mono);font-size:.78rem;color:var(--color-accent);margin-top:4px}.modal-close{width:38px;height:38px;border-radius:9px;background:var(--bg-card-2);border:1px solid var(--border);color:#fff;font-size:1.1rem;transition:all var(--t-fast);flex-shrink:0}.modal-close:hover{border-color:var(--border-accent);color:var(--color-accent)}.modal-body{padding:26px;overflow-y:auto}.modal-foot{padding:18px 26px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.cv-sec{margin-bottom:26px}.cv-sec:last-child{margin-bottom:0}.cv-sec h4{font-size:.85rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}.cv-row{margin-bottom:14px}.cv-row .rt{font-weight:600;font-size:1rem;display:flex;justify-content:space-between;gap:12px}.cv-row .rt .when{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);font-weight:400}.cv-row .rc{color:var(--text-muted);font-size:.9rem}.cv-row .rd{color:var(--text-secondary);font-size:.9rem;margin-top:4px;line-height:1.5}.cv-tags{display:flex;flex-wrap:wrap;gap:7px}.cv-tags span{font-family:var(--font-mono);font-size:.74rem;padding:4px 9px;border-radius:6px;background:var(--bg-card-2);border:1px solid var(--border);color:var(--text-secondary)}.pm-desc{font-size:1rem;color:var(--text-secondary);line-height:1.7;margin-bottom:22px}.pm-label{font-family:var(--font-mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-accent);margin-bottom:12px}.pm-stack{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.pm-stack span{font-family:var(--font-mono);font-size:.78rem;padding:5px 11px;border-radius:var(--r-sm);background:#002e5966;color:#9ec5f0;border:1px solid rgba(79,195,247,.2)}.chat-fab{position:fixed;bottom:24px;right:24px;z-index:120;width:62px;height:62px;border-radius:var(--r-full);border:2px solid var(--color-accent);background:var(--color-primary);box-shadow:var(--shadow-md),0 0 #dbc27d80;overflow:hidden;transition:transform var(--t),box-shadow var(--t);animation:fabpulse 3s infinite}@keyframes fabpulse{0%{box-shadow:var(--shadow-md),0 0 #dbc27d80}70%{box-shadow:var(--shadow-md),0 0 0 14px #dbc27d00}to{box-shadow:var(--shadow-md),0 0 #dbc27d00}}.chat-fab:hover{transform:scale(1.07)}.chat-fab img{width:100%;height:100%;object-fit:cover}.chat-fab.hidden{display:none}.chat-panel{position:fixed;bottom:24px;right:24px;z-index:130;width:min(400px,calc(100vw - 32px));height:min(600px,calc(100vh - 48px));background:var(--bg-card);border:1px solid var(--border-strong);border-radius:var(--r-lg);display:none;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}.chat-panel.open{display:flex;animation:chatin .3s cubic-bezier(.22,1,.36,1)}@keyframes chatin{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}.chat-head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--color-primary-dark),var(--bg-card))}.chat-head .av{width:40px;height:40px;border-radius:50%;overflow:hidden;border:2px solid var(--color-accent);flex-shrink:0}.chat-head .av img{width:100%;height:100%;object-fit:cover}.chat-head .ht{font-weight:600;font-size:.98rem}.chat-head .hs{font-size:.78rem;color:var(--text-muted)}.chat-head .hs .on{color:#7bd88f}.chat-head .x{margin-left:auto;width:34px;height:34px;border-radius:8px;background:#ffffff0f;border:none;color:#fff;font-size:1rem;transition:background var(--t-fast)}.chat-head .x:hover{background:#ffffff24}.chat-msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}.msg{max-width:84%;padding:11px 15px;border-radius:14px;font-size:.92rem;line-height:1.55}.msg.bot{align-self:flex-start;background:var(--bg-card-2);border:1px solid var(--border);border-bottom-left-radius:4px;color:var(--text-secondary)}.msg.user{align-self:flex-end;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));color:#fff;border-bottom-right-radius:4px}.msg.bot strong{color:var(--color-accent)}.chat-typing{align-self:flex-start;display:flex;gap:5px;padding:13px 16px;background:var(--bg-card-2);border:1px solid var(--border);border-radius:14px 14px 14px 4px}.chat-typing i{width:7px;height:7px;border-radius:50%;background:var(--color-accent);animation:td 1.2s infinite}.chat-typing i:nth-child(2){animation-delay:.2s}.chat-typing i:nth-child(3){animation-delay:.4s}@keyframes td{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.chat-suggest{display:flex;flex-wrap:wrap;gap:7px;padding:0 18px 12px}.chat-suggest button{font-size:.78rem;padding:7px 12px;border-radius:var(--r-full);background:var(--bg-card-2);border:1px solid var(--border-accent);color:var(--color-accent);transition:background var(--t-fast)}.chat-suggest button:hover{background:#dbc27d1f}.chat-input{display:flex;gap:9px;padding:14px;border-top:1px solid var(--border)}.chat-input input{flex:1;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:var(--r-full);padding:11px 16px;color:#fff;font-family:inherit;font-size:.92rem}.chat-input input:focus{outline:none;border-color:var(--color-accent)}.chat-input button{width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:#1a1a1a;font-size:1.1rem;flex-shrink:0;transition:transform var(--t-fast)}.chat-input button:hover{transform:scale(1.06)}.chat-input button:disabled{opacity:.5;cursor:not-allowed}@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:36px;text-align:center}.hero-cta,.hero-stats,.code-line{justify-content:center}.hero-tagline{margin-left:auto;margin-right:auto}.hero-photo .photo-ring{width:min(300px,62vw)}.about-grid,.contact-grid{grid-template-columns:1fr;gap:34px}.skill-cats,.edu-grid{grid-template-columns:1fr}.highlights,.proj-grid{grid-template-columns:repeat(2,1fr)}.exp-item{grid-template-columns:1fr;gap:18px}.exp-meta{position:static}.exp-body{border-left:none;padding-left:24px}.exp-body:before{left:-4px}.nav-links{display:none}.nav-toggle{display:block}nav.top.open .nav-links{display:flex;position:absolute;top:72px;left:0;right:0;flex-direction:column;background:var(--bg-primary);border-bottom:1px solid var(--border);padding:14px 32px;gap:2px}}@media (max-width:620px){.wrap,.nav-inner{padding-left:20px;padding-right:20px}section.block{padding:66px 0}.hero{padding-top:100px}.proj-grid,.highlights{grid-template-columns:1fr}.hero-stats{gap:30px}.lang-switch{display:none}}.brand .logo{width:36px;height:36px;display:block;flex-shrink:0}.brand .logo svg{display:block;width:100%;height:100%}.brand .logo:hover .wc-stroke{stroke:var(--color-accent-light)}.timeline2{position:relative;max-width:920px;margin:0 auto;padding-left:0}.tl-item{position:relative;display:grid;grid-template-columns:40px 1fr;gap:24px;padding-bottom:36px}.tl-item:last-child{padding-bottom:0}.tl-marker{position:relative;display:flex;flex-direction:column;align-items:center}.tl-dot{width:20px;height:20px;border-radius:50%;background:var(--bg-card);border:2px solid var(--color-accent);position:relative;z-index:2;margin-top:26px;flex-shrink:0;transition:transform var(--t)}.tl-dot:after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--color-accent);opacity:.4;transition:opacity var(--t)}.tl-dot.active{border-color:#7bd88f;box-shadow:0 0 0 5px #7bd88f1f}.tl-dot.active:after{background:#7bd88f;opacity:1;animation:livedot 1.6s infinite}.tl-line{flex:1;width:2px;background:linear-gradient(var(--color-accent),var(--border) 60%);margin-top:6px;border-radius:2px}.tl-item:last-child .tl-line{display:none}.exp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);padding:26px 28px;transition:transform var(--t),border-color var(--t),box-shadow var(--t)}.exp-card:hover{transform:translateY(-3px);border-color:var(--border-accent);box-shadow:var(--shadow-md)}.ec-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:6px}.ec-role{font-size:1.2rem;font-weight:700;line-height:1.25}.ec-co{color:var(--color-accent);font-weight:600;font-size:1rem;margin-top:3px}.ec-badge{font-family:var(--font-mono);font-size:.72rem;padding:5px 12px;border-radius:var(--r-full);background:#7bd88f1f;color:#7bd88f;border:1px solid rgba(123,216,143,.3);white-space:nowrap}.ec-meta{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--font-mono);font-size:.82rem;color:var(--text-muted);margin:10px 0 18px}.ec-meta span{display:inline-flex;align-items:center;gap:6px}.ec-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:20px}.ec-list li{font-size:.94rem;line-height:1.55;color:var(--text-secondary);padding-left:22px;position:relative}.ec-list li:before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;border-radius:50%;background:var(--color-accent);opacity:.85}.ec-list li strong{color:#fff;font-weight:600}.ec-tech{display:flex;flex-wrap:wrap;gap:7px}.ec-tech span{font-family:var(--font-mono);font-size:.72rem;padding:4px 9px;border-radius:6px;background:#002e5966;color:#9ec5f0;border:1px solid rgba(79,195,247,.2)}.proj-head .proj-overlay{position:absolute;inset:0;z-index:3;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(180deg,#002e5966,#0a0a0cdb);opacity:0;transition:opacity var(--t);padding:14px;flex-wrap:wrap}.proj-card:hover .proj-overlay{opacity:1}.ov-btn{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;padding:8px 12px;border-radius:8px;background:#17181deb;border:1px solid var(--border-strong);color:#fff;transition:all var(--t-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ov-btn:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px)}.ov-btn.demo{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:#1a1a1a;border-color:transparent}.ov-btn.demo:hover{color:#1a1a1a;filter:brightness(1.05)}.ov-btn svg{width:14px;height:14px}.proj-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:16px;border-top:1px solid var(--border)}.proj-stats{display:flex;gap:14px;font-size:.82rem;color:var(--text-muted);font-family:var(--font-mono)}.proj-lang{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:var(--text-secondary)}.proj-lang i{width:10px;height:10px;border-radius:50%}.modal.wide{max-width:1080px;height:84vh;max-height:84vh}.code-body{display:flex;flex:1;overflow:hidden;padding:0}.code-tree{width:260px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;background:var(--bg-secondary);padding:10px 0}.code-tree .tree-head{font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:8px 16px}.tree-node{display:flex;align-items:center;gap:8px;padding:5px 16px;font-size:.85rem;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:background var(--t-fast),color var(--t-fast)}.tree-node:hover{background:var(--bg-hover);color:#fff}.tree-node.active{background:#dbc27d1a;color:var(--color-accent)}.tree-node .chev{font-size:.6rem;transition:transform var(--t-fast);color:var(--text-muted);width:10px}.tree-node .chev.open{transform:rotate(90deg)}.tree-node .ti{width:15px;text-align:center;flex-shrink:0}.tree-node.file{color:var(--text-secondary)}.code-view{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#0d0e12}.code-tabs{display:flex;gap:2px;background:var(--bg-secondary);border-bottom:1px solid var(--border);overflow-x:auto;flex-shrink:0}.code-tab{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:.8rem;color:var(--text-muted);cursor:pointer;border-right:1px solid var(--border);white-space:nowrap;transition:all var(--t-fast)}.code-tab.active{background:#0d0e12;color:var(--color-accent)}.code-tab .tc{font-size:.85rem;opacity:.6}.code-tab .tc:hover{opacity:1;color:#fff}.code-scroll{flex:1;overflow:auto}.code-scroll pre{margin:0;padding:18px 20px;font-family:var(--font-mono);font-size:.82rem;line-height:1.6;tab-size:2}.code-scroll code{font-family:var(--font-mono)}.code-empty,.code-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--text-muted);font-size:.92rem}.md-toolbar{display:flex;align-items:center;gap:8px}.md-toolbar button{width:34px;height:34px;border-radius:8px;background:var(--bg-card-2);border:1px solid var(--border);color:#fff;font-size:.9rem;transition:all var(--t-fast)}.md-toolbar button:hover{border-color:var(--border-accent);color:var(--color-accent)}.md-zoom{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);min-width:42px;text-align:center}.md-content{font-size:calc(.96rem * var(--md-scale,1));line-height:1.7;color:var(--text-secondary)}.md-content h1,.md-content h2,.md-content h3{color:#fff;margin:1.3em 0 .6em;line-height:1.25}.md-content h1{font-size:calc(1.7rem * var(--md-scale,1));border-bottom:1px solid var(--border);padding-bottom:.3em}.md-content h2{font-size:calc(1.35rem * var(--md-scale,1));border-bottom:1px solid var(--border);padding-bottom:.25em}.md-content h3{font-size:calc(1.12rem * var(--md-scale,1))}.md-content p{margin:.7em 0}.md-content a{color:var(--color-accent);text-decoration:underline;text-underline-offset:2px}.md-content ul,.md-content ol{margin:.7em 0;padding-left:1.5em}.md-content li{margin:.3em 0}.md-content code{font-family:var(--font-mono);font-size:.86em;background:var(--bg-card-2);padding:2px 6px;border-radius:5px;color:var(--color-accent-light)}.md-content pre{background:#0d0e12;border:1px solid var(--border);border-radius:var(--r-sm);padding:16px;overflow-x:auto;margin:1em 0}.md-content pre code{background:none;padding:0;color:#e6e6e6}.md-content img{max-width:100%;border-radius:var(--r-sm);margin:.6em 0}.md-content blockquote{border-left:3px solid var(--color-accent);padding-left:1em;margin:1em 0;color:var(--text-muted)}.md-content table{width:100%;border-collapse:collapse;margin:1em 0;font-size:.9em}.md-content th,.md-content td{border:1px solid var(--border);padding:8px 12px;text-align:left}.md-content th{background:var(--bg-card-2);color:#fff}.md-content hr{border:none;border-top:1px solid var(--border);margin:1.4em 0}.demo-frame-wrap{position:relative;width:100%;height:68vh;background:#0d0e12;border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--border)}.demo-frame-wrap iframe{width:100%;height:100%;border:none;background:#fff}.demo-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.demo-bar .url{flex:1;background:var(--bg-primary);border:1px solid var(--border);border-radius:var(--r-full);padding:7px 14px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.cert-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:transform var(--t),border-color var(--t),box-shadow var(--t);display:flex;flex-direction:column}.cert-card:hover{transform:translateY(-4px);border-color:var(--border-accent);box-shadow:var(--shadow-lg)}.cert-preview{height:140px;position:relative;background:linear-gradient(135deg,var(--color-primary-dark),var(--bg-card-2));display:grid;place-items:center;border-bottom:1px solid var(--border)}.cert-preview svg{width:46px;height:46px;color:var(--color-accent);opacity:.85}.cert-preview .badge{position:absolute;top:10px;right:10px;font-size:1.1rem}.cert-body{padding:18px;display:flex;flex-direction:column;gap:12px;flex:1}.cert-name{font-size:.95rem;font-weight:600;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cert-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.cert-size{font-family:var(--font-mono);font-size:.74rem;color:var(--text-muted)}.cert-view{font-size:.78rem;font-weight:600;color:var(--color-accent);display:inline-flex;align-items:center;gap:5px}.cert-state{text-align:center;color:var(--text-muted);padding:40px 0;font-size:.95rem}.cert-state .spin{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 14px}@keyframes spin{to{transform:rotate(360deg)}}.cert-frame-wrap{width:100%;height:72vh;background:#525659;border-radius:var(--r-sm);overflow:hidden}.cert-frame-wrap iframe{width:100%;height:100%;border:none}@media (max-width:980px){.modal.wide{height:88vh}.code-tree{width:200px}.tl-item{grid-template-columns:30px 1fr;gap:16px}}@media (max-width:620px){.code-tree{width:150px}.demo-frame-wrap{height:60vh}}@property --neb-angle{syntax:"<angle>";initial-value:0deg;inherits:false;}.github-stats-btn{position:relative;isolation:isolate;overflow:visible}.github-stats-btn:before{content:"";position:absolute;inset:-3px;border-radius:inherit;z-index:-2;background:conic-gradient(from var(--neb-angle),transparent 0deg,rgba(124,58,237,0) 40deg,rgba(124,58,237,.55) 120deg,rgba(219,194,125,.7) 190deg,rgba(0,240,255,.45) 260deg,rgba(124,58,237,.3) 320deg,transparent 360deg);animation:neb-spin 7s linear infinite;filter:blur(7px);opacity:.55;transition:opacity var(--t)}.github-stats-btn:after{content:"";position:absolute;inset:0;border-radius:inherit;z-index:-1;background:linear-gradient(135deg,#1e083cf0,#0f0523f5)}.github-stats-btn:hover:before{opacity:.9;animation-duration:4s}@keyframes neb-spin{to{--neb-angle:360deg}}@media (prefers-reduced-motion:reduce){.github-stats-btn:before{animation:none}}.chat-panel{height:min(640px,calc(100vh - 48px));width:min(440px,calc(100vw - 32px))}.chat-voice-toggle{margin-left:auto;width:38px;height:34px;border-radius:9px;background:#ffffff0f;border:1px solid var(--border);color:var(--text-muted);display:grid;place-items:center;position:relative;transition:all var(--t-fast)}.chat-voice-toggle svg{width:18px;height:18px;position:absolute;transition:opacity var(--t-fast)}.chat-voice-toggle .v-on{opacity:0}.chat-voice-toggle.active{background:#dbc27d29;border-color:var(--border-accent);color:var(--color-accent)}.chat-voice-toggle.active .v-on{opacity:1}.chat-voice-toggle.active .v-off{opacity:0}.chat-voice-toggle.speaking{animation:vspeak 1.1s ease-in-out infinite}@keyframes vspeak{0%,to{box-shadow:0 0 #dbc27d73}50%{box-shadow:0 0 0 7px #dbc27d00}}.chat-head .x{margin-left:6px}.cert-pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:42px;flex-wrap:wrap}.cert-pagination button{min-width:44px;height:44px;padding:0 8px;border-radius:12px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);font-family:var(--font-mono);font-size:.92rem;font-weight:600;display:grid;place-items:center;transition:all var(--t-fast)}.cert-pagination button:hover:not(:disabled){border-color:var(--border-accent);color:#fff;transform:translateY(-2px)}.cert-pagination button.active{background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;border-color:transparent;box-shadow:var(--shadow-gold)}.cert-pagination button:disabled{opacity:.35;cursor:not-allowed}.cert-pagination .pg-arrow{font-size:1.35rem;line-height:1}.chat-attach-tray{display:flex;flex-wrap:wrap;gap:8px;padding:0 14px;max-height:0;overflow:hidden;transition:max-height var(--t),padding var(--t)}.chat-attach-tray.show{max-height:140px;padding:10px 14px 0}.att-chip{display:flex;align-items:center;gap:8px;background:var(--bg-card-2);border:1px solid var(--border-accent);border-radius:10px;padding:6px 8px 6px 6px;font-size:.78rem;color:var(--text-secondary);max-width:160px}.att-chip img{width:34px;height:34px;border-radius:7px;object-fit:cover;flex-shrink:0}.att-chip .fi{width:34px;height:34px;border-radius:7px;background:#dbc27d1f;display:grid;place-items:center;color:var(--color-accent);flex-shrink:0;font-size:1rem}.att-chip .nm{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.att-chip .rm{background:none;border:none;color:var(--text-muted);font-size:.95rem;padding:0 2px;flex-shrink:0}.att-chip .rm:hover{color:#ff6b6b}.chat-input{align-items:center;gap:6px;padding:12px 14px}.ci-btn{width:40px;height:40px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);font-size:1.05rem;display:grid;place-items:center;flex-shrink:0;transition:all var(--t-fast)}.ci-btn:hover{background:var(--bg-card-2);color:var(--color-accent)}.ci-btn svg{width:20px;height:20px}.chat-input input.ci-text{flex:1;min-width:0;background:var(--bg-primary);border:1px solid var(--border-strong);border-radius:var(--r-full);padding:11px 16px;color:#fff;font-family:inherit;font-size:.92rem}.chat-input input.ci-text:focus{outline:none;border-color:var(--color-accent)}.ci-send{width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:#1a1a1a;display:grid;place-items:center;flex-shrink:0;transition:transform var(--t-fast),opacity var(--t-fast)}.ci-send:hover{transform:scale(1.06)}.ci-send svg{width:19px;height:19px}.chat-rec{display:none;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid var(--border);background:var(--bg-card)}.chat-rec.show{display:flex}.chat-input.recording{display:none}.rec-dot{width:11px;height:11px;border-radius:50%;background:#ff5d5d;flex-shrink:0;animation:recpulse 1.1s infinite;box-shadow:0 0 10px #ff5d5d}@keyframes recpulse{0%,to{opacity:1}50%{opacity:.35}}.rec-time{font-family:var(--font-mono);font-size:.9rem;color:#fff;min-width:42px}.rec-wave{flex:1;display:flex;align-items:center;gap:3px;height:30px;overflow:hidden}.rec-wave i{flex:1;max-width:4px;border-radius:2px;background:var(--color-accent);opacity:.85;animation:wv .9s ease-in-out infinite}@keyframes wv{0%,to{height:18%}50%{height:90%}}.rec-cancel,.rec-stop{width:42px;height:42px;border-radius:50%;border:none;display:grid;place-items:center;flex-shrink:0;transition:transform var(--t-fast)}.rec-cancel{background:var(--bg-card-2);color:#ff6b6b}.rec-cancel:hover{transform:scale(1.08)}.rec-stop{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:#1a1a1a}.rec-stop:hover{transform:scale(1.08)}.rec-cancel svg,.rec-stop svg{width:19px;height:19px}.msg .m-img{display:block;width:100%;max-width:220px;border-radius:10px;margin:2px 0 6px;border:1px solid var(--border)}.msg .m-file{display:flex;align-items:center;gap:9px;background:#ffffff0f;border:1px solid var(--border);border-radius:9px;padding:8px 10px;margin:2px 0 6px;font-size:.82rem}.msg.user .m-file{background:#0000002e}.msg .m-file .fi{width:30px;height:30px;border-radius:7px;background:#dbc27d2e;display:grid;place-items:center;color:var(--color-accent);flex-shrink:0}.m-voice{display:flex;align-items:center;gap:10px;min-width:170px}.m-voice .pv{width:34px;height:34px;border-radius:50%;border:none;flex-shrink:0;display:grid;place-items:center;background:#ffffff24;color:#fff;transition:transform var(--t-fast)}.msg.user .m-voice .pv{background:#0003;color:#fff}.m-voice .pv:hover{transform:scale(1.08)}.m-voice .pv svg{width:15px;height:15px}.m-voice .vbars{flex:1;display:flex;align-items:center;gap:2px;height:24px}.m-voice .vbars i{flex:1;max-width:3px;border-radius:2px;background:currentColor;opacity:.5}.m-voice.playing .vbars i{animation:wv .8s ease-in-out infinite;opacity:.9}.m-voice .vt{font-family:var(--font-mono);font-size:.74rem;opacity:.8;flex-shrink:0}.lightbox{position:fixed;inset:0;z-index:240;background:#050609f0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:opacity var(--t),visibility var(--t)}.lightbox.open{opacity:1;visibility:visible}.lb-top{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 24px;flex-shrink:0}.lb-title{font-weight:600;font-size:1.05rem}.lb-title .sub{font-family:var(--font-mono);font-size:.8rem;color:var(--color-accent);margin-top:2px}.lb-count{font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted)}.lb-close{width:42px;height:42px;border-radius:10px;background:#ffffff14;border:1px solid var(--border);color:#fff;font-size:1.2rem;transition:all var(--t-fast)}.lb-close:hover{border-color:var(--border-accent);color:var(--color-accent)}.lb-stage{flex:1;display:flex;align-items:center;justify-content:center;position:relative;padding:0 24px;min-height:0}.lb-stage img{max-width:100%;max-height:100%;border-radius:var(--r-sm);box-shadow:var(--shadow-lg);object-fit:contain;border:1px solid var(--border);background:var(--bg-card)}.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:#17181dd9;border:1px solid var(--border-strong);color:#fff;font-size:1.5rem;display:grid;place-items:center;transition:all var(--t-fast);z-index:2}.lb-nav:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-50%) scale(1.07)}.lb-nav.prev{left:24px}.lb-nav.next{right:24px}.lb-thumbs{display:flex;gap:10px;padding:18px 24px;overflow-x:auto;justify-content:center;flex-shrink:0}.lb-thumb{width:96px;height:60px;border-radius:8px;overflow:hidden;border:2px solid transparent;cursor:pointer;flex-shrink:0;opacity:.5;transition:all var(--t-fast);background:var(--bg-card)}.lb-thumb img{width:100%;height:100%;object-fit:cover}.lb-thumb:hover{opacity:.85}.lb-thumb.active{opacity:1;border-color:var(--color-accent)}.lb-caption{text-align:center;padding:0 24px 8px;color:var(--text-muted);font-size:.88rem}.ov-btn.gallery{background:#17181deb}.proj-head{height:172px}.proj-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;z-index:1;transition:transform var(--t),filter var(--t)}.proj-card:hover .proj-thumb{transform:scale(1.04);filter:brightness(.55) saturate(1.05)}.proj-head .proj-num{position:absolute;top:12px;left:12px;z-index:2;background:#0a0a0cb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.proj-media-badge{position:absolute;top:12px;right:12px;z-index:2;display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:.7rem;color:#fff;background:#0a0a0cb3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border-strong);padding:4px 9px;border-radius:var(--r-full)}.proj-media-badge svg{width:12px;height:12px}.lb-media{display:flex;align-items:center;justify-content:center;max-width:100%;max-height:100%}.lb-media img,.lb-media video{max-width:100%;max-height:72vh;border-radius:var(--r-sm);box-shadow:var(--shadow-lg);object-fit:contain;border:1px solid var(--border);background:var(--bg-card)}.lb-thumb{position:relative}.lb-thumb .vbadge{position:absolute;inset:0;display:grid;place-items:center;background:#00000059;color:#fff;font-size:1.1rem;pointer-events:none}.cert-filters{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:34px}.cert-filters button{font-size:.84rem;font-weight:600;padding:8px 16px;border-radius:var(--r-full);background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);transition:all var(--t-fast)}.cert-filters button:hover{border-color:var(--border-accent);color:#fff}.cert-filters button.active{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-light));color:#1a1a1a;border-color:transparent}.cert-filters .fcount{opacity:.6;font-weight:400;margin-left:4px}.cert-preview{height:190px;overflow:hidden;padding:0;background:#fff;position:relative}.cert-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:linear-gradient(150deg,var(--color-primary-dark),var(--bg-card-2));color:var(--color-accent);z-index:1}.cert-fallback svg{width:42px;height:42px;opacity:.9}.cert-fallback span{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;color:var(--text-muted)}.cert-iframe{position:absolute;inset:0;width:100%;height:260px;border:none;background:#fff;z-index:2;pointer-events:none;opacity:0;transition:opacity .4s ease}.cert-iframe.loaded{opacity:1}.cert-preview .ribbon{position:absolute;top:10px;left:10px;z-index:3;font-family:var(--font-mono);font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:4px 9px;border-radius:var(--r-full);background:#002e59e6;color:var(--color-accent-light);border:1px solid var(--border-accent)}.cert-preview .pdf-tag{position:absolute;bottom:10px;right:10px;z-index:3;font-family:var(--font-mono);font-size:.62rem;font-weight:700;padding:3px 8px;border-radius:5px;background:#d93025;color:#fff;letter-spacing:.04em}.cert-card .cert-name{min-height:2.6em}@media (max-width:620px){.lb-nav{width:42px;height:42px;font-size:1.2rem}.lb-thumb{width:70px;height:46px}}
