*{margin:0;padding:0;box-sizing:border-box}body{width:100%;height:100vh;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a1a;color:#e0e0e0}#app{display:flex;width:100%;height:100%;gap:12px;padding:12px;position:relative}.panel{width:auto;min-width:320px;max-width:400px;flex-shrink:0;display:flex;flex-direction:column;gap:12px;min-height:0;overflow-y:auto;scrollbar-width:thin;transition:transform .24s ease,opacity .24s ease}.panel::-webkit-scrollbar{width:8px}.panel::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:999px}.panel::-webkit-scrollbar-track{background:transparent}.panel-backdrop,.panel-toggle-button{display:none}.panel-section{background:#2a2a2a;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px}@media(max-width:1100px){#app{gap:0}.panel-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:12;background:#080a0c6b;opacity:0;pointer-events:none;transition:opacity .22s ease;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}#app.panel-drawer-open .panel-backdrop{opacity:1;pointer-events:auto}.panel-toggle-button{display:flex;align-items:center;justify-content:center;position:absolute;top:16px;right:16px;z-index:14;width:44px;height:44px;border:1px solid rgba(255,255,255,.16);border-radius:10px;background:#121212b8;color:#f4f4f4;padding:0;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 8px 24px #00000038}.panel-toggle-button:hover{border-color:#ffffff42;background:#181818c7}.panel-toggle-icon{width:20px;height:20px;display:block}.panel-toggle-close-icon,#app.panel-drawer-open .panel-toggle-open-icon{display:none}#app.panel-drawer-open .panel-toggle-close-icon{display:block}.panel{position:fixed;top:12px;right:12px;bottom:12px;width:min(400px,calc(100vw - 24px));max-width:none;min-width:0;z-index:13;padding:12px;border-radius:12px;background:#181818d1;border:1px solid rgba(255,255,255,.12);box-shadow:0 24px 60px #00000057;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transform:translate3d(calc(100% + 24px),0,0);opacity:0;pointer-events:none}#app.panel-drawer-open .panel{transform:translateZ(0);opacity:1;pointer-events:auto}}.section-header{width:100%;border:0;background:transparent;padding:0;display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:500;letter-spacing:.15em;color:#888;cursor:pointer;margin-bottom:12px}.section-header:hover{color:#bbb}.section-toggle{width:7px;height:7px;border-right:1px solid currentColor;border-bottom:1px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .18s ease}.panel-section.collapsed .section-header{margin-bottom:0}.panel-section.collapsed .section-toggle{transform:rotate(-45deg)}.panel-section.collapsed .section-content{display:none}.controls-section{display:flex;flex-direction:column}.controls-content{flex:0 0 auto}.control-group{padding-top:12px;margin-top:12px;border-top:1px solid rgba(255,255,255,.08)}.control-group:first-child{padding-top:0;margin-top:0;border-top:0}.control-group-title{margin-bottom:10px;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#777}.surface-buttons-row{display:flex;gap:12px;justify-content:center;margin-bottom:8px}.control-group-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;margin-bottom:10px;border:none;background:transparent;color:#777;cursor:pointer}.control-group-header:hover{color:#999}.control-group-header .control-group-title,.displacement-group.collapsed .control-group-header{margin-bottom:0}.displacement-group.collapsed .section-toggle{transform:rotate(-45deg)}.displacement-group.collapsed .displacement-content{display:none}.displacement-map-row{display:block}.surface-btn{width:56px;height:56px;border-radius:50%;border:2px solid rgba(255,255,255,.2);background:#3a3a3a;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#888}.surface-btn:hover{border-color:#fff6;color:#bbb}.surface-btn.active{border-color:#6b9eff;background:#6b9eff26;color:#6b9eff}.surface-btn svg{width:28px;height:28px}.control-row{display:flex;align-items:center;gap:16px;margin-bottom:12px}.control-row:last-child{margin-bottom:0}.control-row.hidden,.control-group.hidden{display:none}.control-row label{font-size:12px;color:#aaa;width:130px;flex-shrink:0}.control-row input[type=range]{flex:1;height:4px;-webkit-appearance:none;background:#ffffff1a;border-radius:2px;outline:none}.control-row .slider-value{font-size:11px;color:#888;min-width:36px;text-align:right;font-family:monospace}.control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#6b9eff;cursor:pointer}.control-row input[type=checkbox]{width:16px;height:16px;accent-color:#6b9eff}.control-row select{flex:1;min-width:0;height:28px;border:1px solid rgba(255,255,255,.16);border-radius:4px;background:#222;color:#ddd;padding:0 8px;font:inherit;font-size:12px}.control-row select:focus{outline:2px solid rgba(107,158,255,.45);outline-offset:1px}.control-row button{min-width:84px;height:28px;border:1px solid rgba(255,255,255,.16);border-radius:4px;background:#222;color:#ddd;padding:0 10px;font:inherit;font-size:12px;cursor:pointer}.control-row button:hover:not(:disabled){border-color:#ffffff3d}.control-row button:disabled{opacity:.4;cursor:not-allowed}.button-group{display:flex;gap:6px}.button-group button{min-width:64px}#displacementMap{width:100%;aspect-ratio:1;border-radius:4px;background:#5a6a50}.preview{flex:1;background:#2a2a2a;border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden;position:relative;container-type:size;container-name:preview}.github-link{position:absolute;left:16px;bottom:16px;z-index:6;display:inline-flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-size:13px;font-weight:600;letter-spacing:0;line-height:1;-webkit-user-select:none;user-select:none}.github-link:hover{color:#ffffffe0}.github-link svg{width:18px;height:18px;display:block;flex:0 0 auto}.preview canvas{width:100%;height:100%;display:block;touch-action:none;position:relative;z-index:1}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;align-items:center;justify-content:center;background:#171717;color:#ffffffdb;transition:opacity .22s ease,visibility .22s ease}#app.scene-loaded .loading-overlay{visibility:hidden;opacity:0;pointer-events:none}.loading-spinner{width:84px;height:84px;border:1px solid rgba(255,255,255,.12);border-top-color:#fffffff0;border-right-color:#ffffff57;border-radius:50%;box-shadow:inset 0 0 10px #ffffff14,0 0 18px #ffffff0f;animation:loading-spin .9s linear infinite}@keyframes loading-spin{to{transform:rotate(360deg)}}.article-background{position:absolute;top:0;right:0;bottom:0;left:0;background:#f8f8f8;z-index:0;overflow:hidden}.article-background.hidden{position:absolute;left:-9999px;top:0}.article-background.capturing{position:absolute;left:-9999px;top:0;visibility:visible}.article-background.html-in-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:auto;user-select:text;-webkit-user-select:text}.banner-background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;background:#111}.banner-background .banner-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center;filter:saturate(1.05) contrast(1.04)}.banner-background:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#0a0c10c7,#0a0c107a 42%,#0a0c100a),linear-gradient(180deg,#ffffff1f,#fff0)}.banner-background.html-in-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:auto;user-select:text;-webkit-user-select:text}.banner-copy{position:relative;z-index:1;width:min(560px,calc(100% - 96px));height:100%;display:flex;flex-direction:column;justify-content:center;gap:16px;padding-left:clamp(32px,7vw,88px);box-sizing:border-box;color:#fff}.banner-category{display:flex;align-items:center;gap:12px;margin:0;font-size:11px;font-weight:700;letter-spacing:.18em;color:#72e7d9}.banner-category .category-line{background:#72e7d9}.banner-title{margin:0;font-size:clamp(34px,6vw,72px);line-height:.95;font-weight:900;letter-spacing:0;color:#fff}.banner-body{margin:0;max-width:500px;font-size:clamp(14px,1.8vw,18px);line-height:1.55;color:#ffffffd1}@container preview (max-width: 700px){.banner-copy{width:calc(100% - 48px);padding-left:28px}.banner-body{font-size:14px}}@container preview (max-height: 420px){.banner-copy{gap:10px}.banner-title{font-size:clamp(28px,5vw,48px)}.banner-body{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}}.css-animation-background{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;background:#bcbcbc}.css-animation-background.html-in-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none}.css-animation-background:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#ffffff29,#fff0 38%,#0000000d);pointer-events:none}.css-animation-background:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#ffffff29,#fff0 45%,#00000014);pointer-events:none}.css-animation-grid{position:absolute;top:-120px;right:-120px;bottom:-120px;left:-120px;background:conic-gradient(from 90deg,#c6c6c6 25%,#b5b5b5 0,#b5b5b5 50%,#c6c6c6 0,#c6c6c6 75%,#b5b5b5 0);background-size:calc(var(--css-grid-cell-size, 105px) * 2) calc(var(--css-grid-cell-size, 105px) * 2);transform:translate3d(var(--css-grid-offset, 0px),var(--css-grid-offset, 0px),0)}@keyframes css-motion-gradient{0%{transform:translate3d(-2%,-2%,0) scale(1.04);opacity:.84}to{transform:translate3d(2%,2%,0) scale(1.04);opacity:.98}}.article-content{display:grid;grid-template-columns:1fr 1fr;gap:40px;height:100%;padding:48px;align-items:center;box-sizing:border-box}@container preview (max-width: 600px){.article-content{grid-template-columns:1fr;grid-template-rows:auto 1fr;gap:20px;padding:24px}.article-text{order:1}.article-image{order:2;max-height:180px}.article-title{font-size:28px}.article-body{font-size:14px}}@container preview (max-height: 450px){.article-content{padding:24px 32px;gap:24px}.article-body{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-title{font-size:32px}}@container preview (max-height: 350px){.article-content{padding:16px 24px;gap:16px}.article-title{font-size:24px}.article-body{font-size:13px;-webkit-line-clamp:2}.article-category{font-size:10px}}.article-text{display:flex;flex-direction:column;gap:16px}.article-category{display:flex;align-items:center;gap:12px;font-size:11px;font-weight:600;letter-spacing:.2em;color:#d32f2f}.category-line{width:28px;height:2px;background:#d32f2f}.article-title{font-size:42px;font-weight:900;line-height:1.1;color:#111;letter-spacing:-.02em}.title-line{display:inline-block;width:40px;height:3px;background:#888;vertical-align:middle;margin-left:10px}@container preview (max-width: 600px){.title-line{display:none}}.article-body{font-size:15px;line-height:1.6;color:#444;max-width:420px}.article-image{position:relative;height:100%;min-height:0;overflow:hidden;border-radius:4px}.article-image img{width:100%;height:100%;object-fit:cover;object-position:center}.article-credit{position:absolute;bottom:12px;right:12px;font-size:10px;font-weight:500;letter-spacing:.1em;color:#00000080;background:#fffc;padding:4px 8px;border-radius:2px}.preview canvas.transparent-bg{background:transparent}
