@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:ital,wght@0,300;0,400;0,500;1,300&display=swap";:root{--accent: #22d3ee;--accent-2: #818cf8;--accent-glow: rgba(34, 211, 238, .18);--accent-2-glow: rgba(129, 140, 248, .15);--danger: #f43f5e;--success: #10b981;--bg-base: #050b18;--bg-layer: #0a1428;--bg-raised: #0f1f3d;--glass-bg: rgba(10, 20, 40, .55);--glass-bg-2: rgba(15, 31, 61, .65);--glass-border: rgba(34, 211, 238, .12);--glass-border-h:rgba(34, 211, 238, .3);--glass-shine: rgba(255, 255, 255, .04);--glass-blur: 18px;--text-primary: #f0f6ff;--text-secondary:#8ba3c7;--text-muted: #3d5a80;--text-on-accent:#050b18;--shadow-sm: 0 2px 8px rgba(0,0,0,.35);--shadow-md: 0 8px 32px rgba(0,0,0,.45);--shadow-lg: 0 20px 60px rgba(0,0,0,.6);--shadow-glow: 0 0 40px rgba(34,211,238,.15);--shadow-glow-2: 0 0 40px rgba(129,140,248,.12);--r-sm: 8px;--r-md: 14px;--r-lg: 22px;--r-xl: 32px;--r-pill:9999px;--font-display: "Outfit", sans-serif;--font-mono: "JetBrains Mono", monospace;--ease: cubic-bezier(.16, 1, .3, 1);--t-fast: .18s;--t-med: .35s;--t-slow: .6s}[data-theme=light]{--accent: #0891b2;--accent-2: #6366f1;--accent-glow: rgba(8, 145, 178, .12);--accent-2-glow: rgba(99, 102, 241, .1);--bg-base: #f0f6ff;--bg-layer: #e4edf9;--bg-raised: #dce7f5;--glass-bg: rgba(255, 255, 255, .55);--glass-bg-2: rgba(255, 255, 255, .72);--glass-border: rgba(8, 145, 178, .15);--glass-border-h:rgba(8, 145, 178, .4);--glass-shine: rgba(255, 255, 255, .7);--text-primary: #0a1428;--text-secondary:#3d5a80;--text-muted: #8ba3c7;--text-on-accent:#ffffff;--shadow-sm: 0 2px 8px rgba(8,145,178,.08);--shadow-md: 0 8px 32px rgba(8,145,178,.12);--shadow-lg: 0 20px 60px rgba(8,145,178,.18);--shadow-glow: 0 0 40px rgba(8,145,178,.12);--shadow-glow-2: 0 0 40px rgba(99,102,241,.1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;scroll-padding-top:76px;font-size:16px}body{font-family:var(--font-display);background:var(--bg-base);color:var(--text-primary);line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;transition:background var(--t-med) var(--ease),color var(--t-med) var(--ease)}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 20% 10%,var(--accent-glow) 0%,transparent 60%),radial-gradient(ellipse 60% 50% at 80% 90%,var(--accent-2-glow) 0%,transparent 60%);pointer-events:none;z-index:0;transition:background var(--t-med) var(--ease)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:var(--r-pill)}::-moz-selection{background:var(--accent-glow);color:var(--accent)}::selection{background:var(--accent-glow);color:var(--accent)}.container{width:100%;max-width:1180px;margin:0 auto;padding:0 clamp(1rem,4vw,2.5rem)}section{padding:clamp(60px,10vw,110px) 0;position:relative;z-index:1}.glass{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-md);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));box-shadow:var(--shadow-md);position:relative;overflow:hidden;transition:border-color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),transform var(--t-fast) var(--ease)}.glass:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,var(--glass-shine) 0%,transparent 50%);pointer-events:none;z-index:0}.glass>*{position:relative;z-index:1}.glass:hover{border-color:var(--glass-border-h);box-shadow:var(--shadow-md),var(--shadow-glow)}.glass--lift:hover{transform:translateY(-5px)}.section-eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.72rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}.section-eyebrow:before{content:"";display:block;width:28px;height:1.5px;background:var(--accent);border-radius:2px}.section-heading{font-size:clamp(1.9rem,4vw,2.9rem);font-weight:800;line-height:1.12;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:1rem}.section-heading em{font-style:normal;color:var(--accent)}.section-sub{font-size:1rem;color:var(--text-secondary);max-width:520px;line-height:1.75}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-family:var(--font-display);font-weight:600;font-size:.9rem;letter-spacing:.02em;border-radius:var(--r-sm);padding:.72rem 1.6rem;cursor:pointer;border:none;outline:none;transition:all var(--t-fast) var(--ease);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--accent);color:var(--text-on-accent);box-shadow:0 4px 20px var(--accent-glow)}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 30px var(--accent-glow)}.btn-ghost{background:var(--glass-bg);color:var(--accent);border:1px solid var(--glass-border-h);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn-ghost:hover{background:var(--accent-glow);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--glass-border) 1px,transparent 1px),linear-gradient(90deg,var(--glass-border) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 100%);mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 100%);pointer-events:none;opacity:.5}.chip{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-size:.7rem;font-weight:400;letter-spacing:.06em;padding:.28rem .75rem;border-radius:var(--r-pill);border:1px solid var(--glass-border);color:var(--text-secondary);background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--t-fast) var(--ease)}.chip:hover{border-color:var(--accent);color:var(--accent)}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--glass-border-h),transparent);margin:0;border:none}.app{position:relative;min-height:100vh}.nav{position:fixed;top:0;left:0;right:0;z-index:999;padding:1.1rem 0;transition:all .35s cubic-bezier(.16,1,.3,1)}.nav--scrolled{background:var(--glass-bg);border-bottom:1px solid var(--glass-border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:.75rem 0;box-shadow:var(--shadow-sm)}.nav__inner{display:flex;align-items:center;gap:1.5rem}.nav__logo{font-family:var(--font-mono);font-size:1.15rem;font-weight:500;color:var(--text-primary);text-decoration:none;margin-right:auto;transition:opacity .2s}.nav__logo:hover{opacity:.75}.nav__logo-lt{color:var(--accent)}.nav__links{display:flex;gap:.1rem;list-style:none}.nav__link{position:relative;padding:.45rem .9rem;font-size:.875rem;font-weight:500;color:var(--text-secondary);text-decoration:none;text-transform:capitalize;border-radius:var(--r-sm);transition:color var(--t-fast) var(--ease),background var(--t-fast) var(--ease)}.nav__link:hover{color:var(--text-primary);background:var(--glass-bg)}.nav__link--active{color:var(--accent)}.nav__link-bar{position:absolute;bottom:2px;left:50%;transform:translate(-50%);width:16px;height:2px;background:var(--accent);border-radius:var(--r-pill)}.nav__right{display:flex;align-items:center;gap:.65rem}.theme-toggle{width:38px;height:38px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all var(--t-fast) var(--ease);overflow:hidden}.theme-toggle:hover{color:var(--accent);border-color:var(--glass-border-h)}.nav__cta{padding:.55rem 1.2rem;font-size:.85rem}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px}.hamburger span{display:block;width:20px;height:2px;background:var(--text-secondary);border-radius:2px;transition:all .3s}.hamburger--open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger--open span:nth-child(2){opacity:0;transform:scaleX(0)}.hamburger--open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-nav{position:fixed;top:64px;left:1rem;right:1rem;z-index:998;border-radius:var(--r-lg);padding:1rem;display:flex;flex-direction:column}.mobile-nav__link{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;border-radius:var(--r-sm);font-size:1rem;font-weight:600;color:var(--text-primary);text-decoration:none;text-transform:capitalize;transition:all var(--t-fast)}.mobile-nav__link:hover{background:var(--glass-bg-2);color:var(--accent)}.mobile-nav__idx{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);opacity:.7}@media (max-width: 820px){.nav__links,.nav__cta{display:none}.hamburger{display:flex}}.footer{position:relative;z-index:2}.footer__divider{height:1px;background:linear-gradient(90deg,transparent,var(--glass-border-h),transparent)}.footer__inner{display:flex;align-items:center;gap:2rem;flex-wrap:wrap;padding-top:1.75rem;padding-bottom:1.75rem}.footer__brand{flex:1;min-width:160px}.footer__logo{font-family:var(--font-mono);font-size:1.1rem;color:var(--text-primary);text-decoration:none;display:inline-block;margin-bottom:.3rem}.footer__logo-b{color:var(--accent)}.footer__tagline{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);letter-spacing:.06em}.footer__nav{display:flex;gap:.25rem;flex-wrap:wrap}.footer__nav-link{padding:.35rem .75rem;font-size:.82rem;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:var(--r-sm);text-transform:capitalize;transition:all var(--t-fast)}.footer__nav-link:hover{color:var(--accent);background:var(--glass-bg)}.footer__right{display:flex;flex-direction:column;gap:.6rem;align-items:flex-end}.footer__socials{display:flex;gap:.5rem}.footer__social{width:36px;height:36px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:.88rem;color:var(--text-secondary);text-decoration:none;transition:color var(--t-fast)}.footer__social:hover{color:var(--accent)}.footer__copy{font-family:var(--font-mono);font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;gap:.3rem}.footer__heart{color:#f43f5e;font-size:.75rem}@media (max-width:680px){.footer__inner{flex-direction:column;align-items:flex-start}.footer__right{align-items:flex-start}}.footer__db-btn{margin-top:.5rem;background:none;border:1px solid var(--glass-border);border-radius:var(--r-sm);padding:.35rem .85rem;font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary);cursor:pointer;transition:all var(--t-fast);width:-moz-fit-content;width:fit-content}.footer__db-btn:hover{color:var(--accent);border-color:var(--glass-border-h);background:var(--glass-bg)}.contact{position:relative;overflow:hidden;padding-bottom:40px}.contact__blob{position:absolute;bottom:-80px;left:-120px;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);pointer-events:none}.contact__layout{display:grid;grid-template-columns:1fr 1.35fr;gap:2.5rem;margin-top:2.75rem;align-items:start}.contact__info{display:flex;flex-direction:column;gap:1.75rem}.contact__intro{font-size:.96rem;color:var(--text-secondary);line-height:1.8}.contact__cards{display:flex;flex-direction:column;gap:.75rem}.contact__card{display:flex;align-items:center;gap:1rem;padding:1rem 1.2rem;text-decoration:none;transition:transform var(--t-fast),border-color var(--t-fast)}.contact__card-icon{width:40px;height:40px;border-radius:var(--r-sm);background:var(--accent-glow);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.contact__card-lbl{display:block;font-family:var(--font-mono);font-size:.65rem;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:.18rem}.contact__card-val{display:block;font-size:.85rem;font-weight:600;color:var(--text-primary);word-break:break-all}.contact__socials-lbl{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);letter-spacing:.16em;text-transform:uppercase;margin-bottom:.75rem}.contact__social-row{display:flex;gap:.65rem;flex-wrap:wrap}.contact__social{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--r-sm);font-size:.82rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all var(--t-fast)}.contact__social:hover{color:var(--accent);border-color:var(--glass-border-h)!important}.contact__form-wrap{padding:2rem}.contact__form{display:flex;flex-direction:column;gap:1.1rem}.contact__row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.contact__field{display:flex;flex-direction:column;gap:.35rem}.contact__label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-secondary);letter-spacing:.12em;text-transform:uppercase}.contact__input{width:100%;padding:.75rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text-primary);font-family:var(--font-display);font-size:.9rem;outline:none;resize:none;transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast)}.contact__input::-moz-placeholder{color:var(--text-muted)}.contact__input::placeholder{color:var(--text-muted)}.contact__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--glass-bg-2)}.contact__textarea{min-height:130px}.contact__submit{width:100%;justify-content:center;padding:.85rem;font-size:.95rem}@media (max-width:900px){.contact__layout{grid-template-columns:1fr}}@media (max-width:480px){.contact__row{grid-template-columns:1fr}}.proj-sec{position:relative;overflow:hidden}.proj__blob{position:absolute;top:0;right:-100px;width:550px;height:550px;border-radius:50%;background:radial-gradient(circle,var(--accent-2-glow) 0%,transparent 70%);pointer-events:none;filter:blur(60px);opacity:.6}.proj__filter-wrap{margin-top:2.25rem;margin-bottom:2.25rem}.proj__filters{display:inline-flex;gap:.25rem;padding:.3rem;border-radius:var(--r-lg)!important;flex-wrap:wrap}.proj__filter-btn{position:relative;display:inline-flex;align-items:center;gap:.45rem;padding:.55rem 1.15rem;background:none;border:none;border-radius:var(--r-md);cursor:pointer;font-family:var(--font-display);font-size:.86rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;transition:color var(--t-fast);z-index:0}.proj__filter-btn:hover,.proj__filter-btn--active{color:var(--text-primary)}.proj__filter-icon{font-size:.9rem}.proj__filter-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--r-md);background:var(--accent-glow);border:1px solid var(--glass-border-h);z-index:-1}.proj__filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:var(--r-pill);background:var(--glass-bg-2);border:1px solid var(--glass-border);font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted)}.proj__filter-btn--active .proj__filter-count{background:var(--accent-glow);color:var(--accent);border-color:#22d3ee4d}.proj__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.proj-card{overflow:hidden;padding:0;display:flex;flex-direction:column;position:relative;transition:transform .28s var(--ease),box-shadow .28s var(--ease)}.proj-card:hover{box-shadow:var(--shadow-lg),0 0 0 1px var(--glass-border-h),0 0 30px color-mix(in srgb,var(--proj-accent, #22d3ee) 12%,transparent)}.proj-card__img-wrap{position:relative;height:220px;overflow:hidden}.proj-card__img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .55s var(--ease),filter .4s;filter:saturate(.82) brightness(.88)}.proj-card:hover .proj-card__img{transform:scale(1.07);filter:saturate(1) brightness(1)}.proj-card__img-shade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(5,11,24,.15) 0%,transparent 35%,rgba(5,11,24,.7) 100%);pointer-events:none}.proj-card__img-top{position:absolute;top:.85rem;left:.85rem;right:.85rem;display:flex;align-items:center;justify-content:space-between;z-index:2}.proj-type-badge{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-mono);font-size:.62rem;font-weight:500;letter-spacing:.08em;padding:.25rem .75rem;border-radius:var(--r-pill);border:1px solid;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.proj-card__year{font-family:var(--font-mono);font-size:.62rem;color:#ffffff8c;letter-spacing:.1em}.proj-card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#050b18d1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .28s var(--ease);z-index:3}.proj-card:hover .proj-card__overlay{opacity:1}.proj-card__overlay-btns{display:flex;gap:.65rem;flex-wrap:wrap;justify-content:center;padding:0 1rem}.proj-overlay-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:var(--r-sm);font-family:var(--font-display);font-size:.82rem;font-weight:600;text-decoration:none;transition:all .2s var(--ease);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);color:#fff;background:#ffffff1f}.proj-overlay-btn:hover{background:#ffffff38;transform:translateY(-2px)}.proj-overlay-btn--android{border-color:#3ddc8466;color:#3ddc84;background:#3ddc841a}.proj-overlay-btn--android:hover{background:#3ddc8433}.proj-overlay-btn--apple{border-color:#ffffff59;color:#f0f0f0;background:#6464642e}.proj-overlay-btn--apple:hover{background:#6464644d}.proj-card__num{position:absolute;bottom:.7rem;right:.9rem;font-family:var(--font-mono);font-size:2.8rem;font-weight:900;line-height:1;color:#ffffff12;pointer-events:none;letter-spacing:-.04em;z-index:1}.proj-card__body{padding:1.35rem;display:flex;flex-direction:column;gap:.75rem;flex:1}.proj-card__title-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.proj-card__name{font-size:1.08rem;font-weight:800;color:var(--text-primary);letter-spacing:-.01em}.proj-card__devices{display:flex;gap:.35rem;flex-shrink:0}.proj-device{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--r-sm);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text-muted);transition:all var(--t-fast)}.proj-device--web{color:var(--accent);border-color:#22d3ee4d;background:#22d3ee12}.proj-device--mobile{color:#a78bfa;border-color:#a78bfa4d;background:#a78bfa12}.proj-card__desc{font-size:.83rem;color:var(--text-secondary);line-height:1.72;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.proj-card__tech{display:flex;flex-wrap:wrap;gap:.4rem}.proj-card__links{margin-top:auto;padding-top:.5rem;border-top:1px solid var(--glass-border)}.proj-link-btn{display:inline-flex;align-items:center;gap:.45rem;padding:.52rem 1.05rem;border-radius:var(--r-sm);font-family:var(--font-display);font-size:.82rem;font-weight:600;text-decoration:none;transition:all .22s var(--ease);white-space:nowrap;cursor:pointer}.proj-link-btn svg:last-child{opacity:.5;transition:transform .2s,opacity .2s}.proj-link-btn:hover svg:last-child{transform:translate(3px);opacity:1}.proj-link-btn--primary{background:var(--accent);color:var(--text-on-accent);box-shadow:0 3px 14px var(--accent-glow)}.proj-link-btn--primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 22px var(--accent-glow)}.proj-link-btn--android{background:#3ddc841f;color:#3ddc84;border:1px solid rgba(61,220,132,.3)}.proj-link-btn--android:hover{background:#3ddc8438;transform:translateY(-2px);box-shadow:0 4px 16px #3ddc842e}.proj-link-btn--apple{background:#c8c8c81a;color:var(--text-primary);border:1px solid rgba(200,200,200,.2)}.proj-link-btn--apple:hover{background:#c8c8c82e;transform:translateY(-2px);box-shadow:0 4px 16px #c8c8c81a}.proj-link-btn--ghost{background:var(--glass-bg);color:var(--accent);border:1px solid var(--glass-border-h)}.proj-link-btn--ghost:hover{background:var(--accent-glow);transform:translateY(-2px)}.proj-card__store-row,.proj-card__app-row{display:flex;gap:.5rem;flex-wrap:wrap}.proj-card__both-links{display:flex;flex-direction:column;gap:.5rem}.proj-card__both-links .proj-link-btn--primary{width:100%;justify-content:center}.proj-card__app-row{display:flex;gap:.5rem}.proj-card__app-row .proj-link-btn{flex:1;justify-content:center}.proj-card__accent-line{height:2.5px;background:linear-gradient(90deg,var(--proj-accent, #22d3ee),color-mix(in srgb,var(--proj-accent, #22d3ee) 30%,transparent));opacity:0;transition:opacity .28s}.proj-card:hover .proj-card__accent-line{opacity:1}@media (max-width: 860px){.proj__grid{grid-template-columns:1fr}.proj__filters{width:100%;justify-content:flex-start}}@media (max-width: 480px){.proj__filter-btn{padding:.5rem .75rem;font-size:.8rem}.proj-card__app-row{flex-direction:column}}.skills-sec{position:relative;overflow:hidden}.skills__glow{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 65%);pointer-events:none;opacity:.5;filter:blur(40px)}.skills__filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:2rem;margin-bottom:2.25rem}.skills__filter{position:relative;overflow:hidden;padding:.5rem 1.1rem;border-radius:var(--r-pill)!important;font-size:.82rem;font-weight:600;cursor:pointer;color:var(--text-secondary);background:var(--glass-bg)!important;border:none;z-index:0;transition:color var(--t-fast)}.skills__filter--active{color:var(--text-primary)}.skills__filter-bg{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--r-pill);background:var(--accent-glow);border:1px solid var(--glass-border-h);z-index:-1}.skills__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.sk-card{padding:1.25rem;position:relative;overflow:hidden;cursor:default;display:flex;flex-direction:column;gap:.6rem;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}.sk-card__glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;z-index:0}.sk-card>*{position:relative;z-index:1}.sk-card__top{display:flex;align-items:center;justify-content:space-between}.sk-card__icon-wrap{width:38px;height:38px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;border:1px solid;font-size:1.1rem;flex-shrink:0}.sk-card__icon{line-height:1}.sk-card__level{font-family:var(--font-mono);font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;opacity:.9}.sk-card__name{font-size:.92rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.sk-card__desc{font-size:.75rem;color:var(--text-secondary);line-height:1.4}.sk-card__bar-wrap{display:flex;align-items:center;gap:.5rem;margin-top:auto;padding-top:.35rem}.sk-card__bar-track{flex:1;height:4px;border-radius:var(--r-pill);background:var(--glass-border);overflow:hidden}.sk-card__bar-fill{height:100%;border-radius:var(--r-pill);box-shadow:0 0 6px currentColor}.sk-card__pct{font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted);min-width:28px;text-align:right}@media (max-width:600px){.skills__grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}.exp-section{position:relative;overflow:hidden}.exp__blob{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);opacity:.55}.exp__blob--1{width:520px;height:520px;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);top:-60px;left:-140px}.exp__blob--2{width:420px;height:420px;background:radial-gradient(circle,var(--accent-2-glow) 0%,transparent 70%);bottom:0;right:-100px}.exp__timeline{display:flex;flex-direction:column;gap:1.5rem}.exp__company{padding:0;overflow:hidden}.exp__company-head{display:flex;align-items:flex-start;gap:1.1rem;padding:1.5rem 1.75rem;border-bottom:1px solid var(--glass-border);background:var(--glass-bg-2)}.exp__logo{width:50px;height:50px;border-radius:var(--r-sm);background:color-mix(in srgb,var(--logo-color) 18%,transparent);border:1.5px solid color-mix(in srgb,var(--logo-color) 35%,transparent);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.78rem;font-weight:600;color:var(--logo-color);flex-shrink:0;letter-spacing:.05em;box-shadow:0 0 16px color-mix(in srgb,var(--logo-color) 20%,transparent)}.exp__company-info{flex:1;min-width:0}.exp__company-top{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;margin-bottom:.4rem}.exp__company-name{font-size:1.05rem;font-weight:800;color:var(--text-primary);letter-spacing:-.01em}.exp__type-badge{font-family:var(--font-mono);font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .65rem;border-radius:var(--r-pill);background:var(--accent-glow);color:var(--accent);border:1px solid rgba(34,211,238,.25)}.exp__company-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.exp__meta-item{display:flex;align-items:center;gap:.3rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary)}.exp__meta-dot{color:var(--text-muted);font-size:.8rem}.exp__roles{display:flex;flex-direction:column}.exp__role{border-bottom:1px solid var(--glass-border);transition:background var(--t-fast)}.exp__role:last-child{border-bottom:none}.exp__role--open{background:color-mix(in srgb,var(--accent) 3%,transparent)}.exp__role-header{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem 1.75rem;background:none;border:none;cursor:pointer;text-align:left;color:var(--text-secondary);transition:background var(--t-fast),color var(--t-fast)}.exp__role-header:hover{background:var(--glass-bg-2);color:var(--text-primary)}.exp__role-left{display:flex;align-items:flex-start;gap:1rem}.exp__role-dot{width:10px;height:10px;border-radius:50%;margin-top:5px;flex-shrink:0}.exp__role-title-row{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin-bottom:.3rem}.exp__role-title{font-size:.95rem;font-weight:700;color:var(--text-primary)}.exp__badge{font-family:var(--font-mono);font-size:.6rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.18rem .55rem;border-radius:var(--r-pill);border:1px solid}.exp__badge--remote{color:#10b981;background:#10b9811a;border-color:#10b98140}.exp__badge--onsite{color:var(--accent-2);background:var(--accent-2-glow);border-color:#818cf84d}.exp__role-period{font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary)}.exp__role-duration{color:var(--text-muted);margin-left:.15rem}.exp__role-body{overflow:hidden}.exp__role-body-inner{padding:0 1.75rem 1.4rem 3.75rem;display:flex;flex-direction:column;gap:.9rem}.exp__role-location{display:flex;align-items:center;gap:.35rem;font-family:var(--font-mono);font-size:.72rem;color:var(--text-secondary)}.exp__role-tech{display:flex;flex-wrap:wrap;gap:.45rem}.exp__highlights{list-style:none;display:flex;flex-direction:column;gap:.55rem}.exp__highlight{display:flex;align-items:flex-start;gap:.7rem;font-size:.875rem;color:var(--text-secondary);line-height:1.6}.exp__highlight-dot{width:5px;height:5px;border-radius:50%;margin-top:8px;flex-shrink:0;opacity:.8}.exp__stats{display:flex;align-items:center;justify-content:space-around;padding:1.5rem 2rem;margin-top:2rem;flex-wrap:wrap;gap:1rem}.exp__stat{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex:1;min-width:100px}.exp__stat-val{font-size:1.9rem;font-weight:900;color:var(--accent);line-height:1;letter-spacing:-.02em}.exp__stat-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text-secondary)}.exp__stat+.exp__stat{border-left:1px solid var(--glass-border)}@media (max-width: 640px){.exp__company-head{padding:1.2rem}.exp__role-header{padding:1rem 1.2rem}.exp__role-body-inner{padding:0 1.2rem 1.2rem 2.8rem}.exp__stat+.exp__stat{border-left:none;border-top:1px solid var(--glass-border)}.exp__stats{flex-direction:column}}.edu{position:relative;overflow:hidden}.edu__blob{position:absolute;bottom:-120px;left:-150px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);pointer-events:none;filter:blur(60px)}.edu__tabs{display:inline-flex;gap:.25rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-md);padding:.3rem;margin-top:2rem;margin-bottom:2.5rem;position:relative}.edu__tab{position:relative;padding:.6rem 1.5rem;background:none;border:none;cursor:pointer;font-family:var(--font-display);font-size:.88rem;font-weight:600;color:var(--text-secondary);border-radius:var(--r-sm);transition:color var(--t-fast);z-index:1}.edu__tab--active{color:var(--text-primary)}.edu__tab-bar{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--r-sm);background:var(--glass-bg-2);border:1px solid var(--glass-border-h);z-index:-1}.edu__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.25rem}.edu__card{padding:2rem;position:relative;overflow:hidden;cursor:default;transition:transform .28s var(--ease),box-shadow .28s var(--ease)}.edu__card-num{font-family:var(--font-mono);font-size:3rem;font-weight:900;color:var(--glass-border-h);line-height:1;position:absolute;top:1rem;right:1.25rem;letter-spacing:-.04em;pointer-events:none}.edu__card-body{position:relative;z-index:1}.edu__card-year{display:inline-block;font-family:var(--font-mono);font-size:.7rem;color:var(--accent);letter-spacing:.15em;text-transform:uppercase;border:1px solid rgba(34,211,238,.25);border-radius:var(--r-pill);padding:.2rem .7rem;margin-bottom:.85rem}.edu__card-title{font-size:1.1rem;font-weight:800;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:.65rem}.edu__card-desc{font-size:.83rem;color:var(--text-secondary);line-height:1.7}.edu__card-glow{position:absolute;bottom:-40px;right:-40px;width:120px;height:120px;border-radius:50%;background:var(--accent-glow);filter:blur(30px);pointer-events:none;opacity:0;transition:opacity .4s}.edu__card:hover .edu__card-glow{opacity:1}.edu__course-list{display:flex;flex-direction:column;gap:0}.edu__course{display:flex;gap:1.25rem;padding:1.5rem;border-radius:0!important;border-left:0!important;border-right:0!important;border-top:0!important;border-bottom:1px solid var(--glass-border)!important;background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;transition:background var(--t-fast)}.edu__course:first-child{border-radius:var(--r-md) var(--r-md) 0 0!important;border-top:1px solid var(--glass-border)!important;border-left:1px solid var(--glass-border)!important;border-right:1px solid var(--glass-border)!important}.edu__course:last-child{border-radius:0 0 var(--r-md) var(--r-md)!important;border-bottom:1px solid var(--glass-border)!important;border-left:1px solid var(--glass-border)!important;border-right:1px solid var(--glass-border)!important}.edu__course{background:var(--glass-bg)!important;-webkit-backdrop-filter:blur(var(--glass-blur))!important;backdrop-filter:blur(var(--glass-blur))!important}.edu__course:hover{background:var(--glass-bg-2)!important}.edu__course-left{display:flex;flex-direction:column;align-items:center;gap:0;width:40px;flex-shrink:0}.edu__course-icon{width:40px;height:40px;border-radius:var(--r-sm);background:var(--accent-glow);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.edu__course-line{flex:1;width:2px;background:var(--glass-border);margin-top:4px;min-height:20px}.edu__course:last-child .edu__course-line{display:none}.edu__course-body{flex:1;min-width:0}.edu__course-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.6rem;flex-wrap:wrap}.edu__course-year{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.3rem;display:block}.edu__course-title{font-size:1rem;font-weight:700;color:var(--text-primary)}.edu__cert-btn{padding:.4rem .9rem;font-size:.78rem;white-space:nowrap;flex-shrink:0}.edu__course-desc{font-size:.83rem;color:var(--text-secondary);line-height:1.7}.about{position:relative;overflow:hidden}.about__blob{position:absolute;top:-120px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,var(--accent-2-glow) 0%,transparent 70%);pointer-events:none}.about__grid{display:grid;grid-template-columns:420px 1fr;gap:5rem;align-items:center}.about__portrait{position:relative;width:360px;height:430px;flex-shrink:0}.about__img-frame{width:100%;height:100%;border-radius:var(--r-lg)!important;overflow:hidden;padding:0;position:relative;transition:border-color .35s,box-shadow .35s}.about__img-frame:hover{border-color:#22d3ee73!important;box-shadow:0 0 40px #22d3ee2e,var(--shadow-lg)!important}.about__img,.about__hover-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.about__img-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 55%,rgba(5,11,24,.72) 100%);pointer-events:none;z-index:2}.about__hint{position:absolute;top:2px;left:2px;transform:translate(-50%);display:flex;align-items:center;gap:.45rem;font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:#ffffffeb;white-space:nowrap;background:#050b1899;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.38rem 1rem;border-radius:var(--r-pill);border:1px solid rgba(255,255,255,.14);z-index:3;pointer-events:none;-webkit-transform:translateX(-50%);-moz-transform:translateX(-50%);-ms-transform:translateX(-50%);-o-transform:translateX(-50%)}.about__ring{position:absolute;border-radius:var(--r-lg);border:1.5px solid var(--glass-border);pointer-events:none}.about__ring--1{top:-10px;right:-10px;bottom:-10px;left:-10px}.about__ring--2{top:-20px;right:-20px;bottom:-20px;left:-20px;opacity:.4}.about__badge{position:absolute;bottom:-18px;right:-22px;padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.2rem;min-width:130px;border-radius:var(--r-md)!important;z-index:5}.about__badge-val{font-size:1.9rem;font-weight:900;color:var(--accent);line-height:1;letter-spacing:-.02em}.about__badge-lbl{font-family:var(--font-mono);font-size:.68rem;color:var(--text-secondary);line-height:1.4;text-transform:uppercase;letter-spacing:.06em}.about__body{display:flex;flex-direction:column;gap:1.25rem}.about__desc{font-size:.96rem;color:var(--text-secondary);line-height:1.8}.about__info{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0;overflow:hidden;border-radius:var(--r-md)!important}.about__info-row{display:flex;flex-direction:column;gap:.2rem;padding:.9rem 1.1rem;border-bottom:1px solid var(--glass-border);border-right:1px solid var(--glass-border);transition:background var(--t-fast)}.about__info-row:hover{background:var(--glass-bg-2)}.about__info-row:nth-child(2n){border-right:none}.about__info-row:nth-last-child(-n+2){border-bottom:none}.about__info-key{font-family:var(--font-mono);font-size:.65rem;color:var(--accent);letter-spacing:.14em;text-transform:uppercase}.about__info-val{font-size:.85rem;font-weight:600;color:var(--text-primary);word-break:break-all}.about__ctas{display:flex;gap:.85rem;flex-wrap:wrap}.video-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem}.video-lightbox__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#050b18e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.video-lightbox__box{position:relative;z-index:1;width:100%;max-width:900px;background:var(--glass-bg);border:1px solid var(--glass-border-h);border-radius:var(--r-lg);overflow:hidden;box-shadow:0 32px 80px #000000bf,0 0 60px #22d3ee1a}.video-lightbox__head{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;background:var(--glass-bg-2);border-bottom:1px solid var(--glass-border)}.video-lightbox__title{display:flex;align-items:center;gap:.6rem;font-family:var(--font-mono);font-size:.78rem;color:var(--text-secondary);letter-spacing:.06em}.video-lightbox__dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:dot-pulse 2s infinite}@keyframes dot-pulse{0%,to{opacity:1;box-shadow:0 0 10px var(--accent)}50%{opacity:.5;box-shadow:0 0 4px var(--accent)}}.video-lightbox__close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--r-sm);background:transparent!important;border:none;cursor:pointer;color:var(--text-secondary);transition:color var(--t-fast)}.video-lightbox__close:hover{color:var(--danger)}.video-lightbox__video-wrap{aspect-ratio:16 / 9;background:#000;width:100%}.video-lightbox__video{width:100%;height:100%;display:block;outline:none;border:none}@media (max-width: 1000px){.about__grid{grid-template-columns:1fr;gap:3.5rem}.about__portrait{margin:0 auto}}@media (max-width: 480px){.about__portrait{width:280px;height:340px}.about__info{grid-template-columns:1fr}.about__info-row{border-right:none}.about__info-row:nth-last-child(-n+2){border-bottom:1px solid var(--glass-border)}.about__info-row:last-child{border-bottom:none}}.hero{min-height:100vh;display:flex;align-items:center;padding-top:76px;position:relative;overflow:hidden}.hero__glow-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);opacity:.5}.hero__glow-orb--1{width:500px;height:500px;background:var(--accent-glow);top:-80px;left:-100px}.hero__glow-orb--2{width:400px;height:400px;background:var(--accent-2-glow);bottom:-60px;right:-80px}.hero__wrap{display:grid;grid-template-columns:1fr 300px;gap:3rem;align-items:center;position:relative;z-index:2;padding-top:2rem;padding-bottom:4rem}.hero__main{display:flex;flex-direction:column;gap:1.2rem}.hero__avail{width:-moz-fit-content;width:fit-content;font-size:.72rem!important;border-color:#22d3ee4d!important}.hero__avail-dot{width:7px;height:7px;border-radius:50%;background:#10b981;box-shadow:0 0 8px #10b981;animation:pulse-green 2s infinite}@keyframes pulse-green{0%,to{opacity:1;box-shadow:0 0 8px #10b981}50%{opacity:.5;box-shadow:0 0 3px #10b981}}.hero__intro{font-family:var(--font-mono);font-size:.95rem;color:var(--text-secondary);margin-bottom:-.4rem}.hero__name{font-size:clamp(3.2rem,8vw,6rem);font-weight:900;line-height:.95;letter-spacing:-.03em;color:var(--text-primary)}.hero__name-outline{-webkit-text-stroke:2px var(--accent);color:var(--accent)}.hero__role-wrap{font-family:var(--font-mono);font-size:1.05rem;color:var(--text-secondary);min-height:1.6em}.hero__role-slash{color:var(--accent)}.hero__role-type{color:var(--text-primary)}.hero__bio{font-size:1rem;color:var(--text-secondary);line-height:1.75;max-width:500px}.hero__ctas{display:flex;gap:.85rem;flex-wrap:wrap}.hero__socials{display:flex;gap:.6rem}.hero__social{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--r-sm);color:var(--text-secondary);font-size:1rem;text-decoration:none;transition:color var(--t-fast),border-color var(--t-fast)}.hero__social:hover{color:var(--accent)}.hero__stats-col{display:flex;flex-direction:column;gap:.9rem}.hero__stat{padding:1.1rem 1.4rem;display:flex;flex-direction:column;gap:.15rem;cursor:default}.hero__stat-val{font-size:2rem;font-weight:900;color:var(--accent);line-height:1;letter-spacing:-.02em}.hero__stat-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary)}.hero__code-card{padding:0;overflow:hidden}.hero__code-bar{display:flex;gap:5px;padding:.6rem .85rem;border-bottom:1px solid var(--glass-border);background:var(--glass-bg-2)}.hero__code-bar span{width:9px;height:9px;border-radius:50%}.hero__code-bar span:nth-child(1){background:#f43f5e}.hero__code-bar span:nth-child(2){background:#f59e0b}.hero__code-bar span:nth-child(3){background:#10b981}.hero__code-pre{font-family:var(--font-mono);font-size:.73rem;color:var(--text-secondary);padding:.85rem;line-height:1.75;margin:0;white-space:pre}.hero__scroll-cue{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);z-index:2}.hero__scroll-mouse{width:22px;height:34px;border-radius:12px;display:flex;align-items:flex-start;justify-content:center;padding-top:6px}.hero__scroll-dot{width:4px;height:6px;border-radius:2px;background:var(--accent);opacity:.6}@media (max-width: 900px){.hero__wrap{grid-template-columns:1fr}.hero__stats-col{flex-direction:row;flex-wrap:wrap}.hero__stat{flex:1;min-width:110px}.hero__code-card{display:none}}@media (max-width: 480px){.hero__name{font-size:2.8rem}}.login-root{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem;background:var(--bg-base);position:relative;overflow:hidden}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.login-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}.login-orb--1{width:500px;height:500px;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);top:-100px;left:-100px}.login-orb--2{width:400px;height:400px;background:radial-gradient(circle,var(--accent-2-glow) 0%,transparent 70%);bottom:-80px;right:-80px}.login-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--glass-border) 1px,transparent 1px),linear-gradient(90deg,var(--glass-border) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 100%);mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black 0%,transparent 100%);opacity:.4}.login-card{position:relative;z-index:1;width:100%;max-width:420px;padding:2.5rem;border-radius:var(--r-xl)!important;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-10px)}40%,80%{transform:translate(10px)}}.login-card--shake{animation:shake .45s ease}.login-icon{width:60px;height:60px;border-radius:var(--r-md);background:var(--accent-glow);border:1.5px solid rgba(34,211,238,.3);display:flex;align-items:center;justify-content:center;color:var(--accent);margin-bottom:.5rem}.login-brand{font-family:var(--font-mono);font-size:1rem;color:var(--text-primary);font-weight:600}.login-brand-lt{color:var(--accent)}.login-brand-sub{color:var(--text-muted);font-size:.8rem}.login-title{font-size:1.6rem;font-weight:900;color:var(--text-primary);letter-spacing:-.02em;margin-top:.25rem}.login-sub{font-size:.87rem;color:var(--text-secondary);line-height:1.6;margin-bottom:.5rem}.login-form{width:100%;display:flex;flex-direction:column;gap:.85rem}.login-field{display:flex;flex-direction:column;gap:.35rem;text-align:left}.login-label{font-family:var(--font-mono);font-size:.67rem;color:var(--text-secondary);letter-spacing:.12em;text-transform:uppercase}.login-input-wrap{position:relative}.login-input{width:100%;padding:.8rem 3rem .8rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text-primary);font-family:var(--font-display);font-size:.95rem;outline:none;transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.login-eye{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;transition:color .2s}.login-eye:hover{color:var(--accent)}.login-error{display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;border-radius:var(--r-sm);background:#f43f5e1a;border:1px solid rgba(244,63,94,.3);font-size:.82rem;color:#f43f5e;text-align:left}.login-btn{width:100%;justify-content:center;padding:.85rem;font-size:.95rem;gap:.6rem;margin-top:.25rem}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-spinner{width:18px;height:18px;border-radius:50%;border:2px solid rgba(5,11,24,.3);border-top-color:var(--text-on-accent);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-notice{display:flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);margin-top:.5rem}.dbl-root{display:flex;min-height:100vh;background:var(--bg-base);font-family:var(--font-display)}.dbl-sidebar{position:fixed;top:0;left:0;height:100vh;z-index:200;display:flex;flex-direction:column;border-radius:0!important;border-top:0!important;border-left:0!important;border-bottom:0!important;padding:0;overflow:hidden;min-width:64px;transition:width .3s}.dbl-sidebar__top{display:flex;align-items:center;justify-content:space-between;padding:1.1rem .9rem;border-bottom:1px solid var(--glass-border);min-height:62px;gap:.5rem}.dbl-sidebar__logo{font-family:var(--font-mono);font-size:.95rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.2rem;white-space:nowrap;overflow:hidden}.dbl-logo-lt{color:var(--accent)}.dbl-logo-sub{color:var(--text-muted);font-size:.72rem;margin-left:.3rem}.dbl-toggle-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:.3rem;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s,background .2s}.dbl-toggle-btn:hover{color:var(--accent);background:var(--glass-bg-2)}.dbl-sidebar__nav{flex:1;padding:.6rem .5rem;display:flex;flex-direction:column;gap:.1rem;overflow-y:auto}.dbl-nav-link{position:relative;display:flex;align-items:center;gap:.75rem;padding:.62rem .75rem;border-radius:var(--r-sm);color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;transition:color .2s,background .2s}.dbl-nav-link:hover{color:var(--text-primary);background:var(--glass-bg-2)}.dbl-nav-link--active{color:var(--accent)}.dbl-nav-link__icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center}.dbl-nav-link__label{flex:1}.dbl-nav-link__bar{position:absolute;left:0;top:20%;bottom:20%;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}.dbl-sidebar__bottom{padding:.6rem .5rem;border-top:1px solid var(--glass-border);display:flex;flex-direction:column;gap:.1rem}.dbl-bottom-btn{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;border-radius:var(--r-sm);background:none;border:none;cursor:pointer;font-family:var(--font-display);font-size:.84rem;font-weight:500;color:var(--text-secondary);text-decoration:none;white-space:nowrap;overflow:hidden;transition:color .2s,background .2s}.dbl-bottom-btn:hover{color:var(--text-primary);background:var(--glass-bg-2)}.dbl-bottom-btn--logout:hover{color:var(--danger)}.dbl-mobile-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#050b18b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300}.dbl-mobile-drawer{position:fixed;top:0;left:0;bottom:0;width:260px;z-index:301;display:flex;flex-direction:column;border-radius:0!important;border-top:0!important;border-left:0!important;border-bottom:0!important}.dbl-main{flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s}.dbl-topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:1rem;padding:.85rem 1.75rem;min-height:62px;border-radius:0!important;border-top:0!important;border-left:0!important;border-right:0!important}.dbl-hamburger{background:none;border:none;cursor:pointer;color:var(--text-secondary);display:none;align-items:center;justify-content:center;padding:.3rem;border-radius:var(--r-sm)}.dbl-topbar__breadcrumb{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.dbl-content{flex:1;padding:1.75rem;overflow-y:auto}.db-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.75rem;flex-wrap:wrap}.db-page-title{font-size:1.5rem;font-weight:900;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:.25rem}.db-page-sub{font-family:var(--font-mono);font-size:.72rem;color:var(--text-muted)}.db-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.db-stat{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.4rem;cursor:pointer;transition:transform .2s}.db-stat__icon{width:44px;height:44px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.db-stat__val{font-size:1.7rem;font-weight:900;color:var(--text-primary);line-height:1}.db-stat__label{font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}.db-stat__arrow{color:var(--text-muted);margin-left:auto}.db-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.db-panel{padding:1.25rem}.db-panel__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.db-panel__title{font-size:.9rem;font-weight:700;color:var(--text-primary)}.db-link{font-family:var(--font-mono);font-size:.72rem;color:var(--accent);text-decoration:none;background:none;border:none;cursor:pointer}.db-link:hover{opacity:.7}.db-panel__list{display:flex;flex-direction:column;gap:.55rem}.db-list-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--glass-border)}.db-list-row:last-child{border-bottom:none}.db-list-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.db-list-name{font-size:.85rem;font-weight:600;color:var(--text-primary);flex:1}.db-cat-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.65rem}.db-cat-label{font-family:var(--font-mono);font-size:.68rem;color:var(--text-secondary);width:72px;text-transform:capitalize;flex-shrink:0}.db-cat-bar{flex:1;height:5px;background:var(--glass-border);border-radius:var(--r-pill);overflow:hidden}.db-cat-bar div{height:100%;border-radius:var(--r-pill)}.db-cat-count{font-family:var(--font-mono);font-size:.68rem;color:var(--text-muted);width:18px;text-align:right}.db-quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}.db-quick-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.2rem;border:none;cursor:pointer;border-radius:var(--r-md)!important;transition:transform .2s,box-shadow .2s;text-align:center}.db-quick-btn:hover{box-shadow:var(--shadow-glow)}.db-quick-btn__icon{font-size:1.4rem}.db-quick-btn__label{font-size:.82rem;font-weight:600;color:var(--text-primary)}.db-table-wrap{overflow:hidden;border-radius:var(--r-md)!important}.db-table{width:100%;border-collapse:collapse}.db-table th{padding:.75rem 1rem;text-align:left;font-family:var(--font-mono);font-size:.62rem;color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--glass-border);background:var(--glass-bg-2)}.db-table td{padding:.85rem 1rem;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--glass-border);vertical-align:middle}.db-table tr:last-child td{border-bottom:none}.db-table tbody tr:hover td{background:var(--glass-bg-2)}.db-proj-cell{display:flex;align-items:center;gap:.75rem}.db-proj-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.db-proj-name{font-weight:700;color:var(--text-primary);font-size:.88rem}.db-proj-desc{font-size:.74rem;color:var(--text-muted);margin-top:1px}.db-mono{font-family:var(--font-mono);font-size:.78rem}.db-truncate{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block}.db-skill-group{margin-bottom:2rem}.db-skill-group__title{font-size:.9rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.db-skill-group__count{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);background:var(--accent-glow);border:1px solid rgba(34,211,238,.25);padding:.1rem .55rem;border-radius:var(--r-pill)}.db-skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(158px,1fr));gap:.85rem}.db-sk-card{padding:1.1rem;position:relative}.db-sk-card__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.db-sk-icon{width:38px;height:38px;border-radius:var(--r-sm);border:1px solid;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.db-sk-name{font-size:.88rem;font-weight:700;color:var(--text-primary);margin-bottom:.2rem}.db-sk-desc{font-size:.72rem;color:var(--text-muted);margin-bottom:.6rem}.db-sk-bar-wrap{display:flex;align-items:center;gap:.5rem}.db-sk-bar-track{flex:1;height:4px;border-radius:var(--r-pill);background:var(--glass-border);overflow:hidden}.db-sk-bar-fill{height:100%;border-radius:var(--r-pill)}.db-sk-pct{font-family:var(--font-mono);font-size:.62rem;min-width:26px;text-align:right}.db-exp-list{display:flex;flex-direction:column;gap:.75rem}.db-exp-card{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.4rem}.db-exp-logo{width:46px;height:46px;border-radius:var(--r-sm);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.78rem;font-weight:700;color:var(--logo-color);background:color-mix(in srgb,var(--logo-color) 15%,transparent);border:1.5px solid color-mix(in srgb,var(--logo-color) 30%,transparent)}.db-exp-info{flex:1;min-width:0}.db-exp-company{font-size:.95rem;font-weight:800;color:var(--text-primary);margin-bottom:.35rem}.db-exp-meta{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.db-edu-group{margin-bottom:2rem}.db-edu-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.85rem}.db-edu-card{padding:1.2rem;position:relative}.db-edu-kind{margin-bottom:.65rem;display:inline-flex;font-size:.62rem!important}.db-edu-year{font-family:var(--font-mono);font-size:.68rem;color:var(--accent);margin-bottom:.35rem}.db-edu-title{font-size:.92rem;font-weight:700;color:var(--text-primary);margin-bottom:.35rem}.db-edu-desc{font-size:.8rem;color:var(--text-secondary);line-height:1.6}.db-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#050b18cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;padding:1rem}[data-theme=light] .db-modal-backdrop{background:#0006}.db-modal{width:100%;max-width:520px;max-height:90vh;overflow-y:auto;border-radius:var(--r-lg)!important}.db-modal__head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid var(--glass-border);position:sticky;top:0;background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:1}.db-modal__title{font-size:.95rem;font-weight:800;color:var(--text-primary)}.db-modal__close{background:none;border:none;cursor:pointer;font-size:.95rem;color:var(--text-muted);padding:.25rem .5rem;border-radius:var(--r-sm);transition:all .2s}.db-modal__close:hover{color:var(--danger);background:#f43f5e1a}.db-modal__body{padding:1.5rem}.db-form{display:flex;flex-direction:column;gap:1rem}.db-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.db-field{display:flex;flex-direction:column;gap:.35rem}.db-field__label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-secondary);letter-spacing:.12em;text-transform:uppercase}.db-input{width:100%;padding:.65rem .9rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--r-sm);color:var(--text-primary);font-family:var(--font-display);font-size:.875rem;outline:none;resize:none;transition:border-color .2s,box-shadow .2s}.db-input::-moz-placeholder{color:var(--text-muted)}.db-input::placeholder{color:var(--text-muted)}.db-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.db-textarea{min-height:90px}.db-color-row{display:flex;align-items:center;gap:.75rem}.db-submit-btn{width:100%;justify-content:center;margin-top:.5rem}.db-del-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:.3rem;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:color .2s,background .2s}.db-del-btn:hover{color:var(--danger);background:#f43f5e1a}.db-del-btn--abs{position:absolute;top:.75rem;right:.75rem}.db-empty{padding:3rem;text-align:center;font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.db-empty-sm{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);padding:.75rem 0}@media (max-width: 1024px){.db-stats-grid{grid-template-columns:repeat(2,1fr)}.db-overview-grid{grid-template-columns:1fr}.db-quick-actions{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dbl-main{margin-left:0!important}.dbl-sidebar{display:none}.dbl-hamburger{display:flex}.dbl-content{padding:1rem}.dbl-topbar{padding:.75rem 1rem}.db-stats-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.db-stats-grid,.db-form-row{grid-template-columns:1fr}.db-quick-actions{grid-template-columns:1fr 1fr}}
