.layout-selector{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e0e0e0;border-radius:12px;margin:var(--space-6) 0;padding:var(--space-5)}.layout-selector-header{align-items:center;background:#fff;border-radius:var(--radius-lg);display:flex;justify-content:space-between;margin-bottom:var(--space-4);padding:var(--space-4);transition:all .3s ease}.layout-selector-header.clickable:hover{background:var(--bg-secondary);box-shadow:0 2px 8px #00000014}.layout-selector-header h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-1) 0}.layout-selector-header p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.layout-options{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:var(--space-4)}.layout-option{background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:var(--space-4);position:relative;transition:all .3s ease}.layout-option:hover{border-color:#fcd116;box-shadow:0 4px 12px #fcd11633;transform:translateY(-2px)}.layout-option.selected{background:linear-gradient(135deg,#fffbeb,#fff);border-color:#fcd116;box-shadow:0 4px 16px #fcd1164d}.layout-option-header{align-items:center;display:flex;gap:var(--space-3);margin-bottom:var(--space-3)}.layout-icon{align-items:center;background:linear-gradient(135deg,#fcd116,#f8a100);border-radius:10px;color:#1a1a1a;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.layout-option.selected .layout-icon{background:linear-gradient(135deg,#f8a100,#e08900);box-shadow:0 4px 12px #f8a10066}.layout-title{align-items:center;display:flex;flex:1 1;gap:var(--space-2);justify-content:space-between}.layout-title h4{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin:0}.selected-badge{background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;color:#fff;font-size:var(--text-xs);font-weight:600;padding:4px 12px;white-space:nowrap}.layout-description{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5;margin-bottom:var(--space-3)}.layout-characteristics{list-style:none;margin:0 0 var(--space-3) 0;padding:0}.layout-characteristics li{align-items:center;color:var(--text-tertiary);display:flex;font-size:var(--text-sm);gap:8px;padding:4px 0}.layout-characteristics .bullet{color:#fcd116;font-size:16px;font-weight:700}.layout-best-for{align-items:center;border-top:1px solid #e5e7eb;display:flex;font-size:var(--text-sm);gap:var(--space-2);padding-top:var(--space-3)}.layout-best-for .label{color:var(--text-tertiary);font-weight:500}.layout-best-for .value{color:var(--text-primary);font-weight:600}.layout-selector-footer{border-top:2px dashed #e0e0e0;padding-top:var(--space-4);text-align:center}.layout-selector-footer p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}@media (max-width:768px){.layout-selector{padding:var(--space-4)}.layout-options{grid-template-columns:1fr}.layout-option{padding:var(--space-3)}.layout-option-header{align-items:flex-start;flex-direction:column}.layout-icon{height:40px;width:40px}.layout-title{align-items:flex-start;flex-direction:column;width:100%}.selected-badge{align-self:flex-start}}.layout-option:focus{outline:3px solid #fcd116;outline-offset:2px}.layout-option:focus:not(:focus-visible){outline:none}.room-size-sliders{background:#fff;border:2px solid #e0e0e0;border-radius:12px;margin:var(--space-6) 0;padding:var(--space-5)}.sliders-header{align-items:center;background:var(--bg-secondary);border-radius:var(--radius-lg);display:flex;justify-content:space-between;margin-bottom:var(--space-4);padding:var(--space-4);transition:all .3s ease}.sliders-header.clickable:hover{background:var(--border-medium);box-shadow:0 2px 8px #00000014}.sliders-header h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-1) 0}.sliders-header p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.toggle-button{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:var(--space-2);transition:all .2s ease}.toggle-button:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:scale(1.1)}.sliders-grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5)}.slider-item{background:linear-gradient(135deg,#f9fafb,#fff);border:1px solid #e5e7eb;border-radius:10px;padding:var(--space-4);transition:all .2s ease}.slider-item:hover{border-color:#fcd116;box-shadow:0 2px 8px #fcd1161a}.slider-header{gap:var(--space-3);margin-bottom:var(--space-3)}.slider-header,.slider-icon{align-items:center;display:flex}.slider-icon{background:linear-gradient(135deg,#fcd116,#f8a100);border-radius:8px;color:#1a1a1a;flex-shrink:0;height:36px;justify-content:center;width:36px}.slider-header label{color:var(--text-primary);cursor:pointer;flex:1 1;font-size:var(--text-base);font-weight:600}.slider-value{color:#f8a100;font-size:var(--text-lg);font-weight:700;min-width:60px;text-align:right}.slider{appearance:none;background:linear-gradient(90deg,#e5e7eb 0,#fcd116 50%,#e5e7eb);border-radius:5px;cursor:pointer;height:8px;margin:var(--space-2) 0;outline:none;width:100%}.slider:disabled{cursor:not-allowed;opacity:.5}.slider::-webkit-slider-thumb{appearance:none;background:linear-gradient(135deg,#fcd116,#f8a100);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #fcd11666;cursor:pointer;height:24px;-webkit-transition:all .2s ease;transition:all .2s ease;width:24px}.slider::-webkit-slider-thumb:hover{box-shadow:0 4px 12px #fcd11699;transform:scale(1.1)}.slider::-webkit-slider-thumb:active{transform:scale(1.05)}.slider::-moz-range-thumb{background:linear-gradient(135deg,#fcd116,#f8a100);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #fcd11666;cursor:pointer;height:24px;-moz-transition:all .2s ease;transition:all .2s ease;width:24px}.slider::-moz-range-thumb:hover{box-shadow:0 4px 12px #fcd11699;transform:scale(1.1)}.slider::-moz-range-track{background:linear-gradient(90deg,#e5e7eb 0,#fcd116 50%,#e5e7eb);border-radius:5px;height:8px;width:100%}.slider-labels{color:var(--text-tertiary);display:flex;font-size:var(--text-xs);justify-content:space-between;margin-top:var(--space-2)}.label-ideal{color:#f8a100;font-weight:600}.size-indicator{display:flex;justify-content:center;margin-top:var(--space-2)}.size-indicator span{border-radius:12px;font-size:var(--text-xs);font-weight:600;padding:4px 12px}.indicator-small{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1e40af}.indicator-ideal{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.indicator-large{background:linear-gradient(135deg,#fed7aa,#fdba74);color:#92400e}.sliders-footer{border-top:2px dashed #e0e0e0;margin-top:var(--space-5);padding-top:var(--space-4);text-align:center}.sliders-footer p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}@media (max-width:768px){.room-size-sliders{padding:var(--space-4)}.slider-header{flex-wrap:wrap}.slider-value{margin-top:var(--space-2);text-align:left;width:100%}.slider-labels{flex-direction:column;gap:4px}}@media (prefers-color-scheme:dark){.room-size-sliders{background:#1a1a1a;border-color:#333}.slider-item{background:linear-gradient(135deg,#2a2a2a,#1f1f1f);border-color:#333}.slider{background:linear-gradient(90deg,#333 0,#fcd116 50%,#333)}.slider::-moz-range-thumb,.slider::-webkit-slider-thumb{border-color:#1a1a1a}}.upgrade-prompt-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:var(--space-4);position:fixed;right:0;top:0;z-index:9999}.upgrade-prompt-modal{animation:slideUp .3s ease;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:520px;padding:var(--space-8);position:relative;text-align:center;width:100%}.modal-close-btn{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:var(--space-4);top:var(--space-4);transition:all .2s ease;width:36px}.modal-close-btn:hover{background:#e5e7eb;color:#1f2937;transform:rotate(90deg)}.upgrade-icon{align-items:center;animation:bounce 2s infinite;background:linear-gradient(135deg,#fcd116,#f8a100);border-radius:50%;box-shadow:0 8px 24px #fcd1164d;color:#1a1a1a;display:flex;height:96px;justify-content:center;margin:0 auto var(--space-5);width:96px}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.upgrade-prompt-modal h2{color:var(--text-primary);font-size:var(--text-3xl);font-weight:700;margin:0 0 var(--space-2) 0}.upgrade-subtitle{color:var(--text-secondary);font-size:var(--text-lg);margin:0 0 var(--space-5) 0}.upgrade-subtitle strong{color:#8b5cf6;font-weight:700}.upgrade-description{margin-bottom:var(--space-5)}.upgrade-description p{color:var(--text-secondary);font-size:var(--text-base);line-height:1.6;margin:0}.upgrade-features{list-style:none;margin:0 0 var(--space-6) 0;padding:0;text-align:left}.upgrade-features li{align-items:flex-start;background:linear-gradient(135deg,#f9fafb,#fff);border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:var(--space-3);margin-bottom:var(--space-2);padding:var(--space-3)}.upgrade-features li svg{color:#10b981;flex-shrink:0;margin-top:2px}.upgrade-features li span{color:var(--text-primary);font-size:var(--text-sm);font-weight:500;line-height:1.5}.upgrade-pricing{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e0e0e0;border-radius:12px;margin-bottom:var(--space-6);padding:var(--space-4)}.price-tag{align-items:center;display:flex;flex-direction:column;gap:var(--space-2)}.price-label{color:#8b5cf6;font-size:var(--text-sm);font-weight:600;letter-spacing:.5px;text-transform:uppercase}.price-amount{align-items:baseline;display:flex;gap:4px}.currency{color:var(--text-secondary);font-size:var(--text-lg);font-weight:600}.amount{color:var(--text-primary);font-size:48px;font-weight:700;line-height:1}.period{color:var(--text-secondary);font-size:var(--text-base);font-weight:600}.upgrade-actions{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-4)}.upgrade-actions button{align-items:center;border:none;border-radius:12px;cursor:pointer;display:flex;font-family:inherit;font-size:var(--text-base);font-weight:700;gap:var(--space-2);justify-content:center;padding:var(--space-4);transition:all .3s ease}.btn-trial{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 4px 12px #8b5cf64d;color:#fff}.btn-trial:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 6px 16px #8b5cf666;transform:translateY(-2px)}.btn-upgrade-now{background:linear-gradient(135deg,#fcd116,#f8a100);box-shadow:0 4px 12px #fcd1164d;color:#1a1a1a}.btn-upgrade-now:hover{background:linear-gradient(135deg,#f8a100,#e08900);box-shadow:0 6px 16px #fcd11666;transform:translateY(-2px)}.upgrade-footer{color:var(--text-tertiary);font-size:var(--text-xs);margin:0}@media (max-width:640px){.upgrade-prompt-modal{max-width:100%;padding:var(--space-6)}.upgrade-icon{height:80px;width:80px}.upgrade-icon svg{height:40px;width:40px}.upgrade-prompt-modal h2{font-size:var(--text-2xl)}.amount{font-size:36px}.upgrade-actions button{font-size:var(--text-sm)}}.upgrade-prompt-overlay{animation:fadeIn .2s ease}.upgrade-prompt-modal{animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}.floor-plan-actions{align-items:center;background:linear-gradient(135deg,#f8f9fa,#fff);border:2px dashed #e0e0e0;border-radius:12px;display:flex;gap:var(--space-4);justify-content:center;margin:var(--space-5) 0;padding:var(--space-4)}.btn-export-svg,.btn-regenerate{align-items:center;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;font-family:inherit;font-size:var(--text-base);font-weight:600;gap:var(--space-2);padding:var(--space-3) var(--space-5);transition:all .3s ease}.btn-regenerate{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 8px #10b9814d;color:#fff}.btn-regenerate:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166;transform:translateY(-2px)}.btn-regenerate:active{transform:translateY(0)}.btn-export-svg{background:#fff;border-color:#8b5cf6;color:#8b5cf6}.btn-export-svg:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 4px 12px #8b5cf64d;color:#fff;transform:translateY(-2px)}.btn-export-svg:active{transform:translateY(0)}.btn-advanced-editor,.btn-advanced-editor-locked{align-items:center;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;font-family:inherit;font-size:var(--text-base);font-weight:600;gap:var(--space-2);padding:var(--space-3) var(--space-5);position:relative;transition:all .3s ease}.btn-advanced-editor{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 2px 8px #8b5cf64d;color:#fff}.btn-advanced-editor:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 12px #8b5cf666;transform:translateY(-2px)}.btn-advanced-editor-locked{animation:pulse 2s infinite;background:linear-gradient(135deg,#fcd116,#f8a100);box-shadow:0 2px 8px #fcd1164d;color:#1a1a1a}.btn-advanced-editor-locked:hover{animation:none;background:linear-gradient(135deg,#f8a100,#e08900);box-shadow:0 4px 12px #fcd11666;transform:translateY(-2px)}@keyframes pulse{0%,to{box-shadow:0 2px 8px #fcd1164d}50%{box-shadow:0 4px 16px #fcd11680}}@keyframes ai-pulse{0%,to{box-shadow:0 2px 8px #667eea4d;transform:scale(1)}50%{box-shadow:0 4px 16px #667eea80;transform:scale(1.05)}}.title-badges{align-items:center;display:flex;gap:8px}.ai-badge{align-items:center;display:inline-flex;gap:4px}.layout-badge{background:linear-gradient(135deg,#fcd116,#f8a100);border-radius:12px;color:#1a1a1a;font-size:var(--text-sm);font-weight:600;padding:4px 12px}.floor-plan-preview{margin:var(--space-4) 0}.floor-preview-container{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e0e0e0;border-radius:16px;box-shadow:0 4px 12px #0000000d;margin-bottom:var(--space-6);padding:var(--space-4)}.floor-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:var(--text-primary);font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-4) 0;text-align:center}.floor-plan-svg-container{-webkit-overflow-scrolling:touch;background:#f8f9fa;border-radius:8px;max-width:100%;overflow:auto;padding:var(--space-2);touch-action:pan-x pan-y}.floor-plan-preview-card{background:linear-gradient(135deg,#f8f9fa,#fff);border:2px solid #e0e0e0;border-radius:16px;box-shadow:0 4px 12px #0000000d;margin:var(--space-4) 0;padding:var(--space-6)}.preview-content{gap:var(--space-6)}.preview-content,.preview-icon{align-items:center;display:flex}.preview-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 12px #667eea4d;color:#fff;justify-content:center;padding:var(--space-4)}.preview-text h4{color:var(--text-primary);font-size:var(--text-xl);font-weight:700;margin:0 0 var(--space-2) 0}.preview-text p{color:var(--text-secondary);font-size:var(--text-base);line-height:1.5;margin:0 0 var(--space-3) 0}.preview-features{display:flex;flex-wrap:wrap;gap:var(--space-2)}.preview-features span{background:linear-gradient(135deg,#e0f2fe,#b3e5fc);border-radius:8px;color:#0277bd;font-size:var(--text-sm);font-weight:600;padding:4px 8px}.multi-storey-info{margin:var(--space-4) 0}.info-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e9;border-radius:12px;box-shadow:0 4px 12px #0ea5e91a;padding:var(--space-5)}.info-card h4{font-size:var(--text-lg);font-weight:700}.info-card h4,.info-card p{color:#0c4a6e;margin:0 0 var(--space-3) 0}.info-card p{font-size:var(--text-base);line-height:1.5}.info-card ul{color:#0c4a6e;margin:0;padding-left:var(--space-4)}.info-card li{font-size:var(--text-sm);margin-bottom:var(--space-1)}.upgrade-prompt{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;box-shadow:0 4px 12px #f59e0b1a;margin:var(--space-4) 0;padding:var(--space-5)}.prompt-content{align-items:center;display:flex;gap:var(--space-4)}.prompt-content svg{color:#92400e;flex-shrink:0}.prompt-content h4{color:#92400e;font-size:var(--text-lg);font-weight:700;margin:0 0 var(--space-2) 0}.prompt-content p{color:#78350f;font-size:var(--text-base);line-height:1.5;margin:0 0 var(--space-3) 0}.btn-upgrade{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:8px;box-shadow:0 2px 8px #f59e0b4d;color:#fff;cursor:pointer;font-size:var(--text-sm);font-weight:600;padding:var(--space-2) var(--space-4);transition:all .3s ease}.btn-upgrade:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #f59e0b66;transform:translateY(-2px)}@media (max-width:768px){.floor-plan-actions{flex-direction:column}.btn-export-svg,.btn-regenerate{justify-content:center;width:100%}.preview-content{flex-direction:column;text-align:center}.preview-features{justify-content:center}.prompt-content{flex-direction:column;text-align:center}}.crv-overlay{-webkit-overflow-scrolling:touch;align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:16px;position:fixed;z-index:9999}.crv-modal{background:#fff;border-radius:14px;box-shadow:0 24px 80px #00000038;display:flex;flex-direction:column;font-size:14px;max-height:90vh;max-width:min(680px,100%);overflow:hidden;width:100%}.crv-header{background:linear-gradient(135deg,#0d9488,#0f5f56);border-radius:14px 14px 0 0;color:#fff;flex-shrink:0;gap:12px;justify-content:space-between;padding:16px 20px}.crv-header,.crv-header-left{align-items:flex-start;display:flex}.crv-header-left{gap:10px}.crv-header h2{font-size:16px;font-weight:700;line-height:1.3;margin:0}.crv-subtitle{font-size:11px;font-weight:400;margin:2px 0 0;opacity:.8}.crv-close{align-items:center;background:#ffffff2e;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:6px;transition:background .15s}.crv-close:hover{background:#ffffff4d}.crv-body{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;gap:20px;overflow-y:auto;padding:20px}.crv-status-card{align-items:center;border-radius:10px;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:16px 20px}.crv-status-card.compliant{background:linear-gradient(135deg,#dcfce7,#d1fae5);border:1px solid #6ee7b7}.crv-status-card.non-compliant{background:linear-gradient(135deg,#fee2e2,#fecaca);border:1px solid #fca5a5}.crv-status-left{align-items:center;display:flex;gap:12px}.crv-status-icon{flex-shrink:0}.crv-status-card.compliant .crv-status-icon{color:#059669}.crv-status-card.non-compliant .crv-status-icon{color:#dc2626}.crv-status-label{display:block;font-size:15px;font-weight:700;letter-spacing:.04em}.crv-status-card.compliant .crv-status-label{color:#065f46}.crv-status-card.non-compliant .crv-status-label{color:#991b1b}.crv-status-sub{color:#6b7280;display:block;font-size:12px;margin-top:2px}.crv-score{align-items:center;display:flex;flex-direction:column;gap:4px}.crv-score-ring{height:52px;position:relative;width:52px}.crv-ring-svg{height:52px;transform:rotate(-90deg);width:52px}.crv-ring-bg{fill:none;stroke:#e5e7eb;stroke-width:3}.crv-ring-fill{fill:none;stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .6s ease}.crv-status-card.compliant .crv-ring-fill{stroke:#059669}.crv-status-card.non-compliant .crv-ring-fill{stroke:#dc2626}.crv-ring-text{align-items:center;color:#1f2937;display:flex;font-size:12px;font-weight:700;inset:0;justify-content:center;position:absolute}.crv-score-label{color:#6b7280;font-size:10px;white-space:nowrap}.crv-section{display:flex;flex-direction:column;gap:8px}.crv-section-heading{align-items:center;border-bottom:1px solid #e5e7eb;color:#1f2937;display:flex;font-size:13px;font-weight:600;gap:6px;letter-spacing:.06em;margin:0;padding-bottom:6px;text-transform:uppercase}.crv-section-heading.danger{border-bottom-color:#fecaca;color:#b91c1c}.crv-summary-grid{grid-gap:6px 12px;display:grid;gap:6px 12px;grid-template-columns:1fr 1fr}.crv-summary-item{align-items:baseline;background:#f8fafc;border-radius:6px;display:flex;font-size:12px;justify-content:space-between;padding:5px 8px}.crv-summary-label{color:#6b7280;font-weight:500;margin-right:8px;white-space:nowrap}.crv-summary-value{color:#111827;font-weight:600;text-align:right}.crv-room-list{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.crv-room-header,.crv-room-row{grid-gap:8px;align-items:center;display:grid;font-size:12px;gap:8px;grid-template-columns:2fr 1fr 1fr 1.5fr 1fr;padding:8px 12px}.crv-room-header{background:#f1f5f9;border-bottom:1px solid #e5e7eb;color:#475569;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.crv-room-row{border-bottom:1px solid #f1f5f9}.crv-room-row:last-child{border-bottom:none}.crv-room-row.pass{background:#fff}.crv-room-row.fail{background:#fff5f5}.crv-room-name{color:#1f2937;font-weight:500}.crv-room-area{color:#374151}.crv-room-min{color:#9ca3af}.crv-room-dim{color:#6b7280;font-size:11px}.crv-room-status{align-items:center;display:flex;font-size:11px;font-weight:600;gap:4px}.crv-room-row.pass .crv-room-status{color:#059669}.crv-room-row.fail .crv-room-status{color:#dc2626}.crv-violation-item{background:#fff5f5;border:1px solid #fecaca;border-radius:8px;padding:10px 12px}.crv-violation-title{align-items:center;display:flex;flex-wrap:wrap;font-size:13px;gap:6px;margin-bottom:4px}.crv-violation-body{color:#4b5563;font-size:12px;margin:0 0 4px}.crv-violation-fix{color:#059669;font-size:11px;font-style:italic;margin:0}.crv-code-badge{background:#f3f4f6;border-radius:4px;color:#6b7280;display:inline-block;flex-shrink:0;font-family:monospace;font-size:10px;padding:1px 5px}.crv-checklist-toggle{align-items:center;background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:600;gap:8px;padding:10px 14px;text-align:left;transition:background .15s;width:100%}.crv-checklist-toggle:hover{background:#f1f5f9}.crv-checklist-toggle svg:last-child{margin-left:auto}.crv-checklist{border:1px solid #e5e7eb;border-radius:8px;margin-top:4px;overflow:hidden}.crv-checklist-item{grid-gap:6px;align-items:start;border-bottom:1px solid #f1f5f9;display:grid;font-size:11px;gap:6px;grid-template-columns:20px 48px 1fr 48px;padding:6px 10px}.crv-checklist-item:last-child{border-bottom:none}.crv-checklist-item.pass{background:#f0fdf4}.crv-checklist-item.fail{background:#fff5f5}.crv-checklist-item.na{background:#fafafa}.crv-checklist-item.info{background:#fffbeb}.crv-checklist-icon{align-items:center;display:flex;padding-top:1px}.crv-checklist-id{color:#374151;font-size:10px;font-weight:700}.crv-checklist-req{color:#374151}.crv-checklist-ref{color:#9ca3af;font-family:monospace;font-size:10px;text-align:right}.crv-checklist-detail{color:#6b7280;font-size:10px;font-style:italic;grid-column:2/5}.crv-rec-group{border:1px solid;border-radius:8px;overflow:hidden}.crv-rec-group.must{border-color:#fca5a5}.crv-rec-group.should{border-color:#fde68a}.crv-rec-group-header{align-items:center;display:flex;font-size:12px;font-weight:700;gap:6px;letter-spacing:.03em;padding:8px 12px}.crv-rec-group.must .crv-rec-group-header{background:#fee2e2;color:#991b1b}.crv-rec-group.should .crv-rec-group-header{background:#fef3c7;color:#92400e}.crv-rec-item{background:#fff;border-top:1px solid;padding:10px 12px}.crv-rec-group.must .crv-rec-item{border-color:#fca5a5}.crv-rec-group.should .crv-rec-item{border-color:#fde68a}.crv-rec-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}.crv-rec-category{color:#374151;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.crv-rec-room{color:#6b7280;font-size:11px;font-style:italic}.crv-rec-issue{color:#374151;font-size:12px;margin:0 0 3px}.crv-rec-fix{color:#059669;font-size:11px;font-style:italic;margin:0}.crv-all-clear{background:#f0fdf4;border:1px solid #6ee7b7;border-radius:8px;color:#065f46;font-size:13px;font-weight:600;padding:12px 16px}.crv-all-clear,.crv-floor-row{align-items:center;display:flex;gap:8px}.crv-floor-row{background:#f8fafc;border-radius:6px;font-size:12px;justify-content:space-between;padding:8px 10px}.crv-legal-note{background:#fafafa;border:1px solid #f3f4f6;border-radius:6px;color:#9ca3af;font-size:10px;line-height:1.6;margin-top:4px;padding:10px 12px}.icon-pass{color:#059669}.icon-fail{color:#dc2626}.icon-info,.icon-warn{color:#d97706}.icon-na{color:#9ca3af;font-size:12px}.text-pass{color:#059669;font-weight:600}.text-fail{color:#dc2626;font-weight:600}.crv-footer{background:#f8fafc;border-radius:0 0 14px 14px;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;flex-wrap:wrap;gap:10px;justify-content:flex-end;padding:14px 20px}.crv-btn{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;font-weight:600;gap:6px;padding:8px 18px;transition:opacity .15s,background .15s}.crv-btn:disabled{cursor:not-allowed;opacity:.45}.crv-btn.secondary{background:#f1f5f9;border:1px solid #e2e8f0;color:#374151}.crv-btn.secondary:hover:not(:disabled){background:#e2e8f0}.crv-btn.outline{background:#0000;border:1px solid #0d9488;color:#0d9488}.crv-btn.outline:hover:not(:disabled){background:#f0fdfa}.crv-btn.primary{background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff}.crv-btn.primary:hover:not(:disabled){opacity:.9}@media (max-width:520px){.crv-overlay{align-items:flex-end;padding:0}.crv-modal{border-radius:14px 14px 0 0;max-height:96vh}.crv-summary-grid{grid-template-columns:1fr}.crv-room-header,.crv-room-row{grid-template-columns:2fr 1fr 1fr}.crv-room-header span:nth-child(3),.crv-room-header span:nth-child(4),.crv-room-row .crv-room-dim,.crv-room-row .crv-room-min{display:none}.crv-footer{flex-direction:column}.crv-btn{justify-content:center;width:100%}}.compliance-report-view-overlay{inset:0;position:fixed;z-index:9999}.react-tabs__tab-list{border-bottom:1px solid #aaa;margin:0 0 10px;padding:0}.react-tabs__tab{border:1px solid #0000;border-bottom:none;bottom:-1px;cursor:pointer;display:inline-block;list-style:none;padding:6px 12px;position:relative}.react-tabs__tab--selected,.react-tabs__tab:focus{border-color:#aaa;color:#1ca6fc;outline:none}.react-tabs__tab-panel{display:none}.react-tabs__tab-panel--selected{display:block}.planner-wrapper-modal{background:#fff;bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:9999}.planner-loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;height:100vh;justify-content:center}.planner-loading .spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:60px;margin-bottom:20px;width:60px}.planner-loading p{font-size:1.2rem;font-weight:600;margin:10px 0}.planner-loading .loading-subtitle{font-size:.9rem;font-weight:400;opacity:.9}.planner-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;flex-shrink:0;justify-content:space-between;padding:15px 20px}.header-info,.planner-header{align-items:center;display:flex}.header-info{gap:12px}.header-info h3{font-size:1.1rem;font-weight:600}.readonly-badge{align-items:center;background:#fff3;border-radius:12px;display:flex;font-size:.85rem;gap:6px;padding:4px 12px}.header-actions{gap:10px}.header-actions button{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.header-actions button:hover:not(:disabled){background:#ffffff4d;transform:translateY(-1px)}.header-actions button:disabled{cursor:not-allowed;opacity:.5}.btn-save{background:#4caf50e6!important}.btn-save:hover:not(:disabled){background:#4caf50!important}.btn-close{background:#f44336e6!important}.btn-close:hover{background:#f44336!important}.planner-content{background:#f5f5f5;flex:1 1;overflow:hidden;position:relative}.planner-footer{align-items:center;background:#fff;border-top:1px solid #e0e0e0;display:flex;flex-shrink:0;justify-content:center;padding:12px 20px}.upgrade-prompt{align-items:center;background:linear-gradient(135deg,gold,#ffed4e);border-radius:8px;color:#333;display:flex;gap:15px;padding:10px 20px}.upgrade-prompt svg{color:#ff9800;flex-shrink:0}.upgrade-prompt strong{display:block;font-size:1rem;margin-bottom:2px}.upgrade-prompt p{font-size:.85rem;margin:0;opacity:.9}.editor-info{align-items:center;color:#666;display:flex;font-size:.9rem;gap:12px}.editor-info span:first-child{color:#4caf50;font-weight:600}@media (max-width:768px){.planner-header{padding:10px 15px}.header-info h3{font-size:.95rem}.header-actions{gap:6px}.header-actions button{font-size:.85rem;padding:6px 12px}.header-actions button span{display:none}.planner-footer{padding:10px 15px}.editor-info{flex-wrap:wrap;font-size:.8rem;gap:8px}.upgrade-prompt{flex-direction:column;padding:15px;text-align:center}}.planner-content [class*=react-planner]{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.ghana-code-compliant{border:2px solid #4caf50}.ghana-code-violation{border:2px solid #f44336}.planner-content [class*=toolbar]{background:#fff;border-bottom:1px solid #e0e0e0}.planner-content [class*=sidebar]{background:#fafafa;border-left:1px solid #e0e0e0}.compliance-checklist-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:10000}.compliance-checklist-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-height:90vh;max-width:900px;overflow-y:auto;width:100%}.compliance-checklist-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #e0e0e0;border-radius:12px 12px 0 0;color:#fff;display:flex;justify-content:space-between;padding:24px}.compliance-checklist-header h2{align-items:center;display:flex;font-size:24px;gap:12px;margin:0}.compliance-checklist-header .icon{font-size:28px}.close-button{align-items:center;background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;padding:0;transition:background .2s;width:32px}.close-button:hover{background:#fff3}.compliance-summary{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:24px}.summary-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px}.status-badge{border-radius:20px;display:inline-block;font-size:14px;margin-bottom:16px;padding:8px 16px}.summary-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.stat{text-align:center}.stat-value{color:#667eea;display:block;font-size:32px;font-weight:700;line-height:1}.stat-label{color:#666;display:block;font-size:14px;margin-top:8px}.compliance-checklist-section,.recommendations-section,.room-summary-section,.violations-section,.warnings-section{border-bottom:1px solid #e0e0e0;padding:24px}.compliance-checklist-section h3,.recommendations-section h3,.room-summary-section h3,.violations-section h3,.warnings-section h3{align-items:center;color:#333;display:flex;font-size:20px;gap:8px;margin:0 0 16px}.icon.error{color:#ef4444}.icon.warning{color:#f59e0b}.violations-list,.warnings-list{display:flex;flex-direction:column;gap:12px}.violation-item,.warning-item{background:#fff5f5;border-left:4px solid #ef4444;border-radius:4px;padding:16px}.warning-item{background:#fffbeb;border-left-color:#f59e0b}.violation-header,.warning-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.room-name{color:#333;font-weight:700}.code-ref{background:#0000000d;border-radius:4px;color:#666;font-size:12px;padding:4px 8px}.violation-message,.warning-message{color:#666;margin-bottom:8px}.violation-details{display:flex;font-size:14px;gap:16px;margin-top:8px}.violation-details .current{color:#ef4444;font-weight:500}.violation-details .required{color:#10b981;font-weight:500}.room-summary-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.room-summary-item{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;padding:16px;transition:transform .2s}.room-summary-item:hover{transform:translateY(-2px)}.room-summary-item.compliant{background:#f0fdf4;border-color:#10b981}.room-summary-item.non-compliant{background:#fef2f2;border-color:#ef4444}.room-summary-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.room-type{color:#333;font-weight:700}.status-icon{font-size:20px}.status-icon.pass{color:#10b981}.status-icon.fail{color:#ef4444}.room-summary-area{color:#667eea;font-size:24px;font-weight:700;margin-bottom:4px}.room-summary-requirement{color:#666;font-size:14px}.recommendations-list{list-style:none;margin:0;padding:0}.recommendations-list li{background:#eff6ff;border-left:3px solid #3b82f6;border-radius:4px;margin-bottom:8px;padding:12px}.recommendations-list li:before{content:"💡 ";margin-right:8px}.checklist-items{display:flex;flex-direction:column;gap:8px}.checklist-item{align-items:flex-start;background:#f9fafb;border-radius:4px;display:flex;gap:12px;padding:12px;transition:background .2s}.checklist-item:hover{background:#f3f4f6}.checklist-checkbox{flex-shrink:0;font-size:20px}.checklist-content{flex:1 1}.checklist-requirement{color:#333;font-weight:500;margin-bottom:4px}.checklist-meta{display:flex;font-size:12px;gap:12px}.checklist-code{background:#0000000d;border-radius:3px;color:#666;padding:2px 6px}.checklist-priority{border-radius:3px;font-weight:700;padding:2px 6px}.checklist-priority.must{background:#fecaca;color:#991b1b}.checklist-priority.should{background:#fed7aa;color:#9a3412}.checklist-priority.recommended{background:#bfdbfe;color:#1e40af}.compliance-footer{background:#f9fafb;border-radius:0 0 12px 12px;padding:24px}.footer-info{margin-bottom:16px}.footer-info p{color:#666;font-size:14px;margin:8px 0}.footer-actions{display:flex;gap:12px;justify-content:flex-end}.action-button{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.action-button.primary{background:#667eea;color:#fff}.action-button.primary:hover{background:#5568d3;box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.action-button.secondary{background:#fff;border:2px solid #667eea;color:#667eea}.action-button.secondary:hover{background:#f3f4f6}@media print{.compliance-checklist-overlay{background:#fff;position:static}.compliance-checklist-modal{box-shadow:none;max-height:none;max-width:none}.close-button,.footer-actions{display:none}.compliance-checklist-header{background:#667eea;print-color-adjust:exact;-webkit-print-color-adjust:exact}}@media (max-width:768px){.compliance-checklist-modal{border-radius:0;margin:0;max-height:100vh;max-width:100%}.compliance-checklist-header h2{font-size:18px}.summary-stats{grid-template-columns:repeat(2,1fr)}.room-summary-grid{grid-template-columns:1fr}.footer-actions{flex-direction:column}.action-button{width:100%}}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.modal-header h3{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.btn-close-modal{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;padding:8px;transition:all .2s ease}.btn-close-modal:hover{background:#f3f4f6;color:#1f2937}.modal-body{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:8px}.form-group input{border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .2s ease;width:100%}.form-group input:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.form-group input.input-error{border-color:#ef4444}.form-group input:disabled{background:#f3f4f6;cursor:not-allowed}.error-message{color:#ef4444;font-size:.875rem;margin-bottom:0;margin-top:8px}.input-hint{color:#6b7280;font-size:.75rem;margin-bottom:0;margin-top:6px}.project-info-box{background:linear-gradient(135deg,#8b5cf60d,#10b9810d);border:1px solid #8b5cf633;border-radius:8px;margin-top:20px;padding:16px}.info-title{color:#1f2937;font-size:.875rem;font-weight:600;margin:0 0 12px}.info-list{list-style:none;margin:0;padding-left:0}.info-list li{color:#4b5563;font-size:.875rem;padding:6px 0}.info-note{border-top:1px solid #8b5cf61a;color:#6b7280;font-size:.75rem;font-style:italic;margin:12px 0 0;padding-top:12px}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.btn-cancel{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s ease}.btn-cancel:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.btn-cancel:disabled{cursor:not-allowed;opacity:.5}.btn-save-primary{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-save-primary:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 12px #8b5cf64d;transform:translateY(-1px)}.btn-save-primary:disabled{cursor:not-allowed;opacity:.5;transform:none}.spinner-small{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;width:14px}@media (max-width:640px){.modal-content{margin:20px;width:95%}.modal-header h3{font-size:1.25rem}.modal-body{padding:16px}.modal-footer{flex-direction:column}.btn-cancel,.btn-save-primary{justify-content:center;width:100%}}.llm-design-agent{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:0;box-shadow:none;display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:100vw;z-index:9999}.diagram-chat-layout{flex:1 1;min-height:0;overflow:hidden}.llm-diagram-panel{background:#fff;border-right:1px solid #e2e8f0;border-right:1px solid var(--border-medium,#e2e8f0);display:flex;flex:1 1 55%;flex-direction:column;min-width:0}.llm-chat-panel{display:flex;flex:0 0 400px;flex-direction:column;min-width:320px;overflow:hidden}.value-summary-card{animation:slideInUp .5s ease-out;background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #8b5cf633;border-radius:20px;box-shadow:0 20px 60px #00000026;margin:20px;padding:32px}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.value-summary-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;gap:16px;margin-bottom:24px;padding-bottom:20px}.value-summary-icon{align-items:center;border-radius:16px;box-shadow:0 8px 24px #8b5cf64d;color:#fff;display:flex;height:64px;justify-content:center;width:64px}.value-summary-icon,.value-summary-title h3{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.value-summary-title h3{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:28px;font-weight:700;margin:0}.value-summary-title p{color:#6b7280;font-size:16px;margin:4px 0 0}.value-summary-cost{background:linear-gradient(135deg,#f8fafc,#fff);border:2px solid #e5e7eb;border-radius:16px;margin-bottom:24px;padding:32px;text-align:center}.cost-label{color:#6b7280;font-size:14px;font-weight:600;letter-spacing:.05em;margin-bottom:12px;text-transform:uppercase}.cost-amount{align-items:baseline;display:flex;gap:8px;justify-content:center;margin-bottom:8px}.cost-amount svg{color:#10b981}.cost-amount span:first-of-type{color:#1f2937;font-size:48px;font-weight:800;line-height:1}.cost-currency{color:#6b7280;font-size:24px;font-weight:600;margin-left:4px}.cost-note{color:#6b7280;font-size:14px;font-style:italic}.value-summary-features,.value-summary-specs{background:#f8fafc;border-radius:12px;margin-bottom:24px;padding:20px}.value-summary-features h4,.value-summary-specs h4{align-items:center;color:#1f2937;display:flex;font-size:18px;font-weight:700;gap:8px;margin:0 0 16px}.specs-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.spec-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;padding:12px}.spec-label{color:#6b7280;font-size:14px;font-weight:500}.spec-value{color:#1f2937;font-size:16px;font-weight:700}.features-list{display:flex;flex-wrap:wrap;gap:8px}.feature-badge{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:20px;box-shadow:0 4px 12px #8b5cf64d;color:#fff;font-size:14px;font-weight:600;padding:10px 16px;transition:transform .2s,box-shadow .2s}.feature-badge:hover{box-shadow:0 6px 16px #8b5cf666;transform:translateY(-2px)}.value-summary-compliance{background:#f0fdf4;border:2px solid #10b981;border-radius:12px;margin-bottom:24px;padding:16px}.value-summary-compliance .compliance-badge{align-items:center;display:flex;font-size:16px;font-weight:600;gap:12px}.value-summary-compliance .compliance-badge.compliant{color:#059669}.value-summary-compliance .compliance-badge.non-compliant{background:#fef2f2;border-color:#dc2626;color:#dc2626}.compliance-score{color:#6b7280;font-size:14px;font-weight:500;margin-left:auto}.value-summary-actions{display:flex;gap:12px;margin-top:24px}.btn-primary-large{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px;box-shadow:0 8px 24px #8b5cf666;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:18px;font-weight:700;gap:12px;justify-content:center;padding:16px 24px;transition:all .3s ease}.btn-primary-large:hover{box-shadow:0 12px 32px #8b5cf680;transform:translateY(-2px)}.btn-primary-large:active{transform:translateY(0)}.btn-secondary{background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#6b7280;cursor:pointer;font-size:16px;font-weight:600;padding:16px 24px;transition:all .2s}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.chat-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #fff3;display:flex;justify-content:space-between;padding:20px}.header-info h3{color:#2d3748;font-size:24px;font-weight:700;margin:0}.status-indicator{color:#10b981;font-size:13px;font-weight:600;margin-left:2px}.persona-avatar-container{margin-right:15px}.persona-avatar{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:2px solid #fff;border-radius:50%;box-shadow:0 4px 12px #8b5cf666;color:#fff;display:flex;font-size:20px;font-weight:800;height:44px;justify-content:center;width:44px}.header-text h3{color:#1e293b;font-size:18px;font-weight:700;margin:0}.credit-status{align-items:flex-end;color:#64748b;display:flex;flex-direction:column;font-size:12px}.credits-remaining{color:#10b981;font-weight:600}.credits-used{color:#64748b}.header-actions{align-items:center;display:flex;gap:12px}.btn-close,.btn-conversations,.btn-download,.btn-new-conversation,.btn-save,.btn-saved-plans,.btn-view-report{border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.btn-save{background:linear-gradient(135deg,#10b981,#059669)!important;color:#fff!important}.btn-save:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-download{background:linear-gradient(135deg,#3b82f6,#1d4ed8)!important;color:#fff!important}.btn-close{background:#ef4444!important;color:#fff!important}.btn-conversations{background:linear-gradient(135deg,#8b5cf6,#7c3aed)!important;color:#fff!important}.btn-saved-plans{background:linear-gradient(135deg,#f59e0b,#d97706)!important;color:#fff!important}.btn-new-conversation{background:linear-gradient(135deg,#06b6d4,#0891b2)!important;color:#fff!important}.btn-close:hover,.btn-conversations:hover,.btn-download:hover,.btn-new-conversation:hover,.btn-save:hover,.btn-saved-plans:hover,.btn-view-report:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.chat-messages{flex:1 1;gap:16px;overflow-y:auto;padding:20px}.chat-messages,.message{display:flex;flex-direction:column}.message{max-width:80%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:16px}.message.user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.message-time{color:#ffffffb3;font-size:12px;margin-top:4px;text-align:right}.message.assistant .message-time{text-align:left}.plan-preview{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border:2px solid #e2e8f0;border-radius:12px;margin-top:16px;padding:20px}.plan-preview h4{color:#2d3748;font-size:18px;font-weight:700;margin:0 0 16px}.plan-details{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.plan-details span{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:6px 12px}.furniture-preview{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b;border-radius:8px;margin:16px 0;padding:16px}.furniture-preview h5{color:#92400e;font-size:14px;font-weight:600;margin:0 0 8px}.furniture-stats{display:flex;flex-wrap:wrap;gap:12px}.furniture-stats span{background:#f59e0b33;border-radius:12px;color:#92400e;font-size:11px;font-weight:600;padding:4px 8px}.compliance-preview{border-left:4px solid;border-radius:8px;margin:16px 0;padding:16px}.compliance-preview.compliant{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-left-color:#10b981}.compliance-preview.non-compliant{background:linear-gradient(135deg,#fee2e2,#fecaca);border-left-color:#ef4444}.compliance-preview h5{font-size:14px;font-weight:600;margin:0 0 8px}.compliance-preview.compliant h5{color:#065f46}.compliance-preview.non-compliant h5{color:#991b1b}.compliance-status{align-items:center;display:flex;gap:12px;margin-bottom:8px}.status-badge{border-radius:12px;font-size:11px;font-weight:700;padding:4px 8px}.status-badge.compliant{background:#10b981;color:#fff}.status-badge.non-compliant{background:#ef4444;color:#fff}.compliance-score{font-size:12px;font-weight:600}.compliance-preview.compliant .compliance-score{color:#065f46}.compliance-preview.non-compliant .compliance-score{color:#991b1b}.violations-summary{margin-top:8px}.violation-count{background:#ef44441a;border-radius:12px;color:#991b1b;font-size:11px;font-weight:600;padding:4px 8px}.plan-actions{display:flex;flex-direction:column;gap:12px;margin-top:16px}.plan-options{display:flex;flex-wrap:wrap;gap:8px}.btn-costs,.btn-refine,.btn-view-empty,.btn-view-furnished{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s ease}.btn-refine{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.btn-view-furnished{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;flex:1 1}.btn-view-empty{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;flex:1 1}.btn-costs{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-view-furnished:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.btn-costs:hover,.btn-refine:hover,.btn-view-empty:hover,.btn-view-furnished:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.compliance-dashboard{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin:20px;padding:20px}.compliance-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.compliance-header h3{color:#2d3748;font-size:18px;font-weight:700;margin:0}.compliance-status{border-radius:20px;font-size:12px;font-weight:700;padding:8px 16px}.compliance-status.compliant{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.compliance-status.non-compliant{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.compliance-metrics{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:16px}.metric{display:flex;flex-direction:column;gap:4px}.metric .label{color:#64748b;font-size:12px;font-weight:600}.metric .value{color:#2d3748;font-size:16px;font-weight:700}.metric .value.error{color:#ef4444}.metric .value.warning{color:#f59e0b}.violations-details{margin-bottom:16px}.violations-details h4{color:#ef4444;font-size:14px;font-weight:600;margin:0 0 8px}.violations-details ul{margin:0;padding-left:16px}.violations-details li{color:#64748b;font-size:12px;margin-bottom:4px}.compliance-actions{display:flex;flex-wrap:wrap;gap:12px}.btn-primary,.btn-secondary{padding:10px 16px}.btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff}.btn-secondary{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.suggestion-chip:hover{background:#f8fafc!important;background:var(--bg-secondary,#f8fafc)!important;border-color:#8b5cf6!important;border-color:var(--primary,#8b5cf6)!important;box-shadow:0 4px 12px #8b5cf626!important;transform:translateY(-2px)}.suggestion-chip:active{transform:translateY(0)}.message-bubble-wrapper{animation:messageSlideIn .3s cubic-bezier(.2,.8,.2,1)}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-bubble-wrapper.assistant>div{background:#fff;border:1px solid #f1f5f9}.message-bubble-wrapper.user>div{background:linear-gradient(135deg,#8b5cf6,#6d28d9)!important}.floor-plan-chat-thinking-dots span{animation:dotFlashing 1s infinite alternate;background-color:#8b5cf6;background-color:var(--primary,#8b5cf6);border-radius:50%;display:inline-block;height:4px;margin:0 2px;width:4px}.floor-plan-chat-thinking-dots span:nth-child(2){animation-delay:.2s}.floor-plan-chat-thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes dotFlashing{0%{opacity:.2;transform:scale(.8)}to{opacity:1;transform:scale(1.2)}}.chat-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-top:1px solid #fff3;padding:20px}.input-container{align-items:flex-end;display:flex;gap:12px}.input-container textarea{background:#fff;border:2px solid #e2e8f0;border-radius:12px;flex:1 1;font-size:14px;outline:none;padding:12px 16px;resize:none;transition:all .2s ease}.input-container textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-send{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 20px;transition:all .2s ease}.btn-send:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-send:disabled{cursor:not-allowed;opacity:.6;transform:none}.input-suggestions{align-items:center;color:#64748b;display:flex;flex-wrap:wrap;font-size:12px;gap:8px;margin-top:12px}.input-suggestions button{background:#667eea1a;border:1px solid #667eea33;border-radius:12px;color:#667eea;cursor:pointer;font-size:11px;padding:4px 8px;transition:all .2s ease}.input-suggestions button:hover{background:#667eea33;transform:translateY(-1px)}.access-checking,.access-denied{align-items:center;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px;text-align:center}.access-checking h3,.access-denied h3{color:#2d3748;font-size:24px;font-weight:700;margin:0 0 16px}.access-checking p,.access-denied p{color:#64748b;font-size:16px;margin:0 0 24px}.upgrade-options{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.loading-spinner{margin-bottom:16px}.spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.typing-indicator{display:flex;gap:4px;margin-bottom:8px}.typing-indicator span{animation:typing 1.4s ease-in-out infinite;background:#667eea;border-radius:50%;height:8px;width:8px}.typing-indicator span:first-child{animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.error-indicator{color:#ef4444;font-size:16px;margin-left:8px}@media (max-width:900px){.diagram-chat-layout{flex-direction:column;overflow:hidden}.llm-diagram-panel{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-medium,#e2e8f0);border-right:none;min-height:0;overflow:hidden}.llm-chat-panel{min-height:0;min-width:0;overflow:hidden}}@media (max-width:768px){.llm-design-agent{border-radius:0;height:100vh;width:100vw}.chat-header{gap:8px;padding:12px 14px}.header-info{flex:1 1 auto;min-width:0}.header-info h3{font-size:16px;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-actions{flex-shrink:0;gap:8px}.chat-messages{padding:12px}.message{max-width:90%}.message-content{font-size:14px;padding:12px}.value-summary-card{margin:12px;padding:20px}.value-summary-icon{height:48px;width:48px}.value-summary-title h3{font-size:22px}.value-summary-title p{font-size:14px}.value-summary-cost{padding:20px}.cost-amount span:first-of-type{font-size:36px}.cost-currency{font-size:18px}.specs-grid{gap:8px;grid-template-columns:1fr}.spec-item{padding:10px}.features-list{gap:6px}.feature-badge{font-size:12px;padding:8px 12px}.value-summary-actions{flex-direction:column}.btn-primary-large{font-size:16px;padding:14px 20px}.btn-secondary{font-size:14px;padding:12px 20px}.plan-actions,.plan-options{flex-direction:column}.plan-options button{width:100%}.btn-costs,.btn-refine,.btn-view-empty,.btn-view-furnished{font-size:14px;padding:12px 16px}.compliance-metrics{gap:12px}.compliance-actions,.compliance-metrics{flex-direction:column}.compliance-dashboard{margin:12px;padding:16px}.plan-preview{padding:16px}.plan-preview h4{font-size:16px}.plan-details{gap:8px}.plan-details span{font-size:11px;padding:5px 10px}.chat-input{padding:12px}.input-container{flex-direction:column;gap:8px}.input-container textarea{font-size:14px;min-height:60px;padding:10px 12px}.btn-send{font-size:15px;padding:12px;width:100%}.input-suggestions{align-items:flex-start;flex-direction:column;gap:6px}.input-suggestions button{font-size:11px;padding:6px 10px}}@media (max-width:480px){.chat-header{padding:10px}.header-info h3{font-size:16px}.chat-messages{gap:12px;padding:10px}.message{max-width:95%}.message-content{font-size:13px;padding:10px}.value-summary-card{margin:10px;padding:16px}.value-summary-header{align-items:flex-start;flex-direction:column;gap:12px}.value-summary-icon{height:40px;width:40px}.value-summary-title h3{font-size:20px}.value-summary-title p{font-size:13px}.value-summary-cost{padding:16px}.cost-amount span:first-of-type{font-size:32px}.cost-currency{font-size:16px}.cost-label,.cost-note{font-size:12px}.spec-item{align-items:flex-start;flex-direction:column;gap:4px;padding:8px}.spec-label{font-size:12px}.spec-value{font-size:14px}.feature-badge{font-size:11px;padding:6px 10px}.btn-primary-large{font-size:15px;padding:12px 16px}.btn-secondary{font-size:13px;padding:10px 16px}.plan-preview{padding:12px}.plan-preview h4{font-size:15px}.plan-details span{font-size:10px;padding:4px 8px}.compliance-dashboard{margin:10px;padding:12px}.compliance-header h3{font-size:16px}.chat-input{padding:10px}.input-container textarea{font-size:13px;min-height:50px;padding:8px 10px}.btn-send{font-size:14px;padding:10px}}.report-view-overlay{align-items:center;background:#00000080;display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;inset:0;justify-content:center;position:fixed;z-index:10001}.report-view-modal{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:85vh;max-width:520px;overflow:hidden;width:90%}.report-view-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.report-view-header h3{color:#1e293b;font-size:18px;font-weight:600;margin:0}.report-view-close{background:none;border:none;color:#64748b;cursor:pointer;font-size:18px;line-height:1;padding:4px 8px}.report-view-close:hover{color:#1e293b}.report-view-body{color:#334155;font-size:14px;overflow-y:auto;padding:20px}.report-view-body .report-view-title{color:#1e293b;font-weight:600;margin:0 0 16px}.report-view-body section{margin-bottom:20px}.report-view-body section h4{color:#475569;font-size:14px;font-weight:600;margin:0 0 8px}.report-view-list{margin:0;padding-left:20px}.report-view-list li{margin-bottom:4px}.conv-drawer{animation:conv-slide-in .22s ease;background:#fff;bottom:0;box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;position:absolute;right:0;top:0;width:360px;z-index:1011}@keyframes conv-slide-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.conv-drawer-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 20px 16px}.conv-drawer-title{color:#0f172a;font-size:1rem;font-weight:700;letter-spacing:-.01em}.conv-drawer-subtitle{color:#94a3b8;font-size:.75rem;margin-top:2px}.conv-icon-btn{align-items:center;background:#f8fafc;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;transition:background .15s,color .15s;width:32px}.conv-icon-btn:hover{background:#f1f5f9;color:#1e293b}.conv-controls{border-bottom:1px solid #f1f5f9;display:flex;flex-shrink:0;gap:8px;padding:12px 16px}.conv-search-wrap{flex:1 1;position:relative}.conv-search-icon{color:#94a3b8;left:10px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.conv-search-input{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#1e293b;font-size:.85rem;outline:none;padding:8px 10px 8px 30px;transition:border-color .15s,box-shadow .15s;width:100%}.conv-search-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.conv-sort-select{background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;color:#475569;cursor:pointer;font-size:.82rem;outline:none;padding:8px 10px}.conv-list{flex:1 1;overflow-y:auto;padding:8px 0}.conv-empty{align-items:center;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:48px 24px;text-align:center}.conv-empty-icon{margin-bottom:4px}.conv-empty-title{color:#334155;font-size:.9rem;font-weight:600;margin:0}.conv-empty-sub{color:#94a3b8;font-size:.8rem;line-height:1.5;margin:0}.conv-item{align-items:stretch;background:none;border:none;border-bottom:1px solid #f8fafc;cursor:pointer;display:flex;padding:0;position:relative;text-align:left;transition:background .12s;width:100%}.conv-item:hover{background:#f8fafc}.conv-item--active{background:#f5f3ff}.conv-item--active:hover{background:#ede9fe}.conv-item-accent{background:#6366f1;border-radius:0 2px 2px 0;flex-shrink:0;width:3px}.conv-item-body{flex:1 1;min-width:0;padding:14px 8px 14px 14px}.conv-item-top{align-items:baseline;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.conv-item-title{color:#0f172a;flex:1 1;font-size:.875rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-item-time{color:#94a3b8;flex-shrink:0;font-size:.72rem}.conv-item-preview{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#64748b;display:-webkit-box;font-size:.8rem;line-height:1.4;margin:0 0 8px;overflow:hidden}.conv-item-tags{display:flex;flex-wrap:wrap;gap:4px}.conv-tag{align-items:center;background:#f1f5f9;border-radius:4px;color:#475569;display:inline-flex;font-size:.7rem;font-weight:500;gap:3px;padding:2px 7px}.conv-tag--style{background:#ede9fe;color:#6d28d9}.conv-tag--muted{background:#f8fafc;color:#94a3b8}.conv-item-arrow{align-items:center;color:#cbd5e1;display:flex;flex-shrink:0;padding:0 14px 0 4px;transition:color .12s}.conv-item:hover .conv-item-arrow{color:#6366f1}@media (max-width:768px){.conv-drawer{left:0;width:100%}}.error-boundary-container{align-items:center;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);display:flex;justify-content:center;min-height:100vh;padding:20px}.error-boundary-content{animation:slideIn .4s ease;background:#fff;border:1px solid #d4af371a;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:800px;padding:40px;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.error-icon{animation:shake .5s ease;display:flex;justify-content:center;margin-bottom:24px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.error-title{color:#1a1a1a;font-size:2rem;font-weight:700;margin:0 0 16px;text-align:center}.error-message{color:#525252;font-size:1.125rem;line-height:1.6;margin:0 0 32px;text-align:center}.error-warning{align-items:center;background:#d4af3714;border:1px solid #d4af374d;border-radius:8px;color:#b8941f;display:flex;font-weight:500;gap:12px;margin-bottom:24px;padding:16px}.error-warning svg{flex-shrink:0}.error-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:32px}.error-actions button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.btn-retry{background:linear-gradient(135deg,#d4af37,#b8941f);color:#fff}.btn-retry:hover:not(:disabled){background:linear-gradient(135deg,#b8941f,#9a7719);box-shadow:0 4px 12px #d4af3766;transform:translateY(-2px)}.btn-retry:disabled{background:#d4d4d4;cursor:not-allowed;opacity:.6}.btn-home{background:linear-gradient(135deg,#2d2d2d,#404040);color:#fff}.btn-home:hover{background:linear-gradient(135deg,#404040,#525252);box-shadow:0 4px 12px #d4af3733;transform:translateY(-2px)}.btn-reload{background:linear-gradient(135deg,#d4af37,#b8941f);color:#fff}.btn-reload:hover{background:linear-gradient(135deg,#b8941f,#9a7719);box-shadow:0 4px 12px #d4af3766;transform:translateY(-2px)}.error-details{background:#fafafa;border:1px solid #e5e5e5;border-radius:8px;margin-bottom:24px;padding:0}.error-details summary{align-items:center;color:#2d2d2d;cursor:pointer;display:flex;font-weight:600;gap:8px;list-style:none;padding:16px;-webkit-user-select:none;user-select:none}.error-details summary::-webkit-details-marker{display:none}.error-details summary:before{content:"▶";display:inline-block;font-size:.75rem;transition:transform .2s ease}.error-details[open] summary:before{transform:rotate(90deg)}.error-details summary:hover{background:#f5f5f5}.error-details-content{border-top:1px solid #e5e5e5;padding:16px}.error-section{margin-bottom:16px}.error-section:last-child{margin-bottom:0}.error-section h4{color:#1a1a1a;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin:0 0 8px;text-transform:uppercase}.error-section pre{background:#2d2d2d;border-radius:6px;color:#f5f5f5;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.875rem;line-height:1.5;margin:0;overflow-x:auto;padding:12px}.error-section p{color:#525252;font-size:.875rem;margin:0}.error-help{background:#d4af370d;border:1px solid #d4af3733;border-radius:8px;color:#2d2d2d;padding:20px}.error-help strong{color:#1a1a1a;display:block;font-size:1rem;margin-bottom:12px}.error-help ul{line-height:1.8;margin:0;padding-left:20px}.error-help li{margin-bottom:8px}.error-help li:last-child{margin-bottom:0}@media (max-width:640px){.error-boundary-content{padding:24px}.error-title{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{flex-direction:column}.error-actions button{justify-content:center;width:100%}.error-section pre{font-size:.75rem;padding:8px}}@media (prefers-color-scheme:dark){.error-boundary-content{background:#2d2d2d;border-color:#d4af3733}.error-title{color:#fafafa}.error-message{color:#d4d4d4}.error-details{background:#1a1a1a;border-color:#404040}.error-details summary{color:#f5f5f5}.error-details summary:hover{background:#2d2d2d}.error-details-content{border-top-color:#404040}.error-section h4{color:#fafafa}.error-section p{color:#d4d4d4}.error-help{background:#d4af371a;border-color:#d4af374d;color:#e5e5e5}.error-help strong{color:#d4af37}}.mobile-bottom-nav{align-items:stretch;background:var(--bg-primary);border-top:1px solid var(--border-light);bottom:0;box-shadow:0 -2px 12px #00000014;display:flex;font-family:var(--font-sans);justify-content:space-around;left:0;padding:var(--space-1) 0;padding-bottom:max(var(--space-1),env(safe-area-inset-bottom,0));position:fixed;right:0;z-index:1040}.mobile-bottom-nav__item{-webkit-tap-highlight-color:rgba(252,209,22,.15);align-items:center;background:#0000;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.65rem;font-weight:var(--font-semibold);gap:2px;justify-content:center;min-height:44px;min-height:var(--touch-target-min,44px);padding:var(--space-2) var(--space-1);touch-action:manipulation;transition:color var(--transition-fast),background var(--transition-fast)}.mobile-bottom-nav__item:focus-visible,.mobile-bottom-nav__item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.mobile-bottom-nav__item:focus{outline:none}.mobile-bottom-nav__item--active{color:var(--charcoal)}.mobile-bottom-nav__item--active .mobile-bottom-nav__icon{color:var(--primary-gold)}.mobile-bottom-nav__icon{align-items:center;color:inherit;display:flex;flex-shrink:0;justify-content:center}.mobile-bottom-nav__label{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}:root{--layout-header-height-mobile:56px;--mobile-bottom-nav-height:56px;--touch-target-min:44px}.dashboard-layout{align-self:stretch;background:var(--cloud);display:flex;flex-direction:column;font-family:var(--font-sans);max-width:100%;min-height:100vh;width:100%}.dashboard-layout__header{align-items:stretch;background:var(--gradient-hero);color:var(--white);display:flex;flex-shrink:0;min-height:56px;min-height:var(--layout-header-height-mobile);z-index:1060}.dashboard-layout__mobile-menu-btn{-webkit-tap-highlight-color:rgba(255,255,255,.15);align-items:center;background:#0000;border:none;color:var(--white);cursor:pointer;display:none;flex-shrink:0;justify-content:center;margin:0;min-height:44px;min-height:var(--touch-target-min);min-width:48px;padding:0;transition:background var(--transition-fast);width:48px}.dashboard-layout__mobile-menu-btn:focus-visible,.dashboard-layout__mobile-menu-btn:hover{background:#ffffff26}.dashboard-layout__mobile-menu-btn:focus{outline:none}.dashboard-layout__header-inner{flex:1 1;min-width:0}.dashboard-layout__body{display:flex;flex:1 1;max-width:100%;min-height:0;width:100%}.dashboard-layout__main{flex:1 1;max-width:100%;min-width:0;overflow-x:hidden;overflow-y:auto;width:100%}.dashboard-layout__backdrop{background:#0006;bottom:0;cursor:pointer;left:0;position:fixed;right:0;top:56px;top:var(--layout-header-height-mobile);z-index:1045}.command-sidebar{background:var(--bg-primary);border-right:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;flex-shrink:0;transition:width var(--transition-base);width:260px;z-index:100}.command-sidebar--collapsed{width:56px}.command-sidebar__nav{display:flex;flex:1 1;flex-direction:column;gap:var(--space-1);overflow-x:hidden;overflow-y:auto;padding:var(--space-3) 0}.command-sidebar__item{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-semibold);gap:var(--space-3);margin:0 var(--space-2);padding:var(--space-3) var(--space-4);text-align:left;transition:all var(--transition-fast);white-space:nowrap;width:100%}.command-sidebar__item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.command-sidebar__item--active{background:#fcd1161f;border-left:3px solid var(--primary-gold);color:var(--charcoal);margin-left:0;padding-left:calc(var(--space-4) - 3px)}.command-sidebar__item--active:hover{background:#fcd1162e}.command-sidebar__icon{align-items:center;color:inherit;display:flex;flex-shrink:0;justify-content:center;width:24px}.command-sidebar__item--active .command-sidebar__icon{color:var(--primary-gold)}.command-sidebar__label{flex:1 1;overflow:hidden;text-overflow:ellipsis}.command-sidebar__group-chevron{align-items:center;color:var(--text-tertiary);display:flex;flex-shrink:0}.command-sidebar__group-header .command-sidebar__label{flex:1 1}.command-sidebar__group,.command-sidebar__group-children{display:flex;flex-direction:column;gap:var(--space-1)}.command-sidebar__group-children{border-left:2px solid var(--border-light);margin-left:calc(var(--space-4) + 24px);padding-left:var(--space-4)}.command-sidebar__group--nested{margin-top:var(--space-1)}.command-sidebar__group--nested .command-sidebar__group-children{margin-left:calc(var(--space-3) + 18px);padding-left:var(--space-3)}.command-sidebar__item--child{font-size:var(--text-xs);font-weight:var(--font-medium);padding:var(--space-2) var(--space-3)}.command-sidebar__item--child .command-sidebar__icon{width:20px}.command-sidebar--collapsed .command-sidebar__group-children{display:none}.command-sidebar__badge{background:linear-gradient(135deg,var(--primary-gold) 0,#f8a100 100%);border-radius:10px;color:var(--charcoal);flex-shrink:0;font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.command-sidebar__badge--count{background:var(--error-red);color:#fff;text-transform:none}.command-sidebar__toggle{align-items:center;background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;margin:var(--space-2);padding:var(--space-3);transition:all var(--transition-fast);width:100%}.command-sidebar__toggle:hover{background:var(--border-medium);color:var(--text-primary)}.command-sidebar--collapsed .command-sidebar__item{justify-content:center;margin-left:var(--space-2);margin-right:var(--space-2);padding-left:var(--space-3);padding-right:var(--space-3)}.command-sidebar--collapsed .command-sidebar__item--active{border-left:none;border-radius:var(--radius-md);box-shadow:inset 3px 0 0 var(--primary-gold);margin-left:var(--space-2);padding-left:var(--space-3)}@media (max-width:1024px){.command-sidebar{bottom:0;height:100vh;left:0;position:fixed;top:0;transform:translateX(0);z-index:var(--z-modal)}.command-sidebar--collapsed{transform:translateX(0);width:56px}}@media (max-width:768px){.dashboard-layout__mobile-menu-btn{display:flex}.command-sidebar{bottom:auto;height:calc(100vh - 56px);height:calc(100vh - var(--layout-header-height-mobile));left:0;top:56px;top:var(--layout-header-height-mobile);transform:translateX(0);transition:transform var(--transition-base);width:260px;z-index:1050}.command-sidebar--collapsed{width:260px}.command-sidebar--overlay-closed{pointer-events:none;transform:translateX(-100%);visibility:visible}.command-sidebar--overlay-closed .command-sidebar__nav,.command-sidebar--overlay-closed .command-sidebar__toggle{pointer-events:none}.command-sidebar__item,.command-sidebar__item--child{min-height:44px;min-height:var(--touch-target-min);padding:var(--space-3) var(--space-4)}.command-sidebar__toggle{min-height:44px;min-height:var(--touch-target-min)}.command-sidebar__item,.command-sidebar__toggle{-webkit-tap-highlight-color:rgba(252,209,22,.12);touch-action:manipulation}}.dashboard-layout--mobile .dashboard-layout__main{padding-bottom:calc(56px + env(safe-area-inset-bottom, 0px));padding-bottom:calc(var(--mobile-bottom-nav-height) + env(safe-area-inset-bottom, 0px))}.live-price-index{--lpi-bg:#0f172a;--lpi-surface:#1e293b;--lpi-surface-elevated:#334155;--lpi-border:#475569;--lpi-text:#f1f5f9;--lpi-text-muted:#94a3b8;--lpi-accent:#f59e0b;--lpi-accent-dim:#f59e0b26;-webkit-font-smoothing:antialiased;background:var(--lpi-bg);box-sizing:border-box;color:var(--lpi-text);font-family:JetBrains Mono,SF Mono,Consolas,Monaco,monospace;margin:0 auto;max-width:1200px;min-height:100vh;overflow-x:hidden;padding:16px;width:100%}@media (min-width:768px){.live-price-index{padding:24px 16px}}.live-price-index__header{margin-bottom:24px}@media (min-width:768px){.live-price-index__header{margin-bottom:32px}}.live-price-index__title{word-wrap:break-word;color:var(--lpi-text);font-size:1.25rem;font-weight:700;letter-spacing:-.02em;line-height:1.3;margin-bottom:8px}@media (min-width:768px){.live-price-index__title{font-size:1.5rem}}.live-price-index__subtitle{color:var(--lpi-text-muted);font-size:.8125rem;line-height:1.5;max-width:60ch}@media (min-width:768px){.live-price-index__subtitle{font-size:1rem}}.live-price-index__controls{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}@media (min-width:640px){.live-price-index__controls{align-items:center;flex-direction:row;flex-wrap:wrap;gap:16px}}.live-price-index__label{align-items:center;color:var(--lpi-text-muted);display:flex;font-size:.8125rem;font-weight:600;gap:8px}.live-price-index__select{appearance:none;background:var(--lpi-surface);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;border:1px solid var(--lpi-border);border-radius:6px;color:var(--lpi-text);font-family:inherit;font-size:.9375rem;min-height:48px;padding:12px 40px 12px 16px;width:100%}@media (min-width:640px){.live-price-index__select{font-size:.875rem;min-height:40px;min-width:200px;padding:8px 40px 8px 16px;width:auto}}.live-price-index__refresh-btn{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--lpi-surface);border:1px solid var(--lpi-border);border-radius:6px;color:var(--lpi-text);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.9375rem;font-weight:600;gap:8px;justify-content:center;min-height:48px;padding:12px 16px;touch-action:manipulation}.live-price-index__refresh-btn:hover{background:var(--lpi-surface-elevated);border-color:var(--lpi-accent);color:var(--lpi-accent)}@media (min-width:640px){.live-price-index__refresh-btn{font-size:.875rem;min-height:40px;padding:8px 16px}}.live-price-index__refresh-btn:disabled{cursor:not-allowed;opacity:.6}.live-price-index__source{color:var(--lpi-text-muted);font-size:.75rem;opacity:.8}.live-price-index__error{background:var(--lpi-surface);border:1px solid var(--lpi-border);border-radius:6px;color:var(--lpi-text-muted);margin-bottom:24px;padding:16px}.live-price-index__section{margin-bottom:24px}@media (min-width:768px){.live-price-index__section{margin-bottom:32px}}.live-price-index__section-title{color:var(--lpi-text);font-size:.9375rem;font-weight:700;letter-spacing:.02em;margin-bottom:12px;text-transform:uppercase}@media (min-width:768px){.live-price-index__section-title{font-size:1rem;margin-bottom:16px}}.live-price-index__section-desc{color:var(--lpi-text-muted);font-size:.8125rem;margin-bottom:16px}.live-price-index__table-container{-webkit-overflow-scrolling:touch;background:var(--lpi-surface);border:1px solid var(--lpi-border);border-radius:6px;overflow-x:auto}.live-price-index__table{border-collapse:collapse;font-size:.8125rem;width:100%}.live-price-index__table td,.live-price-index__table th{padding:10px 12px;white-space:nowrap}@media (min-width:768px){.live-price-index__table td,.live-price-index__table th{padding:10px 14px}}.live-price-index__table th{border-bottom:1px solid var(--lpi-border);color:var(--lpi-text-muted);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-align:left;text-transform:uppercase}.live-price-index__table th--right{text-align:right}.live-price-index__table td{border-bottom:1px solid var(--lpi-border);color:var(--lpi-text)}.live-price-index__table td--secondary{color:var(--lpi-text-muted)}.live-price-index__table td--right{text-align:right}.live-price-index__table td--bold{color:var(--lpi-accent);font-weight:600}.live-price-index__no-copy{-webkit-touch-callout:none;cursor:default;-webkit-user-select:none;user-select:none}.live-price-index__cards{grid-gap:12px;display:grid;gap:12px}@media (min-width:640px){.live-price-index__cards{grid-template-columns:repeat(2,1fr)}}@media (min-width:768px){.live-price-index__cards{display:none}}.live-price-index__card{align-items:center;background:var(--lpi-surface);border:1px solid var(--lpi-border);border-radius:6px;display:flex;justify-content:space-between;padding:14px 16px}.live-price-index__card-name{color:var(--lpi-text);font-size:.8125rem;font-weight:500}.live-price-index__card-unit{color:var(--lpi-text-muted);font-size:.6875rem;letter-spacing:.03em;margin-top:2px;text-transform:uppercase}.live-price-index__card-price{color:var(--lpi-accent);font-size:.9375rem;font-weight:700}.live-price-index__table-container--desktop{display:none}@media (min-width:768px){.live-price-index__table-container--desktop{display:block}}.live-price-index__regional-scroll{position:relative}.live-price-index__scroll-hint{align-items:center;color:var(--lpi-text-muted);display:flex;font-size:.75rem;gap:8px;margin-bottom:8px;opacity:.85}@media (min-width:1024px){.live-price-index__scroll-hint{display:none}}.live-price-index__trends{background:var(--lpi-surface);border:1px solid var(--lpi-border);border-radius:6px;padding:16px}@media (min-width:768px){.live-price-index__trends{padding:24px}}.live-price-index__trends-header{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}@media (min-width:640px){.live-price-index__trends-header{align-items:center;flex-direction:row;flex-wrap:wrap}}.live-price-index__trends-title{align-items:center;display:flex;gap:8px}.live-price-index__trends-title h3{color:var(--lpi-text);font-size:.9375rem;font-weight:700;letter-spacing:.02em;margin:0;text-transform:uppercase}.live-price-index__trends-refresh{-webkit-tap-highlight-color:transparent;align-items:center;background:var(--lpi-bg);border:1px solid var(--lpi-border);border-radius:6px;color:var(--lpi-text-muted);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.8125rem;gap:4px;min-height:40px;padding:8px 12px;touch-action:manipulation}.live-price-index__trends-refresh:hover{border-color:var(--lpi-accent);color:var(--lpi-accent)}.live-price-index__trends-refresh:disabled{cursor:not-allowed;opacity:.6}.live-price-index__material-btns{display:flex;flex-wrap:wrap;gap:8px;width:100%}@media (min-width:640px){.live-price-index__material-btns{width:auto}}.live-price-index__material-btn{-webkit-tap-highlight-color:transparent;background:var(--lpi-bg);border:1px solid var(--lpi-border);border-radius:6px;color:var(--lpi-text-muted);cursor:pointer;flex:1 1;font-family:inherit;font-size:.75rem;font-weight:500;min-height:40px;min-width:90px;padding:8px 12px;text-align:center;touch-action:manipulation}.live-price-index__material-btn:hover{border-color:var(--lpi-accent);color:var(--lpi-text)}@media (min-width:640px){.live-price-index__material-btn{flex:none;font-size:.875rem}}.live-price-index__material-btn--active{background:#c9a227;background:var(--primary-gold,#c9a227);border-color:#c9a227;border-color:var(--primary-gold,#c9a227);color:#1a1a2e;color:var(--charcoal,#1a1a2e);font-weight:700}.live-price-index__trends-empty{color:#6b7280;color:var(--text-secondary,#6b7280);font-size:.875rem;line-height:1.5}.live-price-index__chart-container{height:220px;width:100%}@media (min-width:768px){.live-price-index__chart-container{height:280px}}.live-price-index__loading{color:var(--lpi-text-muted);font-size:.875rem;padding:16px}.live-price-index__empty{background:var(--lpi-surface);border:1px solid var(--lpi-border);border-radius:6px;color:var(--lpi-text-muted);font-size:.8125rem;padding:24px 16px;text-align:center}.onboarding-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:var(--space-4);position:fixed;right:0;top:0;z-index:var(--z-modal)}.onboarding-modal{animation:slideUp .4s ease-out;background:var(--white);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);max-height:90vh;max-width:700px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.wizard-header{align-items:center;background:var(--gradient-hero);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;color:var(--white);display:flex;justify-content:space-between;padding:var(--space-6)}.wizard-header h2{font-size:var(--text-2xl);font-weight:var(--font-bold);margin:0}.btn-close{align-items:center;background:#fff3;border:none;border-radius:var(--radius-full);color:var(--white);cursor:pointer;display:flex;height:36px;justify-content:center;margin:0;padding:0;transition:all var(--transition-fast);width:36px}.btn-close:hover{background:#ffffff4d;transform:scale(1.1)}.wizard-progress{padding:var(--space-6) var(--space-6) var(--space-4)}.progress-bar-bg{background:var(--bg-tertiary);border-radius:var(--radius-full);height:8px;overflow:hidden;width:100%}.progress-bar-fill{background:var(--gradient-sunset);border-radius:var(--radius-full);height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.progress-text{color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);margin:var(--space-2) 0 0;text-align:center}.wizard-content{min-height:400px;padding:var(--space-6)}.wizard-step{animation:fadeIn .3s ease-out}.step-icon{color:var(--primary-gold);margin-bottom:var(--space-4);text-align:center}.wizard-step h3{color:var(--text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);margin:0 0 var(--space-3);text-align:center}.step-description{color:var(--text-secondary);font-size:var(--text-base);line-height:var(--leading-relaxed);margin-bottom:var(--space-6);text-align:center}.step-footer{color:var(--text-tertiary);font-size:var(--text-sm);font-style:italic;margin-top:var(--space-6)}.step-footer,.welcome-step{text-align:center}.feature-list{margin:var(--space-6) auto;max-width:400px;text-align:left}.feature-item{align-items:center;background:var(--bg-secondary);border-radius:var(--radius-md);display:flex;gap:var(--space-3);margin-bottom:var(--space-3);padding:var(--space-3)}.feature-icon{color:var(--grass-green);flex-shrink:0}.feature-item span{color:var(--text-primary);font-size:var(--text-base)}.wizard-form{margin:0 auto;max-width:500px}.wizard-form .form-input,.wizard-form .form-select{font-size:var(--text-base);padding:var(--space-3) var(--space-4)}.help-text{color:var(--text-tertiary);display:block;font-size:var(--text-sm);margin-top:var(--space-2)}.radio-group{flex-direction:column}.radio-group,.radio-label{display:flex;gap:var(--space-3)}.radio-label{align-items:center;border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;padding:var(--space-3);transition:all var(--transition-fast)}.radio-label:hover{background:var(--bg-secondary);border-color:var(--primary-gold)}.radio-label input[type=radio]{cursor:pointer;height:20px;width:20px}.radio-label span{color:var(--text-primary);font-size:var(--text-base)}.template-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin:var(--space-6) 0}.template-card{background:var(--bg-secondary);border:3px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;padding:var(--space-6);position:relative;text-align:center;transition:all var(--transition-base)}.template-card:hover{border-color:var(--primary-gold);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.template-card.selected{background:#fcd1160d;border-color:var(--primary-gold);box-shadow:var(--shadow-gold)}.template-icon{font-size:3rem;margin-bottom:var(--space-3)}.template-card h4{color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-2)}.template-specs{margin:var(--space-3) 0}.template-specs p{color:var(--text-secondary);font-size:var(--text-sm);margin:var(--space-1) 0}.template-cost{color:var(--text-primary);font-family:var(--font-mono)}.selected-badge,.template-cost{font-weight:var(--font-semibold)}.selected-badge{align-items:center;background:var(--primary-green);border-radius:var(--radius-full);color:var(--white);display:flex;font-size:var(--text-sm);gap:var(--space-2);justify-content:center;margin-top:var(--space-3);padding:var(--space-2) var(--space-3)}.finish-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:var(--space-6) 0}.finish-card{background:var(--bg-secondary);border:3px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;padding:var(--space-6);position:relative;transition:all var(--transition-base)}.finish-card:hover{border-color:var(--primary-gold);box-shadow:var(--shadow-lg);transform:translateY(-4px)}.finish-card.selected{background:#fcd1160d;border-color:var(--primary-gold);box-shadow:var(--shadow-gold)}.popular-badge{background:var(--primary-gold);border-radius:var(--radius-full);color:var(--charcoal);font-size:var(--text-xs);font-weight:var(--font-bold);padding:var(--space-1) var(--space-3);position:absolute;right:var(--space-4);text-transform:uppercase;top:-12px}.finish-icon{font-size:2.5rem;margin-bottom:var(--space-3);text-align:center}.finish-card h4{color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-bold);margin:0 0 var(--space-2);text-align:center}.finish-description{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-4);text-align:center}.finish-features{list-style:none;margin:var(--space-4) 0;padding:0;text-align:left}.finish-features li{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:var(--space-2);padding-left:var(--space-2)}.finish-multiplier{color:var(--text-tertiary);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:var(--font-semibold);margin-top:var(--space-4);text-align:center}.review-summary{background:var(--bg-secondary);border-radius:var(--radius-lg);margin:var(--space-6) 0;padding:var(--space-6)}.review-item{border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:var(--space-3) 0}.review-item:last-child{border-bottom:none}.review-item strong{color:var(--text-primary);font-weight:var(--font-semibold)}.review-item span{color:var(--text-secondary);text-align:right}.capitalize{text-transform:capitalize}.review-highlight{border-top:2px solid var(--border-medium)!important;margin-top:var(--space-4);padding-top:var(--space-4)}.cost-highlight{color:var(--primary-gold)!important;font-family:var(--font-mono)!important;font-size:var(--text-xl)!important;font-weight:var(--font-bold)!important}.next-steps{background:#10b9810d;border:2px solid #10b98133;border-radius:var(--radius-lg);margin-top:var(--space-6);padding:var(--space-5)}.next-steps p{color:var(--text-primary);font-weight:var(--font-semibold);margin:0 0 var(--space-3)}.next-steps ul{list-style:none;margin:0;padding:0}.next-steps li{color:var(--text-secondary);font-size:var(--text-base);margin-bottom:var(--space-2)}.ready-banner{align-items:center;background:linear-gradient(135deg,#fcd116,#f59e0b);border-radius:var(--radius-lg);box-shadow:0 4px 12px #fcd1164d;color:var(--charcoal);display:flex;font-size:var(--text-base);gap:var(--space-3);margin-top:var(--space-5);padding:var(--space-4)}.ready-banner svg{color:var(--charcoal);flex-shrink:0}.wizard-footer{border-top:1px solid var(--border-light);display:flex;gap:var(--space-4);justify-content:space-between;padding:var(--space-6)}.wizard-footer button{flex:1 1;max-width:200px}.btn-secondary{background:var(--white);border:2px solid var(--border-medium);box-shadow:none;color:var(--charcoal)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--charcoal);transform:translateY(-1px)}.btn-secondary:disabled{cursor:not-allowed;opacity:.4}.tutorial-step .tutorial-content{margin:0 auto;max-width:550px}.tutorial-feature{align-items:flex-start;background:var(--bg-secondary);border:2px solid #0000;border-radius:var(--radius-lg);display:flex;gap:var(--space-4);margin-bottom:var(--space-5);padding:var(--space-4);transition:all .3s}.tutorial-feature:hover{border-color:var(--primary-gold);box-shadow:0 4px 12px #fcd11626;transform:translateX(4px)}.feature-badge{align-items:center;background:linear-gradient(135deg,var(--primary-gold) 0,#f59e0b 100%);border-radius:var(--radius-full);color:var(--charcoal);display:flex;flex-shrink:0;font-size:var(--text-lg);font-weight:var(--font-bold);height:36px;justify-content:center;min-width:36px}.feature-icon-tutorial{color:var(--primary-gold);flex-shrink:0}.feature-text h4{color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-1)}.feature-text p{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5;margin:0}.tutorial-highlight{align-items:center;background:#8b5cf61a;border:2px solid #8b5cf64d;border-radius:var(--radius-lg);color:#7c3aed;display:flex;font-size:var(--text-sm);font-weight:var(--font-semibold);gap:var(--space-3);margin-top:var(--space-6);padding:var(--space-4)}.tutorial-highlight svg{flex-shrink:0}.template-mini-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(3,1fr);margin-top:var(--space-2)}.template-mini-card{background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;padding:var(--space-3);position:relative;text-align:center;transition:all .3s}.template-mini-card:hover{border-color:var(--primary-gold);transform:translateY(-2px)}.template-mini-card.selected{background:#fcd1161a;border-color:var(--primary-gold)}.template-icon-mini{font-size:2rem;margin-bottom:var(--space-2)}.template-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);margin-bottom:var(--space-1)}.template-area{color:var(--text-tertiary);font-size:var(--text-xs)}.selected-check{color:var(--primary-green);position:absolute;right:4px;top:4px}.finish-mini-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(3,1fr);margin-top:var(--space-2)}.finish-mini-btn{align-items:center;background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;display:flex;flex-direction:column;font-size:var(--text-sm);font-weight:var(--font-semibold);gap:var(--space-2);padding:var(--space-3);transition:all .3s}.finish-mini-btn:hover{border-color:var(--primary-gold);transform:translateY(-2px)}.finish-mini-btn.selected{background:#fcd1161a;border-color:var(--primary-gold)}@media (max-width:768px){.onboarding-modal{max-height:95vh;max-width:95%}.wizard-header h2{font-size:var(--text-xl)}.wizard-content{min-height:350px;padding:var(--space-4)}.finish-grid,.template-grid{grid-template-columns:1fr}.finish-mini-grid,.template-mini-grid{grid-template-columns:repeat(3,1fr)}.wizard-footer{flex-direction:column-reverse}.wizard-footer button{max-width:100%}.tutorial-feature{flex-direction:column;text-align:center}.feature-badge{margin:0 auto}}