:root{font-family:Inter,system-ui,-apple-system,sans-serif;color:#e8eef7;background-color:#0b0f16;line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 20% 20%,rgba(68,130,255,.05),transparent 30%),radial-gradient(circle at 80% 0%,rgba(123,220,181,.05),transparent 25%),#0b0f16;color:#e8eef7}h1{margin:0 0 8px;font-size:24px}p{margin:0 0 12px}.muted{color:#8da1b5}.layout{position:relative;display:grid;grid-template-columns:360px 1fr;gap:16px;height:100vh;padding:16px;max-width:1600px;margin:0 auto}.leftPanel{position:relative;width:100%;max-height:calc(100vh - 32px);overflow-y:auto;background:#101726;border:1px solid #1f2b3d;border-radius:16px;padding:16px 16px 24px;box-shadow:0 18px 48px #00000059;z-index:2}.canvasPanel{position:relative;height:calc(100vh - 32px);min-height:520px;border-radius:16px;overflow:hidden;border:1px solid #1f2b3d;background:#0d1117}.canvasButtons{position:absolute;top:16px;left:16px;z-index:10;display:flex;gap:8px}@media(max-width:1100px){.canvasButtons{inset:auto auto 16px 16px}}.flipBtn,.highResBtn,.exportBtn{padding:10px 16px;font-size:14px;font-weight:600;background:#101726e6;border:1px solid #223149;border-radius:10px;color:#e8eef7;cursor:pointer;transition:background .15s,border-color .15s}.highResBtn{visibility:hidden}.exportBtn{background:linear-gradient(135deg,#4f8bffe6,#7bdcb5e6);border:none;color:#0b0f16}.exportBtn:hover{background:linear-gradient(135deg,#639ffff2,#8ff0c9f2)}.exportBtn:disabled{opacity:.7;cursor:wait}.flipBtn:hover,.highResBtn:hover{background:#1f2b3df2;border-color:#3f6ed8}.highResBtn.active{background:linear-gradient(135deg,#4f8bff,#7bdcb5);color:#0b0f16;border:none}.highResNotice{background:#4f8bff26;border:1px solid rgba(79,139,255,.3);color:#a8c5ff;padding:12px;border-radius:10px;font-size:13px;margin-bottom:12px;text-align:center}.leftPanel.disabled{opacity:.7}.controls.disabled{pointer-events:none;opacity:.5}.controls{display:flex;flex-direction:column;gap:12px}.section-title{font-size:13px;font-weight:600;color:#7bdcb5;text-transform:uppercase;letter-spacing:.5px;margin-top:8px;margin-bottom:4px;padding-top:12px;border-top:1px solid #1f2b3d}.section-title:first-child{border-top:none;padding-top:0;margin-top:0}.control{display:flex;flex-direction:column;gap:6px;font-size:14px}.control input[type=number],.control select,.control input[type=range]{width:100%;background:#0f1724;color:#e8eef7;border:1px solid #223149;border-radius:10px;padding:10px 12px;font-size:14px}.control input[type=range]{padding:6px 0}.checkbox{flex-direction:row;align-items:center;gap:10px}.customHoles{border:1px dashed #1f2b3d;padding:12px;border-radius:12px;background:#ffffff05}.customHolesHeader{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.holeRowHeader{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:8px;font-size:11px;color:#8da1b5;margin-bottom:4px;padding:0 2px}.holeRowHeader span:last-child{width:28px}.holeRow{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:8px;align-items:center;margin-bottom:8px}.holeRow input[type=number]{width:100%;min-width:0}.holeRow input::placeholder{color:#5a6a7a;font-style:italic}.btn{border:1px solid #223149;background:#121b2d;color:#e8eef7;border-radius:10px;padding:8px 12px;cursor:pointer;transition:border-color .15s ease,transform .1s ease}.btn:hover{border-color:#3f6ed8}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:linear-gradient(135deg,#4f8bff,#7bdcb5);color:#0b0f16;font-weight:600;border:none}.btn.ghost{background:transparent}.burger{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:12px;border:1px solid #223149;background:#121b2d;color:#e8eef7;font-size:20px;cursor:pointer;display:none;z-index:3}@media(max-width:1100px){.layout{display:block;padding:16px}.burger{display:block}.leftPanel{position:absolute;top:16px;left:16px;width:calc(100% - 32px);max-height:calc(100vh - 32px);transform:translate(-110%);transition:transform .2s ease}.leftPanel.open{transform:translate(0)}.canvasPanel{height:calc(100vh - 32px);min-height:420px}}.landing{min-height:100vh;max-width:900px;margin:0 auto;padding:48px 24px}.landing-hero{text-align:center;padding:48px 0 64px}.landing-title{font-size:clamp(32px,6vw,48px);font-weight:700;margin:0 0 16px;background:linear-gradient(135deg,#e8eef7,#7bdcb5);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-subtitle{font-size:18px;color:#8da1b5;max-width:560px;margin:0 auto 32px;line-height:1.6}.landing-cta{display:inline-block;padding:16px 32px;font-size:16px;font-weight:600;background:linear-gradient(135deg,#4f8bff,#7bdcb5);color:#0b0f16;border:none;border-radius:12px;cursor:pointer;transition:transform .15s,box-shadow .15s}.landing-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px #4f8bff4d}.landing-section{margin-bottom:56px}.landing-section h2{font-size:24px;margin:0 0 16px;color:#e8eef7}.landing-section p{color:#8da1b5;line-height:1.7}.landing-features{list-style:none;padding:0;margin:24px 0 0}.landing-features li{padding:12px 0;border-bottom:1px solid #1f2b3d;color:#c8d4e0}.landing-features li:last-child{border-bottom:none}.carousel{position:relative;margin:24px 0}.carousel-container{position:relative;height:300px;overflow:hidden;border-radius:12px;background:#101726;border:1px solid #1f2b3d}.carousel-slide{position:absolute;inset:0;opacity:0;transition:opacity .3s ease}.carousel-slide.active{opacity:1}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;border:1px solid #223149;background:#101726e6;color:#e8eef7;font-size:24px;cursor:pointer;z-index:2;transition:background .15s,border-color .15s}.carousel-btn:hover{background:#1f2b3df2;border-color:#3f6ed8}.carousel-btn.prev{left:-22px}.carousel-btn.next{right:-22px}.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:16px}.carousel-dot{width:10px;height:10px;border-radius:50%;border:none;background:#223149;cursor:pointer;transition:background .15s}.carousel-dot.active,.carousel-dot:hover{background:#7bdcb5}.carousel-image{width:100%;height:100%;object-fit:contain;background:#0a0e14}.video-container{margin-top:24px;border-radius:12px;overflow:hidden;background:#101726;border:1px solid #1f2b3d}.landing-video{width:100%;height:auto;display:block;max-height:500px;background:#000}.video-disclaimer{padding:16px 20px;background:#ffb4321a;border-top:1px solid rgba(255,180,50,.3);color:#e0c080;font-size:13px;line-height:1.6}.video-disclaimer strong{color:#fc6}.landing-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:24px}.landing-link{display:flex;align-items:center;gap:12px;padding:16px;background:#101726;border:1px solid #1f2b3d;border-radius:12px;color:#e8eef7;text-decoration:none;transition:border-color .15s,transform .15s}.landing-link:hover{border-color:#3f6ed8;transform:translateY(-2px)}.landing-link.sponsor{border-color:#4f8bff33;background:linear-gradient(135deg,#4f8bff1a,#7bdcb51a)}.landing-link.sponsor:hover{border-color:#7bdcb5}.link-icon{font-size:24px}.link-text{display:flex;flex-direction:column}.link-text strong{font-size:14px}.link-text small{font-size:12px;color:#8da1b5}.landing-footer{text-align:center;padding:48px 0;border-top:1px solid #1f2b3d;margin-top:48px}.landing-footer-text{margin-top:16px;color:#5a6a7a;font-size:14px}@media(max-width:640px){.landing{padding:32px 16px}.landing-hero{padding:32px 0 48px}.carousel-btn.prev{left:8px}.carousel-btn.next{right:8px}.landing-links{grid-template-columns:1fr}}.loading-overlay{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#0d1117cc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;pointer-events:none}.loading-spinner{position:relative;width:80px;height:80px;margin-bottom:20px}.spinner-ring{position:absolute;top:0;left:0;width:100%;height:100%;border:4px solid rgba(123,220,181,.3);border-top-color:#7bdcb5;border-radius:50%;animation:spin 1s linear infinite}.spinner-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;background-color:#7bdcb5;border-radius:50%;box-shadow:0 0 10px #5ba894}.loading-text{color:#7bdcb5;font-size:16px;font-weight:500;text-align:center;animation:pulse 2s ease-in-out infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}
