.placed-item{cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;box-sizing:border-box;border:2px solid #0003;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;transition:box-shadow .1s;display:flex;position:absolute;overflow:visible}.placed-item:active{cursor:grabbing}.placed-item:hover:not(.selected){border-color:#3b82f699;box-shadow:0 0 0 2px #3b82f633}.placed-item.selected{border:2px solid #1d4ed8;outline:none;box-shadow:0 0 0 3px #1d4ed859}.placed-item-icon{pointer-events:none;border-radius:3px;position:absolute;inset:0;overflow:hidden}.placed-item-icon svg{width:100%;height:100%;display:block}.placed-item-overlay{pointer-events:none;flex-direction:column;align-items:center;gap:1px;display:flex;position:absolute;bottom:2px;left:0;right:0}.placed-item-label{color:#000000bf;text-align:center;white-space:nowrap;text-shadow:0 0 3px #ffffffe6;font-size:10px;font-weight:700;line-height:1.2}.placed-item-dims{color:#0000008c;text-shadow:0 0 3px #ffffffe6;font-size:9px}.rot-handle{color:#fff;text-align:center;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;z-index:9999;background:#1d4ed8;border:2px solid #fff;border-radius:50%;width:28px;height:28px;font-size:17px;line-height:28px;position:absolute;top:-36px;left:-14px;box-shadow:0 2px 8px #00000059}.rot-handle:hover{background:#2563eb}.rot-handle:active{cursor:grabbing}.delete-handle{color:#fff;cursor:pointer;z-index:9999;touch-action:none;background:#dc2626;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;line-height:1;display:flex;position:absolute;top:-36px;right:-14px;box-shadow:0 2px 8px #00000059}.delete-handle:hover{background:#b91c1c}.placed-item.selected.resizable:after{content:"";cursor:se-resize;pointer-events:none;background:#1d4ed8;border-radius:2px 0 4px;width:10px;height:10px;position:absolute;bottom:-1px;right:-1px}.floorplan-canvas{cursor:default;border-radius:4px;flex-shrink:0;position:relative;box-shadow:0 4px 24px #0000001f}.sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;width:240px;min-width:240px;height:100%;display:flex;overflow:hidden}@media (width<=768px){.sidebar{width:64px;min-width:64px}.sidebar-tabs button{padding:10px 0;font-size:0}.sidebar-tabs button:before{font-size:16px}.sidebar-tabs button:first-child:before{content:"📦"}.sidebar-tabs button:last-child:before{content:"💾"}.sidebar-hint{display:none}.catalog-group-title{border-top:1px solid #e2e8f0;margin-top:4px;padding:4px 0 2px;font-size:0}.catalog-item{border-left:3px solid;flex-direction:column;align-items:center;gap:0;padding:6px 4px}.catalog-item-text{display:none}.catalog-item-icon{flex-shrink:0;width:36px;height:36px}.properties-panel{padding:8px 6px}.properties-title,.properties-panel label{font-size:10px}.rotation-row{gap:3px}.rot-btn{padding:3px 5px;font-size:11px}.rot-deg{min-width:28px;font-size:11px}.prop-dims{font-size:10px}.btn.btn-danger{padding:5px 8px;font-size:11px}.config-actions{flex-direction:column;gap:4px}.config-actions .btn{padding:5px 6px;font-size:11px}.config-name{font-size:11px}.config-date{display:none}.btn-sm{padding:2px 5px;font-size:10px}}.sidebar-tabs{border-bottom:1px solid #e2e8f0;display:flex}.sidebar-tabs button{cursor:pointer;color:#64748b;background:0 0;border:none;border-bottom:3px solid #0000;flex:1;padding:10px 0;font-size:13px;font-weight:600;transition:all .15s}.sidebar-tabs button.active{color:#1d4ed8;background:#f8faff;border-bottom-color:#1d4ed8}.sidebar-tabs button:hover:not(.active){color:#334155;background:#f8fafc}.sidebar-section{flex:1;padding:8px 0;overflow:hidden auto}.sidebar-hint{color:#94a3b8;margin:0;padding:4px 12px 8px;font-size:11px}.catalog-group{margin-bottom:8px}.catalog-group-title{text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;padding:4px 12px 2px;font-size:10px;font-weight:700}.catalog-item{cursor:grab;-webkit-user-select:none;user-select:none;background:#f8fafc;border-left:4px solid #ccc;border-radius:4px;align-items:center;gap:8px;margin:1px 8px;padding:6px 10px 6px 8px;transition:background .1s;display:flex}.catalog-item:hover{background:#f0f4ff}.catalog-item:active{cursor:grabbing;background:#e0e7ff}.catalog-item-icon{pointer-events:none;border-radius:3px;flex-shrink:0;width:40px;height:28px;overflow:hidden}.catalog-item-icon svg{width:100%;height:100%;display:block}.catalog-item-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.catalog-item-label{color:#1e293b;font-size:12px;font-weight:600}.catalog-item-dims{color:#64748b;font-size:10px}.config-actions{gap:6px;padding:8px 12px;display:flex}.configs-list{padding:4px 8px}.no-configs{color:#94a3b8;text-align:center;padding:12px;font-size:12px}.config-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:4px;padding:8px 10px;display:flex}.config-item.active{background:#eff6ff;border-color:#1d4ed8}.config-item-info{flex-direction:column;gap:2px;display:flex}.config-name{color:#1e293b;font-size:13px;font-weight:600}.config-date{color:#94a3b8;font-size:10px}.config-item-btns{gap:4px;display:flex}.save-modal{background:#f0f4ff;border:1px solid #c7d2fe;border-radius:6px;flex-direction:column;gap:6px;margin:4px 12px 8px;padding:10px;display:flex}.save-modal input{box-sizing:border-box;border:1px solid #c7d2fe;border-radius:4px;width:100%;padding:6px 8px;font-size:13px}.save-modal-btns{gap:6px;display:flex}.properties-panel{background:#fafafa;border-top:1px solid #e2e8f0;flex-direction:column;gap:8px;padding:12px;display:flex}.properties-title{text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-size:11px;font-weight:700}.properties-panel label{color:#64748b;flex-direction:column;gap:3px;font-size:11px;font-weight:600;display:flex}.properties-panel input[type=text]{color:#1e293b;border:1px solid #cbd5e1;border-radius:4px;padding:5px 7px;font-size:13px}.rotation-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.rot-btn{color:#1e293b;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:5px;padding:4px 8px;font-size:12px;font-weight:600;transition:all .12s}.rot-btn:hover{color:#3730a3;background:#e0e7ff;border-color:#818cf8}.rot-deg{color:#1e293b;text-align:center;min-width:36px;font-size:12px;font-weight:700}.prop-dims{color:#475569;font-size:12px}.btn-danger{color:#dc2626;background:#fee2e2;width:100%}.btn-danger:hover{background:#fecaca}.btn-sm{cursor:pointer;color:#475569;background:#fff;border:1px solid #cbd5e1;border-radius:4px;padding:3px 8px;font-size:11px}.btn-sm:hover{background:#f1f5f9}.btn-sm.danger{color:#dc2626;border-color:#fca5a5}.btn-sm.danger:hover{background:#fee2e2}.toolbar{color:#fff;background:#0f172a;border-bottom:2px solid #3b82f6;flex-shrink:0;align-items:center;gap:20px;height:60px;padding:0 20px;display:flex;box-shadow:0 2px 12px #0006}.toolbar-brand{white-space:nowrap;color:#f8fafc;letter-spacing:-.3px;font-size:18px;font-weight:800}.toolbar-nav{flex:1;align-items:center;gap:4px;display:flex}.toolbar-nav button{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;gap:6px;padding:7px 18px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.toolbar-nav button:hover{color:#e2e8f0;background:#1e293b}.toolbar-nav button.active{color:#fff;background:#3b82f6;box-shadow:0 1px 6px #3b82f666}.nav-badge{color:#fff;text-align:center;background:#fff3;border-radius:10px;min-width:18px;padding:0 6px;font-size:11px;font-weight:700}.toolbar-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.toolbar-meta{color:#64748b;white-space:nowrap;font-size:12px}.countdown{color:#94a3b8;white-space:nowrap;background:#334155;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:700}.countdown.warning{color:#fbbf24;background:#78350f}.countdown.overdue{color:#fca5a5;background:#7f1d1d}.toolbar-user{align-items:center;gap:7px;display:flex}.user-avatar{color:#fff;background:#3b82f6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;display:flex}.user-email{color:#64748b;text-overflow:ellipsis;white-space:nowrap;max-width:140px;font-size:12px;overflow:hidden}.signout-btn{color:#64748b;cursor:pointer;background:0 0;border:1px solid #334155;border-radius:6px;padding:4px 8px;font-size:14px;line-height:1;transition:all .15s}.signout-btn:hover{color:#e2e8f0;background:#334155}.hamburger-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px 6px;font-size:20px;line-height:1;display:none}.hamburger-btn:hover{color:#e2e8f0;background:#1e293b}@media (width<=768px){.toolbar{gap:8px;height:52px;padding:0 12px}.hamburger-btn{align-items:center;display:flex}.toolbar-brand{font-size:14px}.toolbar-nav button{gap:4px;padding:5px 10px;font-size:12px}.user-email,.toolbar-meta{display:none}.countdown{padding:2px 8px;font-size:11px}.nav-badge{min-width:15px;padding:0 4px;font-size:10px}}.task-panel{background:#f8fafc;flex-direction:column;flex:1;display:flex;overflow:hidden}.task-panel-header{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 12px;display:flex}.task-panel-title{align-items:baseline;gap:10px;display:flex}.task-panel-title h2{color:#0f172a;font-size:20px;font-weight:700}.task-count{color:#94a3b8;font-size:13px}.task-summary{background:#fff;border-bottom:1px solid #e2e8f0;flex-wrap:wrap;flex-shrink:0;gap:8px;padding:12px 24px;display:flex}.summary-chip{border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600}.done-chip{color:#16a34a;background:#dcfce7}.progress-chip{color:#2563eb;background:#dbeafe}.pending-chip{color:#475569;background:#f1f5f9}.overdue-chip{color:#dc2626;background:#fee2e2}.task-filters{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;align-items:center;gap:10px;padding:10px 24px;display:flex}.task-filters select{color:#374151;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:6px 10px;font-size:13px}.filter-result{color:#94a3b8;margin-left:auto;font-size:12px}.task-list{flex-direction:column;flex:1;gap:10px;padding:16px 24px;display:flex;overflow-y:auto}.no-tasks{text-align:center;color:#94a3b8;padding:40px 0;font-size:14px}.task-card{background:#fff;border:1px solid #e2e8f0;border-left-width:4px;border-radius:10px;flex-direction:column;gap:8px;padding:14px 16px;transition:box-shadow .15s;display:flex}.task-card:hover{box-shadow:0 2px 12px #00000014}.task-card.priority-high{border-left-color:#dc2626}.task-card.priority-medium{border-left-color:#d97706}.task-card.priority-low{border-left-color:#16a34a}.task-card.done{opacity:.65;background:#f8fafc}.task-card.overdue{background:#fff5f5;border-left-color:#dc2626}.task-card-top{justify-content:space-between;align-items:flex-start;display:flex}.task-badges{flex-wrap:wrap;gap:6px;display:flex}.badge{border:1px solid #0000;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.priority-badge{color:#475569;font-size:11px;font-weight:600}.task-card-actions{flex-shrink:0;gap:4px;display:flex}.btn-icon{cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:14px;transition:opacity .1s}.btn-icon:hover{opacity:1;background:#f1f5f9}.task-title{color:#0f172a;font-size:15px;font-weight:700;line-height:1.3}.task-card.done .task-title{color:#94a3b8;text-decoration:line-through}.task-description{color:#475569;font-size:13px;line-height:1.4}.task-card-bottom{justify-content:space-between;align-items:center;gap:12px;display:flex}.task-due{color:#64748b;font-size:12px}.task-due.overdue-date{color:#dc2626;font-weight:600}.status-select{cursor:pointer;border:1px solid #cbd5e1;border-radius:6px;padding:4px 8px;font-size:12px;font-weight:600}.status-select.status-not-started{color:#475569;background:#f1f5f9}.status-select.status-in-progress{color:#1d4ed8;background:#dbeafe;border-color:#93c5fd}.status-select.status-done{color:#16a34a;background:#dcfce7;border-color:#86efac}.task-notes{color:#64748b;background:#f8fafc;border-left:2px solid #cbd5e1;border-radius:4px;padding:4px 8px;font-size:11px}.modal-backdrop{z-index:10000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border-radius:12px;flex-direction:column;width:480px;max-width:94vw;max-height:90vh;display:flex;box-shadow:0 20px 60px #00000040}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-header h3{color:#0f172a;font-size:16px;font-weight:700}.modal-close{cursor:pointer;color:#94a3b8;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px}.modal-close:hover{color:#334155;background:#f1f5f9}.modal-body{flex-direction:column;flex:1;gap:12px;padding:16px 20px;display:flex;overflow-y:auto}.modal-body label{color:#374151;text-transform:uppercase;letter-spacing:.05em;flex-direction:column;gap:4px;font-size:12px;font-weight:700;display:flex}.modal-body input[type=text],.modal-body input[type=date],.modal-body select,.modal-body textarea{color:#1e293b;border:1px solid #cbd5e1;border-radius:6px;padding:8px 10px;font-family:inherit;font-size:13px}.modal-body textarea{resize:vertical;min-height:56px}.modal-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.required{color:#dc2626;font-weight:700}.modal-footer{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}@media (width<=768px){.task-panel-header{padding:14px 16px 10px}.task-panel-title h2{font-size:17px}.task-summary{padding:10px 16px}.task-filters{flex-wrap:wrap;padding:8px 16px}.task-list{padding:12px 16px}.modal-card{border-radius:0;width:100%;max-width:100%;height:100%;max-height:100%}.modal-backdrop{align-items:flex-end}.modal-row{grid-template-columns:1fr}}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary:hover:not(:disabled){background:#1e40af}.btn-ghost{color:#64748b;background:0 0;border:1px solid #cbd5e1}.btn-ghost:hover{background:#f1f5f9}.dashboard{background:#f1f5f9;flex-direction:column;flex:1;display:flex;overflow-y:auto}.dash-hero{color:#fff;background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);flex-direction:column;flex-shrink:0;align-items:center;padding:32px 32px 28px;display:flex}.dash-hero.warning{background:linear-gradient(135deg,#78350f 0%,#451a03 100%)}.dash-hero.overdue{background:linear-gradient(135deg,#7f1d1d 0%,#450a0a 100%)}.dash-countdown-number{color:#fff;letter-spacing:-2px;font-size:72px;font-weight:900;line-height:1}.dash-countdown-label{color:#94a3b8;margin-top:4px;font-size:16px}.dash-deadline-date{color:#475569;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-size:12px}.dash-hero.warning .dash-countdown-label{color:#fde68a}.dash-hero.warning .dash-deadline-date{color:#fbbf24}.dash-hero.overdue .dash-countdown-label{color:#fca5a5}.dash-body{box-sizing:border-box;flex-direction:column;flex:1;gap:20px;width:100%;max-width:900px;margin:0 auto;padding:24px 32px;display:flex}.dash-cards{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.dash-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:4px;padding:16px 18px;display:flex}.dash-card-value{color:#0f172a;font-size:32px;font-weight:800;line-height:1}.dash-card-value span{color:#94a3b8;font-size:18px;font-weight:500}.dash-card-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.dash-progress-bar{background:#e2e8f0;border-radius:3px;height:6px;margin-top:8px;overflow:hidden}.dash-progress-fill{border-radius:3px;height:100%;transition:width .4s}.dash-card-pct{color:#22c55e;font-size:12px;font-weight:700}.dash-main{flex-direction:column;gap:16px;display:flex}.dash-section{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:18px 20px}.dash-section.overdue-section{background:#fff5f5;border-color:#fecaca}.dash-section h3{color:#0f172a;text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px;font-size:14px;font-weight:700}.dash-empty{color:#94a3b8;text-align:center;padding:12px 0;font-size:13px}.dash-category-row{grid-template-columns:100px 1fr 50px 40px;align-items:center;gap:12px;margin-bottom:10px;display:grid}.dash-cat-label{text-align:right;font-size:13px;font-weight:700}.dash-cat-bar{background:#e2e8f0;border-radius:5px;height:10px;overflow:hidden}.dash-cat-fill{border-radius:5px;min-width:4px;height:100%;transition:width .4s}.dash-cat-count{color:#475569;text-align:right;font-size:12px;font-weight:600}.dash-cat-pct{text-align:right;font-size:11px;font-weight:700}.dash-task-row{border-bottom:1px solid #f1f5f9;grid-template-columns:70px 1fr 100px 100px;align-items:center;gap:12px;padding:8px 0;font-size:13px;display:grid}.dash-task-row:last-child{border-bottom:none}.dash-task-row.overdue{background:#fff5f5;border-bottom:none;border-radius:6px;margin:0 -10px 4px;padding:8px 10px}.dash-task-due{color:#64748b;white-space:nowrap;font-size:12px;font-weight:600}.dash-task-row.overdue .dash-task-due{color:#dc2626;font-weight:700}.dash-task-title{color:#1e293b;font-weight:600}.dash-task-cat{text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:700}.dash-task-status{text-align:center;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.status-not-started{color:#475569;background:#f1f5f9}.status-in-progress{color:#1d4ed8;background:#dbeafe}.status-done{color:#16a34a;background:#dcfce7}@media (width<=768px){.dash-hero{padding:20px 16px}.dash-countdown-number{font-size:52px}.dash-countdown-label{font-size:14px}.dash-body{padding:16px}.dash-cards{grid-template-columns:repeat(2,1fr)}.dash-card-value{font-size:26px}.dash-category-row{grid-template-columns:80px 1fr 40px}.dash-cat-pct{display:none}.dash-task-row{grid-template-columns:1fr;gap:4px}.dash-task-due{order:-1}.dash-task-cat,.dash-task-status{display:inline-block}}.dash-footer{gap:12px;padding-top:4px;padding-bottom:8px;display:flex}.btn{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s}.btn-primary{color:#fff;background:#1d4ed8}.btn-primary:hover{background:#1e40af}.btn-secondary{color:#334155;background:#e2e8f0}.btn-secondary:hover{background:#cbd5e1}.notes-panel{background:#1e293b;border-left:2px solid #3b82f6;flex-direction:column;flex-shrink:0;width:260px;display:flex;overflow:hidden}.notes-panel-header{background:#0f172a;border-bottom:1px solid #334155;flex-direction:column;gap:3px;padding:14px 16px 10px;display:flex}.notes-title{text-transform:uppercase;letter-spacing:.08em;color:#3b82f6;font-size:11px;font-weight:700}.notes-layout-name{color:#cbd5e1;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.notes-textarea{color:#e2e8f0;resize:none;background:#1e293b;border:none;outline:none;flex:1;width:100%;padding:14px 16px;font-family:inherit;font-size:13px;line-height:1.65}.notes-textarea:focus{background:#243047}.notes-textarea::placeholder{color:#3d5068}@media (width<=768px){.notes-panel{display:none}}.notes-hint{color:#475569;background:#0f172a;border-top:1px solid #334155;padding:8px 16px;font-size:11px;line-height:1.4}.calendar-panel{background:#1e293b;border-left:1px solid #334155;flex-direction:column;flex-shrink:0;width:230px;display:flex;overflow:hidden}@media (width<=768px){.calendar-panel{display:none}}.countdown-block{text-align:center;background:#0f172a;border-bottom:1px solid #334155;padding:16px 14px 14px}.countdown-block-label{text-transform:uppercase;letter-spacing:.09em;color:#3b82f6;margin-bottom:10px;font-size:10px;font-weight:700}.countdown-timer{justify-content:center;align-items:flex-end;gap:2px;display:flex}.cd-unit{flex-direction:column;align-items:center;gap:2px;display:flex}.cd-num{color:#f8fafc;font-variant-numeric:tabular-nums;font-size:24px;font-weight:800;line-height:1}.cd-label{color:#475569;text-transform:uppercase;letter-spacing:.06em;font-size:9px}.cd-sep{color:#334155;margin-bottom:10px;font-size:20px;font-weight:700;line-height:1.2}.countdown-expired{color:#ef4444;font-size:13px;font-weight:700}.calendar{flex:1;padding:12px 10px}.calendar-nav{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.calendar-month{color:#e2e8f0;font-size:12px;font-weight:700}.calendar-nav button{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px;line-height:1;transition:all .1s}.calendar-nav button:hover{color:#e2e8f0;background:#334155}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.cal-dow{color:#475569;text-align:center;padding:3px 0 5px;font-size:9px;font-weight:600}.cal-day{text-align:center;color:#94a3b8;border-radius:4px;padding:4px 1px;font-size:11px}.cal-day.past{color:#334155}.cal-day.today{color:#fff;background:#3b82f6;font-weight:700}.cal-day.deadline{color:#fff;background:#dc2626;font-weight:700}.calendar-legend{color:#475569;align-items:center;gap:12px;margin-top:10px;font-size:10px;display:flex}.legend-dot{border-radius:2px;width:8px;height:8px;margin-right:4px;display:inline-block}.today-dot{background:#3b82f6}.deadline-dot{background:#dc2626}.login-bg{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);justify-content:center;align-items:center;width:100vw;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:380px;padding:40px 36px 32px;box-shadow:0 24px 64px #0006}.login-header{text-align:center;margin-bottom:28px}.login-icon{margin-bottom:10px;font-size:40px}.login-header h1{color:#0f172a;margin:0 0 4px;font-size:22px;font-weight:800}.login-header p{color:#64748b;margin:0;font-size:13px}.login-form{flex-direction:column;gap:14px;display:flex}.login-form label{color:#374151;text-transform:uppercase;letter-spacing:.05em;flex-direction:column;gap:5px;font-size:12px;font-weight:700;display:flex}.login-form input{color:#0f172a;border:1.5px solid #cbd5e1;border-radius:8px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.login-form input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f626}.login-error{color:#dc2626;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:500}.login-success{color:#16a34a;background:#dcfce7;border:1px solid #86efac;border-radius:8px;padding:8px 12px;font-size:13px;font-weight:500}.login-btn{color:#fff;cursor:pointer;background:#1d4ed8;border:none;border-radius:8px;margin-top:4px;padding:11px;font-size:14px;font-weight:700;transition:background .15s}.login-btn:hover:not(:disabled){background:#1e40af}.login-btn:disabled{opacity:.55;cursor:not-allowed}.login-invite-note{text-align:center;color:#475569;margin-top:20px;font-size:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{color:#1e293b;background:#f1f5f9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{flex-direction:column;width:100vw;height:100vh;display:flex}.app-body{flex:1;display:flex;overflow:hidden}.canvas-container{background:#e2e8f0;flex:1;justify-content:flex-start;align-items:center;padding:20px;display:flex;overflow:auto}.app-loading{color:#94a3b8;background:#0f172a;flex-direction:column;justify-content:center;align-items:center;gap:16px;width:100vw;height:100vh;font-size:14px;display:flex}.app-loading-spinner{border:3px solid #334155;border-top-color:#3b82f6;border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.sidebar-overlay{display:none}@media (width<=768px){.canvas-container{justify-content:center;padding:10px}.sidebar-overlay{z-index:199;background:#00000073;display:block;position:fixed;inset:0}}
