:root{--color-bg-base: #f4f6fb;--color-bg-elevated: #ffffff;--color-bg-muted: #f8fafc;--color-border: #e2e8f0;--color-border-strong: #cbd5e1;--color-text: #0f172a;--color-text-secondary: #334155;--color-text-muted: #64748b;--color-accent: #6366f1;--color-accent-strong: #4f46e5;--color-accent-soft: #eef2ff;--color-input-bg: #ffffff;--color-input-border: #cbd5e1;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-error-text: #b91c1c;--color-success-text: #15803d;--color-header-bg: rgba(255, 255, 255, .88);--shadow-card: 0 1px 3px rgba(15, 23, 42, .06), 0 8px 24px rgba(15, 23, 42, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--color-text);background-color:var(--color-bg-base);background-image:radial-gradient(ellipse 100% 80% at 50% -20%,rgba(99,102,241,.1),transparent 55%),radial-gradient(ellipse 70% 50% at 100% 0%,rgba(56,189,248,.07),transparent 50%),radial-gradient(ellipse 60% 45% at 0% 100%,rgba(167,139,250,.06),transparent 50%),linear-gradient(180deg,#f8faff,#f1f5f9,#eef2f7);background-attachment:fixed;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(15,23,42,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.035) 1px,transparent 1px);background-size:72px 72px;-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 0%,transparent 100%);mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 0%,transparent 100%);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh}.login-page,.dashboard-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.login-card,.dashboard-card{width:100%;max-width:400px;padding:2.5rem 2rem;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:16px;-webkit-backdrop-filter:blur(20px) saturate(1.2);backdrop-filter:blur(20px) saturate(1.2);box-shadow:var(--shadow-card);text-align:center}.login-brand,.dashboard-header{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-bottom:.5rem}.login-logo{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,#818cf8,#6366f1,#4f46e5);box-shadow:0 8px 24px #6366f159;font-size:1.75rem;font-weight:700;color:#fff}.login-brand h1,.dashboard-header h1{font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.login-subtitle{color:var(--color-text-muted);margin-bottom:1.75rem;font-size:.95rem}.auth-actions{display:flex;flex-direction:column;gap:.75rem}.auth-divider{color:var(--color-text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.microsoft-btn{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.25rem;border:1px solid var(--color-border-strong);border-radius:8px;background:#fff;color:var(--color-text);font-size:.95rem;font-weight:600;cursor:pointer;box-shadow:0 1px 2px #0f172a0f;transition:background .15s,transform .1s}.microsoft-btn:hover{background:#f8fafc}.microsoft-btn:active{transform:scale(.98)}.microsoft-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.microsoft-btn:disabled:hover{background:#fff}.microsoft-btn-outline:disabled:hover{background:transparent}.microsoft-btn svg{width:20px;height:20px;flex-shrink:0}.microsoft-btn-outline{background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text);box-shadow:none}.microsoft-btn-outline:hover{background:var(--color-bg-muted)}.user-info{margin:1.5rem 0 2rem;padding:1rem;background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:10px}.user-name{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.user-email{font-size:.875rem;color:var(--color-text-muted)}.logout-btn{width:100%;padding:.75rem 1.25rem;border:1px solid var(--color-border-strong);border-radius:8px;background:transparent;color:var(--color-text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s}.logout-btn:hover{background:var(--color-bg-muted)}.setup-card{text-align:left}.setup-errors{margin:1rem 0;padding:.75rem 1rem;border-radius:8px;background:var(--color-error-bg);border:1px solid var(--color-error-border)}.setup-errors p{color:var(--color-error-text);font-size:.875rem;margin-bottom:.25rem}.setup-errors p:last-child{margin-bottom:0}.setup-steps{padding-left:1.25rem;color:var(--color-text-secondary);font-size:.9rem;line-height:1.7}.setup-steps code{background:#f1f5f9;padding:.1rem .35rem;border-radius:4px;font-size:.85rem}.auth-error{margin-bottom:1rem;padding:.75rem 1rem;border-radius:8px;background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error-text);font-size:.875rem;text-align:left}.user-role,.user-apps{margin-top:.5rem;font-size:.8rem;color:var(--color-text-muted)}.loading-spinner{width:32px;height:32px;margin:1rem auto 0;border:3px solid var(--color-border);border-top-color:var(--color-accent-strong);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mis-items{margin-top:1.25rem;text-align:left}.mis-items-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.mis-items-header h2{font-size:1.1rem;font-weight:600}.mis-btn-compact{width:auto;padding:.4rem .85rem;font-size:.8rem;font-weight:600}.mis-items-table-wrap{overflow-x:auto}.mis-items-table{width:100%;border-collapse:collapse}.mis-items-table th,.mis-items-table td{padding:.6rem .5rem;border-bottom:1px solid var(--color-border)}.mis-items-table th{color:var(--color-text-secondary);font-weight:600}.mis-items-empty{color:var(--color-text-muted);text-align:center;padding:1rem 0;margin:0}.mis-items-pagination{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.mis-table-pagination{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-top:1rem}.mis-page-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border-radius:6px;border:1px solid var(--color-border-strong);background:#fff;color:var(--color-text-secondary);cursor:pointer;transition:background .15s,border-color .15s,color .15s}.mis-page-btn:hover:not(:disabled){background:var(--color-bg-muted);border-color:var(--color-accent);color:var(--color-accent-strong)}.mis-page-btn:disabled{opacity:.45;cursor:not-allowed}.mis-icon-btn:disabled{opacity:.45;cursor:not-allowed}.mis-icon-btn-primary{border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent-strong)}.mis-icon-btn-primary:hover:not(:disabled){background:var(--color-accent);color:#fff}.mis-page-indicator{min-width:4.5rem;text-align:center;font-size:.8rem;font-weight:600;color:var(--color-text-muted)}.mis-item-form-panel{margin-bottom:1rem;padding:1rem;border-radius:10px;border:1px solid var(--color-border);background:var(--color-bg-muted)}.mis-item-form-panel h3{font-size:.95rem;margin-bottom:.75rem;font-weight:600}.mis-item-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.mis-item-form-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--color-text-muted)}.mis-item-form-grid input[type=text],.mis-item-form-grid input[type=email],.mis-item-form-grid input[type=date]{padding:.5rem .6rem;border-radius:6px;border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-text);font-size:.875rem}.mis-item-form-grid input[type=text]:disabled{opacity:.7;cursor:not-allowed}.mis-item-form-wide{grid-column:1 / -1}.mis-item-form-check{flex-direction:row!important;align-items:center;color:var(--color-text-secondary)!important}.mis-item-form-actions{display:flex;gap:.75rem;margin-top:.75rem}.mis-item-form-actions .microsoft-btn{width:auto}.mis-items-actions{display:flex;gap:.5rem;white-space:nowrap}.mis-action-btn{padding:.25rem .6rem;border-radius:6px;border:1px solid var(--color-border-strong);background:#fff;color:var(--color-text-secondary);font-size:.8rem;cursor:pointer}.mis-action-btn:hover{background:var(--color-bg-muted)}.mis-action-btn-danger{border-color:#fca5a5;color:var(--color-error-text)}.mis-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border-radius:6px;border:1px solid var(--color-border-strong);background:#fff;color:var(--color-text-secondary);cursor:pointer}.mis-icon-btn:hover{background:var(--color-bg-muted)}.mis-icon-btn-danger{border-color:#fca5a5;color:var(--color-error-text)}.mis-icon-btn-danger:hover{background:#fef2f2}.mis-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.mis-modal{width:100%;max-width:420px;padding:1.25rem 1.5rem;border-radius:12px;border:1px solid var(--color-border);background:var(--color-bg-elevated);box-shadow:var(--shadow-card)}.mis-modal-title{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;color:var(--color-text)}.mis-modal-message{margin:0 0 1.25rem;font-size:.9rem;line-height:1.5;color:var(--color-text-secondary)}.mis-modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.mis-modal-btn{width:auto;min-width:5.5rem;padding:.55rem 1rem;font-size:.85rem}.mis-modal-btn-danger{background:#fef2f2;border-color:#fca5a5;color:var(--color-error-text)}.mis-modal-btn-danger:hover:not(:disabled){background:#fee2e2}.admin-save-btn{width:auto}.admin-message{margin-top:.5rem;margin-bottom:.75rem;font-size:.85rem;color:var(--color-success-text)}.admin-users-table td .mis-select__control{min-width:180px}.admin-select{width:100%;max-width:220px;padding:.45rem .6rem;border-radius:8px;border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-text);font-size:.875rem}.admin-page{max-width:1100px;margin:0 auto;text-align:left}.admin-page-wrap{min-height:100vh;padding:1.5rem}.admin-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.admin-page-header h2{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.admin-page-subtitle{color:var(--color-text-muted);font-size:.9rem}.admin-back-btn{width:auto;flex-shrink:0}.admin-tabs{display:flex;gap:.25rem;padding:.25rem;margin-bottom:1.25rem;background:var(--color-bg-muted);border:1px solid var(--color-border);border-radius:10px;width:fit-content}.admin-tab{padding:.5rem 1.1rem;border:none;border-radius:8px;background:transparent;color:var(--color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.admin-tab:hover{color:var(--color-text)}.admin-tab-active{background:var(--color-bg-elevated);color:var(--color-accent-strong);box-shadow:0 1px 3px #0f172a14}.admin-loading{display:flex;justify-content:center;padding:3rem 0}.admin-roles-layout{display:grid;grid-template-columns:240px 1fr;gap:1rem;align-items:start}.admin-role-sidebar{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px;padding:.75rem;box-shadow:var(--shadow-card)}.admin-new-role-btn{width:100%;padding:.6rem .75rem;margin-bottom:.5rem;border:1px dashed var(--color-border-strong);border-radius:8px;background:transparent;color:var(--color-accent-strong);font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.admin-new-role-btn:hover,.admin-new-role-btn-active{background:var(--color-accent-soft);border-color:var(--color-accent);border-style:solid}.admin-role-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.admin-role-empty{padding:.75rem;font-size:.8rem;color:var(--color-text-muted);text-align:center}.admin-role-item{width:100%;padding:.65rem .75rem;border:1px solid transparent;border-radius:8px;background:transparent;text-align:left;cursor:pointer;transition:background .15s,border-color .15s}.admin-role-item:hover{background:var(--color-bg-muted)}.admin-role-item-active{background:var(--color-accent-soft);border-color:#6366f140}.admin-role-item-name{display:block;font-size:.875rem;font-weight:600;color:var(--color-text)}.admin-role-item-desc{display:block;margin-top:.15rem;font-size:.75rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-role-detail{min-width:0}.admin-detail-panel{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem 1.5rem;box-shadow:var(--shadow-card)}.admin-detail-empty{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-muted);font-size:.9rem}.admin-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.admin-detail-header h3{font-size:1.1rem;font-weight:600}.admin-detail-desc{margin-top:.25rem;font-size:.85rem;color:var(--color-text-muted)}.admin-detail-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:.75rem}.admin-perm-toggles{display:flex;flex-wrap:wrap;gap:.75rem}.admin-perm-toggle{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-muted);font-size:.875rem;color:var(--color-text-secondary);cursor:pointer;transition:border-color .15s,background .15s}.admin-perm-toggle:has(input:checked){border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent-strong)}.admin-perm-toggle input{width:1rem;height:1rem;accent-color:var(--color-accent-strong)}.admin-create-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--color-text-muted)}.admin-create-form input[type=text]{padding:.5rem .65rem;border-radius:8px;border:1px solid var(--color-input-border);background:var(--color-input-bg);color:var(--color-text);font-size:.875rem}.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}.admin-form-actions{margin-top:1.25rem}.admin-users-panel{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem 1.5rem;box-shadow:var(--shadow-card)}.admin-users-table-wrap{overflow-x:auto}.admin-users-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-users-table th,.admin-users-table td{padding:.75rem .5rem;border-bottom:1px solid var(--color-border);text-align:left}.admin-users-table th{font-weight:600;color:var(--color-text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.admin-user-name{font-weight:500}.admin-user-email{color:var(--color-text-muted)}.admin-empty-cell{text-align:center;color:var(--color-text-muted);padding:2rem!important}.admin-hint{margin-top:1rem;font-size:.8rem;color:var(--color-text-muted)}@media (max-width: 768px){.admin-roles-layout,.admin-form-row{grid-template-columns:1fr}.admin-page-header{flex-direction:column}.admin-tabs{width:100%}.admin-tab{flex:1;text-align:center}}display: flex; flex-wrap: wrap; gap: .75rem; justify-content: center; margin-top: 1rem; } .mis-layout{min-height:100vh;display:flex;flex-direction:column}.mis-header{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);background:var(--color-header-bg);-webkit-backdrop-filter:blur(16px) saturate(1.15);backdrop-filter:blur(16px) saturate(1.15);box-shadow:0 1px 3px #0f172a0a}.mis-home-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin-top:1rem}.mis-header-brand{display:flex;align-items:center;gap:.75rem}.mis-header-brand h1{font-size:1.25rem;font-weight:600}.mis-header-user{font-size:.8rem;color:var(--color-text-muted)}.mis-nav{display:flex;gap:.5rem}.mis-nav-link{padding:.5rem 1rem;border-radius:8px;color:var(--color-text-muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:background .15s,color .15s}.mis-nav-link:hover{color:var(--color-text);background:var(--color-bg-muted)}.mis-nav-link-active{color:var(--color-accent-strong);background:var(--color-accent-soft)}.mis-header-logout{width:auto;padding:.5rem 1rem;white-space:nowrap}.mis-main{flex:1;padding:1.5rem}.mis-page-card{max-width:560px;margin:0 auto;padding:2rem;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:16px;-webkit-backdrop-filter:blur(20px) saturate(1.2);backdrop-filter:blur(20px) saturate(1.2);box-shadow:var(--shadow-card);text-align:center}.mis-page-card-wide{max-width:960px;text-align:left}.mis-page-card h2{font-size:1.5rem;margin-bottom:.5rem}.mis-page-subtitle{color:var(--color-text-muted);margin-bottom:1.5rem}.mis-back-link{display:inline-block;margin-bottom:.75rem;color:var(--color-accent-strong);font-size:.85rem;font-weight:600;text-decoration:none}.mis-back-link:hover{text-decoration:underline}.mis-items-header .mis-page-subtitle{margin-bottom:0;font-size:.85rem}.mis-page-cta{display:inline-flex;width:auto;margin-top:1rem;text-decoration:none}.mis-page-note{margin-top:1rem;color:var(--color-text-muted);font-size:.9rem;line-height:1.5}.mis-page-note code{background:#f1f5f9;padding:.1rem .35rem;border-radius:4px}
