@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Plus+Jakarta+Sans:wght@300;400;500;600;700&display=swap";:root{--font-heading:"Outfit", "Plus Jakarta Sans", sans-serif;--font-body:"Plus Jakarta Sans", sans-serif;--bg-primary:#f9f7f6;--bg-secondary:#f0edea;--bg-card:#fff;--bg-card-hover:#fdfcfc;--text-primary:#30261d;--text-secondary:#766b60;--text-muted:#a69e96;--border-color:#e2deda;--border-focus:#e6854d;--color-accent:#e06c29;--color-accent-light:#fcf3ed;--color-accent-hover:#cf5a17;--color-p0:#df2020;--color-p0-bg:#fceded;--color-p1:#d46c11;--color-p1-bg:#fdf4ec;--color-p2:#1f7ead;--color-p2-bg:#e9f5fb;--color-p3:#389457;--color-p3-bg:#edf8f0;--status-deciding:#d49311;--status-deciding-bg:#fdf6e7;--status-chosen:#395;--status-chosen-bg:#e8f7ed;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--shadow-sm:0 2px 6px #0000000a;--shadow-md:0 10px 20px -5px #1e0f000d, 0 3px 8px -2px #1e0f0005;--shadow-lg:0 20px 40px -10px #1e0f0014;--transition-fast:.12s ease;--transition-normal:.22s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg-primary:#1b1a18;--bg-secondary:#282624;--bg-card:#2e2b29;--bg-card-hover:#363330;--text-primary:#e3e0dd;--text-secondary:#aea8a3;--text-muted:#76706b;--border-color:#403d3a;--border-focus:#e27536;--color-accent:#e47e44;--color-accent-light:#4c230b;--color-accent-hover:#ed935e;--color-p0:#e75555;--color-p0-bg:#590d0d;--color-p1:#ef8e39;--color-p1-bg:#552b07;--color-p2:#44afe4;--color-p2-bg:#0b3950;--color-p3:#53c679;--color-p3-bg:#143d22;--status-deciding:#f0b642;--status-deciding-bg:#553b07;--status-chosen:#53c679;--status-chosen-bg:#143d22;--shadow-sm:0 2px 6px #00000040;--shadow-md:0 10px 20px -5px #0006;--shadow-lg:0 20px 40px -10px #00000080}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color var(--transition-normal), color var(--transition-normal);line-height:1.5;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);font-weight:600}#root,.app-container{flex-direction:column;width:100%;min-height:100vh;display:flex}header{background-color:var(--bg-card);border-bottom:1px solid var(--border-color);z-index:100;box-shadow:var(--shadow-sm);transition:background-color var(--transition-normal), border-color var(--transition-normal);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex;position:sticky;top:0}.brand-section{align-items:center;gap:.5rem;display:flex}.brand-icon{color:var(--color-accent);width:1.8rem;height:1.8rem}.brand-section h1{letter-spacing:-.5px;font-size:1.3rem}.brand-section span{color:var(--color-accent);font-weight:700}.header-controls{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.dashboard-grid{flex-grow:1;grid-template-columns:440px 1fr;gap:1.5rem;width:100%;max-width:1600px;margin:0 auto;padding:1.5rem;display:grid}@media (width<=1100px){.dashboard-grid{grid-template-columns:1fr}}.sidebar-panel,.main-panel{flex-direction:column;gap:1.5rem;min-width:0;display:flex}.card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast), background-color var(--transition-normal), border-color var(--transition-normal);width:100%;padding:1.25rem;overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card-title-bar{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.card-title-bar h2{align-items:center;gap:.5rem;font-size:1.15rem;display:flex}.floorplan-container{aspect-ratio:520/460;background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);width:100%;display:block;position:relative;overflow:hidden}.floorplan-svg{width:100%;height:100%;display:block}.floorplan-room{cursor:pointer;stroke:var(--border-color);stroke-width:2px;transition:fill var(--transition-normal), stroke var(--transition-normal);fill-opacity:.15}.floorplan-room.unplanned{fill:var(--text-muted)}.floorplan-room.deciding{fill:var(--status-deciding)}.floorplan-room.chosen{fill:var(--status-chosen)}.floorplan-room:hover{fill-opacity:.4;stroke:var(--color-accent)}.floorplan-room.active{fill-opacity:.55;stroke:var(--color-accent);stroke-width:3px}.floorplan-label{font-family:var(--font-heading);fill:var(--text-primary);pointer-events:none;text-anchor:middle;font-size:11px;font-weight:700}.floorplan-dim{font-family:var(--font-body);fill:var(--text-secondary);pointer-events:none;text-anchor:middle;font-size:9px}.floorplan-status{font-family:var(--font-body);fill:var(--color-accent);pointer-events:none;text-anchor:middle;font-size:9px;font-weight:700}.floorplan-walls{stroke:var(--text-primary);stroke-width:3.5px;stroke-linecap:round;fill:none}.floorplan-doors{stroke:var(--color-accent);stroke-dasharray:2 2;stroke-width:1.5px;fill:none}.reset-filter-badge{background-color:var(--color-accent);color:#fff;cursor:pointer;transition:background-color var(--transition-fast);border:none;border-radius:50px;padding:.2rem .6rem;font-size:.7rem;font-weight:600}.reset-filter-badge:hover{background-color:var(--color-accent-hover)}.budget-summary-grid{grid-template-columns:repeat(3,1fr);gap:.5rem;width:100%;margin-bottom:1rem;display:grid}.budget-stat-box{background-color:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-color);text-align:center;flex-direction:column;justify-content:center;min-width:0;padding:.5rem .6rem;display:flex}.budget-stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;text-overflow:ellipsis;margin-bottom:.15rem;font-size:.68rem;overflow:hidden}.budget-stat-value{font-size:1.05rem;font-weight:700;font-family:var(--font-heading);white-space:nowrap;text-overflow:ellipsis;width:100%;overflow:hidden}.budget-stat-value.accent{color:var(--color-accent)}.budget-stat-value.spent{color:var(--status-chosen)}.budget-stat-value.warning{color:var(--color-p0)}.progress-bar-container{background-color:var(--bg-secondary);border-radius:100px;width:100%;height:8px;margin-bottom:.4rem;overflow:hidden}.progress-bar{background-color:var(--status-chosen);height:100%;transition:width .3s}.progress-bar.limit-exceeded{background-color:var(--color-p0)}.budget-input-wrapper{border-top:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-top:.75rem;padding-top:.75rem;display:flex}.budget-input-wrapper label{font-size:.8rem;font-weight:600}.list-filter-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.filter-tabs{background-color:var(--bg-secondary);border-radius:var(--radius-sm);gap:.15rem;padding:.15rem;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;border-radius:calc(var(--radius-sm) - 2px);background:0 0;border:none;padding:.3rem .75rem;font-size:.8rem;font-weight:600}.tab-btn.active{background-color:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.btn{font-size:.82rem;font-weight:600;font-family:var(--font-body);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);border:1px solid #0000;justify-content:center;align-items:center;gap:.4rem;padding:.45rem .9rem;display:inline-flex}.btn-primary{background-color:var(--color-accent);color:#fff}.btn-primary:hover{background-color:var(--color-accent-hover)}.btn-secondary{background-color:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background-color:var(--border-color)}.btn-danger{color:var(--color-p0);background-color:#0000;border-color:#0000}.btn-danger:hover{background-color:var(--color-p0-bg);border-color:var(--color-p0)}.btn-icon-only{border-radius:50%;padding:.35rem}.badge-priority{text-transform:uppercase;border-radius:4px;padding:.15rem .4rem;font-size:.65rem;font-weight:700}.badge-priority.p0{background-color:var(--color-p0-bg);color:var(--color-p0)}.badge-priority.p1{background-color:var(--color-p1-bg);color:var(--color-p1)}.badge-priority.p2{background-color:var(--color-p2-bg);color:var(--color-p2)}.badge-priority.p3{background-color:var(--color-p3-bg);color:var(--color-p3)}.furniture-item-card{border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:var(--bg-card);margin-bottom:.75rem;overflow:hidden}.furniture-header-row{cursor:pointer;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.furniture-header-row:hover{background-color:var(--bg-card-hover)}.furniture-header-left{flex-grow:1;align-items:center;gap:.5rem;min-width:0;display:flex}.furniture-expand-icon{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.furniture-item-card.expanded .furniture-expand-icon{transform:rotate(90deg)}.furniture-info{flex-direction:column;min-width:0;display:flex}.furniture-title-line{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.furniture-name{white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:600;overflow:hidden}.furniture-room-tag{color:var(--text-secondary);background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;padding:.05rem .3rem;font-size:.7rem}.furniture-details-line{color:var(--text-muted);gap:.5rem;margin-top:.1rem;font-size:.7rem;display:flex}.furniture-header-right{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.furniture-price{font-family:var(--font-heading);font-size:1rem;font-weight:700}.furniture-status-badge{border-radius:50px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.furniture-status-badge.deciding{background-color:var(--status-deciding-bg);color:var(--status-deciding)}.furniture-status-badge.chosen{background-color:var(--status-chosen-bg);color:var(--status-chosen)}.furniture-details-body{border-top:1px solid var(--border-color);background-color:var(--bg-secondary);flex-direction:column;gap:.75rem;padding:1rem;display:flex}.furniture-meta-info{background-color:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border-color);grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;padding:.75rem;display:grid}.meta-field{flex-direction:column;gap:.15rem;display:flex}.meta-field label{color:var(--text-muted);text-transform:uppercase;font-size:.65rem;font-weight:700}.meta-field span{font-size:.8rem;font-weight:600}.options-section-title{font-family:var(--font-heading);text-transform:uppercase;color:var(--text-secondary);border-bottom:1px dashed var(--border-color);justify-content:space-between;align-items:center;padding-bottom:.25rem;font-size:.85rem;font-weight:700;display:flex}.options-grid{flex-direction:column;gap:.5rem;margin-top:.4rem;display:flex}.option-row{background-color:var(--bg-card);border-radius:var(--radius-sm);border:1px solid var(--border-color);grid-template-columns:1fr auto auto auto;align-items:center;gap:.75rem;padding:.5rem .75rem;display:grid}@media (width<=768px){.option-row{grid-template-columns:1fr;gap:.5rem}}.option-row.chosen{border-color:var(--status-chosen);background-color:var(--status-chosen-bg)}.option-info{flex-direction:column;min-width:0;display:flex}.option-title{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;overflow:hidden}.option-link{color:var(--color-accent);align-items:center;gap:.2rem;width:fit-content;font-size:.7rem;text-decoration:none;display:inline-flex}.option-link:hover{text-decoration:underline}.option-price{font-family:var(--font-heading);font-size:.95rem;font-weight:700}.voting-container{align-items:center;gap:.75rem;display:flex}.voter-box{flex-direction:column;gap:.1rem;display:flex}.voter-name{color:var(--text-muted);text-transform:uppercase;font-size:.6rem;font-weight:700}.vote-buttons{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;gap:.1rem;padding:.1rem;display:flex}.vote-btn{cursor:pointer;opacity:.4;filter:grayscale();background:0 0;border:none;border-radius:2px;padding:.15rem .3rem;font-size:.75rem;line-height:1}.vote-btn:hover,.vote-btn.active{opacity:1;filter:grayscale(0);background-color:var(--bg-card)}.add-option-form{background-color:var(--bg-card);border-radius:var(--radius-sm);border:1px dashed var(--border-color);grid-template-columns:1fr 90px 1.2fr auto;align-items:center;gap:.5rem;padding:.5rem;display:grid}@media (width<=768px){.add-option-form{grid-template-columns:1fr}}.input-style{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-family:var(--font-body);color:var(--text-primary);outline:none;width:100%;padding:.35rem .6rem;font-size:.8rem}.input-style:focus{border-color:var(--border-focus);background-color:var(--bg-card)}.canvas-container{background-color:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-md);box-sizing:border-box;justify-content:center;align-items:center;width:100%;min-height:320px;padding:1rem;display:flex;position:relative;overflow:hidden}.scaled-room-box{background-color:var(--bg-card);border:3.5px solid var(--text-primary);box-shadow:var(--shadow-md);box-sizing:border-box;position:relative}.room-inner-grid{background-image:radial-gradient(var(--border-color) 1.2px, transparent 1.2px);pointer-events:none;background-size:15px 15px;position:absolute;inset:0}.scaled-furniture-item{background-color:var(--color-accent-light);border:1.5px solid var(--color-accent);box-shadow:var(--shadow-sm);cursor:move;-webkit-user-select:none;user-select:none;box-sizing:border-box;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;padding:.15rem;display:flex;position:absolute}.scaled-furniture-item.active{border-color:var(--color-accent-hover);box-shadow:var(--shadow-md);background-color:#f9e0d2}.scaled-furniture-title{text-align:center;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;width:100%;font-size:.62rem;font-weight:700;overflow:hidden}.scaled-furniture-dims{color:var(--text-secondary);text-align:center;font-size:.52rem}.scaled-furniture-controls{background:var(--bg-card);border:1px solid var(--border-color);z-index:10;border-radius:3px;padding:1px;display:flex;position:absolute;top:-20px;right:-1px}.scaled-furniture-ctrl-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;padding:1px;font-size:.55rem}.scaled-furniture-ctrl-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background-color:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:90%;max-width:440px;max-height:90vh;padding:1.5rem;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;display:flex}.modal-body{flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.25rem;display:flex}.form-group label{color:var(--text-secondary);text-transform:uppercase;font-size:.75rem;font-weight:700}.modal-footer{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.5rem;margin-top:1.5rem;padding-top:.75rem;display:flex}.empty-state{color:var(--text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2.5rem 1rem;display:flex}.empty-state-icon{color:var(--text-muted);width:2.5rem;height:2.5rem}.flex-between{justify-content:space-between;align-items:center;display:flex}.flex-center{justify-content:center;align-items:center;display:flex}.text-accent{color:var(--color-accent)}.text-danger{color:var(--color-p0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-overlay{background-color:var(--bg-primary);z-index:9999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-card{background-color:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);text-align:center;width:90%;max-width:380px;padding:2rem;animation:.4s fadeIn}.auth-card h2{font-family:var(--font-display);color:var(--text-primary);margin-bottom:.5rem;font-size:1.5rem}.auth-card p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.85rem}.auth-error{color:var(--color-p0);margin-top:.5rem;font-size:.8rem;display:block}@media (width<=768px){header{text-align:center;flex-direction:column;align-items:center;padding:.75rem 1rem}.header-controls{flex-direction:column;align-items:center;gap:.75rem;width:100%}.mobile-room-carousel{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:.4rem;width:100%;margin-bottom:.75rem;padding-bottom:.6rem;overflow-x:auto;display:flex!important}.mobile-room-carousel::-webkit-scrollbar{display:none}.carousel-badge{background-color:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:50px;flex:none;padding:.4rem .8rem;font-size:.75rem;font-weight:600}.carousel-badge.active{background-color:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:var(--shadow-sm)}.mobile-kanban-tabs{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:.25rem;margin-bottom:1rem;padding:.25rem;display:flex!important}.kanban-tab{color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:.25rem;padding:.5rem .25rem;font-size:.75rem;font-weight:700;display:flex}.kanban-tab.active{background-color:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.tab-title-group{align-items:center;gap:.25rem;display:flex}.tab-count{background-color:var(--bg-secondary);color:var(--text-secondary);border-radius:50px;padding:.05rem .35rem;font-size:.7rem;font-weight:700}.kanban-tab.active .tab-count{background-color:var(--color-accent-light);color:var(--color-accent)}.kanban-column.mobile-hidden{display:none!important}.kanban-column.mobile-active{width:100%!important;display:flex!important}.kanban-columns-container{grid-template-columns:1fr!important}}.mobile-room-carousel,.mobile-kanban-tabs{display:none}.kanban-columns-container{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1rem;display:grid}.kanban-column{background-color:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-color);flex-direction:column;gap:.75rem;min-height:380px;padding:.75rem;display:flex}.kanban-column-header{border-bottom:2px solid var(--border-color);justify-content:space-between;align-items:center;padding-bottom:.25rem;display:flex}@media (width<=520px){.furniture-header-row{flex-direction:column;gap:.5rem;align-items:stretch!important;padding:.75rem!important}.furniture-header-left{width:100%}.furniture-header-right{border-top:1px dashed var(--border-color);justify-content:space-between;align-items:center;width:100%;margin-top:.25rem;margin-left:0;padding-top:.5rem;display:flex}.furniture-info{width:100%}.furniture-title-line{flex-wrap:wrap;gap:.35rem}}@media (width<=768px){input,select,textarea,.input-style{font-size:16px!important}}
