:root{font-family:Inter,Arial,sans-serif;color:#273142;background:#f6f7fb;--app-bg: #f6f7fb;--sidebar-bg: #1f2638;--sidebar-bg-2: #171d2b;--sidebar-text: #c7cfdd;--sidebar-active: linear-gradient(90deg, #04a9f5 0%, #448aff 100%);--primary: #04a9f5;--primary-2: #448aff;--card-border: #edf1f7;--muted: #7a8699;--shadow-soft: 0 6px 24px rgba(24, 39, 75, .08)}html,body,#app{min-height:100%}body{margin:0;background:var(--app-bg)}*{box-sizing:border-box}a{text-decoration:none}.auth-page{min-height:100vh;background:radial-gradient(circle at top right,rgba(68,138,255,.16),transparent 20%),radial-gradient(circle at bottom left,rgba(4,169,245,.16),transparent 20%),#eef2f7}.auth-brand{color:#111827;font-weight:800;letter-spacing:.2px}.auth-card{border:0;border-radius:22px;overflow:hidden;box-shadow:0 24px 60px #1118271f}.auth-cover{min-height:100%;background:linear-gradient(135deg,#1f2638,#273b73 45%,#448aff);color:#fff}.auth-cover .badge-soft{background:#ffffff1f;border:1px solid rgba(255,255,255,.1);color:#fff}.auth-form .form-control{min-height:48px;border-radius:12px;border-color:#dbe3ef}.auth-form .form-control:focus,.form-select:focus{border-color:#7dbdff;box-shadow:0 0 0 .2rem #448aff2e}.btn-primary{background:linear-gradient(90deg,var(--primary) 0%,var(--primary-2) 100%);border:0;box-shadow:0 8px 22px #448aff47}.btn-light-soft{background:#f3f6fb;color:#4a5568;border:1px solid #e6ebf3}.app-shell{min-height:100vh;display:flex}.app-sidebar{width:280px;background:linear-gradient(180deg,var(--sidebar-bg) 0%,var(--sidebar-bg-2) 100%);color:#fff;position:sticky;top:0;height:100vh;box-shadow:8px 0 30px #1018281f}.brand-wrap{padding:1.35rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.06)}.brand-logo{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#04a9f5,#448aff);box-shadow:0 10px 24px #04a9f547}.brand-subtitle,.user-role,.sidebar-caption{color:var(--sidebar-text)}.sidebar-nav{padding:1rem}.sidebar-caption{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;margin:.4rem .8rem .75rem}.sidebar-link{display:flex;align-items:center;gap:.9rem;color:var(--sidebar-text);padding:.85rem 1rem;border-radius:14px;margin-bottom:.35rem;transition:.2s ease}.sidebar-link:hover{background:#ffffff0f;color:#fff}.sidebar-link.active{background:var(--sidebar-active);color:#fff;box-shadow:0 12px 24px #448aff3d}.sidebar-link i{font-size:1rem}.sidebar-user{margin:1rem;padding:1rem;border-radius:18px;background:#ffffff0f;border:1px solid rgba(255,255,255,.06)}.app-main{flex:1;min-width:0;display:flex;flex-direction:column}.app-topbar{background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--card-border);padding:1rem 1.5rem;position:sticky;top:0;z-index:20}.page-content{padding:1.5rem}.panel-card,.stat-card,.surface-card{border:0;border-radius:18px;box-shadow:var(--shadow-soft)}.panel-card .card-header,.surface-card .card-header{background:#fff;border-bottom:1px solid var(--card-border)}.stat-card{position:relative;overflow:hidden}.stat-card:after{content:"";position:absolute;inset:auto -26px -30px auto;width:100px;height:100px;border-radius:50%;background:#448aff14}.stat-icon{width:52px;height:52px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:1.2rem;background:linear-gradient(135deg,#04a9f524,#448aff29);color:var(--primary-2)}.section-title{font-weight:700}.muted{color:var(--muted)}.table-modern thead th{color:#7a8699;font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;border-bottom-width:1px}.table-modern>:not(caption)>*>*{padding:.9rem .85rem;border-color:#eef2f7}.click-row:hover{background:#f8fbff}.form-control,.form-select{min-height:46px;border-radius:12px;border-color:#dce3ef}.form-label{font-size:.875rem;font-weight:600;color:#445269}.material-link{display:inline-flex;align-items:center;gap:.45rem;color:var(--primary-2);font-weight:600}.timeline-list .list-group-item{border-color:#eef2f7}.empty-state{text-align:center;padding:2rem 1rem;color:var(--muted)}.modal-backdrop-custom{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8f;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1050;display:flex;align-items:center;justify-content:center;padding:1rem}.password-card{width:min(100%,520px);border:0;border-radius:22px;box-shadow:0 30px 80px #0f172a47}.badge-soft-primary{background:#448aff1f;color:#36c}.badge-soft-success{background:#22c55e1f;color:#15803d}.badge-soft-warning{background:#f59e0b1f;color:#b45309}@media (max-width: 991.98px){.app-shell{display:block}.app-sidebar{width:100%;height:auto;position:static;border-bottom-left-radius:24px;border-bottom-right-radius:24px}.page-content{padding:1rem}}.topbar-toggle{display:none}.sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:39}.table-modern th{font-size:.82rem;color:#5f6c80;text-transform:uppercase;letter-spacing:.04em;font-weight:700;background:#f9fbfd;border-bottom:1px solid var(--card-border)}.table-modern td{vertical-align:middle}.click-row{cursor:pointer}.click-row:hover{background:#f7fbff}.drawer-header{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--card-border);background:#fffffff5}.form-control,.form-select{min-height:46px;border-radius:12px;border-color:#dbe3ef}.form-control:focus,.form-select:focus{border-color:#7dbdff;box-shadow:0 0 0 .2rem #448aff2e}.badge-soft-info{background:#0dcaf01f;color:#0aa2c0}.material-link{display:inline-flex;gap:.45rem;align-items:center;color:var(--primary-2);font-weight:600}.empty-state{border:1px dashed #d6deea;border-radius:16px;padding:1.2rem;text-align:center;color:var(--muted);background:#f9fbfd}.quick-link{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.1rem;border-radius:18px;border:1px solid var(--card-border);background:#fff;color:inherit}.week-calendar-wrapper{overflow:auto;padding:0}.calendar-time-header,.calendar-day-header,.calendar-time-cell,.calendar-slot-cell{border-right:1px solid var(--card-border);border-bottom:1px solid var(--card-border)}.calendar-day-header{background:#f9fbfd;padding:1rem;text-align:center;position:sticky;top:0;z-index:2}.calendar-day-header.today{background:#448aff1a}.calendar-time-header{background:#f9fbfd;position:sticky;left:0;z-index:3}.calendar-time-cell{background:#f9fbfd;padding:.85rem .75rem;font-weight:700;color:#64748b;position:sticky;left:0;z-index:1}.calendar-slot-cell.todaycol{background:#448aff08}.slot-event:last-child{margin-bottom:0}@media (max-width: 991.98px){.topbar-toggle{display:inline-flex}.app-sidebar{position:fixed;left:0;top:0;bottom:0;z-index:40;transform:translate(-100%);width:min(300px,86vw);height:100vh}.app-sidebar.open{transform:translate(0)}.page-content{padding:1rem}.table-toolbar .table-search,.table-toolbar .per-page-select{width:100%;min-width:0}.week-calendar{grid-template-columns:70px repeat(7,minmax(140px,1fr));min-width:1080px}}@media (min-width: 992px){.app-sidebar.collapsed{width:96px}.app-sidebar.collapsed .sidebar-link{justify-content:center}.app-sidebar.collapsed .sidebar-user{margin-top:auto}}.table-modern th{font-size:.82rem;color:#5f6c80;text-transform:uppercase;letter-spacing:.04em;font-weight:700;background:#f9fbfd;border-bottom:1px solid var(--card-border, #e5e7eb)}.table-toolbar .table-search{min-width:260px}.table-toolbar .per-page-select{width:140px}.right-drawer{position:fixed;top:0;right:0;width:min(520px,96vw);height:100vh;background:#fff;z-index:41;box-shadow:-12px 0 40px #0f172a2e;transform:translate(100%);transition:transform .25s ease;display:flex;flex-direction:column}.right-drawer.open{transform:translate(0)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;z-index:40}.drawer-header{padding:1.25rem 1.25rem 1rem;border-bottom:1px solid #e5e7eb;background:#fffffff5}.drawer-body{padding:1.25rem;overflow:auto}.form-control,.form-select{min-height:46px;border-radius:12px}.material-link{display:inline-flex;gap:.45rem;align-items:center;font-weight:600}.quick-link{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.1rem;border-radius:18px;border:1px solid #e5e7eb;background:#fff;color:inherit;text-decoration:none}.quick-link:hover{background:#f8fbff;color:inherit}.small-icon{width:44px;height:44px;border-radius:14px}.week-calendar-wrapper{overflow:auto}.week-calendar{display:grid;grid-template-columns:90px repeat(7,minmax(160px,1fr));min-width:1200px}.calendar-time-header,.calendar-day-header,.calendar-time-cell,.calendar-slot-cell{border-right:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb}.calendar-day-header{background:#f9fbfd;padding:1rem;text-align:center}.calendar-time-cell{background:#f9fbfd;padding:.85rem .75rem;font-weight:700;color:#64748b}.calendar-slot-cell{min-height:88px;background:#fff;padding:.5rem}.slot-event{border-radius:14px;background:#448aff1f;color:#1f3b77;padding:.6rem .7rem;line-height:1.25;margin-bottom:.45rem}
