:root{color-scheme:dark;--bg: #101314;--bg-soft: #161a1c;--panel: #171c1f;--panel-strong: #20272b;--text: #f4f1ec;--muted: #c9c4bc;--subtle: #9a9992;--line: rgba(244, 241, 236, .13);--accent: #d85d67;--accent-soft: rgba(216, 93, 103, .16);--focus: #f0b86f;--shadow: 0 28px 80px rgba(0, 0, 0, .35);--max: 1180px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-soft: cubic-bezier(.22, 1, .36, 1)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;background:var(--bg);color:var(--text);font-family:Raleway,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6;letter-spacing:0;text-rendering:optimizeLegibility}body:after{position:fixed;inset:auto -12vw -28vh auto;z-index:0;width:46vw;height:46vw;min-width:420px;min-height:420px;pointer-events:none;background:radial-gradient(circle,rgba(216,93,103,.08),transparent 62%);content:"";opacity:.72;animation:ambientDrift 18s var(--ease-soft) infinite alternate}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}a:focus-visible,button:focus-visible{outline:2px solid var(--focus);outline-offset:5px}img{display:block;max-width:100%}main{position:relative;z-index:1}.route-frame{min-height:100vh;opacity:1;transition:opacity .18s var(--ease-out)}.route-frame.is-leaving,.route-frame.is-entering{opacity:0}.site-header{position:fixed;z-index:20;top:0;left:0;right:0;display:flex;align-items:flex-start;justify-content:space-between;gap:32px;padding:24px clamp(22px,4vw,56px);background:#101314eb;border-bottom:1px solid rgba(244,241,236,.08);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);pointer-events:auto}.brand{display:inline-flex;flex-direction:column;width:min-content;font-family:Georgia,Times New Roman,serif;font-size:clamp(1.62rem,2.5vw,2.15rem);font-weight:800;line-height:.96;letter-spacing:0;transition:color .26s var(--ease-out),transform .32s var(--ease-out)}.brand:hover{transform:translateY(-1px);color:#fff}.main-nav{display:flex;align-items:center;gap:clamp(18px,2.4vw,32px);color:var(--muted);font-size:.95rem;font-weight:600}.main-nav a{position:relative;padding-bottom:8px;transition:color .24s var(--ease-out),transform .26s var(--ease-out)}.main-nav a:after{position:absolute;left:0;right:0;bottom:0;height:2px;transform:scaleX(0);transform-origin:left;background:var(--accent);content:"";transition:transform .32s var(--ease-out)}.main-nav a:hover,.main-nav a.is-active{color:var(--text)}.main-nav a:hover{transform:translateY(-1px)}.main-nav a.is-active:after{transform:scaleX(1)}.nav-resume{border:1px solid rgba(244,241,236,.18);border-radius:999px;padding:7px 12px;color:var(--text)}.nav-resume:after{display:none}.side-rail{position:fixed;z-index:15;left:clamp(24px,3.6vw,56px);bottom:clamp(30px,7vh,78px);display:grid;gap:clamp(56px,8vh,88px);color:var(--text);pointer-events:auto}.rail-lines{display:grid;gap:12px}.rail-lines a{width:42px;height:3px;background:#f4f1ec73;transition:width .36s var(--ease-out),background .36s var(--ease-out),transform .36s var(--ease-out)}.rail-lines a.is-active{width:56px;background:var(--text);transform:translate(8px)}.scroll-label{display:flex;align-items:center;gap:10px;writing-mode:vertical-rl;text-transform:uppercase;font-size:.82rem;letter-spacing:.08em;color:var(--muted);transition:color .26s var(--ease-out),transform .36s var(--ease-out)}.scroll-label:hover{color:var(--text);transform:translateY(-3px)}.section-shell{position:relative;width:min(1320px,calc(100% - clamp(220px,18vw,340px)));margin-left:clamp(150px,12vw,230px);margin-right:auto;padding:clamp(76px,9vw,112px) 0;scroll-margin-top:50px;opacity:.72;transform:translateY(18px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out);will-change:opacity,transform}.section-shell.hero,.section-shell.is-section-visible{opacity:1;transform:translateY(0)}.hero{min-height:100svh;display:grid;grid-template-columns:minmax(560px,1fr) minmax(340px,420px);align-items:center;gap:clamp(44px,5vw,76px);padding-top:clamp(118px,10vw,146px);padding-bottom:clamp(64px,7vw,92px)}.hero-copy{max-width:820px;animation:heroCopyIn .9s var(--ease-out) both}.kicker{display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;color:var(--accent);font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.kicker:before{width:32px;height:1px;background:currentColor;content:""}h1,h2,h3,p{margin-top:0}h1{max-width:780px;margin-bottom:24px;font-size:clamp(3rem,4.5vw,5.125rem);line-height:1.05;letter-spacing:0}h2{max-width:760px;margin-bottom:20px;font-size:clamp(1.9rem,3.2vw,3.2rem);line-height:1.04;letter-spacing:0}h3{margin-bottom:12px;font-size:1.18rem;line-height:1.3}p{color:var(--muted);font-size:1.03rem;line-height:1.68}.hero-lede{max-width:720px;margin-bottom:26px;color:#d1ccc4;font-size:clamp(1.08rem,1.18vw,1.16rem);line-height:1.7}.hero-proof{display:grid;gap:9px;max-width:680px;margin:0 0 30px;padding:0;list-style:none}.hero-proof li{position:relative;padding-left:18px;color:#e1ddd6;font-size:1rem;line-height:1.55;opacity:0;transform:translateY(10px);animation:factIn .62s var(--ease-out) both}.hero-proof li:before{position:absolute;top:.72em;left:0;width:6px;height:6px;border-radius:999px;background:var(--accent);content:""}.hero-proof li:nth-child(1){animation-delay:.24s}.hero-proof li:nth-child(2){animation-delay:.34s}.hero-proof li:nth-child(3){animation-delay:.44s}.hero-actions,.contact-actions{display:flex;flex-wrap:wrap;gap:14px}.button,.contact-link{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;border:1px solid var(--line);border-radius:8px;padding:0 18px;color:#f7f3ed;font-size:1rem;font-weight:700;transition:transform .36s var(--ease-out),border-color .36s var(--ease-out),background .36s var(--ease-out),box-shadow .36s var(--ease-out)}.button:hover,.contact-link:hover{transform:translateY(-2px);border-color:#f4f1ec5c;box-shadow:0 16px 40px #00000038}.button-primary{border-color:var(--accent);background:var(--accent);color:#150f10}.button-ghost{background:#ffffff06}.hero-facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin:42px 0 0}.hero-facts div{border-top:1px solid var(--line);padding-top:16px;opacity:0;transform:translateY(10px);animation:factIn .62s var(--ease-out) both}.hero-facts div:nth-child(1){animation-delay:.28s}.hero-facts div:nth-child(2){animation-delay:.38s}.hero-facts div:nth-child(3){animation-delay:.48s}.hero-facts dt{color:var(--subtle);font-size:.78rem;text-transform:uppercase}.hero-facts dd{margin:5px 0 0;color:var(--text);font-weight:700}.hero-visual{position:relative;justify-self:end;width:min(100%,385px);animation:heroVisualIn .98s .16s var(--ease-out) both}.portrait-frame{position:relative;z-index:1;overflow:hidden;border:1px solid rgba(244,241,236,.14);border-radius:8px;background:var(--panel);box-shadow:0 20px 56px #00000047;transition:transform .7s var(--ease-out),border-color .48s var(--ease-out),box-shadow .7s var(--ease-out)}.portrait-frame:before{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(to top,rgba(16,19,20,.16),transparent 34%);content:""}.portrait-frame img{width:100%;aspect-ratio:4 / 4.9;object-fit:cover;object-position:50% 28%;transform:scale(1.01);transition:transform .9s var(--ease-soft)}.portrait-frame:hover{transform:translateY(-6px) rotate(-.35deg);border-color:#d85d675c;box-shadow:0 28px 72px #00000057}.portrait-frame:hover img{transform:scale(1.045)}.portrait-labels{position:absolute;z-index:2;left:18px;right:18px;bottom:18px;display:flex;flex-wrap:wrap;gap:8px;max-width:none}.portrait-labels span{border:1px solid rgba(244,241,236,.14);border-radius:999px;padding:8px 11px;background:#101314c7;color:#f0ece5;font-size:.78rem;font-weight:700;line-height:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hero-visual:after{position:absolute;right:-6%;bottom:-6%;width:62%;height:48%;border-radius:8px;background:var(--panel-strong);content:"";transition:transform .7s var(--ease-out),background .7s var(--ease-out)}.hero-visual:hover:after{transform:translate(10px,10px);background:#252d31}.playground-teaser-section{padding-top:clamp(54px,7vw,86px);padding-bottom:clamp(54px,7vw,86px)}.playground-teaser{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);gap:clamp(28px,5vw,70px);align-items:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(34px,5vw,58px) 0}.playground-teaser-copy,.playground-teaser-copy h2{max-width:690px}.playground-teaser-copy p{max-width:650px;margin-bottom:26px;color:#d8d2ca}.playground-mini-board{position:relative;display:grid;gap:18px;overflow:hidden;border:1px solid rgba(244,241,236,.14);border-radius:8px;padding:24px;background:linear-gradient(135deg,#f4f1ec14,#d85d6714),#ffffff06;box-shadow:0 22px 56px #00000038}.mini-board-header{display:flex;align-items:center;justify-content:space-between;gap:14px;color:#f7f3ed;font-weight:800}.mini-board-header svg{color:var(--accent)}.mini-board-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.mini-board-grid span{min-height:72px;border:1px solid rgba(244,241,236,.12);border-radius:8px;padding:14px;background:#10131452;color:#f4f1ec;font-size:.9rem;font-weight:800}.mini-board-chart{display:grid;grid-template-columns:repeat(4,1fr);align-items:end;gap:10px;height:128px;border:1px solid rgba(244,241,236,.1);border-radius:8px;padding:16px;background:#10131438}.mini-board-chart i{display:block;border-radius:999px 999px 4px 4px;background:var(--accent)}.mini-board-chart i:nth-child(1){height:42%;background:#f0b86f}.mini-board-chart i:nth-child(2){height:66%}.mini-board-chart i:nth-child(3){height:52%;background:#d1ccc4}.mini-board-chart i:nth-child(4){height:82%}.section-intro{max-width:810px;margin-bottom:clamp(32px,5vw,52px)}.section-intro p{max-width:720px;font-size:1.08rem}.panel{border:1px solid var(--line);border-radius:8px;background:#ffffff06}.work-grid,.projects-grid,.tools-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.work-card,.project-card,.tool-group{min-height:235px;padding:26px;transition:transform .42s var(--ease-out),border-color .42s var(--ease-out),background .42s var(--ease-out),box-shadow .42s var(--ease-out)}.work-card p,.tool-group p{color:#d2cdc5;font-size:.98rem;line-height:1.65}.step-number{display:inline-flex;margin-bottom:22px;color:#f4f1ec57;font-size:.82rem;font-weight:800;letter-spacing:.08em}.work-card:hover,.project-card:hover,.tool-group:hover{transform:translateY(-2px);border-color:#d85d678a;background:#d85d670b;box-shadow:0 18px 42px #00000038}.work-card svg,.project-card svg{transition:transform .42s var(--ease-out),color .42s var(--ease-out)}.work-card:hover svg,.project-card:hover svg{transform:translateY(-2px) scale(1.04)}.work-card svg,.project-card svg{margin-bottom:28px;color:var(--accent)}.timeline{display:grid;gap:22px}.timeline-item{display:grid;grid-template-columns:230px minmax(0,1fr);gap:36px}.timeline-meta{border-top:1px solid var(--line);padding-top:18px;color:var(--subtle)}.timeline-meta span,.timeline-meta strong{display:block}.timeline-meta strong{margin-top:7px;color:var(--muted)}.timeline-card{padding:28px;transition:transform .42s var(--ease-out),border-color .42s var(--ease-out),background .42s var(--ease-out)}.role-summary{color:#d1ccc4}.impact-label{display:inline-flex;margin-top:6px;color:var(--accent);font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.timeline-item:hover .timeline-card{transform:translate(4px);border-color:#f4f1ec33;background:#ffffff09}.timeline-card ul{display:grid;gap:9px;margin:22px 0 0;padding:0;list-style:none}.role-context{margin-bottom:14px;color:var(--accent);font-size:.88rem;font-weight:800}.timeline-card li{position:relative;padding-left:18px;color:#ded9d1;font-size:1rem;line-height:1.64}.timeline-card li:before{position:absolute;top:.72em;left:0;width:6px;height:6px;border-radius:999px;background:var(--accent);content:""}.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-card{position:relative;display:flex;flex-direction:column;min-height:640px}.project-card.is-clickable{color:inherit;cursor:pointer}.project-outcome{color:#e1ddd6;font-size:1.02rem;font-weight:600;line-height:1.6}.project-index{position:absolute;top:24px;right:26px;color:#f4f1ec2e;font-family:Georgia,Times New Roman,serif;font-size:2.4rem;font-weight:800;line-height:1}.project-classification{align-self:flex-start;margin-top:18px;margin-bottom:14px;color:var(--accent);font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.tag-row{display:flex;flex-wrap:wrap;gap:9px;margin-top:auto;padding-top:22px}.story-points{display:grid;gap:13px;margin:20px 0 0}.story-points div{border-top:1px solid rgba(244,241,236,.09);padding-top:12px}.story-points dt{margin-bottom:4px;color:var(--accent);font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.story-points dd{margin:0;color:#ddd7ce;font-size:.98rem;line-height:1.65}.story-points .impact-point{border:1px solid rgba(216,93,103,.24);border-radius:8px;padding:15px;background:#d85d6711}.story-points .impact-point dt{color:#ff7b86}.story-points .impact-point dd{color:#f0ece5;font-weight:600}.case-link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;color:#f6f1eb;font-size:.9rem;font-weight:800}.tag-row span{border:1px solid rgba(244,241,236,.12);border-radius:999px;padding:7px 10px;color:#e1ddd6;font-size:.86rem;line-height:1}.tools-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.tool-group{min-height:220px}.contact-section{padding-bottom:clamp(92px,14vw,170px)}.contact-layout{display:grid;grid-template-columns:minmax(0,.95fr) minmax(280px,.55fr);gap:clamp(32px,8vw,92px);align-items:end;border-top:1px solid var(--line);padding-top:clamp(42px,7vw,72px)}.contact-layout p{max-width:650px;font-size:1.08rem}.contact-actions{justify-content:flex-start}.contact-link{width:100%;justify-content:flex-start;background:#ffffff06}.project-detail{width:min(1180px,calc(100% - 48px));margin:0 auto;padding:clamp(132px,12vw,176px) 0 clamp(96px,12vw,150px)}.detail-hero{min-height:auto;padding-bottom:clamp(58px,8vw,96px)}.back-link{display:inline-flex;align-items:center;gap:10px;margin-bottom:clamp(42px,6vw,72px);color:var(--muted);font-weight:800;transition:color .26s var(--ease-out),transform .32s var(--ease-out)}.back-link:hover{color:var(--text);transform:translate(-3px)}.detail-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(290px,360px);gap:clamp(36px,7vw,92px);align-items:end}.detail-hero-copy h1{max-width:900px;font-size:clamp(3rem,6vw,6rem)}.detail-hero-copy p{max-width:780px;color:#d8d2ca;font-size:clamp(1.1rem,1.35vw,1.28rem)}.detail-meta{display:grid;gap:8px;padding:26px}.detail-meta span{color:var(--accent);font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.detail-meta strong{margin-bottom:14px;color:#f5efe8;font-size:1rem;line-height:1.5}.detail-section{padding:clamp(48px,7vw,82px) 0;border-top:1px solid rgba(244,241,236,.08)}.detail-note-section{padding-top:0}.detail-note{padding:26px 30px;border-color:#d85d673d;background:#d85d670e}.detail-note span{display:inline-flex;margin-bottom:10px;color:var(--accent);font-size:.76rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.detail-note p{max-width:940px;margin-bottom:0;color:#e3ded7;font-size:1.02rem}.detail-section-heading{max-width:760px;margin-bottom:30px}.detail-section-heading h2,.case-text h2{font-size:clamp(1.8rem,3vw,2.7rem)}.detail-section-heading p,.case-text p{color:#d6d0c8;font-size:1.05rem}.detail-screens{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.screenshot-card{overflow:hidden;background:#f8f8f8}.screenshot-card img{width:100%;aspect-ratio:16 / 9;object-fit:cover;object-position:0 0}.detail-two-column{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.case-text{padding:30px}.architecture-diagram{position:relative;display:grid;grid-template-columns:1fr 1.05fr 1fr;grid-template-rows:repeat(2,minmax(210px,auto));gap:28px 58px;min-height:470px;padding:34px;overflow:hidden}.architecture-domain{position:relative;z-index:2;display:grid;align-content:center;justify-items:center;border:1px solid rgba(244,241,236,.16);border-radius:8px;background:#ffffff06}.architecture-domain>span{position:absolute;top:16px;left:16px;color:#f4eee7;font-size:.9rem;font-weight:800;line-height:1.15}.frontend-domain{grid-column:1;grid-row:1 / 3;align-self:center;min-height:178px}.backend-domain{grid-column:2;grid-row:1 / 3}.storage-domain{grid-column:3;grid-row:1}.service-domain{grid-column:3;grid-row:2;align-content:start;gap:22px;padding:68px 22px 24px}.architecture-node,.database-node{min-width:min(82%,230px);border:1px solid rgba(244,241,236,.18);border-radius:6px;padding:20px 22px;color:#141617;font-size:1rem;font-weight:800;text-align:center;box-shadow:6px 6px #0000002e}.frontend-node{background:#dcecff}.backend-node{background:#eadbff}.service-node{background:#fff0cf}.database-node{display:grid;place-items:center;min-height:100px;border-radius:50%/18%;background:#e4f7ea}.architecture-lines{position:absolute;inset:34px;z-index:1;width:calc(100% - 68px);height:calc(100% - 68px);pointer-events:none}.architecture-lines path{fill:none;stroke:#f4f1ecb8;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;marker-end:url(#arrowhead)}.architecture-lines marker path{fill:#f4f1ecb8}.generic-architecture{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;padding:24px}.architecture-step{position:relative;min-height:230px;border:1px solid rgba(244,241,236,.1);border-radius:8px;padding:24px;background:#ffffff06}.architecture-step:after{position:absolute;top:34px;right:-17px;z-index:2;width:32px;height:1px;background:#f4f1ec3d;content:""}.architecture-step:last-child:after{display:none}.architecture-step span{display:inline-flex;margin-bottom:34px;color:#f4f1ec57;font-size:.82rem;font-weight:800}.architecture-step h3{color:#f6f1eb}.architecture-step p{margin-bottom:0;color:#d6d0c8;font-size:.98rem}.process-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.process-card{min-height:250px;padding:26px}.process-card span{display:inline-flex;margin-bottom:32px;color:#f4f1ec57;font-size:.82rem;font-weight:800}.process-card p{color:#d6d0c8;font-size:.98rem}.detail-tags{max-width:860px;margin-top:0;padding-top:0}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.metric-card{container-type:inline-size;min-height:180px;padding:26px}.metric-card strong{display:block;margin-bottom:18px;color:#fff;font-size:clamp(2rem,2.6vw,3rem);line-height:1;overflow-wrap:normal;text-wrap:balance;word-break:normal}@supports (font-size: 1cqi){.metric-card strong{font-size:clamp(2.35rem,13cqi,3.65rem)}}.metric-card span{color:#d8d2ca;font-size:.98rem;line-height:1.55}.impact-list{display:grid;gap:14px;margin-top:18px;padding:28px}.impact-list p{position:relative;margin:0;padding-left:18px;color:#e3ded7;font-size:1.02rem}.impact-list p:before{position:absolute;top:.72em;left:0;width:6px;height:6px;border-radius:999px;background:var(--accent);content:""}.ml-page{position:relative;z-index:2;min-height:100vh;background:radial-gradient(circle at 78% 8%,rgba(94,92,230,.16),transparent 34rem),radial-gradient(circle at 12% 34%,rgba(28,181,155,.13),transparent 28rem),#f7f4ee;color:#19202a;animation:mlPageIn .52s var(--ease-out) both}.ml-page main{width:min(100% - 44px,1180px);margin:0 auto;padding-bottom:80px}.ml-header{position:sticky;z-index:30;top:0;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:20px clamp(22px,4vw,54px);background:#f7f4eed1;border-bottom:1px solid rgba(25,32,42,.09);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);animation:mlHeaderIn .52s 80ms var(--ease-out) both}.ml-brand{display:inline-flex;align-items:center;gap:10px;color:#151a23;font-weight:800;transition:color .24s var(--ease-out),transform .3s var(--ease-out)}.ml-brand:hover{color:#3457ff;transform:translateY(-1px)}.ml-brand span{display:grid;place-items:center;width:38px;height:38px;border-radius:13px;background:#3457ff;color:#fff}.ml-header nav a,.ml-back-link{display:inline-flex;align-items:center;gap:8px;color:#374151;font-size:.95rem;font-weight:700;transition:color .24s var(--ease-out),transform .3s var(--ease-out)}.ml-header nav a:hover,.ml-back-link:hover{color:#111827;transform:translate(-2px)}.ml-hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);align-items:center;gap:58px;min-height:calc(100vh - 80px);padding:74px 0 56px}.ml-hero-copy{animation:mlContentUp .68s .14s var(--ease-out) both}.ml-kicker{display:inline-flex;align-items:center;gap:10px;color:#3457ff;font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.ml-hero h1,.ml-module-hero h1{max-width:760px;margin:18px 0 20px;color:#111827;font-size:4.6rem;line-height:.96}.ml-hero p,.ml-module-hero p{max-width:620px;color:#4b5563;font-size:1.18rem;line-height:1.75}.ml-actions,.ml-filter-row{display:flex;flex-wrap:wrap;gap:12px}.ml-actions{margin-top:32px}.ml-button{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:52px;border-radius:999px;padding:0 22px;font-weight:800;transition:background .26s var(--ease-out),border-color .26s var(--ease-out),box-shadow .32s var(--ease-out),color .26s var(--ease-out),transform .32s var(--ease-out)}.ml-button:hover{transform:translateY(-2px)}.ml-button:active{transform:translateY(0) scale(.98)}.ml-button-primary{background:#3457ff;color:#fff;box-shadow:0 16px 34px #3457ff3d}.ml-button-secondary{border:1px solid rgba(25,32,42,.14);background:#ffffffa8;color:#172033}.ml-button-secondary:hover{border-color:#3457ff47;background:#ffffffdb;box-shadow:0 14px 30px #2b35541a}.ml-button:disabled{cursor:not-allowed;opacity:.48;box-shadow:none}.ml-preview{position:relative;min-height:430px;border:1px solid rgba(25,32,42,.09);border-radius:30px;background:linear-gradient(135deg,#ffffffeb,#ecf4ffeb),#fff;box-shadow:0 30px 80px #2b35542e;overflow:hidden;animation:mlPreviewIn .78s .22s var(--ease-out) both;transition:box-shadow .42s var(--ease-out),transform .52s var(--ease-out)}.ml-preview:hover{box-shadow:0 34px 90px #2b355438;transform:translateY(-4px)}.ml-preview:before{position:absolute;inset:36px;border:1px dashed rgba(52,87,255,.22);border-radius:24px;content:""}.ml-preview-card,.ml-chart-card,.ml-dot-field{position:absolute;border:1px solid rgba(25,32,42,.1);border-radius:22px;background:#ffffffe0;box-shadow:0 18px 46px #2b355424}.ml-preview-card{top:54px;left:48px;display:grid;gap:16px;width:156px;padding:22px;color:#3457ff;font-weight:900;animation:mlFloat 5.2s var(--ease-soft) infinite alternate}.ml-dot-field{top:104px;right:46px;width:220px;height:178px;animation:mlFloat 6.4s .42s var(--ease-soft) infinite alternate}.ml-dot-field .dot{position:absolute;width:16px;height:16px;border-radius:999px;animation:mlDotPulse 2.8s var(--ease-soft) infinite}.dot-blue{background:#3457ff}.dot-coral{background:#ff6b6b}.ml-dot-field .dot:nth-child(1){top:36px;left:42px}.ml-dot-field .dot:nth-child(2){top:34px;right:46px}.ml-dot-field .dot:nth-child(3){bottom:40px;left:68px}.ml-dot-field .dot:nth-child(4){right:72px;bottom:48px}.boundary-line{position:absolute;inset:36px auto auto 102px;width:4px;height:112px;border-radius:999px;background:#1cb59b;transform:rotate(20deg);transform-origin:center;animation:mlBoundarySweep 4.8s var(--ease-soft) infinite alternate}.ml-chart-card{left:88px;right:64px;bottom:54px;display:grid;gap:8px;padding:20px;color:#6d5dfc;font-weight:900;animation:mlFloat 5.8s .18s var(--ease-soft) infinite alternate}.ml-chart-card svg{width:100%;height:92px}.ml-chart-card path{fill:none;stroke:#6d5dfc;stroke-linecap:round;stroke-width:6;stroke-dasharray:205;stroke-dashoffset:205;animation:mlLineDraw 1.25s .64s var(--ease-out) both}.ml-chart-card circle{fill:#ffb84d}.ml-section,.ml-footer-cta,.ml-module-page{padding:66px 0}[data-ml-reveal]{opacity:0;transform:translateY(26px);transition:opacity .72s var(--ease-out) var(--ml-reveal-delay, 0ms),transform .72s var(--ease-out) var(--ml-reveal-delay, 0ms);will-change:opacity,transform}[data-ml-reveal].is-visible{opacity:1;transform:translateY(0)}.ml-section-heading{max-width:680px;margin-bottom:26px}.ml-section-heading h2,.ml-footer-cta h2,.ml-mission-card h2,.ml-play-placeholder h2{margin:12px 0;color:#111827;font-size:2.4rem;line-height:1.08}.ml-steps,.ml-featured-grid,.ml-module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.ml-step-card,.ml-module-card,.ml-footer-cta,.ml-mission-card,.ml-play-placeholder,.ml-result-card,.ml-completion-card,.ml-lesson-card,.ml-next-card,.ml-module-status{border:1px solid rgba(25,32,42,.1);border-radius:24px;background:#ffffffbd;box-shadow:0 18px 48px #2b35541a;transition:background .32s var(--ease-out),border-color .32s var(--ease-out),box-shadow .36s var(--ease-out),transform .36s var(--ease-out)}.ml-step-card:hover,.ml-mission-card:hover,.ml-result-card:hover,.ml-lesson-card:hover,.ml-next-card:hover,.ml-module-status:hover{border-color:#3457ff38;background:#ffffffe6;box-shadow:0 22px 54px #2b355421;transform:translateY(-3px)}.ml-step-card{padding:24px}.ml-step-card span{color:#3457ff8a;font-weight:900}.ml-step-card h3,.ml-module-card h3{color:#111827}.ml-step-card p,.ml-module-card p,.ml-footer-cta p,.ml-mission-card p,.ml-play-placeholder p,.ml-result-card p,.ml-lesson-card p{color:#4b5563}.ml-module-card{display:grid;gap:14px;min-height:280px;padding:24px;transition:background .28s var(--ease-out),border-color .28s var(--ease-out),box-shadow .32s var(--ease-out),opacity .28s var(--ease-out),transform .32s var(--ease-out)}.ml-module-card.is-playable:hover{border-color:#3457ff52;box-shadow:0 22px 54px #3457ff29;transform:translateY(-4px)}.ml-module-card.is-playable:active{transform:translateY(-1px) scale(.99)}.ml-module-card.is-locked{opacity:.72}.ml-module-card.is-locked .ml-card-meta span:last-child{background:#ffb84d24;color:#9a5a00}.ml-module-card.is-locked:not(.is-visible){opacity:0}.ml-module-card.is-locked.is-visible{opacity:.72}.ml-module-card.is-featured:first-child{background:linear-gradient(135deg,#fff,#eef3ff)}.ml-module-topline,.ml-card-meta{display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between}.ml-module-topline span,.ml-card-meta span,.ml-module-status span,.ml-result-card span,.ml-mission-card span,.ml-completion-card span,.ml-lesson-card span,.ml-next-card span{color:#3457ff;font-size:.76rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.ml-card-meta span,.ml-module-topline span{display:inline-flex;border-radius:999px;padding:6px 10px;background:#3457ff14}.ml-filter-row{margin-bottom:22px}.ml-filter-row button{flex:1 1 240px;border:1px solid rgba(25,32,42,.1);border-radius:22px;padding:18px;background:#fff9;color:#1f2937;text-align:left;cursor:pointer;transition:background .26s var(--ease-out),border-color .26s var(--ease-out),box-shadow .32s var(--ease-out),transform .32s var(--ease-out)}.ml-filter-row button:hover{border-color:#3457ff3d;background:#ffffffd6;transform:translateY(-2px)}.ml-filter-row button strong,.ml-filter-row button span{display:block}.ml-filter-row button span{margin-top:6px;color:#5b6573;font-size:.92rem}.ml-filter-row button.is-active{border-color:#3457ff61;background:#fff;box-shadow:0 16px 38px #3457ff21;transform:translateY(-2px)}.ml-module-grid{animation:mlContentSwap .36s var(--ease-out) both}.ml-footer-cta{display:flex;align-items:center;justify-content:space-between;gap:26px;margin:30px 0 0;padding:30px}.ml-path-summary{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.8fr);gap:22px;align-items:center;border:1px solid rgba(25,32,42,.1);border-radius:24px;margin-top:10px;padding:28px;background:linear-gradient(135deg,#ffffffd1,#eef3ffe6);box-shadow:0 18px 48px #2b35541a}.ml-path-summary h2{margin:10px 0;color:#111827;font-size:2rem;line-height:1.08}.ml-path-summary p{margin:0;color:#4b5563}.ml-path-summary.is-complete{border-color:#1cb59b4d;background:linear-gradient(135deg,#e8fff9eb,#ffffffe6)}.ml-path-badges{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.ml-path-badges span{border:1px solid rgba(25,32,42,.1);border-radius:999px;padding:8px 12px;background:#ffffffbd;color:#64748b;font-size:.82rem;font-weight:900}.ml-path-badges span.is-complete{border-color:#1cb59b52;background:#1cb59b1f;color:#0e695a}.ml-module-page{padding-top:42px;animation:mlContentUp .56s 90ms var(--ease-out) both}.ml-back-link{margin-bottom:32px}.ml-module-hero{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:28px;align-items:end;padding-bottom:44px}.ml-module-hero>div:first-child{animation:mlContentUp .64s .12s var(--ease-out) both}.ml-module-status{animation:mlContentUp .64s .19s var(--ease-out) both}.ml-module-status{padding:22px}.ml-module-status strong{display:block;margin-top:6px;color:#111827;font-size:1.4rem}.ml-module-shell{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(300px,.65fr);gap:18px;padding-bottom:80px}.ml-mission-card,.ml-play-placeholder,.ml-result-card,.ml-completion-card,.ml-lesson-card,.ml-next-card{padding:24px}.ml-play-placeholder{display:grid;place-items:center;min-height:330px;text-align:center}.ml-result-card,.ml-completion-card,.ml-next-card{display:flex;align-items:center;gap:14px}.ml-lesson-card{display:grid;gap:12px;animation:mlLessonIn .36s var(--ease-out) var(--ml-reveal-delay, 0ms) both}.ml-lesson-list{display:grid;gap:10px}.ml-lesson-list p{margin:0;line-height:1.55}.ml-lesson-list strong{color:#111827}.ml-completion-card strong,.ml-next-card strong{display:block;color:#111827}.ml-next-card{justify-content:space-between}.ml-module-shell.is-teach-module{grid-template-columns:minmax(0,1.2fr) minmax(310px,.8fr)}.ml-module-shell.is-separate-module,.ml-module-shell.is-regression-module{grid-template-columns:minmax(0,1.22fr) minmax(300px,.78fr)}.ml-module-shell.is-teach-module .ml-mission-card,.ml-teach-board,.ml-module-shell.is-separate-module .ml-mission-card,.ml-module-shell.is-regression-module .ml-mission-card,.ml-boundary-board,.ml-regression-board{grid-column:1}.ml-test-panel,.ml-module-shell.is-teach-module .ml-result-card,.ml-module-shell.is-teach-module .ml-completion-card,.ml-module-shell.is-teach-module .ml-lesson-card,.ml-module-shell.is-teach-module .ml-next-card,.ml-score-panel,.ml-module-shell.is-separate-module .ml-result-card,.ml-module-shell.is-separate-module .ml-completion-card,.ml-module-shell.is-separate-module .ml-lesson-card,.ml-module-shell.is-separate-module .ml-next-card,.ml-module-shell.is-regression-module .ml-result-card,.ml-module-shell.is-regression-module .ml-completion-card,.ml-module-shell.is-regression-module .ml-lesson-card{grid-column:2}.ml-teach-board,.ml-test-panel,.ml-boundary-board,.ml-regression-board,.ml-score-panel{border:1px solid rgba(25,32,42,.1);border-radius:24px;padding:24px;background:#ffffffc7;box-shadow:0 18px 48px #2b35541a;transition:border-color .32s var(--ease-out),box-shadow .36s var(--ease-out),transform .36s var(--ease-out)}.ml-teach-board:hover,.ml-test-panel:hover,.ml-boundary-board:hover,.ml-regression-board:hover,.ml-score-panel:hover{border-color:#3457ff33;box-shadow:0 24px 58px #2b355421;transform:translateY(-3px)}.ml-board-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}.ml-board-heading h2,.ml-test-panel h2,.ml-score-panel h2{margin:8px 0 0;color:#111827;font-size:1.8rem;line-height:1.1}.ml-board-heading strong{display:grid;place-items:center;min-width:64px;height:42px;border-radius:999px;background:#3457ff1a;color:#3457ff}.ml-training-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.ml-dot-playfield{position:relative;border:1px solid rgba(25,32,42,.09);border-radius:22px;padding:12px;background:linear-gradient(rgba(52,87,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,107,107,.06) 1px,transparent 1px),#fff;background-size:22px 22px;box-shadow:inset 0 0 0 1px #ffffffb3}.ml-dot-playfield svg{display:block;width:100%;aspect-ratio:1.25;overflow:visible}.ml-boundary-line{stroke:url(#boundaryGradient);stroke-linecap:round;stroke-width:2.2;filter:drop-shadow(0 4px 8px rgba(52,87,255,.2));transition:y1 .22s var(--ease-out),y2 .22s var(--ease-out)}.ml-class-dot circle{stroke:#fffffff0;stroke-width:1.6;transition:opacity .24s var(--ease-out),r .24s var(--ease-out),stroke .24s var(--ease-out),transform .24s var(--ease-out)}.ml-class-dot.is-blue circle{fill:#3457ff}.ml-class-dot.is-coral circle{fill:#ff6b6b}.ml-class-dot.is-missed circle{opacity:.72;stroke:#111827;stroke-width:2}.ml-class-dot path{fill:none;stroke:#111827;stroke-linecap:round;stroke-width:1.2;animation:mlPredictionIn .26s var(--ease-out) both}.ml-boundary-controls{display:grid;gap:14px;margin-top:18px}.ml-boundary-controls label{display:grid;grid-template-columns:68px minmax(0,1fr) 56px;align-items:center;gap:12px;color:#334155;font-weight:800}.ml-boundary-controls label span,.ml-boundary-controls label strong{font-size:.85rem}.ml-boundary-controls input[type=range]{width:100%;accent-color:#3457ff;cursor:pointer}.ml-boundary-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.ml-score-panel{display:grid;align-self:start;gap:14px}.ml-score-panel p{margin:0;color:#4b5563}.ml-accuracy-meter{height:12px;overflow:hidden;border-radius:999px;background:#19202a17}.ml-accuracy-meter i{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#ffb84d,#1cb59b);transition:width .32s var(--ease-out)}.ml-price-chart{position:relative;border:1px solid rgba(25,32,42,.09);border-radius:22px;padding:12px;background:linear-gradient(rgba(109,93,252,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(28,181,155,.06) 1px,transparent 1px),#fff;background-size:22px 22px}.ml-price-chart svg{display:block;width:100%;aspect-ratio:1.25;overflow:visible}.ml-chart-axis{stroke:#19202a3d;stroke-linecap:round;stroke-width:1.1}.ml-user-line,.ml-model-line{stroke-linecap:round;stroke-width:2.6;transition:x1 .24s var(--ease-out),x2 .24s var(--ease-out),y1 .24s var(--ease-out),y2 .24s var(--ease-out)}.ml-user-line{stroke:#3457ff;filter:drop-shadow(0 4px 8px rgba(52,87,255,.22))}.ml-model-line{stroke:#1cb59b;stroke-dasharray:4 4;animation:mlLineDraw .52s var(--ease-out) both}.ml-price-point circle{fill:#ffb84d;stroke:#fff;stroke-width:1.5;filter:drop-shadow(0 3px 6px rgba(99,74,38,.18))}.ml-chart-labels{display:flex;justify-content:space-between;gap:12px;margin-top:10px;color:#64748b;font-size:.82rem;font-weight:800}.ml-error-comparison{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.ml-error-comparison div{border:1px solid rgba(25,32,42,.09);border-radius:18px;padding:14px;background:#ffffffbd}.ml-error-comparison span{display:block;color:#64748b;font-size:.78rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.ml-error-comparison strong{display:block;margin-top:4px;color:#111827;font-size:1.45rem}.ml-training-card{border:1px solid rgba(25,32,42,.09);border-radius:20px;padding:18px;background:#fff;transition:background .26s var(--ease-out),border-color .26s var(--ease-out),box-shadow .32s var(--ease-out),transform .32s var(--ease-out)}.ml-training-card:hover,.ml-training-card.has-label{border-color:#3457ff33;box-shadow:0 14px 32px #2b355417;transform:translateY(-2px)}.ml-training-card.has-label{background:linear-gradient(135deg,#fff,#eef3ff)}.ml-training-icon{display:grid;place-items:center;width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,#eef3ff,#e9fbf6);color:#3457ff;font-size:1.65rem;font-weight:900;transition:background .26s var(--ease-out),color .26s var(--ease-out),transform .32s var(--ease-out)}.ml-food-icon{position:relative;overflow:hidden;background:linear-gradient(135deg,#fff7ed,#eef7ff)}.ml-food-icon span,.ml-food-icon:before,.ml-food-icon:after{position:absolute;display:block;content:""}.ml-food-icon.is-apple span,.ml-food-icon.is-tomato span{width:28px;height:28px;border-radius:45% 45% 52% 52%;background:#df4351;box-shadow:inset -7px -7px #7c202b29,7px 6px #ffffff40}.ml-food-icon.is-tomato span{border-radius:50%;background:#f06452}.ml-food-icon.is-apple:before,.ml-food-icon.is-tomato:before{top:13px;width:13px;height:7px;border-radius:50% 0;background:#3fa66d;transform:rotate(-18deg)}.ml-food-icon.is-banana span{width:34px;height:24px;border-right:9px solid #f2c94c;border-bottom:8px solid #f2c94c;border-radius:50%;transform:rotate(-28deg)}.ml-food-icon.is-banana:before{right:14px;bottom:13px;width:5px;height:5px;border-radius:50%;background:#74522a}.ml-food-icon.is-carrot span{top:19px;width:18px;height:28px;border-radius:70% 20% 80% 30%;background:#f68b31;transform:rotate(42deg);box-shadow:inset -5px -4px #a04a1229}.ml-food-icon.is-carrot:before,.ml-food-icon.is-broccoli:before,.ml-food-icon.is-spinach:before{top:10px;width:20px;height:16px;border-radius:70% 30%;background:#3fa66d;transform:rotate(-22deg)}.ml-food-icon.is-broccoli span{width:30px;height:24px;border-radius:50%;background:radial-gradient(circle at 25% 45%,#2f8f62 0 7px,transparent 8px),radial-gradient(circle at 52% 30%,#43af75 0 8px,transparent 9px),radial-gradient(circle at 75% 50%,#2f8f62 0 7px,transparent 8px)}.ml-food-icon.is-broccoli:after{bottom:13px;width:8px;height:19px;border-radius:999px;background:#68b77f}.ml-food-icon.is-strawberry span{top:19px;width:27px;height:30px;border-radius:58% 58% 70% 70%;background:radial-gradient(circle at 35% 38%,#ffe2a8 0 1px,transparent 2px),radial-gradient(circle at 61% 55%,#ffe2a8 0 1px,transparent 2px),#e83f59;transform:rotate(45deg)}.ml-food-icon.is-strawberry:before{top:9px;width:20px;height:12px;border-radius:70% 30%;background:#3fa66d}.ml-food-icon.is-cucumber span{width:35px;height:18px;border-radius:999px;background:radial-gradient(circle at 24% 50%,rgba(255,255,255,.55) 0 2px,transparent 3px),radial-gradient(circle at 52% 50%,rgba(255,255,255,.55) 0 2px,transparent 3px),#4fa568;transform:rotate(-18deg)}.ml-food-icon.is-potato span{width:31px;height:25px;border-radius:48% 55% 45% 58%;background:radial-gradient(circle at 31% 36%,rgba(112,80,45,.48) 0 2px,transparent 3px),radial-gradient(circle at 62% 58%,rgba(112,80,45,.38) 0 2px,transparent 3px),#c79a62;transform:rotate(-12deg)}.ml-food-icon.is-blueberry span{width:31px;height:31px;border-radius:50%;background:radial-gradient(circle at 50% 40%,#29366f 0 4px,transparent 5px),#4b63c9;box-shadow:inset -7px -7px #202c783d}.ml-food-icon.is-spinach span{width:29px;height:36px;border-radius:90% 10%;background:linear-gradient(125deg,transparent 48%,rgba(255,255,255,.42) 49% 52%,transparent 53%),#3da66d;transform:rotate(35deg)}.ml-training-card:hover .ml-training-icon,.ml-test-object:hover .ml-training-icon{transform:scale(1.05) rotate(-2deg)}.ml-training-card h3,.ml-test-object h3{margin:14px 0 4px;color:#111827}.ml-training-card p,.ml-test-object p{margin:0;color:#596272;font-size:.92rem}.ml-label-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.ml-label-actions button,.ml-small-action{border:1px solid rgba(25,32,42,.12);border-radius:999px;padding:9px 10px;background:#fff;color:#2f3947;font-weight:800;cursor:pointer;transition:background .24s var(--ease-out),border-color .24s var(--ease-out),color .24s var(--ease-out),transform .26s var(--ease-out)}.ml-label-actions button:hover,.ml-small-action:hover{transform:translateY(-1px)}.ml-label-actions button.is-selected{border-color:#3457ff75;background:#3457ff1a;color:#3457ff;animation:mlSelectPop .24s var(--ease-out)}.ml-train-button{margin-top:18px}.ml-test-panel{display:grid;gap:16px;align-self:start}.ml-test-object{display:flex;align-items:center;gap:14px;border:1px solid rgba(25,32,42,.09);border-radius:20px;padding:16px;background:#fff;animation:mlContentSwap .32s var(--ease-out) both;transition:border-color .26s var(--ease-out),box-shadow .32s var(--ease-out),transform .32s var(--ease-out)}.ml-test-object:hover{border-color:#3457ff2e;box-shadow:0 14px 32px #2b355417;transform:translateY(-2px)}.ml-thinking-card{display:flex;align-items:center;gap:10px;border:1px solid rgba(52,87,255,.16);border-radius:18px;padding:13px 14px;background:linear-gradient(135deg,#3457ff1a,#1cb59b1c);color:#26344f;font-weight:800;animation:mlPredictionIn .26s var(--ease-out) both}.ml-thinking-card svg{flex:0 0 auto;color:#3457ff;animation:mlThinkBob .7s var(--ease-soft) infinite alternate}.ml-thinking-card i{display:inline-flex;width:28px;height:8px;margin-left:auto;border-radius:999px;background:radial-gradient(circle,#3457ff 0 3px,transparent 4px) 0 50% / 9px 8px repeat-x;animation:mlThinkingDots .76s steps(3,end) infinite}.ml-prediction{border-radius:18px;padding:14px;background:#ffb84d29;color:#65410d;font-weight:700;animation:mlPredictionIn .34s var(--ease-out) both}.ml-prediction.is-correct{background:#1cb59b29;color:#0e695a}.ml-prediction.is-wrong{background:#ff6b6b29;color:#8b2f2f}.ml-small-action{justify-self:start}.ml-completion-card.is-complete{border-color:#1cb59b52;background:#e8fff9db;animation:mlCompletePulse .52s var(--ease-out)}[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .82s var(--ease-out) var(--reveal-delay, 0ms),transform .82s var(--ease-out) var(--reveal-delay, 0ms);will-change:opacity,transform}[data-reveal].is-visible{opacity:1;transform:translateY(0)}@keyframes heroCopyIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes heroVisualIn{0%{opacity:0;transform:translateY(28px) scale(.975)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes factIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes mlPageIn{0%{opacity:0}to{opacity:1}}@keyframes mlHeaderIn{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes mlContentUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes mlPreviewIn{0%{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes mlContentSwap{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes mlPredictionIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes mlLessonIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes mlThinkBob{0%{transform:translateY(1px) rotate(-2deg)}to{transform:translateY(-2px) rotate(2deg)}}@keyframes mlThinkingDots{0%{background-position-x:-18px}to{background-position-x:9px}}@keyframes mlSelectPop{0%{transform:scale(1)}55%{transform:scale(1.035)}to{transform:scale(1)}}@keyframes mlCompletePulse{0%{transform:scale(1);box-shadow:0 18px 48px #2b35541a}45%{transform:scale(1.015);box-shadow:0 24px 58px #1cb59b33}to{transform:scale(1);box-shadow:0 18px 48px #2b35541a}}@keyframes mlFloat{0%{transform:translateY(0)}to{transform:translateY(-8px)}}@keyframes mlDotPulse{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}@keyframes mlBoundarySweep{0%{transform:rotate(16deg) translate(-6px)}to{transform:rotate(24deg) translate(6px)}}@keyframes mlLineDraw{to{stroke-dashoffset:0}}@keyframes ambientDrift{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(-6vw,-4vh,0) scale(1.08)}}@media(max-width:1180px){.section-shell{width:min(100% - 210px,900px);margin-left:150px;margin-right:32px}.hero,.contact-layout,.playground-teaser,.ml-hero,.ml-module-shell,.ml-module-shell.is-teach-module,.ml-module-shell.is-separate-module,.ml-module-shell.is-regression-module{grid-template-columns:1fr}.ml-module-shell.is-teach-module .ml-mission-card,.ml-module-shell.is-separate-module .ml-mission-card,.ml-module-shell.is-regression-module .ml-mission-card,.ml-teach-board,.ml-test-panel,.ml-boundary-board,.ml-regression-board,.ml-score-panel,.ml-module-shell.is-teach-module .ml-result-card,.ml-module-shell.is-teach-module .ml-completion-card,.ml-module-shell.is-teach-module .ml-lesson-card,.ml-module-shell.is-teach-module .ml-next-card,.ml-module-shell.is-separate-module .ml-result-card,.ml-module-shell.is-separate-module .ml-completion-card,.ml-module-shell.is-separate-module .ml-lesson-card,.ml-module-shell.is-separate-module .ml-next-card,.ml-module-shell.is-regression-module .ml-result-card,.ml-module-shell.is-regression-module .ml-completion-card,.ml-module-shell.is-regression-module .ml-lesson-card{grid-column:1}.hero-visual{justify-self:start;max-width:430px}.ml-preview{max-width:560px}.work-grid,.projects-grid,.process-list,.generic-architecture,.metric-grid,.ml-steps,.ml-featured-grid,.ml-module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-hero-grid{grid-template-columns:1fr}.architecture-step:after{display:none}}@media(max-width:920px){.side-rail{display:none}.section-shell{width:min(100% - 48px,720px);margin-left:auto;margin-right:auto}}@media(max-width:820px){.site-header{position:sticky;align-items:center;padding:18px 20px;background:#101314db;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.brand{font-size:1.42rem}.main-nav{max-width:64vw;overflow-x:auto;gap:18px;scrollbar-width:none;white-space:nowrap}.main-nav::-webkit-scrollbar{display:none}.section-shell{width:min(100% - 36px,680px);margin-left:auto;margin-right:auto;padding:82px 0}.hero{min-height:auto;padding-top:54px}h1{font-size:clamp(2.7rem,14vw,4.5rem)}.hero-facts,.work-grid,.projects-grid,.tools-grid,.detail-screens,.detail-two-column,.process-list,.generic-architecture,.metric-grid,.timeline-item{grid-template-columns:1fr}.timeline-item{gap:14px}.hero-visual{width:min(100%,430px)}.portrait-labels{position:relative;left:auto;bottom:auto;margin-top:14px;max-width:none}.hero-visual:after{right:-4%;bottom:-4%}.project-detail{width:min(100% - 36px,680px);padding-top:72px}.playground-mini-board{max-width:520px}.architecture-diagram{grid-template-columns:1fr;grid-template-rows:auto;gap:18px;min-height:auto;padding:18px}.frontend-domain,.backend-domain,.storage-domain,.service-domain{grid-column:1;grid-row:auto;min-height:170px}.architecture-lines{display:none}.ml-page main{width:min(100% - 36px,680px)}.ml-header{padding:16px 18px}.ml-hero{min-height:auto;padding:54px 0}.ml-hero h1,.ml-module-hero h1{font-size:3.4rem}.ml-steps,.ml-featured-grid,.ml-module-grid,.ml-module-hero{grid-template-columns:1fr}.ml-footer-cta{align-items:flex-start;flex-direction:column}.ml-path-summary{grid-template-columns:1fr}.ml-path-badges{justify-content:flex-start}.ml-module-shell.is-teach-module .ml-mission-card,.ml-module-shell.is-separate-module .ml-mission-card,.ml-module-shell.is-regression-module .ml-mission-card,.ml-teach-board,.ml-test-panel,.ml-boundary-board,.ml-regression-board,.ml-score-panel,.ml-module-shell.is-teach-module .ml-result-card,.ml-module-shell.is-teach-module .ml-completion-card,.ml-module-shell.is-teach-module .ml-lesson-card,.ml-module-shell.is-teach-module .ml-next-card,.ml-module-shell.is-separate-module .ml-result-card,.ml-module-shell.is-separate-module .ml-completion-card,.ml-module-shell.is-separate-module .ml-lesson-card,.ml-module-shell.is-separate-module .ml-next-card,.ml-module-shell.is-regression-module .ml-result-card,.ml-module-shell.is-regression-module .ml-completion-card,.ml-module-shell.is-regression-module .ml-lesson-card{grid-column:1}}@media(max-width:520px){.site-header{gap:16px}.main-nav{font-size:.88rem}.section-shell{width:min(100% - 28px,420px)}.hero-actions,.contact-actions,.ml-actions{display:grid;grid-template-columns:1fr}.button,.contact-link,.ml-button{width:100%}.work-card,.project-card,.tool-group,.timeline-card,.case-text,.detail-note,.generic-architecture,.architecture-step,.process-card,.metric-card,.impact-list{padding:22px}.detail-hero-copy h1{font-size:clamp(2.55rem,14vw,4.2rem)}.ml-page main{width:min(100% - 28px,420px)}.ml-hero h1,.ml-module-hero h1{font-size:2.8rem}.ml-preview{min-height:360px}.mini-board-grid{grid-template-columns:1fr}.mini-board-grid span{min-height:58px}.ml-preview-card{top:38px;left:26px}.ml-dot-field{top:118px;right:24px;width:180px;height:142px}.ml-chart-card{left:26px;right:26px;bottom:32px}.ml-section-heading h2,.ml-footer-cta h2,.ml-mission-card h2,.ml-play-placeholder h2{font-size:2rem}.ml-training-grid{grid-template-columns:1fr}.ml-boundary-controls label{grid-template-columns:1fr;gap:8px}.ml-boundary-controls label strong{justify-self:start}.ml-error-comparison{grid-template-columns:1fr}.ml-test-object{align-items:flex-start;flex-direction:column}}@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],[data-ml-reveal],.section-shell{opacity:1;transform:none}body:after{display:none}}
