@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap');
:root{--bg:#08090a;--panel:#0f1011;--surface:#17181b;--surface-2:#1f2025;--line:rgba(255,255,255,.08);--line-soft:rgba(255,255,255,.05);--text:#f7f8f8;--muted:#8a8f98;--soft:#d0d6e0;--accent:#7170ff;--accent-2:#5e6ad2;--green:#10b981;--red:#ef4444;--yellow:#f59e0b;--shadow:0 24px 80px rgba(0,0,0,.35)}
*{box-sizing:border-box}html{background:var(--bg)}body{font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;font-feature-settings:"cv01","ss03";margin:0;background:radial-gradient(circle at 20% -10%,rgba(113,112,255,.18),transparent 32rem),radial-gradient(circle at 90% 0,rgba(16,185,129,.08),transparent 26rem),var(--bg);color:var(--text);min-height:100vh}a{color:inherit}header{position:sticky;top:0;z-index:20;background:rgba(15,16,17,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line-soft);padding:14px 26px;display:flex;gap:22px;align-items:center}header strong{font-size:15px;letter-spacing:-.2px}header nav{display:flex;gap:6px;flex-wrap:wrap;flex:1}header a{color:var(--soft);text-decoration:none;font-size:13px;font-weight:500;padding:7px 9px;border-radius:8px}header a:hover,header a.nav-active{background:rgba(255,255,255,.08);color:var(--text);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}header span{color:var(--muted);font-size:13px}main{padding:28px;max-width:1360px;margin:auto}h1,h2,h3{letter-spacing:-.04em;margin:.1em 0 .35em}h1{font-size:clamp(32px,5vw,58px);line-height:1;font-weight:650}h2{font-size:24px;font-weight:620}h3{font-size:17px}.card,.panel,.metric-card{background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow)}.card,.panel{padding:20px;margin:14px 0}table{border-collapse:separate;border-spacing:0;width:100%;overflow:hidden}th,td{padding:12px 14px;border-bottom:1px solid var(--line-soft);text-align:left;color:var(--soft);font-size:14px}th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.08em}input,select,textarea{background:rgba(255,255,255,.035);border:1px solid var(--line);color:var(--text);padding:10px 12px;margin:5px;border-radius:10px;outline:none;color-scheme:dark}select{appearance:auto;background-color:#15161a;color:var(--text)}select:focus,select:open{background-color:#191a1f;color:var(--text)}select option,select optgroup{background:#15161a;color:#f7f8f8}select option:checked,select option:hover{background:#5e6ad2;color:#fff}input:focus,select:focus,textarea:focus{border-color:rgba(113,112,255,.7);box-shadow:0 0 0 3px rgba(113,112,255,.18)}button,.btn{background:rgba(255,255,255,.05);color:var(--text);border:1px solid var(--line);border-radius:10px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;padding:9px 13px;font-weight:600;cursor:pointer}.btn.primary,button{background:linear-gradient(180deg,#828fff,#5e6ad2);border-color:rgba(255,255,255,.12);color:white}.btn.ghost{background:rgba(255,255,255,.035)}.danger{background:var(--red)}.ok{background:var(--green)}.warn{background:var(--yellow);color:#111827}.badge{padding:4px 9px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--soft);font-size:12px}.error{background:rgba(239,68,68,.12);color:#fecaca;border:1px solid rgba(239,68,68,.3);padding:12px;border-radius:12px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}.event{border-left:8px solid #7170ff}.muted{color:var(--muted)}
.page-hero{display:flex;justify-content:space-between;gap:24px;align-items:flex-end;margin:8px 0 22px}.hero-copy{color:var(--muted);max-width:740px;font-size:17px;line-height:1.6}.eyebrow{color:var(--accent);font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:700;margin:0 0 8px}.hero-actions,.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}.insight-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:20px 0}.metric-card{padding:18px}.metric-label{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.metric-card strong{display:block;font-size:34px;letter-spacing:-.05em;margin:8px 0 4px}.metric-card small{color:var(--muted)}
.calendar-shell{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.018));border:1px solid var(--line);border-radius:24px;padding:18px;box-shadow:var(--shadow);overflow:hidden}.calendar-toolbar{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:4px 4px 18px}.calendar-weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.calendar-weekdays span{color:var(--muted);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;padding:0 10px 10px}.calendar-grid{border-top:1px solid var(--line);border-left:1px solid var(--line);background:rgba(0,0,0,.14)}.calendar-day{min-height:148px;background:rgba(255,255,255,.022);border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px;position:relative}.calendar-day:hover{background:rgba(255,255,255,.04)}.calendar-day.muted-day{background:rgba(255,255,255,.01);color:#51545d}.calendar-day.today{box-shadow:inset 0 0 0 1px rgba(113,112,255,.85);background:linear-gradient(180deg,rgba(113,112,255,.11),rgba(255,255,255,.025))}.day-number{font-size:13px;color:var(--soft);font-weight:650;margin-bottom:8px}.muted-day .day-number{color:#555a63}.day-events{display:flex;flex-direction:column;gap:6px}.calendar-event{--event-color:#7170ff;--person-color:#7170ff;display:grid;grid-template-columns:22px 1fr;grid-template-areas:'avatar title' 'avatar type';gap:0 7px;text-decoration:none;background:linear-gradient(90deg,color-mix(in srgb,var(--person-color) 26%,transparent),rgba(255,255,255,.035));border:1px solid color-mix(in srgb,var(--person-color) 52%,rgba(255,255,255,.08));border-left:4px solid var(--person-color);border-radius:10px;padding:6px 7px;color:var(--text);min-width:0}.employee-avatar{grid-area:avatar;width:22px;height:22px;border-radius:999px;background:var(--person-color);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;box-shadow:0 0 0 1px rgba(255,255,255,.16)}.employee-avatar.small{width:18px;height:18px;font-size:10px;margin-right:7px}.employee-name{--person-color:#7170ff;display:inline-flex;align-items:center;gap:2px;color:var(--soft);font-weight:650}.event-title{grid-area:title;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:650}.event-type{grid-area:type;color:var(--muted);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.event-type-dot{display:inline-block;width:7px;height:7px;background:var(--event-color);border-radius:99px;margin-right:5px}.calendar-event.pending-preview{opacity:.78;border-style:dashed;background:linear-gradient(90deg,color-mix(in srgb,var(--person-color) 14%,transparent),rgba(255,255,255,.018))}.preview-badge{display:inline-flex;margin-left:6px;padding:2px 6px;border-radius:999px;border:1px dashed color-mix(in srgb,var(--person-color) 70%,rgba(255,255,255,.16));background:rgba(0,0,0,.22);color:#fff;font-size:9px;text-transform:uppercase;letter-spacing:.06em}.table-status{font-size:12px;text-transform:none;letter-spacing:0}.status-sample{width:18px!important;height:10px!important;border-radius:4px!important;background:var(--accent)!important}.preview-sample{border:1px dashed var(--soft);background:rgba(255,255,255,.05)!important}.more-events{font-size:11px;color:var(--muted);padding-left:4px}.content-split{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-top:18px}.panel-title{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.modern-table{background:transparent}.type-pill,.legend-item{--event-color:#7170ff;display:inline-flex;align-items:center;gap:7px;padding:5px 9px;border-radius:999px;background:color-mix(in srgb,var(--event-color) 16%,transparent);border:1px solid color-mix(in srgb,var(--event-color) 36%,rgba(255,255,255,.08));font-size:12px;color:var(--soft)}.legend-list{display:flex;flex-wrap:wrap;gap:9px}.legend-item span{width:8px;height:8px;border-radius:99px;display:inline-block}.legend-item .employee-avatar.small{width:18px;height:18px;display:inline-flex}.legend-block{margin-bottom:16px}.legend-block h3{margin:10px 0;color:var(--muted);font-size:13px;text-transform:uppercase;letter-spacing:.08em}.calendar-hero{padding-top:4px}
.login-card{max-width:460px;margin:10vh auto 0}.login-card input,.login-card button{width:100%;min-height:44px;margin:8px 0}.login-card .demo-hint{background:rgba(113,112,255,.12);border:1px solid rgba(113,112,255,.28);border-radius:12px;padding:10px 12px;color:var(--soft)}.period-bars{margin:16px 0}.period-scale{display:flex;justify-content:space-between;color:var(--muted);font-size:12px;border-bottom:1px solid var(--line-soft);padding:0 0 8px;margin-bottom:10px}.period-bar-list{display:flex;flex-direction:column;gap:9px}.period-bar{position:relative;min-height:34px;border:1px solid var(--line);border-radius:12px;background:rgba(255,255,255,.025);overflow:hidden;text-decoration:none;color:var(--soft);display:block}.period-bar-fill{position:absolute;left:var(--bar-left);width:max(var(--bar-width),2%);top:6px;bottom:6px;border-radius:999px;background:linear-gradient(90deg,var(--person-color),color-mix(in srgb,var(--person-color) 55%,var(--event-color)));opacity:.85}.period-bar.pending-preview .period-bar-fill{border:1px dashed rgba(255,255,255,.75);opacity:.65}.period-bar-label{position:relative;z-index:1;display:flex;align-items:center;min-height:34px;padding:6px 10px;text-shadow:0 1px 2px rgba(0,0,0,.55)}
.admin-tabs{position:sticky;top:58px;z-index:10;display:flex;gap:8px;flex-wrap:wrap;background:rgba(8,9,10,.72);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:16px;padding:10px;margin:18px 0}.admin-flash{margin:12px 0;padding:12px 14px;border-radius:12px;background:rgba(16,185,129,.14);border:1px solid rgba(16,185,129,.32);color:#d1fae5}.error-page{max-width:760px;margin:10vh auto}.admin-tabs a{text-decoration:none;color:var(--soft);font-size:13px;font-weight:650;padding:8px 10px;border-radius:10px}.admin-tabs a:hover{background:rgba(255,255,255,.06);color:var(--text)}.admin-section{scroll-margin-top:130px}.admin-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;align-items:center;margin:12px 0 18px;padding:14px;background:rgba(0,0,0,.16);border:1px solid var(--line-soft);border-radius:16px}.admin-form.wide{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.admin-form input,.admin-form select{width:100%;margin:0}.check{display:flex;align-items:center;gap:8px;color:var(--soft);font-size:13px}.check input{width:auto;margin:0}.check-grid{display:flex;flex-wrap:wrap;gap:8px 12px;grid-column:1/-1}.check-grid .check{background:rgba(255,255,255,.035);border:1px solid var(--line);border-radius:999px;padding:7px 10px}.admin-section h3{margin-top:22px;color:var(--soft)}.calendar-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:end;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:16px;margin:14px 0}.calendar-filters label{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.calendar-filters select{width:100%;display:block;margin:6px 0 0}.day-detail{margin-top:7px;color:var(--muted);font-size:11px}.day-detail summary{cursor:pointer}.day-detail ul{padding-left:16px;margin:6px 0}.approval-modal{display:none;position:fixed;inset:0;z-index:100}.approval-modal:target{display:flex;align-items:center;justify-content:center}.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(8px)}.approval-dialog{position:relative;width:min(560px,92vw);max-height:90vh;overflow:auto}.modal-action-form{display:flex;gap:8px;margin-top:10px}.modal-action-form input{flex:1}.inline-color-form{display:flex;gap:6px;align-items:center}.inline-color-form input[type=color]{width:42px;height:32px;padding:2px}.inline-color-form button{padding:7px 9px}
.user-edit-table input,.user-edit-table select{min-width:120px}.user-edit-table input[type=color]{min-width:48px;width:58px}.check-grid.compact{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:4px}.create-user-card{margin:12px 0 18px}.create-user-card summary{display:inline-flex;cursor:pointer}.user-card-list{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}.user-card-header,.user-card-summary{display:grid;grid-template-columns:minmax(220px,1.5fr) minmax(110px,.7fr) minmax(90px,.6fr) minmax(220px,1.5fr) 80px 70px 110px;gap:12px;align-items:center}.user-card-header{padding:0 14px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.user-card-summary{padding:12px 14px;cursor:pointer;list-style:none}.user-card-summary::-webkit-details-marker{display:none}.user-main{display:flex;flex-direction:column;gap:2px}.user-main small{color:var(--muted)}.role-badges{display:flex;flex-wrap:wrap;gap:5px}.status-badge{display:inline-flex;border-radius:999px;padding:4px 9px;font-size:12px;font-weight:700}.status-badge.active{background:rgba(16,185,129,.16);color:#a7f3d0;border:1px solid rgba(16,185,129,.32)}.status-badge.inactive{background:rgba(148,163,184,.12);color:#cbd5e1;border:1px solid rgba(148,163,184,.24)}.color-swatch{display:inline-block;width:30px;height:18px;border-radius:999px;background:var(--swatch-color);border:1px solid rgba(255,255,255,.28)}.user-edit-form{margin:0 12px 12px;padding:16px;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.22);box-shadow:var(--shadow)}.user-edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.user-edit-grid label{color:var(--muted);font-size:12px}.user-edit-grid input,.user-edit-grid select{width:100%;margin-top:4px}.user-edit-grid small{display:block;margin-top:4px;color:var(--muted)}.form-actions{display:flex;align-items:center;gap:12px;margin-top:12px}@media(max-width:1100px){.user-card-summary{grid-template-columns:1fr 1fr}.user-card-summary .role-badges{grid-column:1/-1}}
.create-workflow-card{margin:12px 0 18px}.create-workflow-card summary{display:inline-flex;cursor:pointer}.workflow-card-list{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}.workflow-card{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.025);overflow:hidden}.workflow-card[open]{background:rgba(255,255,255,.04)}.workflow-card-header,.workflow-card-summary{display:grid;grid-template-columns:minmax(180px,1fr) minmax(240px,1.2fr) minmax(330px,2fr) 110px;gap:12px;align-items:center}.workflow-card-header{padding:0 14px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.workflow-card-summary{padding:12px 14px;cursor:pointer;list-style:none}.workflow-card-summary::-webkit-details-marker{display:none}.workflow-card-summary small{display:block;color:var(--muted);margin-top:2px}.bpmn-mini{margin-top:7px!important;color:#dfe2ff!important;font-size:12px!important;line-height:1.35;background:rgba(113,112,255,.12);border:1px solid rgba(113,112,255,.24);border-radius:999px;padding:5px 8px;white-space:normal}.workflow-steps{display:flex;flex-wrap:wrap;gap:5px}.workflow-edit-form{margin:12px;padding:16px;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.22);box-shadow:var(--shadow)}.workflow-edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.workflow-edit-grid label,.workflow-edit-form label{color:var(--muted);font-size:12px}.workflow-edit-grid input,.workflow-edit-grid select,.workflow-edit-form textarea{width:100%;margin-top:4px}.info-card{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.03);padding:12px 14px;margin:12px 0}.info-card ul{margin:8px 0 0 18px;color:var(--muted)}.bpmn-panel{margin:0 12px 12px;padding:16px;border:1px solid rgba(113,112,255,.24);border-radius:16px;background:linear-gradient(180deg,rgba(113,112,255,.08),rgba(0,0,0,.16))}.panel-title.compact{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.panel-title.compact h3{margin:0}.bpmn-diagram{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px;border:1px solid var(--line-soft);border-radius:14px;background:rgba(0,0,0,.18)}.bpmn-node{min-width:145px;min-height:82px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:4px;padding:10px 12px;border:1px solid var(--line);background:rgba(255,255,255,.035);color:var(--soft)}.bpmn-node strong{font-size:13px}.bpmn-node small{color:var(--muted);font-size:11px}.bpmn-symbol{font-size:24px;line-height:1}.bpmn-start{border-radius:999px;min-width:112px}.bpmn-task{border-radius:10px}.bpmn-gateway{width:104px;min-width:104px;aspect-ratio:1/1;transform:rotate(45deg);border-color:rgba(245,158,11,.45)}.bpmn-gateway>*{transform:rotate(-45deg)}.bpmn-end{border-radius:999px;min-width:112px}.bpmn-end.approved{border-color:rgba(16,185,129,.42);background:rgba(16,185,129,.09)}.bpmn-end.rejected{border-color:rgba(239,68,68,.42);background:rgba(239,68,68,.09)}.bpmn-flow{color:var(--muted);font-weight:800}.bpmn-reject-path{display:flex;align-items:center;gap:8px;width:100%;padding-top:8px;color:var(--muted);font-size:12px;border-top:1px dashed var(--line)}.bpmn-xml-export{margin-top:10px;color:var(--muted);font-size:13px}.bpmn-xml-export summary{cursor:pointer}.bpmn-xml-export textarea{width:100%;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}
.create-department-card{margin:12px 0 18px}.create-department-card summary{display:inline-flex;cursor:pointer}.department-card-list{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}.department-card{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.025);overflow:hidden}.department-card[open]{background:rgba(255,255,255,.04)}.department-card-header,.department-card-summary{display:grid;grid-template-columns:minmax(180px,1fr) 120px minmax(180px,1fr) minmax(260px,2fr) 110px;gap:12px;align-items:center}.department-card-header{padding:0 14px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.department-card-summary{padding:12px 14px;cursor:pointer;list-style:none}.department-card-summary::-webkit-details-marker{display:none}.department-card-summary small{display:block;color:var(--muted);margin-top:2px}.department-edit-form{margin:0 12px 12px;padding:16px;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.22);box-shadow:var(--shadow)}.department-edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.department-edit-grid label{color:var(--muted);font-size:12px}.department-edit-grid input{width:100%;margin-top:4px}.approver-filter{display:block;margin:12px 0;color:var(--muted);font-size:12px}.approver-filter input{display:block;width:100%;margin-top:6px}.approver-picker{max-height:260px;overflow:auto;border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.16);padding:8px;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:8px}.approver-option{display:flex;gap:10px;align-items:flex-start;padding:9px;border:1px solid var(--line-soft);border-radius:12px;background:rgba(255,255,255,.025)}.approver-option input{width:18px;height:18px;margin-top:3px}.approver-option small{display:block;color:var(--muted);margin-top:2px;line-height:1.3}.approver-option[hidden]{display:none!important}@media(max-width:1100px){.department-card-summary,.department-card-header{grid-template-columns:1fr 1fr}.department-card-summary .role-badges{grid-column:1/-1}}
.create-absence-type-card{margin:12px 0 18px}.create-absence-type-card summary{display:inline-flex;cursor:pointer}.absence-type-card-list{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}.absence-type-card{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.025);overflow:hidden}.absence-type-card[open]{background:rgba(255,255,255,.04)}.absence-type-card-header,.absence-type-card-summary{display:grid;grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) minmax(260px,2fr) 70px 110px;gap:12px;align-items:center}.absence-type-card-header{padding:0 14px;color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em}.absence-type-card-summary{padding:12px 14px;cursor:pointer;list-style:none}.absence-type-card-summary::-webkit-details-marker{display:none}.type-main{display:flex;flex-direction:column;gap:2px}.type-main small{color:var(--muted)}.type-rule-badges{display:flex;flex-wrap:wrap;gap:5px}.type-edit-form{margin:0 12px 12px;padding:16px;border:1px solid var(--line);border-radius:16px;background:rgba(0,0,0,.22);box-shadow:var(--shadow)}.type-edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.type-edit-grid label{color:var(--muted);font-size:12px}.type-edit-grid input,.type-edit-grid select{width:100%;margin-top:4px}@media(max-width:1100px){.absence-type-card-summary,.absence-type-card-header{grid-template-columns:1fr 1fr}.absence-type-card-summary .type-rule-badges{grid-column:1/-1}}
@media(max-width:980px){.page-hero,.calendar-toolbar{align-items:flex-start;flex-direction:column}.insight-grid{grid-template-columns:repeat(2,1fr)}.content-split{grid-template-columns:1fr}.calendar-day{min-height:118px;padding:8px}.event-type{display:none}}@media(max-width:700px){header{display:block}header nav{margin:10px 0}.insight-grid{grid-template-columns:1fr}.calendar-shell{padding:10px;border-radius:18px;overflow-x:auto}.calendar-weekdays,.calendar-grid{min-width:760px}main{padding:16px}table{font-size:13px}}
.admin-layout{display:grid;grid-template-columns:240px minmax(0,1fr);gap:18px;align-items:start}.admin-side-nav{position:sticky;top:74px;display:flex;flex-direction:column;gap:7px;padding:14px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));box-shadow:var(--shadow)}.admin-side-nav strong{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin:2px 4px 8px}.admin-side-nav a{text-decoration:none;color:var(--soft);font-weight:650;font-size:14px;padding:10px 11px;border-radius:12px;border:1px solid transparent}.admin-side-nav a:hover,.admin-side-nav a.active{background:rgba(113,112,255,.14);border-color:rgba(113,112,255,.28);color:var(--text)}.admin-content{min-width:0}.admin-section:not(.admin-section-active){display:none}.admin-section.admin-section-active{display:block}.visual-workflow-builder{margin:14px 0;padding:14px;border:1px solid rgba(113,112,255,.25);border-radius:16px;background:rgba(113,112,255,.07)}.builder-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.workflow-builder-canvas{display:flex;flex-direction:column;gap:10px}.workflow-builder-step{display:grid;grid-template-columns:36px minmax(160px,1fr) 130px minmax(170px,1fr) auto;gap:10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:14px;background:rgba(0,0,0,.18)}.workflow-builder-step.dragging{opacity:.55;border-color:rgba(113,112,255,.65)}.step-actions{display:flex;gap:5px;flex-wrap:wrap}.builder-live-bpmn{margin-top:10px;padding:10px 12px;border:1px dashed rgba(113,112,255,.35);border-radius:12px;background:rgba(0,0,0,.18);color:#dfe2ff;font-size:13px;line-height:1.45}.workflow-builder-step label{font-size:12px;color:var(--muted)}.workflow-builder-step select,.workflow-builder-step input{width:100%;margin:4px 0 0}@media(max-width:980px){.admin-layout{grid-template-columns:1fr}.admin-side-nav{position:static;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.workflow-builder-step{grid-template-columns:1fr}.workflow-builder-step .bpmn-symbol{display:none}}

.workflow-planner-shell{display:grid;gap:14px}.workflow-preset-panel,.workflow-simulation-panel,.planner-rating{border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035);padding:12px}.workflow-preset-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px;margin:10px 0}.workflow-simulation-panel{display:grid;grid-template-columns:minmax(180px,1.2fr) 120px repeat(2,minmax(150px,.8fr));gap:10px;align-items:center}.simulation-result{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:8px}.simulation-step{display:inline-flex;padding:7px 10px;border-radius:999px;border:1px solid var(--line);font-size:12px}.simulation-step.applies{background:rgba(34,197,94,.13);border-color:rgba(34,197,94,.35);color:#bbf7d0}.simulation-step.skipped{background:rgba(148,163,184,.12);border-color:rgba(148,163,184,.28);color:#cbd5e1}.workflow-warning{display:grid;gap:6px}.workflow-warning div{padding:8px 10px;border-radius:12px;background:rgba(250,204,21,.11);border:1px solid rgba(250,204,21,.28);color:#fde68a}.workflow-warning div:first-child:last-child{background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.24);color:#bbf7d0}.drag-handle{cursor:grab;color:var(--muted);font-weight:800;text-align:center}.drag-handle:active{cursor:grabbing}.technical-format{border:1px dashed var(--line);border-radius:12px;padding:10px}.technical-format textarea{width:100%;margin:8px 0}.planner-rating{margin:12px}.planner-rating ul{margin:8px 0 0 18px;color:var(--muted)}@media(max-width:980px){.workflow-simulation-panel{grid-template-columns:1fr}}

.workflow-planner-guide{margin:14px 0;padding:14px;border:1px solid rgba(113,112,255,.28);border-radius:16px;background:rgba(113,112,255,.08)}.workflow-planner-guide ol{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;list-style:none;padding:0;margin:10px 0 0}.workflow-planner-guide li{padding:10px;border:1px solid var(--line);border-radius:12px;background:rgba(0,0,0,.18)}.workflow-planner-guide span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.workflow-preset-grid button{text-align:left;white-space:normal}.simulation-step{flex-direction:column;align-items:flex-start;gap:2px}.simulation-step small{color:inherit;opacity:.86}.step-actions .btn span{font-size:11px}@media(max-width:1200px){.step-actions .btn span{display:none}}

.workflow-diagram-editor{border:1px solid rgba(113,112,255,.34);border-radius:18px;background:radial-gradient(circle at 20% 0,rgba(113,112,255,.16),transparent 24rem),rgba(0,0,0,.18);padding:14px}.diagram-toolbar{display:flex;align-items:center;gap:10px;justify-content:space-between;flex-wrap:wrap;margin-bottom:10px}.diagram-help{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}.diagram-help span{font-size:12px;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:5px 8px;background:rgba(255,255,255,.03)}.diagram-stage{overflow-x:auto;padding:10px;border:1px dashed rgba(255,255,255,.12);border-radius:14px;background:rgba(0,0,0,.16)}.diagram-nodes,.diagram-arrows{display:flex;align-items:center;gap:14px;min-width:max-content}.diagram-arrows{margin:8px 74px 0}.diagram-node{min-width:150px;min-height:86px;border:1px solid rgba(255,255,255,.16);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025));color:var(--text);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 12px 28px rgba(0,0,0,.24);cursor:grab}.diagram-node span{font-size:24px}.diagram-node small{color:var(--muted);font-size:11px;max-width:130px}.diagram-node-start{border-color:rgba(34,197,94,.38);background:rgba(34,197,94,.09)}.diagram-node-end{border-color:rgba(113,112,255,.42);background:rgba(113,112,255,.10)}.diagram-node-step{border-color:rgba(255,255,255,.22)}.diagram-node.dragging{opacity:.55;outline:2px solid var(--accent)}.diagram-arrow{min-width:150px;border:1px solid rgba(113,112,255,.28);border-radius:999px;background:rgba(113,112,255,.10);color:#dfe2ff;padding:7px 10px;display:flex;align-items:center;justify-content:center;gap:7px;cursor:pointer}.diagram-arrow span{font-size:22px}.diagram-arrow small{font-size:11px;color:#c7d2fe}.workflow-builder-step.step-focus{outline:2px solid var(--accent);background:rgba(113,112,255,.14)}@media(max-width:900px){.diagram-node{min-width:130px}.diagram-arrow{min-width:120px}.diagram-arrows{margin-left:60px}}

.diagram-stage{position:relative}.diagram-edge-layer{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 10px}.diagram-edge{display:inline-flex;align-items:center;gap:5px;padding:5px 8px;border-radius:999px;background:rgba(14,165,233,.12);border:1px solid rgba(14,165,233,.32);color:#bae6fd;font-size:12px}.diagram-edge-list{display:flex;gap:7px;flex-wrap:wrap;margin-top:10px}.diagram-edge-chip{border:1px solid rgba(14,165,233,.30);background:rgba(14,165,233,.10);color:#bae6fd;border-radius:999px;padding:6px 9px;cursor:pointer}.diagram-link-mode{outline:2px solid rgba(14,165,233,.35);outline-offset:3px}.diagram-link-mode .diagram-node{cursor:crosshair}.diagram-node.selected-source{outline:3px solid #38bdf8;box-shadow:0 0 0 6px rgba(56,189,248,.16),0 12px 28px rgba(0,0,0,.24)}
.diagram-edge-svg{width:100%;height:32px;display:block;margin:0 0 8px;overflow:visible}.diagram-arrow-line{stroke:#38bdf8;stroke-width:2.2;stroke-linecap:round;filter:drop-shadow(0 0 5px rgba(56,189,248,.35))}.diagram-edge-svg marker path{fill:#38bdf8}

.diagram-stage{position:relative}.diagram-edge-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}.diagram-nodes,.diagram-arrows,.diagram-edge-layer,.diagram-edge-list{position:relative;z-index:1}.diagram-arrow-line{stroke:#38bdf8;stroke-width:2.4;stroke-linecap:round;pointer-events:none}

.bpmn-palette{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:10px 0;padding:10px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.035)}.bpmn-palette strong{margin-right:4px}.diagram-node-task{border-color:rgba(255,255,255,.22)}.diagram-node-gateway{border-color:rgba(250,204,21,.45);background:rgba(250,204,21,.10)}.diagram-node-gateway span{color:#fde68a}.diagram-node-parallel{border-color:rgba(168,85,247,.48);background:rgba(168,85,247,.12)}.diagram-node-parallel span{color:#e9d5ff}

.diagram-free-canvas{min-height:360px;overflow:auto}.diagram-free-canvas .diagram-nodes{position:relative;min-height:320px;min-width:980px}.diagram-free-canvas .diagram-node{position:absolute;transition:box-shadow .12s ease, transform .12s ease}.diagram-free-canvas .diagram-node.dragging{transform:scale(1.02);z-index:3}.diagram-free-canvas .diagram-arrows{display:none}.diagram-free-canvas .diagram-edge-svg{min-height:360px}

.bpmn-inspector{margin:10px 0 18px;padding:12px;border:1px solid rgba(56,189,248,.28);border-radius:14px;background:rgba(14,165,233,.08);display:grid;gap:10px;scroll-margin-bottom:120px}.bpmn-inspector small{display:block;color:var(--muted);margin-top:2px}.inspector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;align-items:end}.inspector-grid label{font-size:12px;color:var(--muted)}.inspector-grid input{width:100%;margin:4px 0 0}.inspector-actions{display:flex;gap:8px;flex-wrap:wrap}.btn.danger{border-color:rgba(239,68,68,.35);color:#fecaca}.diagram-node.selected-node{outline:3px solid #facc15;box-shadow:0 0 0 7px rgba(250,204,21,.14),0 12px 28px rgba(0,0,0,.24)}.diagram-edge-chip.selected-edge,.diagram-edge.selected-edge{outline:2px solid #facc15;border-color:rgba(250,204,21,.55);background:rgba(250,204,21,.14);color:#fef3c7}.diagram-arrow-line.selected-edge{stroke:#facc15;stroke-width:3.4;filter:drop-shadow(0 0 7px rgba(250,204,21,.45))}

.diagram-comfort-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:10px 0;padding:10px;border:1px solid rgba(168,85,247,.28);border-radius:14px;background:rgba(168,85,247,.08)}.diagram-comfort-toolbar output{min-width:48px;text-align:center;color:#e9d5ff;font-weight:700}.diagram-free-canvas.snap-grid{background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);background-size:20px 20px}.diagram-free-canvas .diagram-nodes{transform-origin:0 0}.bpmn-minimap{position:absolute;right:12px;top:12px;width:160px;height:96px;border:1px solid rgba(255,255,255,.18);border-radius:12px;background:rgba(8,9,10,.78);backdrop-filter:blur(10px);z-index:4;overflow:hidden;box-shadow:0 12px 28px rgba(0,0,0,.34)}.minimap-node{position:absolute;width:8px;height:8px;border-radius:999px;background:#38bdf8;box-shadow:0 0 0 2px rgba(56,189,248,.18)}.minimap-viewport{position:absolute;left:0;top:0;min-width:28px;min-height:18px;border:1px solid #facc15;background:rgba(250,204,21,.08);border-radius:6px;pointer-events:none}

.diagram-node-event{border-radius:999px;min-width:82px;min-height:82px;border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.10)}.diagram-node-event span{color:#bbf7d0}.diagram-node-boundary{min-width:58px;min-height:58px;border-style:dashed;border-color:rgba(248,113,113,.60);background:rgba(248,113,113,.10)}.diagram-node-boundary span{color:#fecaca}.diagram-node-service{border-color:rgba(56,189,248,.42);background:rgba(56,189,248,.09)}.diagram-node-service span{color:#bae6fd}

.workflow-editor-open{overflow:hidden}.modeler-overlay-active{position:fixed!important;inset:18px;z-index:1000;margin:0!important;padding:16px!important;display:grid!important;grid-template-rows:auto auto auto auto minmax(0,1fr) auto auto auto;gap:12px;overflow:auto;background:linear-gradient(180deg,rgba(15,16,17,.98),rgba(8,9,10,.98));border:1px solid rgba(113,112,255,.45);border-radius:22px;box-shadow:0 40px 120px rgba(0,0,0,.72),0 0 0 9999px rgba(0,0,0,.64)}.modeler-overlay-header{position:sticky;top:0;z-index:8;margin:-4px -4px 0;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(15,16,17,.94);backdrop-filter:blur(16px)}.modeler-overlay-active .workflow-diagram-editor{min-height:calc(100vh - 220px);display:grid;grid-template-rows:auto auto auto auto minmax(0,1fr);overflow:hidden}.modeler-overlay-active .diagram-stage{min-height:560px;height:65vh;overflow:auto}.modeler-overlay-active .diagram-free-canvas .diagram-nodes{min-height:900px;min-width:1800px}.modeler-overlay-active [data-close-workflow-overlay],.modeler-overlay-active [data-overlay-save-workflow]{display:inline-flex}.visual-workflow-builder:not(.modeler-overlay-active) [data-close-workflow-overlay],.visual-workflow-builder:not(.modeler-overlay-active) [data-overlay-save-workflow]{display:none}.modeler-overlay-active .bpmn-inspector{position:sticky;bottom:0;z-index:7;background:rgba(12,19,27,.96);backdrop-filter:blur(14px)}.modeler-overlay-active .workflow-builder-canvas{max-height:180px;overflow:auto;border:1px solid var(--line);border-radius:14px;padding:8px;background:rgba(0,0,0,.18)}@media(max-width:900px){.modeler-overlay-active{inset:8px;border-radius:16px}.modeler-overlay-active .diagram-stage{height:55vh}.modeler-overlay-header span{display:flex;flex-wrap:wrap;gap:6px}}

.beta-label{display:inline-flex;align-items:center;gap:4px;margin-left:6px;padding:2px 7px;border-radius:999px;background:rgba(245,158,11,.16);color:#fbbf24;border:1px solid rgba(245,158,11,.35);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.feature-disabled-card{padding:22px;border:1px dashed rgba(245,158,11,.45);border-radius:18px;background:rgba(245,158,11,.08);display:grid;gap:10px}.feature-disabled-card h3{margin:0}.feature-disabled-card p{max-width:760px}


/* Positive UX refresh */
.skip-link{position:absolute;left:-999px;top:8px;z-index:9999;background:#fff;color:#111;padding:10px 14px;border-radius:10px}.skip-link:focus{left:12px}.app-shell{min-height:100vh}.app-header{position:sticky;top:0;z-index:30;background:rgba(8,9,10,.82);backdrop-filter:blur(22px);border-bottom:1px solid var(--line);padding:12px 24px;display:flex;gap:18px;align-items:center}.brand{display:flex;align-items:center;gap:10px;text-decoration:none;min-width:210px}.brand-mark{width:34px;height:34px;border-radius:12px;background:linear-gradient(135deg,#7170ff,#10b981);display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:900;box-shadow:0 12px 30px rgba(113,112,255,.32)}.brand small{display:block;color:var(--muted);font-size:11px;margin-top:1px}.main-nav{display:flex;gap:6px;align-items:center;flex:1;flex-wrap:wrap}.main-nav a{display:inline-flex;align-items:center;gap:7px;text-decoration:none;color:var(--soft);font-size:13px;font-weight:650;padding:8px 10px;border-radius:12px;border:1px solid transparent}.main-nav a:hover,.main-nav a.nav-active{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.09);color:var(--text)}.nav-icon{opacity:.9}.nav-primary-action{background:linear-gradient(135deg,rgba(113,112,255,.22),rgba(16,185,129,.16));border-color:rgba(113,112,255,.32)!important;color:#fff!important}.user-actions{display:flex;align-items:center;gap:10px}.current-user-pill{display:inline-flex;align-items:center;max-width:210px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid var(--line);border-radius:999px;padding:7px 10px;background:rgba(255,255,255,.04);color:var(--soft);font-size:13px}.main-content{padding:30px;max-width:1360px;margin:auto}.dashboard-welcome{padding:10px 0 4px}.happy-card{background:linear-gradient(180deg,rgba(16,185,129,.13),rgba(255,255,255,.025));border-color:rgba(16,185,129,.28)}.quick-actions{margin:18px 0}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:12px}.action-card{display:flex;gap:12px;align-items:flex-start;text-decoration:none;padding:14px;border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.035);transition:transform .16s ease,border-color .16s ease,background .16s ease}.action-card:hover{transform:translateY(-2px);border-color:rgba(113,112,255,.38);background:rgba(113,112,255,.08)}.action-card span{width:34px;height:34px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(113,112,255,.14);color:#dfe2ff;font-weight:800}.action-card strong{display:block}.action-card small{display:block;color:var(--muted);margin-top:3px}.content-split{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:16px}.soft-list-row{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid var(--line-soft);border-radius:14px;background:rgba(255,255,255,.025);margin:8px 0}.soft-list-row small{display:block;color:var(--muted);margin-top:2px}.positive-empty-state{padding:22px;border:1px dashed rgba(16,185,129,.36);border-radius:18px;background:linear-gradient(180deg,rgba(16,185,129,.10),rgba(255,255,255,.02));color:var(--soft)}.positive-empty-state strong{display:block;color:var(--text);font-size:17px;margin-bottom:5px}.positive-empty-state p{color:var(--muted);margin:0 0 12px}.request-card-list,.approval-card-list{display:grid;gap:12px}.request-card,.approval-card{border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));box-shadow:0 18px 50px rgba(0,0,0,.22)}.request-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;gap:12px;align-items:center;text-decoration:none;padding:14px}.request-card:hover{border-color:rgba(113,112,255,.38);background:rgba(113,112,255,.07)}.request-card-main small,.approval-card small{display:block;color:var(--muted);margin-top:3px}.compact-list .request-card{box-shadow:none}.status-dot{width:12px;height:12px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 4px rgba(113,112,255,.13)}.status-approved{background:var(--green);box-shadow:0 0 0 4px rgba(16,185,129,.14)}.status-rejected{background:var(--red);box-shadow:0 0 0 4px rgba(239,68,68,.14)}.status-requested,.status-in_approval{background:var(--yellow);box-shadow:0 0 0 4px rgba(245,158,11,.14)}.approval-card{padding:14px}.approval-card-body{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center}.approval-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.approval-actions form{display:flex;gap:8px}.approval-actions input{flex:1}.guided-form{display:grid;gap:16px;max-width:940px}.form-step{padding:16px;border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.025)}.step-label{display:inline-flex;margin-bottom:8px;border-radius:999px;padding:4px 9px;background:rgba(113,112,255,.14);color:#dfe2ff;border:1px solid rgba(113,112,255,.30);font-size:12px;font-weight:800}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.form-grid label{color:var(--muted);font-size:12px}.form-grid input,.form-grid select,.form-grid textarea{width:100%;margin:5px 0 0}.friendly-hint{color:#bbf7d0;background:rgba(16,185,129,.09);border:1px solid rgba(16,185,129,.24);border-radius:12px;padding:10px 12px}.friendly-error{border:1px solid rgba(239,68,68,.35);border-radius:14px;background:rgba(239,68,68,.10);padding:12px;margin:12px 0}.sticky-actions{position:sticky;bottom:14px;padding:12px;border:1px solid var(--line);border-radius:16px;background:rgba(15,16,17,.88);backdrop-filter:blur(16px)}@media(max-width:980px){.app-header{align-items:flex-start;flex-direction:column}.brand{min-width:0}.user-actions{width:100%;justify-content:space-between}.content-split{grid-template-columns:1fr}.request-card{grid-template-columns:auto 1fr}.request-card .btn,.request-card .status-badge{grid-column:2}.approval-actions{grid-template-columns:1fr}.main-content{padding:18px}}@media(max-width:720px){.nav-label{display:none}.main-nav a{padding:9px}.nav-primary-action .nav-label{display:inline}.action-grid,.insight-grid{grid-template-columns:1fr}}

/* UX polish after visual review */
:root{--muted:#a7afbd;--soft:#e1e7f0}.metric-card strong{font-size:clamp(25px,3.2vw,34px);line-height:1.05}.request-card strong,.approval-card strong{letter-spacing:-.015em}.request-card small,.approval-card small,.action-card small{color:#b5bdca}.main-nav a[href="/admin"],.main-nav a[href="/system"]{opacity:.86}.main-nav a[href="/admin"] .nav-label,.main-nav a[href="/system"] .nav-label{font-size:12px}.positive-metrics .metric-card:last-child{border-color:rgba(113,112,255,.30);background:linear-gradient(180deg,rgba(113,112,255,.12),rgba(255,255,255,.025))}

/* Connected calendar ranges */
.calendar-grid[data-connected-calendar-grid]{display:block;border-top:1px solid var(--line);border-left:1px solid var(--line);background:rgba(0,0,0,.14)}.calendar-week-row{position:relative;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));border-bottom:1px solid var(--line);min-width:760px}.calendar-week-row .calendar-day{border-top:0;border-left:0;border-bottom:0;min-height:156px;padding-top:44px}.calendar-segment-layer{position:absolute;left:0;right:0;top:8px;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));grid-auto-rows:30px;gap:4px 0;padding:0 6px;z-index:3;pointer-events:none}.calendar-range-segment{grid-column:var(--segment-column) / span var(--segment-span);display:flex;align-items:center;gap:7px;min-width:0;height:28px;padding:5px 10px;text-decoration:none;color:#fff;background:linear-gradient(90deg,color-mix(in srgb,var(--person-color) 72%,#111827),color-mix(in srgb,var(--event-color) 48%,#111827));border:1px solid color-mix(in srgb,var(--person-color) 70%,rgba(255,255,255,.18));box-shadow:0 10px 24px rgba(0,0,0,.30);font-size:12px;font-weight:700;pointer-events:auto;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.calendar-range-segment strong,.calendar-range-segment span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.calendar-range-start{border-top-left-radius:999px;border-bottom-left-radius:999px}.calendar-range-end{border-top-right-radius:999px;border-bottom-right-radius:999px}.calendar-range-continued:not(.calendar-range-start){border-top-left-radius:6px;border-bottom-left-radius:6px}.calendar-range-continued:not(.calendar-range-end){border-top-right-radius:6px;border-bottom-right-radius:6px}.calendar-range-segment.pending-preview{border-style:dashed;opacity:.78}.calendar-range-segment .employee-avatar.small{width:20px;height:20px;font-size:10px;flex:0 0 auto}.calendar-day .day-events{margin-top:2px}@media(max-width:700px){.calendar-grid[data-connected-calendar-grid]{overflow-x:auto}.calendar-week-row{min-width:760px}}

/* Connected calendar range polish */
.calendar-week-row .calendar-day{padding-top:112px}.calendar-segment-layer{grid-auto-rows:32px}.calendar-range-segment{grid-row:var(--segment-lane);height:30px}.calendar-range-segment small{margin-left:auto;opacity:.9;font-weight:650;color:rgba(255,255,255,.86);font-size:11px}.calendar-week-row .day-number{position:absolute;top:8px;right:10px;z-index:4;background:rgba(8,9,10,.72);border:1px solid rgba(255,255,255,.08);border-radius:999px;min-width:24px;text-align:center;padding:2px 6px}.calendar-week-row .day-detail summary{font-size:0}.calendar-week-row .day-detail summary::after{content:'Details';font-size:11px;color:var(--muted)}

/* Connected range final readability polish */
.calendar-segment-layer{top:36px}.calendar-week-row .calendar-day{padding-top:146px}.calendar-week-row .day-number{top:7px;left:10px;right:auto;z-index:5}.calendar-week-row .day-detail{display:none}.calendar-range-segment{height:31px}.calendar-range-segment small{display:none}.calendar-range-segment[style*="--segment-span: 4"] small,.calendar-range-segment[style*="--segment-span: 5"] small,.calendar-range-segment[style*="--segment-span: 6"] small,.calendar-range-segment[style*="--segment-span: 7"] small{display:inline}

/* Registration/auth UX */
.auth-shell{display:grid;place-items:center;min-height:calc(100vh - 180px);padding:24px}.auth-card{width:min(520px,100%);padding:28px}.register-card{width:min(620px,100%)}.auth-form{display:grid;gap:14px;margin-top:18px}.auth-form label{font-weight:750;color:var(--text)}.auth-form input{width:100%;margin-top:6px}.auth-switch{margin-top:18px;color:var(--muted)}.auth-switch a{color:#9dd7ff;font-weight:800}.auth-card .primary{width:100%;justify-content:center}

.security-note{display:grid;gap:4px;margin:14px 0;padding:12px 14px;border:1px solid rgba(125,211,252,.28);background:rgba(14,165,233,.10);border-radius:14px;color:#d8f3ff}.security-note span,.auth-form small{color:#b7c3d2}.auth-form small{display:block;margin-top:4px;font-weight:600}

.approval-pending-label{display:inline-flex;align-items:center;gap:6px;margin-top:6px;padding:5px 8px;border:1px solid rgba(251,191,36,.45);background:rgba(251,191,36,.13);border-radius:999px;color:#fde68a;font-size:12px;font-weight:900;letter-spacing:.01em}.approval-pending-label::before{content:"⏳"}

.user-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inline-activate-form{display:inline;margin:0}.inline-activate-form .btn{padding:7px 10px}


/* Clear pending calendar status */
.calendar-range-segment.pending-preview,
.period-bar.pending-preview{
  border-style:dashed;
  border-width:2px;
  border-color:rgba(251,191,36,.9);
  background:linear-gradient(90deg,rgba(251,191,36,.22),rgba(251,191,36,.10));
  box-shadow:0 0 0 1px rgba(251,191,36,.18),0 8px 22px rgba(251,191,36,.12);
}
.calendar-range-segment.pending-preview::before,
.period-bar.pending-preview::before{
  content:'⏳';
  display:inline-grid;
  place-items:center;
  width:18px;
  height:18px;
  border-radius:999px;
  background:rgba(251,191,36,.24);
  color:#fde68a;
  font-size:11px;
  margin-right:2px;
  flex:0 0 auto;
}
.pending-status-pill{
  display:inline-flex;
  align-items:center;
  gap:4px;
  margin-left:8px;
  padding:3px 8px;
  border-radius:999px;
  background:rgba(251,191,36,.20);
  border:1px solid rgba(251,191,36,.55);
  color:#fde68a;
  font-size:10px;
  font-weight:900;
  letter-spacing:.02em;
  text-transform:uppercase;
  white-space:nowrap;
}
.period-bar.pending-preview .period-bar-fill{background:linear-gradient(90deg,rgba(251,191,36,.85),rgba(251,191,36,.38))}
.status-legend .preview-sample{border-style:dashed;border-color:rgba(251,191,36,.9);background:rgba(251,191,36,.22)}
@media(max-width:900px){.pending-status-pill{font-size:9px;padding:2px 6px;margin-left:4px}.calendar-range-segment.pending-preview::before{display:none}}


/* Pending single-day calendar cards */
.calendar-event.pending-preview{
  min-height:54px;
  border-style:dashed;
  border-width:1.5px;
  border-color:rgba(251,191,36,.75);
  background:rgba(251,191,36,.13);
  color:#fff7ed;
}
.calendar-event.pending-preview .preview-badge{
  display:inline-flex;
  align-items:center;
  width:max-content;
  margin-left:6px;
  padding:2px 6px;
  border-radius:999px;
  background:rgba(251,191,36,.22);
  border:1px solid rgba(251,191,36,.5);
  color:#fde68a;
  font-size:9px;
  font-weight:900;
  text-transform:uppercase;
  white-space:nowrap;
}
.calendar-event.pending-preview .event-type{color:#fde68a;font-weight:800}


/* Expanded request cancellation UX */
.request-detail-grid{align-items:start}.detail-list{display:grid;gap:10px;margin:0}.detail-list div{display:grid;grid-template-columns:150px 1fr;gap:12px;padding:10px 0;border-bottom:1px solid var(--line-soft)}.detail-list dt{color:var(--muted);font-weight:800}.detail-list dd{margin:0;color:var(--text)}.cancellation-card{border-color:rgba(251,191,36,.28);background:linear-gradient(180deg,rgba(251,191,36,.08),rgba(255,255,255,.025))}.stacked-form{display:grid;gap:12px}.stacked-form textarea{min-height:96px}.cancellation-approval-card{border-color:rgba(251,191,36,.36);background:linear-gradient(180deg,rgba(251,191,36,.08),rgba(255,255,255,.025))}.cancellation-badge{display:inline-flex;margin:0 0 6px;background:rgba(251,191,36,.16);border-color:rgba(251,191,36,.45);color:#fde68a}.approval-reason{margin:8px 0 0;color:var(--soft)}


/* Withdrawn request state */
.withdrawn-request{opacity:.72;border-style:dashed}.withdrawn-request .status-dot{background:#94a3b8}.withdrawn-request .status-badge{background:rgba(148,163,184,.16);border-color:rgba(148,163,184,.38);color:#cbd5e1}


/* Calendar filter overhaul */
.calendar-filters{align-items:end}.filter-header{display:flex;flex-direction:column;gap:3px;min-width:170px}.active-filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;grid-column:1/-1}.filter-active-label{font-size:12px;font-weight:900;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.active-filter-chip{display:inline-flex;align-items:center;border:1px solid rgba(125,211,252,.35);background:rgba(125,211,252,.12);color:#bae6fd;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:850}.calendar-filter-empty{margin:14px 0 18px;border-style:dashed}


/* Security/privacy UI helpers */
.privacy-note{margin:10px 0 0;color:#b7c3d2;font-size:13px;font-weight:700}.privacy-note::before{content:"🔒 ";color:#7dd3fc}.table-status{display:inline-flex;white-space:nowrap;line-height:1.1}


/* Responsive form and table overflow guards */
html,body{max-width:100%;overflow-x:hidden}.panel,.card,.calendar-filters,.guided-form,.auth-card{max-width:100%;min-width:0}.panel{overflow-x:auto}.modern-table{width:100%;max-width:100%;border-collapse:collapse}.modern-table th,.modern-table td{overflow-wrap:anywhere}.content-split{min-width:0}.content-split>*{min-width:0}@media(max-width:700px){.modern-table{min-width:620px}.panel:has(.modern-table){overflow-x:auto;-webkit-overflow-scrolling:touch}.calendar-shell{max-width:100%}.calendar-week-row{min-width:680px}.calendar-weekdays,.calendar-grid{min-width:680px}.page-hero{min-width:0}.hero-actions .btn{flex:1 1 auto;text-align:center}.calendar-filters{grid-template-columns:1fr!important}.calendar-filters label,.calendar-filters select,.calendar-filters .btn{width:100%}}


/* Mobile form comfort polish */
@media(max-width:700px){input,select,textarea,button,.btn{min-height:44px}.auth-form label,.guided-form label,.admin-form label,.calendar-filters label{display:block;margin-bottom:12px}.auth-form input,.guided-form input,.guided-form select,.guided-form textarea,.admin-form input,.admin-form select,.calendar-filters select{font-size:16px}.guided-form .form-step,.auth-card,.admin-form{padding:16px}.form-actions,.sticky-actions,.approval-actions{gap:10px}.form-actions .btn,.sticky-actions .btn,.approval-actions button{width:100%}.admin-layout{grid-template-columns:1fr}.admin-side-nav{position:static;display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.user-card-header,.user-card-summary{grid-template-columns:1fr;gap:8px}.user-actions{justify-content:flex-start}.approval-actions form{width:100%}.approval-actions input{width:100%;margin-bottom:8px}}


/* Admin role and permission management */
.role-card-list{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}.role-card{border:1px solid var(--line);border-radius:16px;background:rgba(255,255,255,.025);overflow:hidden}.role-card[open]{background:rgba(255,255,255,.04)}.role-card-header,.role-card-summary{display:grid;grid-template-columns:minmax(170px,1fr) minmax(130px,.8fr) minmax(260px,2fr) 110px;gap:12px;align-items:center;padding:10px 12px}.role-card-header{color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}.role-edit-form{padding:14px;border-top:1px solid var(--line);display:grid;gap:12px}.role-edit-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.permission-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:8px}.permission-option{align-items:flex-start}.permission-option small{display:block;color:var(--muted);font-weight:500;margin-top:2px}@media(max-width:700px){.role-card-header{display:none}.role-card-summary{grid-template-columns:1fr}.permission-grid{grid-template-columns:1fr}}


/* Role department scope picker */
.department-scope-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:10px;margin:10px 0 14px}.department-scope-grid.compact{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}

/* Smartphone UX polish */
button,.btn,a,input,select,textarea,summary{touch-action:manipulation}
@media(max-width:760px){
  body{background:radial-gradient(circle at 18% -8%,rgba(113,112,255,.16),transparent 18rem),var(--bg)}
  .app-header{position:static;display:grid;grid-template-columns:1fr;gap:10px;padding:12px 14px;background:rgba(8,9,10,.95)}
  .brand{min-width:0;width:100%;gap:9px}.brand-mark{width:32px;height:32px;border-radius:10px}.brand small{font-size:10px}.brand strong{font-size:15px}
  .main-nav{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;padding:2px 0 8px;margin:0 -2px;mask-image:linear-gradient(90deg,#000 88%,transparent)}
  .main-nav a{flex:0 0 auto;scroll-snap-align:start;min-height:42px;padding:9px 11px;border-radius:999px;background:rgba(255,255,255,.045);border-color:rgba(255,255,255,.08)}
  .main-nav .nav-primary-action{box-shadow:0 8px 20px rgba(113,112,255,.20)}
  .nav-label{white-space:nowrap;font-size:12px}.nav-icon{font-size:15px}
  .user-actions{width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.current-user-pill{max-width:100%;min-width:0;overflow:hidden;text-overflow:ellipsis}.user-actions form{margin:0}.user-actions .btn{min-height:40px}
  .main-content{padding:16px 12px 24px;max-width:100%}
  h1{font-size:clamp(28px,10vw,38px);line-height:1.04}h2{font-size:21px}h3{font-size:16px}
  .page-hero{display:grid;gap:12px;align-items:start;margin:2px 0 16px}.hero-copy{font-size:15px;line-height:1.5}.hero-actions,.toolbar-actions{display:grid;grid-template-columns:1fr;gap:8px;width:100%}.hero-actions .btn,.toolbar-actions .btn{width:100%;justify-content:center;text-align:center}
  .card,.panel,.metric-card{border-radius:16px;padding:16px;margin:10px 0;box-shadow:0 16px 44px rgba(0,0,0,.32)}
  .insight-grid,.positive-metrics{grid-template-columns:1fr!important;gap:10px}.metric-card strong{font-size:30px}
  .action-grid{grid-template-columns:1fr!important}.action-card{min-height:auto;padding:14px}.request-card,.approval-card{grid-template-columns:1fr!important;gap:10px}.request-card .btn,.approval-card .btn{width:100%;justify-content:center}
  input,select,textarea,button,.btn{min-height:46px;font-size:16px}input,select,textarea{width:100%;margin:6px 0 0}.auth-shell{min-height:calc(100dvh - 96px);padding:14px}.auth-card{padding:20px;border-radius:20px}.login-card{margin:4vh auto 0;width:100%}.auth-form{gap:12px}
  .guided-form,.stacked-form{gap:12px}.form-step{padding:14px;border-radius:16px}.form-actions,.sticky-actions,.approval-actions{display:grid;grid-template-columns:1fr;width:100%}.form-actions .btn,.sticky-actions .btn,.approval-actions button{width:100%}
  .content-split,.request-detail-grid{grid-template-columns:1fr!important}.detail-list div{grid-template-columns:1fr;gap:4px}.period-scale{font-size:11px}.period-bar-label{font-size:12px;line-height:1.25}
  .calendar-toolbar{display:grid;gap:10px}.calendar-shell{padding:10px;border-radius:16px;overflow-x:auto}.calendar-weekdays,.calendar-grid,.calendar-week-row{min-width:640px}.calendar-week-row .calendar-day{min-height:128px;padding-top:126px}.calendar-range-segment{font-size:11px;padding:5px 8px}.calendar-filters{grid-template-columns:1fr!important;padding:12px}.active-filter-row{align-items:flex-start}
  .admin-layout{grid-template-columns:1fr!important;gap:12px}.admin-side-nav{position:static;display:grid;grid-auto-flow:column;grid-auto-columns:max-content;overflow-x:auto;gap:8px;padding:10px;border-radius:16px;-webkit-overflow-scrolling:touch}.admin-side-nav strong{display:none}.admin-side-nav a{white-space:nowrap;min-height:42px;display:inline-flex;align-items:center}.admin-form,.admin-form.wide{grid-template-columns:1fr!important;padding:12px}.admin-section{scroll-margin-top:10px}.user-card-header,.role-card-header,.department-card-header,.absence-type-card-header{display:none}.user-card-summary,.role-card-summary,.department-card-summary,.absence-type-card-summary{grid-template-columns:1fr!important;gap:8px;padding:14px}.user-edit-form,.role-edit-form,.department-edit-form,.type-edit-form{margin:0 8px 10px;padding:12px}.permission-grid,.department-scope-grid,.approver-picker{grid-template-columns:1fr!important}.check-grid{display:grid;grid-template-columns:1fr}.check-grid .check,.permission-option,.approver-option{border-radius:14px;padding:10px}
  .panel:has(.modern-table){overflow-x:auto;-webkit-overflow-scrolling:touch}.modern-table{min-width:620px}.modern-table th,.modern-table td{padding:10px 11px;font-size:13px}
}
@media(max-width:420px){
  .main-content{padding-inline:10px}.app-header{padding-inline:10px}.brand small{display:none}.main-nav a{padding:9px 10px}.nav-label{font-size:11px}.current-user-pill{font-size:12px}.card,.panel,.metric-card{padding:14px}.calendar-weekdays,.calendar-grid,.calendar-week-row{min-width:600px}.modern-table{min-width:560px}
}

/* Smartphone requests refinement */
.request-mobile-meta{display:none}.request-status-row,.request-card-actions{display:inline-flex;align-items:center;gap:8px}
@media(max-width:760px){
  .request-card-list{display:grid;gap:10px}.request-card{grid-template-columns:1fr!important;align-items:start;padding:15px;border-radius:18px;gap:10px;position:relative}.request-card>.status-dot{position:absolute;left:14px;top:18px}.request-card-main{padding-left:18px;display:grid;gap:5px;min-width:0}.request-card-main strong{font-size:17px;line-height:1.2}.request-card-main small{font-size:13px;line-height:1.35;overflow-wrap:anywhere}.request-mobile-meta{display:inline-flex;color:#d8f3ff;font-size:12px;font-weight:800}.request-status-row{padding-left:18px}.request-card-actions{width:100%;padding-left:18px}.request-card-actions .btn{width:100%;justify-content:center}.request-card>.btn{display:none}
  .calendar-filters{margin-bottom:10px}.calendar-filters .filter-header{min-width:0}.content-split .panel{overflow-x:auto}.legend-list{display:flex;flex-wrap:wrap;gap:8px}.legend-item{max-width:100%;overflow-wrap:anywhere}
}
@media(max-width:420px){.request-card-main strong{font-size:16px}}
