:root{color:#1e293b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f6f9fc;font-family:Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:radial-gradient(circle at 0 0,#2563eb1a,#0000 0 34%),radial-gradient(circle at 100% 0,#7c3aed14,#0000 0 28%),linear-gradient(#f8fbff 0%,#f4f7fb 100%);min-height:100vh}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}#root{min-height:100vh}.login-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.login-panel{grid-template-columns:1.1fr .9fr;gap:24px;width:min(1100px,100%);display:grid}.login-copy,.login-card,.hero-card,.panel-card,.stat-card{background:#fff;border:1px solid #dbe4f0;box-shadow:0 18px 40px #0f172a14}.login-copy,.login-card{border-radius:24px;padding:24px}.login-copy{background:linear-gradient(135deg,#eff6ff,#f8fafc 55%,#eef2ff);flex-direction:column;justify-content:center;gap:14px;display:flex}.login-copy h1{color:#0f172a;margin:0;font-size:clamp(2.2rem,5vw,3.4rem);line-height:1.05}.login-card{gap:16px;display:grid}.login-card h2,.brand-block h2,.topbar h1,.hero-card h3,.panel-heading h3{color:#0f172a;margin:4px 0 0}.helper-text,.lead-text,.hero-card p,.muted,.alert-item span,.highlight-card small,.sidebar-footer span,.login-copy p,.demo-note span,.inventory-row span{color:#64748b}.login-highlights,.mini-stat-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.login-highlight,.mini-stat{background:#fffc;border:1px solid #dbe4f0;border-radius:16px;padding:14px}.login-highlight span,.mini-stat span,.section-label{text-transform:uppercase;letter-spacing:.12em;color:#64748b;margin-bottom:6px;font-size:.75rem;display:block}.form-group{gap:8px;display:grid}.form-group span{color:#0f172a;font-size:.9rem;font-weight:600}.form-group input{color:#0f172a;background:#f8fbff;border:1px solid #d0dae8;border-radius:14px;width:100%;padding:12px 14px}.form-group input:focus{outline-offset:1px;outline:2px solid #2563eb40}.demo-note,.error-banner,.status-line{border-radius:14px;padding:12px 14px}.demo-note{background:#f8fbff;border:1px solid #dbe4f0;gap:4px;display:grid}.error-banner{color:#b91c1c;background:#fff1f2;border:1px solid #fecaca}.room-popup-overlay{z-index:50;background:#0f172a5c;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.room-popup-dialog{background:#fff;border:1px solid #dbe4f0;border-radius:20px;width:min(1180px,100%);max-height:92vh;overflow:hidden;box-shadow:0 24px 60px #0f172a2e}.room-popup-header{background:linear-gradient(135deg,#eff6ff,#fff 50%,#f5f3ff);border-bottom:1px solid #e5edf6;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.room-popup-header h3{color:#0f172a;margin:4px 0 0}.room-popup-close{color:#334155;cursor:pointer;background:#fff;border:1px solid #dbe4f0;border-radius:10px;width:36px;height:36px}.room-popup-body{background:#f8fbff;max-height:calc(92vh - 74px);padding:10px;overflow:auto}.app-shell{color:#1e293b;grid-template-columns:280px 1fr;min-height:100vh;display:grid;position:relative}.sidebar{background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;align-self:start;gap:14px;min-height:100vh;padding:16px 12px;display:flex;position:sticky;top:0}.sidebar-header{z-index:5;background:#f8fafc;border:1px solid #e2e8f0;border-radius:0;justify-content:space-between;align-items:center;gap:12px;padding:12px;display:flex;position:sticky;top:0}.sidebar-header .brand-label,.sidebar-header h2{color:#0f172a}.sidebar-scrim{display:none}.sidebar-close-button{color:#64748b;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:1rem;transition:background .2s;display:none}.sidebar-close-button:hover{background:#f1f5f9}.brand-block{align-items:center;gap:12px;display:flex}.brand-logo{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:12px;flex-shrink:0;place-items:center;width:40px;height:40px;font-size:.85rem;font-weight:700;display:grid}.sidebar-nav{gap:10px;display:grid}.nav-dashboard-wrap{background:#f1f5f9;border-radius:12px;padding:3px}.menu-search{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;gap:10px;padding:9px 12px;display:flex}.menu-search-icon{color:#94a3b8;font-size:.95rem}.menu-search input{color:#0f172a;background:0 0;border:0;outline:none;width:100%;font-size:.88rem}.menu-search input::placeholder{color:#94a3b8}.nav-group-list,.nav-children,.nav-entry{gap:6px;display:grid}.nav-item{color:#475569;cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;width:100%;min-height:42px;padding:8px 10px;transition:background .18s,color .18s;display:flex}.nav-item.child{min-height:36px;padding:6px 8px}.nav-icon{color:#2563eb;background:#eef2ff;border-radius:8px;flex-shrink:0;place-items:center;min-width:30px;height:30px;transition:background .18s,color .18s;display:grid}.nav-text{color:inherit;flex:1;font-size:.88rem;font-weight:500}.nav-item.child .nav-text{font-size:.82rem;font-weight:400}.nav-chevron{color:#94a3b8;font-size:.75rem}.nav-item.active .nav-chevron{color:#fffc}.menu-empty{color:#94a3b8;border:1px dashed #cbd5e1;border-radius:10px;margin:0;padding:10px 12px;font-size:.84rem}.sidebar-footer{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:auto;padding:12px}.sidebar-user{align-items:center;gap:10px;display:flex}.sidebar-avatar{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:.9rem;font-weight:700;display:grid}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-info strong{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;font-size:.88rem;display:block;overflow:hidden}.sidebar-user-info span{color:#94a3b8;font-size:.75rem;display:block}.sidebar-logout-btn{color:#94a3b8;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;place-items:center;width:32px;height:32px;transition:background .18s,color .18s;display:grid}.sidebar-logout-btn:hover{color:#ef4444;background:#fff1f2;border-color:#fecaca}.sync-note{color:#94a3b8;margin-top:8px;font-size:.72rem;display:block}.mobile-bottom-nav{display:none}.mobile-nav-item{color:#94a3b8;cursor:pointer;background:0 0;border:0;flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 4px;transition:color .18s;display:flex}.mobile-nav-item.active{color:#2563eb;background:#eaf3ff}.mobile-nav-icon{place-items:center;width:28px;height:28px;display:grid}.mobile-nav-label{white-space:nowrap;font-size:.65rem;font-weight:500}.main-content{flex-direction:column;gap:16px;padding:24px;display:flex}.topbar,.topbar-heading{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.topbar-heading{justify-content:flex-start}.topbar h1{font-size:clamp(2rem,4vw,2.6rem)}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.mobile-menu-button,.primary-button,.secondary-button{cursor:pointer;border-radius:12px;padding:10px 14px;font-weight:700}.mobile-menu-button{color:#fff;background:#ffffff2e;border:0;justify-content:center;align-items:center;display:inline-flex}.primary-button{color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border:0}.secondary-button{color:#334155;background:#fff;border:1px solid #dbe4f0}.primary-button:disabled,.secondary-button:disabled{opacity:.7;cursor:wait}.status-badge,.pill,.user-chip,.inventory-badge{border-radius:999px;align-items:center;padding:6px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.status-badge,.pill-success{color:#15803d;background:#ecfdf3}.pill-warning{color:#b45309;background:#fef3c7}.hero-card,.stat-card,.panel-card{border-radius:20px}.hero-card{background:linear-gradient(135deg,#eff6ff,#fff 50%,#f5f3ff);justify-content:space-between;gap:18px;padding:20px 22px;display:flex}.hero-meta,.stats-grid,.highlight-grid,.chart-summary{gap:12px;display:grid}.hero-meta div,.chart-summary div,.highlight-card,.stat-card,.mini-stat{background:#f8fbff;border:1px solid #dbe4f0;border-radius:14px;padding:12px}.hero-meta span,.stat-card span,.highlight-card span,.chart-summary span{color:#64748b;margin-bottom:6px;font-size:.8rem;display:block}.hero-meta strong,.stat-card strong,.highlight-card strong,.chart-summary strong,.booking-value,.mix-row strong,.status-line strong{color:#0f172a}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.stat-card{flex-direction:column;gap:8px;display:flex}.stat-card strong{font-size:1.7rem}.stat-card small,.chart-column small{color:#2563eb}.content-grid{grid-template-columns:1.6fr 1fr;gap:14px;display:grid}.content-grid.secondary,.module-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.panel-heading{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;color:#334155;border-bottom:1px solid #e5edf6;padding:10px 0}thead th{color:#64748b;font-size:.8rem}.chart-columns{grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:12px;display:grid}.chart-column{text-align:center}.chart-track{background:#f8fbff;border:1px solid #dbe4f0;border-radius:14px;justify-content:center;align-items:end;height:150px;padding:8px;display:flex}.chart-bar{background:linear-gradient(#60a5fa,#7c3aed);border-radius:12px 12px 4px 4px;width:28px;min-height:22px;display:block}.chart-column strong,.chart-column small{margin-top:8px;display:block}.booking-list,.alert-list,.action-list,.mix-list,.inventory-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.booking-item,.inventory-row,.alert-item,.status-line{justify-content:space-between;align-items:center;gap:12px;display:flex}.booking-item{border-bottom:1px solid #e5edf6;padding:12px 0}.booking-item:last-child,.action-list li:last-child{border-bottom:0}.guest-name,.inventory-row strong,.alert-item strong,.mix-row strong,.status-line strong{margin-bottom:4px;font-weight:700;display:block}.inventory-row,.alert-item,.action-list li,.status-line{background:#f8fbff;border:1px solid #dbe4f0;border-radius:14px;padding:12px 14px}.alert-dot{background:#f59e0b;border-radius:50%;flex-shrink:0;width:10px;height:10px}.highlight-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.highlight-card strong{margin-bottom:6px;font-size:1.35rem;display:block}.action-list li:before{content:"✓";color:#15803d;margin-right:10px;font-weight:700}.mix-row{grid-template-columns:92px 1fr 42px;align-items:center;gap:10px;display:grid}.mix-track{background:#dbe4f0;border-radius:999px;height:10px;overflow:hidden}.mix-fill{border-radius:inherit;background:linear-gradient(135deg,#60a5fa,#7c3aed);height:100%;display:block}@media (width<=1100px){.login-panel,.app-shell,.content-grid,.content-grid.secondary,.module-grid{grid-template-columns:1fr}.sidebar{z-index:20;width:min(280px,85vw);transition:transform .25s;position:fixed;inset:0 auto 0 0;transform:translate(-100%);box-shadow:4px 0 24px #0f172a1a}.sidebar.open{transform:translate(0)}.sidebar-scrim{z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a59;border:0;display:block;position:fixed;inset:0}.mobile-menu-button,.sidebar-close-button{justify-content:center;align-items:center;display:inline-flex}.mobile-bottom-nav{z-index:30;padding:4px 0 max(4px, env(safe-area-inset-bottom));background:#fff;border-top:1px solid #e2e8f0;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #0f172a0f}.main-content{padding-bottom:80px}.topbar,.hero-card{flex-direction:column}.topbar-actions{justify-content:flex-start}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){.login-shell,.main-content,.login-copy,.login-card,.panel-card,.hero-card{padding:16px}.stats-grid,.hero-meta,.highlight-grid,.chart-summary,.login-highlights,.mini-stat-grid{grid-template-columns:1fr}.hero-meta{min-width:0}.chart-columns{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (width<=560px){.topbar-actions,.booking-item,.inventory-row,.status-line{flex-direction:column;align-items:stretch}.topbar-actions>*{justify-content:center;width:100%}.mix-row{grid-template-columns:1fr}.chart-columns{grid-template-columns:repeat(2,minmax(0,1fr))}}.app-shell{color:#223247;background:#edf1f5;grid-template-columns:282px minmax(0,1fr);min-height:100vh;transition:grid-template-columns .22s;display:grid}.app-shell.sidebar-hidden{grid-template-columns:0 minmax(0,1fr)}.app-shell.sidebar-hidden .sidebar{opacity:0;pointer-events:none;border-right:0;width:0;min-width:0;padding-left:0;padding-right:0;overflow:hidden}.app-shell.sidebar-visible .sidebar{opacity:1;pointer-events:auto}.sidebar{background:#f4f4f6;border-right:1px solid #d7e0ea;gap:10px;padding:0 8px 12px;box-shadow:inset -1px 0 #ffffffb8}.sidebar-header{z-index:5;background:linear-gradient(135deg,#1f86e5 0%,#2f92eb 100%);border:0;border-radius:0 0 2px 2px;margin:0 -12px 4px;padding:10px 14px;position:sticky;top:0;box-shadow:0 8px 18px #2086e538}.sidebar-header .brand-label,.sidebar-header h2{color:#fff;margin:0}.brand-label{letter-spacing:.12em;text-transform:uppercase;opacity:.8;font-size:.68rem}.brand-block h2{font-size:1.7rem;font-weight:700}.brand-logo{background:#ffffff2e;border:2px solid #ffffffb8;border-radius:50%;width:40px;height:40px;box-shadow:inset 0 1px #fff6}.brand-block{gap:10px}.sidebar-close-button{color:#fff;background:#ffffff29;border:0}.sidebar-nav{gap:8px;padding-top:4px}.nav-dashboard-wrap{background:0 0;padding:0}.menu-search{background:#fff;border:1px solid #d9e2ec;border-radius:2px;padding:8px 10px;box-shadow:0 1px 4px #0f172a0a}.nav-group-list{gap:8px}.nav-item{color:#394b61;border-radius:2px;min-height:34px;padding:5px 8px;font-weight:600}.nav-item.child{min-height:30px;padding:4px 6px;font-weight:500}.nav-item:hover{color:#1b4e7a;background:#e9f1fb}.nav-item.active{color:#fff;background:linear-gradient(135deg,#1f86e5 0%,#2478d6 100%);border-color:#0000;box-shadow:0 6px 18px #2186e547}.nav-item.active .nav-text,.nav-item.active .nav-chevron{color:#fff;font-weight:700}.nav-icon{color:#1f7fda;background:#e8eff8;border-radius:2px;min-width:32px;height:32px}.nav-icon.active{color:#fff;background:#fff3}.nav-chevron{color:#7991ab}.nav-children{border-left:2px solid #dbe4ef;margin-left:10px;padding-left:8px}.sidebar-footer{background:#fff;border:1px solid #dce5f0;border-radius:1px;margin-bottom:10px;box-shadow:0 6px 16px #0f172a0a}.sidebar-avatar{background:linear-gradient(135deg,#1f86e5,#5ba8f0)}.main-content{background:#edf1f5;gap:18px;padding:0 20px 60px}.topbar{z-index:4;background:linear-gradient(135deg,#1f86e5 0%,#2e95ee 100%);align-items:center;margin:0 -20px 2px;padding:8px 18px;position:sticky;top:0;box-shadow:0 8px 18px #1778d238}.topbar-brand-row{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.topbar-search{color:#fff;background:#ffffff29;border-radius:2px;align-items:center;gap:8px;width:min(340px,100%);padding:8px 12px;display:flex}.topbar-search input{color:#fff;background:0 0;border:0;outline:none;width:100%}.topbar-search input::placeholder{color:#ffffffbf}.topbar-actions{align-items:center;gap:10px;display:flex}.topbar-role{color:#ffffffeb;font-size:.95rem;font-weight:600}.user-menu-wrap{position:relative}.user-popup-menu{z-index:30;background:#fff;border:1px solid #dce5f0;width:280px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 14px 30px #0f172a29}.user-popup-header,.user-popup-body,.user-popup-footer{padding:12px}.user-popup-header{background:#f8fbff;border-bottom:1px solid #e6edf5;align-items:center;gap:10px;display:flex}.user-popup-avatar{color:#fff;background:linear-gradient(135deg,#1f86e5,#5ba8f0);border-radius:50%;place-items:center;width:36px;height:36px;font-weight:700;display:grid}.user-popup-title{gap:2px;display:grid}.user-popup-title strong,.user-popup-row strong{color:#0f172a}.user-popup-title span,.user-popup-row span{color:#64748b;font-size:.82rem}.user-popup-body{gap:10px;display:grid}.user-popup-row{gap:2px;display:grid}.user-popup-footer{border-top:1px solid #e6edf5}.user-popup-logout{width:100%}.icon-button{color:#fff;cursor:pointer;background:#ffffff2e;border:0;border-radius:2px;place-items:center;min-width:34px;height:34px;display:inline-grid}.icon-button svg{width:18px;height:18px}.icon-button.subtle{padding-bottom:4px;font-size:1.45rem;line-height:1}.icon-button:disabled{opacity:.65;cursor:wait}.user-chip{color:#fff;background:#ffffff2e}.hero-card,.stat-card,.panel-card{background:#fff;border:1px solid #dce4ef;border-radius:2px;box-shadow:0 10px 24px #0f172a0d}.hero-card{background:linear-gradient(#fff 0%,#fdfeff 100%);grid-template-columns:1.2fr 1fr auto;align-items:center;gap:16px;padding:18px 20px;display:grid}.hero-copy h3{margin:4px 0 8px;font-size:clamp(1.35rem,2.5vw,1.7rem)}.hero-copy p{margin:0}.hero-meta{grid-template-columns:repeat(3,minmax(0,1fr));min-width:0}.hero-meta div,.chart-summary div,.highlight-card,.stat-card,.mini-stat{background:#f9fbfd;border:1px solid #dbe5ef;border-radius:2px}.hero-toolbar{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.primary-button,.secondary-button,.mobile-menu-button{border-radius:10px;padding:10px 14px}.primary-button{background:linear-gradient(135deg,#1f86e5,#2478d6)}.secondary-button{border:1px solid #dbe4ef}.stats-grid{gap:16px}.stat-card{padding:18px}.stat-card-body{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.stat-card strong{font-size:1.9rem;line-height:1.1}.stat-card small{color:#2e7d32;font-weight:600}.stat-icon{border-radius:50%;place-items:center;width:70px;height:70px;display:grid}.stat-icon svg{width:28px;height:28px}.stat-icon.tone-1{color:#2478d6;background:#e8f1fd}.stat-icon.tone-2{color:#2e7d32;background:#edf5ec}.stat-icon.tone-3{color:#ef6c00;background:#fbefe3}.stat-icon.tone-4{color:#9c27b0;background:#f6ebfa}.content-grid,.content-grid.secondary,.module-grid{gap:18px}.panel-card{padding:18px 18px 16px}.panel-card.wide{min-height:420px}.panel-heading h3{font-size:1.12rem}.line-chart{padding:10px 0 0 44px;position:relative}.chart-surface{background:linear-gradient(#fcfdff 0%,#f7fafc 100%);border:1px solid #dbe4ef;border-radius:16px;width:100%;height:260px;overflow:visible}.chart-grid-line{stroke:#cfd9e4;stroke-dasharray:4 6;stroke-width:1px}.chart-area{fill:#2478d61f}.chart-line{fill:none;stroke-width:3px}.chart-line.primary{stroke:#2478d6}.chart-line.secondary{stroke:#ef6c00}.chart-point{fill:#fff;stroke-width:3px}.chart-point.primary{stroke:#2478d6}.chart-point.secondary{stroke:#ef6c00}.chart-y-labels{color:#70839a;flex-direction:column;justify-content:space-between;font-size:.78rem;display:flex;position:absolute;top:26px;bottom:48px;left:0}.chart-x-labels{color:#62748a;text-align:center;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin-left:44px;padding:10px 8px 0;font-size:.78rem;display:grid}.chart-summary{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:14px}.mix-visual{justify-items:center;gap:18px;display:grid}.donut-chart{border-radius:50%;place-items:center;width:210px;height:210px;display:grid;position:relative;box-shadow:inset 0 0 0 1px #0f172a0f}.donut-chart:after{content:"";background:#fff;border-radius:50%;width:122px;height:122px;box-shadow:inset 0 0 0 1px #dce5ef}.donut-chart-center{z-index:1;text-align:center;place-items:center;gap:2px;display:grid;position:absolute}.donut-chart-center strong{color:#1f2f44;font-size:1.6rem}.donut-chart-center span{color:#71839a;font-size:.78rem}.mix-list{width:100%}.mix-row{background:0 0;border:0;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:0}.mix-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.booking-item,.inventory-row,.alert-item,.status-line{background:#f9fbfd;border:1px solid #dce5ef;border-radius:12px;padding:12px 14px}.booking-value{color:#1f7fda;font-weight:700}.table-wrap{background:#fff;border:1px solid #dce5ef;border-radius:2px;overflow:hidden}.properties-page{display:grid}.properties-page .panel-card{padding:12px 12px 10px}.properties-topbar{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:8px;margin-bottom:8px;display:flex}.properties-heading{flex:320px;justify-content:space-between;align-items:center;gap:8px;min-width:240px;margin-bottom:0;display:flex}.properties-heading .section-label{margin-bottom:1px}.properties-heading h3{margin:0;font-size:1rem;line-height:1.2}.properties-toolbar{flex:420px;justify-content:flex-end;align-items:flex-end;gap:8px;margin-bottom:0;display:flex}.properties-filter{gap:2px;display:grid}.properties-filter-search{flex:280px;min-width:220px}.properties-filter-status{flex:0 0 120px}.properties-filter span{color:#64748b;font-size:.68rem;font-weight:600}.properties-filter input,.properties-filter select{color:#0f172a;background:#fff;border:1px solid #d7e1ec;border-radius:2px;width:100%;min-height:30px;padding:5px 8px;font-size:.85rem}@media (width<=860px){.properties-topbar,.properties-heading,.properties-toolbar{flex-direction:column;align-items:stretch}.properties-filter-search,.properties-filter-status{flex:auto}}.status-banner{color:#92400e;background:#fffbeb;border:1px solid #fde68a;margin-bottom:8px;padding:6px 8px;font-size:.82rem}.properties-table-wrap{max-height:calc(100vh - 255px);overflow:auto}.properties-table{position:relative}.properties-table th,.properties-table td{padding:6px 8px;font-size:.84rem;line-height:1.2}.properties-table thead th{z-index:1;background:#f8fbfd;position:sticky;top:0}.properties-action-cell{white-space:nowrap;width:1%}.table-action-wrap{display:inline-block;position:relative}.row-action-button{color:#1d4ed8;background:#eff6ff;min-width:26px;height:26px;padding:0}.table-row-menu{z-index:15;background:#fff;border:1px solid #dce5ef;border-radius:2px;flex-direction:column;min-width:170px;padding:4px;display:flex;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 12px 24px #0f172a24}.table-row-menu button{text-align:left;width:100%;font:inherit;color:#334155;cursor:pointer;background:0 0;border:0;border-radius:2px;padding:9px 10px;display:block}.table-row-menu button+button{margin-top:2px}.table-row-menu button:hover,.table-row-menu button:focus-visible{color:#1d4ed8;background:#eff6ff;outline:none}.empty-state{text-align:center;color:#64748b;padding:18px}.inventory-badge{color:#1d5fbf;background:#eaf2fd}.alert-dot{background:#f57c00}.widget-page{display:grid}.widget-grid{grid-template-columns:minmax(280px,340px) minmax(0,1fr);gap:12px;display:grid}.widget-side-panel,.widget-preview-panel{padding:12px 12px 10px}.widget-panel-heading{margin-bottom:10px}.widget-form{gap:8px;display:grid}.widget-actions{gap:8px;display:flex}.widget-meta-list{gap:6px;margin-top:10px;display:grid}.widget-meta-item{background:#f8fbfd;border:1px solid #dbe5ef;border-radius:2px;gap:2px;padding:7px 8px;display:grid}.widget-meta-item span{color:#64748b;font-size:.68rem;font-weight:600}.widget-meta-item strong,.widget-meta-item code{color:#0f172a;word-break:break-all;font-size:.8rem}.widget-host-wrap{background:#f8fbfd;border:1px solid #dbe5ef;border-radius:2px;min-height:520px;position:relative;overflow:auto}.widget-host{min-height:520px}.widget-placeholder{text-align:center;color:#64748b;background:#f8fbfdf5;place-items:center;gap:6px;padding:20px;display:grid;position:absolute;inset:0}.widget-placeholder strong{color:#0f172a}@media (width<=980px){.widget-grid{grid-template-columns:1fr}}.app-footer{z-index:25;color:#fff;background:linear-gradient(135deg,#1f86e5 0%,#2e95ee 100%);justify-content:space-between;align-items:center;gap:8px;width:100%;margin:0;padding:6px 20px;font-size:.85rem;font-weight:600;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 12px #1778d238}.mobile-bottom-nav{background:#fff;border-top:1px solid #dce5ef}@media (width<=1180px){.hero-card{grid-template-columns:1fr}.hero-toolbar{justify-content:flex-start}.topbar{flex-direction:column;align-items:stretch}.topbar-brand-row,.topbar-actions{width:100%}}@media (width<=1100px){.app-shell,.app-shell.sidebar-hidden,.app-shell.sidebar-visible{grid-template-columns:1fr}.main-content{padding:0 16px 110px}.topbar{margin:0 -16px 8px}.app-footer{padding:10px 16px calc(12px + env(safe-area-inset-bottom))}}@media (width<=720px){.topbar-role{display:none}.properties-toolbar{grid-template-columns:1fr}.line-chart{padding-left:0}.chart-y-labels{display:none}.chart-x-labels{margin-left:0}}@media (width<=560px){.topbar-search{width:100%}.user-popup-menu{width:min(260px,100vw - 24px);right:-8px}.app-footer{flex-direction:column;align-items:flex-start}}
