:root{--bg-light: #fafafa;--bg-light-alt: #f5f5f7;--bg-light-elevated: #ffffff;--text-on-light: #1d1d1f;--text-on-light-2: #6e6e73;--text-on-light-3: #86868b;--border-light: #d2d2d7;--bg-dark: #1d1d1f;--bg-dark-deep: #000000;--bg-dark-elevated: #2d2d2f;--text-on-dark: #f5f5f7;--text-on-dark-2: #a1a1a6;--text-on-dark-3: #6e6e73;--border-dark: #424245;--accent: #7EC8E3;--accent-hover: #5BA3C9;--accent-subtle: rgba(126, 200, 227, .1);--accent-glow: rgba(126, 200, 227, .25);--module-1: #7EC8E3;--module-2: #B8B8E8;--module-3: #95D5B2;--module-4: #F0B27A;--data-blue: #7EC8E3;--data-green: #95D5B2;--data-purple: #B8B8E8;--data-orange: #F0B27A;--data-red: #E07A7A;--data-yellow: #F0D264;--data-pink: #E8A0BF;--data-teal: #6BC5D2;--color-success: #34C759;--color-warning: #FF9500;--color-error: #FF3B30;--font-display: "Playfair Display", "Noto Serif SC", Georgia, serif;--font-heading: "Inter", "Noto Sans SC", -apple-system, sans-serif;--font-body: "Noto Sans SC", "Inter", -apple-system, sans-serif;--font-code: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--text-hero: clamp(3rem, 6vw, 5rem);--text-display: clamp(2.5rem, 5vw, 4.5rem);--text-title: clamp(1.75rem, 3vw, 2.5rem);--text-heading: clamp(1.25rem, 2vw, 1.75rem);--text-body: clamp(1rem, 1.2vw, 1.25rem);--text-small: .875rem;--text-caption: .75rem;--text-stat: clamp(3rem, 8vw, 7rem);--w-reading: 680px;--w-content: 960px;--w-full: 1200px;--space-xs: 8px;--space-sm: 16px;--space-md: 24px;--space-lg: 48px;--space-xl: 80px;--space-2xl: 120px;--space-3xl: 200px;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 12px 40px rgba(0,0,0,.12);--shadow-hover: 0 20px 60px rgba(0,0,0,.15);--shadow-glow: 0 4px 24px var(--accent-glow);--shadow-dark: 0 4px 16px rgba(0,0,0,.4);--ease-apple: cubic-bezier(.25, .46, .45, .94);--ease-out: cubic-bezier(.16, 1, .3, 1);--t-fast: .2s var(--ease-apple);--t-base: .35s var(--ease-apple);--t-slow: .6s var(--ease-apple)}@media(max-width:768px){:root{--space-xl: 48px;--space-2xl: 64px;--space-3xl: 80px}}@media(max-width:480px){:root{--space-xl: 32px;--space-2xl: 48px;--space-3xl: 56px}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:var(--font-body);font-size:var(--text-body);font-weight:400;line-height:1.8;color:var(--text-on-light);background:var(--bg-light);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}@media(max-width:768px){body{font-size:16px;line-height:1.6}}.page-scroll{overflow-x:hidden;width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:700;line-height:1.1;letter-spacing:-.02em}h1{font-size:var(--text-display)}h2{font-size:var(--text-title)}h3{font-size:var(--text-heading)}h4{font-size:var(--text-body);font-weight:600}h5{font-size:var(--text-small);font-weight:600}h6{font-size:var(--text-caption);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.subtitle{font-family:var(--font-heading);font-weight:300;line-height:1.4;color:var(--text-on-light-2)}.section-dark .subtitle{color:var(--text-on-dark-2)}.stat-number{font-family:var(--font-display);font-size:var(--text-stat);font-weight:700;line-height:1.1;letter-spacing:-.02em}p{max-width:var(--w-reading)}.section-dark p{color:var(--text-on-dark-2)}a{color:var(--accent);text-decoration:none;transition:color var(--t-fast)}a:hover{color:var(--accent-hover)}strong{font-weight:600}img,svg{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit}hr{border:none;height:1px;background:var(--border-light);margin:var(--space-lg) 0}.section-dark hr{background:var(--border-dark)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-on-light-3);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-on-light-2)}::selection{background:#7ec8e34d;color:var(--text-on-light)}.section-dark ::selection{color:var(--text-on-dark)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:14px 32px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-full);font-family:var(--font-heading);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--t-base);box-shadow:0 2px 12px var(--accent-glow);min-height:44px;min-width:44px}.btn-primary:hover{transform:scale(1.03);box-shadow:0 6px 24px var(--accent-glow);background:var(--accent-hover)}.btn-primary:active{transform:scale(.97)}.btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:14px 32px;background:transparent;color:var(--accent);border:1.5px solid var(--accent);border-radius:var(--radius-full);font-family:var(--font-heading);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--t-base);min-height:44px;min-width:44px}.btn-ghost:hover{background:var(--accent-subtle)}.btn-ghost:active{background:var(--accent-subtle);transform:scale(.97)}.btn-outline-light{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:14px 32px;background:transparent;color:var(--text-on-dark-2);border:1.5px solid rgba(255,255,255,.25);border-radius:var(--radius-full);font-family:var(--font-heading);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--t-base);min-height:44px;min-width:44px}.btn-outline-light:hover{border-color:#fff9;color:var(--text-on-dark);background:#ffffff0f}.btn-outline-light:active{transform:scale(.97)}.btn-small{padding:8px 20px;font-size:var(--text-small);min-height:36px}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;border-radius:var(--radius-sm);color:var(--text-on-light-2);transition:all var(--t-fast)}.btn-icon:hover{background:var(--bg-light-alt);color:var(--text-on-light)}.section-dark .btn-icon{color:var(--text-on-dark-2)}.section-dark .btn-icon:hover{background:var(--bg-dark-elevated);color:var(--text-on-dark)}.btn-primary:disabled,.btn-ghost:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.tag{display:inline-block;padding:4px 12px;font-size:var(--text-caption);font-weight:500;border-radius:var(--radius-full);background:var(--accent-subtle);color:var(--accent);line-height:1.4}.tag-m1{background:#7ec8e326;color:var(--module-1)}.tag-m2{background:#b8b8e826;color:var(--module-2)}.tag-m3{background:#95d5b226;color:var(--module-3)}.tag-m4{background:#f0b27a26;color:var(--module-4)}.tag-success{background:#34c7591f;color:var(--color-success)}.tag-warning{background:#ff95001f;color:var(--color-warning)}.tag-error{background:#ff3b301f;color:var(--color-error)}pre{font-family:var(--font-code);font-size:14px;line-height:1.6;background:var(--bg-dark);color:var(--text-on-dark);padding:var(--space-md);border-radius:var(--radius-md);overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}code{font-family:var(--font-code);font-size:.9em;background:var(--accent-subtle);color:var(--accent-hover);padding:2px 6px;border-radius:4px}pre code{background:none;color:inherit;padding:0}.section-dark code{background:#7ec8e326;color:var(--accent)}.section-dark pre code{background:none;color:inherit}@media(max-width:768px){pre,.cm-editor{font-size:13px;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word}}.input{display:block;width:100%;padding:10px 16px;font-size:1rem;border:1.5px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-light-elevated);color:var(--text-on-light);transition:border-color var(--t-fast),box-shadow var(--t-fast);min-height:44px}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.input::placeholder{color:var(--text-on-light-3)}.section-dark .input{background:var(--bg-dark-elevated);border-color:var(--border-dark);color:var(--text-on-dark)}.section-dark .input::placeholder{color:var(--text-on-dark-3)}.section-dark .input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}textarea.input{min-height:120px;resize:vertical;line-height:1.6}.input-number{-moz-appearance:textfield}.input-number::-webkit-outer-spin-button,.input-number::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.select{display:block;width:100%;padding:10px 40px 10px 16px;font-size:1rem;border:1.5px solid var(--border-light);border-radius:var(--radius-sm);background:var(--bg-light-elevated) url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2386868b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 16px center;color:var(--text-on-light);appearance:none;-webkit-appearance:none;cursor:pointer;transition:border-color var(--t-fast);min-height:44px}.select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.section-dark .select{background-color:var(--bg-dark-elevated);border-color:var(--border-dark);color:var(--text-on-dark);background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236e6e73' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}.range{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--border-light);border-radius:var(--radius-full);outline:none;cursor:pointer}.range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--accent);border-radius:50%;border:none;box-shadow:0 1px 4px #0003;cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-fast)}.range::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 2px 8px var(--accent-glow)}.range::-moz-range-thumb{width:20px;height:20px;background:var(--accent);border-radius:50%;border:none;box-shadow:0 1px 4px #0003;cursor:pointer}.section-dark .range{background-color:var(--border-dark)}@media(max-width:768px){.range{height:6px;min-height:32px}.range::-webkit-slider-thumb{width:24px;height:24px}.range::-moz-range-thumb{width:24px;height:24px}}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md);border:1px solid var(--border-light)}.section-dark .table-wrapper{border-color:var(--border-dark)}table{width:100%;border-collapse:collapse;font-size:var(--text-small)}th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-light)}th{font-weight:600;color:var(--text-on-light-2);font-size:var(--text-caption);text-transform:uppercase;letter-spacing:.05em;background:var(--bg-light-alt)}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-light-alt)}.section-dark th{color:var(--text-on-dark-2);background:var(--bg-dark-elevated);border-bottom-color:var(--border-dark)}.section-dark td{color:var(--text-on-dark);border-bottom-color:var(--border-dark)}.section-dark tr:hover td{background:var(--bg-dark-elevated)}.divider{height:1px;background:var(--border-light);margin:var(--space-lg) 0;border:none}.section-dark .divider{background:var(--border-dark)}.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:11px;font-weight:600;color:#fff;background:var(--accent);border-radius:var(--radius-full);line-height:1}.color-swatch{display:inline-block;width:48px;height:48px;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.1);flex-shrink:0}.color-swatch-lg{width:80px;height:80px;border-radius:var(--radius-md)}.copy-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:var(--text-small);font-family:var(--font-heading);font-weight:500;color:var(--text-on-dark-2);background:var(--bg-dark-elevated);border:1px solid var(--border-dark);border-radius:var(--radius-full);cursor:pointer;transition:all var(--t-fast);min-height:36px;white-space:nowrap}.copy-btn:hover{color:var(--text-on-dark);border-color:var(--accent);background:#7ec8e31a}.copy-btn:active{transform:scale(.95)}.copy-btn.copy-success{color:var(--color-success, #34c759);border-color:var(--color-success, #34c759);background:#34c7591a}.copy-btn.copy-error{color:var(--color-error, #ff3b30);border-color:var(--color-error, #ff3b30);background:#ff3b301a}.section-light .copy-btn{color:var(--text-on-light-2);background:var(--bg-light-elevated);border-color:var(--border-light)}.section-light .copy-btn:hover{color:var(--text-on-light);border-color:var(--accent);background:var(--accent-subtle)}.code-editor-wrapper{position:relative;border-radius:12px;overflow:hidden}.code-editor-readonly-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.code-editor-readonly-overlay .edit-btn{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-full);font-size:var(--text-small);font-family:var(--font-heading);font-weight:500;cursor:pointer;min-height:44px;transition:all var(--t-fast)}.code-editor-readonly-overlay .edit-btn:active{transform:scale(.95)}.chart-preview-wrapper{border-radius:12px;overflow:hidden}.chart-svg{display:block}.lang-switch.active{background:var(--accent);color:#fff;border-color:var(--accent)}.lang-switch.active:hover{background:var(--accent-hover)}.tab-switcher{display:inline-flex;position:relative;gap:0;background:var(--bg-dark-elevated);border-radius:var(--radius-sm);padding:3px;border:1px solid var(--border-dark)}.section-light .tab-switcher{background:var(--bg-light-alt);border-color:var(--border-light)}.tab-switcher__tab{position:relative;z-index:1;padding:8px 20px;border:none;background:none;font-family:var(--font-heading);font-size:var(--text-small);font-weight:500;color:var(--text-on-dark-3);cursor:pointer;transition:color var(--t-fast);min-height:36px;border-radius:6px;white-space:nowrap}.section-light .tab-switcher__tab{color:var(--text-on-light-3)}.tab-switcher__tab.active{color:var(--text-on-dark)}.section-light .tab-switcher__tab.active{color:var(--text-on-light)}.tab-switcher__tab:hover:not(.active){color:var(--text-on-dark-2)}.section-light .tab-switcher__tab:hover:not(.active){color:var(--text-on-light-2)}.tab-switcher__indicator{position:absolute;top:3px;bottom:3px;background:var(--accent);border-radius:6px;transition:all .3s cubic-bezier(.16,1,.3,1);z-index:0;opacity:.15}.tab-switcher--pill{border-radius:var(--radius-full);padding:4px}.tab-switcher--pill .tab-switcher__tab{border-radius:var(--radius-full);padding:8px 24px}.tab-switcher--pill .tab-switcher__indicator{border-radius:var(--radius-full);top:4px;bottom:4px}@media(max-width:768px){.tab-switcher{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;max-width:100%}.tab-switcher::-webkit-scrollbar{display:none}.tab-switcher__tab{flex-shrink:0;padding:8px 14px;font-size:.8rem}.tab-switcher--pill .tab-switcher__tab{padding:8px 16px}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.modal-container{background:var(--bg-dark-elevated);border-radius:var(--radius-lg);max-width:560px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 24px 80px #00000080;border:1px solid var(--border-dark)}.modal-container--large{max-width:800px}.modal-container--fullscreen{max-width:none;max-height:none;width:100%;height:100%;border-radius:0}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-md) 0;flex-shrink:0}.modal-title{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:600;color:var(--text-on-dark);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:none;color:var(--text-on-dark-3);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--t-fast)}.modal-close:hover{background:#ffffff14;color:var(--text-on-dark)}.modal-body{padding:var(--space-md);overflow-y:auto;color:var(--text-on-dark-2);line-height:1.7}@media(max-width:768px){.modal-overlay{padding:0;align-items:flex-end}.modal-container{max-width:none;max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0}}.accordion{border:1px solid var(--border-dark);border-radius:var(--radius-md);overflow:hidden}.section-light .accordion{border-color:var(--border-light)}.accordion__item{border-bottom:1px solid var(--border-dark)}.section-light .accordion__item{border-bottom-color:var(--border-light)}.accordion__item:last-child{border-bottom:none}.accordion__header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-sm) var(--space-md);border:none;background:none;color:var(--text-on-dark);font-family:var(--font-heading);font-size:1rem;font-weight:500;cursor:pointer;min-height:52px;text-align:left;transition:background var(--t-fast)}.section-light .accordion__header{color:var(--text-on-light)}.accordion__header:hover{background:#ffffff0a}.section-light .accordion__header:hover{background:var(--bg-light-alt)}.accordion__icon{transition:transform .3s cubic-bezier(.16,1,.3,1);flex-shrink:0;color:var(--text-on-dark-3)}.section-light .accordion__icon{color:var(--text-on-light-3)}.accordion__item.expanded .accordion__icon{transform:rotate(180deg)}.accordion__content{overflow:hidden;height:0}.accordion__inner{padding:0 var(--space-md) var(--space-md);color:var(--text-on-dark-2);line-height:1.7}.section-light .accordion__inner{color:var(--text-on-light-2)}.before-after{position:relative;overflow:hidden;border-radius:var(--radius-md);cursor:col-resize;user-select:none;-webkit-user-select:none}.before-after__after,.before-after__before{width:100%;min-height:200px}.before-after__after{position:relative}.before-after__before{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.before-after__handle{position:absolute;top:0;bottom:0;z-index:2;width:2px;transform:translate(-50%)}.before-after__handle-line{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;transform:translate(-50%);box-shadow:0 0 8px #0000004d}.before-after__handle-grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #0000004d;color:var(--text-on-light-2);gap:0}.before-after__label{position:absolute;top:var(--space-sm);z-index:3;padding:4px 12px;background:#00000080;color:#fff;font-size:var(--text-caption);font-weight:500;border-radius:var(--radius-full);pointer-events:none}.before-after__label--before{left:var(--space-sm)}.before-after__label--after{right:var(--space-sm)}@media(max-width:768px){.before-after{cursor:default}.before-after__handle-grip{width:48px;height:48px}}.toast-container{position:fixed;bottom:calc(16px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);z-index:2000;display:flex;flex-direction:column-reverse;gap:var(--space-xs);pointer-events:none;width:max-content;max-width:calc(100vw - 32px)}@media(max-width:768px){.toast-container{bottom:calc(72px + env(safe-area-inset-bottom,0px))}}.toast{display:flex;align-items:center;gap:var(--space-xs);padding:12px 20px;background:var(--bg-dark-elevated);color:var(--text-on-dark);border-radius:var(--radius-full);font-size:var(--text-small);font-family:var(--font-heading);box-shadow:0 8px 32px #0006;border:1px solid var(--border-dark);white-space:nowrap;pointer-events:auto;opacity:0;transform:translateY(16px) scale(.95);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out)}.toast--visible{opacity:1;transform:translateY(0) scale(1)}.toast--exit{opacity:0;transform:translateY(-8px) scale(.95)}.toast__icon{display:flex;flex-shrink:0}.toast--success .toast__icon{color:var(--color-success, #34c759)}.toast--error .toast__icon{color:var(--color-error, #ff3b30)}.toast--landscape .toast__icon{color:var(--accent)}.toast__message{flex:1}.toast__close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:none;color:var(--text-on-dark-3);cursor:pointer;border-radius:50%;flex-shrink:0;transition:all var(--t-fast)}.toast__close:hover{background:#ffffff1a;color:var(--text-on-dark)}.sticky-steps{display:grid;grid-template-columns:280px 1fr;gap:var(--space-xl);position:relative}.sticky-steps__fixed{padding:var(--space-md) 0}.sticky-steps__heading{font-family:var(--font-heading);font-size:var(--text-heading);font-weight:700;margin-bottom:var(--space-xs)}.sticky-steps__subheading{font-size:var(--text-small);color:var(--text-on-dark-2);margin-bottom:var(--space-md)}.section-light .sticky-steps__subheading{color:var(--text-on-light-2)}.sticky-steps__progress{height:3px;background:var(--border-dark);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-sm)}.section-light .sticky-steps__progress{background:var(--border-light)}.sticky-steps__progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .4s cubic-bezier(.16,1,.3,1);width:0}.sticky-steps__current-label{font-size:var(--text-caption);color:var(--accent);font-weight:500}.sticky-steps__scroll{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-md) 0}.sticky-steps__step{display:flex;gap:var(--space-md);opacity:.5;transition:opacity .4s var(--ease-apple)}.sticky-steps__step.active{opacity:1}.sticky-steps__step-marker{display:flex;flex-direction:column;align-items:center;flex-shrink:0}.sticky-steps__step-number{width:32px;height:32px;border-radius:50%;background:var(--border-dark);color:var(--text-on-dark-2);display:flex;align-items:center;justify-content:center;font-size:var(--text-small);font-weight:600;transition:all .3s var(--ease-apple)}.section-light .sticky-steps__step-number{background:var(--border-light);color:var(--text-on-light-2)}.sticky-steps__step.active .sticky-steps__step-number{background:var(--accent);color:#fff}.sticky-steps__step-line{width:2px;flex:1;background:var(--border-dark);margin:var(--space-xs) 0}.section-light .sticky-steps__step-line{background:var(--border-light)}.sticky-steps__step-title{font-family:var(--font-heading);font-weight:600;margin-bottom:var(--space-xs)}.sticky-steps__step-desc{font-size:var(--text-small);color:var(--text-on-dark-2);margin-bottom:var(--space-sm)}.section-light .sticky-steps__step-desc{color:var(--text-on-light-2)}.sticky-steps__step-content{padding:var(--space-sm);background:var(--bg-dark-elevated);border-radius:var(--radius-sm);font-size:var(--text-small);color:var(--text-on-dark-2)}.section-light .sticky-steps__step-content{background:var(--bg-light-alt);color:var(--text-on-light-2)}@media(max-width:768px){.sticky-steps{display:flex;flex-direction:column;gap:var(--space-md)}.sticky-steps__fixed{border-bottom:1px solid var(--border-dark);padding-bottom:var(--space-sm);margin-bottom:0}.section-light .sticky-steps__fixed{border-bottom-color:var(--border-light)}}.color-input{max-width:400px}.color-input__label{display:block;font-size:var(--text-small);font-weight:500;color:var(--text-on-dark-2);margin-bottom:var(--space-xs)}.section-light .color-input__label{color:var(--text-on-light-2)}.color-input__row{display:flex;gap:var(--space-sm);align-items:flex-start}.color-input__preview{width:56px;height:56px;border-radius:var(--radius-sm);border:2px solid var(--border-dark);flex-shrink:0;transition:background-color .15s}.section-light .color-input__preview{border-color:var(--border-light)}.color-input__fields{flex:1;min-width:0}.color-input__tabs{display:flex;gap:2px;margin-bottom:var(--space-xs);background:var(--bg-dark);border-radius:6px;padding:2px}.section-light .color-input__tabs{background:var(--bg-light-alt)}.color-input__tab{flex:1;padding:4px 8px;border:none;background:none;font-size:var(--text-caption);font-weight:600;color:var(--text-on-dark-3);cursor:pointer;border-radius:4px;transition:all var(--t-fast);min-height:28px}.section-light .color-input__tab{color:var(--text-on-light-3)}.color-input__tab.active{background:var(--accent);color:#fff}.color-input__hex-input{font-family:var(--font-code)!important;font-size:var(--text-small)!important;letter-spacing:.05em}.color-input__triple{display:flex;gap:var(--space-xs)}.color-input__triple label{flex:1;display:flex;flex-direction:column;gap:2px}.color-input__triple label span{font-size:10px;font-weight:600;color:var(--text-on-dark-3);text-transform:uppercase}.section-light .color-input__triple label span{color:var(--text-on-light-3)}.color-input__triple .input{padding:6px 8px;font-size:var(--text-small);min-height:32px;text-align:center}.color-input__slider-row{margin-top:var(--space-sm)}.color-input__hue-slider{-webkit-appearance:none;appearance:none;width:100%;height:12px;border-radius:var(--radius-full);background:linear-gradient(to right,red,#ff0,#0f0,#0ff,#00f,#f0f,red);outline:none;cursor:pointer;min-height:44px;background-clip:content-box;padding:16px 0}.color-input__hue-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:#fff;border:2px solid rgba(0,0,0,.2);border-radius:50%;box-shadow:0 1px 4px #0000004d;cursor:pointer}.color-input__hue-slider::-moz-range-thumb{width:20px;height:20px;background:#fff;border:2px solid rgba(0,0,0,.2);border-radius:50%;box-shadow:0 1px 4px #0000004d;cursor:pointer}.workshop-layout{display:grid;grid-template-columns:280px 1fr 360px;gap:var(--space-md);min-height:400px;border:1px solid var(--border-dark);border-radius:var(--radius-md);overflow:hidden}.section-light .workshop-layout{border-color:var(--border-light)}.workshop-panel{display:flex;flex-direction:column;min-width:0}.workshop-panel-header{display:none}.workshop-panel-content{flex:1;padding:var(--space-md);overflow-y:auto}.workshop-panel:not(:last-child){border-right:1px solid var(--border-dark)}.section-light .workshop-panel:not(:last-child){border-right-color:var(--border-light)}.workshop-panel-title{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-heading);font-weight:500}.workshop-panel-icon{font-size:1.1em}.workshop-panel-chevron{transition:transform .3s cubic-bezier(.16,1,.3,1);color:var(--text-on-dark-3);flex-shrink:0}.section-light .workshop-panel-chevron{color:var(--text-on-light-3)}.workshop-panel.expanded .workshop-panel-chevron{transform:rotate(180deg)}@media(max-width:1024px){.workshop-layout{grid-template-columns:240px 1fr}.workshop-panel:nth-child(3){grid-column:1 / -1;border-right:none;border-top:1px solid var(--border-dark);max-height:300px}.section-light .workshop-panel:nth-child(3){border-top-color:var(--border-light)}}@media(max-width:768px){.workshop-layout{display:flex;flex-direction:column;min-height:auto;gap:0}.workshop-panel{border-right:none!important;border-bottom:1px solid var(--border-dark)}.section-light .workshop-panel{border-bottom-color:var(--border-light)}.workshop-panel:last-child{border-bottom:none}.workshop-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);cursor:pointer;min-height:52px;color:var(--text-on-dark);-webkit-tap-highlight-color:transparent}.section-light .workshop-panel-header{color:var(--text-on-light)}.workshop-panel-content{max-height:0;overflow:hidden;padding:0 var(--space-md);transition:max-height .35s cubic-bezier(.16,1,.3,1),padding .35s cubic-bezier(.16,1,.3,1)}.workshop-panel.expanded .workshop-panel-content{max-height:none;padding:var(--space-md);overflow-y:auto}}.hero-quicknav{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:var(--space-lg)}.hero-quicknav__item{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-full);color:var(--text-on-dark-2);font-family:var(--font-heading);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.25,.46,.45,.94);white-space:nowrap}.hero-quicknav__item:hover{background:#7ec8e31f;border-color:var(--accent);color:var(--text-on-dark);transform:translateY(-2px)}.hero-quicknav__item:active{transform:translateY(0);background:#7ec8e32e}@media(max-width:768px){.hero-quicknav{gap:8px;margin-top:var(--space-md)}.hero-quicknav__item{padding:8px 16px;font-size:.78rem}}@media(max-width:400px){.hero-quicknav{flex-direction:column;align-items:center}}#sidebar{position:fixed;left:0;top:0;width:260px;height:100vh;background:#fcfcfce0;backdrop-filter:saturate(180%) blur(24px);-webkit-backdrop-filter:saturate(180%) blur(24px);box-shadow:1px 0 #0000000d,4px 0 24px #00000005;z-index:100;overflow-y:auto;transition:transform var(--t-base);overscroll-behavior:contain}#sidebar::-webkit-scrollbar{width:4px}#sidebar::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}.sidebar-overlay{position:fixed;inset:0;background:#0006;z-index:99;opacity:0;pointer-events:none;transition:opacity var(--t-base)}.sidebar-overlay.active{opacity:1;pointer-events:auto}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm);box-shadow:0 1px #0000000a}.sidebar-logo{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--text-on-light);letter-spacing:.04em;text-shadow:0 0 24px rgba(126,200,227,.1)}.sidebar-close-btn{display:none}@media(max-width:1024px)and (min-width:769px){.sidebar-close-btn{display:flex}.sidebar-header{padding-left:56px}}.nav-module-group{padding:var(--space-xs) 0}.nav-module-group+.nav-module-group{box-shadow:0 -1px #0000000a}.nav-module-title{font-size:var(--text-small);font-weight:600;color:var(--text-on-light-2);padding:var(--space-xs) var(--space-sm);text-transform:none;letter-spacing:0;display:flex;align-items:center;gap:8px;cursor:pointer;transition:color var(--t-fast);-webkit-user-select:none;user-select:none}.nav-module-title:hover{color:var(--text-on-light)}.nav-module-color{width:8px;height:8px;border-radius:50%;flex-shrink:0}.nav-module-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-module-progress-badge{font-size:10px;font-weight:600;opacity:.7}.nav-module-chevron{display:flex;align-items:center;transition:transform var(--t-fast);color:var(--text-on-light-3)}.nav-module-group.expanded .nav-module-chevron{transform:rotate(180deg)}.nav-page-list{max-height:0;overflow:hidden;transition:max-height var(--t-base)}.nav-module-group.expanded .nav-page-list{max-height:600px}.nav-page-item{display:flex!important;align-items:center;gap:8px;padding:7px var(--space-sm) 7px 28px;font-size:.84rem;text-decoration:none;color:var(--text-on-light-2);border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-right:8px;transition:all .2s ease}.nav-page-item:hover{color:var(--text-on-light);background:#00000005}.nav-page-item.active{color:var(--accent);background:#7ec8e30f;font-weight:500}.nav-page-num{width:20px;height:20px;border-radius:50%;background:var(--bg-light-alt);font-size:var(--text-caption);color:var(--text-on-light-3);display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-page-item.active .nav-page-num{background:var(--accent);color:#fff}.nav-page-item.visited .nav-page-num{background:#34c75926;color:var(--color-success)}.nav-page-item.visited.active .nav-page-num{background:var(--accent);color:#fff}.nav-page-title{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-item{padding:10px var(--space-sm) 10px 16px;font-size:.88rem;color:var(--text-on-light-2);cursor:pointer;display:flex;align-items:center;gap:8px;text-decoration:none;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-right:8px;transition:all .2s ease}.nav-item.active{color:var(--accent);background:#7ec8e30f;border-left:2px solid var(--accent);font-weight:600}.nav-item:hover{color:var(--text-on-light);background:#00000006}.nav-item-icon{display:flex;align-items:center;flex-shrink:0;color:inherit}.nav-item-icon svg{width:18px;height:18px}.hamburger-btn{display:none;position:fixed;top:12px;left:12px;z-index:200;width:44px;height:44px;align-items:center;justify-content:center;background:#fafafae6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-light);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-on-light);transition:background var(--t-fast)}.hamburger-btn:active{background:var(--bg-light-alt)}@media(max-width:1024px)and (min-width:769px){.hamburger-btn{display:flex}}@media(max-width:768px){.hamburger-btn{display:none}}.top-bar-hidden{display:none!important}#main-content{margin-left:260px;min-height:100vh}@media(max-width:1200px)and (min-width:1025px){#sidebar{width:220px}#main-content{margin-left:220px}}@media(max-width:1024px)and (min-width:769px){#sidebar{transform:translate(-100%)}#sidebar.open{transform:translate(0)}#main-content{margin-left:0}}@media(max-width:768px){#sidebar{transform:translate(-100%);width:min(280px,85vw)}#sidebar.open{transform:translate(0)}.sidebar-close-btn{display:flex}#main-content{margin-left:0}}.section-light{background:var(--bg-light);color:var(--text-on-light);padding:var(--space-3xl) var(--space-lg);min-height:100vh;display:flex;flex-direction:column;justify-content:center}.section-dark{background:var(--bg-dark);color:var(--text-on-dark);padding:var(--space-3xl) var(--space-lg);min-height:100vh;display:flex;flex-direction:column;justify-content:center}.section-dark-deep{background:var(--bg-dark-deep);color:var(--text-on-dark);padding:var(--space-3xl) var(--space-lg);min-height:100vh;display:flex;flex-direction:column;justify-content:center}.section-light-alt{background:var(--bg-light-alt);color:var(--text-on-light);padding:var(--space-3xl) var(--space-lg);min-height:100vh;display:flex;flex-direction:column;justify-content:center}.section-auto{min-height:auto}@media(max-width:768px){.section-light,.section-dark,.section-dark-deep,.section-light-alt{padding:var(--space-xl) var(--space-sm);min-height:auto}.section-hero-full{min-height:100vh;min-height:100dvh}}.page-hero-title{font-family:var(--font-display);font-size:var(--text-display);font-weight:700;line-height:1.1;letter-spacing:-.02em;text-align:center}.page-hero-sub{font-family:var(--font-heading);font-size:var(--text-title);font-weight:300;line-height:1.4;text-align:center;opacity:.5;max-width:600px;margin:var(--space-md) auto 0}.hero-eyebrow{font-family:var(--font-code);font-size:var(--text-small);color:var(--accent);letter-spacing:.15em;text-transform:uppercase}.text-hero{font-family:var(--font-display);font-size:var(--text-hero);font-weight:700;line-height:1.1;letter-spacing:-.02em}.content-wrapper{max-width:var(--w-content);margin:0 auto;width:100%}.reading-wrapper{max-width:var(--w-reading);margin:0 auto;width:100%}.full-wrapper{max-width:var(--w-full);margin:0 auto;width:100%}@media(max-width:768px){.content-wrapper,.reading-wrapper,.full-wrapper{padding:0 var(--space-sm)}}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-col-center{display:flex;flex-direction:column;align-items:center}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.stagger-row{display:flex;align-items:center;gap:var(--space-xl)}.stagger-row.reverse{flex-direction:row-reverse}.stagger-row>*{flex:1;min-width:0}@media(max-width:768px){.stagger-row,.stagger-row.reverse{flex-direction:column;gap:var(--space-md)}}.two-column{display:flex;gap:var(--space-lg)}.two-column>*{flex:1;min-width:0}@media(max-width:768px){.two-column{flex-direction:column;gap:var(--space-md)}}.side-by-side{display:flex;gap:var(--space-md);align-items:flex-start}@media(max-width:768px){.side-by-side{flex-direction:column;gap:var(--space-md)}}.workshop-layout{display:grid;grid-template-columns:280px 1fr 360px;gap:var(--space-md);height:calc(100vh - 120px)}@media(max-width:1024px){.workshop-layout{grid-template-columns:240px 1fr}.workshop-code-panel{grid-column:1 / -1;max-height:300px}}@media(max-width:768px){.workshop-layout{display:flex;flex-direction:column;height:auto;gap:0}.workshop-panel{border-bottom:1px solid var(--border-dark)}.workshop-panel-header{padding:var(--space-sm);display:flex;justify-content:space-between;align-items:center;cursor:pointer;min-height:44px}.workshop-panel-content{max-height:0;overflow:hidden;transition:max-height var(--t-base)}.workshop-panel.expanded .workshop-panel-content{max-height:500px;overflow-y:auto}}.before-after{position:relative;overflow:hidden;border-radius:var(--radius-md);cursor:col-resize;touch-action:pan-y}@media(max-width:768px){.before-after{cursor:default}.before-after .slider-handle{width:40px}}.code-editor-wrapper{position:relative;border-radius:var(--radius-md);overflow:hidden}@media(max-width:768px){.code-editor-wrapper .cm-editor{font-size:13px}.code-editor-readonly-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;z-index:10}.code-editor-readonly-overlay .edit-btn{padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-full);font-size:var(--text-small);min-height:44px}}.page-footer-cta{background:var(--bg-dark-deep);color:var(--text-on-dark);padding:var(--space-3xl) var(--space-lg);text-align:center;min-height:40vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md)}.page-footer-num{font-family:var(--font-code);font-size:var(--text-caption);color:var(--text-on-dark-3);letter-spacing:.15em;text-transform:uppercase}.page-footer-quote{font-family:var(--font-display);font-size:clamp(1.6rem,4vw,2.8rem);font-weight:700;letter-spacing:-.02em;max-width:640px;line-height:1.3;color:var(--text-on-dark);text-align:center}.page-footer-quote:before{content:"“";margin-right:.1em}.page-footer-quote:after{content:"”";margin-left:.05em}.page-footer-desc{font-size:1rem;color:var(--text-on-dark-2);line-height:1.7;max-width:520px}.page-footer-nav{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;margin-top:var(--space-sm)}@media(max-width:480px){.page-footer-cta{min-height:auto;padding:var(--space-2xl) var(--space-md)}}.tab-bar{display:none;position:fixed;bottom:0;left:0;right:0;padding:6px 0;padding-bottom:max(6px,env(safe-area-inset-bottom,0px));background:#ffffffc7;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);box-shadow:0 -1px #0000000f,0 -8px 24px #0000000a;z-index:200;justify-content:space-around;align-items:center;transform:translateZ(0);-webkit-backface-visibility:hidden;will-change:transform}@media(max-width:768px){.tab-bar{display:flex}#main-content{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}}.tab-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 0;min-width:56px;color:var(--text-on-light-3);font-size:10px;font-weight:500;font-family:var(--font-heading);-webkit-tap-highlight-color:transparent;min-height:44px;justify-content:center;cursor:pointer;background:none;border:none;transition:transform .25s cubic-bezier(.34,1.56,.64,1),color .2s ease}.tab-item:active{transform:scale(.88)}.tab-item svg{width:24px;height:24px;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.tab-item span{transition:opacity .2s ease;opacity:.7}.tab-item.active svg{transform:translateY(-1px)}.tab-item.active span{opacity:1;font-weight:600}.tab-item:after{content:"";position:absolute;top:0;left:50%;width:20px;height:3px;border-radius:1.5px;background:currentColor;transform:translate(-50%) scaleX(0);transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.tab-item.active:after{transform:translate(-50%) scaleX(1)}.mobile-top-bar{display:none;position:fixed;top:0;left:0;right:0;height:48px;padding-top:env(safe-area-inset-top,0px);background:#ffffffc7;backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);box-shadow:0 1px #0000000f,0 4px 16px #00000008;z-index:150;align-items:center;padding-left:var(--space-sm);padding-right:var(--space-sm);gap:var(--space-sm);transform:translateZ(0)}@media(max-width:768px){.mobile-top-bar{display:flex}.mobile-top-bar.top-bar-hidden{display:none}#main-content.has-top-bar{padding-top:calc(48px + env(safe-area-inset-top))}}.mobile-menu-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;color:var(--text-on-light-2);background:none;border:none;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;border-radius:var(--radius-sm);transition:background var(--t-fast),color var(--t-fast)}.mobile-menu-btn:active{background:var(--bg-light-alt);color:var(--text-on-light)}.mobile-page-title{flex:1;font-size:.88rem;font-weight:600;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-on-light)}.mobile-page-index{font-size:.72rem;font-weight:500;color:var(--text-on-light-3);white-space:nowrap;font-variant-numeric:tabular-nums}@media(max-width:768px){body{font-size:16px;line-height:1.6}h1{font-size:clamp(1.75rem,6vw,2.5rem)}h2{font-size:clamp(1.25rem,4vw,1.75rem)}.content-wrapper{padding:0 var(--space-sm)}.two-column{flex-direction:column}.side-by-side{flex-direction:column;gap:var(--space-md)}section[id],[class*=-section]{scroll-margin-top:56px}.table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}pre,.cm-editor{font-size:13px;overflow-x:auto}img,svg.chart-svg{max-width:100%;height:auto}}.touchable{min-width:44px;min-height:44px}@media(max-width:768px){input[type=range]::-webkit-slider-thumb{width:24px;height:24px}input[type=range]::-moz-range-thumb{width:24px;height:24px}input[type=range]{min-height:36px}}@media(max-width:768px){.btn-primary:hover{transform:none;box-shadow:0 2px 12px var(--accent-glow)}.btn-primary:active{transform:scale(.97);background:var(--accent-hover)}.btn-ghost:hover{background:transparent}.btn-ghost:active{background:var(--accent-subtle)}.btn-icon:hover{background:transparent}.btn-icon:active{background:var(--bg-light-alt)}.nav-item:hover{background:transparent;color:var(--text-on-light-2)}.nav-item:active{background:var(--bg-light-alt);color:var(--text-on-light)}tr:hover td{background:transparent}}@media(max-width:480px){.page-hero-sub{font-size:var(--text-body)}}.fade-in{opacity:0;transform:translateY(60px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.fade-in.is-visible{opacity:1;transform:translateY(0)}@media(max-width:768px){.fade-in{transform:translateY(30px)}}.scale-reveal{opacity:0;transform:scale(.9);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}.scale-reveal.is-visible{opacity:1;transform:scale(1)}.slide-in-left{opacity:0;transform:translate(-60px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.slide-in-left.is-visible{opacity:1;transform:translate(0)}.slide-in-right{opacity:0;transform:translate(60px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.slide-in-right.is-visible{opacity:1;transform:translate(0)}@media(max-width:768px){.slide-in-left{transform:translate(-30px)}.slide-in-right{transform:translate(30px)}}.page-enter{animation:pageEnter .5s var(--ease-out) forwards}@keyframes pageEnter{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.landscape-hint{display:none;position:fixed;bottom:calc(72px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);background:var(--bg-dark-elevated);color:var(--text-on-dark);padding:12px 24px;border-radius:var(--radius-full);font-size:var(--text-small);z-index:300;white-space:nowrap;box-shadow:var(--shadow-dark);animation:slideUp .3s var(--ease-out)}@media(orientation:portrait)and (max-width:768px){.page-interactive-heavy .landscape-hint{display:block}}@keyframes slideUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes pulseGlow{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 8px transparent}}.pulse{animation:pulseGlow 2s var(--ease-apple) infinite}.fade-enter{animation:fadeEnter .35s var(--ease-out) forwards}.fade-exit{animation:fadeExit .2s var(--ease-apple) forwards}@keyframes fadeEnter{0%{opacity:0}to{opacity:1}}@keyframes fadeExit{0%{opacity:1}to{opacity:0}}.delay-1{transition-delay:.1s}.delay-2{transition-delay:.2s}.delay-3{transition-delay:.3s}.delay-4{transition-delay:.4s}.delay-5{transition-delay:.5s}.home-hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:0}#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}.home-hero-content{position:relative;z-index:1;text-align:center;max-width:800px;padding:0 var(--space-md)}.home-hero-title{font-family:var(--font-display);font-size:clamp(3.5rem,8vw,6rem);font-weight:700;line-height:1.05;letter-spacing:.02em;color:var(--text-on-dark);margin-bottom:var(--space-md)}.home-hero-slogan{font-family:var(--font-body);font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:300;color:var(--text-on-dark);opacity:.7;margin-bottom:var(--space-sm);letter-spacing:.08em}.home-hero-sub{font-family:var(--font-body);font-size:var(--text-body);color:var(--text-on-dark-2);max-width:520px;margin:0 auto var(--space-lg);line-height:1.7}.home-hero-actions{display:flex;gap:var(--space-sm);justify-content:center;flex-wrap:wrap}.home-hero-btn{display:inline-flex;align-items:center;gap:8px}.hero-kbd{display:inline-block;padding:2px 6px;font-size:11px;font-family:var(--font-code);background:#ffffff1f;border-radius:4px;border:1px solid rgba(255,255,255,.15);color:var(--text-on-dark-2);line-height:1.4}.home-hero-scroll-hint{position:absolute;bottom:32px;left:50%;transform:translate(-50%);color:var(--text-on-dark-3);animation:bounceDown 2s ease-in-out infinite;z-index:1}@keyframes bounceDown{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(8px)}}.home-module-section{padding-top:var(--space-2xl);padding-bottom:var(--space-2xl)}.home-module-card{display:flex;align-items:center;gap:var(--space-xl)}.home-module-card.reverse{flex-direction:row-reverse}.home-module-visual{flex:0 0 280px;display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.home-module-icon-ring{width:120px;height:120px;border-radius:50%;border:2px solid var(--mod-color);display:flex;align-items:center;justify-content:center;position:relative;background:transparent;transition:all var(--t-base)}.home-module-icon-ring:before{content:"";position:absolute;inset:-8px;border-radius:50%;border:1px solid var(--mod-color);opacity:.2}.home-module-icon{color:var(--mod-color)}.home-module-number{font-family:var(--font-display);font-size:clamp(3rem,6vw,5rem);font-weight:700;opacity:.15;line-height:1}.home-module-info{flex:1;min-width:0}.home-module-subtitle{font-family:var(--font-heading);font-size:var(--text-small);font-weight:500;letter-spacing:.08em;text-transform:uppercase;display:block;margin-bottom:var(--space-xs)}.home-module-title{font-family:var(--font-display);font-size:var(--text-display);font-weight:700;letter-spacing:-.02em;line-height:1.1;margin-bottom:var(--space-md)}.home-module-desc{font-size:var(--text-body);line-height:1.8;margin-bottom:var(--space-md);max-width:540px}.section-dark .home-module-desc{color:var(--text-on-dark-2)}.home-module-highlights{list-style:none;padding:0;margin:0 0 var(--space-lg);display:flex;flex-direction:column;gap:8px}.home-module-highlights li{display:flex;align-items:center;gap:10px;font-size:var(--text-small)}.section-dark .home-module-highlights li{color:var(--text-on-dark-2)}.section-light .home-module-highlights li{color:var(--text-on-light-2)}.highlight-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.home-module-footer{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.home-module-btn{display:inline-flex;align-items:center;gap:6px;text-decoration:none;white-space:nowrap;border:none}.home-module-btn:hover{filter:brightness(1.1)}.home-module-progress{display:flex;align-items:center;gap:10px;min-width:160px}.progress-bar-bg{flex:1;height:4px;background:#80808033;border-radius:2px;overflow:hidden;min-width:80px}.progress-bar-fill{height:100%;border-radius:2px;transition:width .6s var(--ease-out)}.progress-label{font-size:var(--text-caption);white-space:nowrap}.section-dark .progress-label{color:var(--text-on-dark-3)}.section-light .progress-label{color:var(--text-on-light-3)}.home-stats-section{padding:var(--space-3xl) var(--space-lg)}.home-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);text-align:center}.home-stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.home-stat-num{color:var(--accent)}.home-stat-label{font-size:var(--text-small);color:var(--text-on-dark-3);letter-spacing:.04em}.home-path-section{padding:var(--space-3xl) var(--space-lg)}.home-path-header{text-align:center;margin-bottom:var(--space-xl)}.home-section-title{font-family:var(--font-display);font-size:var(--text-display);font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-sm)}.home-section-sub{font-size:var(--text-body);font-weight:300;line-height:1.6}.section-light .home-section-sub{color:var(--text-on-light-2)}.section-dark .home-section-sub,.section-dark-deep .home-section-sub{color:var(--text-on-dark-2)}.home-role-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-bottom:var(--space-xl)}.home-role-btn{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:var(--space-md);background:var(--bg-light-elevated);border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--t-base);text-align:left;min-height:44px}.home-role-btn:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.home-role-btn.active{border-color:var(--accent);background:var(--accent-subtle);box-shadow:var(--shadow-glow)}.home-role-label{font-size:1rem;font-weight:600;color:var(--text-on-light)}.home-role-desc{font-size:var(--text-caption);color:var(--text-on-light-3)}.home-path-display{background:var(--bg-light-elevated);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.home-path-tip{font-size:var(--text-small);color:var(--accent);font-weight:500;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-light)}.home-path-steps{display:flex;align-items:center;gap:0;transition:opacity .2s var(--ease-apple),transform .2s var(--ease-apple);flex-wrap:wrap}.home-path-step{display:flex;align-items:center;gap:var(--space-sm)}.home-path-step-num{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;flex-shrink:0}.home-path-step-title{font-weight:600;font-size:var(--text-small);white-space:nowrap}.home-path-connector{width:40px;height:2px;background:var(--border-light);margin:0 var(--space-sm);flex-shrink:0}.home-ref-section,.home-footer-section{padding:var(--space-2xl) var(--space-lg);min-height:auto}.home-footer-brand{font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);font-weight:700;color:var(--text-on-dark);letter-spacing:.02em;margin-bottom:var(--space-sm)}.home-footer-slogan{font-family:var(--font-body);font-size:var(--text-body);font-weight:300;color:var(--text-on-dark-3)}.search-modal-overlay{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding-top:20vh;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;pointer-events:none;transition:opacity .2s var(--ease-apple)}.search-modal-overlay.active{opacity:1;pointer-events:auto}.search-modal{width:560px;max-width:calc(100vw - 32px);background:var(--bg-dark-elevated);border:1px solid var(--border-dark);border-radius:var(--radius-lg);box-shadow:0 24px 80px #00000080;overflow:hidden;transform:scale(.96) translateY(-8px);transition:transform .2s var(--ease-out)}.search-modal-overlay.active .search-modal{transform:scale(1) translateY(0)}.search-input-wrapper{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--border-dark)}.search-icon{color:var(--text-on-dark-3);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;font-size:1rem;font-family:var(--font-body);color:var(--text-on-dark);caret-color:var(--accent)}.search-input::placeholder{color:var(--text-on-dark-3)}.search-kbd{font-family:var(--font-code);font-size:11px;padding:3px 8px;background:#ffffff14;border:1px solid var(--border-dark);border-radius:4px;color:var(--text-on-dark-3);flex-shrink:0}.search-results{max-height:360px;overflow-y:auto;padding:8px}.search-result-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-body);font-size:.9rem;color:var(--text-on-dark);text-align:left;transition:background .1s}.search-result-item:hover,.search-result-item.selected{background:#7ec8e31a}.search-result-item.selected{outline:1px solid rgba(126,200,227,.3)}.search-result-title{flex:1}.search-result-module{font-size:var(--text-caption);color:var(--text-on-dark-3);margin-left:12px;flex-shrink:0}.search-empty{padding:24px;text-align:center;color:var(--text-on-dark-3);font-size:var(--text-small)}@media(max-width:1024px){.home-module-card{gap:var(--space-lg)}.home-module-visual{flex:0 0 200px}.home-module-icon-ring{width:100px;height:100px}}@media(max-width:768px){.home-hero{min-height:100svh}.home-hero-title{font-size:clamp(2.5rem,10vw,3.5rem)}.home-hero-sub{font-size:.9rem}.hero-kbd{display:none}.home-module-section{padding-top:var(--space-xl);padding-bottom:var(--space-xl)}.home-module-card,.home-module-card.reverse{flex-direction:column;gap:var(--space-lg);text-align:center}.home-module-visual{flex:none}.home-module-icon-ring{width:88px;height:88px}.home-module-number{font-size:3rem}.home-module-info{display:flex;flex-direction:column;align-items:center}.home-module-highlights{align-items:center}.home-module-footer{justify-content:center;flex-direction:column;gap:var(--space-md)}.home-module-progress{min-width:200px}.home-stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-md)}.home-stats-section{padding:var(--space-xl) var(--space-sm)}.home-role-selector{grid-template-columns:repeat(2,1fr);gap:var(--space-xs)}.home-role-btn{padding:var(--space-sm)}.home-path-display{padding:var(--space-md)}.home-path-steps{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.home-path-connector{width:2px;height:24px;margin:0 0 0 17px}.home-path-step{width:100%}.search-modal-overlay{padding-top:10vh;align-items:flex-start}.home-hero-scroll-hint{bottom:calc(72px + env(safe-area-inset-bottom))}}@media(max-width:480px){.home-role-selector{grid-template-columns:1fr}.home-stats-grid{grid-template-columns:repeat(2,1fr)}}.m1-nav-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg) 0;border-top:1px solid var(--border-dark);margin-top:var(--space-xl);gap:var(--space-md)}.section-light .m1-nav-footer{border-top-color:var(--border-light)}.m1-nav-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-heading);font-size:var(--text-body);font-weight:500;color:var(--accent);text-decoration:none;padding:var(--space-sm) 0;transition:opacity var(--t-fast);min-height:44px;cursor:pointer}.m1-nav-link:hover{opacity:.75}.m1-nav-link:active{opacity:.6}.m1p2-harmony-section{max-width:var(--w-content);margin:0 auto;padding:var(--space-xl) var(--space-md)}.m1p2-wheel-area{max-width:400px;aspect-ratio:1;margin:0 auto var(--space-lg);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-dark-deep);position:relative}.m1p2-wheel-area canvas{display:block;width:100%;height:100%}.m1p2-harmony-swatches{display:flex;justify-content:center;gap:var(--space-sm);flex-wrap:wrap;padding:var(--space-md) 0}.m1p2-swatch{width:56px;height:56px;border-radius:var(--radius-sm);border:2px solid rgba(255,255,255,.08);flex-shrink:0;cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-fast);position:relative}.section-light .m1p2-swatch{border-color:#00000014}.m1p2-swatch:hover{transform:scale(1.12);box-shadow:0 4px 16px #0000004d}.m1p2-swatch:active{transform:scale(1.04)}.m1p2-swatch-hex{display:block;text-align:center;font-family:var(--font-code);font-size:11px;color:var(--text-on-dark-3);margin-top:6px;white-space:nowrap}.section-light .m1p2-swatch-hex{color:var(--text-on-light-3)}.m1p2-rule-section{max-width:var(--w-content);margin:0 auto;padding:var(--space-xl) var(--space-md)}.m1p2-rule-bars{display:flex;gap:4px;width:100%;height:80px;border-radius:var(--radius-md);overflow:hidden}.m1p2-rule-bar{display:flex;align-items:center;justify-content:center;transition:flex-grow var(--t-slow);position:relative;min-width:0}.m1p2-rule-label{font-family:var(--font-heading);font-size:var(--text-small);font-weight:600;color:inherit;text-shadow:0 1px 2px rgba(0,0,0,.3);white-space:nowrap}.m1p2-deltae-section{max-width:var(--w-content);margin:0 auto;padding:var(--space-xl) var(--space-md)}.m1p2-deltae-inputs{display:flex;gap:var(--space-lg);align-items:flex-start;justify-content:center;margin-bottom:var(--space-lg)}.m1p2-deltae-result{font-family:var(--font-display);font-size:var(--text-stat);font-weight:700;text-align:center;letter-spacing:-.03em;line-height:1;margin-bottom:var(--space-md);color:var(--accent)}.m1p2-deltae-scale{position:relative;height:12px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--color-success) 0%,var(--color-warning) 50%,var(--color-error) 100%);max-width:480px;margin:0 auto;overflow:visible}.m1p2-deltae-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--bg-dark);box-shadow:0 1px 6px #0000004d;transition:left .3s var(--ease-out);z-index:1}.section-light .m1p2-deltae-marker{border-color:var(--bg-light)}.m1p2-palette-section{max-width:var(--w-full);margin:0 auto;padding:var(--space-xl) var(--space-md)}.m1p2-palette-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:520px;overflow-y:auto;padding-right:var(--space-xs);-webkit-overflow-scrolling:touch}.m1p2-palette-list::-webkit-scrollbar{width:4px}.m1p2-palette-list::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:2px}.m1p2-palette-card{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-dark-elevated);border:1px solid var(--border-dark);border-radius:var(--radius-md);transition:border-color var(--t-fast),box-shadow var(--t-fast)}.section-light .m1p2-palette-card{background:var(--bg-light-elevated);border-color:var(--border-light)}.m1p2-palette-card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow)}.m1p2-palette-name{font-family:var(--font-heading);font-size:var(--text-small);font-weight:600;color:var(--text-on-dark)}.section-light .m1p2-palette-name{color:var(--text-on-light)}.m1p2-palette-colors{display:flex;gap:4px;border-radius:var(--radius-sm);overflow:hidden;height:40px}.m1p2-palette-color{flex:1;min-width:0;transition:flex var(--t-fast);cursor:pointer;position:relative}.m1p2-palette-color:hover{flex:2}.m1p2-palette-actions{display:flex;gap:var(--space-xs);align-items:center}.m1p2-palette-actions .copy-btn,.m1p2-palette-actions .btn-small{flex-shrink:0}.m1p2-chart-preview{max-width:var(--w-content);margin:0 auto;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-dark-elevated);border:1px solid var(--border-dark);min-height:300px;position:relative}.section-light .m1p2-chart-preview{background:var(--bg-light-elevated);border-color:var(--border-light)}.m1p2-chart-preview svg{display:block;width:100%;height:auto}@media(max-width:768px){.m1-nav-footer{flex-direction:column;gap:var(--space-sm);text-align:center}.m1-nav-link{width:100%;justify-content:center}.m1p2-harmony-section{padding:var(--space-lg) var(--space-sm)}.m1p2-wheel-area{max-width:100%}.m1p2-harmony-swatches{gap:var(--space-xs)}.m1p2-swatch{width:48px;height:48px}.m1p2-rule-section{padding:var(--space-lg) var(--space-sm)}.m1p2-rule-bars{height:60px}.m1p2-deltae-section{padding:var(--space-lg) var(--space-sm)}.m1p2-deltae-inputs{flex-direction:column;align-items:center;gap:var(--space-md)}.m1p2-deltae-result{font-size:clamp(2.5rem,6vw,4rem)}.m1p2-palette-section{padding:var(--space-lg) var(--space-sm)}.m1p2-palette-list{max-height:400px;padding-right:0}.m1p2-palette-colors{height:32px}.m1p2-palette-actions{flex-wrap:wrap}.m1p2-chart-preview{min-height:220px}}@media(max-width:480px){.m1p2-swatch{width:40px;height:40px}.m1p2-swatch-hex{font-size:10px}.m1p2-rule-bars{height:48px}.m1p2-rule-label{font-size:var(--text-caption)}.m1p2-palette-card{padding:var(--space-sm)}}
