:root{color-scheme:dark;--bg:#0b0d10;--bg-alt:#10141a;--surface:#111720;--card:#151b23;--card-strong:#18212b;--card-border:#2a3441;--ink:#f4f7fb;--muted:#9aa7b8;--soft:#c7d0dd;--accent:#36c275;--accent-strong:#65d98f;--accent-ink:#07130c;--accent-soft:rgba(54,194,117,.12);--info:#38bdf8;--warning:#f59e0b;--brand-a:#65d98f;--brand-h:#f4f7fb;--shadow-sm:0 18px 45px rgba(0,0,0,.26);--shadow-lg:0 28px 80px rgba(0,0,0,.38);--radius:8px;--layout-width:1160px}html[data-theme=day]{color-scheme:light;--bg:#f5f8fb;--bg-alt:#eaf1f7;--surface:#ffffff;--card:#ffffff;--card-strong:#f8fbfe;--card-border:#d8e2ed;--ink:#111827;--muted:#5c6b7c;--soft:#334155;--accent:#16885c;--accent-strong:#0f6f49;--accent-ink:#ffffff;--accent-soft:rgba(22,136,92,.1);--info:#0d7fb8;--warning:#b86a00;--brand-a:#16885c;--brand-h:#111827;--shadow-sm:0 18px 45px rgba(15,23,42,.08);--shadow-lg:0 28px 80px rgba(15,23,42,.14)}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{margin:0;padding:0;color:var(--ink);font-family:Manrope,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;line-height:1.65;letter-spacing:0;background:linear-gradient(180deg,#0b0d10,#10141a 48%,#0b0d10)}html[data-theme=day],html[data-theme=day] body{background:linear-gradient(180deg,#f8fbfe,#eef4f9 48%,#f8fbfe)}a{color:var(--accent);text-decoration:none;transition:color .18s ease,opacity .18s ease}a:hover{color:var(--accent-strong);opacity:.95}.site-header{position:sticky;top:0;z-index:1000;isolation:isolate;background:#0b0d10f5;backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid rgba(154,167,184,.14);box-shadow:0 10px 28px #0000003d}html[data-theme=day] .site-header{background:#ffffffeb;border-bottom-color:#0f172a1a;box-shadow:0 10px 28px #0f172a14}.wrap{max-width:var(--layout-width);margin:0 auto;padding:.9rem 1.4rem}nav{display:grid;grid-template-columns:auto 1fr auto;gap:1rem;align-items:center}.nav-left,.nav-center,.nav-right{display:flex;align-items:center}.nav-left,.nav-center,.nav-right{min-width:0}.nav-left{overflow:hidden}.nav-center{justify-content:center}.nav-right{gap:.45rem;justify-content:flex-end;flex:0 0 auto}.brand{display:flex;gap:.75rem;align-items:center;min-width:0;max-width:100%;font-weight:700;color:var(--ink);font-size:1.05rem;text-transform:uppercase;letter-spacing:.04em}.brand span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.brand-mark{display:grid;place-items:center;flex:0 0 auto;width:40px;height:40px;border-radius:8px;background:var(--accent-soft);border:1px solid rgba(54,194,117,.28)}html[data-theme=day] .brand-mark{border-color:#16885c3d}.brand svg{width:27px;height:27px}.nav-menu-toggle{display:none}.nav-menu-current{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu{display:flex;gap:.32rem;align-items:center;flex-wrap:nowrap;justify-content:center}.menu-link{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:.46rem .82rem;border-radius:8px;font-size:.94rem;font-weight:600;line-height:1.15;color:var(--muted);white-space:nowrap;transition:all .18s ease;border:1px solid transparent}.menu-link:hover{color:var(--ink);background:#9aa7b814;border-color:#9aa7b82e}.menu-link[data-active=true]{color:var(--accent-strong);background:var(--accent-soft);border-color:#36c27552}html[data-theme=day] .menu-link:hover{background:#0f172a0d;border-color:#0f172a1a}html[data-theme=day] .menu-link[data-active=true]{border-color:#16885c3d}.language-menu{position:relative}.language-menu summary{display:inline-flex;align-items:center;gap:.38rem;padding:.32rem .5rem;border-radius:8px;border:1px solid rgba(154,167,184,.18);color:var(--soft);font-size:.86rem;font-weight:800;line-height:1;white-space:nowrap;background:#9aa7b80f;cursor:pointer;list-style:none}.language-menu summary::-webkit-details-marker{display:none}.language-menu summary:after{content:"▾";font-size:.66rem;color:var(--muted)}.language-menu[open] summary,.language-menu summary:hover{color:var(--ink);background:#9aa7b81f}.language-options{position:absolute;right:0;top:calc(100% + .45rem);display:grid;gap:.2rem;width:max-content;padding:.35rem;border:1px solid rgba(154,167,184,.18);border-radius:8px;background:#111720;box-shadow:var(--shadow-sm)}.language-option{display:flex;align-items:center;gap:.45rem;padding:.4rem .5rem;border-radius:6px;color:var(--soft);font-size:.86rem;font-weight:700;white-space:nowrap}.language-option:hover{color:var(--ink);background:#9aa7b81a}.language-option[data-active=true]{color:var(--accent-strong);background:var(--accent-soft)}.flag{font-size:1.05rem;line-height:1}html[data-theme=day] .language-menu summary{border-color:#0f172a1a;background:#0f172a0a}html[data-theme=day] .language-menu[open] summary,html[data-theme=day] .language-menu summary:hover{background:#0f172a12}html[data-theme=day] .language-options{background:#fff;border-color:#0f172a1a}html[data-theme=day] .language-option:hover{background:#0f172a0d}.theme-toggle{display:inline-flex;align-items:center;gap:.12rem;min-height:2rem;padding:.18rem;border:1px solid rgba(154,167,184,.18);border-radius:999px;color:var(--muted);background:#9aa7b80f;cursor:pointer;transition:border-color .18s ease,background .18s ease}.theme-toggle:hover{border-color:#9aa7b847;background:#9aa7b81f}.theme-toggle-option{display:grid;place-items:center;width:1.56rem;height:1.56rem;border-radius:999px;color:var(--muted);transition:color .18s ease,background .18s ease}.theme-toggle svg{width:1rem;height:1rem;stroke:currentColor}html[data-theme=day] .theme-toggle{border-color:#0f172a1a;background:#0f172a0a}html[data-theme=day] .theme-toggle:hover{border-color:#0f172a29;background:#0f172a12}html[data-theme=day] .theme-toggle-sun,html[data-theme=night] .theme-toggle-moon{color:var(--accent-ink);background:var(--accent)}main{max-width:var(--layout-width);margin:0 auto;padding:clamp(2rem,2.5vw + 1rem,3.5rem) 1.4rem 4.5rem;display:grid;gap:1.8rem}h1{font-size:clamp(2.15rem,4vw,3.7rem);line-height:1.05;margin:.2rem 0 .4rem}h2{font-size:clamp(1.35rem,2vw,1.85rem);line-height:1.2;margin:1.3rem 0 .1rem}h3{line-height:1.25}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:1rem}.card{background:linear-gradient(180deg,var(--card-strong),var(--card));border:1px solid var(--card-border);border-radius:var(--radius);padding:clamp(1.1rem,1vw + .9rem,1.45rem);box-shadow:var(--shadow-sm)}.card h1,.card h2,.card h3{margin-top:0;font-weight:700;letter-spacing:0}.card h3{font-size:1.08rem;margin-bottom:.55rem}.article-card{display:flex;flex-direction:column;min-height:100%;gap:.25rem;transition:border-color .18s ease,background .18s ease,box-shadow .18s ease}.article-card:hover{border-color:#9aa7b85c;background:linear-gradient(180deg,#1a2430,#151b23);box-shadow:0 22px 54px #00000052}html[data-theme=day] .article-card:hover{border-color:#0f172a2e;background:linear-gradient(180deg,#fff,#f7fafc);box-shadow:0 22px 54px #0f172a1a}.article-card h3 a{color:var(--ink)}.article-card h3 a:hover{color:var(--accent-strong)}.card-summary{margin:.1rem 0 .35rem}.card-actions{margin-top:auto;padding-top:.95rem}.inline-cta{display:inline-flex;align-items:center;gap:.45rem;color:var(--accent-strong);font-size:.9rem;font-weight:800}.inline-cta:after{content:"->";font-weight:900}.title-accent{color:var(--accent)}.muted{color:var(--muted)}.section-head{position:static;max-width:760px;margin:0 0 .2rem;padding:0;background:transparent;border:0;box-shadow:none}.section-head .muted{font-size:1.04rem;margin:.25rem 0 .4rem}.card-meta{margin:0 0 .55rem;color:var(--soft);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.card-facts{display:grid;gap:.35rem;margin:.1rem 0 .6rem;padding:.65rem 0;border-top:1px solid rgba(154,167,184,.12);border-bottom:1px solid rgba(154,167,184,.12)}.card-fact{display:grid;grid-template-columns:7rem 1fr;gap:.7rem;align-items:start;font-size:.86rem;color:var(--soft)}.card-fact-label{color:var(--muted);font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.tag-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.35rem;padding-top:.45rem}.card-fact .tag-row{margin:0;padding:0}.chip{display:inline-flex;align-items:center;gap:.42rem;min-height:1.7rem;padding:.18rem .55rem;font-size:.74rem;font-weight:700;line-height:1;border:1px solid rgba(54,194,117,.28);border-radius:6px;color:#d8fbe4;background:#36c2751a;text-transform:uppercase;letter-spacing:.05em}html[data-theme=day] .chip{border-color:#16885c38;color:#0f6f49;background:var(--accent-soft)}.chip:before{content:"";width:.38rem;height:.38rem;border-radius:2px;background:var(--accent)}.actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center;margin:1.1rem 0 1.4rem}.btn{appearance:none;-webkit-appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:2.84rem;padding:.62rem 1rem;border-radius:8px;font:inherit;font-weight:700;line-height:1;color:var(--accent-ink);background:var(--accent);border:1px solid rgba(54,194,117,.45);box-shadow:0 16px 34px #36c27529;cursor:pointer;transition:box-shadow .18s ease,opacity .18s ease,background .18s ease,border-color .18s ease,color .18s ease}.btn:hover{color:var(--accent-ink);opacity:1;box-shadow:0 20px 44px #36c27538}.btn.btn-secondary{color:var(--ink);background:#9aa7b814;border-color:#9aa7b838;box-shadow:none}html[data-theme=day] .btn.btn-secondary{background:#0f172a0a;border-color:#0f172a1f}img{display:block;max-width:100%;height:auto;border-radius:calc(var(--radius) - 6px);box-shadow:0 14px 26px #080f1c66}html[data-theme=day] img{box-shadow:0 14px 26px #0f172a1f}.project-screenshot{display:flex;justify-content:center;width:100%;max-width:980px;margin:1.35rem auto 1.8rem;padding:0;overflow:hidden;background:transparent}.project-screenshot img{display:block;width:100%;max-width:100%;max-height:600px;margin:0 auto;border-radius:calc(var(--radius) - 8px);box-shadow:0 14px 28px #080f1c5c;object-fit:contain}.project-screenshot video{display:block;width:100%;max-width:100%;max-height:600px;margin:0 auto;border-radius:calc(var(--radius) - 8px);box-shadow:0 14px 28px #080f1c5c;object-fit:contain}.project-screenshot.video-control-frame{display:block;position:relative;overflow:hidden;border-radius:calc(var(--radius) - 8px);background:#000;box-shadow:0 14px 28px #080f1c5c}.project-screenshot.video-control-frame video{width:100%;max-height:600px;border-radius:0;box-shadow:none;cursor:pointer}.video-controls-overlay{position:absolute;left:0;right:0;bottom:0;display:grid;gap:.42rem;padding:2.7rem .8rem .7rem;color:#fff;background:linear-gradient(180deg,#0000,#000000bd 45%,#000000e0);opacity:0;pointer-events:none;transform:translateY(.35rem);transition:opacity .18s ease,transform .18s ease}.video-control-frame.is-video-controls-visible .video-controls-overlay,.video-control-frame[data-keyboard-control=true]:focus-within .video-controls-overlay{opacity:1;pointer-events:auto;transform:translateY(0)}.video-progress{width:100%;height:.35rem;margin:0;accent-color:var(--accent);cursor:pointer}.video-control-row{display:flex;align-items:center;gap:.45rem}.video-control-button{display:inline-flex;align-items:center;justify-content:center;min-height:2rem;padding:.28rem .62rem;border:1px solid rgba(255,255,255,.18);border-radius:999px;color:#fff;background:#ffffff1a;font:inherit;font-size:.78rem;font-weight:900;line-height:1;cursor:pointer;transition:border-color .18s ease,background .18s ease,color .18s ease}.video-control-button:hover{border-color:#ffffff57;background:#ffffff2e}.video-time{min-width:6.4rem;color:#ffffffd1;font-size:.76rem;font-weight:800;line-height:1;white-space:nowrap}.video-rate-label{margin-left:auto;color:#ffffffd1;font-size:.72rem;font-weight:900;text-transform:uppercase;letter-spacing:.06em;line-height:1}.video-rate-select{min-height:2rem;padding:.2rem .42rem;border:1px solid rgba(255,255,255,.18);border-radius:999px;color:#fff;background:#ffffff1a;font:inherit;font-size:.78rem;font-weight:900;line-height:1;cursor:pointer}.video-rate-select option{color:#111827;background:#fff}.media-pair{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;max-width:980px;margin:1.35rem auto 1.8rem}.media-pair .project-screenshot{margin:0;max-width:none}.media-pair .project-screenshot img{width:100%;height:100%;max-height:460px;object-fit:cover}.media-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;max-width:980px;margin:1.35rem auto 1.8rem}.media-grid .project-screenshot{margin:0;max-width:none}.media-grid .project-screenshot img{width:100%;height:100%;max-height:320px;object-fit:cover}pre{background:#080d17e0;padding:1.2rem;border:1px solid rgba(148,163,184,.12);border-radius:16px;overflow:auto;box-shadow:inset 0 0 0 1px #94a3b80a}code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.video{position:relative;padding-bottom:56.25%;height:0;border-radius:18px;overflow:hidden;box-shadow:0 18px 40px #080e1966}.video iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000}footer{border-top:1px solid rgba(154,167,184,.14);background:#0b0d10d1;backdrop-filter:saturate(180%) blur(18px)}html[data-theme=day] footer{border-top-color:#0f172a1a;background:#ffffffd1}footer .wrap{padding:1.4rem;color:var(--muted);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.8rem;font-size:.9rem}.footer-contact{display:inline-flex;align-items:center;gap:.38rem;flex-wrap:wrap}.footer-contact a{font-weight:800;color:var(--accent-strong)}@media (min-width:1280px){:root{--layout-width:1280px}}@media (max-width:1279px){.wrap{padding:.85rem 1rem}nav{grid-template-columns:minmax(0,1fr) auto;grid-template-areas:"brand controls" "menu menu";align-items:center;gap:.65rem .8rem}.nav-left{grid-area:brand}.nav-center{grid-area:menu;display:flex;width:100%;justify-content:flex-start}.nav-right{grid-area:controls;width:auto;justify-content:flex-end}.menu{width:100%;min-width:0;justify-content:flex-start;align-items:center;flex-wrap:wrap;gap:.4rem .45rem}.menu-link{min-height:2.25rem;padding:.52rem .72rem;font-size:.9rem}}@media (max-width:720px){main{padding:2rem 1rem 3.8rem}.nav-center{display:grid;justify-content:stretch}.nav-menu-toggle{display:flex;align-items:center;justify-content:space-between;gap:.65rem;width:100%;min-height:2.65rem;padding:.58rem .72rem;border:1px solid rgba(154,167,184,.18);border-radius:8px;color:var(--soft);background:#9aa7b80f;font:inherit;font-size:.9rem;font-weight:800;line-height:1;cursor:pointer}.nav-menu-toggle:hover{color:var(--ink);background:#9aa7b81f;border-color:#9aa7b842}.nav-menu-toggle svg{width:1.1rem;height:1.1rem;stroke:currentColor}.nav-menu-toggle .nav-menu-toggle-close,.site-header.is-menu-open .nav-menu-toggle .nav-menu-toggle-open{display:none}.site-header.is-menu-open .nav-menu-toggle .nav-menu-toggle-close{display:block}.menu{display:none;width:100%;min-width:0;margin-top:.45rem;padding:.35rem;border:1px solid rgba(154,167,184,.16);border-radius:8px;background:#111720f5;box-shadow:var(--shadow-sm);overflow:visible}.site-header.is-menu-open .menu{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem}.menu-link{width:100%;min-height:2.45rem;padding:.58rem .72rem;white-space:normal;text-align:center}html[data-theme=day] .nav-menu-toggle{border-color:#0f172a1a;background:#0f172a0a}html[data-theme=day] .nav-menu-toggle:hover{background:#0f172a12;border-color:#0f172a29}html[data-theme=day] .menu{background:#fffffffa;border-color:#0f172a1a}.card-fact{grid-template-columns:1fr;gap:.3rem}.media-pair,.media-grid{grid-template-columns:1fr}.project-screenshot img{max-height:420px}.project-screenshot video{max-height:420px}.video-controls-overlay{padding:2.2rem .58rem .58rem}.video-control-row{gap:.28rem}.video-control-button{min-height:1.85rem;padding:.24rem .46rem}.video-time{min-width:5.4rem;font-size:.68rem}.video-rate-label{display:none}.video-rate-select{min-height:1.85rem;font-size:.72rem}.project-screenshot.video-control-frame video{max-height:420px}footer .wrap{justify-content:center;text-align:center}}@media (max-width:520px){.site-header .wrap{padding:.72rem .82rem}nav{gap:.55rem .6rem}.brand{gap:.52rem;font-size:.88rem}.brand-mark{width:34px;height:34px}.brand svg{width:23px;height:23px}.language-menu summary{min-height:2rem;padding:.34rem .44rem}.language-menu summary span:not(.flag){display:none}.theme-toggle{min-height:2rem}.theme-toggle-option{width:1.48rem;height:1.48rem}.site-header.is-menu-open .menu{grid-template-columns:1fr}}
