:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.koi-pond{position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#0c1621,#1a252f,#2c3e50);overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.pond-container{position:absolute;top:0;left:0;width:100vw;height:100vh;background:transparent;overflow:hidden}.pond-container canvas{width:100%!important;height:100%!important;display:block}.koi-pond-loading{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0c1621,#1a252f,#2c3e50);display:flex;align-items:center;justify-content:center;z-index:1000;color:#fff}.koi-pond-content{transition:opacity .3s ease-in-out}.koi-pond-content.hidden{opacity:0;pointer-events:none}.loading-content{text-align:center;max-width:400px;padding:2rem}.loading-content h2{font-size:2.5rem;margin-bottom:1rem;background:linear-gradient(45deg,#64b5f6,#42a5f5,#2196f3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}.pond-loader{font-size:4rem;margin:2rem 0;animation:float 2s ease-in-out infinite}.loading-content p{font-size:1.1rem;opacity:.8;margin-top:1rem}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.pond-exit-btn{position:fixed;top:2rem;left:2rem;width:60px;height:60px;border:none;border-radius:50%;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.5rem;font-weight:700;cursor:pointer;z-index:100;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #0000004d}.pond-exit-btn:hover{background:#fff3;transform:scale(1.05);box-shadow:0 12px 40px #0006}.pond-exit-btn:active{transform:scale(.95)}.pond-controls-toggle{position:fixed;top:2rem;right:14rem;width:60px;height:60px;border:none;border-radius:50%;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:1.5rem;cursor:pointer;z-index:100;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #0000004d}.pond-controls-toggle:hover{background:#fff3;transform:scale(1.05);box-shadow:0 12px 40px #0006}.pond-controls-toggle:active{transform:scale(.95)}.pond-controls-panel{position:fixed;top:6rem;right:2rem;width:300px;background:#000c;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:1.5rem;color:#fff;z-index:100;box-shadow:0 12px 40px #0006;animation:slideInFromRight .3s ease-out}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.pond-controls-panel h3{margin:0 0 1rem;font-size:1.4rem;text-align:center;color:#64b5f6;border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:.5rem}.control-section{margin-bottom:1.5rem}.control-section:last-child{margin-bottom:0}.control-section h4{margin:0 0 .8rem;font-size:1.1rem;color:#e0e0e0}.control-buttons{display:flex;gap:.5rem}.control-btn{flex:1;padding:.8rem 1rem;border:none;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.add-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;box-shadow:0 4px 15px #4caf504d}.add-btn:hover{background:linear-gradient(135deg,#45a049,#3d8b40);transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.remove-btn{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff;box-shadow:0 4px 15px #f443364d}.remove-btn:hover:not(:disabled){background:linear-gradient(135deg,#d32f2f,#c62828);transform:translateY(-2px);box-shadow:0 6px 20px #f4433666}.remove-btn:disabled{background:#6464644d;color:#ffffff4d;cursor:not-allowed;box-shadow:none}.control-btn:active:not(:disabled){transform:translateY(1px);box-shadow:0 2px 10px #0003}.pond-stats{position:fixed;top:2rem;right:2rem;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1.5rem;color:#fff;z-index:100;box-shadow:0 8px 32px #0000004d;min-width:200px}.stat-item{display:flex;align-items:center;margin-bottom:.8rem;font-size:1rem;font-weight:500}.stat-item:last-child{margin-bottom:0}.stat-icon{font-size:1.2rem;margin-right:.8rem;display:inline-block;width:24px;text-align:center}.pond-instructions{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:24px;padding:1rem 2rem;color:#fff;z-index:100;box-shadow:0 8px 32px #0000004d;text-align:center;animation:fadeInSlideUp 1s ease-out 2s both}.pond-instructions p{margin:0;font-size:1rem;font-weight:400;opacity:.9}@keyframes fadeInSlideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 768px){.pond-exit-btn{top:1rem;left:1rem;width:50px;height:50px;font-size:1.2rem}.pond-stats{top:1rem;right:1rem;padding:1rem;min-width:160px}.stat-item{font-size:.9rem;margin-bottom:.6rem}.stat-icon{font-size:1rem;margin-right:.6rem;width:20px}.pond-instructions{bottom:1rem;padding:.8rem 1.5rem}.pond-instructions p{font-size:.9rem}.loading-content h2{font-size:2rem}.pond-loader{font-size:3rem}}@media (max-width: 480px){.pond-exit-btn{width:45px;height:45px;font-size:1.1rem}.pond-stats{padding:.8rem;min-width:140px}.stat-item{font-size:.8rem;margin-bottom:.5rem}.pond-instructions{padding:.6rem 1.2rem}.pond-instructions p{font-size:.8rem}}@keyframes ripple-expand{0%{transform:scale(0);opacity:1}to{transform:scale(4);opacity:0}}@keyframes stat-update{0%{transform:scale(1)}50%{transform:scale(1.1);color:#64b5f6}to{transform:scale(1)}}.stat-item.updated{animation:stat-update .3s ease-out}.pond-exit-btn,.pond-stats,.pond-instructions{transition:all .3s ease}.pond-stats:hover{background:#ffffff26;transform:translateY(-2px);box-shadow:0 12px 40px #0006}.pond-instructions:hover{background:#ffffff26;transform:translate(-50%) translateY(-2px);box-shadow:0 12px 40px #0006}@media (prefers-reduced-motion: reduce){.pond-loader,.pond-instructions,.stat-item.updated{animation:none}.pond-exit-btn:hover,.pond-stats:hover,.pond-instructions:hover{transform:none}}@media (prefers-contrast: high){.pond-exit-btn,.pond-stats,.pond-instructions{background:#000c;border:2px solid white}.loading-content h2{-webkit-text-fill-color:white;background:none}}.pool-config{margin-top:1rem;padding:.5rem;border-top:1px solid rgba(255,255,255,.2)}.config-title{font-weight:700;margin-bottom:.5rem;color:#64b5f6}.config-control{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;gap:1rem}.config-control label{font-size:.8rem;min-width:70px;color:#ffffffe6}.config-control input[type=range]{flex:1;height:4px;background:#fff3;border-radius:2px;outline:none;opacity:.7;transition:opacity .2s}.config-control input[type=range]:hover{opacity:1}.config-control input[type=range]::-webkit-slider-thumb{appearance:none;width:16px;height:16px;background:#64b5f6;border-radius:50%;cursor:pointer}.config-control input[type=range]::-moz-range-thumb{width:16px;height:16px;background:#64b5f6;border-radius:50%;cursor:pointer;border:none}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:hidden;background:#0a0a0a;color:#fff;-webkit-user-select:none;user-select:none}.coffee-table-app{width:100vw;height:100vh;position:relative;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);overflow:hidden;transition:all .3s ease}.coffee-table-app.fullscreen{background:linear-gradient(135deg,#0f1419,#1a1a2e,#16213e)}.loading-screen{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0a0a,#1a1a2e);position:fixed;top:0;left:0;z-index:1000}.loading-content{text-align:center;padding:2rem}.loading-content h1{font-size:3rem;font-weight:300;margin-bottom:2rem;background:linear-gradient(45deg,#64b5f6,#42a5f5,#2196f3);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-size:200% 200%;animation:gradientShift 3s ease-in-out infinite}.loading-spinner{width:60px;height:60px;border:3px solid rgba(255,255,255,.1);border-top:3px solid #64b5f6;border-radius:50%;margin:0 auto 1rem;animation:spin 1s linear infinite}.loading-content p{font-size:1.1rem;opacity:.8}.fullscreen-toggle{position:fixed;top:20px;right:20px;width:50px;height:50px;border:none;border-radius:50%;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;z-index:100;display:flex;align-items:center;justify-content:center}.fullscreen-toggle:hover{background:#fff3;transform:scale(1.1)}.debug-panel{position:fixed;top:20px;left:20px;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:1rem;font-size:.9rem;z-index:200;max-width:250px;color:#fff}.debug-overlay{z-index:10000!important;background:#000000e6!important;box-shadow:0 8px 32px #00000080!important;border:2px solid rgba(100,181,246,.5)!important}.debug-panel h3{margin-bottom:.5rem;font-size:1rem;color:#64b5f6}.debug-section{margin-bottom:1.2rem}.debug-section h4{margin:0 0 .5rem;font-size:.95rem;color:#64b5f6;font-weight:600}.debug-stats{margin-bottom:.5rem}.debug-stats div{margin-bottom:.25rem;display:flex;justify-content:space-between}.last-gesture{padding:.5rem;background:#ffffff0d;border-radius:5px;margin-bottom:.5rem;font-size:.8rem}.debug-controls{border-top:1px solid rgba(255,255,255,.1);padding-top:.5rem;font-size:.75rem;opacity:.7}.main-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem 1rem;position:relative}.app-header{text-align:center;margin-bottom:2rem}.app-header h1{font-size:2.5rem;font-weight:200;margin-bottom:.75rem;background:linear-gradient(45deg,#fff,#e3f2fd,#bbdefb);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 30px rgba(255,255,255,.1)}.app-header p{font-size:1.1rem;opacity:.7;font-weight:300;margin-bottom:.5rem}.touch-hints{font-size:1rem;opacity:.5;font-weight:300}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:2rem;max-width:1200px;width:100%;margin:0 auto 2rem;padding:0 1rem;box-sizing:border-box}.module-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem 1rem;text-align:center;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;min-height:160px;max-height:220px;display:flex;flex-direction:column;justify-content:space-between;align-items:center;box-sizing:border-box;width:100%}.module-card:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.03),transparent);opacity:0;transition:opacity .3s ease}.module-card:hover{transform:translateY(-5px);background:#ffffff14;border-color:#fff3;box-shadow:0 15px 30px #0000004d;z-index:10}.module-card:hover:before{opacity:1}.module-card:active{transform:translateY(-2px) scale(.98)}.module-card h3{font-size:1.4rem;font-weight:300;margin-bottom:.75rem;color:#fff;line-height:1.2}.module-card p{font-size:.9rem;opacity:.8;font-weight:300;margin-bottom:.75rem;line-height:1.3}.module-status{font-size:.75rem;padding:.4rem .8rem;background:#ffffff1a;border-radius:16px;opacity:.7;font-weight:500}.module-status.ready{background:#4caf50cc;color:#fff;opacity:1;animation:pulse-ready 2s ease-in-out infinite}@keyframes pulse-ready{0%,to{opacity:.8}50%{opacity:1}}.module-card.koi-pond{background:linear-gradient(135deg,#2196f31a,#03a9f40d);border-color:#2196f333}.module-card.koi-pond:hover{background:linear-gradient(135deg,#2196f326,#03a9f414)}.module-card.enhanced-koi-pond{background:linear-gradient(135deg,#0096ff26,#40c4ff1a);border-color:#0096ff4d;position:relative;overflow:hidden}.module-card.enhanced-koi-pond:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:shimmer 3s infinite}.module-card.enhanced-koi-pond:hover{background:linear-gradient(135deg,#0096ff33,#40c4ff26);box-shadow:0 25px 50px #0096ff4d}.module-card.enhanced-koi-pond .module-status.ready{background:linear-gradient(45deg,#00d4ff,#09c);color:#fff;font-weight:600;animation:pulse-enhanced 2s ease-in-out infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}@keyframes pulse-enhanced{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.module-card.interactive-water-pond{background:linear-gradient(135deg,#4caf5026,#8bc34a1a);border-color:#4caf504d;position:relative}.module-card.interactive-water-pond:hover{background:linear-gradient(135deg,#4caf5033,#8bc34a26);box-shadow:0 25px 50px #4caf504d}.module-card.interactive-water-pond .module-status.ready{background:linear-gradient(45deg,#4caf50,#8bc34a);color:#fff;font-weight:600;animation:pulse-working 1.5s ease-in-out infinite}@keyframes pulse-working{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.module-card.gpgpu-water-pond{background:linear-gradient(135deg,#ffc10726,#ff98001a);border-color:#ffc1074d;position:relative}.module-card.gpgpu-water-pond:hover{background:linear-gradient(135deg,#ffc10733,#ff980026);box-shadow:0 25px 50px #ffc10740}.module-card.gpgpu-water-pond .module-status.ready{background:linear-gradient(45deg,#ff9800,#ffc107);color:#000;font-weight:600;animation:pulse-gpgpu 1.8s ease-in-out infinite}@keyframes pulse-gpgpu{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}.module-card.pool-simulation{background:linear-gradient(135deg,#00bfff26,#1e90ff1a);border-color:#00bfff4d;position:relative}.module-card.pool-simulation:hover{background:linear-gradient(135deg,#00bfff33,#1e90ff26);box-shadow:0 25px 50px #00bfff4d}.module-card.pool-simulation .module-status.ready{background:linear-gradient(45deg,#00bfff,#1e90ff);color:#fff;font-weight:600;animation:pulse-pool 2.2s ease-in-out infinite}@keyframes pulse-pool{0%,to{opacity:.9;transform:scale(1)}50%{opacity:1;transform:scale(1.07)}}.pool-content.hidden{display:none}.pool-container{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:1}.loading-overlay,.error-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000c;color:#fff;z-index:1000}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid #00BFFF;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-progress{width:250px;height:8px;background:#fff3;border-radius:4px;overflow:hidden;margin-top:1rem;position:relative}.loading-bar{height:100%;background:linear-gradient(90deg,#00bfff,#0080ff);border-radius:4px;transition:width .3s ease;box-shadow:0 0 10px #00bfff4d}.loading-percentage{position:absolute;top:-25px;right:0;font-size:.8rem;color:#fffc}.debug-stats.pool-debug{position:fixed;top:20px;left:20px;background:#000c;padding:1rem;border-radius:8px;color:#fff;font-size:.9rem;z-index:100}.exit-button{position:fixed;top:20px;right:20px;padding:12px 24px;background:#000000b3;color:#fff;border:2px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;font-size:16px;font-weight:500;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;display:flex;align-items:center;gap:8px}.exit-button:hover{background:#000000e6;border-color:#fff6;transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.exit-button:active{transform:translateY(0)}.module-card.air-hockey{background:linear-gradient(135deg,#f443361a,#ff57220d);border-color:#f4433633}.module-card.air-hockey:hover{background:linear-gradient(135deg,#f4433626,#ff572214)}.interaction-hints{display:flex;gap:2rem;justify-content:center;align-items:center;margin-top:2rem;opacity:.6}.hint-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;font-size:.9rem;text-align:center}.hint-icon{font-size:1.5rem}.version-info{position:fixed;bottom:.5rem;left:.5rem;color:#fff9;font-size:.7rem;font-weight:400;z-index:50;pointer-events:none;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.fullscreen-helper{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1rem;border-radius:20px;font-size:.9rem;opacity:.7}@keyframes touchFeedback{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}.module-card:active{animation:touchFeedback .2s ease-out}@media (max-width: 768px){.app-header h1{font-size:2.5rem}.app-header p{font-size:1.1rem}.module-grid{grid-template-columns:1fr;gap:1.5rem;padding:0 1rem;max-width:100%}.module-card{padding:1.5rem 1rem;min-height:140px;max-height:180px}.module-card h3{font-size:1.3rem}.module-card p{font-size:.85rem}.module-card:hover{transform:translateY(-3px)}.main-content{padding:1rem}.interaction-hints{flex-direction:column;gap:1rem}.hint-item{flex-direction:row;gap:1rem}.debug-panel{top:10px;left:10px;right:10px;max-width:none;font-size:.8rem}}@media (min-width: 769px) and (max-width: 1199px){.module-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;max-width:900px}.module-card{padding:1.75rem 1.25rem;min-height:160px;max-height:200px}.module-card h3{font-size:1.4rem}.module-card p{font-size:.9rem}.app-header h1{font-size:3rem}}@media (min-width: 1200px){.app-header h1{font-size:4rem}.module-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2.5rem}.module-card{padding:2rem 1.5rem;min-height:180px;max-height:240px}.module-card h3{font-size:1.6rem}.module-card p{font-size:1rem}.interaction-hints{gap:2.5rem}.hint-item{font-size:1rem}.hint-icon{font-size:1.8rem}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.coffee-table-app *{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.coffee-table-app{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (pointer: coarse){.module-card{min-height:160px;max-height:200px;padding:1.75rem 1.25rem}.module-card:hover{transform:translateY(-3px)}.fullscreen-toggle{width:60px;height:60px;font-size:1.8rem}.interaction-hints{margin-top:2rem}}
