:root{--md-primary:#6750A4;--md-on-primary:#fff;--md-primary-container:#EADDFF;--md-on-primary-container:#21005D;--md-secondary:#625B71;--md-on-secondary:#fff;--md-secondary-container:#E8DEF8;--md-on-secondary-container:#1D192B;--md-tertiary:#7D5260;--md-on-tertiary:#fff;--md-tertiary-container:#FFD8E4;--md-on-tertiary-container:#31111D;--md-surface:#FEF7FF;--md-surface-variant:#E7E0EC;--md-on-surface:#1D1B20;--md-on-surface-variant:#49454F;--md-outline:#79747E;--md-outline-variant:#CAC4D0;--md-surface-container-lowest:#fff;--md-surface-container-low:#F7F2FA;--md-surface-container:#F3EDF7;--md-surface-container-high:#ECE6F0;--md-surface-container-highest:#E6E0E9;--md-spring: cubic-bezier(.2,1,.2,1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:DM Sans,Google Sans,system-ui,-apple-system,sans-serif;background:var(--md-surface);color:var(--md-on-surface);line-height:1.7;-webkit-font-smoothing:antialiased}.ln-nav{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--md-surface) 85%,transparent);backdrop-filter:blur(24px) saturate(1.6);padding:0 24px}.ln-nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}.ln-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--md-on-surface);font-weight:800;font-size:17px}.ln-logo-icon{width:36px;height:36px;background:var(--md-primary);border-radius:12px;display:flex;align-items:center;justify-content:center;transition:transform .4s var(--md-spring)}.ln-logo:hover .ln-logo-icon{transform:scale(1.08) rotate(-4deg)}.ln-logo span{font-weight:400;color:var(--md-on-surface-variant)}.ln-nav-links{display:flex;gap:4px;align-items:center}.ln-nav-links a{font-size:13px;font-weight:600;color:var(--md-on-surface-variant);text-decoration:none;padding:8px 16px;border-radius:100px;transition:all .3s var(--md-spring);border:1.5px solid transparent}.ln-nav-links a:hover{color:var(--md-on-surface);background:var(--md-surface-container-high)}.ln-nav-links a:not(.ln-cta):not([style*=color]){border-color:transparent}.ln-cta{background:var(--md-primary)!important;color:var(--md-on-primary)!important;font-weight:700!important;border-radius:100px!important;border-color:transparent!important}.ln-cta:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 6px 20px color-mix(in srgb,var(--md-primary) 35%,transparent)}.ln-hero{position:relative;overflow:hidden;padding:64px 24px 56px;text-align:center}.ln-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(160deg,var(--md-on-primary-container) 0%,color-mix(in srgb,var(--md-primary) 80%,#000) 40%,var(--md-primary) 100%)}.ln-hero:after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(255,255,255,.08) 0%,transparent 70%);pointer-events:none}.ln-hero>*{position:relative;z-index:1}.ln-breadcrumb{font-size:12px;color:#ffffff59;margin-bottom:20px}.ln-breadcrumb a{color:#ffffff80;text-decoration:none;transition:color .3s var(--md-spring)}.ln-breadcrumb a:hover{color:#fff}.ln-hero h1{font-size:clamp(30px,5vw,48px);font-weight:800;color:#fff;letter-spacing:-.03em;margin-bottom:14px;line-height:1.12}.ln-hero p{font-size:17px;color:#ffffffb3;max-width:620px;margin:0 auto;line-height:1.65}.ln-article{max-width:840px;margin:-32px auto 0;padding:0 24px 72px;position:relative;z-index:1}.ln-card{background:var(--md-surface-container-lowest);border-radius:28px;padding:52px;box-shadow:0 1px 3px #00000005,0 12px 48px #0000000d}.ln-card h2{font-size:25px;font-weight:800;color:var(--md-on-surface);margin:48px 0 18px;padding-bottom:16px;border-bottom:2px solid var(--md-surface-container-high);letter-spacing:-.025em;position:relative}.ln-card h2:before{content:"";position:absolute;bottom:-2px;left:0;width:52px;height:2px;background:var(--md-primary);border-radius:2px}.ln-card h2:first-child{margin-top:0}.ln-card h3{font-size:18px;font-weight:800;color:var(--md-on-surface);margin:36px 0 12px;padding-left:16px;border-left:4px solid var(--md-primary);border-radius:0 4px 4px 0}.ln-card p{font-size:15px;color:var(--md-on-surface-variant);margin-bottom:16px;line-height:1.8}.ln-card a{color:var(--md-primary);text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--md-primary) 30%,transparent);transition:text-decoration-color .3s var(--md-spring)}.ln-card a:hover{text-decoration-color:var(--md-primary)}.ln-card strong{color:var(--md-on-surface)}.ln-card ul,.ln-card ol{padding-left:24px;margin-bottom:16px}.ln-card li{font-size:15px;color:var(--md-on-surface-variant);margin-bottom:8px;line-height:1.7}.ln-card blockquote{border-left:4px solid var(--md-primary);padding:16px 20px;margin:20px 0;background:var(--md-surface-container-low);border-radius:0 20px 20px 0;font-style:italic;color:var(--md-on-surface-variant)}.ln-card code{background:var(--md-surface-container-high);padding:2px 7px;border-radius:8px;font-family:JetBrains Mono,monospace;font-size:13px;color:var(--md-on-surface)}.ln-card table,.ln-table{width:100%;border-collapse:separate;border-spacing:0;margin:20px 0;font-size:14px;border-radius:20px;overflow:hidden;background:var(--md-surface-container-low)}.ln-card th,.ln-table th{background:var(--md-surface-container-high);padding:14px 18px;text-align:left;font-weight:700;color:var(--md-on-surface);border-bottom:1px solid var(--md-outline-variant);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.ln-card td,.ln-table td{padding:12px 18px;border-bottom:1px solid var(--md-surface-container-high);color:var(--md-on-surface-variant)}.ln-card tr:last-child td,.ln-table tr:last-child td{border-bottom:none}.ln-card tr:hover td,.ln-table tr:hover td{background:var(--md-surface-container)}.ln-card td:first-child,.ln-table td:first-child{font-weight:600;color:var(--md-on-surface)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin:24px 0}.stat-grid>div{padding:22px;border-radius:20px;background:var(--md-surface-container-low);text-align:center;transition:transform .4s var(--md-spring),box-shadow .4s var(--md-spring)}.stat-grid>div:hover{transform:translateY(-4px);box-shadow:0 8px 28px #0000000f}.stat-value{font-family:JetBrains Mono,monospace;font-size:28px;font-weight:800;color:var(--md-primary);letter-spacing:-.03em;line-height:1.2}.stat-label{font-size:11px;font-weight:700;color:var(--md-on-surface-variant);text-transform:uppercase;letter-spacing:.08em;margin-top:4px}.step-list{counter-reset:steps;margin:20px 0}.step-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--md-surface-container-high)}.step-item:last-child{border-bottom:none}.step-item:before{counter-increment:steps;content:counter(steps);display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:14px;background:var(--md-primary);color:var(--md-on-primary);font-weight:800;font-size:15px;flex-shrink:0}.step-item .step-text{flex:1}.step-item .step-text strong{display:block;font-size:15px;color:var(--md-on-surface);margin-bottom:2px}.step-item .step-text span,.step-item .step-text p{font-size:14px;color:var(--md-on-surface-variant);line-height:1.6;margin:0}.diagram-box{margin:24px 0;padding:28px;border-radius:20px;background:var(--md-primary-container);text-align:center;overflow-x:auto}.diagram-box .flow{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;padding:12px 0}.diagram-box .flow-step{padding:10px 18px;background:var(--md-surface-container-lowest);border-radius:14px;font-size:13px;font-weight:700;color:var(--md-on-surface);white-space:nowrap;box-shadow:0 1px 3px #0000000f}.diagram-box .flow-step.active{background:var(--md-primary);color:var(--md-on-primary);box-shadow:0 2px 8px color-mix(in srgb,var(--md-primary) 30%,transparent)}.diagram-box .flow-step.warn{background:#fffbeb;color:#92400e}.diagram-box .flow-arrow{color:var(--md-on-primary-container);font-size:16px;font-weight:700}.diagram-box .caption{font-size:12px;color:var(--md-on-primary-container);margin-top:8px;font-style:italic;opacity:.7}.example-box{margin:24px 0;padding:24px 28px;border-radius:20px;background:var(--md-secondary-container);position:relative}.example-box:before{content:"📋";position:absolute;top:-12px;left:20px;background:var(--md-secondary-container);padding:0 8px;font-size:18px}.example-box h4{font-size:14px;font-weight:800;color:var(--md-on-secondary-container);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.example-box p{font-size:14px;color:var(--md-on-secondary-container);line-height:1.7;margin-bottom:6px}.example-box .math{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--md-on-secondary-container);background:color-mix(in srgb,var(--md-secondary-container) 60%,#fff);padding:12px 16px;border-radius:14px;margin:10px 0;line-height:1.8}.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:24px 0}.compare-card{padding:20px;border-radius:20px}.compare-card.do{background:#e8f5e9}.compare-card.dont{background:#ffebee}.compare-card h5{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.compare-card.do h5{color:#1b5e20}.compare-card.dont h5{color:#b71c1c}.compare-card ul{padding-left:18px;margin:0}.compare-card li{font-size:13px;line-height:1.6;margin-bottom:6px}.compare-card.do li{color:#2e7d32}.compare-card.dont li{color:#c62828}.tip-box{display:flex;gap:14px;padding:20px;border-radius:20px;margin:24px 0;align-items:flex-start}.tip-box.blue{background:var(--md-primary-container)}.tip-box.green{background:#e8f5e9}.tip-box.amber{background:var(--md-tertiary-container)}.tip-box .icon{font-size:20px;flex-shrink:0;margin-top:1px}.tip-box .text{font-size:14px;line-height:1.65}.tip-box .text strong{display:block;margin-bottom:4px}.tip-box.blue .text{color:var(--md-on-primary-container)}.tip-box.green .text{color:#1b5e20}.tip-box.amber .text{color:var(--md-on-tertiary-container)}.callout{padding:18px 22px;border-radius:20px;margin:24px 0;font-size:14px;line-height:1.7}.callout-blue{background:var(--md-primary-container);color:var(--md-on-primary-container)}.callout-amber{background:var(--md-tertiary-container);color:var(--md-on-tertiary-container)}.callout-green{background:#e8f5e9;color:#1b5e20}.callout strong{display:block;margin-bottom:4px}.callout-box{margin:24px 0;padding:20px 24px;border-radius:20px;border-left:4px solid}.callout-box.info{background:var(--md-primary-container);border-color:var(--md-primary)}.callout-box.warning{background:var(--md-tertiary-container);border-color:var(--md-tertiary)}.callout-box.success{background:#e8f5e9;border-color:#4caf50}.callout-box h4{font-size:14px;font-weight:800;margin-bottom:6px}.callout-box.info h4{color:var(--md-on-primary-container)}.callout-box.warning h4{color:var(--md-on-tertiary-container)}.callout-box.success h4{color:#1b5e20}.callout-box p{font-size:14px;margin:0;line-height:1.65}.callout-box.info p{color:var(--md-on-primary-container)}.callout-box.warning p{color:var(--md-on-tertiary-container)}.callout-box.success p{color:#2e7d32}.takeaway,.key-takeaway{margin:28px 0;padding:24px;border-radius:20px;background:var(--md-primary-container)}.takeaway h4,.key-takeaway h4{font-size:12px;font-weight:800;color:var(--md-primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;display:flex;align-items:center;gap:8px}.takeaway p,.key-takeaway p{font-size:15px;color:var(--md-on-primary-container);line-height:1.7;margin:0}.section-divider{height:2px;background:linear-gradient(90deg,transparent,var(--md-outline-variant),transparent);margin:44px 0;border:none}.ln-bottom-cta{text-align:center;margin-top:48px;padding:44px;background:var(--md-on-primary-container);border-radius:28px;position:relative;overflow:hidden}.ln-bottom-cta:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,color-mix(in srgb,var(--md-primary) 20%,transparent),transparent)}.ln-bottom-cta>*{position:relative;z-index:1}.ln-bottom-cta h3{font-size:22px;font-weight:800;color:#fff;margin-bottom:8px}.ln-bottom-cta p{font-size:14px;color:#fff9;margin-bottom:20px;line-height:1.6}.ln-bottom-cta a{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:var(--md-primary);color:var(--md-on-primary);text-decoration:none;border-radius:100px;font-weight:700;font-size:15px;transition:all .4s var(--md-spring)}.ln-bottom-cta a:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 10px 32px color-mix(in srgb,var(--md-primary) 40%,transparent)}.ln-related{max-width:840px;margin:0 auto 72px;padding:0 24px}.ln-related h3{font-size:12px;font-weight:800;color:var(--md-on-surface-variant);text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px}.ln-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.ln-related-card{background:var(--md-surface-container-low);border-radius:20px;padding:22px;text-decoration:none;transition:all .4s var(--md-spring)}.ln-related-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px #00000014;background:var(--md-surface-container)}.ln-related-card .rc-title{font-size:14px;font-weight:700;color:var(--md-on-surface);margin-bottom:4px}.ln-related-card .rc-desc{font-size:12px;color:var(--md-on-surface-variant)}.ln-footer{background:var(--md-surface-container-highest);color:var(--md-on-surface-variant);padding:48px 24px;border-radius:28px 28px 0 0}.ln-footer-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:13px}.ln-footer a{color:var(--md-on-surface-variant);text-decoration:none;padding:6px 14px;border-radius:100px;transition:all .3s var(--md-spring)}.ln-footer a:hover{color:var(--md-on-surface);background:var(--md-surface-container-high)}.ln-footer-links{display:flex;gap:4px}.ln-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:var(--md-primary);z-index:100;transition:width .1s linear;border-radius:0 100px 100px 0}.ln-toc{margin-bottom:36px;padding:22px 26px;border-radius:20px;background:var(--md-surface-container-low)}.ln-toc-title{font-size:11px;font-weight:800;color:var(--md-on-surface-variant);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;display:flex;align-items:center;gap:8px}.ln-toc-title svg{width:14px;height:14px;color:var(--md-on-surface-variant)}.ln-toc-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:6px 16px}.ln-toc-list li{font-size:13px}.ln-toc-list a{color:var(--md-on-surface-variant);text-decoration:none;display:flex;align-items:center;gap:8px;padding:5px 10px;border-radius:100px;transition:all .3s var(--md-spring)}.ln-toc-list a:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--md-primary);opacity:.35;flex-shrink:0;transition:all .3s var(--md-spring)}.ln-toc-list a:hover{color:var(--md-primary);background:var(--md-primary-container)}.ln-toc-list a:hover:before{opacity:1;transform:scale(1.3)}.ln-prereqs{margin-bottom:32px;padding:22px 26px;border-radius:20px;background:var(--md-tertiary-container)}.ln-prereqs-title{font-size:13px;font-weight:800;color:var(--md-on-tertiary-container);margin-bottom:8px;display:flex;align-items:center;gap:8px}.ln-prereqs-desc{font-size:13px;color:var(--md-on-tertiary-container);line-height:1.6;margin-bottom:12px;opacity:.85}.ln-prereqs-links{display:flex;flex-wrap:wrap;gap:8px}.ln-prereqs-links a{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--md-on-tertiary-container);background:color-mix(in srgb,var(--md-tertiary-container) 50%,#fff);padding:7px 16px;border-radius:100px;text-decoration:none;transition:all .3s var(--md-spring)}.ln-prereqs-links a:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 14px #0000000f}.ln-prereqs-links a:after{content:"→"}.ln-keep-learning{margin-top:44px;padding-top:36px;border-top:2px solid var(--md-surface-container-high)}.ln-keep-learning-title{font-size:12px;font-weight:800;color:var(--md-on-surface-variant);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px}.ln-keep-learning-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.ln-keep-card{padding:18px;border-radius:20px;background:var(--md-surface-container-low);text-decoration:none;transition:all .4s var(--md-spring);display:flex;align-items:flex-start;gap:12px}.ln-keep-card:hover{transform:translateY(-4px);box-shadow:0 8px 28px #0000000f;background:var(--md-surface-container)}.ln-keep-icon{width:38px;height:38px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.ln-keep-icon.guide{background:var(--md-primary-container)}.ln-keep-icon.tool{background:#e8f5e9}.ln-keep-icon.template{background:var(--md-tertiary-container)}.ln-keep-icon.framework{background:var(--md-secondary-container)}.ln-keep-info .ln-keep-type{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.ln-keep-icon.guide+.ln-keep-info .ln-keep-type{color:var(--md-primary)}.ln-keep-icon.tool+.ln-keep-info .ln-keep-type{color:#2e7d32}.ln-keep-icon.template+.ln-keep-info .ln-keep-type{color:var(--md-tertiary)}.ln-keep-icon.framework+.ln-keep-info .ln-keep-type{color:var(--md-secondary)}.ln-keep-info .ln-keep-name{font-size:13px;font-weight:700;color:var(--md-on-surface)}input[type=range]{cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--md-primary);cursor:pointer;border:2px solid #fff;box-shadow:0 2px 6px #0003}input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--md-primary);cursor:pointer;border:2px solid #fff;box-shadow:0 2px 6px #0003}.ln-share-btn:hover{background:#fff3!important;color:#fff!important;transform:translateY(-2px) scale(1.08)}@media(max-width:640px){.ln-card{padding:28px 20px;border-radius:20px}.ln-nav-links a:not(.ln-cta){display:none}.stat-grid{grid-template-columns:1fr 1fr}.compare-grid{grid-template-columns:1fr}.step-item{gap:12px}.ln-toc-list,.ln-keep-learning-grid{grid-template-columns:1fr}.ln-footer{border-radius:20px 20px 0 0}}
