@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";body{background:#f5f6f8}:root{--bg: #F5F6F8;--bg-subtle: #ECEEF2;--surface: #FFFFFF;--surface-2: #F8F9FB;--border: #E2E5EA;--border-md: #CBD0D8;--border-dark: #9AA3AF;--accent: #1D4ED8;--accent-lt: #EFF4FF;--accent-mid: rgba(29, 78, 216, .12);--green: #047857;--green-lt: #ECFDF5;--orange: #D97706;--orange-lt: #FFFBEB;--red: #B91C1C;--red-lt: #FEF2F2;--text-primary: #0F172A;--text-secondary: #475569;--text-tertiary: #94A3B8;--text-disabled: #CBD1D9;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--r-sm: 6px;--r: 8px;--r-md: 10px;--r-lg: 12px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 4px 12px rgba(0, 0, 0, .08), 0 2px 4px rgba(0, 0, 0, .04);--shadow-md: 0 8px 24px rgba(0, 0, 0, .1), 0 3px 8px rgba(0, 0, 0, .05)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text-primary);min-height:100vh;line-height:3.5;-webkit-font-smoothing:antialiased;font-size:14px;letter-spacing:-.01em}.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 32px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200;flex-shrink:0}.header-logo{display:flex;align-items:center;gap:10px}.ball-icon{width:30px;height:30px;background:var(--accent);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.ball-icon svg{width:16px;height:16px;color:#fff}.header-wordmark{display:flex;flex-direction:column}.header-wordmark h1{font-size:14px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px;line-height:1}.header-wordmark p{font-size:11px;color:var(--text-tertiary);line-height:1;margin-top:2px}.header-right{display:flex;align-items:center;gap:8px}.header-badge{display:inline-flex;align-items:center;gap:5px;border:1px solid var(--border);color:var(--text-secondary);font-size:11px;font-weight:600;padding:4px 10px;border-radius:4px;background:var(--surface-2);letter-spacing:.4px;text-transform:uppercase}.header-badge-dot{width:5px;height:5px;border-radius:50%;background:var(--green)}.stepper{display:flex;align-items:center;justify-content:center;padding:0 32px;height:68px;background:var(--surface);border-bottom:1px solid var(--border);gap:0;overflow-x:auto;flex-shrink:0}.step-item{display:flex;flex-direction:row;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:8px 16px;border-radius:var(--r);transition:background .15s;white-space:nowrap}.step-item:hover:not(.disabled){background:var(--bg)}.step-item.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.step-circle{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;background:var(--bg-subtle);border:1.5px solid var(--border-md);color:var(--text-tertiary);transition:all .2s;flex-shrink:0}.step-item.active .step-circle{background:var(--accent);border-color:var(--accent);color:#fff}.step-item.completed .step-circle{background:var(--green);border-color:var(--green);color:#fff}.step-label-group{display:flex;flex-direction:column;gap:1px}.step-label{font-size:13px;font-weight:600;color:var(--text-tertiary);line-height:1}.step-sublabel{font-size:11px;color:var(--text-disabled);line-height:1}.step-item.active .step-label{color:var(--text-primary)}.step-item.active .step-sublabel,.step-item.completed .step-label{color:var(--text-secondary)}.step-connector{flex:1;height:1px;min-width:32px;max-width:80px;background:var(--border);transition:background .3s}.step-connector.completed{background:var(--green)}.app-main{flex:1;padding:20px 28px 40px;max-width:1600px;margin:0 auto;width:100%}.step-container{max-width:860px;margin:0 auto;display:flex;flex-direction:column;gap:20px}.step-header{padding-bottom:8px;margin-bottom:0}.step-header h2{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px;line-height:1.2}.step-header p{color:var(--text-secondary);font-size:13px;margin-top:4px;font-weight:400}.area-setup{display:grid;grid-template-columns:35fr 65fr;gap:20px;align-items:start;max-width:1600px;margin:0 auto}.area-left,.area-right{display:flex;flex-direction:column;gap:12px}.area-preview-card{padding:16px 18px;min-height:200px}.area-left>.section-card:first-of-type{min-height:200px}.mini-outer-lg{max-width:100%!important;min-height:55vh!important;max-height:55vh!important}.area-right .btn-next{width:100%;justify-content:center}@media(max-width:960px){.area-setup{grid-template-columns:1fr}}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px}.section-title{font-size:11px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}.section-note{font-size:13px;color:var(--text-secondary);margin-bottom:16px;line-height:2.2}.court-type-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.court-type-card{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-md);padding:14px 16px;text-align:left;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:4px}.court-type-card:hover{border-color:var(--border-md);background:var(--surface);box-shadow:var(--shadow-sm)}.court-type-card.active{border-color:var(--accent);background:var(--accent-lt)}.ct-badge{display:inline-block;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:3px;letter-spacing:.3px;text-transform:uppercase;width:fit-content;margin-bottom:2px}.court-type-card.active .ct-badge{background:var(--accent)}.ct-name{font-weight:600;font-size:13px;color:var(--text-primary)}.ct-desc{font-size:13px;color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}.ct-fixed-tag{font-size:11px;color:var(--text-tertiary);margin-top:2px}.court-dropdown{position:relative}.court-dd-trigger{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 16px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s;text-align:center}.court-dd-trigger:hover{border-color:var(--border-md);background:var(--surface);box-shadow:var(--shadow-xs)}.court-dd-trigger.open{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-lt);background:var(--surface)}.cdd-left{display:flex;align-items:center;justify-content:center;flex:1;min-width:0}.ct-badge{display:inline-block;background:var(--surface);color:var(--text-primary);font-size:13px;font-weight:700;padding:8px 20px;border-radius:6px;letter-spacing:.5px;text-transform:uppercase;border:1.5px solid var(--border-md);transition:all .2s}.ct-text{font-size:15px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.cdd-info{display:flex;flex-direction:column;gap:2px;min-width:0}.cdd-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cdd-dims{font-size:12px;color:var(--accent);font-weight:500;font-variant-numeric:tabular-nums}.cdd-chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform .2s ease}.cdd-chevron.open{transform:rotate(180deg);color:var(--accent)}.court-dd-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);z-index:200;overflow:hidden;animation:ddFadeIn .12s ease}@keyframes ddFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.court-dd-item{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 14px;background:transparent;border:none;cursor:pointer;text-align:center;transition:background .1s;border-bottom:1px solid var(--border);position:relative}.court-dd-item:last-child{border-bottom:none}.court-dd-item:hover{background:var(--bg-subtle)}.court-dd-item.active{background:var(--accent-lt)}.cdi-badge{display:inline-block;background:var(--surface);color:var(--text-primary);font-size:12px;font-weight:700;padding:6px 16px;border-radius:5px;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap;border:1.5px solid var(--border-md);transition:all .2s}.court-dd-item:hover .cdi-badge{border-color:var(--border-dark);background:var(--surface-2)}.court-dd-item.active .cdi-badge{background:var(--accent-lt);border-color:var(--accent);color:var(--accent)}.cdi-text{font-size:14px;font-weight:700;color:var(--text-primary);text-transform:uppercase;letter-spacing:.4px}.court-dd-item.active .cdi-text{color:var(--accent);font-weight:800}.cdi-info{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}.cdi-name{font-size:13px;font-weight:600;color:var(--text-primary)}.court-dd-item.active .cdi-name{color:var(--accent)}.cdi-dims{font-size:11px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.cdi-check{position:absolute;right:14px;color:var(--accent)}.fixed-court-info{background:var(--accent-lt);border:1px solid rgba(29,78,216,.18);border-radius:var(--r-lg);padding:16px 22px}.fci-header{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}.fci-lock{font-size:12px}.fci-values{display:flex;align-items:stretch;gap:0;margin-bottom:12px;border:1px solid rgba(29,78,216,.15);border-radius:var(--r);overflow:hidden}.fci-val{display:flex;flex-direction:column;gap:2px;background:var(--surface);padding:10px 18px;min-width:100px;border-right:1px solid rgba(29,78,216,.15);flex:1}.fci-val:last-child{border-right:none}.fci-val span{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.fci-val strong{font-size:16px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.5px}.fci-sep{display:none}.fci-note{font-size:12px;color:var(--text-secondary);line-height:1.5}.input-row{display:flex;align-items:flex-start;gap:16px}.input-group{flex:1;display:flex;flex-direction:column;gap:6px}.input-group label{font-size:12px;font-weight:600;color:var(--text-secondary)}.input-wrapper{display:flex;align-items:center;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r);overflow:hidden;transition:border-color .15s,box-shadow .15s}.input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-mid)}.input-wrapper input{flex:1;background:none;border:none;outline:none;padding:10px 12px;font-size:15px;font-weight:600;color:var(--text-primary);font-family:var(--font);letter-spacing:-.5px;width:100%;font-variant-numeric:tabular-nums}.input-wrapper input.error{color:var(--red)}.unit{padding:0 12px;color:var(--text-tertiary);font-size:12px;font-weight:600;border-left:1px solid var(--border);height:40px;display:flex;align-items:center;flex-shrink:0}.input-divider{font-size:1.5rem;color:var(--text-disabled);padding-top:26px;font-weight:300;flex-shrink:0}.error-msg{font-size:12px;color:var(--red);display:flex;align-items:center;gap:4px;margin-top:2px}.env-toggle{display:flex;gap:8px}.env-btn{flex:1;display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .15s;text-align:left}.env-btn:hover{border-color:var(--border-md);background:var(--surface)}.env-btn.active{border-color:var(--accent);background:var(--accent-lt)}.env-icon{font-size:1.4rem;flex-shrink:0;margin-top:1px}.env-body{display:flex;flex-direction:column;gap:2px}.env-label{font-size:13px;font-weight:700;color:var(--text-primary)}.env-sub{font-size:12px;color:var(--text-secondary);line-height:1.4}.preview-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 20px}.preview-card h3{font-size:11px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}.preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:var(--r);overflow:hidden}.preview-item{background:var(--surface);padding:12px 14px;display:flex;flex-direction:column;gap:3px}.preview-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;font-weight:600}.preview-value{font-size:15px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.4px}.mini-preview{display:flex;flex-direction:column;align-items:center;gap:12px}.mini-outer{background:var(--bg-subtle);border:1.5px solid var(--border);border-radius:var(--r);display:flex;align-items:center;justify-content:center;width:100%;max-width:500px;min-height:90px;max-height:200px}.mini-court{background:var(--accent);border-radius:3px;display:flex;align-items:center;justify-content:center;min-width:70px;min-height:45px;opacity:.85}.mini-court span{font-size:11px;font-weight:700;color:#fff;text-align:center;padding:4px}.mini-legend{display:flex;gap:18px;font-size:12px;color:var(--text-secondary);flex-wrap:wrap;justify-content:center}.btn-primary{display:inline-flex;align-items:center;gap:6px;background:var(--accent);color:#fff;border:none;border-radius:var(--r);padding:10px 20px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font);letter-spacing:-.1px}.btn-primary:hover{background:#1a44c2;box-shadow:var(--shadow-sm)}.btn-primary:active{transform:translateY(1px)}.btn-secondary{display:inline-flex;align-items:center;gap:6px;background:var(--surface);color:var(--text-secondary);border:1px solid var(--border-md);border-radius:var(--r);padding:10px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font)}.btn-secondary:hover{color:var(--text-primary);border-color:var(--border-dark);background:var(--surface-2)}.btn-next{align-self:flex-end;min-width:200px;justify-content:center}.court-canvas-wrapper{width:100%;background:#e8ebf0;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);position:relative}.court-canvas{width:100%!important;height:auto!important;display:block}.canvas-dimensions-overlay{position:absolute;top:10px;left:12px;display:flex;gap:6px;flex-wrap:wrap}.canvas-dim-chip{background:#ffffffeb;border:1px solid rgba(0,0,0,.1);font-size:11px;font-weight:600;color:var(--text-secondary);padding:3px 9px;border-radius:4px}.design-studio{display:grid;grid-template-columns:340px 1fr;gap:24px;align-items:start}.studio-left-panel{position:sticky;top:76px;max-height:calc(100vh - 92px);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border-md) transparent;display:flex;flex-direction:column;gap:12px}.studio-left-panel::-webkit-scrollbar{width:6px}.studio-left-panel::-webkit-scrollbar-track{background:transparent}.studio-left-panel::-webkit-scrollbar-thumb{background:var(--border-md);border-radius:10px}.studio-left-panel::-webkit-scrollbar-thumb:hover{background:var(--border-dark)}.studio-right-canvas{display:flex;flex-direction:column;gap:12px}.studio-header{display:flex;justify-content:space-between;align-items:flex-start}.studio-header h2{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px}.studio-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.badge{background:var(--surface-2);border:1px solid var(--border);padding:3px 9px;border-radius:4px;font-size:11px;font-weight:600;color:var(--text-tertiary);white-space:nowrap}.badge.locked{color:var(--accent);border-color:#1d4ed833;background:var(--accent-lt)}.studio-live-price{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:10px 16px;font-size:12px;color:var(--text-secondary)}.studio-live-price strong{font-size:16px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.5px}.studio-tips{font-size:11px;color:var(--text-tertiary);text-align:center}.panel-container{display:flex;flex-direction:column;height:100%;background:var(--surface);border-right:1px solid var(--border)}.panel-main-header{padding:28px 20px 20px;border-bottom:1px solid var(--border);background:linear-gradient(to bottom right,var(--surface),var(--surface-2));display:flex;align-items:center;gap:16px}.header-icon-wrap{width:40px;height:40px;background:var(--accent-lt);color:var(--accent);border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:inset 0 0 0 1px #1d4ed81a}.header-text-wrap{display:flex;flex-direction:column}.panel-main-header h1{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.panel-main-header p{font-size:11px;color:var(--text-tertiary);margin-top:2px;font-weight:500;letter-spacing:.01em}.panel-content-scroll{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:32px}.panel-section{display:flex;flex-direction:column;gap:12px}.section-header{display:flex;flex-direction:column;gap:2px}.section-title{font-size:13px;font-weight:600;color:var(--text-primary)}.section-helper{font-size:11px;color:var(--text-tertiary)}.control-group{display:flex;flex-direction:column;gap:8px}.select-wrapper{position:relative;display:flex;align-items:center}.styled-select{width:100%;appearance:none;background:var(--surface);border:1.5px solid var(--border-md);border-radius:var(--r);padding:10px 36px 10px 12px;font-size:13px;font-weight:600;color:var(--text-primary);font-family:var(--font);cursor:pointer;transition:all .15s}.styled-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-mid)}.select-icon{position:absolute;right:12px;pointer-events:none;color:var(--text-tertiary)}.custom-dropdown{position:relative;width:100%}.dropdown-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1.5px solid var(--border-md);border-radius:var(--r);padding:10px 12px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none}.dropdown-trigger:hover{border-color:var(--border-dark);background:var(--surface-2)}.dropdown-trigger.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-mid);background:var(--surface)}.trigger-content{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:var(--text-primary)}.color-swatch{width:16px;height:16px;border-radius:4px;border:1px solid rgba(0,0,0,.1);flex-shrink:0;box-shadow:0 1px 2px #0000000d}.chevron{color:var(--text-tertiary);transition:transform .3s cubic-bezier(.4,0,.2,1)}.chevron.open{transform:rotate(180deg);color:var(--accent)}.dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a;z-index:1000;max-height:280px;overflow-y:auto;padding:6px;animation:fadeInDown .2s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;color:var(--text-secondary);transition:all .15s}.dropdown-item:hover{background:var(--surface-2);color:var(--text-primary)}.dropdown-item.active{background:var(--accent-lt);color:var(--accent);font-weight:700}.dropdown-item.active .color-swatch{border-color:var(--accent)}.material-summary-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:14px;display:flex;flex-direction:column;gap:12px}.summary-main{display:flex;justify-content:space-between;align-items:flex-start}.summary-price{font-size:14px;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.summary-cat{font-size:11px;color:var(--text-tertiary);margin-top:1px}.summary-tags{display:flex;gap:4px}.feat-pill{background:var(--surface);border:1px solid var(--border);padding:2px 6px;border-radius:4px;font-size:9px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.2px}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:12px;border-top:1px solid var(--border)}.metric-item{display:flex;flex-direction:column;gap:2px}.metric-label{font-size:9px;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;letter-spacing:.4px}.metric-value{font-size:12px;font-weight:700;color:var(--text-primary)}.variant-selector-group{margin-top:4px;padding:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);display:flex;flex-direction:column;gap:12px}.variant-label{font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.variant-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.variant-btn{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 4px;background:var(--surface);border:1.5px solid var(--border-md);border-radius:var(--r);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-size:12px;font-weight:600;color:var(--text-secondary);font-family:var(--font)}.variant-btn:hover{border-color:var(--border-dark);color:var(--text-primary);transform:translateY(-1px)}.variant-btn.active{background:var(--accent-lt);border-color:var(--accent);color:var(--accent);box-shadow:0 4px 12px var(--accent-mid)}.variant-badge{position:absolute;top:-6px;right:-4px;background:var(--orange);color:#fff;font-size:8px;font-weight:800;padding:2px 5px;border-radius:4px;text-transform:uppercase;box-shadow:0 2px 4px #d977064d;pointer-events:none}.variant-note{font-style:italic;font-size:10.5px;line-height:1.4;color:var(--text-tertiary);margin:0}.variant-usecase{margin-top:10px;font-size:11px;color:var(--text-secondary);font-weight:500;background:var(--accent-lt);padding:6px 10px;border-radius:4px;border-left:3px solid var(--accent)}.control-note{font-size:10px;color:var(--text-tertiary);margin-top:-4px}.view-toggle{display:flex;background:#f1f5f9cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:4px;border-radius:12px;border:1px solid rgba(226,232,240,.8);gap:4px;box-shadow:inset 0 2px 4px #00000005}.view-toggle .toggle-btn{display:flex;align-items:center;gap:10px;padding:10px 20px;border-radius:9px;border:1px solid transparent;background:transparent;color:#64748b;font-size:13px;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);letter-spacing:-.01em}.view-toggle .toggle-btn svg{opacity:.7;transition:transform .25s ease}.view-toggle .toggle-btn:hover{color:#1e293b;background:#ffffff80}.view-toggle .toggle-btn:hover svg{transform:translateY(-1px)}.view-toggle .toggle-btn.active{background:#fff;color:var(--accent);box-shadow:0 4px 12px #0000000d,0 1px 3px #00000005;border-color:#e2e8f080}.view-toggle .toggle-btn.active svg{opacity:1;color:var(--accent)}.canvas-container-main{flex:1;min-height:580px;position:relative;background:#fdfdfd;border-radius:20px;border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow-sm);transition:all .4s ease}.canvas-2d-wrapper{width:100%;height:100%;animation:fadeIn .5s ease-out}.canvas-3d-wrapper-studio{width:100%;height:100%;background:#040810;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.99)}to{opacity:1;transform:scale(1)}}.preview3d-container.full-page{display:flex;flex-direction:column;height:calc(100vh - 120px);min-height:650px;background:#f1f5f9;border-radius:0;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-shadow:none;animation:slideUp .6s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.preview3d-header.compact{padding:8px 24px;background:#fff6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center;z-index:10}.preview3d-title-group h2{color:#0f172a;margin:0;font-size:14px;font-weight:800;letter-spacing:-.3px}.preview3d-title-group p{color:#64748b;margin:2px 0 0;font-size:10px;font-weight:500}.view-mode-group{display:flex;gap:6px;background:#fffc;padding:4px;border-radius:10px;border:1px solid rgba(0,0,0,.08);box-shadow:0 2px 8px #0000000d}.view-mode-btn{padding:8px 18px;border-radius:7px;border:none;background:transparent;color:#64748b;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);font-family:var(--font);white-space:nowrap}.view-mode-btn:hover{color:#1e293b;background:#fff9;transform:translateY(-1px)}.view-mode-btn.active{background:var(--accent);color:#fff;box-shadow:0 4px 12px #1d4ed840;transform:translateY(0)}.canvas3d-wrapper.realistic-arena{flex:1;position:relative;background:#bae6fd}.canvas3d-wrapper.realistic-arena canvas{outline:none}.preview3d-container .step-actions{padding:12px 24px;background:#fff6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.05);display:flex;justify-content:space-between;align-items:center;z-index:10}.canvas-3d-wrapper-studio .preview3d-container{height:100%;display:flex;flex-direction:column}.canvas-3d-wrapper-studio .canvas3d-wrapper{flex:1;min-height:auto;border-radius:0;border:none}.canvas3d-hint{position:absolute;bottom:24px;left:50%;transform:translate(-50%);background:#000000b3;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#ffffffe6;padding:10px 20px;border-radius:100px;font-size:12px;font-weight:600;pointer-events:none;border:1px solid rgba(255,255,255,.15);z-index:10;box-shadow:0 10px 30px #0000004d;letter-spacing:.2px}.canvas-3d-wrapper-studio .preview3d-header,.canvas-3d-wrapper-studio .step-actions{display:none}.studio-right-canvas{display:flex;flex-direction:column;gap:16px;flex:1}.toggle-list{display:flex;flex-direction:column;gap:1px;background:var(--border);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:8px}.toggle-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface);font-size:12px;color:var(--text-secondary)}.toggle-btn{appearance:none;background:var(--bg-subtle);border:1px solid var(--border-md);border-radius:4px;padding:4px 10px;font-size:10px;font-weight:700;color:var(--text-tertiary);cursor:pointer;transition:all .15s}.toggle-btn.on{background:var(--green-lt);border-color:#0478574d;color:var(--green)}.inline-input-group{display:flex;flex-direction:column;gap:6px;margin-top:10px}.inline-input-group label{font-size:11px;font-weight:600;color:var(--text-secondary)}.inline-input-group input{padding:10px 12px;background:var(--surface-2);border:1.5px solid var(--border-md);border-radius:var(--r);font-size:13px;font-weight:600;font-family:var(--font);color:var(--text-primary);outline:none;transition:all .15s}.inline-input-group input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-mid)}.panel-sticky-actions{padding:16px 20px;border-top:1px solid var(--border);background:var(--surface);display:flex;gap:12px;position:sticky;bottom:0;box-shadow:0 -4px 12px #00000008;z-index:10}.btn-back{display:flex;align-items:center;gap:6px;padding:11px 16px;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r-md);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.btn-back:hover{background:var(--surface-2);border-color:var(--border-dark);color:var(--text-primary);transform:translateY(-1px)}.btn-back:active{transform:translateY(0)}.btn-next{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;background:var(--accent);border:none;border-radius:var(--r-md);color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #1d4ed833}.btn-next:hover{background:#1a44c2;transform:translateY(-1px);box-shadow:0 6px 16px #1d4ed84d}.btn-next:active{transform:translateY(0)}.quotation-container{display:flex;flex-direction:column;gap:16px;max-width:100%;overflow-x:hidden}.quotation-header{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 24px;flex-wrap:wrap}.quotation-header-left{display:flex;align-items:center;gap:14px}.quotation-logo-mark{width:40px;height:40px;background:var(--accent);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:18px}.quotation-header h2{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px;word-break:break-word}.quote-date{font-size:12px;color:var(--text-tertiary);margin-top:2px;word-break:break-word}.quotation-logo{display:none}.btn-print{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border-md);border-radius:var(--r);padding:9px 16px;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font)}.btn-print:hover{color:var(--text-primary);border-color:var(--border-dark);background:var(--surface-2)}.quotation-body{display:grid;grid-template-columns:1fr 380px;gap:16px;align-items:start;max-width:100%;overflow-x:hidden}.quotation-left,.quotation-right{display:flex;flex-direction:column;gap:12px;min-width:0;overflow-x:hidden}.quote-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px 18px;max-width:100%;overflow-x:auto}.quote-card h3{font-size:11px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.spec-table{display:flex;flex-direction:column}.spec-row{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;font-size:13px;border-radius:var(--r-sm);gap:8px;flex-wrap:wrap}.spec-row:nth-child(odd){background:var(--surface-2)}.spec-row:nth-child(2n){background:var(--surface)}.spec-label{color:var(--text-secondary);font-weight:400}.spec-value{color:var(--text-primary);font-weight:600;text-align:right;font-variant-numeric:tabular-nums;word-break:break-word}.addon-list{display:flex;flex-direction:column;gap:4px}.addon-item{display:flex;align-items:center;gap:10px;cursor:pointer;padding:9px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);transition:all .12s}.addon-item:hover{background:var(--surface);border-color:var(--border-md)}.addon-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.addon-icon{font-size:13px}.addon-label{font-size:12px;color:var(--text-secondary);font-weight:500}.quote-canvas-wrap{border-radius:var(--r-sm);overflow:hidden}.breakdown-table{display:flex;flex-direction:column;gap:1px}.breakdown-header{display:grid;grid-template-columns:1fr 56px 56px 84px;gap:4px;padding:6px 10px 8px;font-size:10px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border)}.breakdown-row{display:grid;grid-template-columns:1fr 56px 56px 84px;gap:4px;padding:8px 10px;font-size:12px;color:var(--text-secondary);border-radius:var(--r-sm)}.breakdown-row:nth-child(odd){background:var(--surface-2)}.breakdown-row:nth-child(2n){background:transparent}.br-label{font-weight:500}.br-amount{font-weight:700;text-align:right;color:var(--text-primary);font-variant-numeric:tabular-nums}.br-sqft,.br-rate{text-align:right;color:var(--text-tertiary);font-size:11px;font-variant-numeric:tabular-nums}.breakdown-divider{height:1px;background:var(--border);margin:6px 0}.breakdown-row.subtotal{color:var(--text-primary);font-weight:700;background:transparent}.breakdown-row.gst{color:var(--text-tertiary);font-size:11px;background:transparent}.breakdown-row.grand-total{background:var(--accent-lt);border:1px solid rgba(29,78,216,.2);color:var(--accent);font-weight:800;border-radius:var(--r);margin-top:2px;font-size:13px}.grand-total-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-lg);padding:20px;text-align:center;max-width:100%;overflow-x:hidden}.gt-label{font-size:10px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}.gt-amount{font-size:32px;font-weight:800;color:var(--text-primary);line-height:1;font-variant-numeric:tabular-nums;letter-spacing:-1px;margin-bottom:4px;word-break:break-word}.gt-sub{font-size:11px;color:var(--text-tertiary);margin-bottom:16px}.gt-rate-info{display:flex;justify-content:space-around;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:10px 8px;gap:8px;flex-wrap:wrap}.gt-rate-info>div{display:flex;flex-direction:column;gap:2px;align-items:center}.gt-rate-info span{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.4px;font-weight:600}.gt-rate-info strong{font-size:13px;color:var(--text-primary);font-weight:700}.notes-card ul{list-style:none;display:flex;flex-direction:column;gap:6px}.notes-card li{font-size:12px;color:var(--text-secondary);padding-left:12px;position:relative;line-height:1.5}.notes-card li:before{content:"—";position:absolute;left:0;color:var(--text-tertiary);font-size:12px}.quotation-actions{display:flex;gap:8px;justify-content:flex-end;padding-bottom:20px;flex-wrap:wrap}.app-footer{display:flex;justify-content:space-between;padding:12px 32px;border-top:1px solid var(--border);font-size:11px;color:var(--text-tertiary);background:var(--surface)}.kv-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}.kv-row:last-child{border-bottom:none}.kv-label{color:var(--text-secondary)}.kv-value{color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}@media print{.no-print,.app-header,.stepper,.app-footer{display:none!important}.app-main{padding:0!important}.quotation-body{grid-template-columns:1fr 1fr!important}body{background:#fff!important;color:#111!important}.quote-card,.grand-total-card,.quotation-header{border:1px solid #ddd!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}@media(max-width:1100px){.quotation-body{grid-template-columns:1fr}.quotation-right{order:-1}}@media(max-width:900px){.design-studio{grid-template-columns:1fr}.studio-left-panel{position:static;max-height:none;border-right:none;border-bottom:1px solid var(--border)}.preview-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.app-header{padding:0 16px}.app-main{padding:16px 14px 40px}.step-header h2{font-size:17px}.court-type-grid{grid-template-columns:1fr 1fr}.env-toggle{flex-direction:column}.stepper{padding:0 8px}.fci-values{flex-direction:column}.preview-grid{grid-template-columns:repeat(2,1fr)}.step-sublabel{display:none}}.preview3d-container{display:flex;flex-direction:column;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.preview3d-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:var(--surface);border-bottom:1px solid var(--border)}.preview3d-title-group{display:flex;align-items:center;gap:12px}.preview3d-title-icon{width:36px;height:36px;background:var(--accent-lt);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--accent)}.preview3d-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.preview3d-subtitle{font-size:12px;color:var(--text-secondary);margin:4px 0 0;display:flex;align-items:center;gap:8px}.preview3d-court-name{font-weight:600;color:var(--text-primary)}.preview3d-dot{width:3px;height:3px;background:var(--text-tertiary);border-radius:50%}.preview3d-locked{font-size:11px;color:var(--text-tertiary)}.preview3d-controls{display:flex;align-items:center;gap:16px}.preview3d-chips{display:flex;gap:6px}.info-chip{display:flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--border);padding:6px 12px;border-radius:var(--r);font-size:11px;font-weight:600;color:var(--text-secondary)}.chip-swatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(0,0,0,.1)}.canvas3d-wrapper{position:relative;width:100%;height:600px;background:#040810}.canvas3d-wrapper canvas{width:100%!important;height:100%!important}.preview3d-info-strip{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--surface-2);border-top:1px solid var(--border)}.info-strip-left{display:flex;align-items:center;gap:16px}.info-stat{display:flex;flex-direction:column;gap:2px}.info-stat-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.info-stat-value{font-size:13px;font-weight:700;color:var(--text-primary)}.info-stat-divider{width:1px;height:32px;background:var(--border)}.info-strip-right{display:flex;align-items:center}.color-preview-group{display:flex;gap:12px}.color-preview-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);font-weight:600}.color-dot{width:16px;height:16px;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.step-actions{display:flex;justify-content:space-between;padding:20px 24px;background:var(--surface);border-top:1px solid var(--border)}.preview3d-container.full-page{display:flex;flex-direction:column;min-height:700px}.preview3d-header.compact{padding:16px 24px;background:#fff;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.realistic-arena{background:radial-gradient(circle at 50% 50%,#2c3e50,#000);flex:1;min-height:550px}.preview3d-chips{display:flex;gap:12px;align-items:center}.info-chip{padding:6px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:99px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.8px;box-shadow:0 1px 2px #0000000d}.view-mode-btn{padding:6px 14px;border-radius:6px;font-size:11px;font-weight:700;background:#f1f5f9;border:1px solid #e2e8f0;color:#475569;cursor:pointer;transition:all .2s}.view-mode-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 12px #2563eb33}.view-mode-btn:hover:not(.active){background:#e2e8f0}
