:root{color-scheme:light;font-family:Segoe UI,Helvetica Neue,Inter,system-ui,sans-serif;--ys-sidebar: #0c2138;--ys-sidebar-hover: #152d4a;--ys-sidebar-active: #0085d0;--ys-sidebar-text: #b8c9dc;--ys-sidebar-text-active: #ffffff;--ys-accent: #f58220;--ys-primary: #0085d0;--ys-primary-dark: #006ba6;--ys-page-bg: #eef2f6;--ys-card: #ffffff;--ys-border: #d8e0ea;--ys-text: #1a2b3c;--ys-muted: #6b7c93;--ys-success: #22a06b;--ys-danger: #de350b;--sidebar-bg: var(--ys-sidebar);--sidebar-text: var(--ys-sidebar-text);--sidebar-active: var(--ys-sidebar-active);--page-bg: var(--ys-page-bg);--card-bg: var(--ys-card);--border: var(--ys-border);--text: var(--ys-text);--muted: var(--ys-muted);--primary: var(--ys-primary);--danger: var(--ys-danger)}*{box-sizing:border-box}body{margin:0;background:var(--page-bg);color:var(--text);font-size:14px}a{color:var(--primary);text-decoration:none}a:hover{color:var(--ys-primary-dark)}.mark{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;background:linear-gradient(135deg,var(--ys-primary),#005a8c);color:#fff;font-weight:700}.yeastar-mark{background:linear-gradient(135deg,#f58220,#e06b00);border-radius:6px}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-hero{background:linear-gradient(160deg,#0c2138,#0085d0);color:#fff;padding:3rem;display:flex;flex-direction:column;justify-content:center}.login-hero h1{font-size:2rem;margin:0 0 1rem;font-weight:600}.login-hero p{opacity:.9;line-height:1.6;max-width:420px}.login-hero ul{padding-left:1.2rem;opacity:.85;line-height:1.8}.login-panel{display:grid;place-items:center;padding:2rem;background:#f8fafc}.login-card{width:min(400px,100%);background:var(--card-bg);border-radius:4px;padding:2.5rem;box-shadow:0 4px 24px #0c213814;border:1px solid var(--border)}.login-brand{display:flex;gap:1rem;align-items:center;margin-bottom:2rem}.login-brand strong{font-size:1.25rem;color:var(--ys-sidebar)}.login-hint{font-size:.85rem;margin-top:1.5rem;color:var(--muted)}@media(max-width:860px){.login-page{grid-template-columns:1fr}.login-hero{display:none}}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr}.global-topbar{display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem;height:52px;background:var(--ys-sidebar);color:#fff;box-shadow:0 2px 8px #00000026}.global-topbar .brand{display:flex;align-items:center;gap:.75rem;color:inherit;font-weight:600}.global-topbar nav{display:flex;gap:1.25rem;align-items:center}.global-topbar a{color:var(--ys-sidebar-text);font-size:.92rem}.global-topbar a:hover{color:#fff;text-decoration:none}.global-main{padding:1.5rem 2rem;max-width:1280px;margin:0 auto;width:100%}.pbx-shell{min-height:100vh;display:grid;grid-template-columns:220px 1fr}.sidebar{background:var(--ys-sidebar);color:var(--ys-sidebar-text);display:flex;flex-direction:column;min-height:100vh;box-shadow:2px 0 8px #0000001f}.sidebar-brand{display:flex;gap:.75rem;align-items:center;padding:1rem 1rem .75rem;border-bottom:1px solid rgba(255,255,255,.08)}.brand-title{display:block;color:#fff;font-size:.95rem;letter-spacing:.02em}.brand-sub{display:block;opacity:.65;font-size:.72rem;margin-top:.15rem;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-nav{flex:1;overflow-y:auto;padding:.5rem 0 1rem}.nav-group{margin-bottom:.15rem}.nav-group-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.55rem 1rem .35rem;background:transparent;border:0;cursor:pointer;color:inherit;font:inherit}.nav-group-toggle:hover .nav-group-title{color:#ffffffd9}.nav-group-title{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#b8c9dc8c;font-weight:600;text-align:left}.nav-chevron{display:flex;opacity:.5;transition:transform .15s}.nav-chevron.open{transform:rotate(90deg)}.nav-group-items{padding-bottom:.25rem}.nav-item{display:flex;align-items:center;gap:.65rem;padding:.5rem 1rem;margin:0 .5rem;border-radius:4px;color:var(--ys-sidebar-text);font-size:.88rem;transition:background .15s}.nav-item:hover{background:var(--ys-sidebar-hover);color:#fff;text-decoration:none}.nav-item.active{background:var(--ys-sidebar-active);color:var(--ys-sidebar-text-active);font-weight:500}.nav-icon{display:flex;opacity:.85}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{padding:.75rem;border-top:1px solid rgba(255,255,255,.08)}.sidebar-signout{width:100%;margin-top:.5rem;padding:.45rem;background:transparent;border:1px solid rgba(255,255,255,.15);color:var(--ys-sidebar-text);border-radius:4px;cursor:pointer;font:inherit;font-size:.85rem}.sidebar-signout:hover{background:#ffffff0f;color:#fff}.main-panel{display:flex;flex-direction:column;min-width:0;background:var(--page-bg)}.page-topbar{background:var(--card-bg);border-bottom:1px solid var(--border);padding:.65rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:56px}.topbar-section{display:block;font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.topbar-title{margin:0;font-size:1.15rem;font-weight:600;color:var(--text)}.topbar-right{display:flex;align-items:center;gap:1.25rem}.topbar-stat{text-align:right;font-size:.8rem}.topbar-stat-label{display:block;color:var(--muted);font-size:.7rem}.content-area{padding:1.25rem 1.5rem 2rem;flex:1}.page-header{margin-bottom:1.25rem}.breadcrumbs{font-size:.8rem;color:var(--muted);margin-bottom:.35rem}.breadcrumb-sep{margin:0 .35rem;opacity:.5}.breadcrumb-link{color:var(--muted)}.breadcrumb-link:hover{color:var(--primary)}.breadcrumb-current{color:var(--text)}.page-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.page-title{margin:0;font-size:1.35rem;font-weight:600}.page-desc{margin:.25rem 0 0;color:var(--muted);font-size:.9rem}.page-actions{display:flex;gap:.5rem;flex-shrink:0}.section-title{font-size:.95rem;font-weight:600;margin:1.5rem 0 .75rem;color:var(--text)}button,.btn{font:inherit;padding:.5rem 1rem;border-radius:4px;border:0;cursor:pointer;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;text-decoration:none;line-height:1.3}.btn-primary,button[type=submit]:not(.btn-ghost):not(.sidebar-signout){background:var(--ys-primary);color:#fff}.btn-primary:hover,button[type=submit]:not(.btn-ghost):hover{background:var(--ys-primary-dark)}.btn-accent{background:var(--ys-accent);color:#fff}.btn-accent:hover{filter:brightness(.95)}.btn-ghost{background:transparent;color:var(--primary);border:1px solid var(--border)}.btn-danger-ghost{background:transparent;color:var(--danger);border:0;padding:.35rem .6rem}.btn-sm{padding:.35rem .75rem;font-size:.82rem}button:disabled{opacity:.55;cursor:not-allowed}.link-btn{background:transparent;border:0;color:inherit;cursor:pointer;font:inherit;padding:0}.danger-btn{color:var(--danger);background:transparent;border:0;cursor:pointer;padding:0;font:inherit}.card{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;padding:1.25rem;margin-bottom:1rem;box-shadow:0 1px 3px #0c21380a}.card-flush{padding:0;overflow:hidden}.card-form{border-left:3px solid var(--ys-primary)}.card-title{margin:0 0 1rem;font-size:1rem;font-weight:600}.card-link{display:inline-block;margin-top:.75rem;font-size:.88rem;font-weight:500}.form{display:grid;gap:.75rem;max-width:520px}.inline-form{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));max-width:none;align-items:end}label{display:grid;gap:.3rem;font-size:.85rem;color:var(--text);font-weight:500}label.checkbox{display:flex;align-items:center;gap:.5rem;font-weight:400}input,select,textarea{font:inherit;padding:.45rem .65rem;border-radius:4px;border:1px solid var(--border);background:#fff;color:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--ys-primary);box-shadow:0 0 0 2px #0085d026}.data-table-wrap{width:100%}.table-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:#fafbfc}.search-box{position:relative;flex:1;max-width:320px}.search-icon{position:absolute;left:.65rem;top:50%;transform:translateY(-50%);color:var(--muted)}.search-input{width:100%;padding-left:2rem}.table-scroll{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:.88rem}.yeastar-table th{text-align:left;padding:.65rem 1rem;background:#f4f6f9;color:var(--muted);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}.yeastar-table td{padding:.75rem 1rem;border-bottom:1px solid #eef1f5;vertical-align:middle}.yeastar-table tbody tr:hover{background:#f8fafc}.table-empty{padding:2rem;text-align:center;color:var(--muted);margin:0}.cell-user{display:flex;align-items:center;gap:.65rem}.cell-user small{display:block;color:var(--muted);font-size:.78rem}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0085d0,#005a8c);color:#fff;display:grid;place-items:center;font-size:.75rem;font-weight:600;flex-shrink:0}.row-actions{display:flex;gap:.35rem}.status-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:500;padding:.2rem .55rem;border-radius:999px;background:#eef1f5;color:var(--muted)}.status-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.status-online{background:#e3fcef;color:#064}.status-online .status-dot{background:#22a06b}.status-offline{background:#fff4e5;color:#974f0c}.status-offline .status-dot{background:#f58220}.status-disabled{background:#f4f5f7;color:#6b778c}.status-running{background:#e3fcef;color:#064}.status-warning{background:#fff4e5;color:#974f0c}.pill{padding:.15rem .55rem;border-radius:999px;font-size:.75rem;font-weight:500;background:#dfe1e6;color:#42526e}.pill-sm{font-size:.7rem}.pill.active,.pill.running{background:#e3fcef;color:#064}.pill.provisioning,.pill.pending{background:#fff4e5;color:#974f0c}.dashboard-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:1rem;margin-bottom:1rem}.health-card{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;padding:1.25rem;box-shadow:0 1px 3px #0c21380a}.health-primary{border-top:3px solid var(--ys-primary)}.health-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.health-card h3{margin:0;font-size:.95rem;font-weight:600}.kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1.5rem;margin:0}.kv-grid dt{font-size:.75rem;color:var(--muted);margin-bottom:.15rem}.kv-grid dd{margin:0;font-weight:500;font-size:.88rem}.kv-compact{grid-template-columns:1fr}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.75rem}.yeastar-stats .stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;padding:1rem;display:grid;gap:.2rem;color:inherit;transition:box-shadow .15s,border-color .15s}.stat-card:hover{border-color:var(--ys-primary);box-shadow:0 4px 12px #0085d01f;text-decoration:none}.stat-value{font-size:1.75rem;font-weight:700;line-height:1}.stat-label{font-size:.85rem;font-weight:600;color:var(--text)}.stat-sub{font-size:.75rem;color:var(--muted)}.stat-blue .stat-value{color:var(--ys-primary)}.stat-green .stat-value{color:var(--ys-success)}.stat-orange .stat-value{color:var(--ys-accent)}.stat-purple .stat-value{color:#6554c0}.muted{color:var(--muted)}.error{color:var(--danger)}.success{color:var(--ys-success)}.flash{margin:0;padding:.65rem 1.5rem;font-size:.88rem}.flash-bar{border-bottom:1px solid rgba(34,160,107,.25)}.flash.success{background:#e3fcef;color:#064}.tabs{display:flex;gap:0;margin:1rem 0;border-bottom:2px solid var(--border)}.tab{background:transparent;color:var(--muted);border:0;border-bottom:2px solid transparent;border-radius:0;padding:.65rem 1.25rem;margin-bottom:-2px;font-weight:500}.tab.active{color:var(--ys-primary);border-bottom-color:var(--ys-primary)}.member-picker{border:1px solid var(--border);border-radius:4px;padding:.75rem;background:#fafbfc}.truncate{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.key-row{display:flex;gap:.5rem;margin-bottom:.5rem;align-items:center;flex-wrap:wrap}.loading-screen{min-height:60vh;display:grid;place-items:center;gap:1rem;color:var(--muted)}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--ys-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.tenant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.tenant-card{background:var(--card-bg);border:1px solid var(--border);border-radius:4px;padding:1.25rem;display:grid;gap:.5rem;transition:box-shadow .15s}.tenant-card:hover{box-shadow:0 4px 16px #0085d01a;border-color:var(--ys-primary)}.tenant-card h3{margin:0;font-size:1.05rem}.tenant-card-meta{font-size:.82rem;color:var(--muted)}.report-day-list{list-style:none;padding:0;margin:0}.report-day-list li{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid var(--border);font-size:.88rem}.report-day-list li:last-child{border-bottom:0}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.topbar-right{display:none}}@media(max-width:900px){.pbx-shell{grid-template-columns:1fr}.sidebar{min-height:auto}.nav-label{font-size:.82rem}}
