@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*{box-sizing:border-box}body{margin:0;padding:0;overscroll-behavior:none;-webkit-overflow-scrolling:touch}button,.btn,.tool-btn,.bp-tool-btn,[role=button]{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}*{-webkit-tap-highlight-color:transparent}canvas{touch-action:none;-webkit-user-select:none;user-select:none}button,input[type=checkbox],input[type=radio],.clickable{min-height:44px;min-width:44px}.scrollable,[data-scrollable=true]{touch-action:pan-y;-webkit-overflow-scrolling:touch}input[type=text],input[type=number],input[type=email],input[type=password],input[type=tel],textarea,select{font-size:16px!important}button,.btn,.interactive{transition:transform .1s ease,background-color .15s ease}button:active,.btn:active{transform:scale(.97)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,sans-serif;background:linear-gradient(135deg,#0f172a,#1e293b);min-height:100vh;color:#f1f5f9}.app{min-height:100vh;display:flex;flex-direction:column}.header{background:#0f172af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:100}.logo{height:40px;width:auto;object-fit:contain}.steps-nav{display:flex;gap:.5rem}.user-menu{display:flex;align-items:center;gap:.75rem}.user-info{display:flex;align-items:center;gap:.4rem;color:#94a3b8;font-size:.875rem;padding:.4rem .75rem;background:#ffffff0d;border-radius:6px}.admin-link{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3);border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.admin-link:hover{background:#f59e0b40}.merge-link{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:#6366f126;color:#a5b4fc;border:1px solid rgba(99,102,241,.3);border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.merge-link:hover{background:#6366f140}.blueprint-link{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:#10b98126;color:#34d399;border:1px solid rgba(16,185,129,.3);border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.blueprint-link:hover{background:#10b98140}.preview-container{display:flex;flex-direction:column;gap:1rem}.preview-scroll-container{border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#0003}.logout-btn-header{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3);border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.logout-btn-header:hover{background:#ef444440}.step-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#94a3b8;cursor:pointer;transition:all .2s}.step-btn:hover{background:#ffffff1a}.step-btn.active{background:#3b82f633;border-color:#3b82f6;color:#fff}.step-btn.completed{background:#10b98133;border-color:#10b981;color:#10b981}.step-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border-radius:50%;font-size:12px;font-weight:600}.step-btn.active .step-num{background:#3b82f6;color:#fff}.step-btn.completed .step-num{background:#10b981;color:#fff}.step-label{font-size:.875rem;font-weight:500}.main{flex:1;padding:2rem}.step-content{max-width:1400px;margin:0 auto}.step-header{margin-bottom:1.5rem}.step-header h2{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.step-header p{color:#94a3b8}.step-header.compact{margin-bottom:1rem}.step-header.compact h2{font-size:1.25rem}.jspaint-container{background:#fff;border-radius:12px;overflow:hidden;margin-bottom:1.5rem;box-shadow:0 10px 40px #0000004d}.jspaint-iframe{width:100%;height:850px;border:none}.upload-section{display:flex;align-items:flex-start;gap:2rem;padding:1.5rem;background:#1e293b80;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.upload-instructions{flex:1}.upload-instructions h3{margin-bottom:.75rem;color:#38bdf8}.upload-instructions ol{padding-left:1.25rem;color:#94a3b8;line-height:1.8}.upload-instructions strong{color:#f1f5f9}.upload-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.upload-btn.primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff}.upload-btn.primary:hover{transform:translateY(-2px);box-shadow:0 5px 20px #3b82f666}.preview-small{display:flex;flex-direction:column;align-items:center;gap:.5rem}.preview-small img{width:150px;height:auto;border-radius:8px;border:2px solid #10b981}.success-badge{background:#10b981;color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.calibration-container{display:grid;grid-template-columns:1fr 300px;gap:2rem}.canvas-wrapper{background:#1e293b80;padding:1rem;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.blueprint-canvas{width:100%;border-radius:8px;display:block;cursor:grab}.blueprint-canvas:active{cursor:grabbing}.blueprint-canvas.clickable,.blueprint-canvas.drawing{cursor:crosshair}.calibration-controls{display:flex;flex-direction:column;gap:1rem}.info-box,.success-box{padding:1.25rem;border-radius:12px}.info-box{background:#fbbf241a;border:1px solid rgba(251,191,36,.3)}.info-box strong{color:#fbbf24;display:block;margin-bottom:.5rem}.info-box p{color:#94a3b8;font-size:.875rem}.success-box{background:#10b9811a;border:1px solid rgba(16,185,129,.3)}.success-box h3{color:#10b981;margin-bottom:.5rem}.success-box p{color:#94a3b8}.success-box strong{color:#10b981}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-size:.875rem;color:#94a3b8}.input{padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#f1f5f9;font-size:1rem}.input:focus{outline:none;border-color:#3b82f6}.input.small{padding:.5rem .75rem;font-size:.875rem}.fraction-input{display:inline-flex;align-items:center;gap:.5rem}.fraction-whole{width:70px!important;text-align:center;padding:.5rem .25rem!important}.fraction-part{display:inline-flex;align-items:center;gap:2px;background:#ffffff08;border-radius:6px;padding:2px 6px}.fraction-num,.fraction-den{width:45px!important;text-align:center;padding:.4rem .2rem!important;font-size:.875rem!important}.fraction-slash{color:#94a3b8;font-size:1.1rem;font-weight:300;line-height:1;padding:0 2px}.slab-measure .fraction-input{flex-wrap:nowrap}.slab-measure .fraction-whole{width:55px!important}.slab-measure .fraction-num,.slab-measure .fraction-den{width:38px!important}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:.875rem}.btn.primary{background:#3b82f6;color:#fff}.btn.primary:hover{background:#2563eb}.btn.primary:disabled{background:#475569;cursor:not-allowed}.btn.secondary{background:#ffffff1a;color:#f1f5f9}.btn.secondary:hover{background:#ffffff26}.btn.danger{background:#ef444433;color:#ef4444}.btn.danger:hover{background:#ef44444d}.btn.warning{background:#fbbf2433;color:#fbbf24}.btn.success{background:#10b98133;color:#10b981}.btn.success:hover{background:#10b9814d}.btn.small{padding:.5rem .75rem;font-size:.75rem}.btn.large{padding:1rem 2rem;font-size:1rem}.spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:none;cursor:pointer;transition:all .2s}.btn-icon.danger{background:#ef444433;color:#ef4444}.btn-icon.danger:hover{background:#ef44444d}.btn-icon.danger.tiny{width:22px;height:22px;border-radius:4px}.blueprint-tabs{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.blueprint-tab{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border:2px solid rgba(255,255,255,.1);border-radius:8px;cursor:pointer;position:relative;background:#1e293b80;transition:all .2s}.blueprint-tab:hover{border-color:#ffffff40}.blueprint-tab.active{border-color:#3b82f6;background:#3b82f61a}.blueprint-tab-thumb{width:80px;height:60px;object-fit:cover;border-radius:4px}.blueprint-tab span{font-size:.75rem;color:#94a3b8}.blueprint-tab.active span{color:#f1f5f9}.success-badge.small{font-size:.65rem;padding:1px 4px}.blueprint-selector{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.btn-icon.small{width:24px;height:24px}.slabs-container{display:grid;grid-template-columns:300px 1fr;gap:2rem}.slabs-list{display:flex;flex-direction:column;gap:1rem}.slab-card{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.slab-card.selected{border-color:#3b82f6}.slab-header{display:flex;justify-content:space-between;align-items:center}.slab-thumb{width:100%;height:120px;object-fit:cover;border-radius:8px}.slab-measure{display:flex;gap:.5rem}.slab-dims{background:#10b98133;color:#10b981;padding:.5rem;border-radius:6px;font-size:.875rem;font-weight:600;text-align:center}.crop-area{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.crop-area h3{margin-bottom:.5rem}.crop-area p{color:#94a3b8;margin-bottom:1rem;font-size:.875rem}.crop-actions{display:flex;gap:.75rem;margin-top:.5rem}.crop-actions .btn{display:flex;align-items:center;gap:.4rem}.slab-canvas{width:100%;border-radius:8px;display:block;margin-bottom:1rem}.slab-canvas.cropping,.slab-canvas.measuring{cursor:crosshair}.layout-step .step-content{max-width:1600px}.layout-container{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.layout-panel{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.panel-header h3{font-size:1rem;font-weight:600}.panel-buttons{display:flex;gap:.5rem}.zoom-controls{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;padding:.5rem;background:#ffffff0d;border-radius:6px}.zoom-controls .btn-icon{width:28px;height:28px;font-size:1.1rem;font-weight:700}.zoom-level{font-size:.85rem;color:#94a3b8;min-width:45px;text-align:center}.zoom-separator{width:1px;height:20px;background:#fff3;margin:0 .25rem}.btn-icon.active{background:#fbbf244d;color:#fbbf24}.slabs-scroll-container{max-height:600px;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;padding-right:.5rem}.slab-card{background:#ffffff08;border:2px solid rgba(255,255,255,.1);border-radius:8px;padding:.75rem;cursor:pointer;transition:all .2s}.slab-card:hover{background:#ffffff0d;border-color:#fff3}.slab-card.selected{border-color:#3b82f6;background:#3b82f61a}.slab-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.slab-title{font-weight:600;color:#f1f5f9}.slab-size{font-size:.8rem;color:#94a3b8}.slab-zoom-container{overflow:auto;border-radius:6px}.slab-canvas-multi{width:100%;border-radius:6px;display:block}.slab-canvas-multi.measuring{cursor:crosshair}.slab-tools-inline{display:flex;gap:.35rem;align-items:center}.measurements-list.compact{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;margin-top:.5rem;padding:.4rem;background:#0003;border-radius:4px;font-size:.8rem}.measurements-list.compact strong{margin-right:.25rem}.measure-value{cursor:pointer;padding:.1rem .3rem;background:#ffffff1a;border-radius:3px;transition:background .2s}.measure-value:hover{background:#f59e0b4d}.measure-input{width:50px;padding:.1rem .25rem;background:#f59e0b33;border:1px solid #f59e0b;border-radius:3px;color:#fff;font-size:.8rem;text-align:center}.btn-icon.tiny{width:16px;height:16px;font-size:.7rem;padding:0;margin-left:.15rem}.btn.small{padding:.35rem .6rem;font-size:.8rem}.blueprint-zoom-container{border-radius:8px;background:#0003}.dims-editable{display:flex;align-items:center;gap:.25rem;margin-left:auto;font-size:.8rem;color:#94a3b8}.dim-value{padding:.15rem .35rem;background:#ffffff1a;border-radius:4px;cursor:pointer;transition:background .2s}.dim-value:hover{background:#3b82f64d;color:#93c5fd}.dim-x{color:#64748b}.dim-input{width:50px;padding:.15rem .25rem;background:#3b82f633;border:1px solid #3b82f6;border-radius:4px;color:#fff;font-size:.8rem;text-align:center}.dim-input:focus{outline:none;background:#3b82f64d}.section-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cutout-dropdown-container{position:relative}.cutout-dropdown{position:absolute;top:100%;right:0;margin-top:.5rem;background:#1e293b;border:1px solid rgba(255,255,255,.2);border-radius:8px;box-shadow:0 10px 30px #00000080;z-index:100;min-width:220px;max-height:300px;overflow-y:auto}.cutout-option{display:block;width:100%;padding:.75rem 1rem;text-align:left;background:transparent;border:none;color:#f1f5f9;cursor:pointer;font-size:.875rem;transition:background .2s}.cutout-option:hover{background:#ffffff1a}.cutout-option.custom{border-top:1px solid rgba(255,255,255,.1);color:#fbbf24}.slab-select{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#f1f5f9;font-size:.875rem}.slab-tools{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.mode-indicator{padding:.75rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;margin-bottom:1rem}.mode-indicator.drawing{background:#8b5cf633;border:1px solid rgba(139,92,246,.3);color:#a78bfa}.mode-indicator.cutout{background:#6b728033;border:1px solid rgba(107,114,128,.5);color:#9ca3af}.mode-indicator.measuring{background:#fbbf2433;border:1px solid rgba(251,191,36,.3);color:#fbbf24}.sections-list{display:flex;flex-direction:column;gap:.5rem;margin-top:1rem;max-height:200px;overflow-y:auto}.sections-hint{font-size:.75rem;color:#64748b;margin-top:.5rem;text-align:center}.section-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;cursor:pointer;transition:all .2s}.section-item:hover{background:#ffffff1a}.section-item.selected{background:#3b82f633;border-color:#3b82f6}.section-item.cutout-item{border-color:#6b728080}.section-item.cutout-item.selected{background:#6b728033;border-color:#6b7280}.section-item .section-name-input{flex:1;min-width:80px}.parent-badge{display:inline-block;margin-left:.5rem;padding:.1rem .4rem;background:#10b9814d;border-radius:4px;font-size:.7rem;color:#10b981}.section-item .dims{color:#94a3b8;font-size:.75rem;margin-left:auto}.section-item .placed-badge{color:#10b981;font-size:.75rem}.section-name-input{background:#ffffff1a;border:1px solid #3b82f6;border-radius:4px;color:#f1f5f9;padding:.25rem .5rem;font-size:.875rem;width:120px}.section-item span{cursor:pointer}.section-item span:hover{text-decoration:underline;text-decoration-style:dashed}.measurements-list{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px;margin-bottom:1rem;font-size:.875rem;color:#f59e0b}.measurement-item{display:inline-flex;align-items:center;gap:.25rem;background:#f59e0b33;padding:.25rem .5rem;border-radius:4px}.measurement-item button{background:transparent;color:#ef4444;font-size:1rem;line-height:1;padding:0 .25rem}.slab-measure{display:flex;gap:.5rem;align-items:center}.export-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.export-form{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;color:#94a3b8;font-weight:500}.radio-group{display:flex;gap:1rem}.radio-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.radio-label input{accent-color:#3b82f6}.export-preview{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.export-preview h3{margin-bottom:1rem}.preview-box{background:#fff;border-radius:8px;overflow:hidden;color:#1f2937}.preview-header{background:#0f172a;color:#fff;padding:.75rem 1rem}.preview-content{padding:1rem}.preview-content p{margin-bottom:.5rem;font-size:.875rem}.step-nav{display:flex;justify-content:space-between;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.nav-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-size:1rem}.nav-btn.prev{background:#ffffff1a;color:#f1f5f9}.nav-btn.prev:hover{background:#ffffff26}.nav-btn.next{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff}.nav-btn.next:hover{transform:translateY(-2px);box-shadow:0 5px 20px #3b82f666}@media(max-width:1024px){.layout-container,.calibration-container,.slabs-container,.export-container{grid-template-columns:1fr}.header{flex-direction:column;gap:1rem;padding:.75rem 1rem}.steps-nav{overflow-x:auto;width:100%;justify-content:flex-start;padding-bottom:.5rem}.step-content{padding:1rem}.step-header h2{font-size:1.25rem}.btn,.nav-btn,.upload-btn{min-height:48px;padding:.75rem 1.25rem}.step-btn{min-width:44px;min-height:44px;padding:.5rem .75rem}.canvas-wrapper,.blueprint-zoom-container,.slab-zoom-container{overflow:auto;-webkit-overflow-scrolling:touch;max-height:60vh}.blueprint-canvas,.slab-canvas,.slab-canvas-multi{touch-action:none}.user-menu{flex-wrap:wrap;justify-content:center;gap:.5rem}.layout-container{gap:1rem}.zoom-controls{flex-wrap:wrap;gap:.5rem}.btn-icon{min-width:44px;min-height:44px}.sections-list,.slabs-list{max-height:200px;overflow-y:auto;-webkit-overflow-scrolling:touch}}@media(max-width:768px){.header{padding:.5rem .75rem}.logo{height:32px}.steps-nav{gap:.25rem}.step-btn{font-size:.7rem;padding:.4rem .6rem}.step-content{padding:.75rem}.step-header{margin-bottom:1rem}.step-header h2{font-size:1.1rem}.step-header p{font-size:.8rem}.panel-buttons{flex-direction:column;gap:.5rem}.nav-btn{padding:.75rem 1rem;font-size:.9rem}.input,.form-group input,.form-group select{font-size:16px;padding:.75rem}.cutout-dropdown{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:90%;max-width:320px;max-height:80vh;overflow-y:auto}.cutout-option{padding:1rem;min-height:48px}.measurements-list{font-size:.75rem}.measurement-item{padding:.5rem}}@media(max-width:1024px)and (orientation:landscape){.layout-container{grid-template-columns:1fr 1fr}.canvas-wrapper,.blueprint-zoom-container,.slab-zoom-container{max-height:50vh}}@media(hover:none)and (pointer:coarse){.btn,.btn-icon,.upload-btn,.step-btn{min-height:44px}.btn:hover,.nav-btn:hover{transform:none}.btn:active,.nav-btn:active{transform:scale(.97);opacity:.9}.cutout-dropdown-container{position:relative}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b);padding:1rem}.login-card{background:#1e293bf2;border-radius:16px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 25px 50px -12px #00000080;border:1px solid rgba(255,255,255,.1)}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:#f1f5f9;font-size:1.75rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#3b82f6,#10b981);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:#94a3b8;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-form .form-group{display:flex;flex-direction:column;gap:.5rem}.login-form label{color:#e2e8f0;font-size:.875rem;font-weight:500}.login-form input{padding:.75rem 1rem;background:#0f172acc;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#f1f5f9;font-size:1rem;transition:all .2s}.login-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.login-form input::placeholder{color:#64748b}.password-input{position:relative;display:flex;align-items:center}.password-input input{width:100%;padding-right:3rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;color:#64748b;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.password-toggle:hover{color:#94a3b8}.login-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;text-align:center}.login-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.login-footer p{color:#64748b;font-size:.8rem}@media(max-width:768px){.login-card{padding:1.5rem;margin:.5rem}.login-header h1{font-size:1.5rem}.login-form input{font-size:16px;padding:.875rem 1rem;min-height:48px}.login-btn{min-height:48px;padding:1rem 1.5rem}.password-toggle{min-width:44px;min-height:44px;padding:.5rem}}@media(hover:none)and (pointer:coarse){.login-btn:active{transform:scale(.98)}.password-toggle:active{color:#94a3b8}}.admin-container{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b)}.admin-header{background:#0f172af2;border-bottom:1px solid rgba(255,255,255,.1);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.admin-header-left{display:flex;align-items:center;gap:1.5rem}.admin-header-left h1{color:#f1f5f9;font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.admin-header-left h1 svg{color:#f59e0b}.back-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;color:#94a3b8;border:1px solid rgba(255,255,255,.1);border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s}.back-btn:hover{background:#ffffff26;color:#f1f5f9}.admin-header-right{display:flex;align-items:center;gap:1rem}.admin-user{display:flex;align-items:center;gap:.5rem;color:#94a3b8;font-size:.875rem}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3);border-radius:6px;font-size:.875rem;cursor:pointer;transition:all .2s}.logout-btn:hover{background:#ef444440}.admin-main{padding:2rem;max-width:1200px;margin:0 auto}.admin-card{background:#1e293bf2;border-radius:12px;border:1px solid rgba(255,255,255,.1);overflow:hidden}.admin-card-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.admin-card-header h2{color:#f1f5f9;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.header-actions{display:flex;gap:.5rem}.refresh-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#3b82f626;color:#60a5fa;border:1px solid rgba(59,130,246,.3);border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#3b82f640}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.refresh-btn .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.admin-warning{background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:#fbbf24;padding:1rem 1.5rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.no-users{padding:2rem;text-align:center;color:#64748b;font-style:italic}.setup-instructions{background:#1e293bf2;border-radius:12px;border:1px solid rgba(255,255,255,.1);padding:1.5rem;margin-top:1.5rem}.setup-instructions h3{color:#f1f5f9;font-size:1rem;margin-bottom:1rem}.setup-instructions ol{color:#94a3b8;font-size:.875rem;padding-left:1.25rem;display:flex;flex-direction:column;gap:.5rem}.setup-instructions code{background:#0f172acc;padding:.15rem .4rem;border-radius:4px;font-family:monospace;font-size:.8rem;color:#60a5fa}.create-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.create-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.create-btn.cancel{background:#6b72804d}.create-btn.cancel:hover{background:#6b728080;box-shadow:none}.admin-error{background:#ef444426;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:.75rem 1.5rem;font-size:.875rem;margin:0}.admin-success{background:#10b98126;border:1px solid rgba(16,185,129,.3);color:#6ee7b7;padding:.75rem 1.5rem;font-size:.875rem;margin:0}.create-form{padding:1.25rem 1.5rem;background:#0f172a80;border-bottom:1px solid rgba(255,255,255,.1)}.form-row{display:flex;gap:1rem;align-items:flex-end}.create-form .form-group{flex:1;display:flex;flex-direction:column;gap:.4rem}.create-form label{color:#94a3b8;font-size:.8rem;font-weight:500}.create-form input{padding:.6rem .875rem;background:#0f172acc;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#f1f5f9;font-size:.9rem}.create-form input:focus{outline:none;border-color:#3b82f6}.create-form .password-input{position:relative;display:flex}.create-form .password-input input{width:100%;padding-right:2.5rem}.create-form .password-toggle{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#64748b;cursor:pointer;padding:.25rem}.submit-btn{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.submit-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.users-table{padding:0}.table-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr;gap:1rem;padding:.875rem 1.5rem;background:#0f172a80;border-bottom:1px solid rgba(255,255,255,.1)}.table-header span{color:#64748b;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05);align-items:center;transition:background .2s}.table-row:hover{background:#ffffff05}.table-row.inactive{opacity:.6}.table-row:last-child{border-bottom:none}.col-user{display:flex;align-items:center;gap:.5rem;color:#f1f5f9;font-weight:500}.col-user svg{color:#64748b}.col-role,.col-status,.col-created{color:#94a3b8;font-size:.875rem}.role-badge{display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.75rem;font-weight:500;text-transform:capitalize}.role-badge.admin{background:#f59e0b33;color:#fbbf24}.role-badge.user{background:#3b82f633;color:#60a5fa}.status-badge{display:inline-block;padding:.2rem .6rem;border-radius:4px;font-size:.75rem;font-weight:500}.status-badge.active{background:#10b98133;color:#34d399}.status-badge.inactive{background:#ef444433;color:#f87171}.col-actions{display:flex;align-items:center;gap:.5rem}.action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.action-btn.activate{background:#10b98126;color:#34d399}.action-btn.activate:hover{background:#10b9814d}.action-btn.deactivate{background:#f59e0b26;color:#fbbf24}.action-btn.deactivate:hover{background:#f59e0b4d}.action-btn.delete{background:#ef444426;color:#f87171}.action-btn.delete:hover{background:#ef44444d}.protected{color:#64748b;font-size:.75rem;font-style:italic}@media(max-width:768px){.admin-header{flex-direction:column;gap:1rem;padding:1rem}.admin-header-left{width:100%;justify-content:space-between}.admin-header-right{width:100%;justify-content:flex-end}.form-row{flex-direction:column}.table-header{display:none}.table-row{grid-template-columns:1fr;gap:.5rem}.col-user{font-size:1rem}.col-actions{justify-content:flex-end;margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.05)}}@media(max-width:480px){.admin-card{padding:1rem;margin:.5rem}.admin-card h2{font-size:1.1rem}.form-group input{font-size:16px;padding:.75rem;min-height:48px}.table-row{padding:.75rem}}@media(hover:none)and (pointer:coarse){.toggle-btn,.delete-btn,.btn{min-height:44px;min-width:44px}.toggle-btn:active,.delete-btn:active,.btn:active{transform:scale(.97)}.table-row{padding:1rem .75rem}}.merge-container{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b)}.merge-header{background:#0f172af2;border-bottom:1px solid rgba(255,255,255,.1);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.merge-header-left{display:flex;align-items:center;gap:1.5rem}.merge-header-left h1{color:#f1f5f9;font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem;margin:0}.merge-header-left h1 svg{color:#818cf8}.merge-steps-nav{display:flex;gap:.5rem}.merge-header-right{display:flex;align-items:center;gap:.75rem}.merge-main{flex:1;padding:2rem}.merge-summary{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.merge-summary-card{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem}.merge-summary-card h3{color:#38bdf8;margin-bottom:1rem;font-size:1.1rem}.merge-summary-card p{color:#94a3b8;font-size:.875rem;margin-bottom:.5rem}.merge-summary-card strong{color:#10b981}.merge-preview-img{width:100%;max-height:200px;object-fit:contain;border-radius:8px;margin-bottom:1rem;border:1px solid rgba(255,255,255,.1)}.merge-actions{display:flex;justify-content:center;margin:2rem 0}.back-btn{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:#94a3b826;color:#94a3b8;border:1px solid rgba(148,163,184,.3);border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.back-btn:hover{background:#94a3b840;color:#e2e8f0}@media(max-width:1024px){.merge-header{flex-direction:column;gap:1rem;padding:.75rem 1rem}.merge-summary{grid-template-columns:1fr}.merge-main{padding:1rem}}@media(max-width:768px){.merge-header{padding:.5rem .75rem}.merge-header-left h1{font-size:1.1rem}.merge-steps-nav{flex-wrap:wrap;justify-content:center;gap:.25rem}.merge-main{padding:.75rem}.merge-summary-card{padding:1rem}.back-btn{min-height:44px;padding:.5rem 1rem}}@media(hover:none)and (pointer:coarse){.back-btn{min-height:44px}.back-btn:active{transform:scale(.97)}.merge-container canvas{touch-action:none}}.blueprint-designer{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;flex-direction:column}.bp-header{background:#0f172af2;border-bottom:1px solid rgba(255,255,255,.1);padding:.75rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.bp-header-left{display:flex;align-items:center;gap:1.25rem}.bp-header-left h1{color:#f1f5f9;font-size:1.15rem;font-weight:600;display:flex;align-items:center;gap:.5rem;margin:0}.bp-header-left h1 svg{color:#34d399}.bp-header-right{display:flex;align-items:center;gap:.75rem}.bp-body{flex:1;display:flex;overflow:hidden}.bp-toolbar{width:60px;background:#0f172acc;border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;align-items:center;padding:.75rem 0;gap:.25rem}.bp-tool-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;background:transparent;color:#94a3b8;cursor:pointer;transition:all .15s;font-size:.65rem;flex-direction:column;gap:2px}.bp-tool-btn:hover{background:#ffffff1a;color:#e2e8f0}.bp-tool-btn.active{background:#3b82f640;border-color:#3b82f6;color:#93c5fd}.bp-tool-btn.danger{color:#f87171}.bp-tool-btn.danger:hover{background:#ef444433}.bp-tool-sep{width:36px;height:1px;background:#ffffff1a;margin:.5rem 0}.bp-canvas-area{flex:1;overflow:auto;position:relative;background:#1a1a2e}.bp-canvas{cursor:crosshair;display:block}.bp-canvas.select-mode{cursor:default}.bp-canvas.text-mode{cursor:text}.bp-canvas.pen-mode,.bp-canvas.area-select-mode{cursor:crosshair}.bp-properties{width:240px;background:#0f172acc;border-left:1px solid rgba(255,255,255,.1);padding:1rem;overflow-y:auto}.bp-prop-title{color:#38bdf8;font-size:.85rem;font-weight:600;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.bp-prop-group{margin-bottom:.75rem}.bp-prop-group label{display:block;color:#94a3b8;font-size:.75rem;margin-bottom:.25rem}.bp-prop-group input{width:100%;padding:.4rem .5rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:6px;color:#e2e8f0;font-size:.8rem}.bp-prop-group input:focus{outline:none;border-color:#3b82f6}.bp-prop-row{display:flex;gap:.5rem}.bp-prop-row .bp-prop-group{flex:1}.bp-prop-group .fraction-input{gap:.25rem}.bp-prop-group .fraction-whole{width:45px!important;padding:.35rem .2rem!important;font-size:.8rem!important}.bp-prop-group .fraction-num,.bp-prop-group .fraction-den{width:30px!important;padding:.3rem .1rem!important;font-size:.75rem!important}.bp-prop-group .fraction-slash{font-size:.9rem}.bp-shapes-list{margin-top:1rem}.bp-shape-item{display:flex;justify-content:space-between;align-items:center;padding:.4rem .5rem;border-radius:6px;color:#94a3b8;font-size:.75rem;cursor:pointer;transition:all .15s}.bp-shape-item:hover{background:#ffffff0d}.bp-shape-item.selected{background:#3b82f633;color:#93c5fd}.bp-shape-item button{background:none;border:none;color:#f87171;cursor:pointer;padding:2px;opacity:.6}.bp-shape-item button:hover{opacity:1}.bp-export-bar{background:#0f172af2;border-top:1px solid rgba(255,255,255,.1);padding:.6rem 1.5rem;display:flex;justify-content:space-between;align-items:center}.bp-export-bar .bp-info{color:#64748b;font-size:.75rem}.bp-scale-controls{display:flex;align-items:center;gap:.5rem;color:#94a3b8;font-size:.75rem}.bp-scale-controls input{width:50px;padding:.25rem .4rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#e2e8f0;font-size:.75rem;text-align:center}.bp-grid-info{display:flex;align-items:center;gap:.5rem;color:#64748b;font-size:.7rem}.bp-mode-indicator{position:absolute;top:10px;left:50%;transform:translate(-50%);background:#3b82f6e6;color:#fff;padding:.4rem 1rem;border-radius:20px;font-size:.8rem;font-weight:500;z-index:10;pointer-events:none}.bp-mode-indicator.polygon{background:#a855f7e6}@media(max-width:1024px){.bp-header{padding:.5rem 1rem;flex-wrap:wrap;gap:.5rem}.bp-header-left h1{font-size:1rem}.bp-body{flex-direction:column}.bp-toolbar{width:100%;flex-direction:row;flex-wrap:wrap;justify-content:center;padding:.5rem;gap:.25rem;border-right:none;border-bottom:1px solid rgba(255,255,255,.1)}.bp-tool-btn{width:48px;height:48px}.bp-tool-sep{width:1px;height:36px;margin:0 .25rem}.bp-canvas-area{flex:1;min-height:50vh;-webkit-overflow-scrolling:touch}.bp-canvas{touch-action:none}.bp-properties{width:100%;max-height:30vh;border-left:none;border-top:1px solid rgba(255,255,255,.1);padding:.75rem}.bp-shapes-list{max-height:120px;overflow-y:auto;-webkit-overflow-scrolling:touch}.bp-export-bar{flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem}.bp-export-bar .bp-info{width:100%;text-align:center;font-size:.7rem}.bp-mode-indicator{font-size:.7rem;padding:.3rem .75rem;max-width:90%}}@media(max-width:768px){.bp-header{padding:.4rem .75rem}.bp-header-left{gap:.75rem}.bp-header-left h1{font-size:.9rem}.bp-tool-btn{width:44px;height:44px;font-size:.6rem}.bp-tool-btn span{display:none}.bp-properties{padding:.5rem}.bp-prop-title{font-size:.8rem;margin-bottom:.5rem;padding-bottom:.4rem}.bp-prop-group input{font-size:16px;padding:.5rem}.bp-shape-item{padding:.5rem;min-height:44px}.bp-export-bar{flex-direction:column;align-items:stretch}.bp-export-bar>div{justify-content:center}}@media(hover:none)and (pointer:coarse){.bp-tool-btn{min-width:48px;min-height:48px}.bp-tool-btn:active{transform:scale(.95);background:#3b82f64d}.bp-shape-item{min-height:48px}.bp-shape-item button{min-width:36px;min-height:36px;padding:6px}.bp-toolbar>div[style*="position: absolute"]{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}}@media(max-width:1024px)and (orientation:landscape){.bp-body{flex-direction:row}.bp-toolbar{width:60px;flex-direction:column;flex-wrap:nowrap;overflow-y:auto;border-right:1px solid rgba(255,255,255,.1);border-bottom:none}.bp-tool-sep{width:36px;height:1px;margin:.25rem 0}.bp-properties{width:200px;max-height:none;border-top:none;border-left:1px solid rgba(255,255,255,.1)}.bp-canvas-area{min-height:auto}}
