.app-shell{display:flex;flex-direction:column;min-height:100vh}main{flex:1;width:100%}.promo-banner{background:linear-gradient(90deg,#4f46e5,#7c3aed);color:#fff;padding:.45rem 1rem;display:flex;align-items:center;justify-content:center;gap:.6rem;font-size:.85rem;flex-wrap:wrap;position:relative;line-height:1.3}.promo-banner .promo-text{color:#fff}.promo-banner .promo-link{color:#fff;text-decoration:underline;font-weight:600;background:#ffffff1f;padding:.1rem .55rem;border-radius:999px}.promo-banner .promo-link:hover{background:#ffffff38;text-decoration:underline}.promo-dismiss{background:#ffffff2e;border:none;color:#fff;width:22px;height:22px;border-radius:50%;padding:0;font-size:.72rem;margin-left:.4rem;display:inline-flex;align-items:center;justify-content:center}.promo-dismiss:hover{background:#ffffff52}.navbar{background:#fff;border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}.navbar-inner{max-width:1200px;margin:0 auto;padding:.6rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.navbar-brand{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:1.1rem;color:var(--color-text)}.navbar-brand:hover{text-decoration:none}.navbar-links{display:flex;gap:.25rem;align-items:center;flex-wrap:wrap}.nav-link{color:var(--color-text);padding:.45rem .8rem;border-radius:6px;font-size:.95rem}.nav-link:hover{background:#f3f4f6;text-decoration:none}.nav-link.active{background:#eef2ff;color:var(--color-primary);font-weight:600}.cart-pill{position:relative;display:inline-flex;align-items:center;gap:.35rem}.cart-count{background:var(--color-secondary);color:#fff;border-radius:999px;font-size:.7rem;padding:.05rem .45rem}.nav-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border-radius:8px;color:var(--color-text);font-size:1.05rem;line-height:1}.nav-icon:hover{background:#f3f4f6;text-decoration:none}.nav-icon.active{background:#eef2ff;color:var(--color-primary)}.nav-icon-count{position:absolute;top:-2px;right:-2px;background:var(--color-secondary);color:#fff;border-radius:999px;font-size:.65rem;font-weight:700;padding:.05rem .35rem;min-width:16px;text-align:center;border:2px solid white;line-height:1}.navbar-sep{width:1px;height:22px;background:var(--color-border);margin:0 .25rem}.nav-cta{background:var(--color-primary);color:#fff!important;padding:.45rem .9rem;border-radius:8px;font-weight:500;font-size:.9rem;text-decoration:none}.nav-cta:hover{background:var(--color-primary-dark);text-decoration:none}.nav-learn-menu{position:relative;display:inline-flex}.nav-learn-trigger{background:transparent;border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:.4rem;font:inherit}.nav-learn-trigger:hover{background:#f3f4f6}.nav-learn-trigger.active{background:#eef2ff;color:var(--color-primary);font-weight:600}.nav-learn-trigger.open{background:#eef2ff;border-color:var(--color-border)}.nav-learn-trigger.learn-on{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.nav-learn-trigger.learn-on:hover{background:#d1fae5}.nav-learn-caret{font-size:.75rem;opacity:.7;transition:transform .15s ease}.nav-learn-trigger.open .nav-learn-caret{transform:rotate(180deg)}.nav-learn-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:320px;background:#fff;border:1px solid var(--color-border);border-radius:10px;box-shadow:0 10px 30px #0000001f;padding:.6rem;z-index:60;animation:nav-learn-fade .12s ease-out}@keyframes nav-learn-fade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-learn-section{padding:.25rem}.nav-learn-section-label{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#6b7280;padding:.25rem .5rem .4rem}.nav-learn-toggle-row{display:flex;align-items:center;gap:.6rem;padding:.25rem .5rem .5rem}.nav-learn-toggle-hint{font-size:.8rem;color:#6b7280}.nav-learn-divider{height:1px;background:var(--color-border);margin:.35rem 0}.nav-learn-item{display:flex;align-items:flex-start;gap:.65rem;padding:.55rem .6rem;border-radius:8px;color:var(--color-text);text-decoration:none}.nav-learn-item:hover{background:#f3f4f6;text-decoration:none}.nav-learn-item.active{background:#eef2ff}.nav-learn-item-icon{font-size:1.1rem;line-height:1.2;width:22px;text-align:center}.nav-learn-item-body{display:flex;flex-direction:column;gap:.1rem}.nav-learn-item-title{font-weight:600;font-size:.95rem}.nav-learn-item-sub{font-size:.78rem;color:#6b7280}.footer{background:#0f172a;color:#e5e7eb;padding:2rem 1.5rem 1.1rem;margin-top:2.5rem}.footer-top{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:2.5rem;padding-bottom:1.4rem;align-items:start}@media (max-width: 720px){.footer-top{grid-template-columns:1fr;gap:1.4rem}}.footer-brand-col{max-width:360px}.footer-brand{font-size:1rem;font-weight:700;display:inline-flex;align-items:center;gap:.4rem;color:#fff;letter-spacing:.01em}.footer-tagline{margin:.4rem 0 .85rem;color:#9ca3af;font-size:.83rem;line-height:1.5}.footer-external{display:inline-flex;gap:.35rem;flex-wrap:wrap}.footer-external a{font-size:.78rem;padding:.25rem .65rem;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:#ffffff08;transition:background .15s,border-color .15s}.footer-external a:hover{background:#c7d2fe1f;border-color:#c7d2fe66}.footer-cols{display:grid;grid-template-columns:repeat(3,minmax(120px,auto));gap:1rem 2.5rem}@media (max-width: 720px){.footer-cols{grid-template-columns:repeat(3,1fr);gap:1rem}}@media (max-width: 480px){.footer-cols{grid-template-columns:1fr 1fr}}.footer-col{display:flex;flex-direction:column;gap:.4rem}.footer-col-h{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#6b7280;margin:0 0 .45rem}.footer-col a{font-size:.86rem;line-height:1.45;display:inline-block;width:max-content}.footer a{color:#c7d2fe}.footer a:hover{color:#fff;text-decoration:none}.footer-bottom{max-width:1200px;margin:0 auto;display:flex;flex-wrap:wrap;gap:.6rem;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid rgba(255,255,255,.08);font-size:.78rem}.footer-copy{color:#9ca3af}.footer-utilities{display:inline-flex;align-items:center;gap:.5rem;font-size:.78rem}.footer-util-btn{background:transparent;border:none;color:#9ca3af;cursor:pointer;font:inherit;padding:.2rem .4rem;border-radius:4px}.footer-util-btn:hover{color:#fff;background:#ffffff0f}.footer-util-sep{color:#4b5563}.reset-btn{background:transparent;border:1px solid rgba(251,191,36,.4);color:#fbbf24;padding:.3rem .7rem;font-size:.78rem;border-radius:999px}.reset-btn:hover{background:#fbbf241f;color:#fde68a;border-color:#fbbf24}.hero{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:2.5rem 1.5rem;border-radius:12px;margin-bottom:1.5rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem}.hero h1{font-size:2rem;margin:0 0 .5rem}.hero p{margin:0 0 1rem;opacity:.92}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.product-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.product-card{position:relative}.wish-btn{position:absolute;top:8px;right:8px;width:32px;height:32px;padding:0;border-radius:50%;background:#ffffffeb;border:1px solid var(--color-border);font-size:1.05rem;line-height:1;color:#6b7280;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);z-index:2}.wish-btn:hover{background:#fff;color:var(--color-danger)}.wish-btn.wish-on{color:var(--color-danger);border-color:var(--color-danger)}.wish-on-text{color:var(--color-danger)!important;font-weight:600}.product-card-image{width:100%;height:170px;object-fit:cover;background:#f3f4f6}.product-card-body{padding:.75rem;display:flex;flex-direction:column;flex:1;gap:.4rem}.product-card-title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0}.product-card-title a{color:inherit}.product-card-price{font-size:1.05rem;font-weight:700;color:var(--color-primary)}.product-card-actions{display:flex;gap:.4rem;margin-top:auto}.filter-bar{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;background:#fff;padding:.8rem;border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:1rem}.filter-bar>*{flex:0 0 auto}.filter-bar .grow{flex:1 1 200px}.form-card{max-width:440px;margin:1.5rem auto;padding:1.5rem;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.form-card h2{margin:0 0 1rem}.form-group{margin-bottom:.85rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{background:#fff;color:var(--color-text);border-radius:var(--radius);max-width:520px;width:100%;padding:1.25rem;box-shadow:var(--shadow-md)}.modal p,.modal li{color:var(--color-text)}.modal .muted{color:var(--color-muted)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.modal h3{margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.tour-modal{max-width:540px}.tour-progress{display:flex;gap:.4rem;justify-content:center;margin-bottom:.85rem}.tour-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border)}.tour-dot.active{background:var(--color-primary);width:24px;border-radius:999px}.tour-dot.done{background:#c7d2fe}.tour-body p{margin:0 0 .5rem;line-height:1.5}.tour-actions{justify-content:space-between}.toast-container{position:fixed;top:80px;right:16px;display:flex;flex-direction:column;gap:.5rem;z-index:200;pointer-events:none}.toast{background:#fff;pointer-events:auto;border-left:4px solid var(--color-primary);padding:.7rem 1rem;border-radius:6px;min-width:220px;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;gap:.5rem;align-items:center}.toast.success{border-color:var(--color-success)}.toast.error{border-color:var(--color-danger)}.toast.warning{border-color:var(--color-warning)}.toast button{background:none;color:var(--color-muted);border:none;padding:0}.tabs{display:flex;gap:0;border-bottom:1px solid var(--color-border);margin-bottom:1rem;flex-wrap:wrap}.tab{padding:.6rem 1rem;background:none;border:none;color:var(--color-muted);border-bottom:2px solid transparent;border-radius:0;font-weight:500}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.accordion-item{border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:.5rem;background:#fff}.accordion-header{width:100%;text-align:left;background:none;border:none;padding:.8rem 1rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;border-radius:var(--radius)}.accordion-content{padding:0 1rem 1rem;color:var(--color-muted)}.tooltip-wrap{position:relative;display:inline-block}.tooltip-wrap .tooltip{visibility:hidden;opacity:0;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#111827;color:#fff;padding:.3rem .55rem;border-radius:4px;font-size:.8rem;white-space:nowrap;transition:opacity .15s;z-index:10}.tooltip-wrap:hover .tooltip,.tooltip-wrap:focus-within .tooltip{visibility:visible;opacity:1}.hover-reveal{padding:1rem;border:2px dashed var(--color-border);border-radius:var(--radius);text-align:center;background:#fafafa}.hover-reveal:hover{background:#eef2ff;border-color:var(--color-primary)}.reveal-text{display:none;color:var(--color-primary);font-weight:600}.hover-reveal:hover .reveal-text{display:block}.dnd-zone{min-height:90px;border:2px dashed var(--color-border);border-radius:var(--radius);padding:.75rem;background:#fafafa}.dnd-zone.over{border-color:var(--color-primary);background:#eef2ff}.dnd-item{background:#fff;border:1px solid var(--color-border);border-radius:6px;padding:.4rem .7rem;margin-bottom:.4rem;cursor:grab}.dnd-item:active{cursor:grabbing}.carousel{position:relative;border-radius:var(--radius);overflow:hidden;background:#000}.carousel-track{display:flex;transition:transform .4s ease}.carousel-slide{min-width:100%}.carousel-slide img{width:100%;display:block}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:#00000080;color:#fff;border:none;width:36px;height:36px;border-radius:50%}.carousel-prev{left:8px}.carousel-next{right:8px}.carousel-dots{display:flex;gap:6px;justify-content:center;padding:8px;background:#0006}.carousel-dot{width:8px;height:8px;border-radius:50%;background:#ffffff80;border:none;padding:0}.carousel-dot.active{background:#fff}.stepper{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.step{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--color-muted)}.step .dot{width:26px;height:26px;border-radius:50%;background:var(--color-border);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem}.step.active{color:var(--color-primary)}.step.active .dot{background:var(--color-primary)}.step.done .dot{background:var(--color-success)}.step-sep{flex:1;height:2px;background:var(--color-border)}.pagination{display:flex;gap:.25rem;align-items:center;justify-content:center;margin-top:1rem}.pagination button{background:#fff;color:var(--color-text);border:1px solid var(--color-border)}.pagination button.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.qty-control{display:inline-flex;align-items:center;border:1px solid var(--color-border);border-radius:6px}.qty-control button{background:#fff;border:none;padding:.25rem .6rem;border-radius:0}.qty-control input{width:50px;text-align:center;border:none;border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);border-radius:0}.two-col{display:grid;grid-template-columns:2fr 1fr;gap:1.25rem}@media (max-width: 760px){.two-col{grid-template-columns:1fr}}.progress{background:#e5e7eb;border-radius:999px;height:10px;overflow:hidden}.progress-bar{height:100%;background:var(--color-primary);transition:width .3s}.spinner{width:22px;height:22px;border:3px solid #e5e7eb;border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.stars{color:#fbbf24;letter-spacing:1px}.learn-toggle{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;border-radius:999px;background:#fff;border:1px solid var(--color-border);color:var(--color-text);font-size:.85rem}.learn-toggle:hover{background:#f3f4f6}.learn-toggle.on{background:#fef3c7;border-color:#f59e0b;color:#92400e}.learn-toggle-text{font-weight:500}.learn-toggle-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#d1d5db;margin-left:.2rem}.learn-toggle-dot.dot-on{background:#16a34a;box-shadow:0 0 0 3px #16a34a2e}.anti-list{display:grid;gap:.85rem}.anti-item{border:1px solid var(--color-border);border-radius:8px;background:#fff;overflow:hidden}.anti-title{margin:0;padding:.55rem .85rem;font-size:.95rem;background:#f1f5f9;border-bottom:1px solid var(--color-border)}.anti-row{padding:.55rem .85rem;display:grid;grid-template-columns:80px 1fr;gap:.4rem .75rem;align-items:start}.anti-row+.anti-row{border-top:1px dashed var(--color-border)}.anti-bad{background:#fef2f2}.anti-good{background:#f0fdf4}.anti-label{font-weight:700;font-size:.8rem;letter-spacing:.02em}.anti-bad .anti-label{color:#b91c1c}.anti-good .anti-label{color:#15803d}.anti-code{margin:0;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:#0b1220;color:#e2e8f0;padding:.5rem .7rem;border-radius:4px;font-size:.78rem;white-space:pre-wrap;word-break:break-word;grid-column:2}.anti-why{margin:0;font-size:.82rem;color:var(--color-muted);grid-column:2;line-height:1.45}.learn-banner{background:linear-gradient(135deg,#fef3c7,#fde68a 60%,#fcd34d);border-bottom:1px solid #f59e0b;color:#78350f;padding:.75rem 1.25rem;position:relative;z-index:40}.learn-banner.collapsed{padding:0}.learn-banner-expand{width:100%;background:linear-gradient(135deg,#fef3c7,#fde68a);border:none;border-bottom:1px solid #f59e0b;color:#78350f;padding:.4rem 1rem;font-size:.85rem;cursor:pointer;border-radius:0;text-align:center}.learn-banner-expand:hover{background:#fde68a}.learn-banner-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;max-width:1200px;margin:0 auto}.learn-banner-title{font-size:1rem}.learn-banner-sub{margin:.2rem 0 0;font-size:.85rem;color:#78350f;max-width:720px;line-height:1.4}.learn-banner-collapse{background:#ffffff80;border:1px solid #f59e0b;color:#78350f;width:26px;height:26px;padding:0;border-radius:6px;font-size:1rem;line-height:1}.learn-banner-collapse:hover{background:#fff}.learn-banner-tip{max-width:1200px;margin:.6rem auto 0;padding:.55rem .75rem;background:#ffffffb3;border:1px solid #fbbf24;border-radius:6px;font-size:.85rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.learn-banner-tip-pill{background:#92400e;color:#fff;padding:.1rem .5rem;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:.04em}.learn-banner-tip-text{color:#78350f;flex:1 1 100%}.learn-banner-quick{max-width:1200px;margin:.6rem auto 0;display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;font-size:.8rem;color:#78350f}.learn-banner-step kbd{background:#fff;border:1px solid #fbbf24;border-radius:4px;padding:0 .3rem;font-family:ui-monospace,monospace;font-size:.72rem;font-weight:700;margin-right:.25rem}.learn-banner-links{max-width:1200px;margin:.6rem auto 0;display:flex;flex-wrap:wrap;gap:.4rem 1.1rem;font-size:.85rem}.learn-banner-links a{color:#92400e;font-weight:600;background:#fff9;padding:.2rem .55rem;border-radius:999px;border:1px solid #fbbf24}.learn-banner-links a:hover{background:#fff;text-decoration:none}.learn-hover-rect,.learn-selected-rect{position:fixed;pointer-events:none;z-index:4998;border-radius:4px;transition:top 60ms linear,left 60ms linear,width 60ms linear,height 60ms linear}.learn-hover-rect{box-shadow:0 0 0 2px #4f46e5,0 0 0 6px #4f46e52e}.learn-selected-rect{box-shadow:0 0 0 2px #f59e0b,0 0 0 6px #f59e0b38}.learn-hint{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:#111827;color:#fff;padding:.5rem .9rem;border-radius:999px;font-size:.85rem;box-shadow:var(--shadow-md);z-index:4999;max-width:calc(100vw - 32px)}.learn-panel{position:fixed;top:0;right:0;width:min(440px,100vw);height:100vh;background:#fff;border-left:1px solid var(--color-border);box-shadow:-8px 0 24px #0000001f;overflow-y:auto;z-index:5000;padding:1rem;font-size:.9rem;transition:box-shadow .18s ease,border-radius .18s ease}.learn-panel.learn-panel-mode-dock-left{border-left:none;border-right:1px solid var(--color-border);box-shadow:8px 0 24px #0000001f}.learn-panel.learn-panel-mode-free{height:auto;max-height:calc(100vh - 16px);min-height:240px;width:min(440px,100vw);border-radius:12px;border:1px solid var(--color-border);box-shadow:0 12px 40px #0000002e}.learn-panel.learn-panel-dragging{box-shadow:0 18px 48px #4f46e552;border-color:#a5b4fc;cursor:grabbing;-webkit-user-select:none;user-select:none}.learn-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem;gap:.4rem}.learn-panel-header-actions{display:flex;align-items:center;gap:.2rem}.learn-panel-grip{flex:0 0 auto;background:transparent;border:1px solid transparent;color:#9ca3af;font-size:.95rem;letter-spacing:-2px;padding:.25rem .4rem;border-radius:5px;cursor:grab;touch-action:none;line-height:1}.learn-panel-grip:hover{background:#f3f4f6;color:var(--color-text);border-color:var(--color-border)}.learn-panel-grip:active{cursor:grabbing}.learn-panel-dragging .learn-panel-grip{cursor:grabbing;color:#4f46e5;background:#eef2ff}.learn-panel-reset{background:transparent;border:1px solid transparent;color:var(--color-muted);font-size:.95rem;padding:.25rem .45rem;border-radius:5px;cursor:pointer;line-height:1}.learn-panel-reset:hover{background:#f3f4f6;color:var(--color-text);border-color:var(--color-border)}.learn-panel-context{display:flex;align-items:center;gap:.4rem;padding:.35rem .55rem;margin:0 0 .7rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.78rem;color:var(--color-text);min-width:0}.learn-panel-context-glyph{flex:0 0 auto;font-size:.85rem;line-height:1}.learn-panel-context-title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:40%;flex:0 1 auto}.learn-panel-context-route{background:#fff;border:1px solid #e5e7eb;border-radius:4px;padding:.05rem .35rem;font-size:.74rem;color:#4b5563;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1 auto}.learn-panel-context-copy{flex:0 0 auto;background:transparent;border:1px solid var(--color-border);color:var(--color-muted);font-size:.85rem;line-height:1;padding:.15rem .4rem;border-radius:4px;cursor:pointer}.learn-panel-context-copy:hover{background:#fff;color:var(--color-primary);border-color:#c7d2fe}.learn-inspect-ai{margin:.6rem 0 .7rem;border:1px solid #c7d2fe;background:linear-gradient(135deg,#faf5ff,#eef2ff);border-radius:8px;padding:.6rem .7rem}.learn-inspect-ai-head{display:flex;align-items:center;justify-content:space-between;gap:.4rem;margin-bottom:.3rem}.learn-inspect-ai-title{font-weight:600;font-size:.86rem;color:#1f2937;display:inline-flex;align-items:center;gap:.35rem}.learn-inspect-ai-on{display:inline-block;margin-left:.3rem;background:#10b981;color:#fff;font-size:.6rem;font-weight:700;padding:.04rem .4rem;border-radius:999px;letter-spacing:.04em;text-transform:uppercase}.learn-inspect-ai-settings{font-size:.78rem;padding:.2rem .45rem;border:1px solid var(--color-border);border-radius:5px;background:#fff;color:var(--color-muted);cursor:pointer}.learn-inspect-ai-settings:hover{background:#f9fafb;color:var(--color-text)}.learn-inspect-ai-sub{font-size:.78rem;margin:0 0 .4rem}.learn-inspect-ai-sub code{background:#fff;padding:.05rem .3rem;border-radius:4px;border:1px solid #e5e7eb;font-size:.85em}.learn-inspect-ai-btn{background:#6366f1;color:#fff;border:none;padding:.45rem .9rem;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;width:100%}.learn-inspect-ai-btn:hover:not(:disabled){background:#4f46e5}.learn-inspect-ai-btn:disabled{opacity:.65;cursor:not-allowed}.learn-inspect-ai-result{margin-top:.5rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:.55rem .65rem}.learn-inspect-ai-line{font-size:.85rem;line-height:1.55;color:#1f2937;margin-bottom:.25rem}.learn-inspect-ai-line:last-child{margin-bottom:0}.learn-inspect-ai-meta{display:flex;justify-content:space-between;align-items:center;margin-top:.4rem;font-size:.7rem}.learn-inspect-ai-prompt-toggle{background:transparent;border:1px solid var(--color-border);color:var(--color-muted);font-size:.7rem;padding:.1rem .45rem;border-radius:4px;cursor:pointer}.learn-inspect-ai-prompt-toggle:hover{background:#f3f4f6}.learn-inspect-ai-prompt{margin-top:.4rem;background:#0b1220;color:#e2e8f0;font-size:.7rem;line-height:1.5;padding:.5rem .65rem;border-radius:5px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:pre-wrap;word-break:break-word}.learn-inspect-ai-error{margin-top:.5rem;background:#fef2f2;border:1px solid #fca5a5;color:#991b1b;border-radius:6px;padding:.45rem .6rem;font-size:.82rem}.learn-pick-btn{display:inline-flex;align-items:center;gap:.35rem;background:#fff;border:1px solid var(--color-border);color:var(--color-text);padding:.3rem .6rem;border-radius:5px;font-size:.78rem;font-weight:600;cursor:pointer;flex:0 0 auto;white-space:nowrap}.learn-pick-btn:hover{background:#f9fafb;border-color:#c7d2fe}.learn-pick-btn.armed{background:#4f46e5;color:#fff;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e52e;animation:learn-pick-pulse 1.4s ease-in-out infinite}.learn-pick-btn.armed:hover{background:#4338ca;border-color:#4338ca}@keyframes learn-pick-pulse{0%,to{box-shadow:0 0 0 3px #4f46e52e}50%{box-shadow:0 0 0 6px #4f46e514}}.learn-pick-btn-large{margin:.7rem auto 0;padding:.55rem 1.1rem;font-size:.92rem;background:#4f46e5;color:#fff;border-color:#4f46e5;box-shadow:0 4px 12px #4f46e540}.learn-pick-btn-large:hover{background:#4338ca;border-color:#4338ca}body.learn-pick-mode,body.learn-pick-mode *{cursor:crosshair!important}body.learn-pick-mode [data-learn-mode-ui],body.learn-pick-mode [data-learn-mode-ui] *{cursor:auto!important}body.learn-pick-mode .learn-pick-btn,body.learn-pick-mode .learn-pick-btn *{cursor:pointer!important}.learn-panel-empty kbd{background:#f3f4f6;border:1px solid #d1d5db;border-bottom-width:2px;border-radius:4px;padding:.05rem .35rem;font-size:.75em;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--color-text)}.learn-h4{margin:1rem 0 .4rem;font-size:.95rem}.learn-summary{width:100%;font-size:.82rem}.learn-summary th{width:35%;background:#f9fafb;text-align:left;font-weight:500;color:var(--color-muted);padding:.3rem .5rem;font-size:.78rem}.learn-summary td{padding:.3rem .5rem;word-break:break-all}.learn-summary code{background:#fef3c7;padding:0 .25rem;border-radius:3px}.learn-strategy-list{list-style:none;padding:0;margin:0}.learn-strategy-list li{border:1px solid var(--color-border);border-radius:6px;padding:.5rem;margin-bottom:.5rem}.learn-strategy-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.learn-strategy-label{font-weight:600;font-size:.85rem;flex:1 1 auto}.learn-stability{font-size:.78rem;letter-spacing:1px;margin-right:.4rem}.stability-5{color:#16a34a}.stability-4{color:#65a30d}.stability-3{color:#ca8a04}.stability-2{color:#ea580c}.stability-1{color:#dc2626}.learn-code{display:block;background:#f3f4f6;padding:.35rem .5rem;border-radius:4px;font-size:.8rem;word-break:break-all;white-space:pre-wrap}.learn-why{font-size:.75rem;color:var(--color-muted);margin:.4rem 0 0}.learn-snippet{border:1px solid var(--color-border);border-radius:6px;margin-bottom:.5rem;padding:.4rem .5rem}.learn-snippet-head{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;margin-bottom:.2rem}.learn-pre{margin:0;background:#0f172a;color:#e2e8f0;padding:.5rem .6rem;border-radius:4px;font-size:.78rem;white-space:pre-wrap;word-break:break-all}.btn-stackblitz{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,#1389fd,#0769e3);color:#fff;border:1px solid #0769e3;padding:.45rem .9rem;font-size:.86rem;font-weight:600;border-radius:8px;box-shadow:var(--shadow-sm)}.btn-stackblitz:hover{filter:brightness(1.05);box-shadow:var(--shadow-md)}.btn-stackblitz:active{filter:brightness(.95)}.patterns-intro{background:linear-gradient(135deg,#ecfeff,#cffafe);border-color:#67e8f9}.patterns-toolbar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin:.75rem 0}.patterns-fw{margin-bottom:0;border-bottom:none}.patterns-toc{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem;display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1rem}.patterns-toc-link{background:#f1f5f9;color:var(--color-text);padding:.25rem .7rem;border-radius:999px;font-size:.82rem;display:inline-flex;align-items:center;gap:.3rem}.patterns-toc-link:hover{background:#e2e8f0;text-decoration:none}.patterns-toc-count{background:var(--color-primary);color:#fff;border-radius:999px;padding:0 .4rem;font-size:.7rem;font-weight:700}.patterns-cat{margin:1.25rem 0;scroll-margin-top:80px}.patterns-cat-title{font-size:1.1rem;margin:0 0 .25rem;border-left:3px solid var(--color-primary);padding-left:.5rem}.patterns-cat-intro{font-size:.85rem;margin:0 0 .6rem}.patterns-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:.75rem}.pattern-card{padding:.85rem}.pattern-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.5rem;margin-bottom:.4rem}.pattern-title{margin:0;font-size:.95rem}.pattern-demo-link{font-size:.78rem}.pattern-why{font-size:.82rem;color:var(--color-muted);margin:0 0 .4rem;line-height:1.4}.challenges-intro{background:linear-gradient(135deg,#f0fdf4,#d1fae5);border-color:#6ee7b7}.challenges-filter{display:flex;gap:.4rem;flex-wrap:wrap;margin:.75rem 0 1.1rem}.challenge-filter-btn{background:#fff;border:1px solid var(--color-border);color:var(--color-text);padding:.35rem .95rem;border-radius:999px;font-size:.85rem;font-weight:500;transition:background .15s,border-color .15s,color .15s}.challenge-filter-btn:hover{background:#f3f4f6}.challenge-filter-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 1px 3px #4f46e540}.challenges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:1rem}.challenge-card{position:relative;padding:1.1rem 1.2rem 1.15rem;display:flex;flex-direction:column;gap:.7rem;border-radius:12px;transition:box-shadow .18s ease,transform .18s ease,border-color .18s;overflow:hidden}.challenge-card:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--color-border);transition:background .18s}.challenge-card[data-difficulty=easy]:before{background:linear-gradient(90deg,#10b981,#6ee7b7)}.challenge-card[data-difficulty=medium]:before{background:linear-gradient(90deg,#f59e0b,#fcd34d)}.challenge-card[data-difficulty=hard]:before{background:linear-gradient(90deg,#ef4444,#fca5a5)}.challenge-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:#c7d2fe}.challenge-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.6rem;flex-wrap:nowrap}.challenge-title{margin:0;font-size:1.02rem;font-weight:600;line-height:1.35;flex:1 1 auto;min-width:0;color:var(--color-text)}.challenge-card>.badge{flex:0 0 auto}.challenge-goal{margin:0;font-size:.88rem;line-height:1.55;color:#374151}.challenge-deeplink{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;font-weight:500;color:var(--color-primary);background:#eef2ff;padding:.32rem .7rem;border-radius:999px;align-self:flex-start;border:1px solid #c7d2fe;transition:background .15s,border-color .15s,transform .1s}.challenge-deeplink:hover{background:#e0e7ff;text-decoration:none;border-color:#a5b4fc}.challenge-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:auto;padding-top:.8rem;border-top:1px dashed var(--color-border)}.challenge-actions-left{display:flex;gap:.5rem;align-items:center;flex:1 1 auto;min-width:0}.challenge-actions .btn,.challenge-actions .challenge-hint-toggle,.challenge-actions .challenge-stackblitz{height:34px;padding:0 .85rem;font-size:.83rem;font-weight:500;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;white-space:nowrap;line-height:1}.challenge-actions .btn{box-shadow:0 1px 2px #4f46e526}.challenge-hint-toggle{background:transparent;border:1px solid var(--color-border);color:var(--color-muted)}.challenge-hint-toggle:hover{background:#f9fafb;color:var(--color-text);border-color:#d1d5db}.challenge-actions .challenge-stackblitz{margin-left:auto}@media (max-width: 460px){.challenge-actions .challenge-stackblitz{margin-left:0;flex:1 1 100%;justify-content:center}}.challenge-hint{margin-top:.1rem}.challenge-result{margin-top:.1rem;padding:.6rem .8rem;border-radius:8px;font-size:.85rem;border:1px solid;line-height:1.45;display:flex;align-items:flex-start;gap:.5rem;animation:challenge-result-in .18s ease-out}@keyframes challenge-result-in{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}.challenge-result.pass{background:#f0fdf4;border-color:#86efac;color:#166534}.challenge-result.fail{background:#fef2f2;border-color:#fca5a5;color:#991b1b}.code-file{border:1px solid #1e293b;border-radius:8px;overflow:hidden;background:#0b1220;box-shadow:0 1px 2px #0000000d}.code-file-head{display:flex;align-items:center;gap:.5rem;padding:.4rem .7rem;background:#1e293b;color:#cbd5e1;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;border-bottom:1px solid #0b1220}.code-file-icon{background:#4f46e5;color:#fff;padding:.05rem .35rem;border-radius:3px;font-size:.65rem;font-weight:700;letter-spacing:.04em}.code-file-name{color:#e2e8f0}.code-file-actions{margin-left:auto;display:flex;gap:.35rem;align-items:center}.code-file-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#e2e8f0;padding:.2rem .55rem;font-size:.72rem;border-radius:4px;cursor:pointer;font-family:-apple-system,BlinkMacSystemFont,sans-serif}.code-file-btn:hover{background:#ffffff29;border-color:#ffffff40}.code-file-btn.copied{background:#22c55e40;border-color:#22c55e80;color:#bbf7d0}.code-file .hl{border-radius:0;border:none;margin:0;max-height:280px}.api-intro{background:linear-gradient(135deg,#eef2ff,#ede9fe);border-color:#c7d2fe}.api-intro p,.api-intro li{font-size:.92rem}.api-section-h{font-size:1.1rem;font-weight:700;margin:1.6rem 0 .6rem;color:var(--color-text);display:flex;align-items:center;gap:.5rem}.api-section-h:before{content:"";display:inline-block;width:4px;height:1.05rem;background:var(--color-primary);border-radius:2px}.api-card{margin-bottom:.75rem;border-left:3px solid transparent;transition:border-color .15s,box-shadow .15s}.api-card:hover{box-shadow:var(--shadow-md)}.api-card:has(.method-get){border-left-color:#16a34a}.api-card:has(.method-post){border-left-color:#2563eb}.api-card:has(.method-put){border-left-color:#d97706}.api-card:has(.method-patch){border-left-color:#ca8a04}.api-card:has(.method-delete){border-left-color:#dc2626}.api-head{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;flex-wrap:wrap}.api-title{margin:0;font-size:1rem;font-weight:600}.api-desc{font-size:.86rem;margin:.25rem 0 0;line-height:1.45}.api-actions{display:flex;gap:.4rem;align-items:center}.api-meta{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin:.6rem 0;padding:.5rem .7rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;font-size:.82rem}.api-method{font-family:ui-monospace,Menlo,monospace;font-weight:700;letter-spacing:.05em;padding:.18rem .55rem;font-size:.72rem;color:#fff!important}.method-get{background:#16a34a}.method-post{background:#2563eb}.method-put{background:#d97706}.method-patch{background:#ca8a04}.method-delete{background:#dc2626}.api-url{word-break:break-all;font-size:.82rem;color:#1e293b;font-weight:500}.api-detail{margin-top:.5rem}.api-detail summary{cursor:pointer;font-size:.82rem;color:var(--color-muted);padding:.3rem 0;-webkit-user-select:none;user-select:none}.api-detail summary:hover{color:var(--color-text)}.api-status-row{display:flex;gap:.6rem;align-items:center;margin-top:.6rem}.api-snippet-tabs{margin-top:.4rem;margin-bottom:0;align-items:center}.api-snippet-copy{margin-left:auto;font-size:.78rem}.api-time{font-size:.78rem;background:#f1f5f9;padding:.15rem .5rem;border-radius:999px;color:#475569;font-variant-numeric:tabular-nums}.api-card .badge{font-size:.78rem;font-weight:600;padding:.25rem .65rem;display:inline-flex;align-items:center;gap:.35rem}.hl{background:#0b1220;color:#e2e8f0;padding:.7rem .9rem;border-radius:6px;font-size:.78rem;line-height:1.55;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;white-space:pre-wrap;word-break:break-word;max-height:320px;overflow-y:auto;margin:.35rem 0 0;border:1px solid #1e293b;box-shadow:inset 0 1px #ffffff0a}.hl code{font-family:inherit;background:none;padding:0;color:inherit}.hl-string-key{color:#7dd3fc}.hl-string{color:#fdba74}.hl-number{color:#c4b5fd}.hl-boolean{color:#f0abfc;font-weight:600}.hl-null{color:#94a3b8;font-style:italic}.hl-punctuation{color:#cbd5e1}.hl-keyword{color:#f0abfc;font-weight:600}.hl-function{color:#fde68a}.hl-comment-line,.hl-comment-block{color:#64748b;font-style:italic}.hl-operator{color:#cbd5e1}.hl-identifier,.hl-text{color:#e2e8f0}.hl-whitespace{color:inherit}.api-mock-intro{background:linear-gradient(135deg,#fdf4ff,#fae8ff);border-color:#e9d5ff}.mock-user-card{display:flex;gap:.85rem;align-items:center;padding:.85rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:.6rem}.mock-user-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;background:#e5e7eb;border:2px solid white;box-shadow:var(--shadow-sm)}.mock-feed-list{list-style:none;padding:0;margin:.7rem 0 0;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.mock-feed-item{display:flex;gap:.6rem;align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem}.mock-feed-thumb{width:50px;height:50px;object-fit:cover;border-radius:6px;background:#e5e7eb}.api-mock-intro{background:#fdf4ff;border-color:#e9d5ff}.api-mock-card{margin-bottom:.75rem}.mock-user-card{display:flex;gap:.85rem;align-items:center;padding:.75rem;background:#f9fafb;border-radius:8px;margin-top:.5rem}.mock-user-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;background:#e5e7eb}.mock-user-name{font-weight:600;font-size:1rem}.mock-feed-list{list-style:none;padding:0;margin:.6rem 0 0;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.mock-feed-item{display:flex;gap:.6rem;align-items:center;background:#f9fafb;border-radius:6px;padding:.5rem}.mock-feed-thumb{width:50px;height:50px;object-fit:cover;border-radius:4px;background:#e5e7eb}.skeleton{display:inline-block;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.2s infinite;vertical-align:middle;margin-bottom:.35rem}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.crumbs{font-size:.85rem;color:var(--color-muted);margin-bottom:.75rem}.crumbs a{color:var(--color-muted)}.crumbs span{margin:0 .3rem}.learn-fab{position:fixed;bottom:24px;right:24px;z-index:4900;display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:1px solid #4338ca;padding:.55rem 1rem;font-size:.88rem;font-weight:600;border-radius:999px;box-shadow:0 6px 20px #4f46e559,0 2px 4px #0000001a;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.learn-fab:hover{transform:translateY(-1px);box-shadow:0 10px 24px #4f46e573,0 2px 4px #0000001a}.learn-fab:active{transform:translateY(0)}.learn-panel-tabs{display:inline-flex;gap:.25rem;background:#f3f4f6;padding:3px;border-radius:8px}.learn-panel-tab{background:transparent;border:none;padding:.35rem .7rem;font-size:.82rem;font-weight:500;color:#475569;border-radius:6px;cursor:pointer}.learn-panel-tab:hover{color:#1f2937}.learn-panel-tab.active{background:#fff;color:#4f46e5;box-shadow:0 1px 2px #00000014}.learn-panel-empty{text-align:center;padding:1.5rem .5rem;color:#6b7280}.learn-panel-empty-glyph{font-size:2rem}.learn-inspect-head{margin-bottom:.6rem;font-size:.95rem}.locator-lab{display:flex;flex-direction:column;gap:.7rem;font-size:.86rem}.lab-types{display:inline-flex;gap:.25rem;flex-wrap:wrap}.lab-type{background:#f3f4f6;border:1px solid var(--color-border);padding:.3rem .65rem;font-size:.78rem;font-weight:500;border-radius:999px;cursor:pointer;color:#374151}.lab-type:hover{background:#e5e7eb}.lab-type.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.lab-helper{margin:0;font-size:.74rem;color:var(--color-muted)}.lab-input-wrap{position:relative}.lab-input{width:100%;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.82rem;padding:.5rem .6rem;border:1.5px solid #cbd5e1;border-radius:6px;resize:vertical;min-height:2.4rem;background:#fafafa;box-sizing:border-box;line-height:1.45}.lab-input:focus{outline:none;border-color:#4f46e5;background:#fff;box-shadow:0 0 0 3px #4f46e526}.lab-suggest{list-style:none;margin:4px 0 0;padding:4px 0;position:absolute;top:100%;left:0;right:0;z-index:5100;background:#fff;border:1px solid #cbd5e1;border-radius:8px;box-shadow:0 8px 24px #0f172a2e;max-height:280px;overflow-y:auto}.lab-suggest-head{display:flex;align-items:center;justify-content:space-between;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);padding:.3rem .6rem .35rem;border-bottom:1px solid #f1f5f9}.lab-suggest-kbd{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.66rem;text-transform:none;letter-spacing:0;color:#94a3b8;background:#f8fafc;padding:1px 6px;border-radius:4px;border:1px solid #e2e8f0}.lab-suggest-item{display:flex;align-items:center;gap:.5rem;padding:.35rem .6rem;font-size:.78rem;cursor:pointer;border-left:2px solid transparent}.lab-suggest-item.active,.lab-suggest-item:hover{background:#eef2ff;border-left-color:#4f46e5}.lab-suggest-kind{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:1px 6px;border-radius:4px;background:#f1f5f9;color:#475569;flex:0 0 auto;min-width:54px;text-align:center}.lab-suggest-kind.kind-testid{background:#dcfce7;color:#14532d}.lab-suggest-kind.kind-id{background:#e0e7ff;color:#312e81}.lab-suggest-kind.kind-role{background:#ede9fe;color:#5b21b6}.lab-suggest-kind.kind-label{background:#cffafe;color:#155e75}.lab-suggest-kind.kind-name{background:#fef9c3;color:#713f12}.lab-suggest-kind.kind-placeholder{background:#fff7ed;color:#9a3412}.lab-suggest-kind.kind-attr{background:#fee2e2;color:#7f1d1d}.lab-suggest-kind.kind-text{background:#fce7f3;color:#831843}.lab-suggest-kind.kind-class{background:#f1f5f9;color:#334155}.lab-suggest-kind.kind-tag{background:#e2e8f0;color:#1e293b}.lab-suggest-value{flex:1 1 auto;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.76rem;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lab-suggest-mark{background:#fef08a;color:inherit;padding:0 1px;border-radius:2px}.lab-suggest-hint{flex:0 0 auto;font-size:.7rem;color:var(--color-muted);white-space:nowrap;max-width:40%;overflow:hidden;text-overflow:ellipsis}.lab-suggest-count{flex:0 0 auto;font-size:.7rem;color:#b45309;background:#fef3c7;padding:1px 6px;border-radius:999px;font-weight:600}.lab-status{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;font-size:.78rem;min-height:1.5rem}.lab-pill{display:inline-flex;align-items:center;padding:.18rem .55rem;border-radius:999px;font-size:.75rem;font-weight:600;border:1px solid transparent}.lab-pill.good{background:#dcfce7;color:#14532d;border-color:#86efac}.lab-pill.warn{background:#fef3c7;color:#78350f;border-color:#fcd34d}.lab-pill.err{background:#fee2e2;color:#7f1d1d;border-color:#fca5a5}.lab-pill.stability{background:#fff;border-color:#e5e7eb;letter-spacing:1px}.lab-pill.stability-5{color:#16a34a}.lab-pill.stability-4{color:#65a30d}.lab-pill.stability-3{color:#ca8a04}.lab-pill.stability-2{color:#ea580c}.lab-pill.stability-1{color:#dc2626}.lab-tips{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.3rem}.lab-tip{display:flex;align-items:flex-start;gap:.4rem;font-size:.78rem;padding:.4rem .55rem;border-radius:6px;line-height:1.4}.lab-tip-glyph{flex:0 0 auto}.lab-tip-good{background:#f0fdf4;color:#14532d}.lab-tip-warn{background:#fffbeb;color:#78350f}.lab-tip-error{background:#fef2f2;color:#7f1d1d}.lab-tip-suggest{background:#eef2ff;color:#312e81}.lab-preview{border:1px dashed #cbd5e1;border-radius:6px;padding:.5rem .6rem;background:#fafbfc}.lab-preview-head{font-size:.7rem;color:var(--color-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.2rem}.lab-preview-code{display:block;font-size:.78rem;word-break:break-all;white-space:pre-wrap;color:#1f2937}.lab-section{margin-top:.2rem}.lab-section-h{font-size:.82rem;font-weight:600;margin-bottom:.35rem;color:#1f2937}.lab-section-sub{font-size:.74rem;margin:0 0 .4rem}.lab-example-list{display:flex;flex-wrap:wrap;gap:.3rem}.lab-example{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.74rem;background:#f8fafc;border:1px solid #e2e8f0;padding:.25rem .55rem;border-radius:4px;color:#334155;cursor:pointer}.lab-example:hover{background:#eef2ff;border-color:#c7d2fe;color:#312e81}.lab-example-more{font-family:inherit;background:transparent;border-style:dashed;color:var(--color-muted)}.lab-challenges{display:flex;flex-wrap:wrap;gap:.3rem}.lab-challenge{background:#fff;border:1px solid var(--color-border);padding:.3rem .6rem .3rem .5rem;font-size:.76rem;font-weight:500;border-radius:999px;color:#374151;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.lab-challenge:hover{background:#f9fafb}.lab-challenge.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.lab-challenge-dot{width:7px;height:7px;border-radius:50%;flex:0 0 7px}.lab-diff-easy{background:#10b981}.lab-diff-medium{background:#f59e0b}.lab-diff-hard{background:#ef4444}.lab-challenge-meta{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.4rem}.lab-diff-badge{font-size:.62rem;font-weight:700;letter-spacing:.04em;padding:.15rem .45rem;border-radius:4px;color:#fff}.lab-diff-badge.lab-diff-easy{background:#10b981}.lab-diff-badge.lab-diff-medium{background:#f59e0b}.lab-diff-badge.lab-diff-hard{background:#ef4444}.lab-rule-badge{font-size:.68rem;font-weight:600;padding:.15rem .45rem;border-radius:4px;background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.lab-challenge-detail{margin-top:.5rem;border:1px solid #e2e8f0;border-left:3px solid #4f46e5;border-radius:6px;padding:.55rem .7rem;background:#fafbff}.lab-challenge-goal{font-size:.82rem;color:#1f2937;margin-bottom:.25rem}.lab-challenge-where{font-size:.72rem;margin-bottom:.45rem}.lab-verify{background:#4f46e5;color:#fff;border:none;padding:.4rem .85rem;font-size:.8rem;font-weight:600;border-radius:6px;cursor:pointer}.lab-verify:hover{background:#4338ca}.lab-result{margin-top:.5rem;padding:.45rem .6rem;border-radius:6px;font-size:.78rem;line-height:1.4}.lab-result-pass{background:#dcfce7;color:#14532d;border:1px solid #86efac}.lab-result-partial{background:#fef3c7;color:#78350f;border:1px solid #fcd34d}.lab-result-fail{background:#fee2e2;color:#7f1d1d;border:1px solid #fca5a5}.lab-match-rect{position:fixed;pointer-events:none;z-index:4800;border:2px solid #16a34a;background:#16a34a14;box-shadow:0 0 0 3px #16a34a26;border-radius:2px;transition:top .08s linear,left .08s linear,width .08s linear,height .08s linear}.lab-match-num{position:absolute;top:-10px;left:-10px;background:#16a34a;color:#fff;font-size:.66rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 1px 2px #0003}.learn-page{max-width:880px;margin:0 auto;padding-bottom:2.5rem}.learn-breadcrumb{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--color-muted);margin-bottom:1rem}.learn-breadcrumb a{color:var(--color-primary)}.learn-hero{background:linear-gradient(135deg,#f0fdf4,#ecfdf5,#eef2ff);border:1px solid #c7d2fe;border-radius:16px;padding:1.6rem 1.8rem 1.4rem;margin-bottom:1.5rem}.learn-hero-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#4f46e5;margin-bottom:.3rem}.learn-hero-title{font-size:1.8rem;margin:0 0 .5rem;line-height:1.15}.learn-hero-sub{font-size:1rem;line-height:1.55;color:#1f2937;margin:0 0 1.1rem;max-width:60ch}.learn-how{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin:.4rem 0 1.1rem}.learn-how-step{flex:1 1 160px;background:#ffffffb3;border:1px solid rgba(199,210,254,.7);border-radius:10px;padding:.65rem .8rem;min-width:160px}.learn-how-num{width:24px;height:24px;background:#4f46e5;color:#fff;border-radius:999px;font-weight:700;font-size:.78rem;display:inline-flex;align-items:center;justify-content:center;margin-bottom:.25rem}.learn-how-h{font-weight:600;font-size:.95rem}.learn-how-sub{font-size:.8rem;color:#4b5563}.learn-how-arrow{font-size:1.2rem;color:#6b7280;align-self:center}.learn-cta-row{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-top:.6rem}.learn-cta-primary{font-size:1rem;padding:.6rem 1.1rem;font-weight:600}.learn-reset{font-size:.82rem;color:var(--color-muted)}.learn-progress{margin-top:1rem;background:#ffffffb3;border:1px solid rgba(199,210,254,.7);border-radius:10px;padding:.6rem .85rem}.learn-progress-text{font-size:.85rem;margin-bottom:.4rem}.learn-progress-track{background:#e5e7eb;border-radius:999px;height:8px;overflow:hidden}.learn-progress-fill{background:linear-gradient(90deg,#10b981,#4f46e5);height:100%;transition:width .3s ease}.learn-modules-section{margin-top:1.4rem}.learn-modules-h{font-size:1.1rem;margin:0 0 .7rem}.learn-modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.85rem}.learn-module-link{text-decoration:none;color:inherit}.learn-module-link:hover{text-decoration:none}.learn-module-card{background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:.95rem 1.05rem .85rem;display:flex;flex-direction:column;gap:.5rem;transition:box-shadow .18s,transform .18s,border-color .18s;height:100%;min-height:152px}.learn-module-link:hover .learn-module-card{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:#c7d2fe}.learn-module-card.done{background:#f0fdf4;border-color:#86efac}.learn-module-card.planned{opacity:.6}.learn-module-head{display:flex;justify-content:space-between;align-items:center}.learn-module-num{font-size:.72rem;font-weight:600;color:var(--color-muted);letter-spacing:.04em;text-transform:uppercase}.learn-module-status{font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;letter-spacing:.03em}.learn-module-status.done{background:#10b981;color:#fff}.learn-module-status.ready{background:#eef2ff;color:#4f46e5;border:1px solid #c7d2fe}.learn-module-status.planned{background:#f3f4f6;color:#6b7280;border:1px solid #e5e7eb}.learn-module-title{font-size:1rem;margin:0;line-height:1.3}.learn-module-sub{font-size:.82rem;line-height:1.45;color:#4b5563;margin:0;flex:1}.learn-module-foot{display:flex;justify-content:space-between;align-items:center;font-size:.78rem}.learn-module-time{color:var(--color-muted)}.learn-module-go{color:var(--color-primary);font-weight:600}.learn-complete-banner{margin-top:1.4rem;padding:.9rem 1.1rem;background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1px solid #86efac;border-radius:10px;font-size:.95rem}.learn-foot-note{margin-top:1.4rem;font-size:.85rem;text-align:center}.learn-chapter{background:#fff}.learn-chapter-head{margin-bottom:1.6rem;padding-bottom:1.1rem;border-bottom:1px solid var(--color-border)}.learn-chapter-meta{display:flex;gap:.8rem;flex-wrap:wrap;font-size:.8rem;color:var(--color-muted);margin-bottom:.5rem}.learn-chapter-num{font-weight:600;color:#4f46e5}.learn-chapter-done{background:#10b981;color:#fff;padding:.1rem .5rem;border-radius:999px;font-weight:700}.learn-chapter-title{font-size:2rem;margin:0 0 .5rem;line-height:1.15}.learn-chapter-lede{font-size:1.05rem;line-height:1.55;color:#1f2937;margin:0}.learn-section{margin:1.6rem 0}.learn-section-h{display:flex;align-items:center;gap:.6rem;font-size:1.2rem;margin:0 0 .7rem;line-height:1.3}.learn-section-n{background:#4f46e5;color:#fff;width:28px;height:28px;border-radius:50%;font-size:.85rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex:0 0 28px}.learn-section-body{font-size:.96rem;line-height:1.65;color:#1f2937}.learn-section-body p{margin:0 0 .7rem}.learn-section-body p>code,.learn-section-body li>code,.learn-section-body .learn-callout>code,.learn-section-body .learn-callout code:not([class*=hl-]){background:#f3f4f6;padding:.05rem .35rem;border-radius:4px;font-size:.88em}.learn-callout{background:#fffbeb;border:1px solid #fcd34d;border-left:3px solid #f59e0b;border-radius:6px;padding:.7rem .85rem;margin:.7rem 0;font-size:.92rem;line-height:1.55}.learn-checklist,.learn-recap{margin:.5rem 0 .7rem 1.2rem;padding:0}.learn-checklist li,.learn-recap li{margin-bottom:.45rem;line-height:1.55}.learn-bad-good{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:.6rem 0}@media (max-width: 720px){.learn-bad-good{grid-template-columns:1fr}}.learn-bad,.learn-good{border-radius:10px;padding:.65rem;border:1px solid}.learn-bad{background:#fef2f2;border-color:#fca5a5}.learn-good{background:#f0fdf4;border-color:#86efac}.learn-bad-h,.learn-good-h{font-weight:700;margin-bottom:.5rem;font-size:.92rem}.learn-bad-h{color:#991b1b}.learn-good-h{color:#166534}.learn-try{background:#eef2ff;border:1px dashed #a5b4fc;border-radius:8px;padding:.8rem .95rem;margin:.8rem 0}.learn-figure{margin:.9rem 0;background:#0b1220;border:1px solid #1e293b;border-radius:12px;padding:.5rem .5rem .4rem;box-shadow:0 6px 24px #0000002e}.learn-figure img{display:block;width:100%;height:auto;border-radius:8px;max-height:720px;object-fit:contain;background:#0b1220}.pseudo-badge{display:inline-block;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#78350f;border:1px solid #fbbf24;border-radius:999px;padding:.35rem .95rem .35rem .75rem;font-size:.88rem;font-weight:600}.pseudo-badge:before{content:"✦ NEW";font-size:.7rem;letter-spacing:.05em;font-weight:800;color:#b91c1c;background:#fff;padding:.1rem .4rem;border-radius:4px;margin-right:.45rem;vertical-align:middle}.learn-figure figcaption{font-size:.78rem;line-height:1.5;color:#94a3b8;padding:.55rem .4rem .2rem;font-style:italic}@media (max-width: 720px){.learn-figure{padding:.35rem .35rem .25rem}.learn-figure img{max-height:480px}}.learn-try-btn{background:#4f46e5;color:#fff;border:none;padding:.55rem 1rem;font-weight:600;border-radius:7px;cursor:pointer;font-size:.92rem;margin-bottom:.4rem}.learn-try-btn:hover{background:#4338ca}.learn-try-hint{font-size:.82rem;line-height:1.5}.learn-chapter-foot{margin-top:2rem;padding-top:1.2rem;border-top:1px solid var(--color-border);display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}.learn-mark-done{font-weight:600}.learn-mark-done:disabled{background:#10b981;opacity:.85}.learn-go-recap{margin-left:auto}.learn-complete-hero{text-align:center;background:linear-gradient(135deg,#ecfdf5,#eef2ff);border:1px solid #c7d2fe;border-radius:16px;padding:1.8rem 1.4rem;margin-bottom:1.6rem}.learn-complete-confetti{font-size:2.5rem;margin-bottom:.4rem}.learn-complete-title{font-size:1.7rem;margin:0 0 .4rem;line-height:1.2}.learn-complete-sub{margin:0 auto 1rem;max-width:56ch;color:#1f2937;line-height:1.55}.learn-stats{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:.8rem}.learn-stat{background:#fff;border:1px solid #c7d2fe;border-radius:10px;padding:.6rem 1rem;min-width:110px}.learn-stat-value{font-size:1.2rem;font-weight:700;color:#4f46e5}.learn-stat-label{font-size:.75rem;color:var(--color-muted);margin-top:.15rem}.learn-complete-section{margin:1.6rem 0}.learn-complete-h{font-size:1.15rem;margin:0 0 .6rem}.learn-cheat-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.learn-recap-list{margin:0;padding-left:1.2rem}.learn-recap-list li{margin-bottom:.35rem}.learn-next-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.7rem;margin-top:.6rem}.learn-next-link{text-decoration:none;color:inherit}.learn-next-link:hover{text-decoration:none}.learn-next-card{background:#fff;border:1px solid var(--color-border);border-radius:10px;padding:.85rem .95rem;height:100%;display:flex;flex-direction:column;gap:.3rem;transition:box-shadow .15s,border-color .15s,transform .15s}.learn-next-link:hover .learn-next-card{box-shadow:var(--shadow-md);border-color:#c7d2fe;transform:translateY(-1px)}.learn-next-card.disabled{opacity:.55;cursor:not-allowed}.learn-next-card h3{margin:0;font-size:.95rem}.learn-next-card p{margin:0;font-size:.82rem;line-height:1.5;color:#4b5563;flex:1}.learn-next-cta{font-size:.82rem;font-weight:600;color:var(--color-primary)}.learn-complete-foot{margin-top:1.6rem;padding-top:1rem;border-top:1px solid var(--color-border)}.back-to-lesson-pill{position:fixed;bottom:18px;left:18px;z-index:70;display:inline-flex;align-items:stretch;background:#4f46e5;color:#fff;border-radius:999px;box-shadow:0 6px 20px #4f46e566;font-weight:600;font-size:.85rem;animation:back-pill-in .25s ease-out}@keyframes back-pill-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.back-to-lesson-link{color:#fff!important;padding:.55rem .9rem .55rem 1.05rem;text-decoration:none;display:inline-flex;align-items:center}.back-to-lesson-link:hover{text-decoration:none}.back-to-lesson-dismiss{background:#ffffff26;border:none;color:#fff;width:30px;border-radius:0 999px 999px 0;cursor:pointer;font-size:1rem;line-height:1}.back-to-lesson-dismiss:hover{background:#ffffff40}.nav-learn-item-feature{background:linear-gradient(90deg,#eef2ff,#ecfdf5);border:1px solid #c7d2fe;margin-bottom:.25rem}.nav-learn-item-feature:hover{background:linear-gradient(90deg,#e0e7ff,#d1fae5)}.lab-ai-coach{margin-top:.5rem;border:1px solid #c7d2fe;background:linear-gradient(135deg,#faf5ff,#eef2ff);border-radius:8px;padding:.55rem .7rem}.lab-ai-head{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.lab-ai-btn{background:#6366f1;color:#fff;border:none;padding:.4rem .85rem;border-radius:6px;font-size:.82rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:.35rem}.lab-ai-btn:hover:not(:disabled){background:#4f46e5}.lab-ai-btn:disabled{opacity:.6;cursor:not-allowed}.lab-ai-settings{font-size:.78rem;color:var(--color-muted);padding:.35rem .55rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;margin-left:auto}.lab-ai-settings:hover{background:#f9fafb;color:var(--color-text)}.lab-ai-result{margin-top:.55rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;padding:.6rem .7rem}.lab-ai-result-text{font-size:.85rem;line-height:1.55;color:#1f2937}.lab-ai-line{margin-bottom:.25rem}.lab-ai-line:last-child{margin-bottom:0}.lab-ai-meta{display:flex;justify-content:space-between;align-items:center;margin-top:.45rem;font-size:.72rem}.lab-ai-prompt-toggle{background:transparent;border:1px solid var(--color-border);color:var(--color-muted);font-size:.72rem;padding:.15rem .5rem;border-radius:4px;cursor:pointer}.lab-ai-prompt-toggle:hover{background:#f3f4f6}.lab-ai-prompt{margin-top:.4rem;background:#0b1220;color:#e2e8f0;font-size:.72rem;line-height:1.5;padding:.55rem .7rem;border-radius:6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;white-space:pre-wrap;word-break:break-word}.lab-ai-error{margin-top:.55rem;background:#fef2f2;border:1px solid #fca5a5;color:#991b1b;border-radius:6px;padding:.5rem .65rem;font-size:.82rem}.ai-settings-body{display:flex;flex-direction:column;gap:.9rem;font-size:.88rem;line-height:1.55;color:#1f2937}.ai-settings-intro{margin:0}.ai-settings-intro code{background:#f3f4f6;padding:.05rem .35rem;border-radius:4px;font-size:.85em}.ai-settings-field{display:flex;flex-direction:column;gap:.35rem}.ai-settings-label{font-weight:600;font-size:.85rem}.ai-settings-key-row{display:flex;gap:.3rem;align-items:stretch}.ai-settings-key-input{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.82rem;padding:.5rem .65rem;border:1px solid var(--color-border);border-radius:6px}.ai-settings-reveal{border:1px solid var(--color-border);border-radius:6px;padding:0 .65rem;background:#fff;cursor:pointer;font-size:1rem}.ai-settings-model-select{padding:.5rem .65rem;border:1px solid var(--color-border);border-radius:6px;background:#fff;font-size:.85rem}.ai-settings-hint{font-size:.78rem;color:var(--color-muted);line-height:1.5}.ai-settings-hint a{color:var(--color-primary)}.ai-settings-error{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b;border-radius:6px;padding:.5rem .65rem;font-size:.82rem}.ai-settings-clear{color:#b91c1c}.ai-settings-clear:hover{background:#fef2f2;color:#991b1b}.ai-settings-details{font-size:.82rem;background:#f9fafb;border:1px solid var(--color-border);border-radius:6px;padding:.55rem .7rem}.ai-settings-details summary{cursor:pointer;font-weight:600}.ai-settings-details ul{margin:.4rem 0 .4rem 1.2rem;padding:0}.ai-settings-details li{margin-bottom:.2rem}.ai-settings-details code{font-size:.78rem}.nav-learn-item-foot{width:100%;background:transparent;border:none;text-align:left;cursor:pointer;font:inherit}.nav-learn-item-pill{display:inline-block;margin-left:.45rem;background:#10b981;color:#fff;font-size:.62rem;font-weight:700;padding:.05rem .4rem;border-radius:999px;vertical-align:middle;letter-spacing:.04em;text-transform:uppercase}.whats-new{max-width:880px;margin:0 auto;padding-bottom:2.5rem}.whats-new-hero{background:linear-gradient(135deg,#eef2ff,#ecfdf5);border:1px solid #c7d2fe;border-radius:16px;padding:1.6rem 1.8rem 1.4rem;margin-bottom:1.4rem}.whats-new-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#4f46e5;margin-bottom:.3rem}.whats-new-title{font-size:1.7rem;margin:0 0 .4rem;line-height:1.15}.whats-new-sub{font-size:.95rem;margin:0 0 .9rem;color:#1f2937}.whats-new-sub a{color:var(--color-primary)}.whats-new-legend{display:flex;flex-wrap:wrap;gap:.4rem}.wn-kind-pill{font-size:.72rem;font-weight:600;padding:.18rem .55rem;border-radius:999px;display:inline-flex;align-items:center;gap:.3rem;border:1px solid}.wn-kind-added{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.wn-kind-updated{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}.wn-kind-fix{background:#fff7ed;color:#9a3412;border-color:#fed7aa}.whats-new-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.9rem}.whats-new-release{background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:1.05rem 1.2rem 1.1rem;position:relative}.whats-new-release:before{content:"";position:absolute;inset:0 0 auto 0;height:3px;border-radius:12px 12px 0 0;background:linear-gradient(90deg,#4f46e5,#10b981)}.whats-new-release-meta{display:flex;justify-content:space-between;align-items:center;gap:.6rem;margin-bottom:.35rem;flex-wrap:wrap}.whats-new-release-date{font-size:.78rem;font-weight:700;color:#4f46e5;letter-spacing:.03em;text-transform:uppercase}.whats-new-release-counts{font-size:.72rem;color:var(--color-muted)}.whats-new-release-title{font-size:1.15rem;margin:0 0 .3rem;line-height:1.3}.whats-new-release-summary{font-size:.9rem;line-height:1.55;margin:0 0 .7rem;color:#4b5563}.whats-new-items{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.45rem}.whats-new-item{display:flex;align-items:flex-start;gap:.55rem;padding:.5rem .65rem;border-radius:8px;border:1px solid var(--color-border);background:#f9fafb;font-size:.88rem;line-height:1.55}.whats-new-item.wn-kind-added{border-color:#a7f3d0;background:#f0fdf4}.whats-new-item.wn-kind-updated{border-color:#c7d2fe;background:#eef2ff}.whats-new-item.wn-kind-fix{border-color:#fed7aa;background:#fff7ed}.whats-new-item-tag{flex:0 0 auto;font-size:.7rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap;padding:.05rem .45rem;border-radius:4px;background:#fff;border:1px solid currentColor;align-self:flex-start}.whats-new-item.wn-kind-added .whats-new-item-tag{color:#065f46}.whats-new-item.wn-kind-updated .whats-new-item-tag{color:#4338ca}.whats-new-item.wn-kind-fix .whats-new-item-tag{color:#9a3412}.whats-new-item-text{flex:1}.whats-new-item-text code{background:#ffffffb3;padding:0 .25rem;border-radius:3px;font-size:.88em}.whats-new-foot{margin-top:1.4rem;font-size:.85rem;text-align:center}.whats-new-foot a{color:var(--color-primary)}.tc-page{max-width:1080px;margin:0 auto;padding-bottom:2.5rem}.tc-hero{background:linear-gradient(135deg,#f0fdf4,#ecfdf5,#eef2ff);border:1px solid #c7d2fe;border-radius:16px;padding:1.6rem 1.8rem 1.4rem;margin-bottom:1.4rem}.tc-hero-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#4f46e5;margin-bottom:.3rem}.tc-hero-title{font-size:1.7rem;margin:0 0 .4rem;line-height:1.15}.tc-hero-sub{font-size:.95rem;margin:0 0 1.1rem;color:#1f2937;max-width:64ch}.tc-stats{display:flex;gap:.7rem;flex-wrap:wrap}.tc-stat{background:#fff;border:1px solid #c7d2fe;border-radius:10px;padding:.55rem 1rem;min-width:110px}.tc-stat-value{font-size:1.4rem;font-weight:700;color:var(--color-primary)}.tc-stat-label{font-size:.72rem;color:var(--color-muted);margin-top:.1rem;letter-spacing:.04em;text-transform:uppercase}.tc-stat.tc-pos .tc-stat-value{color:#047857}.tc-stat.tc-neg .tc-stat-value{color:#b91c1c}.tc-controls{background:#fff;border:1px solid var(--color-border);border-radius:12px;padding:.85rem 1rem;margin-bottom:1rem;position:sticky;top:56px;z-index:20;box-shadow:0 4px 12px #0000000a}.tc-search-row{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-bottom:.6rem}.tc-search{flex:1 1 260px;font-size:.9rem;padding:.5rem .8rem;border:1px solid var(--color-border);border-radius:8px}.tc-search:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e52e}.tc-kind-pills{display:inline-flex;gap:.3rem}.tc-kind-pill{background:#fff;border:1px solid var(--color-border);color:var(--color-text);padding:.4rem .8rem;border-radius:999px;font-size:.82rem;font-weight:500;cursor:pointer}.tc-kind-pill:hover{background:#f9fafb}.tc-kind-pill.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 1px 4px #4f46e540}.tc-area-row{display:flex;flex-wrap:wrap;gap:.3rem;padding-top:.4rem;border-top:1px dashed var(--color-border);margin-top:.4rem}.tc-area-chip{background:#fff;border:1px solid var(--color-border);color:var(--color-text);padding:.25rem .65rem;border-radius:999px;font-size:.78rem;cursor:pointer;display:inline-flex;align-items:center;gap:.3rem}.tc-area-chip:hover{background:#f3f4f6}.tc-area-chip.active{background:#eef2ff;color:var(--color-primary);border-color:#c7d2fe;font-weight:600}.tc-area-count{background:#0000000f;border-radius:999px;font-size:.7rem;padding:0 .4rem;margin-left:.2rem}.tc-area-chip.active .tc-area-count{background:#4f46e526;color:var(--color-primary)}.tc-bulk-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.4rem;margin-top:.6rem;padding-top:.5rem;border-top:1px dashed var(--color-border)}.tc-result-line{font-size:.82rem}.tc-bulk-actions{display:inline-flex;gap:.35rem}.tc-bulk-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-muted);font-size:.78rem;padding:.25rem .6rem;border-radius:5px;cursor:pointer}.tc-bulk-btn:hover{background:#f9fafb;color:var(--color-text)}.tc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.tc-item{background:#fff;border:1px solid var(--color-border);border-left:3px solid #d1d5db;border-radius:8px;overflow:hidden;transition:box-shadow .15s,border-color .15s,transform .1s}.tc-item.tc-pos{border-left-color:#10b981}.tc-item.tc-neg{border-left-color:#ef4444}.tc-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.tc-item-head{width:100%;display:grid;grid-template-columns:auto auto 1fr auto auto auto;align-items:center;gap:.55rem;padding:.65rem .85rem;background:#fff;border:none;cursor:pointer;text-align:left;font:inherit;color:var(--color-text)}.tc-item-head:hover{background:#fafbff}.tc-kind-glyph{font-size:.95rem;line-height:1;flex:0 0 auto}.tc-item-id{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.72rem;color:var(--color-muted);background:#f3f4f6;padding:.1rem .45rem;border-radius:4px;letter-spacing:.02em}.tc-item-title{font-size:.93rem;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis}.tc-pri-pill{font-size:.65rem;font-weight:700;padding:.1rem .4rem;border-radius:4px;letter-spacing:.04em;text-transform:uppercase}.tc-pri-high{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.tc-pri-med{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.tc-pri-low{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.tc-area-pill{font-size:.7rem;background:#eef2ff;color:#4338ca;padding:.1rem .45rem;border-radius:4px;border:1px solid #c7d2fe;white-space:nowrap}.tc-caret{font-size:.85rem;color:var(--color-muted);margin-left:.2rem}@media (max-width: 720px){.tc-item-head{grid-template-columns:auto auto 1fr auto}.tc-pri-pill,.tc-area-pill{display:none}}.tc-item-body{padding:.4rem .95rem .95rem;background:linear-gradient(180deg,#fafbff,#fff);border-top:1px dashed var(--color-border);animation:tc-slide-in .15s ease-out}@keyframes tc-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.tc-item-section{margin-bottom:.65rem}.tc-item-section-h{font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted);margin-bottom:.25rem}.tc-steps{margin:0;padding-left:1.3rem;font-size:.86rem;line-height:1.55;color:#1f2937}.tc-steps li{margin-bottom:.2rem}.tc-expected{margin:0;font-size:.86rem;line-height:1.55;color:#1f2937;background:#ecfdf5;border-left:3px solid #10b981;border-radius:4px;padding:.45rem .65rem}.tc-item.tc-neg .tc-expected{background:#fef2f2;border-left-color:#ef4444}.tc-item-actions{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.55rem}.tc-action{font-size:.78rem;padding:.35rem .75rem;border-radius:5px;text-decoration:none;border:1px solid var(--color-border);background:#fff;color:var(--color-text);cursor:pointer;display:inline-flex;align-items:center;gap:.3rem}.tc-action:hover{background:#f9fafb;text-decoration:none}.tc-action-link{background:var(--color-primary);color:#fff!important;border-color:var(--color-primary)}.tc-action-link:hover{background:var(--color-primary-dark)}.tc-empty{text-align:center;padding:2rem 1rem;background:#fff;border:1px dashed var(--color-border);border-radius:12px}.tc-empty-glyph{font-size:2rem;margin-bottom:.4rem}.tc-empty h3{margin:0 0 .3rem;font-size:1rem}.tc-foot{margin-top:1.2rem;font-size:.82rem;text-align:center}.tc-foot code{background:#f3f4f6;padding:.05rem .35rem;border-radius:4px;font-size:.86em}.quiz-page{max-width:720px;margin:0 auto;padding-bottom:2.5rem}.quiz-hero{background:linear-gradient(135deg,#faf5ff,#eef2ff,#ecfdf5);border:1px solid #c7d2fe;border-radius:16px;padding:1.8rem 1.8rem 1.5rem;text-align:center;display:flex;flex-direction:column;align-items:center}.quiz-hero-eyebrow{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#4f46e5;margin-bottom:.3rem}.quiz-hero-title{font-size:1.9rem;margin:0 0 .5rem;line-height:1.15}.quiz-hero-sub{font-size:.95rem;margin:0 0 1.2rem;max-width:52ch;color:#1f2937;line-height:1.55}.quiz-prev{display:flex;gap:1.2rem;background:#fff;border:1px solid #c7d2fe;border-radius:10px;padding:.7rem 1.2rem;margin:0 0 1.1rem;flex:0 0 auto}.quiz-scoreboard{background:linear-gradient(135deg,#eef2ff,#ecfdf5);border:1px solid #c7d2fe;border-radius:12px;padding:.95rem 1.1rem;margin:0 0 1.1rem;width:100%;max-width:480px;box-shadow:0 1px 4px #4f46e51a;flex:0 0 auto}.quiz-scoreboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-bottom:.7rem}.quiz-scorestat{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.6rem .55rem;text-align:center}.quiz-scorestat-total{border-color:#c7d2fe}.quiz-scorestat-passed{border-color:#a7f3d0}.quiz-scorestat-failed{border-color:#fde68a}.quiz-scorestat-value{font-size:1.5rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}.quiz-scorestat-total .quiz-scorestat-value{color:#4f46e5}.quiz-scorestat-passed .quiz-scorestat-value{color:#047857}.quiz-scorestat-failed .quiz-scorestat-value{color:#b45309}.quiz-scorestat-label{font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted);margin-top:.3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quiz-scoreboard-cta{font-size:.95rem;text-align:center;color:#1f2937;padding-top:.5rem;border-top:1px dashed rgba(79,70,229,.25);line-height:1.4}.quiz-scoreboard-cta strong{color:#4f46e5}@media (max-width: 480px){.quiz-scorestat-value{font-size:1.25rem}.quiz-scorestat-label{font-size:.62rem}.quiz-scorestat{padding:.5rem .35rem}}.quiz-result-global{margin-top:.7rem;font-size:.88rem;line-height:1.45;opacity:.9}.quiz-result-global strong{font-variant-numeric:tabular-nums}.quiz-prev-row{display:flex;flex-direction:column;align-items:center}.quiz-prev-label{font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-muted)}.quiz-prev-value{font-size:1.05rem;font-weight:700;color:var(--color-primary);margin-top:.1rem}.quiz-start-btn{background:var(--color-primary);color:#fff;border:none;font-size:1rem;font-weight:600;padding:.7rem 1.4rem;border-radius:8px;cursor:pointer;box-shadow:0 4px 12px #4f46e540}.quiz-start-btn:hover{background:var(--color-primary-dark)}.quiz-hero-note{font-size:.85rem;margin:1.1rem 0 0;max-width:52ch}.quiz-hero-note a{color:var(--color-primary)}.quiz-progress{margin-bottom:1rem}.quiz-progress-text{font-size:.85rem;margin-bottom:.35rem}.quiz-progress-track{background:#e5e7eb;border-radius:999px;height:6px;overflow:hidden}.quiz-progress-fill{background:linear-gradient(90deg,#10b981,#4f46e5);height:100%;transition:width .3s ease}.quiz-card{background:#fff;border:1px solid var(--color-border);border-radius:14px;padding:1.4rem 1.5rem 1.2rem;box-shadow:0 4px 20px #0000000d}.quiz-mod-pill{display:inline-block;background:#eef2ff;color:#4338ca;border:1px solid #c7d2fe;font-size:.72rem;font-weight:600;padding:.18rem .55rem;border-radius:999px;letter-spacing:.02em;margin-bottom:.65rem}.quiz-prompt{font-size:1.1rem;line-height:1.45;margin:0 0 1.1rem;color:#1f2937;font-weight:500}.quiz-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.9rem}.quiz-option{display:flex;align-items:center;gap:.7rem;background:#fff;border:1px solid var(--color-border);border-radius:8px;padding:.7rem .85rem;font:inherit;font-size:.9rem;color:var(--color-text);cursor:pointer;text-align:left;transition:background .12s,border-color .12s,box-shadow .12s}.quiz-option:hover:not(:disabled){background:#f9fafb;border-color:#c7d2fe}.quiz-option:disabled{cursor:default}.quiz-option-letter{flex:0 0 26px;width:26px;height:26px;background:#eef2ff;color:#4338ca;border-radius:6px;font-size:.78rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.quiz-option-text{flex:1;line-height:1.45;word-break:break-word}.quiz-option-mark{flex:0 0 auto;font-size:1.05rem;font-weight:700}.quiz-option-picked{background:#eef2ff;border-color:#818cf8}.quiz-option-correct{background:#f0fdf4;border-color:#86efac}.quiz-option-correct .quiz-option-letter{background:#10b981;color:#fff}.quiz-option-correct .quiz-option-mark{color:#16a34a}.quiz-option-wrong{background:#fef2f2;border-color:#fca5a5}.quiz-option-wrong .quiz-option-letter{background:#ef4444;color:#fff}.quiz-option-wrong .quiz-option-mark{color:#dc2626}.quiz-explanation{border-radius:8px;padding:.7rem .85rem;font-size:.88rem;line-height:1.55;border:1px solid;animation:quiz-fade-in .2s ease-out}@keyframes quiz-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.quiz-exp-correct{background:#f0fdf4;border-color:#86efac;color:#166534}.quiz-exp-wrong{background:#fffbeb;border-color:#fde68a;color:#78350f}.quiz-exp-link{font-weight:600;white-space:nowrap}.quiz-card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px dashed var(--color-border)}.quiz-quit{font-size:.85rem;color:var(--color-muted)}.quiz-result-hero{text-align:center;border-radius:16px;padding:2rem 1.4rem 1.6rem;margin-bottom:1.5rem;border:1px solid}.quiz-band-perfect{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fbbf24;color:#78350f}.quiz-band-good{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#86efac;color:#166534}.quiz-band-ok{background:linear-gradient(135deg,#eef2ff,#ddd6fe);border-color:#c7d2fe;color:#4338ca}.quiz-band-low{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fde68a;color:#92400e}.quiz-result-band{font-size:.95rem;font-weight:700;letter-spacing:.02em;margin-bottom:.4rem}.quiz-result-score{font-size:3rem;font-weight:800;line-height:1}.quiz-result-total{font-size:1.4rem;opacity:.7;font-weight:600}.quiz-result-pct{font-size:.95rem;margin-top:.4rem;opacity:.8}.quiz-review-h{font-size:1rem;margin:0 0 .7rem}.quiz-review-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.quiz-review-item{background:#fff;border:1px solid var(--color-border);border-left:3px solid #ef4444;border-radius:8px;padding:.6rem .85rem}.quiz-review-mod{font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#b91c1c;margin-bottom:.2rem}.quiz-review-prompt{font-size:.88rem;line-height:1.45;color:var(--color-text);margin-bottom:.35rem}.quiz-review-link{font-size:.82rem;font-weight:600;color:var(--color-primary)}.quiz-review-clean{background:#fff;border:1px solid #86efac;border-radius:10px;padding:1rem 1.2rem;font-size:.92rem;text-align:center}.quiz-review-clean a{color:var(--color-primary);font-weight:600}.quiz-result-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1.4rem;justify-content:center}.quiz-result-actions .btn-ghost{color:var(--color-primary)}@media (max-width: 720px){input[type=text],input[type=email],input[type=password],input[type=search],input[type=tel],input[type=url],input[type=number],input[type=date],input[type=time],input[type=datetime-local],textarea,select{font-size:16px}}@media (max-width: 720px){.container{padding:.85rem}body{-webkit-text-size-adjust:100%}.section-title{font-size:1.4rem}}@media (max-width: 720px){.navbar{position:relative;transform:translateZ(0)}.navbar-inner{padding:.5rem .85rem;gap:.5rem;flex-wrap:wrap}.navbar-brand{font-size:1rem}.navbar-links{gap:.15rem;row-gap:.35rem}.nav-link{padding:.35rem .55rem;font-size:.88rem}.nav-cta{padding:.4rem .75rem;font-size:.85rem}.navbar-sep{display:none}}@media (max-width: 720px){.nav-learn-dropdown{position:fixed;left:.5rem;right:.5rem;top:calc(var(--navbar-h, 56px) + .4rem);min-width:0;max-height:calc(100vh - var(--navbar-h, 56px) - 1rem);overflow-y:auto}}.nav-learn-mobile-note{display:flex;align-items:flex-start;gap:.5rem;padding:.55rem .65rem;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;font-size:.82rem;line-height:1.45;color:#78350f}@media (max-width: 720px){.learn-hero,.learn-complete-hero,.quiz-hero,.quiz-result-hero,.tc-hero,.whats-new-hero{padding:1.2rem 1rem;border-radius:12px}.learn-hero-title,.quiz-hero-title,.tc-hero-title,.whats-new-title{font-size:1.4rem}}@media (max-width: 720px){.learn-how{flex-direction:column;gap:.4rem}.learn-how-arrow{transform:rotate(90deg)}}@media (max-width: 720px){.two-col{grid-template-columns:1fr!important;gap:1rem}}@media (max-width: 720px){[data-testid=cart-table]{display:block;width:100%}[data-testid=cart-table] thead{display:none}[data-testid=cart-table] tbody{display:block}[data-testid=cart-table] tr{display:grid;grid-template-columns:1fr auto;gap:.4rem .6rem;padding:.7rem .85rem;border-bottom:1px solid var(--color-border)}[data-testid=cart-table] tr:last-child{border-bottom:none}[data-testid=cart-table] td{display:flex;align-items:center;border:none;padding:0}[data-testid=cart-table] td:first-child{grid-column:1 / -1;font-weight:500}[data-testid=cart-table] td:nth-of-type(2):before{content:"Price:";color:var(--color-muted);margin-right:.4rem;font-size:.78rem}[data-testid=cart-table] td:nth-of-type(4):before{content:"Subtotal:";color:var(--color-muted);margin-right:.4rem;font-size:.78rem}[data-testid=cart-table] td:nth-of-type(3){justify-content:flex-end}[data-testid=cart-table] td:nth-of-type(5){grid-column:1 / -1;justify-content:flex-end}}@media (max-width: 720px){.checkout-step-indicator{gap:.3rem;flex-wrap:wrap}.form-group input,.form-group textarea,.form-group select{width:100%}}@media (max-width: 720px){.tc-controls{position:static;padding:.65rem .7rem}.tc-search-row{flex-direction:column;align-items:stretch}.tc-kind-pills{width:100%;justify-content:space-between}.tc-kind-pill{flex:1 1 auto;text-align:center;padding:.45rem .5rem;font-size:.78rem}.tc-area-row{gap:.25rem}.tc-area-chip{font-size:.74rem;padding:.22rem .55rem}.tc-bulk-row{font-size:.78rem}.tc-item-id{display:none}}@media (max-width: 720px){.modal-overlay{padding:1rem .5rem .5rem;align-items:flex-start}.modal{padding:1rem;max-height:calc(100vh - 2rem);overflow-y:auto}.modal h3{font-size:1.05rem}.modal-actions{flex-wrap:wrap}}@media (max-width: 720px){.quiz-card{padding:1rem 1rem .9rem;border-radius:10px}.quiz-prompt{font-size:1rem}.quiz-option{padding:.6rem .7rem;font-size:.86rem}.quiz-result-hero{padding:1.4rem 1rem 1.2rem}.quiz-result-score{font-size:2.4rem}.quiz-result-actions .btn,.quiz-result-actions .btn-secondary,.quiz-result-actions .btn-ghost{flex:1 1 100%;text-align:center}}@media (max-width: 720px){.challenges-grid{grid-template-columns:1fr}}@media (max-width: 720px){.learn-modules-grid{grid-template-columns:1fr}.learn-module-card{padding:.85rem .95rem;min-height:0}.learn-chapter-title{font-size:1.5rem}.learn-chapter-lede{font-size:.95rem}.learn-section-h{font-size:1rem}.learn-section-body{font-size:.92rem}}@media (max-width: 720px){.toast-container{top:auto;left:.5rem;right:.5rem;bottom:.5rem}.toast{max-width:100%}}:root{--color-primary: #4f46e5;--color-primary-dark: #4338ca;--color-secondary: #f97316;--color-bg: #f9fafb;--color-surface: #ffffff;--color-border: #e5e7eb;--color-text: #111827;--color-muted: #6b7280;--color-success: #16a34a;--color-danger: #dc2626;--color-warning: #d97706;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--radius: 8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:16px;color:var(--color-text);background-color:var(--color-bg)}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:inherit;font-size:.95rem;border-radius:var(--radius);border:1px solid transparent;padding:.55rem 1rem;transition:background-color .15s,border-color .15s,color .15s}button:disabled{opacity:.55;cursor:not-allowed}.btn{background:var(--color-primary);color:#fff}.btn:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:#fff;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-secondary:hover:not(:disabled){background:#eef2ff}.btn-danger{background:var(--color-danger);color:#fff}.btn-success{background:var(--color-success);color:#fff}.btn-ghost{background:transparent;color:var(--color-text)}.btn-link{background:none;border:none;color:var(--color-primary);padding:0;text-decoration:underline}input,select,textarea{font-family:inherit;font-size:.95rem;padding:.5rem .7rem;border:1px solid var(--color-border);border-radius:var(--radius);background:#fff;width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--color-primary);outline-offset:1px}label{font-size:.9rem;font-weight:500;display:block;margin-bottom:.3rem;color:var(--color-text)}.container{max-width:1200px;margin:0 auto;padding:1.25rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow-sm)}.grid{display:grid;gap:1rem}.row{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.muted{color:var(--color-muted)}.error-text{color:var(--color-danger);font-size:.85rem;margin-top:.25rem}.success-text{color:var(--color-success);font-size:.85rem;margin-top:.25rem}.badge{display:inline-block;background:var(--color-primary);color:#fff;border-radius:999px;font-size:.75rem;padding:.15rem .55rem}.badge-secondary{background:var(--color-secondary)}.badge-success{background:var(--color-success)}.badge-danger{background:var(--color-danger)}.badge-muted{background:#9ca3af}table{width:100%;border-collapse:collapse;background:#fff}th,td{text-align:left;padding:.6rem .8rem;border-bottom:1px solid var(--color-border);font-size:.95rem}th{background:#f3f4f6;font-weight:600}.section-title{font-size:1.4rem;font-weight:700;margin:0 0 .75rem}.h-divider{height:1px;background:var(--color-border);margin:1rem 0}
