:root{--font-display: "Space Grotesk", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--bg: #07090c;--bg-2: #0b0f14;--bg-3: #10151c;--surface: #0d1219;--line: rgba(125, 211, 252, .08);--line-strong: rgba(125, 211, 252, .16);--fg: #e6edf3;--fg-2: #b5c0cc;--fg-3: #7b8796;--fg-4: #4d5866;--accent: #7dd3fc;--accent-hot: #22d3ee;--accent-dim: rgba(125, 211, 252, .5);--accent-bg: rgba(125, 211, 252, .08);--grid-opacity: .06;--grid-size: 48px;--ok: #86efac;--warn: #fbbf24;--err: #fca5a5}:root[data-theme=light]{--bg: #f4f2ed;--bg-2: #ecebe4;--bg-3: #e4e2d9;--surface: #ffffff;--line: rgba(10, 30, 50, .08);--line-strong: rgba(10, 30, 50, .16);--fg: #0a1520;--fg-2: #32414f;--fg-3: #5c6b79;--fg-4: #8a96a3;--accent: #0284c7;--accent-hot: #0369a1;--accent-dim: rgba(2, 132, 199, .45);--accent-bg: rgba(2, 132, 199, .08);--grid-opacity: .1;--ok: #15803d;--warn: #a16207;--err: #b91c1c}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--fg);font-family:var(--font-body);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.5;scroll-behavior:smooth}body{min-height:100vh;overflow-x:hidden;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size);background-position:-1px -1px}body:before{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse at 50% 0%,transparent 0%,transparent 40%,var(--bg) 100%);z-index:0}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}.container{width:100%;max-width:1240px;margin:0 auto;padding:0 32px;position:relative;z-index:1}@media(max-width:720px){.container{padding:0 20px}:root{--grid-size: 32px}}section{padding:120px 0;position:relative}@media(max-width:720px){section{padding:80px 0}}.sec-label{display:flex;align-items:center;gap:12px;font-family:var(--font-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin-bottom:24px}.sec-label:before{content:"";width:8px;height:8px;background:var(--accent);border-radius:50%;box-shadow:0 0 12px var(--accent)}.sec-label .num{color:var(--accent)}.sec-title{font-family:var(--font-display);font-size:clamp(32px,5vw,56px);font-weight:500;letter-spacing:-.02em;line-height:1.05;margin-bottom:12px}.sec-sub{color:var(--fg-3);font-size:17px;max-width:640px;margin-bottom:56px}.nav{position:fixed;top:0;left:0;right:0;z-index:50;backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);background:color-mix(in srgb,var(--bg) 70%,transparent);border-bottom:1px solid var(--line)}.nav-inner{max-width:1240px;margin:0 auto;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px}.nav-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:14px;font-weight:500}.nav-logo .mark{width:28px;height:28px;border:1px solid var(--accent);display:grid;place-items:center;color:var(--accent);font-family:var(--font-display);font-weight:600;font-size:15px;position:relative}.nav-logo .mark:after{content:"";position:absolute;inset:-3px;border:1px solid var(--line-strong);pointer-events:none}.nav-logo .mark-exp{position:absolute;top:3px;right:4px;font-size:7px;font-weight:700;line-height:1;color:var(--accent)}.nav-logo .dot{color:var(--accent)}.nav-links{display:flex;gap:4px;align-items:center}.nav-links a{font-family:var(--font-mono);font-size:12.5px;color:var(--fg-3);padding:8px 12px;letter-spacing:.04em;transition:color .2s;border-radius:2px}.nav-links a:hover{color:var(--fg)}.nav-links a .idx{color:var(--accent);margin-right:6px;font-size:11px}.nav-tools{display:flex;gap:8px;align-items:center}.nav-btn{font-family:var(--font-mono);font-size:11.5px;color:var(--fg-2);padding:7px 10px;border:1px solid var(--line-strong);border-radius:2px;display:inline-flex;align-items:center;gap:6px;transition:all .15s;letter-spacing:.04em;min-height:32px}.nav-btn:hover{border-color:var(--accent);color:var(--accent)}.nav-btn .sep{color:var(--fg-4)}.nav-btn .on{color:var(--accent)}@media(max-width:860px){.nav-links{display:none}}.hero{padding-top:180px;padding-bottom:140px;position:relative;overflow:hidden}.hero-grid{display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:end}@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:40px}}.hero-meta{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:11.5px;color:var(--fg-3);letter-spacing:.08em;text-transform:uppercase;padding-bottom:32px;border-bottom:1px solid var(--line-strong);margin-bottom:56px;flex-wrap:wrap;gap:12px}.hero-meta span b{color:var(--fg);font-weight:500}.hero-title{font-family:var(--font-display);font-weight:500;font-size:clamp(56px,11vw,148px);line-height:.92;letter-spacing:-.035em;margin-bottom:32px}.hero-title .line{display:block}.hero-title .it{font-style:italic;font-weight:400;color:var(--accent)}.hero-title .slash{color:var(--fg-4);font-weight:300}.hero-tagline{font-family:var(--font-mono);font-size:13px;color:var(--fg-2);letter-spacing:.04em;margin-bottom:28px;display:flex;flex-wrap:wrap;gap:8px 20px;align-items:center}.hero-tagline .tag{display:inline-flex;align-items:center;gap:8px}.hero-tagline .tag:before{content:"";width:4px;height:4px;background:var(--accent);border-radius:50%}.hero-desc{font-size:17px;color:var(--fg-2);max-width:520px;margin-bottom:40px;line-height:1.6}.hero-desc em{font-style:normal;color:var(--fg);background:var(--accent-bg);padding:0 4px;border-left:2px solid var(--accent)}.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}.btn{font-family:var(--font-mono);font-size:13px;letter-spacing:.06em;padding:14px 20px;border:1px solid var(--line-strong);border-radius:2px;color:var(--fg);display:inline-flex;align-items:center;gap:10px;transition:all .2s;position:relative;background:transparent}.btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.btn-primary{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:500}.btn-primary:hover{background:var(--accent-hot);color:var(--bg);border-color:var(--accent-hot)}.btn .arr{transition:transform .2s}.btn:hover .arr{transform:translate(3px)}.hero-side{padding:24px;border:1px solid var(--line-strong);background:color-mix(in srgb,var(--surface) 60%,transparent);position:relative;font-family:var(--font-mono);font-size:12px}.hero-side:before{content:"";position:absolute;top:-1px;left:-1px;width:10px;height:10px;border-top:1px solid var(--accent);border-left:1px solid var(--accent)}.hero-side:after{content:"";position:absolute;bottom:-1px;right:-1px;width:10px;height:10px;border-bottom:1px solid var(--accent);border-right:1px solid var(--accent)}.hero-side h4{font-size:11px;color:var(--fg-3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px;display:flex;justify-content:space-between}.hero-side h4 .live{color:var(--ok);display:flex;align-items:center;gap:6px}.hero-side h4 .live:before{content:"";width:6px;height:6px;background:var(--ok);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.status-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line);color:var(--fg-3)}.status-row:last-child{border-bottom:none}.status-row b{color:var(--fg);font-weight:500}.status-row .ok{color:var(--ok)}.about-grid{display:grid;grid-template-columns:280px 1fr;gap:64px;align-items:start}@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:40px}}.photo-frame{aspect-ratio:4 / 5;border:1px solid var(--line-strong);background:linear-gradient(135deg,var(--bg-3),var(--bg-2));position:relative;overflow:hidden}.photo-frame:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,transparent,transparent 8px,var(--line) 8px,var(--line) 9px);opacity:.6}.photo-frame .ph-tag{position:absolute;top:12px;left:12px;font-family:var(--font-mono);font-size:10px;color:var(--fg-3);letter-spacing:.08em;background:var(--bg);padding:3px 6px;border:1px solid var(--line-strong)}.photo-frame .ph-label{position:absolute;bottom:16px;left:16px;right:16px;font-family:var(--font-mono);font-size:11px;color:var(--fg-3);line-height:1.4}.photo-frame .ph-label b{color:var(--fg);font-weight:500}.photo-frame .ph-ticks{position:absolute;top:0;right:0;width:24px;height:100%;display:flex;flex-direction:column;justify-content:space-between;padding:8px 0;align-items:center}.photo-frame .ph-ticks span{width:10px;height:1px;background:var(--line-strong)}.about-body p{font-size:18px;line-height:1.65;color:var(--fg-2);margin-bottom:20px}.about-body p b{color:var(--fg);font-weight:500}.about-body p mark{background:transparent;color:var(--accent);font-weight:500}.about-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:40px;border-top:1px solid var(--line-strong);border-bottom:1px solid var(--line-strong)}.about-facts>div{padding:20px 20px 20px 0;border-right:1px solid var(--line)}.about-facts>div:last-child{border-right:none;padding-left:20px;padding-right:0}.about-facts>div:nth-child(2){padding-left:20px}.about-facts .k{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}.about-facts .v{font-family:var(--font-display);font-size:17px;color:var(--fg);font-weight:500}.about-facts .vs{font-size:13px;color:var(--fg-3);margin-top:2px;font-family:var(--font-body)}@media(max-width:720px){.about-facts{grid-template-columns:1fr}.about-facts>div{border-right:none;border-bottom:1px solid var(--line);padding:16px 0!important}.about-facts>div:last-child{border-bottom:none}}.term{background:var(--bg-2);border:1px solid var(--line-strong);font-family:var(--font-mono);font-size:13.5px;position:relative;overflow:hidden}.term-chrome{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);background:var(--bg-3)}.term-chrome .dots{display:flex;gap:6px}.term-chrome .dots span{width:10px;height:10px;border-radius:50%;background:var(--fg-4);opacity:.5}.term-chrome .dots span:first-child{background:var(--accent);opacity:.8}.term-chrome .path{color:var(--fg-3);font-size:11.5px;letter-spacing:.04em;flex:1;text-align:center}.term-chrome .meta{color:var(--fg-4);font-size:11px}.term-body{padding:24px 20px;display:grid;gap:4px}.term-line{display:flex;gap:12px;align-items:baseline}.term-line.cmd{margin-top:16px}.term-line.cmd:first-child{margin-top:0}.term-line .prompt{color:var(--accent);user-select:none;flex-shrink:0}.term-line .cmd-txt{color:var(--fg)}.term-line .cmd-flag{color:var(--fg-3)}.term-out{display:flex;flex-wrap:wrap;gap:6px 8px;padding:8px 0 4px 26px;margin-bottom:4px}.term-tag{padding:4px 10px;border:1px solid var(--line-strong);color:var(--fg-2);font-size:12px;letter-spacing:.02em;background:var(--bg-3);transition:all .15s}.term-tag:hover{border-color:var(--accent);color:var(--accent)}.term-tag.prime{background:var(--accent-bg);border-color:var(--accent-dim);color:var(--accent)}.term-tag .lvl{color:var(--fg-4);margin-left:8px;font-size:10.5px}.caret{display:inline-block;width:8px;height:14px;background:var(--accent);animation:blink 1s steps(2) infinite;vertical-align:-2px}@keyframes blink{50%{opacity:0}}.xp-grid{display:grid;grid-template-columns:200px 1fr;gap:48px}@media(max-width:720px){.xp-grid{grid-template-columns:1fr;gap:20px}}.xp-date{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);letter-spacing:.06em;padding-top:6px;line-height:1.6}.xp-date .cur{color:var(--ok);display:inline-flex;align-items:center;gap:6px}.xp-date .cur:before{content:"";width:6px;height:6px;background:var(--ok);border-radius:50%;animation:pulse 2s infinite}.xp-card{border-left:1px solid var(--line-strong);padding-left:32px;position:relative}.xp-card:before{content:"";position:absolute;left:-5px;top:10px;width:9px;height:9px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 4px var(--bg),0 0 0 5px var(--accent-dim)}.xp-role{font-family:var(--font-display);font-size:28px;font-weight:500;letter-spacing:-.01em;margin-bottom:4px}.xp-company{font-family:var(--font-mono);font-size:13px;color:var(--accent);margin-bottom:16px;letter-spacing:.04em}.xp-company .dot{color:var(--fg-4);margin:0 8px}.xp-desc{color:var(--fg-2);margin-bottom:20px;line-height:1.6;font-size:16px;max-width:680px}.xp-highlights{list-style:none;margin-bottom:24px}.xp-highlights li{padding:10px 0 10px 28px;position:relative;color:var(--fg-2);border-bottom:1px dashed var(--line);font-size:15px;line-height:1.5}.xp-highlights li:last-child{border-bottom:none}.xp-highlights li:before{content:"→";position:absolute;left:0;color:var(--accent);font-family:var(--font-mono)}.xp-highlights li b{color:var(--fg);font-weight:500}.xp-highlights li code{font-family:var(--font-mono);font-size:12.5px;color:var(--accent);background:var(--accent-bg);padding:1px 5px}.xp-stack{display:flex;flex-wrap:wrap;gap:6px;padding-top:20px;border-top:1px solid var(--line)}.xp-stack .pill{font-family:var(--font-mono);font-size:11.5px;color:var(--fg-3);padding:3px 8px;border:1px solid var(--line)}.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:minmax(200px,auto);gap:16px}@media(max-width:960px){.bento{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.bento{grid-template-columns:1fr}}.proj{grid-column:span 3;border:1px solid var(--line-strong);background:var(--surface);padding:28px;display:flex;flex-direction:column;gap:16px;position:relative;transition:all .25s;overflow:hidden;min-height:280px}.proj:hover{border-color:var(--accent-dim);transform:translateY(-2px)}.proj.hero-proj{grid-column:span 6;grid-row:span 2;min-height:380px}.proj.small{grid-column:span 3}.proj.thesis{grid-column:span 6;background:linear-gradient(135deg,var(--surface) 0%,color-mix(in srgb,var(--accent) 5%,var(--surface)) 100%)}@media(max-width:960px){.proj,.proj.small,.proj.thesis{grid-column:span 2}.proj.hero-proj{grid-column:span 2;grid-row:auto}}@media(max-width:560px){.proj,.proj.small,.proj.thesis,.proj.hero-proj{grid-column:span 1;grid-row:auto}}.proj-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.proj-num{font-family:var(--font-mono);font-size:11px;color:var(--fg-3);letter-spacing:.12em}.proj-year{font-family:var(--font-mono);font-size:11px;color:var(--fg-4);letter-spacing:.08em}.proj-title{font-family:var(--font-display);font-weight:500;letter-spacing:-.02em;line-height:1.1;font-size:28px;margin-top:4px}.proj.hero-proj .proj-title{font-size:44px}@media(max-width:720px){.proj.hero-proj .proj-title{font-size:32px}}.proj-title .it{font-style:italic;color:var(--accent);font-weight:400}.proj-desc{color:var(--fg-2);line-height:1.55;font-size:15px;flex:1;max-width:620px}.proj-desc b{color:var(--fg);font-weight:500}.proj-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap}.proj-stack{display:flex;flex-wrap:wrap;gap:6px}.proj-stack .pill{font-family:var(--font-mono);font-size:11px;color:var(--fg-2);padding:3px 8px;border:1px solid var(--line);background:var(--bg-2);letter-spacing:.02em}.proj-link{font-family:var(--font-mono);font-size:12px;color:var(--fg-3);display:inline-flex;align-items:center;gap:8px;transition:color .2s;flex-shrink:0}.proj-link:hover{color:var(--accent)}.proj-link .arr{transition:transform .2s}.proj-link:hover .arr{transform:translate(2px,-2px)}.proj-badge{position:absolute;top:16px;right:16px;font-family:var(--font-mono);font-size:10px;color:var(--accent);letter-spacing:.1em;padding:3px 8px;background:var(--accent-bg);border:1px solid var(--accent-dim)}.proj-viz{position:absolute;inset:auto -40px -40px auto;width:260px;height:260px;border:1px solid var(--line);border-radius:50%;opacity:.4;pointer-events:none}.proj-viz:before{content:"";position:absolute;inset:30px;border:1px solid var(--line);border-radius:50%}.proj-viz:after{content:"";position:absolute;inset:60px;border:1px dashed var(--line-strong);border-radius:50%}.lab{background:var(--bg-2);margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);padding-left:calc(50vw - 50%);padding-right:calc(50vw - 50%);border-top:1px solid var(--line-strong);border-bottom:1px solid var(--line-strong);position:relative}.lab:before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px);background-size:100% 32px;opacity:.5;pointer-events:none}.lab>.container{position:relative;z-index:1}.lab-header{display:grid;grid-template-columns:1fr auto;gap:40px;align-items:end;margin-bottom:64px;padding-bottom:32px;border-bottom:1px solid var(--line)}@media(max-width:860px){.lab-header{grid-template-columns:1fr;gap:32px}}.lab-diagram-container{background:var(--bg);border:1px solid var(--line);padding:20px;border-radius:8px;width:100%;max-width:600px}.lab-svg{width:100%;height:auto;display:block}.lab-svg .hl{fill:var(--accent)}.lab-svg .fg{fill:var(--fg-2)}.lab-svg .lbl{fill:var(--fg-4)}.lab-svg .lbl-color{color:var(--fg-4)}.lab-svg .line-color{color:var(--line);stroke-width:1.5}.lab-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:720px){.lab-grid{grid-template-columns:1fr}}.service{border:1px solid var(--line-strong);background:var(--bg);padding:24px;display:flex;flex-direction:column;gap:16px;position:relative;transition:all .2s}.service:hover{border-color:var(--accent-dim)}.service:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--accent);opacity:0;transition:opacity .2s}.service:hover:before{opacity:1}.service-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.service-meta{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}.service-name{font-family:var(--font-display);font-size:24px;font-weight:500;letter-spacing:-.015em;line-height:1.15}.service-status{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding-top:4px;flex-shrink:0}.service-status.live{color:var(--ok)}.service-status.live:before{content:"";width:6px;height:6px;background:var(--ok);border-radius:50%;animation:pulse 2s infinite}.service-status.dev{color:var(--warn)}.service-status.dev:before{content:"";width:6px;height:6px;background:var(--warn);border-radius:50%}.service-desc{color:var(--fg-2);font-size:14.5px;line-height:1.55}.service-desc b{color:var(--fg);font-weight:500}.service-log{font-family:var(--font-mono);font-size:11px;background:var(--bg-2);padding:12px;color:var(--fg-3);display:grid;gap:2px;border:1px solid var(--line);max-height:110px;overflow:hidden;line-height:1.5}.service-log .ts{color:var(--fg-4)}.service-log .lvl-i{color:var(--accent)}.service-log .lvl-ok{color:var(--ok)}.service-log .lvl-w{color:var(--warn)}.service-log .m{color:var(--fg-2)}.service-stack{display:flex;flex-wrap:wrap;gap:6px;padding-top:12px;border-top:1px dashed var(--line)}.service-stack .pill{font-family:var(--font-mono);font-size:10.5px;color:var(--fg-3);padding:2px 7px;border:1px solid var(--line)}.edu-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px}@media(max-width:860px){.edu-grid{grid-template-columns:1fr;gap:40px}}.edu-card{border:1px solid var(--line-strong);padding:32px;background:var(--surface);position:relative}.edu-head{font-family:var(--font-mono);font-size:11px;color:var(--fg-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:20px;display:flex;justify-content:space-between}.edu-title{font-family:var(--font-display);font-size:26px;font-weight:500;letter-spacing:-.015em;line-height:1.2;margin-bottom:8px}.edu-sub{color:var(--fg-2);font-size:15px;margin-bottom:20px}.edu-badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11.5px;color:var(--accent);background:var(--accent-bg);padding:5px 10px;border:1px solid var(--accent-dim);letter-spacing:.04em}.edu-desc{color:var(--fg-2);font-size:14.5px;line-height:1.6;margin-top:20px;padding-top:20px;border-top:1px solid var(--line)}.cert-list{display:grid;gap:12px}.cert{padding:20px;border:1px solid var(--line-strong);background:var(--surface);display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;transition:border-color .2s}.cert:hover{border-color:var(--accent-dim)}.cert-ico{width:44px;height:44px;border:1px solid var(--line-strong);display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;color:var(--accent);letter-spacing:.04em}.cert-name{font-family:var(--font-display);font-weight:500;font-size:16px;letter-spacing:-.005em}.cert-issuer{font-family:var(--font-mono);font-size:11.5px;color:var(--fg-3);margin-top:2px;letter-spacing:.02em}.cert-year{font-family:var(--font-mono);font-size:12px;color:var(--fg-3)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}@media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:40px}}.contact-intro h3{font-family:var(--font-display);font-size:clamp(36px,5vw,56px);font-weight:500;line-height:1;letter-spacing:-.025em;margin-bottom:24px}.contact-intro h3 .it{font-style:italic;color:var(--accent);font-weight:400}.contact-intro p{color:var(--fg-2);font-size:17px;line-height:1.6;margin-bottom:28px;max-width:440px}.contact-links{display:grid;gap:4px}.clink{display:grid;grid-template-columns:28px 1fr auto;gap:16px;align-items:center;padding:14px 0;border-bottom:1px solid var(--line);transition:all .2s;font-family:var(--font-mono);font-size:13.5px}.clink:last-child{border-bottom:none}.clink .ico{color:var(--fg-3);font-size:12px;letter-spacing:.05em}.clink .val{color:var(--fg);transition:color .2s}.clink .arr{color:var(--fg-4);font-size:12px;transition:all .2s}.clink:hover .val{color:var(--accent)}.clink:hover .arr{color:var(--accent);transform:translate(3px,-3px)}.form{border:1px solid var(--line-strong);padding:28px;background:var(--surface);display:grid;gap:20px;position:relative}.form:before{content:"new_message.md";position:absolute;top:-1px;left:24px;transform:translateY(-50%);background:var(--bg);padding:2px 10px;font-family:var(--font-mono);font-size:11px;color:var(--fg-3);border:1px solid var(--line-strong)}.field label{display:block;font-family:var(--font-mono);font-size:11px;color:var(--fg-3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}.field label .req{color:var(--accent)}.field input,.field textarea{width:100%;background:var(--bg);border:1px solid var(--line-strong);color:var(--fg);padding:10px 12px;font-family:var(--font-body);font-size:14px;transition:border-color .15s;border-radius:2px}.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}.field textarea{min-height:110px;resize:vertical;font-family:var(--font-body)}.form-foot{display:flex;justify-content:space-between;align-items:center;gap:16px}.form-hint{font-family:var(--font-mono);font-size:11px;color:var(--fg-4)}.form .btn{width:auto}.form-wip-wrap{position:relative}.form-wip-wrap .form{opacity:.3;pointer-events:none;user-select:none}.form-wip-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:color-mix(in srgb,var(--bg) 70%,transparent);backdrop-filter:blur(3px);border:1px solid var(--line-strong);border-radius:2px}.form-wip-badge{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--accent);border:1px solid var(--accent);padding:4px 14px;text-transform:uppercase}.form-wip-overlay p{color:var(--fg-3);font-size:13px;text-align:center;margin:0}.footer{border-top:1px solid var(--line-strong);padding:48px 0 32px;position:relative;z-index:1}.footer-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;font-family:var(--font-mono);font-size:11.5px;color:var(--fg-3);letter-spacing:.04em}@media(max-width:720px){.footer-inner{grid-template-columns:1fr;text-align:center}}.footer a:hover{color:var(--accent)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.8,.2,1),transform .7s cubic-bezier(.2,.8,.2,1);will-change:opacity,transform}.reveal.in{opacity:1;transform:translateY(0)}.reveal.delay-1{transition-delay:.06s}.reveal.delay-2{transition-delay:.12s}.reveal.delay-3{transition-delay:.18s}.reveal.delay-4{transition-delay:.24s}@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}.row{display:flex;align-items:center;gap:8px}.mono{font-family:var(--font-mono)}.accent{color:var(--accent)}.dim{color:var(--fg-3)}.bframe{position:relative;border:1px solid var(--line-strong);background:var(--bg-2);overflow:hidden;border-radius:3px;box-shadow:0 1px 0 0 var(--line) inset,0 20px 40px -20px #0006}.bframe-chrome{display:flex;align-items:center;gap:12px;padding:8px 10px;background:var(--bg-3);border-bottom:1px solid var(--line);font-family:var(--font-mono);font-size:11px;color:var(--fg-3)}.bframe-compact .bframe-chrome{padding:6px 8px;font-size:10px;gap:8px}.bframe-dots{display:flex;gap:5px;flex-shrink:0}.bframe-dots span{width:8px;height:8px;border-radius:50%;background:var(--line-strong)}.bframe-dots span:nth-child(1){background:color-mix(in srgb,var(--fg-3) 60%,transparent)}.bframe-dots span:nth-child(2){background:color-mix(in srgb,var(--fg-3) 40%,transparent)}.bframe-dots span:nth-child(3){background:color-mix(in srgb,var(--accent) 60%,transparent)}.bframe-url{flex:1;display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg);border:1px solid var(--line);border-radius:2px;min-width:0}.bframe-lock{color:var(--accent);font-size:11px}.bframe-host{color:var(--fg-2);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bframe-tools{color:var(--fg-4);font-size:13px;flex-shrink:0;letter-spacing:.15em}.bframe-body{position:relative;aspect-ratio:16 / 9;background:var(--bg);overflow:hidden}.islider{display:flex;flex-direction:column;gap:10px;width:100%}.islider-stage{position:absolute;inset:0}.islider-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;opacity:0;transition:opacity .35s ease}.islider-img.on{opacity:1}.islider-nav{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;display:grid;place-items:center;background:color-mix(in srgb,var(--bg) 70%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--line-strong);color:var(--fg-2);font-family:var(--font-display);font-size:18px;line-height:1;cursor:pointer;transition:all .18s;border-radius:2px;opacity:0}.bframe:hover .islider-nav{opacity:1}.islider-nav:hover{color:var(--accent);border-color:var(--accent)}.islider-nav.prev{left:8px}.islider-nav.next{right:8px}.islider-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--font-mono);font-size:11px;color:var(--fg-3);flex-wrap:wrap}.islider-ticks{display:flex;gap:6px}.islider-ticks .tick{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;color:var(--fg-4);background:transparent;border:1px solid var(--line);padding:3px 7px;cursor:pointer;border-radius:2px;transition:all .18s}.islider-ticks .tick:hover{color:var(--fg-2);border-color:var(--line-strong)}.islider-ticks .tick.on{color:var(--accent);border-color:var(--accent);background:var(--accent-bg)}.islider-cap{letter-spacing:.04em;color:var(--fg-3);font-style:italic}.proj.has-img{display:flex;flex-direction:column;gap:18px;padding-top:18px}.proj.hero-proj.has-img{display:grid;grid-template-columns:1.15fr 1fr;gap:28px;align-items:center;padding:24px}.proj.hero-proj.has-img .proj-content{display:flex;flex-direction:column}.proj-media{position:relative}.proj.has-img .proj-content{display:flex;flex-direction:column;gap:0}.proj.has-img .proj-content .proj-head{margin-bottom:8px}.proj.has-img .proj-content .proj-title{margin-bottom:10px}.proj.has-img .proj-content .proj-desc{margin-bottom:14px}@media(max-width:960px){.proj.hero-proj.has-img{grid-template-columns:1fr;gap:20px}}.demo-btn{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--line-strong);background:var(--bg);border-radius:2px;font-family:var(--font-mono);font-size:12px;letter-spacing:.04em;color:var(--fg-2);text-decoration:none;margin:14px 0 18px;width:fit-content;max-width:100%;flex-wrap:wrap;transition:all .18s}.demo-btn .demo-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.demo-btn .demo-label{color:var(--fg);font-weight:500;text-transform:lowercase}.demo-btn .demo-host{color:var(--fg-3);border-left:1px solid var(--line-strong);padding-left:10px}.demo-btn .demo-note{color:var(--fg-4);font-style:italic;font-size:11px}.demo-btn .arr{color:var(--fg-3);margin-left:auto;transition:transform .18s}.demo-btn.live{border-color:color-mix(in srgb,#22c55e 60%,var(--line-strong))}.demo-btn.live .demo-dot{background:#22c55e;box-shadow:0 0 10px #22c55e,0 0 0 3px color-mix(in srgb,#22c55e 25%,transparent);animation:demo-pulse 2.4s ease-in-out infinite}.demo-btn.live:hover{border-color:#22c55e;background:color-mix(in srgb,#22c55e 6%,var(--bg))}.demo-btn.live:hover .arr{transform:translate(2px,-2px);color:#22c55e}.demo-btn.soon .demo-dot{background:#f59e0b;box-shadow:0 0 8px color-mix(in srgb,#f59e0b 60%,transparent)}.demo-btn.soon{border-style:dashed}.demo-btn.repo .demo-dot{background:var(--accent);box-shadow:0 0 8px var(--accent-dim)}.demo-btn.private .demo-dot{background:var(--fg-4);border:1px solid var(--fg-3)}.demo-btn.private{opacity:.85}@keyframes demo-pulse{0%,to{box-shadow:0 0 10px #22c55e,0 0 0 3px color-mix(in srgb,#22c55e 25%,transparent)}50%{box-shadow:0 0 14px #22c55e,0 0 0 6px color-mix(in srgb,#22c55e 12%,transparent)}}.service-media{margin:4px 0 16px}.service.has-img .service-media .bframe-body{aspect-ratio:16 / 10}:root[data-theme=light] .bframe{box-shadow:0 1px 0 0 var(--line) inset,0 12px 28px -16px #0a1e322e}[data-lang=es] [lang=en],[data-lang=en] [lang=es]{display:none!important}html:not([data-lang]) [lang=en]{display:none!important}.ph-photo[data-astro-cid-v2cbyr3p]{width:100%;height:100%;object-fit:cover;object-position:top center;position:absolute;inset:0;border-radius:inherit}
