:root{--bg:#070a14;--bg-2:#0a0e1a;--surface:#ffffff0a;--surface-2:#ffffff0f;--border:#ffffff1a;--border-strong:#ffffff2e;--text:#eaf0ff;--text-dim:#a9b4cf;--text-faint:#6c7793;--green:#45f0a0;--cyan:#22d3ee;--violet:#3b82f6;--pink:#6366f1;--grad:linear-gradient(120deg, var(--cyan) 0%, var(--violet) 55%, var(--pink) 100%);--grad-soft:linear-gradient(120deg, color-mix(in srgb, var(--cyan) 18%, transparent), color-mix(in srgb, var(--violet) 18%, transparent));--ink-accent:var(--cyan);--glass-blur:14px;--radius:18px;--radius-sm:12px;--shadow:0 20px 60px -20px #0009;--maxw:1120px;--font-display:"Space Grotesk", system-ui, sans-serif;--font-body:"Inter", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace}[data-theme=ocean]{--cyan:#22d3ee;--violet:#3b82f6;--pink:#6366f1}[data-theme=cyber]{--cyan:#00e5ff;--violet:#7c5cff;--pink:#ff5cc8}[data-theme=matrix]{--cyan:#45f0a0;--violet:#14b8a6;--pink:#00e5ff}[data-theme=sunset]{--cyan:#ffd166;--violet:#ff8a3d;--pink:#ff5cc8}[data-mode=light]{--bg:#eef1f9;--bg-2:#e3e8f4;--surface:#ffffff9e;--surface-2:#ffffffd9;--border:#141e3c1f;--border-strong:#141e3c38;--text:#131a30;--text-dim:#41506e;--text-faint:#6b7488;--shadow:0 20px 50px -26px #141e3c47;--ink-accent:color-mix(in srgb, var(--violet) 70%, #0a0a18)}[data-mode=light] .gradient-text,[data-mode=light] .stat-num{background:linear-gradient(120deg, color-mix(in srgb, var(--cyan) 55%, #0a0a18), var(--violet) 55%, var(--pink));-webkit-background-clip:text;background-clip:text}[data-mode=light] .bg-wrap{background:radial-gradient(900px 600px at 80% -10%, color-mix(in srgb, var(--violet) 22%, transparent), transparent 60%), radial-gradient(800px 500px at 0% 20%, color-mix(in srgb, var(--cyan) 18%, transparent), transparent 55%), linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%)}[data-mode=light] .bg-grid{background-image:linear-gradient(#141e3c0d 1px,#0000 1px),linear-gradient(90deg,#141e3c0d 1px,#0000 1px)}[data-mode=light] .blob{opacity:.3}[data-mode=light] .navbar.scrolled{background:#ffffffb8}[data-mode=light] .nav-links{background:#ffffffeb}[data-mode=light] .admin-header{background:#ffffffc7}[data-mode=light] .btn-primary,[data-mode=light] .filter-chip.active,[data-mode=light] .lesson-done.is-done .check,[data-mode=light] .brand-mark,[data-mode=light] .stat-num{color:#07101a}[data-mode=light] ::selection{color:#07101a;background:#3b82f640}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.65;overflow-x:hidden}a{color:inherit;text-decoration:none}ul{list-style:none}img{max-width:100%;display:block}::selection{color:#fff;background:#7c5cff66}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}.section{padding:110px 0;position:relative}@media (max-width:700px){.section{padding:72px 0}}.bg-wrap{z-index:-2;background:radial-gradient(900px 600px at 80% -10%, color-mix(in srgb, var(--violet) 20%, transparent), transparent 60%), radial-gradient(800px 500px at 0% 20%, color-mix(in srgb, var(--cyan) 14%, transparent), transparent 55%), linear-gradient(180deg, var(--bg) 0%, var(--bg-2) 100%);transition:background .5s;position:fixed;inset:0;overflow:hidden}.bg-grid{background-image:linear-gradient(#ffffff0a 1px,#0000 1px),linear-gradient(90deg,#ffffff0a 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,#0000 75%);mask-image:radial-gradient(circle at 50% 30%,#000 0%,#0000 75%)}.blob{filter:blur(64px);opacity:.45;will-change:transform;border-radius:50%;position:absolute;transform:translateZ(0)}.blob-1{background:var(--cyan);width:420px;height:420px;animation:18s ease-in-out infinite float1;top:-80px;left:-60px}.blob-2{background:var(--violet);width:480px;height:480px;animation:22s ease-in-out infinite float2;bottom:-120px;right:-80px}.blob-3{background:var(--pink);opacity:.3;width:320px;height:320px;animation:26s ease-in-out infinite float3;top:45%;left:55%}@keyframes float1{0%,to{transform:translate(0)}50%{transform:translate(60px,80px)}}@keyframes float2{0%,to{transform:translate(0)}50%{transform:translate(-70px,-50px)}}@keyframes float3{0%,to{transform:translate(0)scale(1)}50%{transform:translate(-40px,40px)scale(1.15)}}.scroll-progress{transform-origin:0 0;will-change:transform;background:var(--grad);z-index:200;width:100%;height:3px;position:fixed;top:0;left:0;transform:scaleX(0);box-shadow:0 0 12px #00e5ff99}.glass{background:var(--surface);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.navbar{z-index:100;border-bottom:1px solid #0000;padding:18px 0;transition:background .3s,border-color .3s,padding .3s;position:fixed;top:0;left:0;right:0}.navbar.scrolled{-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#080b14a6;padding:12px 0}.nav-inner{justify-content:space-between;align-items:center;gap:20px;display:flex}.brand{font-family:var(--font-display);align-items:center;gap:12px;font-weight:700;display:flex}.brand-mark{background:var(--grad);color:#07101a;border-radius:11px;place-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:grid;box-shadow:0 6px 20px -6px #00e5ff80}.brand-name{letter-spacing:-.02em;font-size:18px}.brand-dot{color:var(--ink-accent)}.nav-links{gap:6px;display:flex}.nav-links a{color:var(--text-dim);border-radius:10px;padding:8px 14px;font-size:14.5px;font-weight:500;transition:color .2s,background .2s;position:relative}.nav-links a:hover{color:var(--text);background:var(--surface)}.nav-links a.active{color:var(--text)}.nav-links a.active:after{content:"";background:var(--grad);border-radius:2px;height:2px;position:absolute;bottom:2px;left:14px;right:14px}.nav-actions{align-items:center;gap:12px;display:flex}.lang-toggle{cursor:pointer;background:var(--surface);border:1px solid var(--border);font-family:var(--font-mono);color:var(--text-faint);border-radius:10px;align-items:center;gap:4px;padding:7px 12px;font-size:13px;font-weight:500;transition:border-color .2s;display:flex}.lang-toggle:hover{border-color:var(--border-strong)}.lang-opt{transition:color .2s}.lang-opt.active{color:var(--ink-accent)}.lang-sep{color:var(--text-faint)}.menu-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;gap:5px;padding:6px;display:none}.menu-btn span{background:var(--text);border-radius:2px;width:24px;height:2px;transition:all .3s}.menu-btn.open span:first-child{transform:translateY(7px)rotate(45deg)}.menu-btn.open span:nth-child(2){opacity:0}.menu-btn.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.btn{cursor:pointer;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:13px 24px;font-size:15px;font-weight:600;transition:transform .2s,box-shadow .2s,background .2s;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn-primary{background:var(--grad);color:#06101a;box-shadow:0 12px 30px -10px #00e5ff80}.btn-primary:hover{box-shadow:0 18px 40px -10px #7c5cff99}.btn-ghost{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-ghost:hover{border-color:var(--border-strong);background:var(--surface-2)}.hero{align-items:center;min-height:100vh;padding-top:80px;display:flex;position:relative}.hero-inner{flex-direction:column;align-items:flex-start;max-width:860px;display:flex}.hero-badge{color:var(--text-dim);border-radius:999px;align-items:center;gap:9px;margin-bottom:28px;padding:8px 16px;font-size:13.5px;font-weight:500;display:inline-flex}.status-dot{background:var(--green);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse;box-shadow:0 0 #45f0a0b3}@keyframes pulse{0%{box-shadow:0 0 #45f0a099}70%{box-shadow:0 0 0 8px #45f0a000}to{box-shadow:0 0 #45f0a000}}.hero-title{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:18px;font-size:clamp(2.4rem,6vw,4.6rem);font-weight:700;line-height:1.05}.hero-title span{display:block}.gradient-text{background:var(--grad);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text}.hero-role{font-family:var(--font-mono);color:var(--text);min-height:1.6em;margin-bottom:22px;font-size:clamp(1.1rem,2.6vw,1.6rem)}.role-prefix{color:var(--text-faint);margin-right:8px}.typed{color:var(--ink-accent);font-weight:500}.caret{color:var(--ink-accent);font-weight:300;animation:1s step-end infinite blink}@keyframes blink{0%,50%{opacity:1}50.01%,to{opacity:0}}.hero-desc{color:var(--text-dim);max-width:640px;margin-bottom:34px;font-size:1.1rem}.hero-cta{flex-wrap:wrap;gap:14px;margin-bottom:34px;display:flex}.hero-socials{gap:12px;display:flex}.social-link{background:var(--surface);border:1px solid var(--border);width:46px;height:46px;color:var(--text-dim);border-radius:12px;place-items:center;transition:color .2s,transform .2s,border-color .2s;display:grid}.social-link:hover{color:var(--ink-accent);border-color:var(--ink-accent);transform:translateY(-3px)}.scroll-hint{position:absolute;bottom:30px;left:50%;transform:translate(-50%)}.mouse{border:2px solid var(--text-faint);border-radius:14px;width:26px;height:42px;display:block;position:relative}.wheel{background:var(--cyan);border-radius:2px;width:4px;height:8px;animation:1.8s infinite wheel;position:absolute;top:8px;left:50%;transform:translate(-50%)}@keyframes wheel{0%{opacity:0;transform:translate(-50%)}30%{opacity:1}to{opacity:0;transform:translate(-50%,14px)}}.section-head{margin-bottom:52px}.section-kicker{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-accent);align-items:center;gap:8px;margin-bottom:14px;font-size:13px;display:inline-flex}.section-kicker.center{justify-content:center;display:flex}.kicker-num{color:var(--text-faint)}.section-title{font-family:var(--font-display);letter-spacing:-.02em;max-width:16ch;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;line-height:1.1}.section-title.center{text-align:center;max-width:none}.about-grid{grid-template-columns:1.4fr 1fr;align-items:start;gap:28px;display:grid}.about-text{padding:34px}.about-text p{color:var(--text-dim);margin-bottom:16px}.about-text p:last-child{margin-bottom:0}.about-text strong{color:var(--text)}.about-stats{grid-template-columns:1fr 1fr;gap:16px;display:grid}.stat-card{flex-direction:column;gap:6px;padding:24px 20px;transition:transform .25s,border-color .25s;display:flex}.stat-card:hover{border-color:var(--border-strong);transform:translateY(-4px)}.stat-num{font-family:var(--font-display);background:var(--grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.8rem,4vw,2.4rem);font-weight:700}.stat-label{color:var(--text-faint);font-size:13px;line-height:1.4}.skills-grid{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.skill-card{padding:26px;transition:transform .25s,border-color .25s}.skill-card:hover{border-color:var(--border-strong);transform:translateY(-5px)}.skill-icon{margin-bottom:12px;font-size:26px}.skill-card h3{font-family:var(--font-display);margin-bottom:16px;font-size:1.15rem}.tags{flex-wrap:wrap;gap:8px;display:flex}.tags span{font-size:12.5px;font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:5px 11px}.lang-bars{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(var(--glass-blur));margin-top:30px;padding:30px 34px}.lang-bars-title{font-family:var(--font-display);margin-bottom:20px;font-size:1.15rem}.bar-row{margin-bottom:16px}.bar-row:last-child{margin-bottom:0}.bar-label{color:var(--text-dim);margin-bottom:8px;font-size:14px;display:block}.bar{background:var(--surface-2);border-radius:6px;height:8px;overflow:hidden}.bar i{background:var(--grad);border-radius:6px;width:0;height:100%;transition:width 1.2s cubic-bezier(.2,.8,.2,1);display:block}.bar.animate i{width:var(--w)}.timeline{padding-left:34px;position:relative}.timeline:before{content:"";background:linear-gradient(var(--cyan), var(--violet), transparent);width:2px;position:absolute;top:8px;bottom:8px;left:7px}.tl-item{margin-bottom:26px;position:relative}.tl-item:last-child{margin-bottom:0}.tl-dot{background:var(--bg-2);border:3px solid var(--cyan);border-radius:50%;width:16px;height:16px;position:absolute;top:26px;left:-34px;box-shadow:0 0 0 4px #00e5ff1f}.tl-card{padding:26px 28px;transition:transform .25s,border-color .25s}.tl-card:hover{border-color:var(--border-strong);transform:translate(4px)}.tl-top{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:4px;display:flex}.tl-card h3{font-family:var(--font-display);font-size:1.2rem}.tl-date{font-family:var(--font-mono);color:var(--ink-accent);white-space:nowrap;font-size:12.5px}.tl-company{color:var(--text-faint);margin-bottom:14px;font-size:14px}.tl-card ul{flex-direction:column;gap:9px;display:flex}.tl-card li{color:var(--text-dim);padding-left:20px;font-size:14.5px;position:relative}.tl-card li:before{content:"▹";color:var(--ink-accent);position:absolute;left:0}.tl-card strong{color:var(--text)}.projects-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.project-card{flex-direction:column;padding:28px;transition:transform .25s,border-color .25s;display:flex}.project-card:hover{border-color:var(--border-strong);transform:translateY(-6px)}.project-head{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.project-icon{font-size:30px}.project-period{font-family:var(--font-mono);color:var(--text-faint);font-size:12px}.project-card h3{font-family:var(--font-display);margin-bottom:4px;font-size:1.2rem}.project-sub{color:var(--ink-accent);font-size:13.5px;font-family:var(--font-mono);margin-bottom:14px}.project-desc{color:var(--text-dim);flex:1;margin-bottom:18px;font-size:14.5px}.project-links{margin-top:16px}.project-links a{color:var(--ink-accent);font-size:14px;font-weight:600;transition:opacity .2s}.project-links a:hover{opacity:.75}.edu-grid{grid-template-columns:1fr 1fr;align-items:start;gap:28px;display:grid}.edu-col-title{font-family:var(--font-display);margin-bottom:18px;font-size:1.2rem}.edu-card{padding:24px 26px}.edu-card h4{font-family:var(--font-display);font-size:1.1rem}.cert-list{flex-direction:column;gap:14px;display:flex}.cert-card{align-items:center;gap:16px;padding:18px 20px;transition:transform .2s,border-color .2s;display:flex}.cert-card:hover{border-color:var(--border-strong);transform:translate(4px)}.cert-badge{background:var(--grad-soft);border:1px solid var(--border);width:46px;height:46px;font-family:var(--font-mono);color:var(--ink-accent);border-radius:12px;flex-shrink:0;place-items:center;font-size:14px;font-weight:700;display:grid}.cert-info h4{font-size:1rem;font-family:var(--font-display);font-weight:600}.cert-meta{color:var(--text-faint);font-size:12.5px;font-family:var(--font-mono)}.cert-progress .cert-badge{color:var(--green)}.contact-box{text-align:center;flex-direction:column;align-items:center;padding:56px 40px;display:flex}.contact-desc{color:var(--text-dim);max-width:560px;margin:6px auto 30px;font-size:1.05rem}.contact-actions{flex-wrap:wrap;justify-content:center;gap:14px;margin-bottom:28px;display:flex}.contact-form{text-align:left;flex-direction:column;gap:12px;width:100%;max-width:540px;margin:0 auto 26px;display:flex}.cf-row{gap:12px;display:flex}.contact-form input,.contact-form textarea{background:var(--surface-2);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font-body);border-radius:12px;outline:none;padding:13px 16px;font-size:15px;transition:border-color .2s}.contact-form input:focus,.contact-form textarea:focus{border-color:var(--ink-accent)}.contact-form textarea{resize:vertical}.contact-form .hp{opacity:0;width:1px;height:1px;position:absolute;left:-9999px}.contact-form .btn{align-self:center;min-width:200px}.cf-status{text-align:center;min-height:1.2em;margin:0;font-size:14px}.cf-status.ok{color:var(--green)}.cf-status.err{color:#ff7a7a}@media (max-width:540px){.cf-row{flex-direction:column}}.contact-meta{color:var(--text-faint);flex-wrap:wrap;justify-content:center;gap:24px;font-size:14px;display:flex}.footer{border-top:1px solid var(--border);padding:30px 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.footer-brand{font-family:var(--font-display);font-weight:600}.footer-copy{color:var(--text-faint);font-size:13.5px}.footer-top{color:var(--text-dim);font-size:14px;transition:color .2s}.footer-top:hover{color:var(--ink-accent)}[data-reveal]{opacity:0;transition:opacity .7s,transform .7s cubic-bezier(.2,.8,.2,1);transform:translateY(28px)}[data-reveal].in{opacity:1;transform:none}@media (max-width:920px){.skills-grid,.projects-grid{grid-template-columns:repeat(2,1fr)}.about-grid{grid-template-columns:1fr}}@media (max-width:760px){.nav-links{border-left:1px solid var(--border);z-index:110;background:#0a0e1a;flex-direction:column;align-items:stretch;gap:4px;width:min(82%,300px);height:100dvh;padding:88px 22px 40px;transition:transform .35s;position:fixed;inset:0 0 0 auto;overflow-y:auto;transform:translate(101%);box-shadow:-24px 0 60px #00000073}[data-mode=light] .nav-links{background:#f3f5fb}.navbar .nav-links.open{transform:translate(0)!important}.nav-links a{border-radius:10px;padding:13px 16px;font-size:16px}.menu-btn{z-index:115;display:flex;position:relative}.edu-grid{grid-template-columns:1fr}.about-stats{grid-template-columns:1fr 1fr}}@media (max-width:540px){.skills-grid,.projects-grid{grid-template-columns:1fr}.contact-box{padding:40px 22px}.contact-actions{flex-direction:column;width:100%}.contact-actions .btn{width:100%}.tl-card,.about-text{padding:22px}.brand-name{display:none}}.about-top{grid-template-columns:280px 1fr;align-items:stretch;gap:28px;margin-bottom:24px;display:grid}.photo-card{justify-content:center;align-items:center;padding:16px;display:flex}.photo-frame{aspect-ratio:1;background:var(--grad-soft);border:1px solid var(--border);border-radius:16px;width:100%;position:relative;overflow:hidden}.photo-frame img{object-fit:cover;width:100%;height:100%;display:block}.photo-fallback{font-family:var(--font-display);color:#06101a;background:var(--grad);justify-content:center;align-items:center;font-size:4rem;font-weight:700;display:flex;position:absolute;inset:0}.photo-ring{background:var(--grad);-webkit-mask-composite:xor;opacity:.6;pointer-events:none;border-radius:18px;padding:2px;position:absolute;inset:-2px;-webkit-mask-image:linear-gradient(#000 0 0),linear-gradient(#000 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.theme-fab{z-index:120;cursor:pointer;background:var(--grad);color:#06101a;border:none;border-radius:50%;place-items:center;width:52px;height:52px;font-size:22px;transition:transform .25s;display:grid;position:fixed;bottom:22px;right:22px;box-shadow:0 10px 30px -8px #0009}.theme-fab:hover{transform:rotate(25deg)scale(1.08)}.theme-panel{z-index:120;opacity:0;pointer-events:none;border-radius:16px;width:230px;padding:18px;transition:opacity .25s,transform .25s;position:fixed;bottom:86px;right:22px;transform:translateY(12px)scale(.96)}.theme-panel.open{opacity:1;pointer-events:auto;transform:none}.theme-panel h4{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);margin-bottom:12px;font-size:.82rem}.swatches{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.swatch{cursor:pointer;border:1px solid var(--border);background:var(--surface-2);border-radius:11px;flex-direction:column;align-items:flex-start;gap:7px;padding:9px;transition:border-color .2s,transform .2s;display:flex}.swatch:hover{border-color:var(--border-strong);transform:translateY(-2px)}.swatch.active{border-color:var(--text);box-shadow:0 0 0 1px var(--text) inset}.swatch-bar{border-radius:7px;width:100%;height:22px}.swatch-name{color:var(--text-dim);font-size:12px;font-family:var(--font-mono)}.mode-row{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:16px;padding-top:14px;display:flex}.mode-row>span{text-transform:uppercase;letter-spacing:.1em;color:var(--text-faint);font-size:12px;font-family:var(--font-display)}.mode-toggle{cursor:pointer;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;gap:4px;padding:4px;display:flex}.mode-opt{opacity:.45;border-radius:999px;place-items:center;width:30px;height:26px;font-size:14px;transition:opacity .2s,background .2s;display:grid}.mode-opt.active{opacity:1;background:var(--grad)}.sw-ocean{background:linear-gradient(120deg,#22d3ee,#3b82f6,#6366f1)}.sw-cyber{background:linear-gradient(120deg,#00e5ff,#7c5cff,#ff5cc8)}.sw-matrix{background:linear-gradient(120deg,#45f0a0,#14b8a6,#00e5ff)}.sw-sunset{background:linear-gradient(120deg,#ffd166,#ff8a3d,#ff5cc8)}.gallery-grid{columns:3;column-gap:16px}.gallery-item{break-inside:avoid;border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);background:var(--surface);margin-bottom:16px;transition:transform .25s,border-color .25s;position:relative;overflow:hidden}.gallery-item:hover{border-color:var(--border-strong);transform:translateY(-4px)}.gallery-item img,.gallery-item video{width:100%;display:block}.vid-badge{z-index:2;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;background:#05081099;border-radius:50%;place-items:center;width:48px;height:48px;padding-left:3px;font-size:18px;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.lightbox video{border:1px solid var(--border-strong);background:#000;border-radius:14px;max-width:92vw;max-height:82vh}.gallery-item .ph{aspect-ratio:4/3;background:var(--grad-soft);place-items:center;font-size:2.4rem;display:grid}.gallery-cap{color:#fff;opacity:0;background:linear-gradient(#0000,#050810d9);padding:28px 16px 14px;font-size:13.5px;transition:opacity .25s;position:absolute;inset:auto 0 0}.gallery-item:hover .gallery-cap{opacity:1}.gallery-cap .g-loc{font-family:var(--font-mono);color:var(--ink-accent);margin-top:2px;font-size:11.5px;display:block}.empty-note{color:var(--text-faint);text-align:center;padding:22px;font-size:14.5px}.lightbox{z-index:200;-webkit-backdrop-filter:blur(8px);background:#04060ce0;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.lightbox.open{display:flex}.lightbox img{border:1px solid var(--border-strong);border-radius:14px;max-width:92vw;max-height:82vh}.lightbox-cap{text-align:center;color:var(--text-dim);font-size:14px;position:absolute;bottom:26px;left:0;right:0}.lightbox-close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:30px;line-height:1;position:absolute;top:22px;right:26px}.blog-list{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.blog-card{flex-direction:column;padding:0;transition:transform .25s,border-color .25s;display:flex;overflow:hidden}.blog-card:hover{border-color:var(--border-strong);transform:translateY(-5px)}.blog-media{aspect-ratio:16/9;background:var(--grad-soft);width:100%;position:relative;overflow:hidden}.blog-media img,.blog-media video,.blog-media iframe{object-fit:cover;border:0;width:100%;height:100%;display:block}.blog-media .ph{place-items:center;width:100%;height:100%;font-size:2.6rem;display:grid}.blog-type-tag{font-family:var(--font-mono);color:var(--cyan);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border);background:#050810b3;border-radius:7px;padding:4px 10px;font-size:11px;position:absolute;top:12px;left:12px}.blog-body{flex-direction:column;flex:1;padding:22px 24px 24px;display:flex}.blog-meta{font-family:var(--font-mono);color:var(--text-faint);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:10px;font-size:12px;display:flex}.blog-meta .b-loc{color:var(--ink-accent)}.blog-card h3{font-family:var(--font-display);margin-bottom:8px;font-size:1.2rem}.blog-card p{color:var(--text-dim);font-size:14.5px}.blog-card.text-only .blog-body{padding-top:24px}@media (max-width:920px){.gallery-grid{columns:2}.blog-list{grid-template-columns:1fr}.about-top{grid-template-columns:220px 1fr}}@media (max-width:620px){.gallery-grid{columns:1}.about-top{grid-template-columns:1fr}.photo-card{width:100%;max-width:260px;margin:0 auto}.theme-fab{bottom:16px;right:16px}.theme-panel{bottom:80px;right:16px}}.filter-bar{flex-wrap:wrap;gap:10px;margin-bottom:26px;display:flex}.filter-chip{cursor:pointer;font-family:var(--font-mono);background:var(--surface);border:1px solid var(--border);color:var(--text-dim);border-radius:999px;padding:8px 16px;font-size:13px;transition:color .2s,border-color .2s,background .2s,transform .2s}.filter-chip:hover{color:var(--text);border-color:var(--border-strong);transform:translateY(-2px)}.filter-chip.active{color:#06101a;background:var(--grad);border-color:#0000;font-weight:600}.blog-readmore{cursor:pointer;color:var(--ink-accent);font-family:var(--font-body);background:0 0;border:none;align-self:flex-start;margin-top:14px;padding:0;font-size:14px;font-weight:600;transition:opacity .2s}.blog-readmore:hover{opacity:.7}.post-modal{z-index:210;-webkit-backdrop-filter:blur(8px);background:#04060cd9;justify-content:center;align-items:flex-start;padding:40px 20px;display:none;position:fixed;inset:0;overflow-y:auto}.post-modal.open{display:flex}.post-modal-inner{border-radius:var(--radius);width:100%;max-width:760px;animation:.35s cubic-bezier(.2,.8,.2,1) popin;position:relative;overflow:hidden}@keyframes popin{0%{opacity:0;transform:translateY(20px)scale(.98)}to{opacity:1;transform:none}}.post-close{z-index:3;border:1px solid var(--border);color:#fff;cursor:pointer;background:#05081099;border-radius:50%;width:38px;height:38px;font-size:24px;line-height:1;position:absolute;top:14px;right:16px}.post-close:hover{background:#050810e6}.post-media{background:var(--grad-soft);width:100%;max-height:420px;overflow:hidden}.post-media img,.post-media video{object-fit:cover;width:100%;max-height:420px;display:block}.post-media-video{aspect-ratio:16/9;max-height:none}.post-media-video iframe{border:0;width:100%;height:100%;display:block}.post-text{padding:30px 34px 36px}.post-text h2{font-family:var(--font-display);margin:6px 0 16px;font-size:1.7rem;line-height:1.15}.post-text p{color:var(--text-dim);margin-bottom:14px;font-size:1.02rem}.lx-hero{min-height:auto;padding-top:150px;padding-bottom:40px}.lesson-search{background:var(--surface);border:1px solid var(--border);color:var(--text-faint);border-radius:12px;align-items:center;gap:10px;margin-bottom:18px;padding:12px 18px;transition:border-color .2s;display:flex}.lesson-search:focus-within{border-color:var(--ink-accent);color:var(--ink-accent)}.lesson-search input{color:var(--text);font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;font-size:15px}.lesson-search input::placeholder{color:var(--text-faint)}.lessons-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.lesson-card{flex-direction:column;padding:26px 28px;transition:transform .25s,border-color .25s;display:flex}.lesson-card:hover{border-color:var(--border-strong);transform:translateY(-4px)}.lesson-meta{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.lesson-date{font-family:var(--font-mono);color:var(--text-faint);font-size:12px}.lesson-cat{font-family:var(--font-mono);background:var(--grad-soft);border:1px solid var(--border);color:var(--ink-accent);border-radius:7px;padding:4px 10px;font-size:11.5px}.lesson-card h3{font-family:var(--font-display);margin-bottom:10px;font-size:1.25rem}.lesson-body{color:var(--text-dim);flex:1;font-size:14.5px}.lesson-body p{margin-bottom:10px}.lesson-body code,.post-text code{font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);color:var(--ink-accent);border-radius:6px;padding:2px 6px;font-size:.88em}.lesson-cmds{flex-wrap:wrap;align-items:center;gap:8px;margin-top:16px;display:flex}.lesson-cmds-label{color:var(--text-faint);width:100%;margin-bottom:2px;font-size:12px}.cmd-chip{cursor:pointer;font-family:var(--font-mono);background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:6px 12px;font-size:12.5px;transition:color .2s,border-color .2s,transform .2s}.cmd-chip:before{content:"$ ";color:var(--ink-accent)}.cmd-chip:hover{color:var(--text);border-color:var(--ink-accent);transform:translateY(-2px)}.term-window{padding:0;overflow:hidden}.term-bar{border-bottom:1px solid var(--border);background:#ffffff0a;align-items:center;gap:8px;padding:12px 16px;display:flex}.term-dot{border-radius:50%;width:12px;height:12px}.d-red{background:#ff5f57}.d-yellow{background:#febc2e}.d-green{background:#28c840}.term-bar-title{font-family:var(--font-mono);color:var(--text-faint);margin-left:10px;font-size:12.5px}.term{cursor:text;height:440px;font-family:var(--font-mono);color:#d8e0f0;background:#03060c8c;padding:18px 20px;font-size:13.5px;line-height:1.6;overflow-y:auto}.term::-webkit-scrollbar{width:9px}.term::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:6px}.term-line{white-space:pre-wrap;word-break:break-word}.term-inputline{align-items:baseline;gap:8px;display:flex}.term-prompt{color:var(--green);white-space:nowrap}.term-input{caret-color:var(--cyan);font-family:var(--font-mono);color:#eaf0ff;background:0 0;border:none;outline:none;flex:1;padding:0;font-size:13.5px}.term-cmd{color:var(--cyan)}.term-dir{color:#6ea8ff;font-weight:600}.term-file{color:#d8e0f0}.term-err{color:#ff7a7a}.term-match{color:#ffe7a6;background:#ffd16647;border-radius:3px}.term-dim{color:var(--text-faint)}.term-logo{color:var(--cyan)}.nano-overlay{z-index:240;-webkit-backdrop-filter:blur(6px);background:#04060ccc;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.nano-overlay.open{display:flex}.nano-win{border:1px solid var(--border-strong);width:100%;max-width:760px;height:min(75vh,560px);box-shadow:var(--shadow);font-family:var(--font-mono);background:#0b0f1a;border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.nano-top{color:#1a1a1a;text-align:center;background:#e8e8e8;padding:7px 14px;font-size:13px;font-weight:600}.nano-area{resize:none;color:#e8ecf6;width:100%;font-family:var(--font-mono);background:#0b0f1a;border:none;outline:none;flex:1;padding:16px 18px;font-size:13.5px;line-height:1.6}.nano-bottom{color:#1a1a1a;background:#e8e8e8;justify-content:center;gap:22px;padding:7px 14px;font-size:12px;display:flex}.nano-bottom b{color:#000}.term-hints{flex-wrap:wrap;align-items:center;gap:8px;margin-top:18px;display:flex}.term-hints-label{color:var(--text-faint);margin-right:4px;font-size:13px}.term-note{color:var(--text-faint);margin-top:14px;font-size:13px}@media (max-width:760px){.lessons-grid{grid-template-columns:1fr}.term{height:360px;font-size:12.5px}.post-text{padding:24px 22px 28px}}.books-grid{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.book-card{align-items:flex-start;gap:18px;padding:22px;transition:transform .25s,border-color .25s;display:flex;position:relative}.book-card:hover{border-color:var(--border-strong);transform:translateY(-4px)}.book-cover{background:var(--grad-soft);border:1px solid var(--border);border-radius:10px;flex-shrink:0;width:92px;height:124px;overflow:hidden}.book-cover img{object-fit:cover;width:100%;height:100%;display:block}.book-emoji{place-items:center;width:100%;height:100%;font-size:2.6rem;display:grid}.book-info{flex:1;min-width:0}.book-info h3{font-family:var(--font-display);margin-bottom:3px;font-size:1.15rem}.book-author{color:var(--ink-accent);font-size:13px;font-family:var(--font-mono);margin-bottom:10px}.book-desc{color:var(--text-dim);margin-bottom:16px;font-size:14px}.book-actions{flex-wrap:wrap;gap:10px;display:flex}.book-nofile{color:var(--text-faint);font-size:12.5px}.blog-card,.lesson-card{position:relative}.pin-badge{z-index:3;filter:drop-shadow(0 2px 4px #00000080);font-size:14px;position:absolute;top:10px;right:12px}.gallery-item .pin-badge,.blog-card .pin-badge{top:10px;left:12px;right:auto}.reader-modal{z-index:230;-webkit-backdrop-filter:blur(8px);background:#04060ce6;justify-content:center;align-items:center;padding:24px;display:none;position:fixed;inset:0}.reader-modal.open{display:flex}.reader-inner{flex-direction:column;width:100%;max-width:960px;height:90vh;padding:0;display:flex;overflow:hidden}.reader-bar{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:14px;padding:12px 16px;display:flex}.reader-title{font-family:var(--font-display);text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:600;overflow:hidden}.reader-actions{flex-shrink:0;align-items:center;gap:12px;display:flex}.reader-close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:26px;line-height:1}.reader-inner iframe{background:#2a2a2a;border:0;flex:1;width:100%}@media (max-width:760px){.books-grid{grid-template-columns:1fr}.reader-inner{height:88vh}}.stat-card,.skill-card,.tl-card,.project-card,.cert-card,.blog-card,.lesson-card,.gallery-item,.photo-card,.cmd-chip,.filter-chip,.lesson-search,.term-window,.book-card{-webkit-backdrop-filter:none}.glass{transform:translateZ(0)}html,body{max-width:100%}.tags span,.cmd-chip,.lesson-body code,.post-text code,.project-sub,.cert-meta,.term-bar-title,.blog-meta,.lesson-meta{overflow-wrap:anywhere;word-break:break-word}.cmd-chip{white-space:normal;text-align:left;max-width:100%}.lesson-body,.blog-card p,.project-desc,.about-text p{overflow-wrap:anywhere}img,video,iframe{max-width:100%}.lesson-progress{margin-bottom:20px;padding:16px 22px}.prog-top{color:var(--text-dim);justify-content:space-between;align-items:center;margin-bottom:10px;font-size:14px;display:flex}.prog-count{font-family:var(--font-mono);color:var(--ink-accent);font-weight:600}.prog-bar{background:var(--surface-2);border-radius:6px;height:8px;overflow:hidden}.prog-bar i{background:var(--grad);border-radius:6px;height:100%;transition:width .5s cubic-bezier(.2,.8,.2,1);display:block}.lesson-foot{margin-top:16px}.lesson-done{cursor:pointer;font-family:var(--font-body);background:var(--surface);border:1px solid var(--border);color:var(--text-dim);border-radius:999px;align-items:center;gap:8px;padding:8px 16px;font-size:13.5px;font-weight:600;transition:color .2s,border-color .2s,background .2s;display:inline-flex}.lesson-done:hover{border-color:var(--border-strong);color:var(--text)}.lesson-done .check{border:1.5px solid var(--text-faint);border-radius:50%;place-items:center;width:18px;height:18px;font-size:11px;line-height:1;display:inline-grid}.lesson-done.is-done{background:var(--grad-soft);color:var(--green);border-color:#0000}.lesson-done.is-done .check{border-color:var(--green);color:var(--green)}.lesson-card.done{border-color:color-mix(in srgb, var(--green) 35%, var(--border))}.btn-sm{padding:8px 14px;font-size:13px}.btn-block{width:100%;margin-top:12px}.admin-body{min-height:100vh}.admin-lock{z-index:300;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.lock-card{text-align:center;flex-direction:column;gap:14px;width:100%;max-width:400px;padding:40px 34px;display:flex}.lock-icon{font-size:40px}.lock-card h1{font-family:var(--font-display);font-size:1.5rem}.lock-card p{color:var(--text-dim);font-size:14.5px}.lock-card input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:12px;outline:none;padding:12px 16px;font-size:15px}.lock-card input:focus{border-color:var(--ink-accent)}.lock-note{color:var(--text-faint);font-size:12px}.lock-note code,.admin-hint code{font-family:var(--font-mono);background:var(--surface-2);color:var(--ink-accent);border-radius:5px;padding:1px 6px}.admin-header{z-index:50;-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--border);background:#080b14b3;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:16px 24px;display:flex;position:sticky;top:0}.admin-brand{font-family:var(--font-display);align-items:center;gap:12px;font-size:1.05rem;display:flex}.admin-head-actions{flex-wrap:wrap;gap:10px;display:flex}.admin-tabs{flex-wrap:wrap;gap:8px;width:100%;max-width:1100px;margin:0 auto;padding:18px 24px 0;display:flex}.admin-tab{cursor:pointer;color:var(--text-dim);font-family:var(--font-body);background:0 0;border:1px solid #0000;border-radius:12px 12px 0 0;padding:10px 18px;font-size:14.5px;font-weight:500}.admin-tab:hover{color:var(--text)}.admin-tab.active{background:var(--surface);border-color:var(--border);color:var(--text);border-bottom-color:#0000}.admin-main{width:100%;max-width:1100px;margin:0 auto;padding:22px 24px 60px}.admin-grid{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}.admin-card{margin-bottom:20px;padding:24px 26px}.admin-card h2{font-family:var(--font-display);margin-bottom:14px;font-size:1.2rem}.admin-hint{color:var(--text-faint);margin-bottom:14px;font-size:13px;line-height:1.5}.admin-list{flex-direction:column;gap:8px;max-height:60vh;display:flex;overflow-y:auto}.admin-item{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;transition:border-color .2s;display:flex}.admin-item:hover{border-color:var(--border-strong)}.admin-item.active{border-color:var(--ink-accent)}.admin-item-title{text-overflow:ellipsis;white-space:nowrap;font-size:14px;overflow:hidden}.admin-item-actions{flex-shrink:0;gap:4px;display:flex}.admin-item-actions button{cursor:pointer;background:var(--surface-2);border:1px solid var(--border);width:28px;height:28px;color:var(--text-dim);border-radius:7px;font-size:13px}.admin-item-actions button:hover{color:var(--text);border-color:var(--border-strong)}.admin-item-actions button.danger:hover{color:#ff7a7a;border-color:#ff7a7a}.admin-form{flex-direction:column;gap:14px;display:flex}.admin-field{flex-direction:column;gap:6px;display:flex}.admin-field>span{color:var(--text-dim);font-size:13px}.admin-field input,.admin-field select,.admin-field textarea{background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);border-radius:10px;outline:none;width:100%;padding:10px 13px;font-size:14.5px}.admin-field textarea.mono,textarea.mono{font-family:var(--font-mono);font-size:13px}.admin-field input:focus,.admin-field select:focus,.admin-field textarea:focus{border-color:var(--ink-accent)}.admin-field textarea{resize:vertical}.admin-form-actions{gap:10px;margin-top:4px;display:flex}.admin-export-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:12px;display:flex}.msg-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;padding:16px 18px}.msg-top{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:10px;display:flex}.msg-top b{font-size:15px}.msg-top span{color:var(--text-faint);font-size:12px;font-family:var(--font-mono)}.msg-email{color:var(--cyan);font-size:13px;font-family:var(--font-mono);margin:2px 0 8px;display:inline-block}.msg-body{color:var(--text-dim);white-space:pre-wrap;margin-bottom:12px;font-size:14.5px}.astat-row{flex-wrap:wrap;gap:16px;margin-bottom:22px;display:flex}.astat{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;flex:1;gap:4px;min-width:130px;padding:20px;display:flex}.anum{font-family:var(--font-display);background:var(--grad);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700}.alabel{color:var(--text-faint);font-size:13px}.asub{font-family:var(--font-display);margin:18px 0 12px;font-size:1rem}.abars{align-items:flex-end;gap:8px;height:120px;padding:8px 0;display:flex}.abar{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:4px;height:100%;display:flex}.abar i{background:var(--grad);border-radius:5px 5px 0 0;width:70%;max-width:34px;min-height:2px;display:block}.abar span{color:var(--text-faint);font-size:10.5px;font-family:var(--font-mono)}.abar b{color:var(--text-dim);font-size:11px}.apages{flex-direction:column;gap:6px;display:flex}.apage{background:var(--surface);border:1px solid var(--border);border-radius:9px;justify-content:space-between;padding:9px 13px;font-size:13.5px;display:flex}.apage span{font-family:var(--font-mono);color:var(--text-dim)}.apage b{color:var(--cyan)}.admin-toast{z-index:320;background:var(--grad);color:#06101a;box-shadow:var(--shadow);opacity:0;border-radius:12px;padding:12px 22px;font-size:14px;font-weight:600;transition:opacity .25s,transform .25s;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(20px)}.admin-toast.show{opacity:1;transform:translate(-50%)translateY(0)}.composer{flex-direction:column;gap:12px;max-width:680px;margin-bottom:22px;padding:22px 24px;display:flex}.composer-title{font-family:var(--font-display);font-size:1.15rem;font-weight:600}.composer-drop{border:1.5px dashed var(--border-strong);cursor:pointer;background:var(--surface);border-radius:14px;place-items:center;min-height:150px;transition:border-color .2s,background .2s;display:grid;position:relative;overflow:hidden}.composer-drop:hover,.composer-drop.over{border-color:var(--cyan);background:var(--surface-2)}.cmp-ph{color:var(--text-faint);flex-direction:column;align-items:center;gap:4px;padding:20px;display:flex}.cmp-ph .cmp-ic{font-size:26px}.cmp-ph b{color:var(--text)}.cmp-prev{width:100%;position:relative}.cmp-prev img,.cmp-prev video{object-fit:cover;width:100%;max-height:320px;display:block}.cmp-x{color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#050810bf;border-radius:999px;padding:5px 11px;font-size:12px;position:absolute;top:10px;right:10px}.cmp-busy{color:var(--cyan);font-size:13.5px}.composer input,.composer textarea{background:var(--surface-2);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);border-radius:11px;outline:none;width:100%;padding:11px 14px;font-size:15px}.composer input:focus,.composer textarea:focus{border-color:var(--cyan)}.composer textarea{resize:vertical}.composer-actions{align-items:center;gap:12px;display:flex}.cmp-post{min-width:110px}.cmp-status{color:var(--text-faint);font-size:13.5px}.dropzone{border:1.5px dashed var(--border-strong);text-align:center;cursor:pointer;color:var(--text-faint);background:var(--surface);border-radius:12px;padding:26px;transition:border-color .2s,background .2s}.dropzone:hover,.dropzone.over{border-color:var(--ink-accent);background:var(--surface-2);color:var(--text)}.dz-inner{flex-direction:column;align-items:center;gap:4px;display:flex}.dz-icon{font-size:22px}.dz-inner b{color:var(--text)}.dz-sm{margin-top:6px;padding:12px}.dz-sm .dz-inner{flex-direction:row;gap:8px;font-size:13px}.dz-preview{margin-top:8px}.dz-preview img{border:1px solid var(--border);border-radius:8px;max-height:90px}.dz-preview span{color:var(--text-faint);word-break:break-all;margin-top:4px;font-size:12px;display:block}.dz-file{font-family:var(--font-mono);color:var(--text-dim);font-size:12.5px}.media-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-top:18px;display:grid}.media-card{border-radius:12px;padding:12px}.media-thumb{background:var(--surface-2);border-radius:8px;place-items:center;height:100px;margin-bottom:8px;display:grid;overflow:hidden}.media-thumb img{object-fit:cover;width:100%;height:100%}.media-thumb span{font-size:2.2rem}.media-name{text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.media-meta{color:var(--text-faint);text-overflow:ellipsis;margin:4px 0 10px;font-size:11px;overflow:hidden}.media-meta code{font-size:10.5px}.media-actions{flex-wrap:wrap;gap:6px;display:flex}.media-actions button{cursor:pointer;background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);border-radius:7px;flex:1;padding:6px 8px;font-size:11.5px}.media-actions button:hover{color:var(--text);border-color:var(--border-strong)}.media-actions button.danger:hover{color:#ff7a7a;border-color:#ff7a7a}.cat-list{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.cat-row,.cat-add{grid-template-columns:56px 1fr 1fr 1fr auto;align-items:center;gap:8px;display:grid}.cat-add{margin-top:6px}.cat-row input,.cat-add input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;min-width:0;padding:8px 10px;font-size:13px}.cat-row input:focus,.cat-add input:focus{border-color:var(--ink-accent)}.cat-row input[readonly]{color:var(--ink-accent);font-family:var(--font-mono)}.cat-del{cursor:pointer;background:var(--surface-2);border:1px solid var(--border);color:var(--text-dim);border-radius:8px;padding:8px}.cat-del:hover{color:#ff7a7a;border-color:#ff7a7a}@media (max-width:760px){.admin-grid{grid-template-columns:1fr}.admin-tabs{padding:14px 16px 0}.admin-main{padding:18px 16px 50px}.cat-row,.cat-add{grid-template-columns:48px 1fr 1fr}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}[data-reveal]{opacity:1;transform:none}}section.page-hero{padding-top:124px}article.post-page{max-width:820px;padding-top:120px;padding-bottom:80px}.post-back{color:var(--text-dim);margin-bottom:22px;font-size:.92rem;font-weight:600;transition:color .2s;display:inline-block}.post-back:hover{color:var(--ink-accent)}.post-page .post-media{border-radius:var(--radius);border:1px solid var(--border);margin:0 0 28px;overflow:hidden}.post-page .post-media img,.post-page .post-media video{width:100%;display:block}.post-page .post-media-video{padding-top:56.25%;position:relative}.post-page .post-media-video iframe{border:0;width:100%;height:100%;position:absolute;inset:0}.post-title{font-family:var(--font-display);margin:10px 0 18px;font-size:clamp(1.9rem,4vw,2.9rem);line-height:1.12}.post-text .blog-meta{color:var(--text-dim);flex-wrap:wrap;align-items:center;gap:14px;font-size:.9rem;display:flex}.read-time{color:var(--ink-accent);font-weight:600}.post-text p{color:var(--text);margin:0 0 1.15em;font-size:1.08rem;line-height:1.8}.post-text strong{color:var(--ink-accent)}.post-share{border-top:1px solid var(--border);margin:40px 0 10px;padding-top:26px}.post-share-label{color:var(--text-dim);margin-bottom:12px;font-size:.95rem;font-weight:600;display:block}.share-row{flex-wrap:wrap;gap:10px;display:flex}.share-btn{background:var(--surface);border:1px solid var(--border);width:44px;height:44px;color:var(--text);cursor:pointer;border-radius:50%;place-items:center;transition:transform .18s,border-color .18s,color .18s,background .18s;display:grid}.share-btn:hover{border-color:var(--ink-accent);color:var(--ink-accent);transform:translateY(-3px)}.share-btn.ok{color:var(--green);border-color:var(--green)}.post-related{margin-top:52px}.post-related h3{font-family:var(--font-display);margin-bottom:16px;font-size:1.25rem}.related-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.related-card{border-radius:var(--radius);padding:16px 18px;display:block}.related-card:hover{transform:translateY(-3px)}.related-date{color:var(--text-dim);font-size:.8rem}.related-card h4{margin-top:6px;font-size:1rem;line-height:1.35}.bl-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:22px;display:grid}.bl-card{border-radius:var(--radius);flex-direction:column;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.bl-card:hover{box-shadow:var(--shadow);transform:translateY(-5px)}.bl-thumb{aspect-ratio:16/9;background:var(--surface);position:relative;overflow:hidden}.bl-thumb img,.bl-thumb video{object-fit:cover;width:100%;height:100%}.bl-thumb .ph{place-items:center;width:100%;height:100%;font-size:2.4rem;display:grid}.bl-thumb-text{background:var(--grad-soft);place-items:center;font-size:2.6rem;display:grid}.bl-body{flex-direction:column;flex:1;gap:8px;padding:18px 20px 22px;display:flex}.bl-body h3{font-size:1.15rem;line-height:1.3}.bl-body p{color:var(--text-dim);flex:1;font-size:.94rem;line-height:1.6}.bl-read{color:var(--ink-accent);margin-top:4px;font-size:.9rem;font-weight:600}.blog-viewall{margin:28px auto 0;display:inline-flex}a.blog-viewall{width:max-content}.album-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;display:grid}.album-card{border-radius:var(--radius);aspect-ratio:4/3;border:1px solid var(--border);transition:transform .2s,box-shadow .2s;display:block;position:relative;overflow:hidden}.album-card:hover{box-shadow:var(--shadow);transform:translateY(-5px)}.album-card img{object-fit:cover;width:100%;height:100%;transition:transform .4s}.album-card:hover img{transform:scale(1.05)}.album-card .ph{background:var(--grad-soft);place-items:center;width:100%;height:100%;font-size:2.6rem;display:grid}.album-overlay{background:linear-gradient(#0000 35%,#000000c7);flex-direction:column;justify-content:flex-end;padding:16px 18px;display:flex;position:absolute;inset:0}.album-overlay h3{color:#fff;font-size:1.1rem}.album-count{color:#fffc;margin-top:2px;font-size:.82rem}.album-photos{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.album-photos figure{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;background:var(--surface);position:relative;overflow:hidden}.album-photos img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.album-photos figure:hover img{transform:scale(1.06)}.album-title{margin-bottom:24px}.album-photos figure figcaption{color:#fff;opacity:0;background:linear-gradient(#0000,#000c);padding:8px 10px;font-size:.78rem;transition:opacity .2s;position:absolute;bottom:0;left:0;right:0}.album-photos figure:hover figcaption{opacity:1}.album-photos .vid-badge{width:44px;height:44px}.lb-count{opacity:.7;margin-left:8px;font-size:.85em}.cmp-fields{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;display:grid}.cmp-fields input{width:100%}@media (max-width:560px){.cmp-fields{grid-template-columns:1fr}}.cmp-grid{grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:8px;margin:12px 0;display:grid}.cmp-thumb{aspect-ratio:1;background:var(--surface);border:1px solid var(--border);border-radius:10px;position:relative;overflow:hidden}.cmp-thumb img,.cmp-thumb video{object-fit:cover;width:100%;height:100%}.cmp-thumb-x{color:#fff;cursor:pointer;background:#000000a6;border:0;border-radius:50%;place-items:center;width:22px;height:22px;font-size:.7rem;line-height:1;display:grid;position:absolute;top:3px;right:3px}.cmp-thumb-x:hover{background:#e5484d}.digest-card{border-radius:var(--radius);align-items:center;gap:16px;padding:22px 24px;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;position:relative;overflow:hidden}.digest-bg{opacity:.16;z-index:0;background-position:50%;background-size:cover;position:absolute;inset:0}.digest-card:hover .digest-bg{opacity:.26}.digest-icon{z-index:1;background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-shrink:0;place-items:center;width:56px;height:56px;font-size:2rem;display:grid;position:relative}.digest-body{z-index:1;flex-direction:column;flex:1;gap:3px;min-width:0;display:flex;position:relative}.digest-body b{font-family:var(--font-display);font-size:1.2rem}.digest-sub{color:var(--ink-accent);font-size:.86rem;font-weight:600}.digest-teaser{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:.86rem;overflow:hidden}.digest-arrow{z-index:1;color:var(--text-dim);flex-shrink:0;font-size:1.3rem;transition:transform .2s,color .2s;position:relative}.digest-card:hover .digest-arrow{color:var(--ink-accent);transform:translate(4px)}@media (max-width:680px){.digest-grid{grid-template-columns:1fr}}.hero{overflow:hidden}.hero-canvas{z-index:0;pointer-events:none;position:absolute;inset:0}.hero-canvas canvas{width:100%!important;height:100%!important}.hero .hero-inner{z-index:2;position:relative}.hero-hi{color:var(--text-dim);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:500}.hero-role-line{font-family:var(--font-mono);min-height:1.6em;margin:4px 0 22px;font-size:clamp(1.1rem,2.6vw,1.6rem)}.hero-role-prefix{color:var(--text-dim)}.caret{width:2px;color:var(--cyan);margin-left:1px;animation:1s steps(2,end) infinite blink;display:inline-block}.digest-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;display:grid}.digest-wrap{display:block}.digest-card{border-radius:var(--radius);flex-direction:column;height:100%;transition:transform .25s,box-shadow .25s,border-color .25s;display:flex;overflow:hidden}.digest-card:hover{box-shadow:var(--shadow);border-color:var(--border-strong);transform:translateY(-6px)}.digest-cover{object-fit:cover;width:100%;height:150px;display:block}.digest-cover.ph{background:var(--grad-soft);place-items:center;font-size:3rem;display:grid}.digest-body{flex-direction:column;flex:1;gap:7px;padding:18px 20px 22px;display:flex;position:relative}.digest-icon{background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:13px;place-items:center;width:46px;height:46px;font-size:1.4rem;display:grid;position:absolute;top:-28px;right:18px}.digest-body h3{font-size:1.2rem}.digest-body p{color:var(--text-dim);flex:1;font-size:.92rem;line-height:1.5}.digest-meta{color:var(--text-faint);font-size:.8rem;font-family:var(--font-mono)}.digest-open{color:var(--ink-accent);margin-top:4px;font-size:.9rem;font-weight:600}.hero-title span{opacity:0;animation:.9s cubic-bezier(.2,.7,.2,1) forwards heroUp}.hero-title span:first-child{animation-delay:.12s}.hero-title span:nth-child(2){animation-delay:.26s}@keyframes heroUp{0%{opacity:0;transform:translateY(38px)}to{opacity:1;transform:translateY(0)}}.ad-loading{min-height:100vh;color:var(--text-dim);place-items:center;display:grid}.ad-lock{place-items:center;min-height:100vh;padding:24px;display:grid}.ad-lock-card{border-radius:var(--radius);text-align:center;flex-direction:column;gap:14px;width:100%;max-width:380px;padding:36px 30px;display:flex}.ad-lock-icon{font-size:2.4rem}.ad-lock-card h1{font-family:var(--font-display);font-size:1.5rem}.ad-lock-card p{color:var(--text-dim);font-size:.92rem}.ad-lock-card input{width:100%}.ad-lock-note{color:var(--text-faint);font-size:.78rem}.ad-err{color:#ff6b6b;font-size:.85rem}.ad-app{min-height:100vh;display:flex}.ad-side{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:6px;width:248px;height:100vh;padding:22px 14px;display:flex;position:sticky;top:0;overflow-y:auto}.ad-brand{font-family:var(--font-display);align-items:center;gap:10px;padding:0 8px 14px;font-size:1.1rem;display:flex}.ad-navlabel{text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint);margin:14px 8px 4px;font-size:.7rem}.ad-side nav button{text-align:left;width:100%;color:var(--text-dim);cursor:pointer;background:0 0;border:0;border-radius:9px;padding:9px 12px;font-family:inherit;font-size:.92rem;transition:background .15s,color .15s}.ad-side nav button:hover{background:var(--bg);color:var(--text)}.ad-side nav button.active{background:var(--grad);color:#06121f;font-weight:600}.ad-side-foot{flex-direction:column;gap:8px;margin-top:auto;padding-top:16px;display:flex}.ad-burger{z-index:60;border:1px solid var(--border);background:var(--surface);width:40px;height:40px;color:var(--text);cursor:pointer;border-radius:10px;font-size:1.2rem;display:none;position:fixed;top:12px;left:12px}.ad-main{flex:1;max-width:980px;padding:34px clamp(18px,4vw,48px)}.ad-section{flex-direction:column;gap:18px;display:flex}.ad-head{align-items:center;gap:14px;display:flex}.ad-head h2{font-family:var(--font-display);font-size:1.5rem}.ad-msg{color:var(--cyan);font-size:.9rem}.ad-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:12px;padding:20px;display:flex}.ad-card h3{font-size:1.05rem}.ad-form{gap:12px;display:grid}.ad-field{flex-direction:column;gap:5px;display:flex}.ad-field>span{color:var(--text-dim);font-size:.82rem}.ad-app input:not([type=checkbox]):not([type=file]),.ad-app textarea,.ad-app select,.ad-lock input{background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);font:inherit;border-radius:9px;padding:10px 12px;font-size:.92rem;transition:border-color .15s}.ad-app input:not([type=checkbox]):not([type=file]):focus,.ad-app textarea:focus,.ad-app select:focus,.ad-lock input:focus{border-color:var(--cyan);outline:none}.ad-app input::placeholder,.ad-app textarea::placeholder{color:var(--text-faint)}.ad-app select option{background:var(--bg);color:var(--text)}.ad-app textarea{resize:vertical}.ad-check{color:var(--text-dim);align-items:center;gap:8px;font-size:.9rem;display:flex}.ad-check input{width:auto}.ad-actions{gap:10px;display:flex}.ad-list{flex-direction:column;gap:6px;display:flex}.ad-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;display:flex}.ad-item.active{border-color:var(--cyan)}.ad-item-title{text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;overflow:hidden}.ad-item-actions{flex-shrink:0;gap:4px;display:flex}.ad-item-actions button{border:1px solid var(--border);background:var(--bg);width:30px;height:30px;color:var(--text-dim);cursor:pointer;border-radius:7px}.ad-item-actions button:hover{color:var(--text);border-color:var(--border-strong)}.ad-item-actions button.on{color:var(--cyan);border-color:var(--cyan)}.ad-item-actions button.danger:hover{color:#ff6b6b;border-color:#ff6b6b}.ad-hint{color:var(--text-faint);font-size:.9rem}.ad-grid2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.ad-grid4{grid-template-columns:1fr 1fr 1fr auto;align-items:center;gap:8px;display:grid}.ad-dropzone{border:1.5px dashed var(--border-strong);text-align:center;color:var(--text-dim);cursor:pointer;border-radius:12px;padding:26px;font-size:.9rem}.ad-dropzone:hover{border-color:var(--cyan);color:var(--text)}.ad-thumbs,.ad-media-grid{grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:8px;display:grid}.ad-tn,.ad-media{aspect-ratio:1;background:var(--bg);border:1px solid var(--border);border-radius:9px;position:relative;overflow:hidden}.ad-tn img,.ad-tn video,.ad-media img{object-fit:cover;width:100%;height:100%}.ad-tn button,.ad-media button{color:#fff;cursor:pointer;background:#000000a8;border:0;border-radius:50%;width:22px;height:22px;font-size:.7rem;position:absolute;top:3px;right:3px}.ad-media button.danger{top:29px;right:3px}.ad-media-doc{place-items:center;width:100%;height:100%;font-size:1.8rem;display:grid}.ad-upload{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.ad-upload input[type=text]{flex:1;min-width:160px}.ad-thumb{object-fit:cover;border-radius:8px;width:46px;height:46px}.ad-filelink{color:var(--cyan);font-size:.85rem}.ad-acc{color:var(--text);font-family:var(--font-display);cursor:pointer;text-align:left;background:0 0;border:0;padding:0;font-size:1.05rem}.ad-cats{flex-direction:column;gap:6px;display:flex}.ad-cat{align-items:center;gap:10px;font-size:.88rem;display:flex}.ad-cat b{color:var(--cyan)}.ad-cat button{cursor:pointer;background:0 0;border:0;margin-left:auto}.ad-stats{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.ad-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:18px}.ad-stat b{font-family:var(--font-display);color:var(--cyan);font-size:1.8rem;display:block}.ad-stat span{color:var(--text-dim);font-size:.8rem}.ad-bar-row{align-items:center;gap:10px;font-size:.82rem;display:flex}.ad-bar-label{text-overflow:ellipsis;white-space:nowrap;width:130px;color:var(--text-dim);flex-shrink:0;overflow:hidden}.ad-bar{background:var(--bg);border-radius:5px;flex:1;height:9px;overflow:hidden}.ad-bar i{background:var(--grad);height:100%;display:block}.ad-bar-n{text-align:right;width:36px}.ad-msg-card p{color:var(--text-dim);white-space:pre-wrap;font-size:.92rem}.ad-msg-top{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.ad-msg-date{color:var(--text-faint);margin-left:auto;font-size:.78rem}@media (max-width:820px){.ad-side{z-index:50;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%)}.ad-side.open{transform:translate(0)}.ad-burger{display:block}.ad-main{padding-top:64px}.ad-grid2,.ad-stats{grid-template-columns:1fr}}.lx-progress{color:var(--text-dim);align-items:center;gap:14px;margin-bottom:18px;font-size:.9rem;display:flex}.lx-prog-bar{background:var(--surface);border:1px solid var(--border);border-radius:5px;flex:1;max-width:360px;height:9px;overflow:hidden}.lx-prog-bar i{background:var(--grad);height:100%;transition:width .5s;display:block}.lx-controls{flex-direction:column;gap:12px;margin-bottom:22px;display:flex}.lx-search{background:var(--surface);border:1px solid var(--border);width:100%;max-width:420px;color:var(--text);font:inherit;border-radius:10px;padding:11px 14px}.lx-search:focus{border-color:var(--cyan);outline:none}.ad-avatar{object-fit:cover;border-radius:9px;width:30px;height:30px}.gprev-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.gprev-tile{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);display:block;position:relative;overflow:hidden}.gprev-tile img,.gprev-tile video{object-fit:cover;width:100%;height:100%;transition:transform .35s}.gprev-tile:hover img,.gprev-tile:hover video{transform:scale(1.07)}.gprev-tile .vid-badge{width:40px;height:40px}@media (max-width:760px){.gprev-grid{grid-template-columns:repeat(2,1fr)}}.ad-files{flex-direction:column;gap:8px;display:flex}.ad-file-list{flex-direction:column;gap:4px;display:flex}.ad-file-row{background:var(--bg);border:1px solid var(--border);border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:7px 10px;font-size:.85rem;display:flex}.ad-file-row a{color:var(--text);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ad-file-row button{color:var(--text-dim);cursor:pointer;background:0 0;border:0}.ad-file-row button:hover{color:#ff6b6b}.lesson-files{flex-wrap:wrap;gap:10px;margin:12px 0;display:flex}.lesson-att{background:var(--surface);border:1px solid var(--border);color:var(--ink-accent);border-radius:9px;align-items:center;gap:6px;padding:8px 14px;font-size:.88rem;font-weight:600;transition:border-color .15s,transform .15s;display:inline-flex}.lesson-att:hover{border-color:var(--ink-accent);transform:translateY(-2px)}.lesson-att-img{border:1px solid var(--border);border-radius:9px;width:120px;height:84px;display:block;overflow:hidden}.lesson-att-img img{object-fit:cover;width:100%;height:100%}.lesson-att-vid{border:1px solid var(--border);border-radius:9px;width:240px;max-width:100%}.ad-album{border:1px solid var(--border);border-radius:12px;margin-top:10px;overflow:hidden}.ad-album-head{align-items:center;gap:12px;padding:10px 12px;display:flex}.ad-album-cover{object-fit:cover;background:var(--bg);border-radius:9px;flex-shrink:0;place-items:center;width:52px;height:52px;font-size:1.4rem;display:grid}.ad-album-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.ad-album-info b{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ad-album-info span{color:var(--text-dim);font-size:.8rem}.ad-album-actions{flex-shrink:0;gap:4px;display:flex}.ad-album-actions button{border:1px solid var(--border);background:var(--bg);width:32px;height:32px;color:var(--text-dim);cursor:pointer;border-radius:8px;font-size:.9rem}.ad-album-actions button:hover{color:var(--text);border-color:var(--border-strong)}.ad-album-actions button.danger:hover{color:#ff6b6b;border-color:#ff6b6b}.ad-album-grid{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px;padding:0 12px 12px;display:grid}.ad-album-ph{aspect-ratio:1;background:var(--bg);border:1px solid var(--border);border-radius:9px;position:relative;overflow:hidden}.ad-album-ph.is-cover{border-color:var(--cyan)}.ad-album-ph img,.ad-album-ph video{object-fit:cover;width:100%;height:100%}.ad-cover-badge{background:var(--cyan);color:#06121f;border-radius:5px;padding:1px 6px;font-size:.62rem;font-weight:700;position:absolute;top:4px;left:4px}.ad-album-ph-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex;position:absolute;bottom:4px;right:4px}.ad-album-ph:hover .ad-album-ph-actions{opacity:1}.ad-album-ph-actions button{color:#fff;cursor:pointer;background:#000000b3;border:0;border-radius:6px;width:24px;height:24px;font-size:.72rem}.ad-album-ph-actions button.danger:hover{background:#e5484d}.cv-wrap{max-width:900px;margin:0 auto;padding-top:100px}.cv-actions{justify-content:flex-end;gap:10px;margin-bottom:18px;display:flex}.cv-page{color:#1a2030;border-radius:var(--radius);box-shadow:var(--shadow);background:#fff;padding:44px 48px}.cv-head{border-bottom:2px solid #e3e8f0;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:18px;padding-bottom:16px;display:flex}.cv-name{font-family:var(--font-display);color:#0d1424;font-size:1.9rem}.cv-role{color:#5b6b8c;margin-top:2px;font-weight:600}.cv-contact{text-align:right;color:#41506e;flex-direction:column;gap:3px;font-size:.86rem;list-style:none;display:flex}.cv-sec{margin-bottom:18px}.cv-sec h2{font-family:var(--font-display);color:#0d1424;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid #e3e8f0;margin-bottom:10px;padding-bottom:4px;font-size:1.05rem}.cv-sec p{color:#2a3650;font-size:.92rem;line-height:1.5}.cv-job{margin-bottom:12px}.cv-job-top{justify-content:space-between;gap:12px;display:flex}.cv-job-top b{color:#0d1424;font-size:.98rem}.cv-job-top span{color:#6b7a99;white-space:nowrap;font-size:.82rem}.cv-job-meta{color:#5b6b8c;margin:1px 0 5px;font-size:.85rem}.cv-job ul{margin:0;padding-left:18px}.cv-job li{color:#2a3650;margin-bottom:3px;font-size:.88rem;line-height:1.45}.cv-skills p{color:#2a3650;margin-bottom:3px;font-size:.88rem}.cv-skills b,.cv-edu b{color:#0d1424}.cv-cols{grid-template-columns:1fr 1fr;gap:24px;display:grid}.cv-edu{flex-direction:column;margin-bottom:8px;display:flex}.cv-edu span{color:#5b6b8c;font-size:.82rem}.cv-certs{margin:0;padding-left:18px}.cv-certs li{color:#2a3650;margin-bottom:3px;font-size:.88rem}@media (max-width:620px){.cv-page{padding:28px 22px}.cv-head{flex-direction:column}.cv-contact{text-align:left}.cv-cols{grid-template-columns:1fr}}@media print{.navbar,.theme-fab,.theme-panel,.footer,.bg-wrap,.scroll-progress,.cv-actions{display:none!important}body{background:#fff!important}.cv-wrap{max-width:none;padding:0}.cv-page{box-shadow:none;border-radius:0;padding:0}.section{padding:0!important}.cv-job,.cv-sec{page-break-inside:avoid}}.ctf-score{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:22px;padding:16px 20px;display:flex}.ctf-score-main{align-items:baseline;gap:6px;display:flex}.ctf-score-main b{font-family:var(--font-display);color:var(--cyan);font-size:1.8rem}.ctf-score-main span{color:var(--text-dim);font-size:.85rem}.ctf-score-meta{color:var(--text-dim);align-items:center;gap:14px;font-size:.85rem;display:flex}.ctf-rank{color:var(--ink-accent);font-weight:700}.ctf-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;display:grid}.ctf-card{border-radius:var(--radius);flex-direction:column;gap:12px;padding:22px;transition:border-color .2s;display:flex;position:relative}.ctf-card.solved{border-color:var(--green)}.ctf-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.ctf-top h3{font-size:1.12rem}.ctf-pts{font-family:var(--font-mono);color:#06121f;background:var(--grad);border-radius:20px;flex-shrink:0;padding:3px 10px;font-size:.78rem;font-weight:700}.ctf-prompt{color:var(--text-dim);font-size:.92rem;line-height:1.55}.ctf-prompt code{background:var(--bg);font-family:var(--font-mono);color:var(--ink-accent);border-radius:5px;padding:1px 6px;font-size:.85em}.ctf-hint{background:var(--bg);border-left:3px solid var(--cyan);color:var(--text-dim);border-radius:6px;padding:8px 12px;font-size:.85rem}.ctf-hint-btn{color:var(--text-faint);cursor:pointer;background:0 0;border:0;align-self:flex-start;padding:0;font-size:.82rem}.ctf-hint-btn:hover{color:var(--cyan)}.ctf-answer{flex-wrap:wrap;align-items:center;gap:8px;margin-top:auto;display:flex}.ctf-answer input{background:var(--bg);border:1px solid var(--border);min-width:150px;color:var(--text);font:inherit;border-radius:9px;flex:1;padding:9px 12px;font-size:.9rem}.ctf-answer input:focus{border-color:var(--cyan);outline:none}.ctf-answer.shake input{border-color:#ff6b6b;animation:.4s ctfshake}@keyframes ctfshake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.ctf-fb-err{color:#ff6b6b;width:100%;font-size:.82rem}.ctf-solved-row{color:var(--green);margin-top:auto;font-size:.92rem;font-weight:600}.ctf-solved-row b{color:var(--green)}.rte{border:1px solid var(--border);background:var(--bg);border-radius:9px;overflow:hidden}.rte-bar{border-bottom:1px solid var(--border);background:var(--surface);flex-wrap:wrap;gap:2px;padding:6px;display:flex}.rte-bar button{min-width:30px;height:28px;color:var(--text-dim);cursor:pointer;font-size:.85rem;font-family:var(--font-mono);background:0 0;border:1px solid #0000;border-radius:6px;padding:0 8px}.rte-bar button:hover{background:var(--bg);color:var(--text);border-color:var(--border)}.rte-body{min-height:140px;max-height:360px;color:var(--text);font:inherit;outline:none;padding:12px 14px;font-size:.92rem;line-height:1.55;overflow-y:auto}.rte-body:empty:before{content:attr(data-ph);color:var(--text-faint)}.rte-body h3{margin:.6em 0 .3em;font-size:1.1rem}.rte-body p{margin:0 0 .6em}.rte-body ul,.rte-body ol{margin:0 0 .6em;padding-left:22px}.rte-body a{color:var(--cyan)}.rte-body pre{background:var(--surface);font-family:var(--font-mono);border-radius:8px;padding:10px 12px;font-size:.85em;overflow-x:auto}.ad-drag{cursor:grab;color:var(--text-faint);-webkit-user-select:none;user-select:none;padding:0 4px}.ad-item{cursor:default}.ad-item.dragging{opacity:.5;border-color:var(--cyan)}.post-rich{color:var(--text);font-size:1.08rem;line-height:1.8}.post-rich h2,.post-rich h3{font-family:var(--font-display);margin:1.2em 0 .4em;line-height:1.2}.post-rich h3{font-size:1.4rem}.post-rich p{margin:0 0 1.1em}.post-rich ul,.post-rich ol{margin:0 0 1.1em;padding-left:24px}.post-rich li{margin-bottom:.4em}.post-rich a{color:var(--ink-accent);text-decoration:underline}.post-rich strong{color:var(--ink-accent)}.post-rich pre{background:var(--surface);border:1px solid var(--border);font-family:var(--font-mono);border-radius:10px;margin:0 0 1.1em;padding:14px 16px;font-size:.9rem;overflow-x:auto}.post-rich blockquote{border-left:3px solid var(--cyan);color:var(--text-dim);margin:0 0 1.1em;padding-left:16px}.crop-modal{border-radius:var(--radius);flex-direction:column;gap:14px;width:min(560px,94vw);max-height:92vh;padding:22px;display:flex;overflow:auto}.crop-stage{align-self:center;max-width:100%;line-height:0;display:inline-block;position:relative}.crop-stage img{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;border-radius:6px;max-width:min(520px,86vw);max-height:56vh}.crop-box{border:2px solid var(--cyan);cursor:move;touch-action:none;position:absolute;box-shadow:0 0 0 9999px #00000080}.crop-handle{background:var(--cyan);cursor:nwse-resize;touch-action:none;border:2px solid #06121f;border-radius:50%;width:18px;height:18px;position:absolute;bottom:-8px;right:-8px}.voice-rec{flex-direction:column;gap:6px;margin:-4px 0 4px;display:flex}.voice-label{color:var(--text-dim);font-size:.82rem}.voice-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.voice-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;font:inherit;border-radius:10px;align-items:center;gap:8px;padding:9px 16px;font-size:.9rem;transition:border-color .15s;display:inline-flex}.voice-btn:hover{border-color:var(--ink-accent)}.voice-btn.is-rec{color:#ff8095;border-color:#ff5470}.rec-dot{background:#ff5470;border-radius:50%;width:10px;height:10px;animation:1s infinite recpulse}@keyframes recpulse{0%,to{opacity:1}50%{opacity:.3}}.voice-row audio{max-width:240px;height:36px}.voice-x{color:var(--text-dim);cursor:pointer;background:0 0;border:0;font-size:1rem}.voice-x:hover{color:#ff6b6b}.voice-err{color:#ff6b6b;font-size:.8rem}.ad-msg-audio{width:100%;max-width:320px;height:38px;margin-top:8px}.search-fab{z-index:90;background:var(--surface);border:1px solid var(--border);width:50px;height:50px;color:var(--text);cursor:pointer;box-shadow:var(--shadow);border-radius:50%;place-items:center;transition:transform .2s,border-color .2s;display:grid;position:fixed;bottom:24px;right:88px}.search-fab:hover{border-color:var(--ink-accent);transform:translateY(-3px)}.search-overlay{z-index:250;background:#0000008c;justify-content:center;align-items:flex-start;padding:12vh 20px 20px;display:flex;position:fixed;inset:0}.search-box{border-radius:var(--radius);flex-direction:column;width:min(620px,96vw);max-height:70vh;display:flex;overflow:hidden}.search-inp{border-bottom:1px solid var(--border);color:var(--text-dim);align-items:center;gap:10px;padding:16px 18px;display:flex}.search-inp input{color:var(--text);font:inherit;background:0 0;border:0;outline:none;flex:1;font-size:1.05rem}.search-inp kbd{font-family:var(--font-mono);color:var(--text-faint);border:1px solid var(--border);border-radius:5px;padding:2px 6px;font-size:.72rem}.search-results{padding:6px;overflow-y:auto}.search-empty{text-align:center;color:var(--text-faint);padding:24px}.search-hit{border-radius:10px;align-items:center;gap:12px;padding:11px 14px;display:flex}.search-hit:hover{background:var(--surface)}.search-hit-ic{flex-shrink:0;font-size:1.2rem}.search-hit-main{flex-direction:column;flex:1;min-width:0;display:flex}.search-hit-main b{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.search-hit-main span{color:var(--text-dim);font-size:.8rem}.search-hit-kind{color:var(--text-faint);font-size:.72rem;font-family:var(--font-mono);flex-shrink:0}@media (max-width:560px){.search-fab{width:46px;height:46px;bottom:22px;right:80px}}.crop-overlay{z-index:400;background:#040810d1;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.crop-modal{border-radius:var(--radius);flex-direction:column;gap:14px;width:100%;max-width:600px;padding:22px;display:flex}.crop-modal h3{font-size:1.1rem}.crop-ratios{flex-wrap:wrap;gap:6px;display:flex}.crop-stage{-webkit-user-select:none;user-select:none;touch-action:none;max-width:100%;margin:0 auto;line-height:0;display:inline-block;position:relative}.crop-stage img{border-radius:8px;max-width:100%;max-height:56vh;display:block}.crop-box{border:2px solid var(--cyan);cursor:move;position:absolute;box-shadow:0 0 0 9999px #00000080}.crop-handle{background:var(--cyan);cursor:nwse-resize;border:2px solid #06121f;border-radius:50%;width:18px;height:18px;position:absolute;bottom:-8px;right:-8px}.crop-actions{flex-wrap:wrap;gap:10px;display:flex}.ad-dash-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;display:grid}.ad-dash-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;flex-direction:column;align-items:flex-start;gap:2px;padding:16px;transition:border-color .15s,transform .15s;display:flex}.ad-dash-card:hover{border-color:var(--cyan);transform:translateY(-2px)}.ad-dash-ic{font-size:1.3rem}.ad-dash-card b{font-family:var(--font-display);color:var(--cyan);font-size:1.7rem;line-height:1.1}.ad-dash-label{color:var(--text-dim);font-size:.8rem}.ad-recent{text-align:left;background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:9px;align-items:center;gap:10px;width:100%;margin-bottom:6px;padding:9px 12px;display:flex}.ad-recent:hover{border-color:var(--border-strong)}.ad-recent b{flex-shrink:0}.ad-recent span{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.85rem;overflow:hidden}.ad-recent-date{color:var(--text-faint);flex:none}.ad-filter{margin-bottom:8px}
