@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(../media/inter-cyrillic-ext-wght-normal.0njn0k24e9yoi.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(../media/inter-cyrillic-wght-normal.0rcuf0.1.yh_r.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(../media/inter-greek-ext-wght-normal.06-9dg6i6j3-0.woff2)format("woff2-variations");unicode-range:U+1F??}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(../media/inter-greek-wght-normal.0k9zl1k-01kin.woff2)format("woff2-variations");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(../media/inter-vietnamese-wght-normal.0tobx9jzz29xd.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(../media/inter-latin-ext-wght-normal.102o-0.xi~5bx.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(../media/inter-latin-wght-normal.055ydel_y7o6i.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.absolute{position:absolute}.static{position:static}.block{display:block}.hidden{display:none}.inline{display:inline}.table{display:table}.h-full{height:100%}.w-full{width:100%}.grow{flex-grow:1}.object-cover{object-fit:cover}}:root,[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#070a12;--bg-soft:#0c101b;--panel:#101522;--panel-strong:#151b2c;--line:#909cbe2e;--text:#f6f8ff;--muted:#a8b0c4;--soft:#778098;--violet:#7b4dff;--blue:#5c8dff;--teal:#31e3c4;--amber:#f6bf5f;--shadow:0 24px 80px #0000006b;--header-bg:#070a12c7;--hero-glow-1:#7b4dff2e;--hero-glow-2:#31e3c414;--eyebrow:#a487ff;--input-bg:#090d16;--secondary-btn-bg:#1015228c;--floating-card-bg:#101522c7}[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#f3f5fc;--bg-soft:#e9edf7;--panel:#fff;--panel-strong:#e4e9f5;--line:#3c486e29;--text:#0c1020;--muted:#4b556f;--soft:#6b7288;--violet:#6b3df0;--blue:#3f6fe8;--teal:#0f9f86;--amber:#d89a2c;--shadow:0 24px 80px #0f172a1f;--header-bg:#f3f5fce0;--hero-glow-1:#7b4dff1f;--hero-glow-2:#31e3c41a;--eyebrow:#6b3df0;--input-bg:#fff;--secondary-btn-bg:#ffffffd9;--floating-card-bg:#ffffffeb}*{box-sizing:border-box}.skip-link{z-index:100;background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:8px;padding:.75rem 1rem;font-weight:700;transition:top .18s;position:absolute;top:-100%;left:1rem}.skip-link:focus{outline:2px solid var(--blue);outline-offset:2px;top:1rem}html{scroll-behavior:smooth;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}html[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}body{background:radial-gradient(circle at 70% 14%, var(--hero-glow-1), transparent 30rem), radial-gradient(circle at 20% 20%, var(--hero-glow-2), transparent 24rem), var(--bg);min-width:320px;color:var(--text);margin:0;font-family:Inter Variable,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:background .24s,color .24s}a{color:inherit;text-decoration:none}img,svg{display:block}button,input,textarea{font:inherit}.site-header{z-index:20;border-bottom:1px solid var(--line);background:var(--header-bg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);grid-template-columns:1fr auto 1fr;align-items:center;gap:1.25rem;min-height:72px;padding:0 4.8vw;display:grid;position:sticky;top:0}.brand,.site-nav,.header-actions,.header-cta,.hero-actions,.social-links,.panel-header,.tags,.site-footer{align-items:center;display:flex}.header-actions{justify-self:end;gap:.75rem}.brand{gap:.9rem;font-weight:700}.brand-mark{color:#0000;background:linear-gradient(135deg, var(--violet), var(--blue));-webkit-background-clip:text;background-clip:text;place-items:center;width:2.4rem;height:2.4rem;font-size:1.25rem;font-weight:900;display:grid}.site-nav{color:var(--muted);justify-content:center;gap:clamp(1rem,2.5vw,2.6rem);font-size:.95rem;font-weight:650}.site-nav a{padding:1.7rem 0;position:relative}.site-nav a:after{content:"";background:linear-gradient(90deg, var(--violet), var(--blue));transform-origin:50%;height:2px;transition:transform .18s;position:absolute;bottom:0;left:0;right:0;transform:scaleX(0)}.site-nav a:is(:hover,.active){color:var(--text)}.site-nav a:is(:hover,.active):after{transform:scaleX(1)}.header-cta{background:linear-gradient(135deg,#7b4dff21,#5c8dff0d);border:1px solid #7b4dff8c;border-radius:8px;gap:.75rem;min-height:44px;padding:0 1.35rem;font-weight:800;box-shadow:0 0 34px #7b4dff1f}.header-cta svg,.primary-btn svg,.secondary-btn svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.2px;width:1rem;height:1rem}.theme-toggle{border:1px solid var(--line);background:var(--secondary-btn-bg);width:2.65rem;height:2.65rem;color:var(--text);cursor:pointer;border-radius:8px;place-items:center;transition:border-color .18s,transform .18s;display:grid}.theme-toggle:hover{border-color:#5c8dff8c;transform:translateY(-1px)}.theme-toggle svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px;width:1.15rem;height:1.15rem}.nav-toggle{display:none}main{width:min(1240px,90vw);margin:0 auto}.hero{grid-template-columns:minmax(0,.95fr) minmax(340px,1.05fr);align-items:center;gap:3rem;min-height:calc(100svh - 72px);padding:4.8rem 0 3rem;display:grid}.eyebrow{color:var(--eyebrow);margin:0 0 1rem;font-size:clamp(1.1rem,2vw,1.45rem);font-weight:750}h1,h2,h3,p{margin-top:0}h1{color:#0000;background:linear-gradient(90deg, var(--violet), #7c70ff 42%, var(--blue));-webkit-background-clip:text;background-clip:text;max-width:12ch;margin-bottom:1rem;font-size:clamp(3.2rem,7.2vw,5.8rem);line-height:.95}.hero-role{min-height:2.4rem;margin-bottom:1.1rem;font-size:clamp(1.35rem,3vw,2rem);font-weight:780}.hero-role span:after{background:var(--blue);content:"";vertical-align:-.12em;width:2px;height:1em;margin-left:.2rem;animation:1s step-end infinite blink;display:inline-block}.hero-text{max-width:39rem;color:var(--muted);font-size:1.08rem;line-height:1.85}.hero-actions{flex-wrap:wrap;gap:1rem;margin-top:2rem}.primary-btn,.secondary-btn{border-radius:8px;justify-content:center;align-items:center;gap:.75rem;min-height:52px;padding:0 1.35rem;font-weight:850;display:inline-flex}.primary-btn{background:linear-gradient(135deg, var(--violet), var(--blue));color:#fff;box-shadow:0 18px 42px #5c8dff33}.secondary-btn{border:1px solid var(--line);background:var(--secondary-btn-bg);color:var(--text)}.social-links{gap:1.35rem;margin-top:1.8rem}.social-links a{width:2rem;height:2rem;color:var(--text);place-items:center;transition:color .18s,transform .18s;display:grid}.social-links a:hover{color:var(--blue);transform:translateY(-2px)}.social-links svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px;width:1.55rem;height:1.55rem}.hero-visual{isolation:isolate;min-height:520px;position:relative}.portrait-orbit{aspect-ratio:1;filter:blur(1px)saturate(1.16);opacity:.82;background:radial-gradient(circle at 42% 30%,#5c8dff70,#0000 30%),radial-gradient(circle at 68% 66%,#7b4dff57,#0000 42%),linear-gradient(135deg,#5c8dff2e,#7b4dff1f);border-radius:58% 42% 52% 48%/44% 56%;width:min(80%,27.5rem);animation:8s ease-in-out infinite portraitFloat;position:absolute;top:9%;right:9%}.portrait-orbit:before,.portrait-orbit:after{content:"";border-radius:inherit;pointer-events:none;position:absolute}.portrait-orbit:before{filter:blur(32px);opacity:.86;background:radial-gradient(circle at 50% 46%,#5c8dff6b,#7b4dff29 50%,#0000 74%);inset:2%}.portrait-orbit:after{filter:blur(48px);opacity:.78;z-index:-1;background:radial-gradient(circle at 48% 45%,#5c8dff4d,#0000 43%),radial-gradient(circle,#7b4dff33,#0000 66%);inset:-12%}.portrait-card{aspect-ratio:.86;background:radial-gradient(circle at 50% 30%,#5c8dff29,#0000 42%),linear-gradient(#121d3a47,#070a1275);border-radius:58% 42% 55% 45%/45% 54% 46% 55%;place-items:end center;width:min(74%,26.5rem);animation:8s ease-in-out infinite portraitFloat;display:grid;position:absolute;bottom:1.4rem;right:11%;overflow:hidden;box-shadow:0 28px 76px #0000005c,0 0 58px #5c8dff52,0 0 112px #7b4dff29}.portrait-card:after{z-index:1;content:"";pointer-events:none;border:1px solid var(--line);background:linear-gradient(135deg,#5c8dff14,#7b4dff0f);position:absolute;inset:0;box-shadow:inset 0 -22px 48px #070a122e}.portrait-card img{object-fit:cover;object-position:50% 48%;filter:contrast(1.04)saturate(1.04);transform-origin:50%;width:100%;height:100%;transform:scale(1.03)}.floating-card{border:1px solid var(--line);background:var(--floating-card-bg);min-width:12.5rem;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:8px;align-items:center;gap:.8rem;padding:.95rem;display:flex;position:absolute}.floating-card small{color:var(--muted);margin-bottom:.28rem;font-size:.75rem;font-weight:700;display:block}.floating-card strong{font-size:.95rem}.mini-icon,.stat-icon{width:2.8rem;height:2.8rem;color:var(--blue);background:#7b4dff1f;border-radius:8px;flex:none;place-items:center;font-size:.9rem;font-weight:900;display:grid}.learn-card{top:12%;right:0}.build-card{top:62%;left:0}.open-card{bottom:6%;right:0}.stats{border:1px solid var(--line);background:var(--secondary-btn-bg);border-radius:8px;grid-template-columns:repeat(4,1fr);gap:0;margin-bottom:3.5rem;display:grid;overflow:hidden;box-shadow:0 20px 70px #00000029}.stats article{border-right:1px solid var(--line);justify-content:center;align-items:center;gap:1.35rem;min-height:112px;padding:1rem;display:flex}.stats article:last-child{border-right:0}.stats strong{font-size:1.7rem;display:block}.stats span:last-child{color:var(--muted)}.section{padding:3rem 0}.section-heading{max-width:48rem;margin-bottom:1.8rem}.section-heading h2,.panel-header h2{margin:0;font-size:clamp(1.65rem,3vw,2.35rem)}.about-grid{border-bottom:1px solid var(--line);grid-template-columns:minmax(0,.8fr) minmax(320px,1fr);align-items:start;gap:2rem;padding-bottom:1rem;display:grid}.about-grid p{color:var(--muted);font-size:1.06rem;line-height:1.8}.skill-cloud{flex-wrap:wrap;gap:.75rem;display:flex}.skill-cloud span,.tags span{border:1px solid var(--line);background:var(--secondary-btn-bg);color:var(--text);border-radius:8px;font-size:.82rem;font-weight:750}.skill-cloud span{padding:.75rem .95rem}.content-grid{grid-template-columns:minmax(0,1.35fr) minmax(320px,.95fr);gap:2rem;display:grid}.projects-panel,.blog-panel{min-width:0}.panel-header{justify-content:space-between;gap:1rem;margin-bottom:1.35rem}.muted-link{color:var(--soft);cursor:not-allowed;font-size:.9rem;font-weight:800}.project-list{border:1px solid var(--line);background:var(--secondary-btn-bg);border-radius:8px;grid-template-columns:repeat(3,minmax(0,1fr));display:grid;overflow:hidden}.project-card{border-right:1px solid var(--line);min-width:0;padding:1rem;transition:background .18s,transform .18s}.project-card:hover{background:var(--floating-card-bg);transform:translateY(-2px)}.project-card:last-child{border-right:0}.project-shot{background:var(--panel-strong);color:#f9fbff;text-align:center;border-radius:8px;place-items:center;min-height:150px;margin-bottom:1.1rem;font-size:.88rem;font-weight:850;display:grid;position:relative;overflow:hidden}.project-shot:before{content:"";opacity:.8;position:absolute;inset:0}.project-shot span{z-index:1;max-width:12rem;position:relative}.assistant-shot:before{background:radial-gradient(circle,#7b4dff42,#0000 42%),linear-gradient(135deg,#0b0f19,#171d2d)}.task-shot:before{background:linear-gradient(90deg,#070a12d9,#070a1233),linear-gradient(135deg,#101827,#37245a)}.weather-shot:before{background:linear-gradient(135deg,#1942a3,#071634 72%)}.project-card h3,.blog-item h3{margin-bottom:.55rem;font-size:1.1rem}.project-card p,.blog-item p{color:var(--muted);line-height:1.55}.tags{flex-wrap:wrap;gap:.55rem;margin-top:.9rem}.tags span{padding:.42rem .58rem}.card-meta{flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.9rem;display:flex}.status-badge,.progress-dot{border-radius:999px;align-items:center;min-height:1.55rem;font-size:.72rem;font-weight:850;display:inline-flex}.status-badge{color:#cdd8ff;background:#5c8dff1a;border:1px solid #5c8dff52;padding:0 .65rem}.progress-dot{color:var(--teal);gap:.4rem}.progress-dot:before{content:"";background:currentColor;border-radius:50%;width:.48rem;height:.48rem;box-shadow:0 0 14px #31e3c48c}.project-actions{flex-wrap:wrap;gap:.6rem;margin-top:1rem;display:flex}.project-actions button{border:1px solid var(--line);background:var(--secondary-btn-bg);min-height:38px;color:var(--soft);cursor:not-allowed;border-radius:8px;padding:0 .8rem;font-size:.78rem;font-weight:850}.blog-panel{border-left:1px solid var(--line);padding-left:2rem}.blog-item{border:1px solid #0000;border-radius:8px;grid-template-columns:8.8rem minmax(0,1fr);gap:1.25rem;padding:1rem;transition:background .18s,border-color .18s,transform .18s;display:grid}.blog-item:hover{border-color:var(--line);background:var(--floating-card-bg);transform:translateY(-2px)}.blog-thumb{color:#fff;border-radius:8px;place-items:center;min-height:6.5rem;font-size:1.8rem;font-weight:950;display:grid}.ai-thumb{background:radial-gradient(circle,#7b4dffe6,#111729 70%)}.web-thumb{background:linear-gradient(135deg,#1d3557,#31e3c4)}.code-thumb{background:linear-gradient(135deg,#101827,#5c8dff)}time{color:var(--soft);font-size:.88rem;font-weight:700}.contact-section{padding-bottom:5rem}.contact-form{border:1px solid var(--line);background:var(--secondary-btn-bg);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;max-width:850px;padding:1rem;display:grid}.contact-form label{gap:.55rem;display:grid}.contact-form label.full{grid-column:1/-1}.contact-form span{color:var(--muted);font-weight:800}.contact-form input,.contact-form textarea{border:1px solid var(--line);background:var(--input-bg);width:100%;color:var(--text);border-radius:8px;outline:none}.contact-form input{height:48px;padding:0 .9rem}.contact-form textarea{resize:vertical;padding:.9rem}.contact-form input:focus,.contact-form textarea:focus{border-color:#5c8dffcc;box-shadow:0 0 0 3px #5c8dff24}.contact-form button{cursor:pointer;border:0;width:fit-content}.site-footer{border-top:1px solid var(--line);width:min(1240px,90vw);min-height:76px;color:var(--muted);justify-content:space-between;margin:0 auto}.thanks-page{place-items:center;min-height:100svh;padding:2rem 0;display:grid}.thanks-panel{border:1px solid var(--line);background:radial-gradient(circle at 78% 18%, #7b4dff38, transparent 18rem), var(--floating-card-bg);width:min(680px,100%);box-shadow:var(--shadow);border-radius:8px;padding:clamp(2rem,6vw,4rem)}.thanks-panel h1{max-width:12ch;margin-bottom:1rem;font-size:clamp(2.6rem,7vw,4.8rem)}.thanks-panel p:not(.eyebrow){max-width:38rem;color:var(--muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.75}@keyframes blink{50%{opacity:0}}@keyframes portraitFloat{0%,to{transform:translate(0)}50%{transform:translateY(-10px)}}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.portrait-card,.portrait-orbit{animation:none}}@media (max-width:980px){.site-header{grid-template-columns:1fr auto auto}.nav-toggle{border:1px solid var(--line);background:var(--secondary-btn-bg);width:2.65rem;height:2.65rem;color:var(--text);border-radius:8px;place-content:center;gap:.28rem;display:grid}.nav-toggle span{background:currentColor;width:1.1rem;height:2px}.site-nav,.header-cta{display:none}.header-actions{justify-self:end;display:flex}.site-header.nav-open .site-nav{border:1px solid var(--line);background:var(--header-bg);border-radius:8px;justify-content:stretch;gap:0;padding:.75rem;display:grid;position:absolute;top:72px;left:4.8vw;right:4.8vw}.site-header.nav-open .site-nav a{padding:.95rem}.hero,.about-grid,.content-grid{grid-template-columns:1fr}.hero{gap:1rem;padding-top:3rem}.hero-visual{min-height:460px}.stats{grid-template-columns:repeat(2,1fr)}.stats article:nth-child(2){border-right:0}.stats article:nth-child(-n+2){border-bottom:1px solid var(--line)}.project-list{grid-template-columns:1fr}.project-card{border-right:0;border-bottom:1px solid var(--line)}.project-card:last-child{border-bottom:0}.blog-panel{border-left:0;padding-left:0}}@media (max-width:640px){main,.site-footer{width:min(100% - 1.35rem,1240px)}.site-header{padding:0 .8rem}.brand{gap:.5rem}.brand span:last-child{text-overflow:ellipsis;white-space:nowrap;max-width:11rem;overflow:hidden}.hero{min-height:auto}h1{font-size:clamp(3rem,15vw,4.5rem)}.hero-actions{flex-direction:column;align-items:stretch}.primary-btn,.secondary-btn{width:100%}.hero-visual{min-height:385px}.portrait-orbit{width:88%;margin:auto;left:0;right:0}.portrait-card{width:78%;margin:auto;bottom:1rem;left:0;right:0}.floating-card{min-width:9.8rem;padding:.75rem}.learn-card{top:4%;right:0}.build-card{top:64%;left:0}.open-card{bottom:-2%;right:0}.stats,.contact-form{grid-template-columns:1fr}.stats article{border-right:0;border-bottom:1px solid var(--line);justify-content:flex-start}.stats article:last-child{border-bottom:0}.blog-item{grid-template-columns:1fr}.blog-thumb{min-height:5.5rem}.site-footer{flex-direction:column;justify-content:center;align-items:flex-start;gap:.55rem}}.panel-link{color:var(--blue);white-space:nowrap;font-size:.9rem;font-weight:800;transition:color .18s}.panel-link:hover{color:var(--violet)}.blog-card{border:1px solid #0000;border-radius:8px;transition:background .18s,border-color .18s,transform .18s}.blog-card:hover{border-color:var(--line);background:var(--floating-card-bg);transform:translateY(-2px)}.blog-card-inner{flex-direction:column;gap:.55rem;height:100%;padding:1rem;display:flex}.blog-card h3{color:var(--text);margin:0;font-size:1.05rem;font-weight:750;line-height:1.4}.blog-card p{color:var(--muted);margin:0;font-size:.88rem;line-height:1.55}.blog-card-date{color:var(--soft);margin-top:auto;padding-top:.5rem;font-size:.82rem;font-weight:700}.blog-index-section{max-width:820px;margin:0 auto;padding:2.5rem 0 5rem}.blog-index-hero{border-bottom:1px solid var(--line);margin-bottom:2rem;padding-bottom:2rem}.blog-index-hero-text{margin-top:1.5rem}.blog-index-heading{color:#0000;background:linear-gradient(90deg, var(--violet), #7c70ff 42%, var(--blue));-webkit-background-clip:text;background-clip:text;max-width:none;margin-bottom:.6rem;font-size:clamp(1.8rem,4vw,2.6rem);line-height:1.1}.blog-index-subtitle{color:var(--muted);max-width:48rem;margin:0;font-size:1.02rem;line-height:1.7}.blog-index-content{margin-top:2rem}.blog-index-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;display:grid}.blog-index-grid .blog-card{background:var(--panel);border-color:var(--line)}.blog-index-grid .blog-card h3{font-size:1.15rem}.blog-index-grid .blog-card p{font-size:.92rem}.blog-empty{color:var(--muted);font-size:1rem}@media (max-width:640px){.blog-index-grid{grid-template-columns:1fr}.blog-index-section{padding:1.5rem 0 3rem}}.blog-post-article{max-width:720px;margin:0 auto;padding:2.5rem 0 5rem}.blog-back-link{color:var(--muted);align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.88rem;font-weight:700;transition:color .18s;display:inline-flex}.blog-back-link:hover{color:var(--blue)}.blog-back-link svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.2px;width:1rem;height:1rem}.blog-post-header{border-bottom:1px solid var(--line);margin-bottom:2.5rem;padding-bottom:2rem}.blog-post-header h1{max-width:28ch;margin-top:1rem;margin-bottom:1.25rem;font-size:clamp(1.8rem,4.5vw,2.8rem);line-height:1.15}.blog-post-meta{color:var(--soft);flex-wrap:wrap;align-items:center;gap:1.25rem;font-size:.88rem;font-weight:700;display:flex}.blog-post-footer{border-top:1px solid var(--line);margin-top:3rem;padding-top:2rem}.blog-comments{border-top:1px solid var(--line);margin-top:3rem;padding-top:2.5rem}.blog-comments-inner{max-width:100%}.blog-comments-title{color:var(--text);margin:0 0 1.25rem;font-size:1.25rem;font-weight:750}.blog-comments-placeholder{border:1px dashed var(--line);background:var(--secondary-btn-bg);text-align:center;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.65rem;padding:2.5rem;display:flex}.comments-icon{fill:none;width:2rem;height:2rem;stroke:var(--soft);stroke-linecap:round;stroke-linejoin:round;stroke-width:1.5px;opacity:.6}.blog-comments-placeholder p{color:var(--muted);margin:0;font-size:1rem;font-weight:600}.blog-comments-placeholder span{color:var(--soft);font-size:.82rem}.prose{color:var(--muted);font-size:1.06rem;line-height:1.85}.prose>:first-child{margin-top:0}.prose h2{color:var(--text);margin-top:2.5rem;margin-bottom:.75rem;font-size:clamp(1.45rem,3vw,1.9rem);font-weight:750;line-height:1.25}.prose h3{color:var(--text);margin-top:2rem;margin-bottom:.5rem;font-size:clamp(1.15rem,2.5vw,1.45rem);font-weight:750;line-height:1.3}.prose h4{color:var(--text);margin-top:1.75rem;margin-bottom:.4rem;font-size:1.1rem;font-weight:750}.prose p{margin-top:0;margin-bottom:1.25rem}.prose a{color:var(--blue);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1px;transition:color .18s}.prose a:hover{color:var(--violet)}.prose strong{color:var(--text);font-weight:700}.prose em{font-style:italic}.prose ul,.prose ol{margin-top:0;margin-bottom:1.25rem;padding-left:1.5rem}.prose li{margin-bottom:.45rem}.prose li::marker{color:var(--violet)}.prose ol li::marker{color:var(--blue)}.prose blockquote{border-left:3px solid var(--violet);color:var(--soft);margin:1.75rem 0;padding:.1rem 0 .1rem 1.25rem;font-style:italic}.prose blockquote p{margin-bottom:0}.prose code{background:var(--panel-strong);border:1px solid var(--line);color:var(--teal);border-radius:4px;padding:.15em .4em;font-family:ui-monospace,Cascadia Code,Source Code Pro,Menlo,Monaco,Consolas,monospace;font-size:.875em}.prose pre{background:var(--panel-strong);border:1px solid var(--line);border-radius:8px;margin:1.5rem 0;padding:1.25rem;overflow-x:auto}.prose pre code{color:var(--text);background:0 0;border:none;padding:0;font-size:.875rem}.prose hr{border:none;border-top:1px solid var(--line);margin:2.5rem 0}.prose img{border-radius:8px;max-width:100%;margin:1.5rem 0}.prose-figure{flex-direction:column;gap:0;margin:2rem 0;display:flex}.prose-figure img{border:1px solid var(--line);border-bottom:none;border-radius:8px 8px 0 0;width:100%;height:auto;margin:0;display:block}.prose-figcaption{color:var(--soft);text-align:center;background:var(--panel-strong);border:1px solid var(--line);border-top:0;border-radius:0 0 8px 8px;padding:.6rem 1rem;font-size:.82rem;font-style:italic;line-height:1.4}.screenshot-link{border-radius:8px;transition:transform .18s,box-shadow .18s;display:block;position:relative;overflow:hidden;text-decoration:none!important}.screenshot-link:hover{transform:translateY(-2px);box-shadow:0 8px 32px #5c8dff2e}.screenshot-link img{border:1px solid var(--line);border-radius:8px;width:100%;height:auto;margin:0;display:block}.screenshot-cta{color:var(--blue);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#070a12c7;border:1px solid #5c8dff4d;border-radius:6px;padding:.35rem .65rem;font-size:.78rem;font-weight:750;transition:color .18s;position:absolute;bottom:.75rem;right:.75rem}.screenshot-link:hover .screenshot-cta{color:var(--violet)}.prose table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.92rem}.prose th,.prose td{border:1px solid var(--line);text-align:left;padding:.65rem .9rem}.prose th{background:var(--panel-strong);color:var(--text);font-weight:700}@media (prefers-reduced-motion:reduce){.blog-card{transition:none}}
