/*
 * Phase 1.1.11 — Kanit self-host ready font-face
 * โหลด Kanit จาก public/assets/fonts/kanit/*.ttf ก่อน แล้ว fallback เป็น local()/system font
 * หมายเหตุ: ไม่แนบไฟล์ฟอนต์ในแพ็ก ผู้ใช้ต้องวางไฟล์ฟอนต์เองตาม path นี้
 */
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Thin"),local("Kanit-Thin"),url("../fonts/kanit/Kanit-Thin.ttf") format("truetype");font-weight:100;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Thin Italic"),local("Kanit-ThinItalic"),url("../fonts/kanit/Kanit-ThinItalic.ttf") format("truetype");font-weight:100;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit ExtraLight"),local("Kanit-ExtraLight"),url("../fonts/kanit/Kanit-ExtraLight.ttf") format("truetype");font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit ExtraLight Italic"),local("Kanit-ExtraLightItalic"),url("../fonts/kanit/Kanit-ExtraLightItalic.ttf") format("truetype");font-weight:200;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Light"),local("Kanit-Light"),url("../fonts/kanit/Kanit-Light.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Light Italic"),local("Kanit-LightItalic"),url("../fonts/kanit/Kanit-LightItalic.ttf") format("truetype");font-weight:300;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Regular"),local("Kanit-Regular"),local("Kanit"),url("../fonts/kanit/Kanit-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Italic"),local("Kanit-Italic"),url("../fonts/kanit/Kanit-Italic.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium"),local("Kanit-Medium"),url("../fonts/kanit/Kanit-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium Italic"),local("Kanit-MediumItalic"),url("../fonts/kanit/Kanit-MediumItalic.ttf") format("truetype");font-weight:500;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium"),local("Kanit-Medium"),url("../fonts/kanit/Kanit-Medium.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium Italic"),local("Kanit-MediumItalic"),url("../fonts/kanit/Kanit-MediumItalic.ttf") format("truetype");font-weight:600;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium"),local("Kanit-Medium"),url("../fonts/kanit/Kanit-Medium.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium Italic"),local("Kanit-MediumItalic"),url("../fonts/kanit/Kanit-MediumItalic.ttf") format("truetype");font-weight:700;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium"),local("Kanit-Medium"),url("../fonts/kanit/Kanit-Medium.ttf") format("truetype");font-weight:800;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium Italic"),local("Kanit-MediumItalic"),url("../fonts/kanit/Kanit-MediumItalic.ttf") format("truetype");font-weight:800;font-style:italic;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium"),local("Kanit-Medium"),url("../fonts/kanit/Kanit-Medium.ttf") format("truetype");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"GovLeave Kanit";src:local("Kanit Medium Italic"),local("Kanit-MediumItalic"),url("../fonts/kanit/Kanit-MediumItalic.ttf") format("truetype");font-weight:900;font-style:italic;font-display:swap}


/*
 * Phase 1.1.12 — WMS-style app.css theme port
 * อิงแนว app.css ที่ผู้ใช้แนบมา: shell สะอาด, card ชัด, sidebar/topbar มืออาชีพ, responsive จริง
 * ใช้ Kanit จาก public/assets/fonts/kanit/*.ttf ก่อน โดยไม่เรียก CDN และไม่แนบไฟล์ฟอนต์
 */
:root{
  --ink:#0b1728;--muted:#607086;--line:#dbe5f0;--line-soft:#edf3f8;--paper:#ffffff;--canvas:#f4f8fb;
  --brand-950:#031a2d;--brand-900:#06243a;--brand-800:#0b3b5f;--brand-700:#0e5d89;--brand-600:#0d7fa8;--brand-500:#13a5c7;
  --brand-soft:#e8f6fb;--brand-soft-2:#f2fbfd;
  --orange:#e2742b;--orange-2:#ff9900;--orange-soft:#fff4ec;
  --green:#16815a;--green-soft:#edfdf6;--red:#bd2b2b;--red-soft:#fff1f1;--amber:#c88618;--amber-soft:#fff8e8;
  --shadow-sm:0 1px 2px rgba(6,36,58,.05);--shadow-md:0 14px 34px rgba(6,36,58,.09);--shadow-lg:0 24px 70px rgba(6,36,58,.18);
  --radius-sm:12px;--radius-md:18px;--radius-lg:24px;--radius-xl:30px;
  --focus-ring:0 0 0 4px rgba(13,127,168,.16);
  --font-sans:"GovLeave Kanit","Kanit","Noto Sans Thai",ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}
html{background:var(--canvas);scroll-behavior:smooth}
body{margin:0;min-height:100vh;font-family:var(--font-sans);background:var(--canvas);color:var(--ink);font-size:15px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-synthesis-weight:none}
a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.is-hidden{display:none!important}.hidden{display:none!important}.w-full{width:100%}.block{display:block}.min-w-0{min-width:0}.muted{color:var(--muted)}.text-center{text-align:center}.no-print{}

/* Buttons and shared controls */
.btn,.button,.btn-core{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:40px;border-radius:13px;border:1px solid transparent;padding:.64rem 1rem;font-weight:900;font-size:.88rem;line-height:1.2;white-space:nowrap;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease,color .16s ease}
.btn:hover,.button:hover,.btn-core:hover{transform:translateY(-1px)}.btn:active,.button:active,.btn-core:active{transform:translateY(0)}
.btn-primary,.button-primary{background:linear-gradient(135deg,var(--brand-800) 0%,var(--brand-700) 50%,var(--brand-500) 100%);color:#fff;border-color:rgba(14,93,137,.08);box-shadow:0 14px 28px rgba(14,93,137,.20)}
.btn-primary:hover,.button-primary:hover{box-shadow:0 20px 40px rgba(14,93,137,.26);filter:saturate(1.04)}
.btn-light,.btn-secondary,.button-secondary,.btn.ghost{background:#fff;color:#26364b;border-color:#cbd8e6;box-shadow:0 7px 18px rgba(6,36,58,.055)}
.btn-light:hover,.btn-secondary:hover,.button-secondary:hover,.btn.ghost:hover{background:#f8fbfd;border-color:#9ecddd;color:var(--brand-700)}
.btn-ghost{background:rgba(255,255,255,.16);color:#fff;border-color:rgba(255,255,255,.35);box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.btn-ghost:hover{background:rgba(255,255,255,.24);color:#fff}.btn-block{width:100%}.button-row{display:flex;gap:.7rem;flex-wrap:wrap;align-items:center}.btn-sm,.button-sm{min-height:32px;padding:.44rem .68rem;border-radius:10px;font-size:.78rem}.icon-btn{border:1px solid rgba(148,163,184,.34);background:#fff;color:#0f172a;border-radius:15px;width:44px;height:44px;display:none;place-items:center;font-size:1.25rem;box-shadow:var(--shadow-sm)}

.brand-mark{width:50px;height:50px;flex:0 0 auto;border-radius:18px;display:grid;place-items:center;color:#fff;font-weight:1000;letter-spacing:-.06em;background:linear-gradient(135deg,#ff9900 0%,#ffbf3f 42%,#1698ff 43%,#0758b8 100%);text-shadow:0 2px 5px rgba(0,0,0,.38);box-shadow:0 18px 36px rgba(255,153,0,.26),0 14px 34px rgba(14,116,214,.18)}
.required{display:inline-flex;vertical-align:middle;align-items:center;border-radius:999px;margin-left:.28rem;padding:.12rem .48rem;background:var(--red-soft);color:#be123c;font-size:.68rem;font-weight:1000}.required-mark,.form-required-mark{color:#dc2626!important;font-weight:950!important;margin-left:3px}
.alert{border-radius:18px;padding:.95rem 1rem;margin-bottom:1rem;font-weight:750}.alert-danger{background:#fff1f2;color:#be123c;border:1px solid #fecdd3}.alert ul{margin:.5rem 0 0;padding-left:1.1rem}

/* Auth layout — split-screen like the provided reference */
.auth-body,.auth-body-pro{min-height:100vh;background:#f8fbff;color:#0f172a;overflow-x:hidden}.auth-page-pro{min-height:100vh;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(440px,.92fr);background:radial-gradient(circle at 10% 10%,rgba(255,153,0,.12),transparent 28%),radial-gradient(circle at 62% 86%,rgba(14,165,233,.15),transparent 32%),linear-gradient(135deg,#ffffff 0%,#f8fbff 55%,#eef7ff 100%)}
.auth-showcase{position:relative;isolation:isolate;min-height:100vh;padding:44px clamp(28px,4vw,72px);display:flex;flex-direction:column;overflow:hidden}.auth-showcase::before{content:"";position:absolute;right:3.5vw;top:11vh;width:min(560px,45vw);height:min(560px,45vw);border-radius:44px;transform:rotate(-8deg);background:linear-gradient(rgba(37,99,235,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.055) 1px,transparent 1px),linear-gradient(135deg,rgba(255,255,255,.96),rgba(226,241,255,.82));background-size:28px 28px,28px 28px,100% 100%;border:1px solid rgba(59,130,246,.12);box-shadow:0 30px 100px rgba(15,23,42,.06);z-index:-1}.auth-showcase::after{content:"";position:absolute;inset:auto 0 0 auto;width:60%;height:42%;background:radial-gradient(circle at 70% 60%,rgba(14,165,233,.14),transparent 65%);z-index:-1}
.auth-brand-row{display:flex;align-items:center;gap:.9rem}.auth-brand-title{font-size:1.22rem;line-height:1.05;font-weight:1000;letter-spacing:-.03em;color:#0b1f3c}.auth-brand-subtitle{margin-top:.12rem;color:#56708f;font-weight:850;font-size:.78rem}.auth-hero-copy{max-width:820px;margin-top:12vh}.auth-eyebrow,.hero-kicker{display:inline-flex;align-items:center;gap:.5rem;padding:.38rem .78rem;border-radius:999px;border:1px solid rgba(255,153,0,.28);background:rgba(255,247,237,.9);color:#c2410c;font-size:.78rem;font-weight:950}.auth-hero-copy h1{margin:1.2rem 0 0;font-size:clamp(2.9rem,5.1vw,5.8rem);line-height:1.08;font-weight:1000;letter-spacing:-.065em;color:#08213f}.auth-hero-copy p{max-width:760px;margin:1.35rem 0 0;color:#31445f;font-size:1.08rem;line-height:1.85;font-weight:760}
.auth-process-card{margin-top:2.2rem;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;max-width:760px}.auth-process-step{position:relative;border:1px solid rgba(219,229,240,.9);border-radius:1.15rem;background:rgba(255,255,255,.72);padding:1rem;box-shadow:0 10px 26px rgba(15,23,42,.045)}.auth-process-step span{display:inline-grid;place-items:center;width:34px;height:28px;border-radius:999px;background:var(--orange-soft);color:#c2410c;font-weight:1000;font-size:.75rem}.auth-process-step strong{display:block;margin-top:.65rem;color:#08213f;font-size:.98rem;font-weight:1000}.auth-process-step small{display:block;margin-top:.25rem;color:#607086;font-weight:760;line-height:1.45}.auth-feature-pills{margin-top:auto;display:flex;gap:.6rem;flex-wrap:wrap}.auth-feature-pills span{display:inline-flex;border:1px solid rgba(148,163,184,.28);background:rgba(255,255,255,.86);color:#405269;border-radius:999px;padding:.36rem .7rem;font-size:.76rem;font-weight:900;box-shadow:0 8px 20px rgba(15,23,42,.04)}
.auth-login-zone{position:relative;min-height:100vh;display:grid;place-items:center;padding:2rem;overflow:hidden}.auth-pattern-panel{position:absolute;inset:0;background:linear-gradient(135deg,rgba(232,246,251,.92),rgba(244,248,251,.8));border-left:1px solid rgba(219,229,240,.75)}.auth-pattern-panel::before{content:"";position:absolute;inset:0;opacity:.45;background-image:radial-gradient(circle at 1px 1px,rgba(14,93,137,.14) 1px,transparent 0);background-size:22px 22px}.auth-login-card{position:relative;z-index:1;width:min(100%,460px);border:1px solid rgba(191,222,233,.88);border-radius:32px;background:rgba(255,255,255,.92);box-shadow:0 28px 80px rgba(6,36,58,.16);padding:2rem;backdrop-filter:blur(20px)}.auth-card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem}.auth-card-logo{width:58px;height:58px;border-radius:20px}.auth-secure-badge{display:inline-flex;border:1px solid #bfdbfe;background:#eff6ff;color:var(--brand-700);border-radius:999px;padding:.22rem .55rem;font-size:.68rem;font-weight:1000}.auth-card-header h2{margin:.42rem 0 0;font-size:1.78rem;line-height:1.1;color:#08213f;font-weight:1000}.auth-card-header p{margin:.25rem 0 0;color:#607086;font-size:.84rem;font-weight:780}.auth-form{gap:.95rem}.auth-input-wrap{display:flex;align-items:center;gap:.65rem;border:1px solid #cbd8e6;border-radius:1rem;background:#fff;padding:0 .85rem;box-shadow:0 1px 2px rgba(15,23,42,.025)}.auth-input-wrap:focus-within{border-color:#60a5fa;box-shadow:var(--focus-ring)}.auth-input-wrap input{border:0!important;box-shadow:none!important;padding:.78rem 0!important;min-height:48px;background:transparent!important}.auth-system-note{margin-top:1rem;border:1px solid #dbeafe;background:#eff6ff;border-radius:1rem;padding:.8rem;display:grid;gap:.25rem}.auth-system-note strong{color:var(--brand-800);font-weight:1000}.auth-system-note span{color:#475569;font-size:.8rem;font-weight:760}.auth-mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;margin-top:1rem}.auth-mini-grid div{border:1px solid #e2e8f0;background:#fff;border-radius:1rem;padding:.75rem;text-align:center;color:#475569;font-weight:850}.auth-mini-grid span{display:block;margin-top:.2rem}

/* App shell */
.app-body{background:radial-gradient(circle at 18% 0%,rgba(13,127,168,.10) 0,rgba(13,127,168,0) 34%),radial-gradient(circle at 100% 12%,rgba(14,93,137,.08) 0,rgba(14,93,137,0) 30%),linear-gradient(180deg,#f8fbfd 0%,#f4f8fb 46%,#eef5f8 100%)}.app-shell{min-height:100vh;display:grid;grid-template-columns:310px minmax(0,1fr)}.sidebar{position:sticky;top:0;z-index:40;min-height:100vh;height:100vh;overflow:auto;padding:1.05rem;background:linear-gradient(180deg,rgba(255,255,255,.96) 0%,rgba(247,251,253,.94) 100%);border-right:1px solid rgba(219,229,240,.9);box-shadow:10px 0 34px rgba(6,36,58,.045)}.sidebar-glow{position:absolute;inset:0 0 auto auto;width:180px;height:180px;background:radial-gradient(circle,rgba(19,165,199,.16),transparent 66%);pointer-events:none}.brand{position:relative;display:flex;align-items:center;gap:.85rem;padding:.85rem;border:1px solid rgba(191,222,233,.75);border-radius:26px;background:linear-gradient(135deg,#fff 0%,var(--brand-soft-2) 100%);box-shadow:0 10px 28px rgba(6,36,58,.065)}.brand-title{font-size:1.03rem;line-height:1.05;font-weight:1000;color:var(--brand-900);letter-spacing:-.035em}.brand-subtitle{font-size:.72rem;color:#6b7c90;font-weight:850;margin-top:.14rem}.sidebar-status-card,.sidebar-footer-card{margin-top:.9rem;display:flex;align-items:center;gap:.75rem;border:1px solid rgba(191,222,233,.7);background:linear-gradient(135deg,#fff 0%,var(--brand-soft-2) 100%);border-radius:22px;padding:.85rem;box-shadow:0 10px 24px rgba(6,36,58,.055)}.status-dot{width:.62rem;height:.62rem;border-radius:999px;background:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.13)}.sidebar-status-card strong,.sidebar-footer-card strong{display:block;color:var(--brand-900);font-weight:1000}.sidebar-status-card small,.sidebar-footer-card span{display:block;color:#66768a;font-size:.75rem;font-weight:780}.sidebar-section-label{margin:1.35rem .7rem .55rem;color:#6b7c90;font-size:.68rem;font-weight:1000;letter-spacing:.08em;text-transform:uppercase}.nav{display:grid;gap:.35rem}.nav a{display:flex;align-items:center;gap:.75rem;min-height:50px;border-radius:18px;padding:.62rem .7rem;color:#405269;border:1px solid transparent;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.nav a:hover{background:#fff;border-color:#cfe0ed;color:var(--brand-800);transform:translateX(2px)}.nav a.is-active{background:linear-gradient(135deg,var(--brand-800) 0%,var(--brand-700) 100%);border-color:rgba(14,93,137,.12);color:#fff;box-shadow:0 14px 30px rgba(14,93,137,.18)}.nav-icon{width:34px;height:34px;flex:0 0 auto;border-radius:14px;display:grid;place-items:center;background:#edf4f8;color:#31445f;font-weight:1000}.nav a.is-active .nav-icon{background:rgba(255,255,255,.18);color:#fff}.nav-text{min-width:0;display:grid;gap:.05rem}.nav-text strong{font-size:.88rem;line-height:1.2;font-weight:950}.nav-text small{font-size:.7rem;line-height:1.25;color:#8aa0b5;font-weight:760}.nav a.is-active .nav-text small{color:rgba(255,255,255,.76)}.debug-pill{margin-top:.9rem;display:flex;justify-content:center;border:1px solid #fed7aa;background:#fff7ed;color:#b45309;border-radius:999px;padding:.45rem .7rem;font-size:.75rem;font-weight:1000}.main-section{min-width:0;display:flex;flex-direction:column;min-height:100vh}.topbar{position:sticky;top:0;z-index:30;min-height:76px;padding:0 1.6rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:rgba(255,255,255,.82);border-bottom:1px solid rgba(219,229,240,.86);backdrop-filter:blur(18px);box-shadow:0 12px 28px rgba(6,36,58,.045)}.topbar-title-wrap{min-width:0}.topbar-kicker{display:block;color:var(--brand-700);font-size:.72rem;font-weight:1000;text-transform:uppercase;letter-spacing:.065em}.topbar h1{margin:.1rem 0 0;color:var(--brand-900);font-size:1.62rem;line-height:1.15;font-weight:1000;letter-spacing:-.04em}.topbar p{margin:.2rem 0 0;color:#64748b;font-size:.8rem;font-weight:760}.topbar-user{display:flex;align-items:center;gap:.7rem;flex:0 0 auto}.topbar-chip{display:inline-flex;align-items:center;border-radius:999px;background:var(--brand-soft);color:var(--brand-700);border:1px solid rgba(191,222,233,.75);padding:.42rem .68rem;font-size:.74rem;font-weight:950}.user-chip{display:flex;align-items:center;gap:.55rem;border:1px solid #dbe5f0;background:#fff;border-radius:999px;padding:.32rem .7rem .32rem .35rem;box-shadow:var(--shadow-sm);max-width:210px}.user-avatar{width:34px;height:34px;border-radius:14px;background:var(--brand-soft);color:var(--brand-700);display:grid;place-items:center;font-weight:1000}.user-chip span{font-weight:850;color:#31445f;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.content{width:100%;max-width:1660px;margin:0 auto;padding:1.75rem;display:grid;gap:1rem}

/* Cards, hero, dashboard */
.card,.soft-card,.panel,.summary-box,.module-card{background:rgba(255,255,255,.93);border:1px solid rgba(219,229,240,.95);border-radius:var(--radius-lg);box-shadow:0 14px 36px rgba(6,36,58,.075);padding:1.15rem}.glass-card{background:rgba(255,255,255,.82);backdrop-filter:blur(16px)}.page-hero{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:1.2rem;border:1px solid rgba(191,222,233,.88);border-radius:32px;background:linear-gradient(135deg,var(--brand-900) 0%,var(--brand-700) 52%,var(--brand-500) 100%);color:#fff;padding:1.55rem 1.7rem;box-shadow:var(--shadow-md)}.page-hero::after{content:"";position:absolute;right:-70px;top:-90px;width:280px;height:280px;border-radius:999px;background:rgba(255,255,255,.12)}.page-hero>div{position:relative;z-index:1}.page-hero h2{margin:.75rem 0 0;font-size:2rem;line-height:1.12;font-weight:1000;letter-spacing:-.045em}.page-hero p{max-width:830px;margin:.7rem 0 0;color:rgba(255,255,255,.84);font-weight:740;line-height:1.75}.page-hero-actions{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:1rem}.hero-kicker{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.12);color:#fff}.hero-orbit-card,.hero-stepper{position:relative;z-index:1;min-width:220px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.13);border-radius:24px;padding:1rem;box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}.hero-orbit-card span{display:block;color:rgba(255,255,255,.70);font-size:.72rem;font-weight:1000}.hero-orbit-card strong{display:block;margin:.2rem 0;color:#fff;font-size:1.65rem;line-height:1.1;font-weight:1000}.hero-orbit-card small{color:rgba(255,255,255,.74);font-weight:760}.hero-stepper{display:grid;gap:.55rem}.hero-stepper div{display:flex;align-items:center;gap:.55rem}.hero-stepper span{width:34px;height:30px;border-radius:999px;background:rgba(255,255,255,.20);display:grid;place-items:center;font-weight:1000}.hero-stepper strong{font-size:.85rem}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem}.kpi-card{position:relative;overflow:hidden;display:grid;gap:.35rem;min-height:146px}.kpi-card::after{content:"";position:absolute;right:-40px;bottom:-50px;width:120px;height:120px;border-radius:999px;background:rgba(14,93,137,.06)}.kpi-icon{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:var(--brand-soft);color:var(--brand-700);font-weight:1000}.kpi-card span{color:#64748b;font-size:.83rem;font-weight:850}.kpi-card strong{color:var(--brand-900);font-size:2.2rem;line-height:1;font-weight:1000}.kpi-card small{color:#94a3b8;font-weight:760}.kpi-success .kpi-icon{background:var(--green-soft);color:var(--green)}.kpi-warn .kpi-icon{background:var(--orange-soft);color:#c2410c}.kpi-danger .kpi-icon{background:var(--red-soft);color:#be123c}.kpi-info .kpi-icon{background:var(--brand-soft);color:var(--brand-700)}.dashboard-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);gap:1rem}.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.section-header.compact{margin-bottom:.75rem}.section-header h2{margin:0;font-size:1.25rem;line-height:1.22;font-weight:1000;letter-spacing:-.03em;color:var(--brand-900)}.section-header p{margin:.25rem 0 0;color:#64748b;font-weight:750}.workflow-steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}.workflow-steps div,.quick-actions a{border:1px solid rgba(219,229,240,.95);background:linear-gradient(180deg,#fff,#f8fbfd);border-radius:1.15rem;padding:1rem}.workflow-steps span,.quick-actions span{display:inline-grid;place-items:center;width:34px;height:30px;border-radius:999px;background:var(--brand-soft);color:var(--brand-700);font-weight:1000}.workflow-steps strong,.quick-actions strong{display:block;margin-top:.55rem;font-weight:1000;color:var(--brand-900)}.workflow-steps small,.quick-actions small{display:block;color:#64748b;font-weight:750}.quick-actions{display:grid;gap:.75rem}.quick-actions a{transition:transform .18s ease,box-shadow .18s ease}.quick-actions a:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}

/* Tables */
.table-card,.premium-report-card{overflow:hidden}.table-responsive{width:100%;overflow:auto;border:1px solid rgba(219,229,240,.95);border-radius:1.25rem;background:#fff}.data-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;min-width:860px}.data-table th{position:sticky;top:0;z-index:1;background:#f8fafc;color:#334155;text-align:left;font-weight:1000;font-size:.78rem;letter-spacing:.01em;border-bottom:1px solid #e2e8f0;padding:.9rem .85rem;white-space:nowrap}.data-table td{border-bottom:1px solid #edf2f7;padding:.9rem .85rem;vertical-align:top;color:#334155;font-weight:680}.data-table tr:last-child td{border-bottom:0}.data-table tbody tr:hover td{background:#f8fbff}.empty{text-align:center;color:#64748b;padding:2.2rem!important}.compact-table{min-width:0}.compact-table th{position:static;width:42%;top:auto}.status-badge{display:inline-flex;align-items:center;gap:.35rem;border-radius:999px;padding:.36rem .66rem;font-size:.74rem;font-weight:1000;background:#eef2ff;color:#3730a3;white-space:nowrap}.status-badge::before{content:"";width:.45rem;height:.45rem;border-radius:999px;background:currentColor}.status-approved,.status-completed{background:var(--green-soft);color:#047857}.status-rejected{background:var(--red-soft);color:#be123c}.status-draft{background:#f1f5f9;color:#475569}.status-submitted,.status-waiting_head_review,.status-waiting_director_approval,.status-waiting_rector_approval,.status-waiting_director_review{background:var(--orange-soft);color:#c2410c}.numeric-pill{display:inline-flex;min-width:2.2rem;justify-content:center;border-radius:999px;background:var(--brand-soft);color:var(--brand-700);padding:.2rem .55rem;font-weight:1000}

/* Forms */
.form-stack{display:flex;flex-direction:column;gap:1rem}.form-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:1rem}.form-grid>.form-group{grid-column:span 6}.form-span-2{grid-column:1/-1!important}.filter-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:1rem;align-items:end}.filter-grid>.form-group{grid-column:span 3}.filter-grid>.form-actions{grid-column:span 12;justify-content:flex-end}.form-group{display:flex;flex-direction:column;gap:.45rem}.form-group label,.field label,.form-label{color:#1f2937;font-weight:1000;font-size:.86rem}input,select,textarea{width:100%;border:1px solid rgba(148,163,184,.42);border-radius:1rem;background:#fff;color:#0f172a;padding:.78rem .88rem;min-height:48px;outline:0;box-shadow:0 1px 2px rgba(15,23,42,.02);transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}textarea{resize:vertical}input:focus,select:focus,textarea:focus{border-color:#38bdf8;box-shadow:var(--focus-ring)}input::placeholder,textarea::placeholder{color:#94a3b8}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;align-items:center;flex-wrap:wrap}.form-section{grid-column:1/-1;border:1px solid rgba(191,219,254,.65);background:linear-gradient(135deg,#f8fbff,#fff);border-radius:1.38rem;padding:1rem}.form-section h3{margin:0;font-size:1.04rem;font-weight:1000;color:var(--brand-900)}.form-section p{margin:.15rem 0 .9rem;color:#64748b;font-weight:750}.nested-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.template-status{min-width:292px;border:1px solid rgba(125,211,252,.75);background:linear-gradient(135deg,#eff6ff,#ecfeff);color:#1e3a8a;border-radius:1.25rem;padding:.9rem 1rem;box-shadow:0 14px 30px rgba(14,165,233,.08)}.template-status strong{display:block;font-size:.9rem;font-weight:1000}.template-status span{display:block;color:#475569;font-weight:780;font-size:.8rem;margin-top:.1rem}.form-helper-panel{grid-column:1/-1;display:flex;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,#f8fafc,#eef6ff);border:1px dashed #93c5fd;border-radius:1.35rem;padding:1rem}.form-helper-panel strong{display:block;color:#0f172a;font-weight:1000}.form-helper-panel p,.form-helper-panel ul{margin:.2rem 0 0;color:#64748b;font-weight:750}.form-helper-panel ul{padding-left:1.2rem}.filter-card .section-header{border-bottom:1px solid rgba(226,232,240,.9);padding-bottom:1rem}.premium-form-card{border-color:rgba(191,219,254,.8)}

/* Report / Health */
.report-card{padding:1rem}.health-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.health-card{position:relative;overflow:hidden}.health-card::after{content:"";position:absolute;right:-3rem;bottom:-3rem;width:9rem;height:9rem;border-radius:999px;background:rgba(14,165,233,.08)}.health-card-head{position:relative;z-index:1;display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:.8rem}.health-key{display:inline-flex;border-radius:999px;background:#f1f5f9;color:#64748b;padding:.2rem .55rem;font-size:.68rem;font-weight:1000}.health-card h2{margin:.45rem 0 .1rem;font-size:1.12rem;font-weight:1000;color:var(--brand-900)}.health-card p{margin:0;color:#64748b;font-weight:750}.health-meta-table{position:relative;z-index:1;border-radius:1rem}.health-ok{border-color:rgba(16,185,129,.22)}.health-fail{border-color:rgba(225,29,72,.25)}.command-card{margin-top:1rem}.code-block{white-space:pre-wrap;background:#07172e;color:#e5e7eb;border-radius:1.1rem;padding:1rem;overflow:auto;border:1px solid rgba(148,163,184,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}.print-header{display:none}

/* Error pages */
.error-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,rgba(59,130,246,.14),transparent 36%),#f8fafc;padding:1.5rem}.error-card{width:min(100%,560px);text-align:center;border:1px solid #e2e8f0;border-radius:2rem;background:#fff;box-shadow:var(--shadow-lg);padding:2.2rem}.error-card h1{font-size:5rem;line-height:1;margin:0;color:var(--brand-700);font-weight:1000}.error-card h2{margin:.5rem 0;color:#0f172a}.error-card p{color:#64748b}

/* Compatibility aliases for future pages using stock-style classes from the sample app.css */
.stock-layout{min-height:100vh;display:grid;grid-template-columns:310px minmax(0,1fr);background:var(--canvas)}.stock-sidebar{position:sticky;top:0;height:100vh;overflow:auto;background:var(--paper);border-right:1px solid var(--line);padding:18px;z-index:45}.stock-main{min-width:0;display:flex;flex-direction:column;min-height:100vh}.stock-topbar{height:78px;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 28px;position:sticky;top:0;z-index:35;backdrop-filter:blur(12px)}.stock-page-shell{padding:28px;max-width:1600px;width:100%;margin:0 auto}.stock-page-card{background:var(--paper);border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow-sm);padding:28px;min-height:calc(100vh - 140px)}.stock-brand{display:flex;align-items:center;gap:12px;padding:14px;border:1px solid var(--line);border-radius:22px;background:var(--paper);box-shadow:var(--shadow-sm)}.stock-brand-mark{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#ff9900 0%,#ffbf3f 42%,#1698ff 43%,#0758b8 100%);color:#fff;display:grid;place-items:center;font-weight:900;font-size:20px;box-shadow:var(--shadow-sm)}.stock-nav-link{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:16px;font-weight:700;color:#475569;transition:background .15s ease,color .15s ease,border .15s ease;border:1px solid transparent}.stock-nav-link:hover{background:#f8fafc;border-color:var(--line);color:var(--ink)}.stock-nav-active{background:var(--brand-soft);border-color:#bfdbfe;color:var(--brand-700)}.stock-nav-icon{width:30px;height:30px;border-radius:12px;display:grid;place-items:center;background:#f1f5f9;color:#334155;font-weight:900;font-size:12px;flex:0 0 auto}.stock-user-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:var(--paper);border-radius:18px;padding:8px 12px;box-shadow:var(--shadow-sm)}

/* Responsive */
@media(max-width:1180px){.auth-page-pro{grid-template-columns:1fr}.auth-showcase{min-height:auto;padding-bottom:2rem}.auth-hero-copy{margin-top:4rem}.auth-process-card{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-login-zone{min-height:auto}.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:-320px;width:300px;transition:left .22s ease;box-shadow:var(--shadow-lg)}.sidebar.is-open{left:0}.icon-btn{display:grid}.topbar-user .user-chip span,.topbar-chip{display:none}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-layout{grid-template-columns:1fr}.filter-grid>.form-group{grid-column:span 6}.workflow-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.page-hero{align-items:flex-start}.hero-stepper{min-width:0;grid-template-columns:1fr}}
@media(max-width:760px){body{font-size:14px}.auth-showcase{padding:1.25rem}.auth-hero-copy{margin-top:3rem}.auth-hero-copy h1{font-size:2.45rem}.auth-process-card{grid-template-columns:1fr}.auth-feature-pills{margin-top:1.5rem}.auth-login-zone{padding:1.25rem}.auth-login-card{padding:1.1rem;border-radius:1.5rem}.auth-mini-grid{grid-template-columns:1fr}.content{padding:1rem;gap:1rem}.topbar{padding:.85rem;min-height:76px}.topbar h1{font-size:1.22rem}.topbar p,.topbar-kicker{display:none}.topbar-user{gap:.5rem}.topbar-user form .btn{padding:.58rem .72rem;min-height:40px}.page-hero{padding:1.1rem;border-radius:1.45rem;flex-direction:column}.page-hero h2{font-size:1.65rem}.hero-orbit-card,.hero-stepper{width:100%;min-width:0}.kpi-grid{grid-template-columns:1fr}.workflow-steps{grid-template-columns:1fr}.card{padding:1rem;border-radius:1.35rem}.section-header{flex-direction:column}.form-grid{grid-template-columns:1fr}.form-grid>.form-group{grid-column:auto}.form-span-2{grid-column:auto!important}.filter-grid{grid-template-columns:1fr}.filter-grid>.form-group,.filter-grid>.form-actions{grid-column:auto}.filter-grid>.form-actions,.form-actions{justify-content:stretch;flex-direction:column}.form-actions .btn{width:100%}.nested-grid{grid-template-columns:1fr}.template-status{width:100%;min-width:0}.form-helper-panel{flex-direction:column}.button-row{width:100%}.button-row .btn{flex:1 1 auto}.auth-card-header{align-items:flex-start}.auth-card-header h2{font-size:1.55rem}.health-card-head{flex-direction:column}}

@media print{body{background:#fff!important;font-size:12px}.sidebar,.topbar,.no-print,.page-hero{display:none!important}.app-shell{display:block}.content{padding:0}.card{box-shadow:none;border:0;border-radius:0;padding:0;background:#fff}.print-header{display:block;text-align:center;margin-bottom:12px}.print-header h2{margin:0;font-size:18px}.print-header p{margin:2px 0 0}.table-responsive{overflow:visible;border:0}.data-table{min-width:0;font-size:11px;border-collapse:collapse}.data-table th,.data-table td{border:1px solid #555!important;padding:4px 5px}@page{size:A4 landscape;margin:10mm}}

/*
 * Phase 1.1.13 — Kanit weight comfort fix
 * ลดน้ำหนักตัวอักษร Kanit ที่หนาเกินไปจากธีมตัวอย่าง เพื่อให้อ่านสบายและเป็นทางการขึ้น
 * ไม่เปลี่ยน font-face / ไม่เรียก CDN / ไม่แนบไฟล์ฟอนต์
 */
:root{
  --font-weight-normal:400;
  --font-weight-text:400;
  --font-weight-medium:500;
  --font-weight-semibold:600;
  --font-weight-bold:700;
  --font-weight-display:700;
}
body{
  font-weight:var(--font-weight-text)!important;
  letter-spacing:0!important;
}

/* Global typography: Kanit จะหนากว่า Inter/Noto เล็กน้อย จึงลดเพดาน weight ลง */
h1,h2,h3,h4,h5,h6,
.stock-page-title,
.page-title,
.section-title,
.card-title,
.dashboard-hero h1,
.dashboard-panel-head h2,
.material-form-hero h2,
.material-detail-hero h2,
.auth-copy h1,
.auth-hero-copy h1,
.auth-card-header h2,
.auth-brand-title,
.stock-brand-title{
  font-weight:var(--font-weight-display)!important;
  letter-spacing:-.018em!important;
}
strong,b,
.btn,.button,.btn-core,
label,.form-label,.field label,
.badge,.badge-soft,.pill,.status-badge,
.stock-nav-link,
.stock-nav-label-th,
.stock-user-chip,
.auth-eyebrow,
.hero-kicker,
.auth-secure-badge,
.required,
.required-mark,
.form-required-mark{
  font-weight:var(--font-weight-semibold)!important;
}

/* Auth page: ลดความหนักของ headline และ element รอบ login card */
.auth-hero-copy h1{
  font-size:clamp(3.4rem,6vw,6.25rem)!important;
  line-height:1.1!important;
  font-weight:700!important;
  letter-spacing:-.025em!important;
  text-shadow:none!important;
}
.auth-hero-copy p{
  font-weight:500!important;
  color:#263b57!important;
  line-height:1.85!important;
}
.auth-process-step strong,
.auth-feature-pills span,
.auth-mini-grid div,
.auth-system-note strong,
.auth-system-note span,
.auth-card-header p,
.auth-brand-subtitle,
.auth-field label{
  font-weight:500!important;
}
.auth-process-step span,
.auth-eyebrow,
.auth-secure-badge,
.required{
  font-weight:600!important;
}
.auth-card-header h2{
  font-weight:700!important;
  letter-spacing:-.015em!important;
}
.auth-submit,
.auth-input-wrap input{
  font-weight:500!important;
}

/* Main app: ลดน้ำหนัก navigation, table, form เพื่อไม่ให้ทุกอย่างดูดำหนา */
.stock-page-title{
  font-weight:700!important;
}
.stock-breadcrumb,
.stock-nav-group-title,
.table-wrap th,
.data-table th,
.kpi span,
.summary-box span,
.dashboard-kpi-label,
.dashboard-mini-card span,
.health-key{
  font-weight:600!important;
}
.stock-nav-link,
.stock-nav-label-th,
.table-wrap td,
.data-table td,
.input,.select,.form-control,input,select,textarea{
  font-weight:400!important;
}
.table-wrap strong,
.data-table strong,
.kpi strong,
.summary-box strong,
.dashboard-kpi-card strong,
.dashboard-mini-card strong,
.dashboard-value-card strong{
  font-weight:700!important;
}
.btn-primary,.button-primary,
.btn-secondary,.button-secondary,
.btn-light,.btn-ghost{
  font-weight:600!important;
}

/* ลดการใช้ Kanit Black/ExtraBold ใน badge/chip */
.phase-badge,
.auth-feature-card strong,
.stock-brand-title,
.stock-system-state-title,
.numeric-pill,
.status-pill,
.readiness-badge{
  font-weight:600!important;
}

@media(max-width:760px){
  .auth-hero-copy h1{
    font-size:2.9rem!important;
    line-height:1.12!important;
  }
}


/*
 * Phase 1.1.14 — Kanit ultra-light readability override
 * ผู้ใช้แจ้งว่าฟอนต์ยังหนาเกินไป จึงลดเพดาน weight ทั้งระบบแบบชัดเจน
 * และบังคับไม่ให้ heading/auth ใช้ Kanit Bold/Black ในทางปฏิบัติ
 */
:root{
  --font-weight-normal:400;
  --font-weight-ui:400;
  --font-weight-label:500;
  --font-weight-title:500;
  --font-weight-display:500;
}
body,
body :where(p,span,small,td,th,label,input,select,textarea,button,a,li,div){
  font-weight:400!important;
}
:where(h1,h2,h3,h4,h5,h6,
.stock-page-title,.page-title,.section-title,.card-title,
.auth-hero-copy h1,.auth-card-header h2,.auth-brand-title,
.dashboard-hero h1,.dashboard-panel-head h2,
.kpi strong,.summary-box strong,.dashboard-kpi-card strong){
  font-weight:500!important;
  letter-spacing:-.012em!important;
}
:where(strong,b,
.btn,.button,.btn-core,
.btn-primary,.button-primary,
.form-label,.field label,label,
.badge,.badge-soft,.pill,.status-badge,.required,
.stock-nav-link,.stock-nav-label-th,
.auth-eyebrow,.hero-kicker,.auth-secure-badge,
.auth-process-step strong,.auth-feature-pills span,
.stock-brand-title,.stock-system-state-title){
  font-weight:500!important;
}
:where(.auth-hero-copy h1){
  font-weight:500!important;
  letter-spacing:-.012em!important;
  text-shadow:none!important;
  -webkit-text-stroke:0 transparent!important;
}
:where(.auth-hero-copy p,.auth-process-step small,.auth-card-header p,
.table-wrap td,.data-table td,.input,.select,.form-control){
  font-weight:400!important;
}
:where(.required,.required-mark,.form-required-mark){
  font-weight:500!important;
}
/* ป้องกัน utility/class เดิมที่ใส่ 800/900/950/1000 ทับกลับมา */
[style*="font-weight: 800"],[style*="font-weight:800"],
[style*="font-weight: 900"],[style*="font-weight:900"],
[style*="font-weight: 950"],[style*="font-weight:950"],
[style*="font-weight: 1000"],[style*="font-weight:1000"]{
  font-weight:500!important;
}

/* Phase 1.2 — Working Day / Holiday Engine UI */
.working-day-hero .hero-orbit-card strong{font-weight:500!important}
.settings-grid-two{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.72fr);gap:18px;align-items:start;margin:18px 0}.working-day-kpi-grid{margin-top:18px}.inline-filter-form{display:grid;gap:8px;margin-bottom:18px}.inline-filter-form label,.working-day-policy-form label{font-weight:500;color:#16324a}.working-day-policy-form{display:grid;gap:16px}.weekday-toggle-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.working-day-toggle{display:flex;align-items:center;justify-content:center;gap:7px;min-height:42px;border:1px solid var(--line);border-radius:14px;background:#fff;cursor:pointer;font-weight:500;color:#334155}.working-day-toggle input{width:16px;height:16px;accent-color:var(--blue)}.working-day-toggle:has(input:checked){background:var(--blue-soft);border-color:#bfdbfe;color:var(--blue)}.policy-option-list{display:grid;gap:10px;border:1px solid var(--line);border-radius:18px;background:#f8fafc;padding:12px}.policy-option-list label{display:flex;align-items:center;gap:9px;font-weight:400}.policy-option-list input{width:16px;height:16px;accent-color:var(--blue)}.one-column-form{display:grid!important;grid-template-columns:1fr!important}.working-day-preview-card{display:grid;gap:12px}.working-day-preview-meta{display:flex;flex-wrap:wrap;gap:8px}.working-day-preview-meta span{display:inline-flex;align-items:center;gap:4px;border:1px solid #dbeafe;background:#eff6ff;color:#0e5d89;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:500}.working-day-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px}.working-day-chip{border:1px solid var(--line);background:#fff;border-radius:14px;padding:10px;display:grid;gap:3px}.working-day-chip strong{font-weight:500;color:#0f172a}.working-day-chip span,.working-day-chip small{font-size:12px;color:#64748b}.working-day-chip em{font-style:normal;font-size:12px;font-weight:500}.working-day-chip.is-counted{border-color:#bbf7d0;background:#f0fdf4}.working-day-chip.is-counted em{color:#15803d}.working-day-chip.is-skipped{border-color:#e2e8f0;background:#f8fafc;opacity:.9}.working-day-chip.is-skipped em{color:#64748b}.working-day-more{display:grid;place-items:center;border:1px dashed #cbd5e1;border-radius:14px;color:#64748b;font-size:12px;font-weight:500;padding:10px}.status-holiday{background:#fff1f2;color:#be123c}.status-working_day{background:#dcfce7;color:#15803d}.status-half_day{background:#fff7ed;color:#c2410c}
@media(max-width:1100px){.settings-grid-two{grid-template-columns:1fr}.weekday-toggle-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:640px){.weekday-toggle-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.working-day-breakdown{grid-template-columns:1fr}.working-day-preview-meta span{width:100%;justify-content:space-between}}

/* Phase 1.3 — Vacation Policy + Carry Forward UI */
.vacation-policy-hero .hero-orbit-card strong{font-size:1.35rem}
.vacation-policy-kpi-grid .kpi-card strong{font-weight:500}
.vacation-policy-layout{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr);gap:18px;align-items:start;margin:18px 0}.vacation-filter-form{margin-bottom:16px}.policy-rule-list{display:grid;gap:10px;margin-bottom:16px}.policy-rule-list div{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center;border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:10px 12px}.policy-rule-list strong{width:30px;height:30px;border-radius:12px;background:var(--blue-soft);color:var(--blue);display:grid;place-items:center;font-weight:600}.policy-rule-list span{font-size:13px;line-height:1.55;color:#334155}.vacation-policy-card{margin-top:18px}.vacation-policy-list{display:grid;gap:14px}.vacation-policy-row{border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);padding:16px;display:grid;gap:14px}.vacation-policy-row-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;border-bottom:1px solid #edf2f7;padding-bottom:12px}.vacation-policy-row-head h3{margin:2px 0 4px;color:var(--ink);font-size:20px;font-weight:500}.vacation-policy-row-head p{margin:0;color:var(--muted);font-size:13px;line-height:1.5}.vacation-policy-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.policy-checkbox-group{grid-column:span 2;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;align-content:end}.policy-checkbox-group label{display:flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;border-radius:14px;padding:9px 10px;font-size:13px;font-weight:500;color:#334155}.policy-checkbox-group input{width:16px;height:16px;accent-color:var(--blue)}.carry-forward-card{margin-top:18px}.carry-forward-filter{display:flex;align-items:end;gap:8px;flex-wrap:wrap}.carry-forward-filter label{display:block;width:100%;font-size:12px;font-weight:600;color:var(--muted)}.carry-forward-filter select{min-width:220px}.carry-forward-summary-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin:0 0 14px}.carry-forward-summary-grid>div{border:1px solid var(--line);background:#f8fafc;border-radius:16px;padding:12px;display:grid;gap:3px}.carry-forward-summary-grid span{font-size:11px;font-weight:600;color:var(--muted)}.carry-forward-summary-grid strong{font-size:20px;font-weight:500;color:var(--ink)}.carry-forward-summary-grid small{font-size:11px;color:var(--muted)}.carry-forward-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #bfdbfe;background:#eff6ff;border-radius:18px;padding:12px 14px;margin-top:14px}.carry-forward-actions span{font-size:13px;color:#1e3a8a;line-height:1.5}.carry-forward-actions button:disabled{opacity:.48;cursor:not-allowed}.notice.alert-info{display:grid;gap:4px}.notice.alert-info span{font-size:13px;line-height:1.55;color:#1e3a8a}.two-cols{grid-template-columns:repeat(2,minmax(0,1fr))!important}
@media(max-width:1180px){.vacation-policy-layout{grid-template-columns:1fr}.vacation-policy-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.carry-forward-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:760px){.vacation-policy-grid,.policy-checkbox-group,.two-cols{grid-template-columns:1fr!important}.policy-checkbox-group{grid-column:auto}.vacation-policy-row-head,.carry-forward-actions{display:grid}.carry-forward-summary-grid{grid-template-columns:1fr}.carry-forward-filter,.carry-forward-filter select,.carry-forward-actions button{width:100%}.vacation-policy-row{padding:14px;border-radius:18px}}

/* Phase 1.4 — Approval Workflow MVP */
.approval-inbox-card .data-table td{vertical-align:middle}.approval-detail-hero{align-items:stretch}.approval-tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.approval-detail-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:18px;margin-top:18px}.approval-info-card,.approval-action-card,.approval-steps-card,.approval-timeline-card{padding:20px;border-radius:24px}.approval-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.approval-info-grid>div{border:1px solid var(--line);border-radius:16px;background:#f8fafc;padding:12px}.approval-info-grid>div.full{grid-column:1/-1}.approval-info-grid span{display:block;color:var(--muted);font-size:12px;font-weight:500;margin-bottom:4px}.approval-info-grid strong{display:block;color:var(--ink);font-weight:500;line-height:1.55}.approval-action-form{display:grid;gap:14px}.approval-action-buttons{display:grid;gap:10px}.approval-action-buttons .btn{width:100%;min-height:42px}.approval-stepper{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.approval-step{border:1px solid var(--line);border-radius:18px;background:#fff;padding:14px;display:grid;gap:5px}.approval-step.is-active{border-color:#93c5fd;background:#eff6ff;box-shadow:0 10px 24px rgba(37,99,235,.10)}.approval-step span{width:30px;height:30px;border-radius:12px;background:#e2e8f0;color:#334155;display:grid;place-items:center;font-weight:600}.approval-step.is-active span{background:#0e5d89;color:#fff}.approval-step strong{font-size:14px;font-weight:500;color:var(--ink)}.approval-step small{color:var(--muted)}.approval-timeline{display:grid;gap:12px}.approval-timeline-item{display:grid;grid-template-columns:18px minmax(0,1fr);gap:10px}.timeline-dot{width:12px;height:12px;border-radius:999px;background:#0e5d89;margin-top:5px;box-shadow:0 0 0 4px rgba(14,93,137,.12)}.approval-timeline-item>div{border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px}.approval-timeline-item strong{display:block;font-weight:500;color:var(--ink)}.approval-timeline-item small{display:block;color:var(--muted);margin-top:3px}.approval-timeline-item p{margin:8px 0 0;color:#334155;line-height:1.55}.status-returned{background:#fff7ed;color:#c2410c}.status-waiting_director_review,.status-waiting_director_approval,.status-waiting_rector_approval,.status-submitted,.status-waiting_head_review{background:#eff6ff;color:#1d4ed8}.status-approved{background:#dcfce7;color:#15803d}.status-rejected{background:#fee2e2;color:#b91c1c}
@media(max-width:1100px){.approval-detail-grid{grid-template-columns:1fr}.approval-action-card{order:-1}.approval-info-grid{grid-template-columns:1fr}}

/* Phase 1.5 — print/verify UI */
.approval-print-actions{display:grid;gap:8px;justify-items:center}.approval-print-actions .btn{width:100%;justify-content:center}.verify-page-body{min-height:100vh;background:radial-gradient(circle at 20% 0%,rgba(14,93,137,.12),transparent 34%),linear-gradient(180deg,#f8fbfd,#eef5f8);font-family:"GovLeave Kanit","Kanit","Noto Sans Thai",sans-serif;color:#0f172a}.verify-page-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.verify-card{width:min(760px,100%);background:rgba(255,255,255,.94);border:1px solid #dbe5f0;border-radius:32px;box-shadow:0 24px 70px rgba(6,36,58,.18);padding:30px}.verify-mark{width:64px;height:64px;border-radius:22px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-size:32px;margin-bottom:14px}.verify-kicker{margin:0;color:#0e5d89;font-size:12px;font-weight:500;letter-spacing:.08em;text-transform:uppercase}.verify-card h1{margin:5px 0 12px;font-size:30px;font-weight:500}.verify-card h2{margin:24px 0 10px;font-size:18px;font-weight:500}.verify-status{display:inline-flex;border-radius:999px;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;padding:7px 12px;font-weight:400;margin-bottom:16px}.verify-status.approved{background:#edfdf6;color:#16815a;border-color:#bbf7d0}.verify-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.verify-grid>div{border:1px solid #e2e8f0;background:#f8fafc;border-radius:16px;padding:12px}.verify-grid span{display:block;color:#64748b;font-size:12px}.verify-grid strong{display:block;margin-top:4px;font-weight:400}.verify-timeline{display:grid;gap:10px}.verify-timeline>div{border:1px solid #e2e8f0;border-radius:16px;padding:12px;background:#fff}.verify-timeline strong{display:block;font-weight:500}.verify-timeline span{display:block;color:#64748b;font-size:12px;margin-top:2px}@media(max-width:640px){.verify-card{padding:20px;border-radius:24px}.verify-grid{grid-template-columns:1fr}.verify-card h1{font-size:24px}}

/* Phase 1.6 — My Leave List + Detail + Print Access */
.my-leave-hero,
.my-leave-detail-hero{
    background:linear-gradient(135deg,#eff6ff 0%,#ffffff 56%,#f8fafc 100%);
}
.my-leave-kpi-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
    margin-bottom:18px;
}
.my-leave-filter-card{
    padding:16px;
    margin-bottom:18px;
}
.my-leave-filter-grid{
    display:grid;
    grid-template-columns:minmax(220px,1.25fr) minmax(160px,.75fr) minmax(170px,.8fr) minmax(145px,.7fr) minmax(145px,.7fr) auto;
    gap:12px;
    align-items:end;
}
.my-leave-filter-actions{
    display:flex;
    gap:8px;
    align-items:center;
    justify-content:flex-end;
}
.my-leave-table-card .table-responsive{
    overflow:auto;
}
.my-leave-table td,
.my-leave-table th{
    vertical-align:middle;
}
.table-link{
    color:#0e5d89;
    text-decoration:none;
}
.table-link:hover{
    color:#0d7fa8;
    text-decoration:underline;
}
.button-row.compact{
    display:flex;
    gap:6px;
    flex-wrap:wrap;
}
.status-badge{
    display:inline-flex;
    align-items:center;
    gap:6px;
    min-height:26px;
    padding:5px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:600;
    line-height:1.2;
    border:1px solid #e2e8f0;
    background:#f8fafc;
    color:#475569;
    white-space:nowrap;
}
.status-pending,
.status-submitted,
.status-waiting_head_review,
.status-waiting_director_review,
.status-waiting_director_approval,
.status-waiting_rector_approval{
    background:#eff6ff;
    border-color:#bfdbfe;
    color:#1d4ed8;
}
.status-approved,
.status-completed{
    background:#f0fdf4;
    border-color:#bbf7d0;
    color:#15803d;
}
.status-rejected{
    background:#fef2f2;
    border-color:#fecaca;
    color:#b91c1c;
}
.status-returned{
    background:#fff7ed;
    border-color:#fed7aa;
    color:#c2410c;
}
.status-cancelled,
.status-cancel_requested{
    background:#f1f5f9;
    border-color:#cbd5e1;
    color:#475569;
}
.status-draft{
    background:#f8fafc;
    border-color:#cbd5e1;
    color:#334155;
}
.my-leave-detail-grid{
    display:grid;
    grid-template-columns:minmax(0,1.55fr) minmax(320px,.85fr);
    gap:18px;
    margin-bottom:18px;
    align-items:start;
}
.my-leave-detail-card,
.my-leave-side-card,
.my-leave-workflow-card,
.my-leave-days-card,
.my-leave-ledger-card{
    padding:18px;
}
.my-leave-print-card{
    display:grid;
    gap:8px;
}
.my-leave-status-panel{
    display:grid;
    gap:8px;
    border:1px solid #dbeafe;
    border-radius:18px;
    background:linear-gradient(180deg,#eff6ff 0%,#ffffff 100%);
    padding:14px;
    margin-bottom:12px;
}
.my-leave-status-panel strong{
    color:#0f172a;
    font-size:16px;
    line-height:1.4;
    font-weight:600;
}
.my-leave-status-panel small{
    color:#64748b;
    line-height:1.5;
}
.my-leave-side-actions{
    display:grid;
    gap:8px;
    margin-bottom:12px;
}
.my-leave-verify-box{
    display:grid;
    gap:5px;
    border:1px dashed #bfdbfe;
    background:#f8fbff;
    border-radius:16px;
    padding:12px;
}
.my-leave-verify-box span{
    color:#64748b;
    font-size:12px;
    font-weight:600;
}
.my-leave-verify-box a{
    color:#0e5d89;
    font-weight:600;
    text-decoration:none;
    word-break:break-word;
}
.my-leave-stepper .approval-step.is-done{
    border-color:#bbf7d0;
    background:#f0fdf4;
}
.my-leave-day-list,
.my-leave-ledger-list{
    display:grid;
    gap:8px;
}
.my-leave-day-item,
.my-leave-ledger-item{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto auto;
    gap:10px;
    align-items:center;
    border:1px solid #e2e8f0;
    border-radius:15px;
    background:#fff;
    padding:10px 12px;
}
.my-leave-day-item strong,
.my-leave-ledger-item strong{
    color:#0f172a;
    font-weight:600;
}
.my-leave-day-item span,
.my-leave-day-item em,
.my-leave-ledger-item small{
    color:#64748b;
    font-size:12px;
    line-height:1.45;
    font-style:normal;
}
.my-leave-ledger-item{
    grid-template-columns:minmax(0,1fr) auto;
}
.my-leave-ledger-item span{
    display:inline-flex;
    border-radius:999px;
    background:#eff6ff;
    border:1px solid #bfdbfe;
    color:#1d4ed8;
    padding:5px 9px;
    font-size:12px;
    font-weight:600;
}
.notice.compact{
    padding:8px 10px;
    margin:0;
    font-size:12px;
    border-radius:12px;
}
@media(max-width:1180px){
    .my-leave-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
    .my-leave-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
    .my-leave-filter-actions{justify-content:flex-start;}
    .my-leave-detail-grid{grid-template-columns:1fr;}
}
@media(max-width:720px){
    .my-leave-kpi-grid,
    .my-leave-filter-grid{grid-template-columns:1fr;}
    .my-leave-filter-actions,
    .my-leave-filter-actions .btn{width:100%;}
    .my-leave-day-item{grid-template-columns:1fr;}
    .my-leave-ledger-item{grid-template-columns:1fr;}
    .my-leave-table{min-width:920px;}
    .my-leave-detail-card,
    .my-leave-side-card,
    .my-leave-workflow-card,
    .my-leave-days-card,
    .my-leave-ledger-card{padding:14px;}
}


/* Phase 1.6.1 — My Leave UI regression fix
   Fixes: light hero with white text, KPI cards stacked vertically, oversized empty blocks, and cramped table controls. */
.content{
  gap:1rem;
}
.my-leave-hero,
.my-leave-detail-hero{
  color:#0f172a!important;
  background:
    radial-gradient(circle at 100% 0%,rgba(13,127,168,.13),transparent 30%),
    linear-gradient(135deg,#ffffff 0%,#f8fbff 52%,#e8f6fb 100%)!important;
  border-color:#cfe4ef!important;
  box-shadow:0 14px 34px rgba(6,36,58,.075)!important;
  align-items:center!important;
  min-height:auto!important;
}
.my-leave-hero::after,
.my-leave-detail-hero::after{
  background:rgba(13,127,168,.075)!important;
}
.my-leave-hero .hero-kicker,
.my-leave-detail-hero .hero-kicker{
  display:inline-flex;
  width:max-content;
  border:1px solid #bfdbfe!important;
  background:#eff6ff!important;
  color:#0e5d89!important;
  border-radius:999px;
  padding:.38rem .72rem;
  font-size:.76rem;
  font-weight:500!important;
}
.my-leave-hero h2,
.my-leave-detail-hero h2{
  color:#0b1728!important;
  font-size:clamp(1.55rem,2.1vw,2.15rem)!important;
  font-weight:500!important;
  letter-spacing:-.018em!important;
  margin:.55rem 0 0!important;
}
.my-leave-hero p,
.my-leave-detail-hero p{
  color:#475569!important;
  font-weight:400!important;
  line-height:1.72!important;
  margin:.55rem 0 0!important;
}
.my-leave-hero .hero-orbit-card,
.my-leave-detail-hero .hero-orbit-card{
  min-width:210px!important;
  background:rgba(255,255,255,.88)!important;
  border:1px solid #dbe5f0!important;
  color:#0f172a!important;
  box-shadow:0 10px 26px rgba(6,36,58,.06)!important;
}
.my-leave-hero .hero-orbit-card span,
.my-leave-detail-hero .hero-orbit-card span{
  color:#64748b!important;
  font-weight:500!important;
}
.my-leave-hero .hero-orbit-card strong,
.my-leave-detail-hero .hero-orbit-card strong{
  color:#0e5d89!important;
  font-weight:500!important;
}
.my-leave-hero .hero-orbit-card small,
.my-leave-detail-hero .hero-orbit-card small{
  color:#64748b!important;
  font-weight:400!important;
}
.my-leave-kpi-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:14px!important;
  margin:0 0 18px!important;
}
.my-leave-kpi-grid .kpi-card{
  min-height:118px!important;
  padding:1rem!important;
  border-radius:22px!important;
}
.my-leave-kpi-grid .kpi-icon{
  width:38px!important;
  height:38px!important;
  border-radius:14px!important;
  font-weight:500!important;
}
.my-leave-kpi-grid .kpi-card span{
  font-weight:400!important;
  color:#64748b!important;
}
.my-leave-kpi-grid .kpi-card strong{
  font-size:1.85rem!important;
  font-weight:500!important;
}
.my-leave-kpi-grid .kpi-card small{
  font-weight:400!important;
  color:#64748b!important;
}
.notice.danger,
.notice.alert-error{
  border:1px solid #fecaca!important;
  background:#fff7f7!important;
  color:#7f1d1d!important;
  border-radius:16px!important;
  padding:.85rem 1rem!important;
  font-weight:400!important;
  line-height:1.65!important;
  box-shadow:0 8px 20px rgba(185,28,28,.035)!important;
}
.my-leave-filter-card,
.my-leave-table-card{
  border-radius:24px!important;
  box-shadow:0 10px 28px rgba(6,36,58,.055)!important;
}
.my-leave-filter-grid{
  display:grid!important;
}
.my-leave-table-card .section-header h2{
  font-weight:500!important;
}
.my-leave-table-card .section-header p{
  font-weight:400!important;
}
.my-leave-table td,
.my-leave-table th{
  font-weight:400!important;
}
.my-leave-table th{
  font-weight:500!important;
}
.my-leave-table strong{
  font-weight:500!important;
}
.button-row.compact .btn{
  min-height:32px!important;
  padding:.45rem .7rem!important;
  border-radius:10px!important;
}
@media(max-width:1180px){
  .my-leave-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;}
}
@media(max-width:760px){
  .my-leave-hero,.my-leave-detail-hero{flex-direction:column!important;align-items:flex-start!important;padding:1.1rem!important;}
  .my-leave-hero .hero-orbit-card,.my-leave-detail-hero .hero-orbit-card{width:100%!important;min-width:0!important;}
  .my-leave-kpi-grid{grid-template-columns:1fr!important;}
}

/* Phase 1.6.2 — Header cleanup + user profile management */
.topbar-title-wrap{display:flex;align-items:center;min-height:48px}
.topbar-title-wrap h1{margin:0!important;font-weight:620!important;letter-spacing:-.018em!important}
.topbar-kicker,.topbar-title-wrap p{display:none!important}
.user-chip{text-decoration:none!important;transition:background .16s ease,border-color .16s ease,transform .16s ease}
.user-chip:hover{background:#f8fbff;border-color:#b7d8e8;transform:translateY(-1px)}
.sidebar-status-card strong,.sidebar-footer-card strong,.brand-title,.nav-text strong{font-weight:620!important}
.sidebar-status-card small,.sidebar-footer-card span,.nav-text small{font-weight:420!important}
.debug-pill{font-weight:560!important;letter-spacing:0!important}
.profile-page{display:grid;gap:1rem}.profile-hero{display:flex;justify-content:space-between;align-items:stretch;gap:1rem;padding:1.25rem;border-radius:1.55rem;background:linear-gradient(135deg,#ffffff 0%,#f0f8fc 100%)}
.profile-hero-main{min-width:0;display:grid;align-content:center;gap:.55rem}.profile-eyebrow{width:max-content;border-radius:999px;background:#e8f6fb;border:1px solid #b7d8e8;color:#0e5d89;padding:.32rem .62rem;font-size:.75rem;font-weight:560}.profile-hero h2{font-size:1.7rem;line-height:1.15;margin:0;color:#06243a;font-weight:620;letter-spacing:-.02em}.profile-hero p{margin:0;color:#607086;font-size:.92rem;line-height:1.65}.profile-chip-row{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.25rem}.profile-chip-row span{display:inline-flex;border:1px solid #dbe5f0;background:#fff;border-radius:999px;padding:.34rem .6rem;color:#405269;font-size:.78rem;font-weight:450}.profile-avatar-card{min-width:220px;border:1px solid #dbe5f0;background:#fff;border-radius:1.35rem;padding:1rem;display:grid;justify-items:center;align-content:center;text-align:center;gap:.35rem}.profile-avatar-large{width:62px;height:62px;border-radius:22px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-size:1.5rem;font-weight:620}.profile-avatar-card strong{color:#06243a;font-weight:620}.profile-avatar-card span{max-width:220px;color:#607086;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:1rem}.profile-card{padding:1.25rem;border-radius:1.45rem}.profile-card .section-header.compact{margin-bottom:1rem}.profile-card .section-header h3{margin:0;color:#06243a;font-size:1.1rem;font-weight:620}.profile-card .section-header p{margin:.25rem 0 0;color:#607086;line-height:1.55}.profile-info-list{display:grid;border:1px solid #e4edf4;border-radius:1.05rem;overflow:hidden}.profile-info-list>div{display:flex;justify-content:space-between;gap:1rem;padding:.78rem .9rem;border-bottom:1px solid #e4edf4;background:#fff}.profile-info-list>div:nth-child(2n){background:#f8fbfd}.profile-info-list>div:last-child{border-bottom:0}.profile-info-list span{color:#607086;font-size:.82rem}.profile-info-list strong{color:#0b1728;font-size:.88rem;font-weight:520;text-align:right}.profile-card .form-control:disabled{background:#f4f8fb;color:#94a3b8}.notice.warning{background:#fff8e8;border-color:#fde5ad;color:#8a520d}
@media(max-width:980px){.profile-hero,.profile-grid{grid-template-columns:1fr;display:grid}.profile-avatar-card{min-width:0;justify-items:start;text-align:left}.profile-info-list>div{display:grid;gap:.25rem}.profile-info-list strong{text-align:left}.topbar-title-wrap h1{font-size:1.18rem!important}}
@media(max-width:760px){.topbar-chip{display:none}.profile-hero h2{font-size:1.35rem}.profile-card{padding:1rem}.profile-hero{padding:1rem}.profile-avatar-large{width:54px;height:54px}}

/* Phase 1.7 — Draft edit / returned revision UI */
.btn-warning,
.button-warning{
    background:#f59e0b!important;
    border-color:#f59e0b!important;
    color:#111827!important;
}
.btn-warning:hover,
.button-warning:hover{
    background:#d97706!important;
    border-color:#d97706!important;
    color:#111827!important;
}
.my-leave-revision-card .my-leave-ledger-item span{
    max-width:160px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}
.notice.warning.compact,
.notice.warning{
    border-color:#fde68a;
    background:#fffbeb;
    color:#92400e;
}

/* Phase 1.7.1 — Working day template/edit polish */
.holiday-template-card,
.working-day-help-card{
  display:grid;
  gap:14px;
}
.template-option-list{
  display:grid;
  gap:10px;
}
.template-option{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:10px;
  align-items:flex-start;
  border:1px solid var(--line, #dbe5f0);
  border-radius:18px;
  padding:12px 14px;
  background:#fff;
  cursor:pointer;
}
.template-option:hover{
  border-color:#bfdbfe;
  background:#f8fbff;
}
.template-option input{
  margin-top:3px;
  accent-color:var(--blue, #0e5d89);
}
.template-option strong{
  display:block;
  color:var(--ink, #0b1728);
  font-weight:600;
  line-height:1.45;
}
.template-option small{
  display:block;
  margin-top:3px;
  color:var(--muted, #607086);
  line-height:1.55;
}
.working-day-rule-list{
  display:grid;
  gap:10px;
}
.working-day-rule-list>div{
  border:1px solid var(--line, #dbe5f0);
  border-radius:16px;
  background:#fff;
  padding:12px 14px;
}
.working-day-rule-list strong{
  display:block;
  color:var(--ink, #0b1728);
  font-weight:600;
}
.working-day-rule-list span{
  display:block;
  margin-top:3px;
  color:var(--muted, #607086);
  font-size:13px;
  line-height:1.5;
}
.working-day-edit-table .working-day-name-input,
.working-day-edit-table .working-day-type-select{
  min-width:220px;
}
.working-day-edit-table .button-row{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
@media(max-width:900px){
  .working-day-edit-table{min-width:920px;}
}

/* Phase 1.7.2 — Auto Last Leave Snapshot */
.last-leave-auto-card{
    border-color:#bfdbfe!important;
    background:linear-gradient(180deg,#f8fbff 0%,#ffffff 100%)!important;
}
.last-leave-auto-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:14px;
    margin-bottom:14px;
}
.last-leave-auto-head h3{margin:0 0 4px;color:var(--brand-900,#06243a)}
.last-leave-auto-head p{margin:0;color:#64748b;line-height:1.55}
.last-leave-preview{
    display:grid;
    gap:4px;
    border:1px solid #dbeafe;
    background:#eff6ff;
    border-radius:18px;
    padding:13px 14px;
    margin-bottom:14px;
    color:#1e3a8a;
}
.last-leave-preview strong{font-size:14px;font-weight:600;color:#0f172a}
.last-leave-preview span{font-size:13px;line-height:1.5;color:#334155}
.last-leave-preview em,
.last-leave-preview small{font-style:normal;font-size:12px;color:#64748b;font-weight:500}
.last-leave-preview.is-found{border-color:#bbf7d0;background:#f0fdf4;color:#166534}
.last-leave-preview.is-empty{border-color:#e2e8f0;background:#f8fafc;color:#475569}
.last-leave-preview.is-loading{border-color:#fed7aa;background:#fff7ed;color:#9a3412}
.last-leave-note{display:block;margin-top:8px;color:#64748b;line-height:1.5}
.last-leave-auto-card input[readonly]{background:#f8fafc;color:#475569;border-style:dashed}
.last-leave-detail-row{display:grid!important;gap:4px;background:#f8fafc!important;border:1px solid #dbeafe!important;border-radius:16px!important;padding:12px!important}
.last-leave-detail-row small{color:#64748b;font-size:12px;font-weight:500}
@media(max-width:720px){.last-leave-auto-head{display:grid}.last-leave-auto-head .badge{justify-self:start}}

/* Phase 1.8 — Attachment Upload + Secure Download */
.leave-attachment-card,
.leave-attachment-detail-card {
  border: 1px solid var(--line, #dbe5f0);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  border-radius: 22px;
}
.leave-attachment-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}
.leave-attachment-head h3 {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: #0f172a;
}
.leave-attachment-head p {
  margin: 4px 0 0;
  color: #64748b;
  font-size: 13px;
  line-height: 1.6;
  font-weight: 400;
}
.leave-upload-box {
  display: grid;
  gap: 6px;
  cursor: pointer;
  border: 1px dashed #93c5fd;
  background: #eff6ff;
  color: #1e3a8a;
  border-radius: 18px;
  padding: 18px;
  text-align: center;
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.leave-upload-box:hover {
  background: #dbeafe;
  border-color: #2563eb;
  box-shadow: 0 0 0 4px rgba(37,99,235,.08);
}
.leave-upload-box input {
  width: 100%;
  max-width: 520px;
  margin: 0 auto;
  border: 1px solid #bfdbfe;
  background: #ffffff;
  border-radius: 14px;
  padding: 10px;
}
.leave-upload-box span {
  font-size: 15px;
  font-weight: 600;
}
.leave-upload-box small {
  color: #475569;
  font-weight: 400;
  line-height: 1.55;
}
.leave-existing-attachments {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}
.leave-existing-attachments > strong {
  color: #0f172a;
  font-weight: 600;
}
.leave-attachment-list {
  display: grid;
  gap: 10px;
}
.leave-attachment-list.is-detail {
  margin-top: 4px;
}
.leave-attachment-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  border: 1px solid #e2e8f0;
  background: #ffffff;
  border-radius: 16px;
  padding: 12px 14px;
}
.leave-attachment-item span {
  display: block;
  color: #0f172a;
  font-weight: 600;
  line-height: 1.35;
  word-break: break-word;
}
.leave-attachment-item small {
  display: block;
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.45;
  font-weight: 400;
}
.leave-attachment-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 7px;
  flex: 0 0 auto;
}
.leave-attachment-delete-choice {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid #fecaca;
  background: #fff1f2;
  color: #991b1b;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 500;
}
.leave-attachment-delete-choice input {
  width: 15px;
  height: 15px;
  accent-color: #dc2626;
}
.leave-upload-preview {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}
.leave-upload-preview-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid #dbeafe;
  background: #ffffff;
  border-radius: 14px;
  padding: 10px 12px;
}
.leave-upload-preview-item strong {
  min-width: 0;
  color: #0f172a;
  font-weight: 500;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.leave-upload-preview-item span {
  color: #64748b;
  font-size: 12px;
  font-weight: 400;
  flex: 0 0 auto;
}
@media (max-width: 720px) {
  .leave-attachment-head,
  .leave-attachment-item {
    display: grid;
  }
  .leave-attachment-actions {
    justify-content: flex-start;
  }
  .leave-attachment-actions .btn {
    flex: 1 1 auto;
  }
}

/* Phase 1.8.2 — Leave subject/recipient suggestion UX */
.leave-text-suggestion-group {
  align-self: stretch;
}
.leave-text-suggestion-group input[list] {
  padding-right: 42px;
  background-image: linear-gradient(45deg, transparent 50%, #64748b 50%), linear-gradient(135deg, #64748b 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}
.leave-suggestion-panel {
  margin-top: 9px;
  display: grid;
  gap: 8px;
}
.leave-suggestion-row {
  display: grid;
  gap: 6px;
}
.leave-suggestion-row > span {
  color: #64748b;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.35;
}
.leave-suggestion-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.leave-suggestion-chip {
  border: 1px solid #dbeafe;
  background: #eff6ff;
  color: #1d4ed8;
  border-radius: 999px;
  padding: 6px 10px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.25;
  cursor: pointer;
  transition: background .15s ease, border-color .15s ease, transform .15s ease;
}
.leave-suggestion-chip:hover {
  background: #dbeafe;
  border-color: #93c5fd;
  transform: translateY(-1px);
}
.leave-suggestion-chip.is-history {
  border-color: #e2e8f0;
  background: #ffffff;
  color: #334155;
}
.leave-suggestion-chip.is-history:hover {
  background: #f8fafc;
  border-color: #cbd5e1;
}
.leave-suggestion-empty {
  display: block;
  margin-top: 7px;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 400;
}
.leave-suggestion-empty[hidden] {
  display: none !important;
}
@media (max-width: 720px) {
  .leave-suggestion-chip-list {
    gap: 6px;
  }
  .leave-suggestion-chip {
    width: auto;
    max-width: 100%;
    white-space: normal;
    text-align: left;
  }
}

/* Phase 1.8.3 — Attachment preview modal */
.leave-modal-open{overflow:hidden!important}
.leave-attachment-modal{position:fixed;inset:0;z-index:1200;display:none;align-items:center;justify-content:center;padding:22px}
.leave-attachment-modal.is-open{display:flex}
.leave-attachment-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.64);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.leave-attachment-modal-panel{position:relative;z-index:1;width:min(1120px,calc(100vw - 28px));height:min(780px,calc(100vh - 28px));display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;background:#fff;border:1px solid #dbe4ef;border-radius:28px;box-shadow:0 30px 90px rgba(6,36,58,.34)}
.leave-attachment-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid #e2e8f0;background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%)}
.leave-attachment-modal-titlebox{min-width:0;display:grid;gap:3px}.leave-attachment-modal-kicker{display:inline-flex;width:max-content;border-radius:999px;background:#e8f6fb;color:#0e5d89;border:1px solid #bfdeea;padding:5px 10px;font-size:11px;line-height:1.2;font-weight:650}.leave-attachment-modal-titlebox h2{margin:2px 0 0;color:#06243a;font-size:19px;line-height:1.35;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(690px,58vw)}.leave-attachment-modal-titlebox p{margin:0;color:#64748b;font-size:12.5px;line-height:1.45;font-weight:400}.leave-attachment-modal-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:0 0 auto}.leave-attachment-modal-close{min-width:38px;font-size:18px;line-height:1;padding-left:10px!important;padding-right:10px!important}
.leave-attachment-modal-body{min-height:0;background:linear-gradient(180deg,#f8fafc 0%,#eef5f8 100%);display:grid;overflow:hidden}.leave-attachment-preview-stage{min-width:0;min-height:0;width:100%;height:100%;display:grid;place-items:center;padding:16px;overflow:auto}.leave-attachment-preview-loading{color:#64748b;font-size:13px;font-weight:500}.leave-attachment-preview-stage.is-image img{max-width:100%;max-height:100%;object-fit:contain;border:1px solid #dbe4ef;border-radius:18px;background:#fff;box-shadow:0 12px 28px rgba(6,36,58,.10)}.leave-attachment-preview-stage.is-frame{padding:0;background:#f8fafc}.leave-attachment-preview-frame{width:100%;height:100%;border:0;background:#fff}.leave-attachment-preview-unsupported{width:min(420px,100%);display:grid;justify-items:center;gap:12px;text-align:center;background:#fff;border:1px solid #dbe4ef;border-radius:24px;padding:28px;box-shadow:0 16px 36px rgba(6,36,58,.10)}.leave-attachment-preview-icon{width:70px;height:70px;border-radius:22px;display:grid;place-items:center;background:#e8f6fb;color:#0e5d89;border:1px solid #bfdeea;font-size:18px;font-weight:600}.leave-attachment-preview-unsupported strong{font-size:16px;color:#0f172a;font-weight:600;word-break:break-word}.leave-attachment-preview-unsupported p{margin:0;color:#64748b;line-height:1.65;font-size:13px}.leave-attachment-list.is-detail .leave-attachment-item,.leave-existing-attachments .leave-attachment-item{border-radius:18px;border:1px solid #dbe4ef;background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%);box-shadow:0 1px 2px rgba(6,36,58,.04)}.js-attachment-preview{cursor:pointer}
@media(max-width:760px){.leave-attachment-modal{padding:8px}.leave-attachment-modal-panel{width:100%;height:calc(100vh - 16px);border-radius:18px}.leave-attachment-modal-header{display:grid;gap:12px;padding:12px}.leave-attachment-modal-titlebox h2{max-width:100%;font-size:16px;white-space:normal}.leave-attachment-modal-actions{justify-content:flex-start;flex-wrap:wrap}.leave-attachment-modal-actions .btn{flex:1 1 auto}.leave-attachment-preview-stage{padding:10px}.leave-attachment-preview-unsupported{padding:22px;border-radius:20px}.leave-attachment-actions{display:flex;flex-wrap:wrap;gap:6px}.leave-attachment-actions .btn{flex:1 1 auto}}

/* Phase 1.8.4 — System suggestion UI replaces browser datalist */
.leave-text-suggestion-group {
  position: relative;
}
.leave-system-combobox {
  position: relative;
}
.leave-system-combobox input {
  padding-right: 48px !important;
}
.leave-system-suggest-toggle {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 12px;
  background: #f1f5f9;
  color: #334155;
  display: grid;
  place-items: center;
  font-size: 16px;
  line-height: 1;
  cursor: pointer;
  transition: background .16s ease, color .16s ease, transform .16s ease;
}
.leave-system-suggest-toggle:hover {
  background: #dbeafe;
  color: #1d4ed8;
}
.leave-system-suggest-menu {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 80;
  max-height: 300px;
  overflow: auto;
  border: 1px solid #dbe4ef;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 20px 60px rgba(6, 36, 58, .16);
  padding: 8px;
}
.leave-system-suggest-menu[hidden] {
  display: none !important;
}
.leave-system-suggest-menu-head {
  padding: 7px 10px 8px;
  color: #64748b;
  font-size: 12px;
  font-weight: 500;
  border-bottom: 1px solid #eef2f7;
  margin-bottom: 6px;
}
.leave-system-suggest-options {
  display: grid;
  gap: 4px;
}
.leave-system-suggest-option {
  width: 100%;
  min-height: 38px;
  border: 0;
  border-radius: 12px;
  background: #fff;
  color: #0f172a;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 8px 10px;
  text-align: left;
  font-family: inherit;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.45;
  cursor: pointer;
  transition: background .14s ease, color .14s ease;
}
.leave-system-suggest-option:hover,
.leave-system-suggest-option:focus {
  background: #eff6ff;
  color: #1d4ed8;
  outline: none;
}
.leave-system-suggest-empty {
  padding: 12px 10px;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 400;
  text-align: center;
}
.leave-system-suggest-empty[hidden] {
  display: none !important;
}
.leave-text-suggestion-group input::-webkit-calendar-picker-indicator {
  display: none !important;
}
@media (max-width: 720px) {
  .leave-system-suggest-menu {
    position: fixed;
    left: 14px;
    right: 14px;
    top: auto;
    bottom: 14px;
    max-height: min(56vh, 380px);
    border-radius: 22px;
    box-shadow: 0 24px 70px rgba(6,36,58,.22);
  }
}

/* Phase 1.8.5 — Suggest dropdown hardening + creator audit UI */
.leave-system-combobox input {
  padding-right: 88px !important;
}
.leave-system-suggest-clear,
.leave-system-suggest-toggle {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 12px;
  display: grid;
  place-items: center;
  line-height: 1;
  cursor: pointer;
  transition: background .16s ease, color .16s ease, opacity .16s ease;
}
.leave-system-suggest-toggle {
  right: 8px;
  background: #f1f5f9;
  color: #334155;
  font-size: 16px;
}
.leave-system-suggest-clear {
  right: 48px;
  background: #fff1f2;
  color: #be123c;
  font-size: 18px;
  opacity: 0;
  pointer-events: none;
}
.leave-system-suggest-clear.is-visible {
  opacity: 1;
  pointer-events: auto;
}
.leave-system-suggest-clear:hover {
  background: #ffe4e6;
  color: #9f1239;
}
.leave-text-suggestion-group.is-suggest-open .leave-system-suggest-toggle {
  background: #dbeafe;
  color: #1d4ed8;
}
.leave-text-suggestion-group.is-suggest-open .leave-system-suggest-toggle {
  transform: translateY(-50%) rotate(180deg);
}
.leave-system-suggest-menu {
  z-index: 210;
}
.leave-system-suggest-option {
  font-weight: 400 !important;
}
.leave-creator-note {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  border: 1px solid #bfdeea;
  background: linear-gradient(135deg,#f8fbfd 0%,#e8f6fb 100%);
  border-radius: 18px;
  padding: 12px 14px;
  color: #0f172a;
}
.leave-creator-note strong {
  flex: 0 0 auto;
  font-weight: 600;
  color: #0e5d89;
}
.leave-creator-note span {
  color: #475569;
  font-size: 13px;
  line-height: 1.55;
  font-weight: 400;
}
.leave-creator-note.is-other-requester {
  border-color: #fed7aa;
  background: linear-gradient(135deg,#fff7ed 0%,#ffffff 100%);
}
.leave-creator-note.is-other-requester strong {
  color: #c2410c;
}
.creator-audit-row {
  border-color: #dbeafe !important;
  background: #f8fbff !important;
}
.creator-audit-row.is-other-requester {
  border-color: #fed7aa !important;
  background: #fff7ed !important;
}
.creator-audit-row small {
  display: block;
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
  font-weight: 400;
}
@media(max-width:720px){
  .leave-creator-note{display:grid;gap:6px}
  .leave-system-combobox input{padding-right:82px!important}
  .leave-system-suggest-clear{right:46px}
}

/* Phase 1.8.5.1 — Suggest control visual polish
   Replace chunky clear/toggle pills with subtle inline controls that match the system UI. */
.leave-system-combobox {
  position: relative;
  isolation: isolate;
}
.leave-system-combobox input {
  padding-right: 78px !important;
}
.leave-system-combobox::after {
  content: '';
  position: absolute;
  top: 8px;
  right: 42px;
  width: 1px;
  height: calc(100% - 16px);
  background: #e2e8f0;
  opacity: .9;
  pointer-events: none;
}
.leave-system-suggest-clear,
.leave-system-suggest-toggle {
  width: 30px !important;
  height: 30px !important;
  min-width: 30px !important;
  min-height: 30px !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  box-shadow: none !important;
  color: #64748b !important;
  font-size: 0 !important;
  line-height: 1 !important;
  display: grid !important;
  place-items: center !important;
  padding: 0 !important;
  transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease, opacity .16s ease !important;
}
.leave-system-suggest-toggle {
  right: 8px !important;
}
.leave-system-suggest-clear {
  right: 44px !important;
  opacity: 0;
  pointer-events: none;
  color: #94a3b8 !important;
}
.leave-system-suggest-clear.is-visible {
  opacity: 1;
  pointer-events: auto;
}
.leave-system-suggest-clear::before,
.leave-system-suggest-clear::after {
  content: '';
  position: absolute;
  width: 12px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}
.leave-system-suggest-clear::before {
  transform: rotate(45deg);
}
.leave-system-suggest-clear::after {
  transform: rotate(-45deg);
}
.leave-system-suggest-toggle::before {
  content: '';
  width: 8px;
  height: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-2px) rotate(45deg);
  border-radius: 1px;
}
.leave-system-suggest-clear:hover,
.leave-system-suggest-toggle:hover {
  background: #f8fafc !important;
  border-color: #dbe4ef !important;
  color: #0e5d89 !important;
}
.leave-system-suggest-clear:hover {
  color: #b91c1c !important;
  background: #fff7f7 !important;
  border-color: #fecaca !important;
}
.leave-text-suggestion-group.is-suggest-open .leave-system-suggest-toggle {
  background: #e8f6fb !important;
  border-color: #bfdeea !important;
  color: #0e5d89 !important;
  transform: translateY(-50%) rotate(180deg) !important;
}
.leave-text-suggestion-group.is-suggest-open .leave-system-suggest-toggle::before {
  transform: translateY(-2px) rotate(45deg);
}
.leave-system-suggest-menu {
  border-color: #dbe4ef !important;
  border-radius: 20px !important;
  padding: 8px !important;
  box-shadow: 0 22px 54px rgba(6,36,58,.14) !important;
}
.leave-system-suggest-menu-head {
  color: #64748b !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  letter-spacing: .01em;
}
.leave-system-suggest-option {
  border-radius: 14px !important;
  min-height: 40px !important;
  padding: 8px 11px !important;
  font-size: 13px !important;
  font-weight: 400 !important;
}
.leave-system-suggest-option:hover,
.leave-system-suggest-option:focus {
  background: #e8f6fb !important;
  color: #0b3b5f !important;
}
@media (max-width: 720px) {
  .leave-system-combobox input {
    padding-right: 74px !important;
  }
  .leave-system-combobox::after {
    right: 40px;
  }
  .leave-system-suggest-clear {
    right: 42px !important;
  }
}

/* Phase 1.9 — Cancellation & Reversal Foundation */
.leave-cancellation-card,
.approval-cancellation-card,
.cancellation-inbox-card{
  margin:18px 0;
  padding:20px;
  border-radius:26px;
  border:1px solid #dbe4ef;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  box-shadow:0 12px 34px rgba(6,36,58,.065);
}
.cancellation-pending-box{
  border:1px solid #fed7aa;
  background:#fff7ed;
  color:#7c2d12;
  border-radius:20px;
  padding:14px 16px;
  display:grid;
  gap:6px;
  margin-bottom:14px;
}
.cancellation-pending-box strong{font-weight:620;color:#9a3412}.cancellation-pending-box p{margin:0;line-height:1.65}.cancellation-pending-box small{color:#9a3412;font-size:12px}
.cancellation-request-form,.cancellation-decision-form{display:grid;gap:12px}.cancellation-request-form textarea,.cancellation-decision-form textarea{min-height:92px}
.cancellation-history-list{display:grid;gap:10px;margin-top:14px}.cancellation-history-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;border:1px solid #e2e8f0;background:#fff;border-radius:18px;padding:12px 14px}.cancellation-history-item strong{display:block;color:#06243a;font-weight:620}.cancellation-history-item p{margin:5px 0 0;color:#475569;line-height:1.55}.cancellation-history-item small{display:block;color:#64748b;margin-top:4px}.cancellation-history-item>span{white-space:nowrap;color:#64748b;font-size:12px;font-weight:500}
.cancel-reason-preview{display:block;max-width:360px;color:#475569;line-height:1.55;white-space:normal}.approval-action-buttons.two-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.status-cancel_requested{background:#fff7ed!important;border-color:#fed7aa!important;color:#c2410c!important}.status-cancelled{background:#f1f5f9!important;border-color:#cbd5e1!important;color:#475569!important}.btn.btn-danger,.button-danger{background:#b91c1c;border-color:#b91c1c;color:#fff}.btn.btn-danger:hover,.button-danger:hover{background:#991b1b;border-color:#991b1b}
@media(max-width:720px){.cancellation-history-item{grid-template-columns:1fr}.approval-action-buttons.two-actions{grid-template-columns:1fr}.leave-cancellation-card,.approval-cancellation-card,.cancellation-inbox-card{padding:16px;border-radius:22px}}

/* Phase 1.9.1 — Profile avatar upload and display */
.user-avatar.has-image,
.profile-avatar-large.has-image,
.profile-avatar-preview.has-image{
    overflow:hidden;
    background:#fff;
    border:1px solid #dbe5f0;
}
.user-avatar.has-image img,
.profile-avatar-large.has-image img,
.profile-avatar-preview.has-image img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
.user-avatar.has-image{
    padding:0;
    border-radius:14px;
}
.profile-avatar-card-pro{
    background:linear-gradient(180deg,#ffffff 0%,#f8fbfd 100%);
}
.profile-avatar-card-pro .profile-avatar-large{
    width:78px;
    height:78px;
    border-radius:26px;
    box-shadow:0 14px 30px rgba(6,36,58,.12);
}
.profile-avatar-manage-card{
    grid-column:1 / -1;
}
.profile-avatar-manage{
    display:grid;
    grid-template-columns:132px minmax(0,1fr);
    gap:1rem;
    align-items:start;
}
.profile-avatar-preview{
    width:132px;
    height:132px;
    border-radius:30px;
    display:grid;
    place-items:center;
    background:linear-gradient(135deg,#e8f6fb 0%,#ffffff 100%);
    color:#0e5d89;
    font-size:2.6rem;
    font-weight:560;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 14px 30px rgba(6,36,58,.10);
}
.profile-avatar-actions{
    display:grid;
    gap:.75rem;
    min-width:0;
}
.profile-avatar-upload-form{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:.75rem;
    align-items:center;
}
.profile-avatar-upload-form input[type="file"]{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
}
.profile-upload-dropzone{
    min-height:74px;
    border:1px dashed #b7d8e8;
    border-radius:20px;
    background:#f8fbfd;
    display:flex;
    align-items:center;
    gap:.85rem;
    padding:.85rem 1rem;
    cursor:pointer;
    transition:background .16s ease,border-color .16s ease,box-shadow .16s ease;
}
.profile-upload-dropzone:hover{
    background:#e8f6fb;
    border-color:#0d7fa8;
    box-shadow:0 0 0 4px rgba(13,127,168,.10);
}
.profile-upload-icon{
    width:42px;
    height:42px;
    border-radius:16px;
    display:grid;
    place-items:center;
    background:#fff;
    border:1px solid #dbe5f0;
    color:#0e5d89;
    font-weight:560;
    flex:0 0 auto;
}
.profile-upload-dropzone strong{
    display:block;
    color:#06243a;
    font-weight:560;
    font-size:.92rem;
}
.profile-upload-dropzone small{
    display:block;
    color:#607086;
    font-size:.78rem;
    line-height:1.45;
    margin-top:.12rem;
}
.profile-avatar-delete{
    color:#b91c1c!important;
    border-color:#fecaca!important;
    background:#fff!important;
}
.profile-avatar-delete:hover{
    background:#fff1f1!important;
}
.profile-avatar-meta{
    margin:0;
    color:#607086;
    font-size:.78rem;
    line-height:1.5;
}
@media(max-width:760px){
    .profile-avatar-manage{grid-template-columns:1fr;justify-items:start}
    .profile-avatar-upload-form{grid-template-columns:1fr}
    .profile-avatar-upload-form .btn{width:100%}
    .profile-avatar-preview{width:112px;height:112px;border-radius:26px}
}

/* Phase 1.9.2 — HR API mapping UI */
.hr-mapping-grid{display:grid;gap:18px}.hr-mapping-card{padding:0;overflow:hidden}.hr-mapping-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:16px 18px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fff 0%,#f8fbff 100%)}.hr-mapping-head strong{display:block;font-size:17px;font-weight:650;color:var(--ink)}.hr-mapping-head span:not(.badge){display:block;margin-top:4px;color:var(--muted);font-size:13px;line-height:1.55}.hr-mapping-table-wrap{border:0;border-radius:0}.hr-mapping-table td{vertical-align:top}.hr-mapping-edit{position:relative}.hr-mapping-edit summary{list-style:none;cursor:pointer}.hr-mapping-edit summary::-webkit-details-marker{display:none}.hr-mapping-edit[open] summary{margin-bottom:10px}.hr-mapping-edit-form{position:absolute;right:0;top:36px;z-index:70;width:min(360px,calc(100vw - 32px));display:grid;gap:12px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--shadow-lg)}.hr-mapping-edit-form .form-actions{margin-top:0}.hr-mapping-edit-form textarea{resize:vertical}@media(max-width:900px){.hr-mapping-head{display:grid}.hr-mapping-table{min-width:760px}.hr-mapping-edit-form{position:fixed;right:14px;left:14px;top:90px;width:auto}}

/* Phase 2.0 — Approval delegation / acting approver */
.delegation-hero {
    background: linear-gradient(135deg, #eff6ff 0%, #ffffff 58%, #f8fafc 100%);
}
.delegation-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(280px, .55fr);
    gap: 18px;
    align-items: start;
    margin-bottom: 18px;
}
.delegation-form-card,
.delegation-help-card,
.delegation-list-card {
    border-radius: 24px;
}
.delegation-form .field small {
    display: block;
    margin-top: 6px;
    color: #64748b;
    font-size: 12px;
    line-height: 1.45;
}
.delegation-rule-list {
    display: grid;
    gap: 12px;
}
.delegation-rule-list > div {
    display: grid;
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    padding: 12px;
    border: 1px solid #dbeafe;
    border-radius: 16px;
    background: #f8fbff;
}
.delegation-rule-list strong {
    width: 34px;
    height: 34px;
    border-radius: 12px;
    display: grid;
    place-items: center;
    background: #e0f2fe;
    color: #075985;
    font-weight: 800;
}
.delegation-rule-list span {
    color: #334155;
    line-height: 1.55;
    font-size: 13px;
}
.delegation-table td {
    vertical-align: top;
}
.delegation-reason {
    display: block;
    max-width: 280px;
    color: #475569;
    font-size: 12.5px;
    line-height: 1.55;
}
[data-delegation-department-field].is-muted {
    opacity: .55;
}
.delegation-acting-notice {
    margin-bottom: 14px;
}
.delegation-timeline-note {
    display: inline-flex;
    margin-left: 6px;
    padding: 2px 7px;
    border-radius: 999px;
    background: #eff6ff;
    color: #1d4ed8;
    font-weight: 700;
}
@media (max-width: 1100px) {
    .delegation-layout {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 720px) {
    .delegation-table {
        min-width: 920px;
    }
}

/* Phase 2.0.1 — UX/UI polish for Delegation and HR API Mapping pages */
.admin-pro-hero{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(280px,420px);
    gap:20px;
    align-items:stretch;
    border:1px solid #dbe5f0;
    border-radius:30px;
    padding:22px;
    margin:0 0 18px;
    background:linear-gradient(135deg,#ffffff 0%,#f4fbff 54%,#eef7fb 100%);
    box-shadow:0 16px 42px rgba(6,36,58,.07);
}
.admin-pro-hero-main{display:grid;gap:8px;align-content:center;min-width:0}
.admin-pro-kicker{display:inline-flex;width:max-content;max-width:100%;border:1px solid #bfdbfe;background:#eff6ff;color:#0e5d89;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:650;letter-spacing:.035em;text-transform:uppercase}
.admin-pro-hero h2{margin:0;color:#06243a;font-size:28px;line-height:1.18;font-weight:600;letter-spacing:-.035em}
.admin-pro-hero p{margin:0;max-width:820px;color:#607086;font-size:14px;line-height:1.75;font-weight:400}
.admin-pro-hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.admin-pro-hero-tags span{border:1px solid #dbe5f0;background:#fff;border-radius:999px;padding:6px 10px;color:#405269;font-size:12px;font-weight:500}
.admin-pro-kpi-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.admin-pro-kpi{border:1px solid #dbe5f0;background:rgba(255,255,255,.82);border-radius:20px;padding:14px;display:grid;gap:4px;box-shadow:0 1px 2px rgba(6,36,58,.04)}.admin-pro-kpi span{color:#607086;font-size:12px;font-weight:500}.admin-pro-kpi strong{color:#06243a;font-size:27px;line-height:1.05;font-weight:600}.admin-pro-kpi.is-green{background:#edfdf6;border-color:#bbf7d0}.admin-pro-kpi.is-blue{background:#eff6ff;border-color:#bfdbfe}.admin-pro-kpi.is-orange{background:#fff7ed;border-color:#fed7aa}
.admin-pro-card{border:1px solid #dbe5f0;border-radius:26px;background:rgba(255,255,255,.94);box-shadow:0 10px 30px rgba(6,36,58,.055);padding:18px;min-width:0}.admin-pro-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.admin-pro-card-head.compact{margin-bottom:12px}.admin-pro-card-head h3{margin:5px 0 0;color:#06243a;font-size:20px;line-height:1.28;font-weight:600;letter-spacing:-.025em}.admin-pro-card-head p{margin:5px 0 0;color:#607086;font-size:13px;line-height:1.6;font-weight:400}.admin-pro-icon{width:46px;height:46px;border-radius:17px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-weight:650;flex:0 0 auto}

.delegation-pro-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(300px,.55fr);gap:18px;margin-bottom:18px}.delegation-pro-form{display:grid;gap:16px}.delegation-people-grid{display:grid;grid-template-columns:minmax(0,1fr) 46px minmax(0,1fr);gap:12px;align-items:end}.delegation-person-field{border:1px solid #dbe5f0;border-radius:20px;background:#f8fbfd;padding:12px}.delegation-flow-arrow{width:46px;height:46px;border-radius:17px;background:#0e5d89;color:#fff;display:grid;place-items:center;font-size:20px;font-weight:600;margin-bottom:24px;box-shadow:0 12px 24px rgba(14,93,137,.2)}.delegation-date-grid{margin-top:0}.delegation-scope-panel{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:12px;border:1px dashed #bfdbfe;background:#f4fbff;border-radius:22px;padding:14px}.delegation-submit-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid #dbe5f0;background:#fff;border-radius:20px;padding:12px 14px}.delegation-submit-bar strong{display:block;color:#06243a;font-size:14px;font-weight:600}.delegation-submit-bar span{display:block;color:#607086;font-size:12px;margin-top:2px}.delegation-guide-card{align-self:start}.delegation-rule-list.pro>div{background:#f8fbfd;border-color:#dbe5f0}.delegation-rule-list.pro strong{background:#e8f6fb;color:#0e5d89;font-weight:600}
.admin-list-tools{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.admin-list-tools .input{min-width:260px}.admin-list-tools .select{width:auto;min-width:150px}.delegation-card-list{display:grid;gap:12px}.delegation-pro-card{border:1px solid #dbe5f0;border-radius:22px;background:#fff;padding:14px;display:grid;grid-template-columns:150px minmax(0,1fr) minmax(240px,.8fr) auto;gap:14px;align-items:center;box-shadow:0 1px 2px rgba(6,36,58,.035)}.delegation-pro-card-status{display:grid;gap:6px}.delegation-pro-card-status small{color:#607086;font-size:12px;line-height:1.45}.delegation-pro-card-people{display:grid;grid-template-columns:minmax(0,1fr) 28px minmax(0,1fr);gap:10px;align-items:center;min-width:0}.delegation-person{display:flex;align-items:center;gap:10px;min-width:0}.delegation-avatar{width:42px;height:42px;border-radius:16px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-weight:600;flex:0 0 auto}.delegation-avatar.is-delegate{background:#edfdf6;color:#16815a}.delegation-person div{min-width:0}.delegation-person small{display:block;color:#607086;font-size:11px;font-weight:500}.delegation-person strong{display:block;color:#06243a;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.delegation-person em{display:block;color:#607086;font-style:normal;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.delegation-card-arrow{width:28px;height:28px;border-radius:999px;background:#f1f5f9;color:#607086;display:grid;place-items:center}.delegation-pro-card-scope{display:flex;flex-wrap:wrap;gap:7px}.delegation-pro-card-scope span{border:1px solid #dbe5f0;background:#f8fbfd;border-radius:999px;padding:5px 9px;color:#405269;font-size:12px;font-weight:500}.delegation-pro-reason{grid-column:2 / 4;margin:-4px 0 0;color:#607086;font-size:12.5px;line-height:1.55}.delegation-pro-card-actions{justify-self:end}.admin-filter-empty{margin-top:4px}

.hr-ref-hero{background:linear-gradient(135deg,#ffffff 0%,#f4fbff 60%,#f8fafc 100%)}.hr-ref-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.hr-api-source-card{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.hr-api-source-main{display:flex;align-items:flex-start;gap:12px}.hr-api-source-main strong{display:block;color:#06243a;font-size:16px;font-weight:600}.hr-api-source-main p{margin:4px 0 0;color:#607086;line-height:1.6;font-size:13px}.hr-api-source-meta{display:grid;gap:4px;min-width:280px}.hr-api-source-meta span{font-size:11px;font-weight:600;color:#607086;text-transform:uppercase;letter-spacing:.04em}.hr-api-source-meta code{display:block;max-width:520px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:1px solid #dbe5f0;background:#f8fbfd;border-radius:12px;padding:8px 10px;color:#405269;font-size:12px}.hr-api-source-meta small{color:#607086;font-size:11px}.hr-ref-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.hr-ref-tab{border:1px solid #dbe5f0;background:#fff;border-radius:999px;padding:8px 12px;display:inline-flex;align-items:center;gap:7px;color:#405269;font-size:13px;font-weight:500;cursor:pointer}.hr-ref-tab:hover{border-color:#bfdbfe;background:#eff6ff;color:#0e5d89}.hr-ref-tab span{font-size:10px;border-radius:999px;background:#e8f6fb;color:#0e5d89;padding:3px 6px}.hr-ref-tab strong{font-weight:600;color:#06243a}.hr-ref-grid{display:grid;gap:18px}.hr-ref-section{padding:0;overflow:hidden}.hr-ref-section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;border-bottom:1px solid #dbe5f0;background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%)}.hr-ref-section-title{display:flex;align-items:center;gap:12px;min-width:0}.hr-ref-section-icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;font-size:12px;font-weight:650;flex:0 0 auto}.hr-ref-section-icon.is-blue{background:#eff6ff;color:#0e5d89}.hr-ref-section-icon.is-green{background:#edfdf6;color:#16815a}.hr-ref-section-icon.is-orange{background:#fff7ed;color:#e2742b}.hr-ref-section h3{margin:0;color:#06243a;font-size:20px;font-weight:600}.hr-ref-section p{margin:4px 0 0;color:#607086;font-size:13px;line-height:1.55}.hr-ref-section-summary{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.hr-ref-section-summary span{border:1px solid #dbe5f0;background:#fff;border-radius:999px;padding:5px 9px;color:#405269;font-size:12px;font-weight:500}.hr-ref-toolbar{display:flex;gap:10px;padding:14px 18px;border-bottom:1px solid #edf3f8;background:#fff}.hr-ref-toolbar .input{max-width:360px}.hr-ref-toolbar .select{width:auto;min-width:140px}.hr-ref-card-list{display:grid;gap:10px;padding:16px 18px 18px}.hr-ref-card{border:1px solid #dbe5f0;border-radius:20px;background:#fff;overflow:hidden}.hr-ref-card[open]{box-shadow:0 12px 30px rgba(6,36,58,.07);border-color:#bfdbfe}.hr-ref-card summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:130px minmax(0,1fr) auto;gap:12px;align-items:center;padding:13px 14px}.hr-ref-card summary::-webkit-details-marker{display:none}.hr-ref-code-block{border:1px solid #edf3f8;background:#f8fbfd;border-radius:14px;padding:8px 10px;display:grid;gap:2px}.hr-ref-code-block span{color:#607086;font-size:10.5px;font-weight:500}.hr-ref-code-block strong{color:#06243a;font-size:18px;font-weight:600;line-height:1.05}.hr-ref-name-block{display:grid;gap:3px;min-width:0}.hr-ref-name-block strong{color:#06243a;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hr-ref-name-block span{color:#607086;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hr-ref-status-actions{display:flex;align-items:center;gap:10px}.hr-ref-status-actions em{font-style:normal;color:#0e5d89;font-size:12px;font-weight:500}.hr-ref-edit-form{border-top:1px solid #edf3f8;background:#f8fbfd;padding:14px;display:grid;gap:12px}.hr-ref-edit-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.hr-ref-toggle{display:inline-flex;align-items:center;gap:9px;color:#405269;font-size:13px;font-weight:500}.hr-ref-toggle input{position:absolute;opacity:0}.hr-ref-toggle span{width:42px;height:24px;border:1px solid #cbd5e1;background:#e2e8f0;border-radius:999px;display:inline-flex;align-items:center;padding:2px}.hr-ref-toggle span:before{content:"";width:18px;height:18px;border-radius:999px;background:#fff;box-shadow:0 2px 6px rgba(15,23,42,.16);transition:transform .16s ease}.hr-ref-toggle input:checked+span{background:#0e5d89;border-color:#0e5d89}.hr-ref-toggle input:checked+span:before{transform:translateX(18px)}.hr-ref-empty{margin:0}
@media(max-width:1180px){.admin-pro-hero,.delegation-pro-layout{grid-template-columns:1fr}.delegation-pro-card{grid-template-columns:1fr}.delegation-pro-card-actions{justify-self:start}.delegation-pro-reason{grid-column:auto}.hr-api-source-card{display:grid}.hr-api-source-meta{min-width:0}.hr-ref-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:820px){.delegation-people-grid{grid-template-columns:1fr}.delegation-flow-arrow{margin:0 auto;transform:rotate(90deg)}.delegation-scope-panel{grid-template-columns:1fr}.delegation-submit-bar,.admin-pro-card-head,.hr-ref-section-head,.hr-ref-toolbar,.hr-ref-edit-actions{display:grid}.admin-list-tools,.admin-list-tools .input,.admin-list-tools .select{width:100%}.delegation-pro-card-people{grid-template-columns:1fr}.delegation-card-arrow{transform:rotate(90deg);margin:0 auto}.hr-ref-card summary{grid-template-columns:1fr}.hr-ref-status-actions{justify-content:space-between}.hr-ref-toolbar .input,.hr-ref-toolbar .select{max-width:none;width:100%}.admin-pro-kpi-grid,.hr-ref-kpi-grid{grid-template-columns:1fr 1fr}.hr-api-source-meta code{max-width:100%}}
@media(max-width:520px){.admin-pro-hero{padding:16px;border-radius:24px}.admin-pro-hero h2{font-size:24px}.admin-pro-kpi-grid,.hr-ref-kpi-grid{grid-template-columns:1fr}.admin-pro-card{padding:14px;border-radius:22px}.hr-ref-card-list,.hr-ref-section-head,.hr-ref-toolbar{padding:14px}.hr-ref-edit-form{padding:12px}}

/* Phase 2.0.2 — Profile official data edit polish */
.profile-edit-note{
  display:flex;
  gap:.65rem;
  align-items:flex-start;
  border:1px solid #b7d8e8;
  background:linear-gradient(135deg,#f0f8fc 0%,#ffffff 100%);
  border-radius:1rem;
  padding:.75rem .9rem;
  margin-bottom:1rem;
  color:#405269;
  font-size:.84rem;
  line-height:1.55;
}
.profile-edit-note strong{
  flex:0 0 auto;
  color:#0e5d89;
  font-weight:650;
}
.profile-card select.form-control{
  appearance:auto;
}
.profile-card .field-hint{
  display:block;
  margin-top:.4rem;
  color:#607086;
  font-size:.76rem;
  line-height:1.45;
}
@media(max-width:760px){
  .profile-edit-note{display:grid;gap:.25rem}
}

/* Phase 2.0.3 — Public working day / holiday calendar */
.calendar-hero{
    background:linear-gradient(135deg,#eff6ff 0%,#ffffff 58%,#f8fafc 100%);
    border:1px solid #dbeafe;
}
.calendar-toolbar{
    padding:16px 18px;
    margin-bottom:18px;
    border-radius:22px;
}
.calendar-filter-form{
    display:grid;
    grid-template-columns:minmax(220px,1.1fr) minmax(180px,.65fr) auto;
    gap:14px;
    align-items:end;
}
.calendar-filter-actions{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:8px;
    flex-wrap:wrap;
}
.calendar-summary-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
    margin-bottom:18px;
}
.calendar-summary-card .kpi-icon{
    width:42px;
    min-width:42px;
}
.calendar-summary-card.is-working .kpi-icon{background:#e8f6fb;color:#0e5d89}
.calendar-summary-card.is-holiday .kpi-icon{background:#fff1f1;color:#bd2b2b}
.calendar-summary-card.is-special .kpi-icon{background:#edfdf6;color:#16815a}
.calendar-summary-card.is-half .kpi-icon{background:#fff8e8;color:#c88618}
.calendar-panel{
    padding:20px;
    border-radius:26px;
    overflow:hidden;
}
.calendar-panel-head{
    display:flex;
    justify-content:space-between;
    gap:16px;
    align-items:flex-start;
    margin-bottom:16px;
}
.calendar-panel-head h2{
    margin:0;
    font-size:24px;
    line-height:1.25;
    color:#0b1728;
    font-weight:650;
}
.calendar-panel-head p{
    margin:5px 0 0;
    color:#607086;
    font-size:13px;
    line-height:1.55;
}
.calendar-legend{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    flex-wrap:wrap;
    gap:9px 13px;
    max-width:560px;
    color:#475569;
    font-size:12px;
    font-weight:500;
}
.calendar-legend span{
    display:inline-flex;
    align-items:center;
    gap:6px;
}
.calendar-legend i{
    width:11px;
    height:11px;
    border-radius:999px;
    display:inline-block;
    border:1px solid rgba(15,23,42,.08);
}
.legend-working{background:#e8f6fb}
.legend-holiday{background:#fff1f1}
.legend-special{background:#edfdf6}
.legend-half{background:#fff8e8}
.legend-today{background:#0e5d89}
.calendar-month-grid{
    display:grid;
    grid-template-columns:repeat(7,minmax(0,1fr));
    gap:8px;
}
.calendar-weekday{
    min-height:38px;
    display:grid;
    place-items:center;
    border-radius:14px;
    background:#f8fafc;
    color:#607086;
    font-size:12px;
    font-weight:650;
    border:1px solid #e2e8f0;
}
.calendar-day{
    position:relative;
    min-height:132px;
    border:1px solid #dbe4ef;
    border-radius:18px;
    background:#fff;
    padding:11px;
    display:grid;
    align-content:start;
    gap:6px;
    box-shadow:0 1px 2px rgba(15,23,42,.035);
    overflow:hidden;
}
.calendar-day:before{
    content:'';
    position:absolute;
    left:0;
    top:0;
    width:4px;
    height:100%;
    background:#cbd5e1;
}
.calendar-day-top{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:8px;
    min-width:0;
}
.calendar-day time{
    width:30px;
    height:30px;
    display:grid;
    place-items:center;
    border-radius:12px;
    background:#f1f5f9;
    color:#0f172a;
    font-size:13px;
    font-weight:650;
}
.calendar-day-top span{
    min-width:0;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    border-radius:999px;
    padding:4px 8px;
    background:#f8fafc;
    color:#475569;
    font-size:10.5px;
    font-weight:500;
    white-space:nowrap;
}
.calendar-day strong{
    color:#0f172a;
    font-size:13px;
    line-height:1.35;
    font-weight:500;
    min-height:34px;
}
.calendar-day small{
    color:#64748b;
    font-size:11px;
    line-height:1.35;
    font-weight:400;
}
.calendar-day em{
    justify-self:start;
    max-width:100%;
    border-radius:999px;
    background:rgba(255,255,255,.72);
    border:1px solid rgba(148,163,184,.22);
    padding:3px 7px;
    color:#64748b;
    font-size:10px;
    font-style:normal;
    font-weight:500;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.calendar-day-working{background:#ffffff}
.calendar-day-working:before{background:#0e5d89}
.calendar-day-working .calendar-day-top span{background:#e8f6fb;color:#0e5d89}
.calendar-day-weekend{background:#f8fafc;color:#64748b}
.calendar-day-weekend:before{background:#94a3b8}
.calendar-day-weekend .calendar-day-top span{background:#f1f5f9;color:#64748b}
.calendar-day-holiday{background:linear-gradient(180deg,#fff8f8 0%,#ffffff 100%);border-color:#fecaca}
.calendar-day-holiday:before{background:#bd2b2b}
.calendar-day-holiday .calendar-day-top span{background:#fff1f1;color:#bd2b2b}
.calendar-day-special-working{background:linear-gradient(180deg,#f3fff9 0%,#ffffff 100%);border-color:#bbf7d0}
.calendar-day-special-working:before{background:#16815a}
.calendar-day-special-working .calendar-day-top span{background:#edfdf6;color:#16815a}
.calendar-day-half{background:linear-gradient(180deg,#fffaf0 0%,#ffffff 100%);border-color:#fde68a}
.calendar-day-half:before{background:#c88618}
.calendar-day-half .calendar-day-top span{background:#fff8e8;color:#c88618}
.calendar-day.is-outside-month{
    opacity:.46;
    filter:saturate(.76);
}
.calendar-day.is-today{
    border-color:#0e5d89;
    box-shadow:0 0 0 3px rgba(14,93,137,.12),0 12px 26px rgba(6,36,58,.08);
}
.calendar-day.is-today time{
    background:#0e5d89;
    color:#fff;
}
.calendar-note-card{
    margin-top:18px;
    padding:14px 16px;
    border-radius:20px;
    background:#f8fafc;
    border:1px solid #dbe4ef;
}
.calendar-note-card strong{
    display:block;
    color:#0f172a;
    font-weight:650;
    margin-bottom:4px;
}
.calendar-note-card p{
    margin:0;
    color:#607086;
    font-size:13px;
    line-height:1.6;
}
@media(max-width:1180px){
    .calendar-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
    .calendar-filter-form{grid-template-columns:1fr 220px}
    .calendar-filter-actions{grid-column:1/-1;justify-content:flex-start}
    .calendar-panel-head{display:grid}
    .calendar-legend{justify-content:flex-start;max-width:none}
}
@media(max-width:860px){
    .calendar-month-grid{gap:6px;overflow:auto;padding-bottom:4px}
    .calendar-weekday,.calendar-day{min-width:132px}
    .calendar-day{min-height:124px;border-radius:16px;padding:10px}
}
@media(max-width:640px){
    .calendar-filter-form{grid-template-columns:1fr}
    .calendar-filter-actions .btn{width:100%}
    .calendar-summary-grid{grid-template-columns:1fr}
    .calendar-panel{padding:14px;border-radius:20px}
    .calendar-panel-head h2{font-size:20px}
}
@media print{
    .calendar-toolbar,.calendar-note-card,.page-hero-actions,.topbar,.sidebar{display:none!important}
    .app-shell{display:block!important}
    .content{padding:0!important}
    .calendar-panel{box-shadow:none!important;border:0!important;padding:0!important}
    .calendar-day{min-height:94px;box-shadow:none!important;page-break-inside:avoid}
    .calendar-day strong{font-size:10px;min-height:auto}
    .calendar-day small,.calendar-day em{font-size:9px}
}

/* Phase 2.0.4 — Delegation & working calendar UX polish */
.delegate-page-hero,
.calendar-view-hero{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);
  gap:18px;
  align-items:stretch;
  border:1px solid #dbeafe;
  background:linear-gradient(135deg,#ffffff 0%,#f2fbfd 54%,#eef8fc 100%);
  border-radius:30px;
  padding:22px;
  box-shadow:0 16px 44px rgba(6,36,58,.075);
  margin-bottom:18px;
}
.delegate-page-copy,
.calendar-view-copy{display:grid;gap:8px;align-content:center;min-width:0}
.delegate-kicker,
.calendar-view-kicker{
  display:inline-flex;
  width:max-content;
  max-width:100%;
  border:1px solid #bfdbfe;
  background:#eff6ff;
  color:#0e5d89;
  border-radius:999px;
  padding:5px 10px;
  font-size:11px;
  font-weight:500;
  letter-spacing:.035em;
}
.delegate-page-hero h2,
.calendar-view-hero h2{margin:0;color:#06243a;font-size:28px;line-height:1.18;font-weight:500;letter-spacing:-.025em}
.delegate-page-hero p,
.calendar-view-hero p{margin:0;max-width:860px;color:#607086;font-size:14px;line-height:1.75;font-weight:400}
.delegate-hero-chips,
.calendar-view-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.delegate-hero-chips span,
.calendar-view-meta span{border:1px solid #dbe5f0;background:#fff;border-radius:999px;padding:6px 10px;color:#405269;font-size:12px;font-weight:400}
.delegate-kpi-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;align-content:center}
.delegate-kpi,
.calendar-kpi{border:1px solid #dbe5f0;background:#fff;border-radius:20px;padding:14px;display:grid;gap:4px;box-shadow:0 1px 2px rgba(6,36,58,.04)}
.delegate-kpi span,
.calendar-kpi span{color:#607086;font-size:12px;font-weight:400}
.delegate-kpi strong,
.calendar-kpi strong{color:#06243a;font-size:26px;line-height:1.05;font-weight:500}
.delegate-kpi.is-active,.calendar-kpi.is-working{background:#edfdf6;border-color:#bbf7d0}
.delegate-kpi.is-scheduled{background:#eff6ff;border-color:#bfdbfe}
.delegate-kpi.is-expired,.calendar-kpi.is-half{background:#fff8e8;border-color:#fde68a}
.delegate-kpi.is-inactive{background:#f8fafc;border-color:#dbe5f0}
.delegate-workspace{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:18px;margin-bottom:18px;align-items:start}
.delegate-form-card,
.delegate-help-card,
.delegate-list-shell,
.calendar-control-panel,
.calendar-board-card,
.calendar-footnote{
  border:1px solid #dbe5f0;
  border-radius:26px;
  background:rgba(255,255,255,.94);
  box-shadow:0 10px 30px rgba(6,36,58,.055);
  padding:18px;
  min-width:0;
}
.delegate-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}
.delegate-card-head h3,
.delegate-help-card h3,
.delegate-list-head h3,
.calendar-board-head h3{margin:5px 0 0;color:#06243a;font-size:20px;line-height:1.28;font-weight:500;letter-spacing:-.015em}
.delegate-card-head p,
.delegate-list-head p,
.calendar-board-head p{margin:5px 0 0;color:#607086;font-size:13px;line-height:1.6;font-weight:400}
.delegate-head-icon{width:44px;height:44px;border-radius:16px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-weight:500;flex:0 0 auto}
.delegate-form-v2{display:grid;gap:14px}
.delegate-people-panel{display:grid;grid-template-columns:minmax(0,1fr) 110px minmax(0,1fr);gap:12px;align-items:stretch}
.delegate-person-select{border:1px solid #dbe5f0;border-radius:20px;background:#f8fbfd;padding:12px;display:grid;gap:5px}
.delegate-person-select small,.delegate-form-section small{color:#607086;font-size:12px;line-height:1.45}
.delegate-flow-center{display:grid;align-content:center;justify-items:center;gap:6px;color:#607086;font-size:11px;font-weight:500;text-align:center}
.delegate-flow-center strong{width:42px;height:42px;border-radius:16px;background:#0e5d89;color:#fff;display:grid;place-items:center;font-size:18px;font-weight:500;box-shadow:0 12px 24px rgba(14,93,137,.18)}
.delegate-form-section{border:1px solid #edf3f8;border-radius:20px;background:#fff;padding:14px;display:grid;gap:12px}
.delegate-section-title{display:flex;align-items:center;gap:9px;color:#06243a;font-size:14px;font-weight:500}
.delegate-section-title span{width:26px;height:26px;border-radius:10px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-size:12px;font-weight:500}
.compact-form-grid{gap:12px!important}
.delegate-scope-grid{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);gap:12px}
.delegate-condition-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}
.delegate-reason-field{grid-column:1/-1}
.delegate-submit-bar-v2{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid #dbe5f0;background:#f8fbfd;border-radius:20px;padding:12px 14px}
.delegate-submit-bar-v2 strong{display:block;color:#06243a;font-size:14px;font-weight:500}.delegate-submit-bar-v2 span{display:block;color:#607086;font-size:12px;margin-top:2px}
.delegate-help-card{position:sticky;top:92px;display:grid;gap:12px}
.delegate-rule-list-v2{display:grid;gap:10px}.delegate-rule-list-v2>div{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center;border:1px solid #dbe5f0;background:#f8fbfd;border-radius:18px;padding:12px}.delegate-rule-list-v2 strong{width:30px;height:30px;border-radius:12px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-weight:500}.delegate-rule-list-v2 span{color:#405269;font-size:13px;line-height:1.55}
.delegate-list-shell{padding:0;overflow:hidden}.delegate-list-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px;border-bottom:1px solid #edf3f8}.delegate-list-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.delegate-list-tools .input{min-width:320px}.delegate-list-tools .select{min-width:150px;width:auto}.delegate-card-list-v2{display:grid;gap:12px;padding:18px}.delegate-row-card{display:grid;grid-template-columns:160px minmax(0,1.25fr) minmax(260px,.85fr) auto;gap:14px;align-items:center;border:1px solid #dbe5f0;background:#fff;border-radius:22px;padding:14px;box-shadow:0 1px 2px rgba(6,36,58,.035);position:relative;overflow:hidden}.delegate-row-card:before{content:'';position:absolute;left:0;top:0;width:4px;height:100%;background:#cbd5e1}.delegate-row-card.is-active:before{background:#16a34a}.delegate-row-card.is-scheduled:before{background:#0e5d89}.delegate-row-card.is-expired:before{background:#c88618}.delegate-row-status{display:grid;gap:6px}.delegate-row-status small{color:#607086;font-size:12px;line-height:1.45}.delegate-row-people{display:grid;grid-template-columns:minmax(0,1fr) 28px minmax(0,1fr);gap:10px;align-items:center;min-width:0}.delegate-user-mini{display:flex;align-items:center;gap:10px;min-width:0}.delegate-avatar-v2{width:42px;height:42px;border-radius:16px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-weight:500;flex:0 0 auto}.delegate-avatar-v2.is-delegate{background:#edfdf6;color:#16815a}.delegate-user-mini div{min-width:0}.delegate-user-mini small{display:block;color:#607086;font-size:11px;font-weight:400}.delegate-user-mini strong{display:block;color:#06243a;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.delegate-user-mini em{display:block;color:#607086;font-style:normal;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.delegate-row-arrow{width:28px;height:28px;border-radius:999px;background:#f1f5f9;color:#607086;display:grid;place-items:center}.delegate-row-meta{display:flex;flex-wrap:wrap;gap:7px;min-width:0}.delegate-row-meta span{border:1px solid #dbe5f0;background:#f8fbfd;border-radius:999px;padding:5px 9px;color:#405269;font-size:12px;font-weight:400}.delegate-row-meta p{flex:0 0 100%;margin:0;color:#607086;font-size:12.5px;line-height:1.55}.delegate-row-actions{justify-self:end}.delegate-row-actions form{margin:0}
[data-delegation-department-field].is-muted{opacity:.62}
[data-delegation-department-field].is-muted select{background:#f8fafc;color:#94a3b8}
.calendar-view-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;align-content:center}.calendar-control-panel{padding:14px 16px;margin-bottom:16px}.calendar-control-form{display:grid;grid-template-columns:minmax(260px,1fr) 210px auto;gap:12px;align-items:end}.calendar-control-buttons{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.calendar-kpi-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.calendar-kpi small{color:#607086;font-size:12px;line-height:1.45}.calendar-kpi.is-holiday{background:#fff1f1;border-color:#fecaca}.calendar-kpi.is-special{background:#edfdf6;border-color:#bbf7d0}
.calendar-board-card{padding:18px;overflow:hidden}.calendar-board-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.calendar-legend-v2{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:9px 13px;max-width:560px;color:#475569;font-size:12px;font-weight:400}.calendar-legend-v2 span{display:inline-flex;align-items:center;gap:6px}.calendar-legend-v2 i{width:11px;height:11px;border-radius:999px;display:inline-block;border:1px solid rgba(15,23,42,.08)}.calendar-grid-v2{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.calendar-weekday-v2{min-height:38px;display:grid;place-items:center;border-radius:14px;background:#f8fafc;color:#607086;font-size:12px;font-weight:500;border:1px solid #e2e8f0}.calendar-day-v2{min-height:126px;border-radius:18px;padding:11px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.calendar-day-v2:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(6,36,58,.08)}.calendar-day-top-v2{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.calendar-day-top-v2 time{width:30px;height:30px;display:grid;place-items:center;border-radius:12px;background:#f1f5f9;color:#0f172a;font-size:13px;font-weight:500}.calendar-day-top-v2 span{min-width:0;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:4px 8px;background:#f8fafc;color:#475569;font-size:10.5px;font-weight:400;white-space:nowrap}.calendar-footnote{margin-top:16px;padding:14px 16px;background:#f8fafc}.calendar-footnote strong{display:block;color:#0f172a;font-weight:500;margin-bottom:4px}.calendar-footnote p{margin:0;color:#607086;font-size:13px;line-height:1.6}
@media(max-width:1180px){.delegate-page-hero,.calendar-view-hero,.delegate-workspace{grid-template-columns:1fr}.delegate-help-card{position:static}.delegate-row-card{grid-template-columns:1fr}.delegate-row-actions{justify-self:start}.calendar-kpi-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-control-form{grid-template-columns:1fr 210px}.calendar-control-buttons{grid-column:1/-1;justify-content:flex-start}.calendar-board-head{display:grid}.calendar-legend-v2{justify-content:flex-start;max-width:none}}
@media(max-width:860px){.delegate-people-panel{grid-template-columns:1fr}.delegate-flow-center{grid-template-columns:auto auto;justify-content:center}.delegate-flow-center strong{transform:rotate(90deg)}.delegate-scope-grid,.delegate-condition-grid{grid-template-columns:1fr}.delegate-submit-bar-v2,.delegate-list-head{display:grid}.delegate-list-tools,.delegate-list-tools .input,.delegate-list-tools .select{width:100%;min-width:0}.delegate-row-people{grid-template-columns:1fr}.delegate-row-arrow{transform:rotate(90deg);margin:0 auto}.calendar-grid-v2{gap:6px;overflow:auto;padding-bottom:4px}.calendar-weekday-v2,.calendar-day-v2{min-width:132px}.calendar-day-v2{min-height:118px;border-radius:16px;padding:10px}}
@media(max-width:640px){.delegate-page-hero,.calendar-view-hero{padding:16px;border-radius:24px}.delegate-page-hero h2,.calendar-view-hero h2{font-size:23px}.delegate-kpi-row,.calendar-kpi-strip{grid-template-columns:1fr}.delegate-form-card,.delegate-help-card,.delegate-list-shell,.calendar-control-panel,.calendar-board-card{border-radius:22px;padding:14px}.calendar-control-form{grid-template-columns:1fr}.calendar-control-buttons .btn,.calendar-view-actions .btn{width:100%}.calendar-board-head h3{font-size:20px}}
@media print{.calendar-view-actions,.calendar-control-panel,.calendar-footnote,.calendar-legend-v2{display:none!important}.calendar-view-hero,.calendar-board-card{box-shadow:none!important;border:0!important;padding:0!important}.calendar-kpi-strip{grid-template-columns:repeat(4,1fr)}.calendar-day-v2{min-height:90px;box-shadow:none!important;page-break-inside:avoid}}

/* Phase 2.0.5 — Menu restructuring + system-wide UX/UI review pass */
:root{
  --phase205-sidebar-w:300px;
  --phase205-surface:#ffffff;
  --phase205-surface-soft:#f7fbfd;
  --phase205-line:#dbe7f0;
  --phase205-text:#0b1728;
  --phase205-muted:#607086;
  --phase205-primary:#0e5d89;
  --phase205-primary-2:#0d7fa8;
  --phase205-soft:#e8f6fb;
  --phase205-radius:22px;
}
.app-shell{grid-template-columns:var(--phase205-sidebar-w) minmax(0,1fr)}
.sidebar{width:var(--phase205-sidebar-w);padding:16px 14px;background:linear-gradient(180deg,#ffffff 0%,#f7fbfd 100%)}
.brand{min-height:76px;padding:12px;border-radius:24px}.brand-mark{width:48px;height:48px;border-radius:18px;font-weight:600}.brand-title{font-size:17px;font-weight:600;letter-spacing:-.02em}.brand-subtitle{font-size:11.5px;font-weight:400;color:#6b7c90}.sidebar-status-card{padding:12px;border-radius:20px;margin-top:12px}.sidebar-status-card strong{font-weight:500}.sidebar-status-card small{font-weight:400}.nav{gap:0;margin-top:14px}.nav-group{display:grid;gap:5px;padding:10px 0;border-top:1px solid rgba(219,231,240,.75)}.nav-group:first-child{border-top:0;padding-top:0}.nav-group-debug{margin-top:8px;border:1px dashed #fed7aa;border-radius:18px;padding:10px;background:#fff7ed}.sidebar-section-label{margin:0 8px 4px;color:#7b8da2;font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:none}.nav a{min-height:46px;padding:8px 10px;border-radius:16px}.nav a:hover{transform:none;background:#fff;border-color:#dbe7f0}.nav a.is-active{background:linear-gradient(135deg,#064768 0%,#0d7fa8 100%);box-shadow:0 12px 24px rgba(13,127,168,.18)}.nav-icon{width:32px;height:32px;border-radius:13px;font-weight:500;font-size:12px}.nav-text strong{font-size:13.5px;font-weight:500;line-height:1.25}.nav-text small{font-size:11px;font-weight:400;line-height:1.3;color:#74889c}.topbar{min-height:68px;padding:0 24px;background:rgba(255,255,255,.88)}.topbar h1{font-size:23px;font-weight:500;letter-spacing:-.02em}.topbar-chip{font-weight:500}.user-chip span{font-weight:400}.content{padding:22px;gap:18px}.page-hero,.delegate-page-hero,.calendar-view-hero,.admin-pro-hero{border-radius:28px;box-shadow:0 16px 38px rgba(6,36,58,.075)}.page-hero h2,.delegate-page-hero h2,.calendar-view-hero h2,.admin-pro-hero h2{font-weight:500;letter-spacing:-.025em}.hero-kicker,.delegate-kicker,.calendar-view-kicker,.admin-pro-kicker{font-weight:500}.card,.soft-card,.panel,.summary-box,.module-card,.filter-card,.table-card{border-color:var(--phase205-line);border-radius:22px;box-shadow:0 10px 26px rgba(6,36,58,.055)}.section-header h3,.section-header h2,.card h3,.card h2{font-weight:500;letter-spacing:-.01em}.section-header p,.muted,.text-muted{font-weight:400}.kpi-grid,.my-leave-kpi-grid,.health-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.kpi-card{min-height:132px}.kpi-card strong,.kpi-card .kpi-value{font-weight:500}.form-grid,.premium-form-grid,.filter-grid{gap:14px}.form-group label,.field label,.form-label{font-weight:500;color:#11233a}.input,.select,.form-control,textarea,select{font-weight:400}.btn,.button,.btn-core{font-weight:500}.badge,.status-badge,.pill{font-weight:500}.data-table th,.table-wrap th{font-weight:500;text-transform:none;letter-spacing:0}.data-table td,.table-wrap td{font-weight:400}.data-table strong,.table-wrap strong{font-weight:500}.notice,.alert{font-weight:400}.notice strong,.alert strong{font-weight:500}.table-responsive{border-radius:20px}.topbar-user{gap:10px}.icon-btn{border-radius:14px}.debug-pill{font-weight:500}
/* Prevent normal user pages from leaking technical-looking secondary text. */
body:not(.debug-ui-enabled) .debug-inline,body:not(.debug-ui-enabled) .debug-panel,body:not(.debug-ui-enabled) .permission-strip{display:none!important}
/* Form action bars should never overlap content in normal pages. */
.form-actions,.button-row,.page-hero-actions{align-items:center}.form-actions .btn,.button-row .btn,.page-hero-actions .btn{min-height:40px}
@media(max-width:1180px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;transform:translateX(-105%);transition:transform .18s ease;width:min(var(--phase205-sidebar-w),calc(100vw - 42px));box-shadow:var(--shadow-lg)}body.sidebar-open .sidebar,.sidebar.is-open{transform:translateX(0)}.content{padding:16px}.topbar{padding:10px 16px}.topbar-user .topbar-chip{display:none}.kpi-grid,.my-leave-kpi-grid,.health-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){.topbar{align-items:flex-start}.topbar-title-wrap{min-width:0}.topbar h1{font-size:19px;white-space:normal}.topbar-user{margin-left:auto}.user-chip span{display:none}.content{padding:12px}.page-hero,.delegate-page-hero,.calendar-view-hero,.admin-pro-hero{padding:16px;border-radius:22px}.page-hero h2,.delegate-page-hero h2,.calendar-view-hero h2,.admin-pro-hero h2{font-size:24px}.kpi-grid,.my-leave-kpi-grid,.health-grid{grid-template-columns:1fr}.btn,.button,.btn-core{white-space:normal}.nav-group{padding:9px 0}}

/* Phase 2.0.6 — User / Employee consistency management */
.user-employee-hero{margin-bottom:18px}
.user-employee-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.data-authority-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:16px;margin-bottom:16px}
.data-authority-card p{margin:4px 0 0;color:#607086;line-height:1.65}.data-authority-card strong{color:#06243a;font-size:16px}
.user-employee-filter-card{padding:14px;margin-bottom:16px}.user-employee-filter{margin:0;grid-template-columns:minmax(280px,1fr) minmax(190px,.45fr) auto auto}
.user-employee-list{display:grid;gap:14px}.user-employee-card{display:grid;gap:14px;border:1px solid #dbe5f0;background:#fff;border-radius:24px;padding:16px;box-shadow:0 10px 28px rgba(6,36,58,.055)}
.user-employee-card.is-unlinked{border-color:#fecaca;background:linear-gradient(180deg,#fff 0%,#fff7f7 100%)}.user-employee-main{display:flex;align-items:flex-start;gap:14px}.user-employee-avatar{width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,#e8f6fb,#dbeafe);color:#0e5d89;display:grid;place-items:center;font-size:20px;font-weight:600;flex:0 0 auto}.user-employee-title{min-width:0;display:grid;gap:7px;flex:1}.user-employee-topline{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.user-employee-topline strong{font-size:18px;line-height:1.35;color:#06243a;font-weight:600}.user-employee-meta{display:flex;flex-wrap:wrap;gap:8px;color:#607086;font-size:12px;font-weight:500}.user-employee-meta span{display:inline-flex;border:1px solid #e2e8f0;background:#f8fafc;border-radius:999px;padding:5px 9px}.user-employee-issues{display:flex;flex-wrap:wrap;gap:6px}.user-employee-issues span{display:inline-flex;border-radius:999px;background:#fff7ed;border:1px solid #fed7aa;color:#c2410c;padding:4px 8px;font-size:11px;font-weight:600}.user-employee-info-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.user-employee-info-grid>div{border:1px solid #e2e8f0;background:#f8fafc;border-radius:16px;padding:10px;display:grid;gap:4px}.user-employee-info-grid span{color:#607086;font-size:11px;font-weight:600}.user-employee-info-grid strong{color:#0b1728;font-size:13px;line-height:1.4;font-weight:500;word-break:break-word}.user-employee-actions{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;border-top:1px solid #edf3f8;padding-top:12px}.user-employee-actions form{margin:0}.user-employee-relink{min-width:min(100%,520px);border:1px solid #dbe5f0;border-radius:16px;background:#f8fbfd;overflow:hidden}.user-employee-relink summary{cursor:pointer;padding:10px 12px;color:#0e5d89;font-size:13px;font-weight:600;list-style:none}.user-employee-relink summary::-webkit-details-marker{display:none}.user-employee-relink[open] summary{border-bottom:1px solid #dbe5f0;background:#fff}.user-employee-relink form{padding:12px;display:grid;gap:10px}.badge-gray{background:#f1f5f9;color:#64748b}
@media(max-width:1200px){.user-employee-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.user-employee-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.data-authority-card{grid-template-columns:1fr}.user-employee-filter{grid-template-columns:1fr}}
@media(max-width:720px){.user-employee-kpi-grid,.user-employee-info-grid{grid-template-columns:1fr}.user-employee-main{display:grid}.user-employee-actions,.user-employee-actions .button,.user-employee-actions form{width:100%}.user-employee-relink{width:100%}.user-employee-topline strong{font-size:16px}}

/* Phase 2.0.7 — Core Toast / Confirm / Alert System */
.core-toast-host{
    position:fixed;
    top:18px;
    right:18px;
    z-index:12000;
    display:grid;
    gap:12px;
    width:min(420px,calc(100vw - 28px));
    pointer-events:none;
}
.core-toast{
    display:grid;
    grid-template-columns:42px minmax(0,1fr) 32px;
    align-items:flex-start;
    gap:12px;
    padding:14px;
    border:1px solid #dbe5f0;
    border-radius:22px;
    background:rgba(255,255,255,.96);
    box-shadow:0 22px 60px rgba(6,36,58,.18);
    opacity:0;
    transform:translateY(-8px) scale(.985);
    transition:opacity .18s ease,transform .18s ease;
    pointer-events:auto;
    overflow:hidden;
    position:relative;
}
.core-toast::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:#0d7fa8}
.core-toast.is-visible{opacity:1;transform:translateY(0) scale(1)}
.core-toast-success::before{background:#16815a}.core-toast-error::before{background:#bd2b2b}.core-toast-warning::before{background:#e2742b}.core-toast-info::before{background:#0d7fa8}
.core-toast-icon{
    width:42px;height:42px;border-radius:16px;display:grid;place-items:center;
    font-weight:600;font-size:15px;background:#e8f6fb;color:#0d5f89;
}
.core-toast-success .core-toast-icon{background:#edfdf6;color:#16815a}.core-toast-error .core-toast-icon{background:#fff1f1;color:#bd2b2b}.core-toast-warning .core-toast-icon{background:#fff4ec;color:#e2742b}
.core-toast-body{min-width:0;padding-top:1px}.core-toast-body strong{display:block;color:#06243a;font-size:14px;font-weight:500;line-height:1.35}.core-toast-body p{margin:3px 0 0;color:#607086;font-size:13px;line-height:1.55;font-weight:400;word-break:break-word}.core-toast-close{width:30px;height:30px;border:0;border-radius:12px;background:#f4f8fb;color:#607086;display:grid;place-items:center;cursor:pointer;font-size:18px;line-height:1}.core-toast-close:hover{background:#eef5f8;color:#0b1728}
.core-dialog-open{overflow:hidden}.core-dialog-backdrop{position:fixed;inset:0;z-index:11900;display:grid;place-items:center;padding:18px;background:rgba(6,36,58,.56);backdrop-filter:blur(10px);opacity:0;transition:opacity .16s ease}.core-dialog-backdrop.is-visible{opacity:1}.core-dialog{width:min(470px,100%);display:grid;grid-template-columns:54px minmax(0,1fr);gap:14px;background:#fff;border:1px solid #dbe5f0;border-radius:28px;box-shadow:0 28px 90px rgba(6,36,58,.32);padding:22px;transform:translateY(8px) scale(.985);transition:transform .16s ease}.core-dialog-backdrop.is-visible .core-dialog{transform:translateY(0) scale(1)}.core-dialog-icon{width:54px;height:54px;border-radius:20px;display:grid;place-items:center;background:#e8f6fb;color:#0d5f89;font-size:20px;font-weight:600}.core-dialog-success .core-dialog-icon{background:#edfdf6;color:#16815a}.core-dialog-error .core-dialog-icon{background:#fff1f1;color:#bd2b2b}.core-dialog-warning .core-dialog-icon{background:#fff4ec;color:#e2742b}.core-dialog-content h2{margin:0;color:#06243a;font-size:20px;line-height:1.35;font-weight:500;letter-spacing:-.015em}.core-dialog-content p{margin:7px 0 0;color:#607086;font-size:14px;line-height:1.7}.core-dialog-actions{grid-column:1/-1;display:flex;justify-content:flex-end;gap:10px;margin-top:8px;flex-wrap:wrap}.core-dialog-actions .btn{min-width:104px}.core-alert{display:grid;grid-template-columns:40px minmax(0,1fr);gap:12px;align-items:flex-start;border:1px solid #dbe5f0;border-radius:20px;background:#fff;padding:14px 16px;margin-bottom:14px;box-shadow:0 8px 24px rgba(6,36,58,.06)}.core-alert-icon{width:40px;height:40px;border-radius:15px;display:grid;place-items:center;font-weight:600;background:#e8f6fb;color:#0d5f89}.core-alert strong{display:block;color:#06243a;font-size:14px;font-weight:500}.core-alert p{margin:3px 0 0;color:#607086;font-size:13px;line-height:1.6}.core-alert-success{border-color:#bfead7;background:#fbfffd}.core-alert-error{border-color:#f5c7c7;background:#fffafa}.core-alert-warning{border-color:#fed7aa;background:#fffdf8}.core-alert-success .core-alert-icon{background:#edfdf6;color:#16815a}.core-alert-error .core-alert-icon{background:#fff1f1;color:#bd2b2b}.core-alert-warning .core-alert-icon{background:#fff4ec;color:#e2742b}
@media(max-width:640px){.core-toast-host{left:14px;right:14px;top:14px;width:auto}.core-toast{grid-template-columns:36px minmax(0,1fr) 30px;border-radius:18px}.core-toast-icon{width:36px;height:36px;border-radius:14px}.core-dialog{grid-template-columns:1fr;gap:10px;border-radius:24px;padding:20px}.core-dialog-icon{width:48px;height:48px;border-radius:18px}.core-dialog-actions{display:grid;grid-template-columns:1fr}.core-dialog-actions .btn{width:100%}}

/* Phase 2.0.8 — HR Mapping form UI polish */
.hr-ref-hero-clean{
  margin-bottom:18px;
}
.hr-api-source-card-clean{
  margin-bottom:18px;
  padding:18px 22px;
}
.hr-ref-tabs-clean{
  margin:6px 0 18px;
}
.hr-ref-grid-clean{
  gap:20px;
}
.hr-ref-section-clean{
  overflow:hidden;
  border-radius:28px;
}
.hr-ref-section-head-clean{
  padding:20px 22px;
}
.hr-ref-toolbar-clean{
  display:grid;
  grid-template-columns:minmax(260px,420px) minmax(170px,220px) minmax(0,1fr);
  align-items:end;
  gap:12px;
  padding:16px 22px;
  background:#fbfdff;
}
.hr-ref-search-field,
.hr-ref-status-field{
  display:grid;
  gap:7px;
  min-width:0;
}
.hr-ref-search-field>span,
.hr-ref-status-field>span{
  color:#405269;
  font-size:12px;
  font-weight:500;
}
.hr-ref-toolbar-clean .input,
.hr-ref-toolbar-clean .select{
  max-width:none!important;
  width:100%!important;
}
.hr-ref-card-list-clean{
  gap:14px;
  padding:18px 22px 22px;
}
.hr-ref-card-pro{
  border-radius:24px;
  border-color:#dbe5f0;
  box-shadow:0 1px 2px rgba(6,36,58,.035);
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.hr-ref-card-pro:hover{
  border-color:#bfdbfe;
  transform:translateY(-1px);
  box-shadow:0 12px 28px rgba(6,36,58,.055);
}
.hr-ref-card-pro[open]{
  transform:none;
  box-shadow:0 18px 42px rgba(6,36,58,.085);
}
.hr-ref-card-summary-pro{
  grid-template-columns:150px minmax(0,1fr) auto!important;
  min-height:86px;
  gap:16px!important;
  padding:16px 18px!important;
  background:#fff;
}
.hr-ref-code-block-pro{
  min-height:58px;
  align-content:center;
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbfd 100%);
}
.hr-ref-code-block-pro strong{
  font-size:20px!important;
  letter-spacing:.02em;
}
.hr-ref-name-block-pro{
  gap:4px!important;
}
.hr-ref-name-block-pro strong{
  font-size:16px!important;
  line-height:1.35;
}
.hr-ref-name-block-pro small{
  display:block;
  color:#607086;
  font-size:12px;
  line-height:1.45;
  max-width:680px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.hr-ref-status-actions-pro{
  gap:9px!important;
  flex-wrap:nowrap;
}
.hr-ref-status-actions-pro i{
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border:1px solid #dbe5f0;
  border-radius:12px;
  color:#607086;
  font-style:normal;
  transition:transform .16s ease, background .16s ease;
}
.hr-ref-card-pro[open] .hr-ref-status-actions-pro i{
  transform:rotate(180deg);
  background:#eff6ff;
  color:#0e5d89;
  border-color:#bfdbfe;
}
.hr-ref-edit-form-pro{
  padding:0!important;
  gap:0!important;
  background:#f8fbfd!important;
  border-top:1px solid #dbe5f0!important;
}
.hr-ref-edit-panel-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding:16px 18px;
  border-bottom:1px solid #edf3f8;
  background:linear-gradient(180deg,#fbfdff 0%,#f8fbfd 100%);
}
.hr-ref-edit-panel-head strong{
  display:block;
  color:#06243a;
  font-size:16px;
  font-weight:600;
}
.hr-ref-edit-panel-head span{
  display:block;
  margin-top:3px;
  color:#607086;
  font-size:12px;
  line-height:1.55;
}
.hr-ref-edit-api-meta{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
  flex:0 0 auto;
}
.hr-ref-edit-api-meta span{
  margin:0;
  border:1px solid #dbe5f0;
  border-radius:999px;
  background:#fff;
  color:#405269;
  padding:6px 10px;
  font-size:11.5px;
  font-weight:500;
}
.hr-ref-edit-grid-pro{
  display:grid;
  grid-template-columns:minmax(220px,.7fr) minmax(260px,1fr) minmax(360px,1.25fr);
  gap:16px;
  padding:18px;
  align-items:start;
}
.hr-ref-edit-field{
  display:grid!important;
  gap:7px;
  min-width:0;
  padding:14px;
  border:1px solid #e3edf5;
  border-radius:20px;
  background:#fff;
}
.hr-ref-edit-field .form-label{
  margin:0;
  color:#11233a;
  font-size:13px;
  font-weight:500;
}
.hr-ref-edit-field .input{
  min-height:44px;
  border-radius:14px;
  font-size:14px;
  background:#fff;
}
.hr-ref-edit-field textarea.input{
  min-height:104px;
  resize:vertical;
  line-height:1.65;
}
.hr-ref-edit-field small{
  margin:0;
  color:#607086;
  font-size:11.5px;
  line-height:1.55;
}
.hr-ref-edit-actions-pro{
  display:flex!important;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:16px 18px;
  border-top:1px solid #edf3f8;
  background:#fff;
}
.hr-ref-toggle-pro{
  min-height:44px;
  padding:9px 12px;
  border:1px solid #dbe5f0;
  border-radius:16px;
  background:#f8fbfd;
}
.hr-ref-toggle-pro strong{
  color:#11233a;
  font-size:13px;
  font-weight:500;
}
.hr-ref-edit-actions-pro .button{
  min-height:44px;
  border-radius:14px;
  padding-left:18px;
  padding-right:18px;
}
@media(max-width:1180px){
  .hr-ref-edit-grid-pro{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .hr-ref-edit-field-full{
    grid-column:1 / -1;
  }
}
@media(max-width:820px){
  .hr-ref-toolbar-clean{
    grid-template-columns:1fr;
  }
  .hr-ref-card-summary-pro{
    grid-template-columns:1fr!important;
  }
  .hr-ref-status-actions-pro{
    justify-content:space-between;
  }
  .hr-ref-edit-panel-head,
  .hr-ref-edit-actions-pro{
    display:grid!important;
  }
  .hr-ref-edit-api-meta{
    justify-content:flex-start;
  }
  .hr-ref-edit-grid-pro{
    grid-template-columns:1fr;
    padding:14px;
    gap:12px;
  }
  .hr-ref-edit-field-full{
    grid-column:auto;
  }
  .hr-ref-edit-actions-pro .button{
    width:100%;
  }
}
@media(max-width:520px){
  .hr-ref-section-head-clean,
  .hr-ref-toolbar-clean,
  .hr-ref-card-list-clean{
    padding:14px;
  }
  .hr-ref-card-summary-pro{
    padding:14px!important;
  }
  .hr-ref-edit-panel-head,
  .hr-ref-edit-actions-pro{
    padding:14px;
  }
  .hr-ref-edit-field{
    padding:12px;
    border-radius:18px;
  }
}

/*
 * Phase 2.0.9 — System-wide Spacing Rhythm Pass
 * ปรับ margin / padding / gap ทั้งระบบให้มีจังหวะเดียวกัน โดยไม่เปลี่ยน route, DB, permission หรือ workflow
 */
:root{
  --space-0:0;
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --space-7:28px;
  --space-8:32px;
  --space-10:40px;
  --page-x:24px;
  --page-y:22px;
  --card-p:20px;
  --card-p-lg:24px;
  --section-gap:18px;
  --form-gap:14px;
  --control-gap:8px;
  --control-h:42px;
  --radius-card:22px;
  --radius-section:18px;
}

/* Page shell rhythm */
.content,
.stock-page-shell{
  padding:var(--page-y) var(--page-x)!important;
  gap:var(--section-gap)!important;
}
.stock-page-card,
.page-card,
.card,
.glass-card,
.admin-pro-card,
.form-card,
.filter-card,
.report-card,
.health-card,
.command-card,
.delegate-form-card,
.delegate-help-card,
.delegate-list-shell,
.calendar-board-card,
.calendar-control-panel,
.hr-ref-section-clean,
.hr-api-source-card-clean,
.user-employee-panel,
.user-employee-card,
.profile-card,
.leave-attachment-card,
.approval-inbox-card,
.approval-info-card,
.approval-steps-card,
.approval-timeline-card,
.vacation-policy-card,
.working-day-card{
  border-radius:var(--radius-card)!important;
  padding:var(--card-p)!important;
}
.stock-page-card{
  min-height:calc(100vh - 118px)!important;
  padding:var(--card-p-lg)!important;
}

/* Consistent vertical stacks */
.dashboard-layout,
.form-stack,
.master-content,
.delegate-workspace,
.delegate-form-v2,
.delegate-card-list-v2,
.hr-ref-grid-clean,
.hr-ref-card-list-clean,
.calendar-grid-v2,
.approval-timeline,
.approval-block-grid,
.approval-detail-grid,
.health-grid,
.kpi-grid,
.admin-pro-kpi-grid,
.carry-forward-summary-grid,
.permission-summary-grid,
.movement-kpi-grid,
.user-employee-grid,
.leave-attachment-list,
.cancellation-history-list{
  gap:var(--section-gap)!important;
}
.card + .card,
.glass-card + .glass-card,
.section-header + .table-responsive,
.section-header + .form-grid,
.section-header + .form-stack,
.page-hero + .card,
.page-hero + .dashboard-layout,
.page-hero + .filter-card{
  margin-top:var(--section-gap)!important;
}

/* Headers / hero blocks */
.page-hero,
.admin-pro-hero,
.dashboard-hero,
.form-hero,
.health-hero,
.delegate-page-hero,
.calendar-view-hero,
.hr-ref-hero-clean,
.approval-detail-hero,
.auth-card-header,
.hr-api-source-card-clean{
  padding:var(--card-p-lg)!important;
  border-radius:26px!important;
  margin:0 0 var(--section-gap)!important;
}
.page-hero h1,
.page-hero h2,
.admin-pro-hero h2,
.dashboard-hero h1,
.form-hero h2,
.health-hero h2,
.delegate-page-hero h2,
.calendar-view-copy h2,
.hr-ref-hero-clean h2,
.approval-detail-hero h2,
.stock-page-title{
  margin:0!important;
  line-height:1.24!important;
}
.page-hero p,
.admin-pro-hero p,
.dashboard-hero p,
.form-hero p,
.health-hero p,
.delegate-page-copy p,
.calendar-view-copy p,
.hr-ref-hero-clean p{
  margin-top:var(--space-2)!important;
  margin-bottom:0!important;
  line-height:1.65!important;
}
.section-header,
.page-section-header,
.hr-ref-section-head-clean,
.delegate-list-head,
.calendar-board-head,
.approval-block-head,
.leave-attachment-head{
  margin:0 0 var(--space-4)!important;
  padding-bottom:var(--space-3)!important;
  gap:var(--space-4)!important;
}

/* Sidebar and topbar density */
.sidebar,
.stock-sidebar{
  padding:var(--space-4)!important;
}
.brand,
.stock-brand,
.stock-scope-card,
.stock-system-state{
  padding:var(--space-3)!important;
  margin-bottom:var(--space-3)!important;
}
.nav-section,
.stock-nav-group{
  margin:var(--space-4) 0!important;
}
.nav-link,
.stock-nav-link{
  min-height:44px!important;
  padding:var(--space-2) var(--space-3)!important;
  gap:var(--space-3)!important;
  border-radius:16px!important;
}
.topbar,
.stock-topbar{
  min-height:68px!important;
  height:auto!important;
  padding:var(--space-3) var(--page-x)!important;
  gap:var(--space-4)!important;
}
.topbar-user,
.stock-topbar-actions{
  gap:var(--space-2)!important;
}

/* Forms: labels, controls, grid */
.form-grid,
.filter-grid,
.compact-form-grid,
.delegate-condition-grid,
.delegate-scope-grid,
.info-grid,
.approval-info-grid,
.hr-ref-edit-grid-pro{
  gap:var(--form-gap)!important;
}
.form-group,
.field,
.auth-field,
.filter-field,
.hr-ref-edit-field{
  gap:6px!important;
}
.form-group label,
.field label,
.form-label,
.auth-field label,
.hr-ref-edit-field .form-label{
  margin:0 0 4px!important;
  line-height:1.35!important;
}
input,
select,
textarea,
.input,
.select,
.form-control,
.auth-input-wrap input,
.hr-ref-edit-field .input{
  min-height:var(--control-h)!important;
  padding:10px 13px!important;
  border-radius:14px!important;
  line-height:1.45!important;
}
textarea,
textarea.input,
.hr-ref-edit-field textarea.input{
  min-height:92px!important;
  padding-top:11px!important;
  padding-bottom:11px!important;
}
.form-actions,
.button-row,
.action-row,
.approval-action-buttons,
.calendar-control-buttons,
.delegate-row-actions,
.hr-ref-status-actions-pro,
.hr-ref-edit-actions-pro{
  gap:var(--control-gap)!important;
}
.btn,
.button,
.btn-core,
.auth-submit{
  min-height:40px!important;
  padding:9px 14px!important;
  border-radius:13px!important;
}
.btn-sm,
.button-sm{
  min-height:32px!important;
  padding:6px 10px!important;
}

/* Tables and list cards */
.table-responsive,
.table-wrap,
.table-container{
  border-radius:18px!important;
  margin-top:var(--space-3)!important;
}
.data-table th,
.table-wrap th,
.data-table td,
.table-wrap td{
  padding:12px 14px!important;
  line-height:1.5!important;
}
.data-table th,
.table-wrap th{
  height:42px!important;
}
.hr-ref-card-list-clean,
.delegate-card-list-v2,
.leave-attachment-list,
.cancellation-history-list{
  padding:var(--space-4)!important;
}
.hr-ref-card-summary-pro,
.delegate-row-card,
.leave-attachment-item,
.approval-step,
.approval-timeline-item,
.cancellation-history-item,
.calendar-day-v2{
  padding:var(--space-4)!important;
  border-radius:18px!important;
}
.hr-ref-edit-panel-head,
.hr-ref-edit-actions-pro,
.delegate-submit-bar-v2{
  padding:var(--space-4)!important;
}
.hr-ref-edit-grid-pro{
  padding:var(--space-4)!important;
}

/* KPI / badge / utility */
.kpi-card,
.admin-pro-kpi,
.delegate-kpi,
.calendar-kpi,
.carry-forward-card,
.health-card,
.summary-card{
  padding:var(--space-4)!important;
  border-radius:20px!important;
}
.badge,
.badge-blue,
.badge-gray,
.badge-cyan,
.badge-red,
.badge-green,
.badge-orange,
.numeric-pill,
.auth-secure-badge{
  padding:5px 10px!important;
  line-height:1.2!important;
}
.alert,
.notice,
.auth-alert,
.alert-info,
.alert-warning,
.alert-error,
.alert-danger{
  padding:var(--space-3) var(--space-4)!important;
  border-radius:16px!important;
  margin:0 0 var(--space-4)!important;
}

/* Specific pages with previously uneven whitespace */
.hr-ref-hero-clean,
.hr-api-source-card-clean{
  align-items:center!important;
}
.hr-ref-toolbar-clean{
  padding:var(--space-4)!important;
  gap:var(--form-gap)!important;
}
.hr-ref-section-head-clean{
  padding:var(--space-4)!important;
}
.delegate-people-panel,
.delegate-form-section,
.delegate-reason-field,
.delegate-rule-list-v2{
  padding:var(--space-4)!important;
  border-radius:18px!important;
}
.calendar-view-actions,
.calendar-legend-v2,
.calendar-footnote{
  gap:var(--space-2)!important;
  margin-top:var(--space-3)!important;
}
.calendar-grid-v2{
  padding:var(--space-3)!important;
}

/* Responsive density */
@media(max-width:1180px){
  :root{
    --page-x:18px;
    --page-y:18px;
    --card-p:18px;
    --card-p-lg:20px;
    --section-gap:16px;
    --form-gap:12px;
  }
  .form-grid>.form-group,
  .filter-grid>.form-group{
    grid-column:span 6!important;
  }
}
@media(max-width:760px){
  :root{
    --page-x:12px;
    --page-y:12px;
    --card-p:14px;
    --card-p-lg:16px;
    --section-gap:14px;
    --form-gap:10px;
    --control-h:40px;
  }
  .content,
  .stock-page-shell{
    padding:var(--page-y) var(--page-x)!important;
  }
  .stock-page-card,
  .page-card,
  .card,
  .glass-card,
  .admin-pro-card,
  .form-card,
  .filter-card,
  .report-card,
  .health-card,
  .delegate-form-card,
  .delegate-help-card,
  .delegate-list-shell,
  .calendar-board-card,
  .calendar-control-panel,
  .hr-ref-section-clean,
  .hr-api-source-card-clean{
    padding:var(--card-p)!important;
    border-radius:18px!important;
  }
  .page-hero,
  .admin-pro-hero,
  .dashboard-hero,
  .form-hero,
  .health-hero,
  .delegate-page-hero,
  .calendar-view-hero,
  .hr-ref-hero-clean,
  .approval-detail-hero{
    padding:var(--card-p-lg)!important;
    border-radius:20px!important;
  }
  .topbar,
  .stock-topbar{
    padding:10px 12px!important;
  }
  .form-grid>.form-group,
  .filter-grid>.form-group,
  .filter-grid>.form-actions{
    grid-column:1 / -1!important;
  }
  .form-actions,
  .button-row{
    align-items:stretch!important;
  }
  .form-actions .btn,
  .form-actions .button,
  .button-row .btn,
  .button-row .button{
    width:100%!important;
  }
  .data-table th,
  .table-wrap th,
  .data-table td,
  .table-wrap td{
    padding:10px 11px!important;
  }
}

/* Phase 2.0.10 — Form/Button spacing normalization hotfix
   Fixes cramped filter/search forms where action buttons sit too close to fields. */
:root{
  --form-control-gap: 12px;
  --form-action-gap: 10px;
  --form-block-gap: 16px;
}

/* Search / filter bars: keep fields and actions aligned, but never cramped. */
.filter-bar,
.search-bar,
.search-filter,
.user-employee-filter,
.hr-ref-toolbar-clean,
.calendar-filter-row,
.delegate-filter-row,
.report-filter-bar{
  display:grid!important;
  grid-template-columns:minmax(280px,1.4fr) minmax(200px,.75fr) auto auto!important;
  align-items:end!important;
  column-gap:var(--form-control-gap)!important;
  row-gap:var(--form-action-gap)!important;
  padding:16px!important;
}

.filter-bar .field,
.search-bar .field,
.search-filter .field,
.user-employee-filter .field,
.report-filter-bar .field{
  display:grid!important;
  gap:6px!important;
  margin:0!important;
  min-width:0!important;
}

.filter-bar .form-label,
.search-bar .form-label,
.search-filter .form-label,
.user-employee-filter .form-label,
.report-filter-bar .form-label{
  min-height:18px!important;
  margin:0!important;
  line-height:1.35!important;
  font-size:13px!important;
  font-weight:600!important;
  color:#0f2a44!important;
}

.filter-bar .input,
.filter-bar .select,
.search-bar .input,
.search-bar .select,
.search-filter .input,
.search-filter .select,
.user-employee-filter .input,
.user-employee-filter .select,
.report-filter-bar .input,
.report-filter-bar .select{
  width:100%!important;
  min-height:46px!important;
  padding:0 16px!important;
  border-radius:16px!important;
}

.filter-bar > .button,
.filter-bar > .btn,
.filter-bar > a.button,
.search-bar > .button,
.search-bar > .btn,
.search-filter > .button,
.search-filter > .btn,
.user-employee-filter > .button,
.user-employee-filter > a.button,
.report-filter-bar > .button,
.report-filter-bar > a.button{
  min-height:46px!important;
  padding:0 18px!important;
  border-radius:16px!important;
  align-self:end!important;
  justify-self:start!important;
  white-space:nowrap!important;
  margin:0!important;
}

/* Generic form actions: create consistent distance from last field. */
.form-actions,
.button-row,
.action-row,
.settings-sticky-actions,
.permission-sticky-save,
.material-form-actions,
.material-form-actions-sticky,
.profile-actions,
.delegate-form-actions,
.calendar-form-actions{
  gap:var(--form-action-gap)!important;
  row-gap:var(--form-action-gap)!important;
}

form > .form-actions,
form > .button-row,
form > .action-row,
.admin-pro-card > form .form-actions,
.admin-pro-card > form .button-row{
  margin-top:var(--form-block-gap)!important;
}

/* Buttons should have breathing room when they wrap. */
.button,
.btn,
.btn-core{
  min-height:42px!important;
  padding:0 16px!important;
  border-radius:14px!important;
  line-height:1.2!important;
}
.button-sm,
.btn-sm,
.btn.small{
  min-height:34px!important;
  padding:0 12px!important;
  border-radius:12px!important;
}

/* Inline forms inside cards should not collapse spacing. */
.admin-pro-card form,
.card form,
.soft-card form,
.panel form{
  min-width:0;
}

/* Filter cards: avoid content touching the card edge. */
.user-employee-filter-card,
.report-filter-card,
.filter-card,
.search-card{
  padding:0!important;
  overflow:hidden!important;
}
.user-employee-filter-card .filter-bar,
.report-filter-card .filter-bar,
.filter-card .filter-bar,
.search-card .filter-bar{
  margin:0!important;
  border:0!important;
  border-radius:0!important;
  background:#fff!important;
}

/* Tablet: two-column filters, actions stay below if needed. */
@media(max-width:1100px){
  .filter-bar,
  .search-bar,
  .search-filter,
  .user-employee-filter,
  .hr-ref-toolbar-clean,
  .calendar-filter-row,
  .delegate-filter-row,
  .report-filter-bar{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    padding:14px!important;
  }
  .filter-bar > .button,
  .filter-bar > a.button,
  .search-bar > .button,
  .search-filter > .button,
  .user-employee-filter > .button,
  .user-employee-filter > a.button,
  .report-filter-bar > .button,
  .report-filter-bar > a.button{
    justify-self:stretch!important;
    width:100%!important;
  }
}

/* Mobile: stack fields/actions with clear rhythm. */
@media(max-width:720px){
  .filter-bar,
  .search-bar,
  .search-filter,
  .user-employee-filter,
  .hr-ref-toolbar-clean,
  .calendar-filter-row,
  .delegate-filter-row,
  .report-filter-bar{
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding:12px!important;
  }
  .filter-bar > .button,
  .filter-bar > a.button,
  .search-bar > .button,
  .search-filter > .button,
  .user-employee-filter > .button,
  .user-employee-filter > a.button,
  .report-filter-bar > .button,
  .report-filter-bar > a.button{
    width:100%!important;
    justify-content:center!important;
  }
  .form-actions,
  .button-row,
  .action-row{
    display:flex!important;
    flex-direction:column!important;
    align-items:stretch!important;
  }
  .form-actions .button,
  .button-row .button,
  .action-row .button,
  .form-actions .btn,
  .button-row .btn,
  .action-row .btn{
    width:100%!important;
  }
}

/* Phase 2.1 — Notification Center */
.notification-menu{position:relative;display:inline-flex;align-items:center;z-index:70}
.notification-bell{position:relative;width:42px;height:42px;border:1px solid #dbeafe;background:linear-gradient(180deg,#fff,#f8fbff);border-radius:16px;display:grid;place-items:center;color:#0e5d89;box-shadow:0 8px 22px rgba(6,36,58,.06);cursor:pointer;transition:.16s ease}
.notification-bell:hover{transform:translateY(-1px);border-color:#93c5fd;box-shadow:0 12px 28px rgba(6,36,58,.11)}
.notification-bell span{font-size:17px;line-height:1}.notification-bell strong{position:absolute;right:-5px;top:-6px;min-width:20px;height:20px;padding:0 5px;border-radius:999px;background:#dc2626;color:#fff;border:2px solid #fff;display:grid;place-items:center;font-size:10px;font-weight:800;line-height:1}
.notification-dropdown{position:absolute;right:0;top:calc(100% + 12px);width:min(390px,calc(100vw - 24px));background:#fff;border:1px solid #dbe4ef;border-radius:22px;box-shadow:0 24px 70px rgba(6,36,58,.2);overflow:hidden;display:none}.notification-menu.is-open .notification-dropdown{display:block}
.notification-dropdown-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px;border-bottom:1px solid #eef2f7;background:linear-gradient(180deg,#f8fbff,#fff)}.notification-dropdown-head strong{display:block;color:#0b1728;font-size:15px}.notification-dropdown-head small{display:block;margin-top:2px;color:#64748b;font-size:12px}.notification-dropdown-head a{font-size:12px;font-weight:700;color:#0e5d89;text-decoration:none}.notification-dropdown-head a:hover{text-decoration:underline}
.notification-dropdown-list{max-height:390px;overflow:auto}.notification-dropdown-empty{padding:24px;text-align:center;color:#64748b;font-weight:600}.notification-dropdown-item{margin:0;border:0;border-bottom:1px solid #f1f5f9}.notification-dropdown-item:last-child{border-bottom:0}.notification-dropdown-item button{width:100%;border:0;background:#fff;text-align:left;display:grid;grid-template-columns:10px minmax(0,1fr);gap:10px;padding:13px 16px;cursor:pointer}.notification-dropdown-item button:hover{background:#f8fbff}.notification-dropdown-item strong{display:block;color:#0b1728;font-size:13px;line-height:1.35;font-weight:650}.notification-dropdown-item small{display:block;margin-top:3px;color:#64748b;font-size:12px;line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notification-dropdown-item time{display:block;margin-top:5px;color:#94a3b8;font-size:11px;font-weight:600}.notification-dot{width:8px;height:8px;margin-top:6px;border-radius:999px;background:#cbd5e1}.notification-dropdown-item.is-unread .notification-dot{background:#0d7fa8;box-shadow:0 0 0 4px rgba(13,127,168,.1)}.notification-dropdown-item.is-unread button{background:#f2fbfd}.notification-dropdown-item.is-unread strong{font-weight:750}
.notification-page-hero{align-items:center}.notification-tabs{margin:0}.notification-list-card{padding:18px}.notification-list{display:grid;gap:12px}.notification-item{display:grid;grid-template-columns:42px minmax(0,1fr);gap:13px;border:1px solid #dbe4ef;background:#fff;border-radius:20px;padding:14px;box-shadow:0 1px 2px rgba(6,36,58,.04)}.notification-item.is-unread{border-color:#bfdbfe;background:linear-gradient(180deg,#eff6ff 0%,#fff 100%)}.notification-item-icon{width:42px;height:42px;border-radius:15px;background:#f1f5f9;color:#64748b;display:grid;place-items:center;font-weight:900}.notification-item.is-unread .notification-item-icon{background:#dbeafe;color:#0e5d89}.notification-item-body{min-width:0}.notification-item-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.notification-item-top strong{font-size:15px;line-height:1.35;color:#0b1728}.notification-item-top time{font-size:12px;color:#64748b;white-space:nowrap}.notification-item p{margin:5px 0 0;color:#475569;line-height:1.6}.notification-item-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:12px}.notification-item-actions form{margin:0}
@media(max-width:760px){.notification-dropdown{right:-72px;width:calc(100vw - 18px)}.notification-item{grid-template-columns:1fr}.notification-item-icon{width:36px;height:36px}.notification-item-top{display:grid}.notification-item-top time{white-space:normal}.notification-page-hero .page-hero-actions{align-items:stretch}.notification-page-hero .page-hero-actions .btn,.notification-page-hero .page-hero-actions form,.notification-page-hero .page-hero-actions button{width:100%}}

/* Phase 2.2 — SLA Pending Task + Escalation Dashboard */
.sla-hero,.sla-settings-hero{background:linear-gradient(135deg,#ffffff 0%,#eef8fb 56%,#f8fbfd 100%);border:1px solid #dbe5f0}
.sla-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))!important;margin-bottom:var(--space-5,20px)}
.sla-filter-card{padding:0!important;overflow:hidden}.sla-filter-bar{display:grid;grid-template-columns:minmax(260px,1.4fr) minmax(180px,.8fr) minmax(220px,1fr) auto;gap:14px;align-items:end;margin:0;padding:18px;background:#fff;border:0}.sla-filter-bar .filter-field{display:grid;gap:7px}.sla-filter-bar .filter-field span{font-size:12px;font-weight:700;color:#607086}.filter-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end}.sla-task-list{display:grid;gap:12px}.sla-task-item{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(220px,.9fr) minmax(150px,.55fr) auto;gap:16px;align-items:center;border:1px solid #dbe5f0;background:#fff;border-radius:22px;padding:16px;box-shadow:0 8px 22px rgba(6,36,58,.045)}.sla-task-item.sla-status-warning{border-color:#fed7aa;background:linear-gradient(180deg,#fffaf4 0%,#fff 100%)}.sla-task-item.sla-status-overdue{border-color:#fecaca;background:linear-gradient(180deg,#fff5f5 0%,#fff 100%)}.sla-task-item.sla-status-escalated{border-color:#fca5a5;background:linear-gradient(180deg,#fff1f2 0%,#fff 100%);box-shadow:0 12px 30px rgba(189,43,43,.09)}.sla-task-main{display:grid;gap:8px;min-width:0}.sla-task-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sla-task-head strong{font-size:16px;color:#06243a}.sla-task-head small{color:#607086;font-size:12px;font-weight:600}.sla-task-title{display:grid;gap:3px}.sla-task-title strong{font-size:15px;color:#0b1728}.sla-task-title span,.sla-task-meta span,.sla-task-step small,.sla-task-time small{font-size:12px;color:#607086;font-weight:500}.sla-task-meta{display:flex;gap:8px;flex-wrap:wrap}.sla-task-meta span{border:1px solid #dbe5f0;background:#f8fbfd;border-radius:999px;padding:4px 9px}.sla-task-step,.sla-task-time{display:grid;gap:4px}.sla-task-step span,.sla-task-time span{font-size:11px;font-weight:700;color:#607086;text-transform:uppercase;letter-spacing:.03em}.sla-task-step strong{font-size:14px;color:#06243a}.sla-task-time strong{font-size:20px;line-height:1;color:#06243a}.sla-task-action{display:flex;justify-content:flex-end}.sla-status-pill{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:5px 10px;border-radius:999px;font-size:12px;font-weight:700;border:1px solid #dbe5f0;background:#f8fbfd;color:#405269;white-space:nowrap}.sla-status-normal{background:#edfdf6!important;border-color:#bbf7d0!important;color:#16815a!important}.sla-status-warning{background:#fff8e8!important;border-color:#fde68a!important;color:#c88618!important}.sla-status-overdue{background:#fff1f1!important;border-color:#fecaca!important;color:#bd2b2b!important}.sla-status-escalated{background:#bd2b2b!important;border-color:#bd2b2b!important;color:#fff!important}.sla-policy-list{display:grid;gap:14px}.sla-policy-item{border:1px solid #dbe5f0;background:#fff;border-radius:22px;padding:16px;display:grid;gap:14px}.sla-policy-title{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center}.sla-policy-code{display:inline-flex;align-items:center;justify-content:center;min-width:76px;height:42px;border-radius:14px;background:#e8f6fb;color:#0e5d89;font-weight:700}.sla-policy-title strong{display:block;font-size:16px;color:#06243a}.sla-policy-title small{display:block;margin-top:3px;color:#607086}.sla-policy-toggle{display:inline-flex;align-items:center;gap:8px;border:1px solid #dbe5f0;border-radius:999px;padding:7px 10px;background:#f8fbfd;font-weight:700;color:#405269}.sla-policy-toggle input{width:16px;height:16px;accent-color:#0e5d89}.sla-policy-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.sla-policy-grid .field,.sla-policy-add-form .field{display:grid;gap:7px}.sla-policy-grid .field span,.sla-policy-add-form .field span{font-size:12px;font-weight:700;color:#607086}.field-wide{grid-column:1/-1}.sla-policy-add-form{grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}.dashboard-sla-panel{margin-top:20px}.dashboard-sla-list{display:grid;gap:9px}.dashboard-sla-row{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(160px,.8fr) auto;gap:12px;align-items:center;border:1px solid #dbe5f0;background:#fff;border-radius:16px;padding:12px;text-decoration:none;color:#0b1728}.dashboard-sla-row:hover{border-color:#9dd8ea;background:#f8fbfd}.dashboard-sla-row strong{display:block;color:#06243a}.dashboard-sla-row small{display:block;margin-top:3px;color:#607086;font-size:12px}.dashboard-sla-row span{font-size:13px;color:#405269;font-weight:600}.dashboard-sla-row b{font-size:13px;color:#06243a}.dashboard-sla-row.sla-status-warning{border-color:#fed7aa;background:#fffaf4}.dashboard-sla-row.sla-status-overdue,.dashboard-sla-row.sla-status-escalated{border-color:#fecaca;background:#fff5f5}
@media(max-width:1100px){.sla-filter-bar{grid-template-columns:1fr 1fr}.filter-actions{justify-content:flex-start}.sla-task-item{grid-template-columns:1fr}.sla-task-action{justify-content:flex-start}.sla-policy-grid,.sla-policy-add-form{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-sla-row{grid-template-columns:1fr}}
@media(max-width:640px){.sla-filter-bar,.sla-policy-grid,.sla-policy-add-form{grid-template-columns:1fr}.filter-actions,.filter-actions .btn{width:100%}.sla-task-item{padding:14px;border-radius:18px}.sla-policy-title{grid-template-columns:1fr}.sla-policy-code{justify-content:flex-start;padding:0 12px;width:max-content}.sla-policy-toggle{justify-content:flex-start;width:max-content}}

/* Phase 2.3 — Leave Calendar / Team Availability */
.leave-calendar-page{display:grid;gap:18px}.leave-calendar-hero{display:grid;grid-template-columns:minmax(0,1fr) 420px;gap:18px;align-items:stretch;border:1px solid #dbeafe;border-radius:28px;background:linear-gradient(135deg,#eff6ff 0%,#ffffff 58%,#f8fafc 100%);padding:22px;box-shadow:0 14px 38px rgba(6,36,58,.08)}.leave-calendar-hero-main{display:grid;align-content:center;gap:8px;min-width:0}.leave-calendar-hero h2{margin:0;color:#06243a;font-size:30px;line-height:1.18;font-weight:650;letter-spacing:-.03em}.leave-calendar-hero p{margin:0;color:#607086;line-height:1.7;font-weight:400;max-width:880px}.leave-calendar-hero-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.page-kicker{display:inline-flex;width:max-content;border:1px solid #bfdbfe;border-radius:999px;background:#eff6ff;color:#0e5d89;padding:5px 10px;font-size:12px;font-weight:600}.leave-calendar-kpis{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.leave-calendar-kpis>div{border:1px solid #dbe4ef;background:#fff;border-radius:20px;padding:14px;display:grid;gap:4px;align-content:center}.leave-calendar-kpis span{font-size:12px;color:#607086;font-weight:500}.leave-calendar-kpis strong{font-size:28px;line-height:1.1;color:#06243a;font-weight:600}.calendar-filter-card{display:grid;grid-template-columns:150px minmax(200px,1fr) minmax(180px,.8fr) minmax(180px,.8fr) minmax(240px,1.1fr) auto;gap:14px;align-items:end;border:1px solid #dbe4ef;border-radius:24px;background:#fff;padding:18px;box-shadow:0 8px 26px rgba(6,36,58,.055)}.calendar-filter-card .field{display:grid;gap:6px}.calendar-filter-card label{font-size:13px;font-weight:600;color:#0b1728}.calendar-filter-actions{display:flex;gap:8px;align-items:center;justify-content:flex-end}.calendar-legend-card{display:flex;flex-wrap:wrap;gap:10px;align-items:center;border:1px solid #dbe4ef;border-radius:18px;background:#fff;padding:12px 14px}.calendar-legend-card span{display:inline-flex;align-items:center;gap:7px;color:#607086;font-size:12px;font-weight:500}.calendar-legend-card i{width:12px;height:12px;border-radius:999px;display:inline-block}.calendar-legend-card i.is-approved{background:#16a34a}.calendar-legend-card i.is-pending{background:#0e5d89}.calendar-legend-card i.is-warning{background:#e2742b}.calendar-legend-card i.is-danger{background:#bd2b2b}.calendar-scope-chip{margin-left:auto;border:1px solid #dbeafe;background:#eff6ff;border-radius:999px;padding:6px 10px;color:#0e5d89!important}.leave-calendar-shell{border:1px solid #dbe4ef;border-radius:26px;background:#fff;overflow:hidden;box-shadow:0 10px 30px rgba(6,36,58,.06)}.leave-calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.leave-calendar-grid.weekdays{background:#f8fbfd;border-bottom:1px solid #dbe4ef}.leave-calendar-grid.weekdays>div{text-align:center;padding:11px;color:#607086;font-size:12px;font-weight:600}.leave-calendar-day{min-height:145px;border-right:1px solid #edf3f8;border-bottom:1px solid #edf3f8;background:#fff;padding:10px;display:grid;grid-template-rows:auto 1fr;gap:8px;min-width:0}.leave-calendar-day:nth-child(7n){border-right:0}.leave-calendar-day.is-other-month{background:#f8fafc;color:#94a3b8}.leave-calendar-day.is-today{box-shadow:inset 0 0 0 2px #0d7fa8;background:#f2fbfd}.leave-calendar-day.has-leave{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)}.leave-calendar-day-head{display:flex;align-items:center;justify-content:space-between;gap:6px}.leave-calendar-day-head strong{width:30px;height:30px;border-radius:12px;display:grid;place-items:center;color:#06243a;font-size:13px;font-weight:600}.leave-calendar-day.is-today .leave-calendar-day-head strong{background:#0d7fa8;color:#fff}.leave-calendar-day-head span{font-size:10px;color:#0d7fa8;font-weight:600}.leave-calendar-events{display:grid;gap:5px;align-content:start;min-width:0}.leave-event{display:grid;gap:1px;text-decoration:none;border-radius:12px;padding:7px 8px;border:1px solid #dbe4ef;background:#f8fafc;color:#0b1728;min-width:0}.leave-event strong{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leave-event span{font-size:11px;color:#607086;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leave-event.is-approved{border-color:#bbf7d0;background:#f0fdf4}.leave-event.is-pending{border-color:#bfdbfe;background:#eff6ff}.leave-event.is-warning{border-color:#fed7aa;background:#fff7ed}.leave-event.is-danger{border-color:#fecaca;background:#fff1f1}.leave-event.is-returned{border-color:#e9d5ff;background:#faf5ff}.leave-event-more{border:1px dashed #cbd5e1;background:#fff;color:#607086;border-radius:12px;min-height:30px;font-size:11px;font-weight:600;cursor:pointer}.calendar-list-card{border:1px solid #dbe4ef;background:#fff;border-radius:24px;padding:18px;box-shadow:0 8px 26px rgba(6,36,58,.055)}.calendar-list-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.calendar-list-head h3{margin:5px 0 0;color:#06243a;font-size:20px;font-weight:600}.calendar-status-pill{display:inline-flex;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:600}.calendar-status-pill.is-approved{background:#dcfce7;color:#15803d}.calendar-status-pill.is-pending{background:#dbeafe;color:#0e5d89}.calendar-status-pill.is-warning{background:#ffedd5;color:#c2410c}.calendar-status-pill.is-danger{background:#fee2e2;color:#b91c1c}.calendar-status-pill.is-returned{background:#f3e8ff;color:#7e22ce}.calendar-status-pill.is-muted{background:#f1f5f9;color:#607086}@media(max-width:1320px){.leave-calendar-hero{grid-template-columns:1fr}.leave-calendar-kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.calendar-filter-card{grid-template-columns:repeat(3,minmax(0,1fr))}.calendar-filter-keyword{grid-column:span 2}.calendar-filter-actions{justify-content:flex-start}}@media(max-width:900px){.calendar-filter-card{grid-template-columns:1fr 1fr}.calendar-filter-keyword{grid-column:1/-1}.calendar-filter-actions{grid-column:1/-1}.leave-calendar-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.leave-calendar-shell{overflow:auto}.leave-calendar-grid{min-width:900px}.leave-calendar-day{min-height:135px}.calendar-scope-chip{margin-left:0}}@media(max-width:640px){.leave-calendar-hero{padding:16px;border-radius:22px}.leave-calendar-hero h2{font-size:24px}.leave-calendar-kpis,.calendar-filter-card{grid-template-columns:1fr}.calendar-filter-actions{display:grid}.calendar-filter-actions .btn{width:100%}.calendar-list-card{padding:14px;border-radius:20px}.calendar-list-table table{min-width:920px}.leave-calendar-grid{min-width:780px}}

/* Phase 2.4 — Report Center & Export Governance */
.report-center-hero,
.report-summary-hero{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(240px,320px);
    gap:22px;
    align-items:stretch;
    border:1px solid var(--line,#dbe5f0);
    border-radius:30px;
    background:linear-gradient(135deg,#ffffff 0%,#f2fbfd 58%,#e8f6fb 100%);
    padding:24px;
    box-shadow:0 18px 46px rgba(6,36,58,.08);
    margin-bottom:20px;
}
.report-center-hero h2,
.report-summary-hero h2{margin:4px 0 8px;color:#06243a;font-size:30px;line-height:1.18;font-weight:650;letter-spacing:-.025em}
.report-center-hero p,
.report-summary-hero p{margin:0;color:#607086;font-size:14px;line-height:1.75;max-width:840px}.hero-kicker{display:inline-flex;align-items:center;border:1px solid #bfdbfe;background:#eff6ff;color:#0e5d89;border-radius:999px;padding:6px 11px;font-size:12px;font-weight:600}.report-center-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.report-center-period{border:1px solid #cde8f3;background:#fff;border-radius:24px;padding:18px;display:grid;align-content:center;gap:5px;min-height:150px}.report-center-period span,.report-summary-kpis span{font-size:12px;font-weight:600;color:#607086}.report-center-period strong{font-size:30px;line-height:1;color:#06243a;font-weight:650}.report-center-period small{color:#607086;line-height:1.45}.report-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px}.report-kpi-card{border:1px solid var(--line,#dbe5f0);border-radius:22px;background:#fff;padding:18px;box-shadow:0 10px 26px rgba(6,36,58,.055)}.report-kpi-card span{display:block;color:#607086;font-size:12px;font-weight:600}.report-kpi-card strong{display:block;margin-top:6px;color:#06243a;font-size:30px;line-height:1;font-weight:650}.report-kpi-card small{display:block;margin-top:8px;color:#607086}.report-kpi-card.is-warning{background:#fff7ed;border-color:#fed7aa}.report-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:20px}.report-link-card{display:flex;flex-direction:column;justify-content:space-between;gap:16px;min-height:190px;border:1px solid var(--line,#dbe5f0);border-radius:24px;background:#fff;color:inherit;text-decoration:none;padding:20px;box-shadow:0 10px 26px rgba(6,36,58,.055);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.report-link-card:hover{transform:translateY(-2px);border-color:#9bd4e8;box-shadow:0 18px 42px rgba(6,36,58,.11)}.report-link-card span{display:inline-flex;width:max-content;border-radius:999px;background:#e8f6fb;color:#0e5d89;border:1px solid #cde8f3;padding:5px 10px;font-size:11px;font-weight:600}.report-link-card h3{margin:10px 0 6px;color:#06243a;font-size:20px;line-height:1.25;font-weight:650}.report-link-card p{margin:0;color:#607086;font-size:13px;line-height:1.65}.report-link-card>strong{font-size:13px;color:#0e5d89;font-weight:600}.report-center-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}.report-center-grid.is-bottom{align-items:start}.report-panel{padding:18px;border-radius:24px}.section-header.compact{margin-bottom:14px}.section-header.compact h2{font-size:18px;font-weight:650;color:#06243a}.section-header.compact p{font-size:13px;color:#607086}.report-mini-list,.report-export-list,.report-trend-list{display:grid;gap:10px}.report-mini-row,.report-export-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid #e3edf5;background:#fff;border-radius:16px;padding:12px 14px}.report-mini-row strong,.report-export-row strong{display:block;color:#06243a;font-size:14px;font-weight:600}.report-mini-row small,.report-export-row small{display:block;margin-top:3px;color:#607086;font-size:12px}.report-mini-row>span,.report-export-row>span{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:32px;border-radius:999px;background:#e8f6fb;color:#0e5d89;font-weight:650}.report-trend-row{display:grid;grid-template-columns:86px 1fr 84px;gap:12px;align-items:center}.report-trend-row strong,.report-trend-row span{font-size:12px;font-weight:600;color:#607086}.report-trend-track{height:12px;border-radius:999px;background:#edf3f8;overflow:hidden}.report-trend-track i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#0e5d89,#13a5c7)}.report-summary-kpis{display:grid;grid-template-columns:1fr;gap:10px}.report-summary-kpis div{border:1px solid #cde8f3;background:#fff;border-radius:18px;padding:14px}.report-summary-kpis strong{display:block;margin-top:5px;color:#06243a;font-size:26px;line-height:1;font-weight:650}.report-filter-grid{display:grid;grid-template-columns:1.2fr repeat(3,minmax(160px,.75fr));gap:14px;align-items:end}.report-filter-grid .form-group{display:grid;gap:6px}.report-filter-grid label{font-size:13px;font-weight:600;color:#0b1728}.report-filter-grid input,.report-filter-grid select{min-height:44px;border:1px solid #cbd9e6;border-radius:14px;padding:0 12px;background:#fff}.report-filter-actions{grid-column:1/-1;display:flex;gap:10px;justify-content:flex-end;margin-top:2px}.block-muted{display:block;margin-top:2px;color:#607086;font-size:11px}.status-badge{display:inline-flex;align-items:center;border-radius:999px;background:#eff6ff;color:#0e5d89;border:1px solid #cde8f3;padding:5px 9px;font-size:11px;font-weight:600}
@media(max-width:1180px){.report-kpi-grid,.report-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-center-grid,.report-center-hero,.report-summary-hero{grid-template-columns:1fr}.report-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-summary-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:720px){.report-center-hero,.report-summary-hero{padding:18px;border-radius:24px}.report-center-hero h2,.report-summary-hero h2{font-size:24px}.report-kpi-grid,.report-card-grid,.report-filter-grid,.report-summary-kpis{grid-template-columns:1fr}.report-filter-actions{justify-content:stretch;flex-direction:column}.report-filter-actions .btn{width:100%}.report-trend-row{grid-template-columns:1fr}.report-center-actions .btn{width:100%}}
@media print{.report-center-hero,.report-summary-hero,.filter-card,.no-print,.sidebar,.topbar{display:none!important}.app-shell{display:block}.main-section{display:block}.content{padding:0!important}.report-card{border:0!important;box-shadow:none!important}.report-table{font-size:11px}.report-table th,.report-table td{padding:6px!important}.print-header{display:block;text-align:center;margin-bottom:12px}}

/* Phase 2.5 — System QA Gate */
.qa-hero{
    display:grid;
    grid-template-columns:minmax(0,1fr) 180px;
    gap:18px;
    align-items:stretch;
    border:1px solid #dbe4ef;
    border-radius:28px;
    padding:22px;
    margin-bottom:18px;
    background:linear-gradient(135deg,#ffffff 0%,#f8fbff 58%,#eff6ff 100%);
    box-shadow:0 14px 34px rgba(6,36,58,.075);
}
.qa-hero.is-warn{background:linear-gradient(135deg,#ffffff 0%,#fffaf2 58%,#eff6ff 100%)}
.qa-hero.is-fail{background:linear-gradient(135deg,#ffffff 0%,#fff1f1 58%,#eff6ff 100%)}
.qa-hero-copy h2{margin:0;font-size:28px;line-height:1.18;font-weight:600;color:#06243a;letter-spacing:-.02em}
.qa-hero-copy p{margin:8px 0 0;color:#607086;line-height:1.7;max-width:900px}
.qa-hero-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.qa-hero-meta span{display:inline-flex;border:1px solid #dbe4ef;background:#fff;border-radius:999px;padding:6px 10px;color:#334155;font-size:12px;font-weight:500}
.qa-score-card{display:grid;align-content:center;justify-items:center;text-align:center;border:1px solid #bfdbfe;background:#fff;border-radius:22px;padding:18px}
.qa-score-card span,.qa-kpi span{font-size:12px;font-weight:500;color:#64748b}
.qa-score-card strong{font-size:44px;line-height:1;font-weight:600;color:#bd2b2b}
.qa-score-card small,.qa-kpi small{font-size:12px;color:#64748b;line-height:1.45}
.qa-kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}
.qa-kpi{border:1px solid #dbe4ef;background:#fff;border-radius:20px;padding:16px;display:grid;gap:5px;box-shadow:0 1px 2px rgba(6,36,58,.04)}
.qa-kpi strong{font-size:30px;line-height:1.05;font-weight:600;color:#06243a}
.qa-kpi-ok{border-color:#bbf7d0;background:#f0fdf4}.qa-kpi-ok strong{color:#16815a}
.qa-kpi-warn{border-color:#fde68a;background:#fffbeb}.qa-kpi-warn strong{color:#c88618}
.qa-kpi-fail{border-color:#fecaca;background:#fff1f1}.qa-kpi-fail strong{color:#bd2b2b}
.qa-action-strip{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px solid #dbe4ef;background:#fff;border-radius:20px;padding:14px 16px;margin-bottom:18px}
.qa-action-strip strong{display:block;color:#0b1728;font-weight:600}.qa-action-strip span{display:block;margin-top:3px;color:#64748b;font-size:13px}.qa-action-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.qa-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.qa-group-card{border:1px solid #dbe4ef;background:#fff;border-radius:24px;box-shadow:0 10px 28px rgba(6,36,58,.055);overflow:hidden}
.qa-group-card.qa-group-fail{border-color:#fecaca}.qa-group-card.qa-group-warn{border-color:#fde68a}
.qa-group-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:16px 18px;border-bottom:1px solid #edf3f8;background:#f8fbfd}
.qa-group-key{display:inline-flex;margin-bottom:5px;border-radius:999px;background:#e8f6fb;color:#0e5d89;padding:4px 9px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.qa-group-head h3{margin:0;font-size:17px;line-height:1.3;font-weight:600;color:#06243a}.qa-group-head p{margin:4px 0 0;color:#64748b;font-size:12.5px;line-height:1.5}
.qa-group-counts{display:flex;gap:5px;flex:0 0 auto}.qa-group-counts span{min-width:28px;height:26px;border-radius:999px;display:grid;place-items:center;font-size:12px;font-weight:600}.qa-mini-ok{background:#dcfce7;color:#15803d}.qa-mini-warn{background:#fef3c7;color:#b45309}.qa-mini-fail{background:#fee2e2;color:#b91c1c}
.qa-check-list{display:grid;gap:0}.qa-check-item{border-bottom:1px solid #edf3f8}.qa-check-item:last-child{border-bottom:0}.qa-check-item summary{list-style:none;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;padding:13px 16px;cursor:pointer}.qa-check-item summary::-webkit-details-marker{display:none}.qa-check-item summary:hover{background:#f8fbfd}
.qa-dot{width:12px;height:12px;border-radius:999px;display:inline-block}.qa-status-ok,.qa-dot.qa-status-ok{background:#16a34a;color:#fff}.qa-status-warn,.qa-dot.qa-status-warn{background:#f59e0b;color:#fff}.qa-status-fail,.qa-dot.qa-status-fail{background:#dc2626;color:#fff}.qa-check-title strong{display:block;font-size:13.5px;font-weight:600;color:#0b1728}.qa-check-title small{display:block;margin-top:2px;color:#64748b;font-size:12px;line-height:1.45}.qa-status{border-radius:999px;padding:5px 9px;font-size:11px;font-weight:600;white-space:nowrap}
.qa-meta-table{padding:0 16px 14px 38px}.qa-meta-table table{width:100%;border-collapse:collapse;border:1px solid #edf3f8;border-radius:12px;overflow:hidden;background:#fff}.qa-meta-table th,.qa-meta-table td{padding:8px 10px;border-bottom:1px solid #edf3f8;text-align:left;vertical-align:top;font-size:12px;line-height:1.45}.qa-meta-table th{width:170px;color:#64748b;background:#f8fbfd;font-weight:500}.qa-meta-table td{color:#334155;word-break:break-word}.qa-meta-table tr:last-child th,.qa-meta-table tr:last-child td{border-bottom:0}
.qa-command-card{display:flex;align-items:center;justify-content:space-between;gap:14px;border:1px dashed #bfd0e5;background:#f8fbfd;border-radius:20px;padding:16px;margin-top:18px}.qa-command-card strong{display:block;color:#0b1728;font-weight:600}.qa-command-card span{display:block;color:#64748b;font-size:12px;margin-top:3px}.qa-command-card pre{margin:0;background:#0f172a;color:#e2e8f0;border-radius:14px;padding:12px 14px;font-size:12px;overflow:auto}
@media(max-width:1180px){.qa-grid{grid-template-columns:1fr}.qa-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.qa-hero{grid-template-columns:1fr}.qa-score-card{justify-items:start;text-align:left}.qa-action-strip,.qa-command-card{display:grid}.qa-action-buttons{justify-content:flex-start}}
@media(max-width:640px){.qa-hero{padding:16px;border-radius:22px}.qa-hero-copy h2{font-size:22px}.qa-kpi-grid{grid-template-columns:1fr}.qa-group-head{display:grid}.qa-check-item summary{grid-template-columns:auto minmax(0,1fr)}.qa-status{grid-column:2;justify-self:start}.qa-meta-table{padding:0 12px 12px}.qa-meta-table th,.qa-meta-table td{display:block;width:100%}.qa-command-card pre{width:100%}}
@media print{.qa-action-strip,.sidebar,.topbar,.qa-command-card{display:none!important}.main-section,.content{display:block!important}.qa-grid{grid-template-columns:1fr}.qa-group-card,.qa-hero,.qa-kpi{break-inside:avoid;box-shadow:none}}

/* Phase 2.6 — Approval Route Builder */
.approval-route-hero{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr);
  gap:18px;
  align-items:stretch;
  border:1px solid #dbeafe;
  border-radius:28px;
  background:linear-gradient(135deg,#eff6ff 0%,#ffffff 58%,#f8fafc 100%);
  padding:22px;
  margin-bottom:20px;
  box-shadow:0 14px 34px rgba(15,23,42,.07);
}
.approval-route-kicker{display:inline-flex;width:max-content;border-radius:999px;background:#dbeafe;color:#1d4ed8;padding:6px 11px;font-size:12px;font-weight:700;margin-bottom:8px}
.approval-route-hero h2{margin:0;font-size:30px;line-height:1.15;font-weight:600;color:#0f172a;letter-spacing:-.03em}.approval-route-hero p{margin:8px 0 0;color:#475569;line-height:1.75;font-size:14px}.approval-route-kpi-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.approval-route-kpi-grid>div{border:1px solid #dbe4ef;background:#fff;border-radius:20px;padding:14px;display:grid;gap:4px;align-content:center}.approval-route-kpi-grid span{font-size:12px;color:#64748b;font-weight:600}.approval-route-kpi-grid strong{font-size:28px;line-height:1.1;font-weight:600;color:#0f172a}.approval-route-kpi-grid small{font-size:12px;color:#64748b}.approval-route-kpi-grid .is-warning{background:#fff7ed;border-color:#fed7aa}.approval-route-kpi-grid .is-ok{background:#f0fdf4;border-color:#bbf7d0}
.approval-route-layout{display:grid;grid-template-columns:330px minmax(0,1fr);gap:18px;align-items:start}.approval-route-sidebar,.approval-route-panel{border:1px solid #dbe4ef;background:#fff;border-radius:24px;box-shadow:0 8px 24px rgba(15,23,42,.055)}.approval-route-sidebar{padding:14px;display:grid;gap:14px;position:sticky;top:92px}.approval-route-sidebar-head{display:flex;justify-content:space-between;gap:12px}.approval-route-sidebar h3,.approval-route-panel h3{margin:0;color:#0f172a;font-weight:600}.approval-route-list{display:grid;gap:8px}.approval-route-item{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;text-decoration:none;border:1px solid #e2e8f0;border-radius:16px;background:#f8fafc;padding:12px;color:#334155}.approval-route-item:hover{background:#eff6ff;border-color:#bfdbfe}.approval-route-item.is-active{background:#0e5d89;border-color:#0e5d89;color:#fff}.approval-route-item strong{display:block;font-size:13px;font-weight:600;color:inherit}.approval-route-item small{display:block;margin-top:3px;font-size:11.5px;color:inherit;opacity:.8}.approval-route-create-card{border:1px dashed #cbd5e1;background:#f8fafc;border-radius:18px;padding:12px}.approval-route-create-card summary{cursor:pointer;font-weight:600;color:#0f172a}.approval-route-mini-form{display:grid;gap:10px;margin-top:12px}.approval-route-mini-form label{display:grid;gap:6px;font-size:12px;font-weight:600;color:#334155}.approval-route-toggle{display:inline-flex!important;align-items:center;gap:8px!important;border:1px solid #e2e8f0;border-radius:14px;background:#f8fafc;padding:9px 11px;font-weight:600;color:#334155}.approval-route-toggle input{width:16px;height:16px;accent-color:#0e5d89}
.approval-route-content{display:grid;gap:18px;min-width:0}.approval-route-panel{padding:18px}.approval-route-overview-card{display:grid;grid-template-columns:minmax(0,.95fr) minmax(360px,1.05fr);gap:18px}.approval-route-overview-main h3{font-size:24px}.approval-route-overview-main p{color:#64748b;line-height:1.6}.approval-route-warning-list{display:grid;gap:7px;margin-top:12px}.approval-route-warning-list span{display:block;border:1px solid #fed7aa;background:#fff7ed;color:#9a3412;border-radius:12px;padding:8px 10px;font-size:12px;font-weight:500}.approval-route-ready{margin-top:12px;border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;border-radius:14px;padding:10px 12px;font-size:13px;font-weight:600}.approval-route-route-form{border:1px solid #e2e8f0;background:#f8fafc;border-radius:20px;padding:14px}.approval-route-section-head{display:flex;justify-content:space-between;gap:14px;margin-bottom:14px}.approval-route-section-head p{margin:4px 0 0;color:#64748b;font-size:13px;line-height:1.55}.approval-step-list{display:grid;gap:12px}.approval-step-card{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:12px;align-items:start;border:1px solid #e2e8f0;background:#fff;border-radius:20px;padding:14px}.approval-step-card.is-final{border-color:#bbf7d0;background:linear-gradient(180deg,#ffffff 0%,#f0fdf4 100%)}.approval-step-number{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:#eff6ff;color:#1d4ed8;font-size:18px;font-weight:600}.approval-step-grid{display:grid;grid-template-columns:90px 180px minmax(220px,1fr) minmax(180px,.8fr) 150px 170px auto;gap:10px;align-items:end}.approval-step-grid label{display:grid;gap:6px;font-size:12px;font-weight:600;color:#334155}.approval-step-grid .span-2{grid-column:span 1}.approval-step-save{display:flex;justify-content:flex-end}.approval-step-meta{display:grid;gap:6px;min-width:120px}.approval-step-meta span{display:inline-flex;justify-content:center;border:1px solid #e2e8f0;background:#f8fafc;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600;color:#475569}.approval-route-add-card{margin-top:14px;border:1px dashed #cbd5e1;background:#f8fafc;border-radius:18px;padding:12px}.approval-route-add-card summary{cursor:pointer;font-weight:600;color:#0f172a}.approval-step-grid-new{margin-top:12px}
.approval-assignment-form{border:1px solid #dbeafe;background:#eff6ff;border-radius:20px;padding:14px;margin-bottom:16px}.approval-assignment-list{display:grid;gap:14px}.approval-assignment-step{border:1px solid #e2e8f0;border-radius:20px;background:#fff;overflow:hidden}.approval-assignment-step>header{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:12px 14px}.approval-assignment-step>header strong{font-weight:600;color:#0f172a}.approval-assignment-step>header span{font-size:12px;color:#64748b;font-weight:600}.approval-assignment-empty{padding:18px;color:#64748b;font-size:13px;text-align:center}.approval-assignment-cards{display:grid;gap:10px;padding:12px}.approval-assignment-card{display:grid;grid-template-columns:42px minmax(0,1fr) auto;gap:12px;align-items:center;border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:12px}.approval-assignment-card.is-disabled{opacity:.62;background:#f8fafc}.approval-assignment-avatar{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:#e8f6fb;color:#0e5d89;font-weight:600}.approval-assignment-info{display:grid;gap:2px;min-width:0}.approval-assignment-info strong{font-weight:600;color:#0f172a}.approval-assignment-info small,.approval-assignment-info span{font-size:12px;color:#64748b}.approval-assignment-actions{display:flex;align-items:center;gap:8px;justify-content:flex-end}.approval-assignment-actions form{margin:0}
@media(max-width:1280px){.approval-route-hero,.approval-route-overview-card{grid-template-columns:1fr}.approval-route-layout{grid-template-columns:1fr}.approval-route-sidebar{position:static}.approval-route-list{grid-template-columns:repeat(2,minmax(0,1fr))}.approval-step-card{grid-template-columns:42px minmax(0,1fr)}.approval-step-meta{grid-column:1/-1;display:flex;flex-wrap:wrap}.approval-step-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.approval-step-grid .span-2{grid-column:1/-1}.approval-step-save{justify-content:flex-start}}
@media(max-width:760px){.approval-route-hero{padding:16px;border-radius:22px}.approval-route-hero h2{font-size:24px}.approval-route-kpi-grid,.approval-route-list{grid-template-columns:1fr}.approval-route-panel{padding:14px;border-radius:20px}.approval-step-card{grid-template-columns:1fr}.approval-step-number{width:38px;height:38px}.approval-step-grid{grid-template-columns:1fr}.approval-assignment-form .form-grid{grid-template-columns:1fr!important}.approval-assignment-card{grid-template-columns:38px minmax(0,1fr)}.approval-assignment-actions{grid-column:1/-1;justify-content:flex-start}.approval-assignment-actions form,.approval-assignment-actions button{width:100%}}

/* Phase 2.6.1 — Approval Route Builder UX/UI Polish */
.route-builder-hero{
  display:grid;
  grid-template-columns:minmax(0,1.12fr) minmax(360px,.88fr);
  gap:18px;
  align-items:stretch;
  margin:0 0 20px;
  padding:24px;
  border:1px solid #d8e8f2;
  border-radius:30px;
  background:
    radial-gradient(circle at 96% 6%,rgba(13,127,168,.13),transparent 30%),
    linear-gradient(135deg,#ffffff 0%,#f2fbfd 56%,#eef7fb 100%);
  box-shadow:0 18px 46px rgba(6,36,58,.075);
}
.route-builder-hero-copy{display:grid;align-content:center;gap:8px;min-width:0}.route-builder-eyebrow{display:inline-flex;width:max-content;align-items:center;gap:6px;padding:6px 11px;border:1px solid #b9dfee;border-radius:999px;background:#e8f6fb;color:#0e5d89;font-size:12px;line-height:1.2;font-weight:650}.route-builder-hero h2{margin:0;color:#06243a;font-size:30px;line-height:1.18;font-weight:600;letter-spacing:-.025em}.route-builder-hero p{margin:0;max-width:780px;color:#526478;font-size:14px;line-height:1.8}.route-builder-hero-actions{display:flex;flex-wrap:wrap;gap:9px;margin-top:8px}.route-builder-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.route-builder-stat-card{display:grid;align-content:center;gap:4px;min-height:132px;padding:16px;border:1px solid #dbe5f0;border-radius:22px;background:rgba(255,255,255,.92);box-shadow:0 8px 22px rgba(6,36,58,.045)}.route-builder-stat-card span{color:#607086;font-size:12px;font-weight:600}.route-builder-stat-card strong{color:#06243a;font-size:31px;line-height:1.05;font-weight:600}.route-builder-stat-card small{color:#607086;font-size:12px;line-height:1.4}.route-builder-stat-card.is-warning{background:#fff7ed;border-color:#fed7aa}.route-builder-stat-card.is-ok{background:#f0fdf4;border-color:#bbf7d0}
.route-builder-layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:18px;align-items:start}.route-builder-sidebar{position:sticky;top:92px;display:grid;gap:14px;padding:16px;border:1px solid #dbe5f0;border-radius:26px;background:#fff;box-shadow:0 10px 28px rgba(6,36,58,.055)}.route-builder-side-head h3{margin:4px 0 0;color:#06243a;font-size:18px;font-weight:600}.route-builder-search .input{padding-left:13px;background:#f8fbfd;border-color:#dbe5f0}.route-builder-route-list{display:grid;gap:9px;max-height:58vh;overflow:auto;padding-right:2px}.route-builder-route-card{display:grid;gap:10px;padding:12px;border:1px solid #dbe5f0;border-radius:20px;background:#f8fbfd;color:#334155;text-decoration:none;transition:background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease}.route-builder-route-card:hover{transform:translateY(-1px);border-color:#b9dfee;background:#eef8fb;box-shadow:0 10px 22px rgba(6,36,58,.06)}.route-builder-route-card.is-active{border-color:#0e5d89;background:linear-gradient(135deg,#0b3b5f,#0e5d89);color:#fff;box-shadow:0 14px 26px rgba(14,93,137,.2)}.route-builder-route-card-main{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center}.route-builder-route-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:#e8f6fb;color:#0e5d89;font-weight:650}.route-builder-route-card.is-active .route-builder-route-icon{background:rgba(255,255,255,.18);color:#fff}.route-builder-route-card strong{display:block;min-width:0;font-size:13.5px;line-height:1.35;font-weight:600;color:inherit}.route-builder-route-card small{display:block;margin-top:3px;color:inherit;opacity:.78;font-size:11.5px;line-height:1.45}.route-builder-route-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.route-builder-route-meta>span:first-child{font-size:11px;font-weight:550;color:inherit;opacity:.78}.route-builder-add-route{border:1px dashed #bfd0e5;border-radius:20px;background:#f8fbfd;padding:12px}.route-builder-add-route summary{cursor:pointer;color:#06243a;font-weight:600}.route-builder-side-form{display:grid;gap:11px;margin-top:12px}.route-builder-side-form .field{display:grid;gap:6px}.route-builder-side-form label,.route-builder-card label{font-size:13px;font-weight:560;color:#334155}.route-builder-check{display:flex!important;align-items:center;gap:9px!important;min-height:42px;padding:10px 12px;border:1px solid #dbe5f0;border-radius:15px;background:#f8fbfd;color:#334155;font-weight:560}.route-builder-check input{width:17px;height:17px;accent-color:#0e5d89}.route-builder-content{display:grid;gap:18px;min-width:0}.route-builder-selected-card,.route-builder-card{border:1px solid #dbe5f0;border-radius:26px;background:#fff;box-shadow:0 10px 28px rgba(6,36,58,.055)}.route-builder-selected-card{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;padding:20px}.route-builder-selected-main h3{margin:8px 0 8px;color:#06243a;font-size:25px;line-height:1.25;font-weight:600}.route-builder-status-badge{display:inline-flex;border-radius:999px;padding:6px 11px;font-size:12px;font-weight:650}.route-builder-status-badge.is-ready{background:#dcfce7;color:#15803d}.route-builder-status-badge.is-warning{background:#fff7ed;color:#c2410c}.route-builder-selected-meta{display:flex;flex-wrap:wrap;gap:8px 10px;margin:0 0 12px}.route-builder-selected-meta span{display:inline-flex;align-items:center;gap:4px;border:1px solid #e2e8f0;border-radius:999px;background:#f8fbfd;padding:6px 10px;color:#607086;font-size:12px}.route-builder-selected-meta strong{color:#06243a;font-weight:600}.route-builder-warning-box,.route-builder-ready-box{border-radius:18px;padding:13px 14px;font-size:13px;line-height:1.6}.route-builder-warning-box{border:1px solid #fed7aa;background:#fff7ed;color:#9a3412}.route-builder-warning-box strong{display:block;margin-bottom:5px;font-weight:600}.route-builder-warning-box ul{margin:0;padding-left:20px}.route-builder-ready-box{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;font-weight:560}.route-builder-process-preview{border:1px solid #e2e8f0;border-radius:22px;background:#f8fbfd;padding:16px}.route-builder-mini-step-list{display:grid;gap:9px;margin-top:10px}.route-builder-mini-step{display:grid;grid-template-columns:30px minmax(0,1fr) auto;gap:9px;align-items:center;padding:9px 10px;border:1px solid #e2e8f0;border-radius:15px;background:#fff;text-decoration:none;color:#334155}.route-builder-mini-step:hover{border-color:#b9dfee;background:#f2fbfd}.route-builder-mini-step span{width:30px;height:30px;border-radius:12px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-weight:650}.route-builder-mini-step strong{font-size:13px;color:#06243a;font-weight:600}.route-builder-mini-step small{font-size:11px;color:#607086;font-weight:500}.route-builder-mini-step.is-final{border-color:#bbf7d0}.route-builder-card{padding:20px}.route-builder-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #edf3f8}.route-builder-section-head h3{margin:4px 0 3px;color:#06243a;font-size:20px;font-weight:600}.route-builder-section-head p{margin:0;color:#607086;font-size:13px;line-height:1.55}.route-builder-form-grid{display:grid;gap:13px}.route-builder-form-grid-route{grid-template-columns:1fr 1fr}.route-builder-form-grid-step{grid-template-columns:92px 180px minmax(220px,1fr) minmax(180px,.85fr) 170px 190px}.route-builder-form-grid-assignment{grid-template-columns:minmax(220px,.9fr) minmax(260px,1.25fr) minmax(150px,.65fr) minmax(220px,.9fr)}.route-builder-form-grid .field{display:grid;gap:6px;min-width:0}.route-builder-form-grid .field-wide{grid-column:span 1}.route-builder-form-grid .input,.route-builder-form-grid .select{min-height:42px}.route-builder-form-actions{display:flex;justify-content:flex-end;gap:9px;margin-top:14px}.route-builder-step-timeline{display:grid;gap:14px}.route-builder-step-card{display:grid;grid-template-columns:52px minmax(0,1fr);gap:14px;border:1px solid #dbe5f0;border-radius:22px;background:#fff;padding:14px}.route-builder-step-card.is-final{border-color:#bbf7d0;background:linear-gradient(180deg,#fff 0%,#f4fdf8 100%)}.route-builder-step-rail{display:flex;flex-direction:column;align-items:center}.route-builder-step-rail span{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:#e8f6fb;color:#0e5d89;font-size:18px;font-weight:650}.route-builder-step-rail i{width:2px;flex:1;margin-top:8px;border-radius:999px;background:linear-gradient(#cbd5e1,transparent)}.route-builder-step-body{min-width:0}.route-builder-step-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:13px}.route-builder-step-title-row h4{margin:0;color:#06243a;font-size:17px;line-height:1.35;font-weight:600}.route-builder-step-title-row p{margin:3px 0 0;color:#607086;font-size:12px;line-height:1.45}.route-builder-step-badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.route-builder-step-form{border:1px solid #edf3f8;background:#f8fbfd;border-radius:18px;padding:13px}.route-builder-add-card{margin-top:16px;border:1px dashed #bfd0e5;border-radius:20px;background:#f8fbfd;padding:14px}.route-builder-add-card summary{cursor:pointer;color:#06243a;font-weight:600}.route-builder-step-form-new{margin-top:13px}.route-builder-assignment-form{border:1px solid #dbeafe;background:linear-gradient(135deg,#eff6ff 0%,#fff 100%);border-radius:22px;padding:16px;margin-bottom:18px}.route-builder-assignment-groups{display:grid;gap:14px}.route-builder-assignment-group{border:1px solid #dbe5f0;border-radius:22px;background:#fff;overflow:hidden}.route-builder-assignment-group>header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #edf3f8;background:#f8fbfd}.route-builder-assignment-group header strong{display:block;color:#06243a;font-size:15px;font-weight:600}.route-builder-assignment-group header small{display:block;margin-top:3px;color:#607086;font-size:12px}.route-builder-empty-line{padding:22px;text-align:center;color:#607086;background:#fff;font-size:13px}.route-builder-approver-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:11px;padding:14px}.route-builder-approver-card{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}.route-builder-approver-card.is-disabled{opacity:.62;background:#f8fbfd}.route-builder-approver-avatar{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:#e8f6fb;color:#0e5d89;font-weight:650}.route-builder-approver-info{display:grid;gap:2px;min-width:0}.route-builder-approver-info strong{color:#06243a;font-size:13.5px;font-weight:600}.route-builder-approver-info small,.route-builder-approver-info span{color:#607086;font-size:12px;line-height:1.35}.route-builder-approver-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.route-builder-approver-actions form{margin:0}.route-builder-empty-filter{display:none;padding:14px;text-align:center;color:#64748b;border:1px dashed #cbd5e1;border-radius:18px;background:#f8fbfd}.route-builder-route-list.is-empty + .route-builder-empty-filter{display:block}
@media(max-width:1280px){.route-builder-hero,.route-builder-selected-card{grid-template-columns:1fr}.route-builder-layout{grid-template-columns:1fr}.route-builder-sidebar{position:static}.route-builder-route-list{grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}.route-builder-form-grid-step,.route-builder-form-grid-assignment{grid-template-columns:repeat(2,minmax(0,1fr))}.route-builder-step-title-row,.route-builder-section-head{display:grid}.route-builder-step-badges{justify-content:flex-start}}
@media(max-width:760px){.route-builder-hero,.route-builder-card,.route-builder-selected-card{padding:15px;border-radius:22px}.route-builder-hero h2{font-size:23px}.route-builder-stats,.route-builder-route-list,.route-builder-form-grid-route,.route-builder-form-grid-step,.route-builder-form-grid-assignment{grid-template-columns:1fr}.route-builder-layout{gap:14px}.route-builder-sidebar{padding:13px;border-radius:22px}.route-builder-mini-step{grid-template-columns:30px minmax(0,1fr)}.route-builder-mini-step small{grid-column:2}.route-builder-step-card{grid-template-columns:1fr}.route-builder-step-rail{align-items:flex-start}.route-builder-step-rail i{display:none}.route-builder-form-actions,.route-builder-hero-actions{display:grid}.route-builder-form-actions .btn,.route-builder-hero-actions .btn{width:100%}.route-builder-assignment-group>header{display:grid}.route-builder-approver-card{grid-template-columns:42px minmax(0,1fr)}.route-builder-approver-actions{grid-column:1/-1;justify-content:flex-start}.route-builder-approver-actions form,.route-builder-approver-actions button{width:100%}}

/* Phase 2.6.2 — Approval route step order UI repair */
.route-builder-step-order-card{
    overflow:visible;
}
.route-builder-section-head-pro{
    align-items:flex-start;
}
.route-builder-section-tools{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:10px;
    flex:0 0 auto;
}
.route-builder-step-order-help{
    display:grid;
    grid-template-columns:44px minmax(0,1fr);
    gap:12px;
    align-items:center;
    margin:0 0 16px;
    padding:13px 14px;
    border:1px solid #dbeafe;
    border-radius:18px;
    background:linear-gradient(135deg,#eff6ff 0%,#ffffff 100%);
    color:#334155;
}
.route-builder-help-icon{
    width:44px;
    height:44px;
    border-radius:16px;
    display:grid;
    place-items:center;
    background:#0e5d89;
    color:#fff;
    font-size:18px;
    font-weight:650;
    box-shadow:0 10px 22px rgba(14,93,137,.18);
}
.route-builder-step-order-help strong{
    display:block;
    color:#06243a;
    font-size:14px;
    font-weight:600;
}
.route-builder-step-order-help p{
    margin:3px 0 0;
    color:#607086;
    font-size:12.5px;
    line-height:1.65;
}
.route-builder-step-empty{
    margin-bottom:16px;
}
.route-builder-step-stack{
    display:grid;
    gap:14px;
}
.route-builder-step-row{
    display:grid;
    grid-template-columns:86px minmax(0,1fr);
    gap:14px;
    align-items:start;
    border:1px solid #dbe5f0;
    border-radius:24px;
    padding:14px;
    background:linear-gradient(180deg,#fff 0%,#fbfdff 100%);
    box-shadow:0 8px 22px rgba(6,36,58,.045);
}
.route-builder-step-row.is-final{
    border-color:#bbf7d0;
    background:linear-gradient(180deg,#ffffff 0%,#f5fdf8 100%);
}
.route-builder-step-order-box{
    min-height:112px;
    border:1px solid #dbeafe;
    border-radius:20px;
    background:#eff6ff;
    display:grid;
    align-content:center;
    justify-items:center;
    gap:5px;
    color:#0e5d89;
}
.route-builder-step-row.is-final .route-builder-step-order-box{
    border-color:#bbf7d0;
    background:#f0fdf4;
    color:#15803d;
}
.route-builder-step-order-box span{
    font-size:11px;
    line-height:1.2;
    font-weight:550;
    color:#607086;
}
.route-builder-step-order-box strong{
    font-size:34px;
    line-height:1;
    font-weight:600;
}
.route-builder-step-edit-panel{
    min-width:0;
    display:grid;
    gap:12px;
}
.route-builder-step-summary{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    padding:2px 2px 10px;
    border-bottom:1px solid #edf3f8;
}
.route-builder-step-summary-main{
    min-width:0;
}
.route-builder-step-summary h4{
    margin:0;
    color:#06243a;
    font-size:17px;
    line-height:1.35;
    font-weight:600;
}
.route-builder-step-summary p{
    margin:3px 0 0;
    color:#607086;
    font-size:12px;
    line-height:1.45;
}
.route-builder-step-form-clean{
    border:0!important;
    background:transparent!important;
    border-radius:0!important;
    padding:0!important;
}
.route-builder-step-clean-grid{
    display:grid;
    grid-template-columns:90px minmax(150px,.7fr) minmax(240px,1.25fr) minmax(220px,1fr) minmax(170px,.75fr) minmax(190px,.8fr);
    gap:12px;
    align-items:end;
}
.route-builder-step-clean-grid .field{
    display:grid;
    gap:6px;
    min-width:0;
}
.route-builder-step-clean-grid label:not(.route-builder-final-toggle){
    min-height:20px;
    font-size:12.5px;
    line-height:1.35;
    font-weight:560;
    color:#334155;
}
.route-builder-step-clean-grid .input,
.route-builder-step-clean-grid .select{
    min-height:42px;
    width:100%;
    border-radius:13px;
}
.route-step-name-field{
    min-width:0;
}
.route-step-permission-field .select{
    font-size:12px;
}
.route-builder-final-toggle{
    min-height:42px;
    display:flex!important;
    align-items:center;
    gap:10px!important;
    padding:8px 11px;
    border:1px solid #dbe5f0;
    border-radius:14px;
    background:#fff;
    color:#334155;
    cursor:pointer;
    user-select:none;
}
.route-builder-final-toggle input{
    position:absolute;
    opacity:0;
    pointer-events:none;
}
.route-builder-final-toggle span{
    width:38px;
    height:22px;
    border-radius:999px;
    display:inline-flex;
    align-items:center;
    padding:2px;
    background:#cbd5e1;
    flex:0 0 auto;
    transition:background .16s ease, box-shadow .16s ease;
}
.route-builder-final-toggle span:before{
    content:'';
    width:18px;
    height:18px;
    border-radius:999px;
    background:#fff;
    box-shadow:0 2px 6px rgba(15,23,42,.18);
    transition:transform .16s ease;
}
.route-builder-final-toggle input:checked + span{
    background:#15803d;
    box-shadow:0 0 0 4px rgba(21,128,61,.12);
}
.route-builder-final-toggle input:checked + span:before{
    transform:translateX(16px);
}
.route-builder-final-toggle strong{
    min-width:0;
    color:#334155;
    font-size:12.5px;
    line-height:1.25;
    font-weight:560;
}
.route-builder-final-toggle input:checked ~ strong{
    color:#166534;
}
.route-builder-step-actions{
    display:flex;
    justify-content:flex-end;
    gap:8px;
    margin-top:12px;
}
.route-builder-add-step-card{
    margin-top:18px;
    padding:15px;
    border-radius:22px;
    background:#f8fbfd;
}
.route-builder-add-step-card summary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    list-style:none;
}
.route-builder-add-step-card summary::-webkit-details-marker{
    display:none;
}
.route-builder-add-step-card summary:after{
    content:'+';
    width:28px;
    height:28px;
    border-radius:10px;
    display:grid;
    place-items:center;
    background:#e8f6fb;
    color:#0e5d89;
    font-weight:700;
}
.route-builder-add-step-card[open] summary:after{
    content:'–';
}
.route-builder-add-step-card .route-builder-step-form-new{
    margin-top:14px;
    padding-top:14px!important;
    border-top:1px solid #edf3f8!important;
}
/* Neutralize the older 6-column step grid inside the repaired section. */
.route-builder-step-order-card .route-builder-form-grid-step{
    grid-template-columns:unset;
}
@media(max-width:1380px){
    .route-builder-step-clean-grid{
        grid-template-columns:90px minmax(170px,1fr) minmax(220px,1.25fr);
    }
    .route-step-permission-field,
    .route-step-scope-field,
    .route-step-final-field{
        grid-column:auto;
    }
}
@media(max-width:920px){
    .route-builder-step-row{
        grid-template-columns:1fr;
    }
    .route-builder-step-order-box{
        min-height:70px;
        grid-template-columns:auto auto;
        justify-content:start;
        padding:10px 13px;
    }
    .route-builder-step-order-box strong{
        font-size:28px;
    }
    .route-builder-step-summary{
        display:grid;
    }
    .route-builder-step-badges{
        justify-content:flex-start;
    }
    .route-builder-step-clean-grid{
        grid-template-columns:1fr 1fr;
    }
    .route-step-name-field,
    .route-step-permission-field{
        grid-column:1/-1;
    }
}
@media(max-width:640px){
    .route-builder-section-tools,
    .route-builder-step-actions{
        width:100%;
        display:grid;
    }
    .route-builder-section-tools .btn,
    .route-builder-step-actions .btn{
        width:100%;
    }
    .route-builder-step-order-help{
        grid-template-columns:1fr;
    }
    .route-builder-help-icon{
        width:38px;
        height:38px;
        border-radius:14px;
    }
    .route-builder-step-clean-grid{
        grid-template-columns:1fr;
    }
    .route-step-name-field,
    .route-step-permission-field{
        grid-column:auto;
    }
    .route-builder-step-row,
    .route-builder-card{
        border-radius:20px;
    }
}

/* Phase 2.6.3 — Approval Route Builder full layout refresh */
.approval-studio-hero{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.9fr);gap:18px;align-items:stretch;margin-bottom:20px;padding:22px;border:1px solid #dbe5f0;border-radius:30px;background:linear-gradient(135deg,#ffffff 0%,#f2fbfd 55%,#eef7fb 100%);box-shadow:0 14px 34px rgba(6,36,58,.07)}
.approval-studio-hero-main{display:grid;align-content:center;gap:10px;min-width:0}.approval-studio-eyebrow{display:inline-flex;width:max-content;align-items:center;gap:6px;padding:6px 11px;border:1px solid #b9dfee;border-radius:999px;background:#e8f6fb;color:#0e5d89;font-size:12px;line-height:1.2;font-weight:600}.approval-studio-hero h2{margin:0;color:#06243a;font-size:30px;line-height:1.18;font-weight:550;letter-spacing:-.025em}.approval-studio-hero p{margin:0;max-width:820px;color:#526478;font-size:14px;line-height:1.75}.approval-studio-hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.approval-studio-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.approval-studio-kpi{display:grid;align-content:center;gap:5px;min-height:132px;padding:16px;border:1px solid #dbe5f0;border-radius:22px;background:#fff;box-shadow:0 8px 22px rgba(6,36,58,.045)}.approval-studio-kpi span{color:#607086;font-size:12px;font-weight:550}.approval-studio-kpi strong{color:#06243a;font-size:30px;line-height:1.05;font-weight:560}.approval-studio-kpi small{color:#607086;font-size:12px;line-height:1.45}.approval-studio-kpi.is-warning{background:#fff7ed;border-color:#fed7aa}.approval-studio-kpi.is-ok{background:#f0fdf4;border-color:#bbf7d0}
.approval-studio-layout{display:grid;grid-template-columns:330px minmax(0,1fr);gap:18px;align-items:start}.approval-studio-sidebar{position:sticky;top:92px;display:grid;gap:14px;padding:15px;border:1px solid #dbe5f0;border-radius:26px;background:#fff;box-shadow:0 10px 28px rgba(6,36,58,.055);min-width:0}.approval-studio-sidebar-head h3{margin:6px 0 0;color:#06243a;font-size:18px;font-weight:560}.approval-studio-search .input{background:#f8fbfd;border-color:#dbe5f0}.approval-studio-route-list{display:grid;gap:9px;max-height:58vh;overflow:auto;padding-right:2px}.approval-studio-route-item{display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;padding:12px;border:1px solid #dbe5f0;border-radius:20px;background:#f8fbfd;color:#334155;text-decoration:none;transition:.16s ease}.approval-studio-route-item:hover{transform:translateY(-1px);border-color:#b9dfee;background:#eef8fb;box-shadow:0 10px 22px rgba(6,36,58,.06)}.approval-studio-route-item.is-active{border-color:#0e5d89;background:linear-gradient(135deg,#0b3b5f,#0e5d89);color:#fff;box-shadow:0 14px 26px rgba(14,93,137,.2)}.approval-studio-route-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;background:#e8f6fb;color:#0e5d89;font-weight:600}.approval-studio-route-item.is-active .approval-studio-route-icon{background:rgba(255,255,255,.18);color:#fff}.approval-studio-route-body{min-width:0}.approval-studio-route-body strong{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;color:inherit;font-size:13.5px;line-height:1.35;font-weight:600}.approval-studio-route-body small{display:block;margin-top:3px;color:inherit;opacity:.78;font-size:11.5px;line-height:1.45}.approval-studio-route-tail{grid-column:2;display:flex;align-items:center;justify-content:space-between;gap:8px}.approval-studio-route-tail small{font-size:11px;font-weight:520;color:inherit;opacity:.78}.approval-studio-route-tail em{font-style:normal;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:650;background:#e2e8f0;color:#475569}.approval-studio-route-tail em.is-ready{background:#dcfce7;color:#15803d}.approval-studio-route-tail em.is-warning{background:#ffedd5;color:#c2410c}.approval-studio-route-item.is-active .approval-studio-route-tail em{background:rgba(255,255,255,.18);color:#fff}.approval-studio-empty-filter{padding:14px;text-align:center;color:#64748b;border:1px dashed #cbd5e1;border-radius:18px;background:#f8fbfd}.approval-studio-add-route{border:1px dashed #bfd0e5;border-radius:20px;background:#f8fbfd;padding:12px}.approval-studio-add-route summary{cursor:pointer;color:#06243a;font-weight:600}.approval-studio-side-form{display:grid;gap:12px;margin-top:12px}.approval-studio-side-form .field{display:grid;gap:6px}.approval-studio-check{display:flex!important;align-items:center;gap:9px!important;min-height:42px;padding:10px 12px;border:1px solid #dbe5f0;border-radius:15px;background:#f8fbfd;color:#334155;font-weight:520}.approval-studio-check input{width:17px;height:17px;accent-color:#0e5d89}
.approval-studio-main{display:grid;gap:18px;min-width:0}.approval-studio-empty-state{display:grid;justify-items:center;gap:10px;text-align:center;border:1px dashed #cbd5e1;border-radius:26px;background:#f8fbfd;padding:52px 20px;color:#64748b}.approval-studio-empty-state>div{width:54px;height:54px;border-radius:18px;background:#fff;border:1px solid #dbe5f0;display:grid;place-items:center;color:#0e5d89;font-size:22px;font-weight:600}.approval-studio-empty-state h3{margin:0;color:#06243a;font-size:18px;font-weight:560}.approval-studio-empty-state p{margin:0;max-width:540px;line-height:1.7}.approval-studio-empty-state.is-small{padding:30px 16px;border-radius:22px}
.approval-studio-overview,.approval-studio-panel{border:1px solid #dbe5f0;border-radius:28px;background:#fff;box-shadow:0 10px 28px rgba(6,36,58,.055)}.approval-studio-overview{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;padding:20px}.approval-studio-overview-main h3{margin:8px 0;color:#06243a;font-size:25px;line-height:1.25;font-weight:560}.approval-studio-status{display:inline-flex;border-radius:999px;padding:6px 11px;font-size:12px;font-weight:620}.approval-studio-status.is-ready{background:#dcfce7;color:#15803d}.approval-studio-status.is-warning{background:#fff7ed;color:#c2410c}.approval-studio-meta-pills{display:flex;flex-wrap:wrap;gap:8px 10px;margin:0 0 12px}.approval-studio-meta-pills span{display:inline-flex;align-items:center;gap:5px;border:1px solid #e2e8f0;border-radius:999px;background:#f8fbfd;padding:6px 10px;color:#607086;font-size:12px}.approval-studio-meta-pills strong{color:#06243a;font-weight:600}.approval-studio-warning,.approval-studio-ready{border-radius:18px;padding:13px 14px;font-size:13px;line-height:1.6}.approval-studio-warning{border:1px solid #fed7aa;background:#fff7ed;color:#9a3412}.approval-studio-warning strong{display:block;margin-bottom:5px;font-weight:600}.approval-studio-warning ul{margin:0;padding-left:20px}.approval-studio-ready{border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;font-weight:540}.approval-studio-process{border:1px solid #e2e8f0;border-radius:22px;background:#f8fbfd;padding:16px}.approval-studio-process-list{display:grid;gap:9px;margin-top:10px}.approval-studio-process-item{display:grid;grid-template-columns:30px minmax(0,1fr) auto;gap:9px;align-items:center;padding:9px 10px;border:1px solid #e2e8f0;border-radius:15px;background:#fff;text-decoration:none;color:#334155}.approval-studio-process-item:hover{border-color:#b9dfee;background:#f2fbfd}.approval-studio-process-item span{width:30px;height:30px;border-radius:12px;background:#e8f6fb;color:#0e5d89;display:grid;place-items:center;font-weight:600}.approval-studio-process-item strong{font-size:13px;color:#06243a;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.approval-studio-process-item small{font-size:11px;color:#607086;font-weight:500}.approval-studio-process-item.is-final{border-color:#bbf7d0}
.approval-studio-panel{padding:20px}.approval-studio-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid #edf3f8}.approval-studio-section-head h3{margin:4px 0 3px;color:#06243a;font-size:20px;font-weight:560}.approval-studio-section-head p{margin:0;color:#607086;font-size:13px;line-height:1.55}.approval-studio-route-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.approval-studio-route-grid .field{display:grid;gap:6px;min-width:0}.approval-studio-span-2{grid-column:1/-1}.approval-studio-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
.approval-step-workspace{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)}.approval-step-guide{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;border:1px solid #dbeafe;background:#eff6ff;border-radius:18px;padding:12px 14px}.approval-step-guide span{flex:0 0 auto;border-radius:999px;background:#0e5d89;color:#fff;min-width:30px;height:30px;display:grid;place-items:center;font-weight:600}.approval-step-guide strong{display:block;color:#06243a;font-weight:560;line-height:1.55}.approval-step-flow{display:grid;gap:14px}.approval-step-card{display:grid;grid-template-columns:76px minmax(0,1fr);gap:14px;padding:14px;border:1px solid #dbe5f0;border-radius:24px;background:#fff;box-shadow:0 8px 22px rgba(6,36,58,.04)}.approval-step-card.is-final{border-color:#bbf7d0;background:linear-gradient(180deg,#ffffff 0%,#f4fdf8 100%)}.approval-step-no{min-height:86px;border-radius:20px;background:#e8f6fb;color:#0e5d89;display:grid;align-content:center;justify-items:center;gap:2px}.approval-step-card.is-final .approval-step-no{background:#dcfce7;color:#15803d}.approval-step-no span{font-size:11px;font-weight:600}.approval-step-no strong{font-size:28px;line-height:1;font-weight:560}.approval-step-body{min-width:0}.approval-step-titlebar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.approval-step-titlebar h4{margin:0;color:#06243a;font-size:17px;line-height:1.35;font-weight:560}.approval-step-titlebar p{margin:4px 0 0;color:#607086;font-size:12px;line-height:1.45}.approval-step-badges{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.approval-step-form{border:1px solid #edf3f8;background:#f8fbfd;border-radius:20px;padding:14px}.approval-step-fields{display:grid;grid-template-columns:92px 170px minmax(220px,1fr);gap:12px;align-items:end}.approval-step-fields .field{display:grid;gap:6px;min-width:0}.approval-step-fields label:not(.approval-studio-switch){font-size:12.5px;font-weight:560;color:#334155}.approval-step-fields .input,.approval-step-fields .select{min-height:42px;background:#fff}.approval-step-fields .is-permission{grid-column:1 / span 2}.approval-step-fields .is-scope{grid-column:auto}.approval-step-fields .is-final{grid-column:auto}.approval-studio-switch{display:flex!important;align-items:center;gap:10px;min-height:42px;padding:9px 12px;border:1px solid #dbe5f0;border-radius:15px;background:#fff;cursor:pointer}.approval-studio-switch input{position:absolute;opacity:0;pointer-events:none}.approval-studio-switch span{width:42px;height:24px;border-radius:999px;background:#cbd5e1;position:relative;transition:.16s}.approval-studio-switch span:before{content:"";position:absolute;left:3px;top:3px;width:18px;height:18px;border-radius:999px;background:#fff;box-shadow:0 2px 7px rgba(15,23,42,.22);transition:.16s}.approval-studio-switch input:checked + span{background:#16a34a}.approval-studio-switch input:checked + span:before{transform:translateX(18px)}.approval-studio-switch strong{font-size:12.5px;font-weight:560;color:#475569}.approval-studio-switch input:checked ~ strong{color:#15803d}.approval-step-actions{display:flex;justify-content:flex-end;margin-top:12px}.approval-add-step{margin-top:16px;border:1px dashed #bfd0e5;border-radius:22px;background:#f8fbfd;padding:14px}.approval-add-step summary{cursor:pointer;color:#06243a;font-weight:600}.approval-add-step .approval-step-form{margin-top:13px;background:#fff}
.approval-assignment-form{border:1px solid #dbeafe;background:linear-gradient(135deg,#eff6ff 0%,#fff 100%);border-radius:22px;padding:16px;margin-bottom:18px}.approval-assignment-grid{display:grid;grid-template-columns:minmax(220px,.9fr) minmax(300px,1.25fr) minmax(150px,.65fr) minmax(220px,.9fr);gap:14px}.approval-assignment-grid .field{display:grid;gap:6px;min-width:0}.approval-assignment-grid .is-user{min-width:0}.approval-assignment-groups{display:grid;gap:14px}.approval-assignment-group{border:1px solid #dbe5f0;border-radius:22px;background:#fff;overflow:hidden}.approval-assignment-group>header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #edf3f8;background:#f8fbfd}.approval-assignment-group header strong{display:block;color:#06243a;font-size:15px;font-weight:560}.approval-assignment-group header small{display:block;margin-top:3px;color:#607086;font-size:12px}.approval-assignment-empty{padding:22px;text-align:center;color:#607086;background:#fff;font-size:13px}.approval-approver-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:11px;padding:14px}.approval-approver-card{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid #e2e8f0;border-radius:18px;background:#fff}.approval-approver-card.is-disabled{opacity:.62;background:#f8fbfd}.approval-approver-avatar{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:#e8f6fb;color:#0e5d89;font-weight:600}.approval-approver-info{display:grid;gap:2px;min-width:0}.approval-approver-info strong{color:#06243a;font-size:13.5px;font-weight:560}.approval-approver-info small,.approval-approver-info span{color:#607086;font-size:12px;line-height:1.35}.approval-approver-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.approval-approver-actions form{margin:0}
@media(max-width:1280px){.approval-studio-hero,.approval-studio-overview{grid-template-columns:1fr}.approval-studio-layout{grid-template-columns:1fr}.approval-studio-sidebar{position:static}.approval-studio-route-list{grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}.approval-step-fields,.approval-assignment-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.approval-step-fields .is-permission{grid-column:auto}.approval-studio-section-head,.approval-step-titlebar{display:grid}.approval-step-badges{justify-content:flex-start}}
@media(max-width:760px){.approval-studio-hero,.approval-studio-panel,.approval-studio-overview{padding:15px;border-radius:22px}.approval-studio-hero h2{font-size:23px}.approval-studio-kpis,.approval-studio-route-list,.approval-studio-route-grid,.approval-step-fields,.approval-assignment-grid{grid-template-columns:1fr}.approval-studio-layout{gap:14px}.approval-studio-sidebar{padding:13px;border-radius:22px}.approval-studio-process-item{grid-template-columns:30px minmax(0,1fr)}.approval-studio-process-item small{grid-column:2}.approval-step-card{grid-template-columns:1fr}.approval-step-no{min-height:60px;justify-items:start;padding:12px;display:flex;align-items:center;gap:8px}.approval-step-no strong{font-size:20px}.approval-studio-actions,.approval-studio-hero-actions,.approval-step-actions{display:grid}.approval-studio-actions .btn,.approval-studio-hero-actions .btn,.approval-step-actions .btn{width:100%}.approval-assignment-group>header{display:grid}.approval-approver-card{grid-template-columns:42px minmax(0,1fr)}.approval-approver-actions{grid-column:1/-1;justify-content:flex-start}.approval-approver-actions form,.approval-approver-actions button{width:100%}}

/* Phase 2.6.4 — Approval Route Builder overflow containment
   Fixes nested builder layout that became wider than the content area on 1366-1536px screens. */
.approval-studio-hero,
.approval-studio-layout,
.approval-studio-sidebar,
.approval-studio-main,
.approval-studio-panel,
.approval-studio-overview,
.approval-step-card,
.approval-step-body,
.approval-step-form,
.approval-assignment-form,
.approval-assignment-group,
.approval-approver-card{
    max-width:100% !important;
    min-width:0 !important;
    box-sizing:border-box !important;
}
.approval-studio-main,
.approval-step-body,
.approval-step-titlebar,
.approval-step-fields,
.approval-assignment-grid,
.approval-studio-route-grid{
    overflow-wrap:anywhere;
}
.approval-studio-main{
    overflow:hidden !important;
}
.approval-studio-panel{
    overflow:hidden !important;
}
.approval-studio-panel .input,
.approval-studio-panel .select,
.approval-studio-panel textarea,
.approval-studio-sidebar .input,
.approval-studio-sidebar .select,
.approval-studio-sidebar textarea{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
}
.approval-step-fields{
    grid-template-columns:minmax(74px,.45fr) minmax(130px,.8fr) minmax(180px,1.35fr) !important;
}
.approval-step-fields .is-permission,
.approval-step-fields .is-scope,
.approval-step-fields .is-final{
    grid-column:auto !important;
}
.approval-step-titlebar{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) auto;
}
.approval-step-badges{
    min-width:0 !important;
}
.approval-assignment-grid{
    grid-template-columns:minmax(180px,1fr) minmax(220px,1.15fr) minmax(140px,.65fr) minmax(180px,1fr) !important;
}
.approval-studio-process-item,
.approval-studio-route-item,
.approval-approver-card{
    min-width:0 !important;
}
.approval-studio-process-item strong,
.approval-studio-route-body strong,
.approval-studio-route-body small,
.approval-approver-info strong,
.approval-approver-info small,
.approval-approver-info span{
    min-width:0 !important;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}

/* Content width inside a left-sidebar application shell is smaller than viewport width.
   Switch the route builder to a single-column studio earlier to prevent horizontal overflow. */
@media(max-width:1700px){
    .approval-studio-layout{
        grid-template-columns:1fr !important;
        gap:16px !important;
    }
    .approval-studio-sidebar{
        position:static !important;
        top:auto !important;
    }
    .approval-studio-route-list{
        display:grid !important;
        grid-template-columns:repeat(auto-fit,minmax(260px,1fr)) !important;
        max-height:none !important;
        overflow:visible !important;
        padding-right:0 !important;
    }
    .approval-studio-add-route .approval-studio-side-form{
        display:grid !important;
        grid-template-columns:repeat(auto-fit,minmax(220px,1fr)) !important;
        gap:12px !important;
    }
    .approval-studio-add-route .approval-studio-check,
    .approval-studio-add-route .btn{
        align-self:end !important;
    }
}
@media(max-width:1400px){
    .approval-studio-hero,
    .approval-studio-overview{
        grid-template-columns:1fr !important;
    }
    .approval-studio-kpis{
        grid-template-columns:repeat(3,minmax(0,1fr)) !important;
    }
    .approval-step-fields,
    .approval-assignment-grid,
    .approval-studio-route-grid{
        grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    }
    .approval-step-fields .is-name,
    .approval-step-fields .is-permission,
    .approval-studio-span-2{
        grid-column:1 / -1 !important;
    }
    .approval-step-titlebar{
        grid-template-columns:1fr !important;
    }
    .approval-step-badges{
        justify-content:flex-start !important;
    }
}
@media(max-width:900px){
    .approval-studio-hero,
    .approval-studio-panel,
    .approval-studio-overview,
    .approval-studio-sidebar{
        border-radius:20px !important;
        padding:14px !important;
    }
    .approval-studio-kpis,
    .approval-studio-route-list,
    .approval-step-fields,
    .approval-assignment-grid,
    .approval-studio-route-grid{
        grid-template-columns:1fr !important;
    }
    .approval-step-card{
        grid-template-columns:1fr !important;
        gap:10px !important;
    }
    .approval-step-no{
        min-height:50px !important;
        display:flex !important;
        align-items:center !important;
        justify-content:flex-start !important;
        gap:8px !important;
        padding:10px 12px !important;
    }
    .approval-step-no strong{
        font-size:20px !important;
    }
    .approval-studio-actions,
    .approval-step-actions,
    .approval-studio-hero-actions{
        display:grid !important;
        grid-template-columns:1fr !important;
    }
    .approval-studio-actions .btn,
    .approval-step-actions .btn,
    .approval-studio-hero-actions .btn{
        width:100% !important;
    }
    .approval-approver-card{
        grid-template-columns:42px minmax(0,1fr) !important;
    }
    .approval-approver-actions{
        grid-column:1 / -1 !important;
        justify-content:flex-start !important;
        flex-wrap:wrap !important;
    }
}


/*
 * Phase 2.8.4 — Leave create duration selector repair
 * Root cause: global input rule made radio/checkbox width:100% and author display rules overrode [hidden].
 * This block restores native control sizing and gives duration choices a production card layout.
 */
[hidden]{display:none!important}
input[type="radio"],
input[type="checkbox"]{
    width:18px!important;
    height:18px!important;
    min-width:18px!important;
    min-height:18px!important;
    max-width:18px!important;
    padding:0!important;
    margin:0!important;
    flex:0 0 18px!important;
    box-shadow:none!important;
    accent-color:var(--brand-700);
    cursor:pointer;
}
input[type="radio"]{border-radius:50%!important}
input[type="checkbox"]{border-radius:5px!important}

.leave-duration-card{
    padding:18px!important;
    border-color:#bfd8f0!important;
    background:linear-gradient(135deg,#ffffff 0%,#f8fbff 100%)!important;
}
.leave-duration-card>h3{
    margin:0!important;
    color:#06243a!important;
    font-size:18px!important;
    line-height:1.35!important;
    font-weight:650!important;
}
.leave-duration-card>p{
    margin:5px 0 14px!important;
    color:#526478!important;
    font-size:13.5px!important;
    line-height:1.65!important;
    font-weight:400!important;
}
.leave-duration-options{
    display:grid!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
    gap:12px!important;
    margin:0!important;
}
.leave-duration-option{
    position:relative!important;
    display:grid!important;
    grid-template-columns:22px minmax(0,1fr)!important;
    grid-template-areas:"control title" "control desc"!important;
    align-items:start!important;
    gap:4px 12px!important;
    min-height:96px!important;
    padding:14px 15px!important;
    border:1px solid #dbe5f0!important;
    border-radius:18px!important;
    background:#fff!important;
    color:#334155!important;
    cursor:pointer!important;
    box-shadow:0 6px 18px rgba(6,36,58,.035)!important;
    transition:border-color .16s ease,box-shadow .16s ease,background .16s ease,transform .16s ease!important;
}
.leave-duration-option:hover{
    border-color:#9fd5e8!important;
    background:#f8fcff!important;
    transform:translateY(-1px)!important;
}
.leave-duration-option.is-active{
    border-color:#0d7fa8!important;
    background:linear-gradient(135deg,#effaff 0%,#ffffff 100%)!important;
    box-shadow:0 12px 28px rgba(13,127,168,.13)!important;
}
.leave-duration-option input[type="radio"]{
    grid-area:control!important;
    margin-top:3px!important;
}
.leave-duration-option strong{
    grid-area:title!important;
    display:block!important;
    min-width:0!important;
    color:#06243a!important;
    font-size:15px!important;
    line-height:1.3!important;
    font-weight:650!important;
}
.leave-duration-option span{
    grid-area:desc!important;
    display:block!important;
    min-width:0!important;
    color:#607086!important;
    font-size:12.5px!important;
    line-height:1.55!important;
    font-weight:400!important;
}
.leave-duration-option.is-active strong{color:#0e5d89!important}
.leave-duration-extra{
    margin-top:14px!important;
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:12px!important;
    align-items:end!important;
    padding:14px!important;
    border:1px solid #edf3f8!important;
    border-radius:20px!important;
    background:#fbfdff!important;
}
.leave-duration-extra .form-group{
    min-width:0!important;
}
.leave-duration-extra .form-group label{
    color:#25364d!important;
    font-size:13px!important;
    line-height:1.45!important;
    font-weight:600!important;
}
.leave-duration-extra select,
.leave-duration-extra input[type="number"]{
    min-height:46px!important;
    border-radius:14px!important;
    background:#fff!important;
}
.leave-policy-gate-note{
    grid-column:1/-1!important;
    display:grid!important;
    gap:3px!important;
    align-self:stretch!important;
    min-width:0!important;
    padding:12px 14px!important;
    border:1px solid #dbeafe!important;
    border-radius:16px!important;
    background:linear-gradient(135deg,#eff6ff 0%,#ffffff 100%)!important;
    color:#334155!important;
}
.leave-policy-gate-note strong{
    color:#0e5d89!important;
    font-size:13px!important;
    line-height:1.35!important;
    font-weight:650!important;
}
.leave-policy-gate-note span{
    color:#526478!important;
    font-size:12.5px!important;
    line-height:1.6!important;
    font-weight:400!important;
}

@media(max-width:980px){
    .leave-duration-options{
        grid-template-columns:1fr!important;
    }
    .leave-duration-option{
        min-height:auto!important;
    }
    .leave-duration-extra{
        grid-template-columns:1fr!important;
    }
}

/* Phase 2.8.5 — SLA hero consistency repair
   Keep the SLA Pending Task / SLA Policy hero aligned with the standard page-hero theme.
   The old SLA block changed the hero to a light surface while it still inherited page-hero text rules,
   making the hero look inconsistent compared with the rest of the system. */
.sla-hero,
.sla-settings-hero{
  background:linear-gradient(135deg,var(--brand-900,#06243a) 0%,var(--brand-700,#0e5d89) 52%,var(--brand-500,#13a5c7) 100%)!important;
  border:1px solid rgba(191,222,233,.88)!important;
  color:#fff!important;
  align-items:center!important;
}
.sla-hero::after,
.sla-settings-hero::after{
  content:""!important;
  position:absolute!important;
  right:-70px!important;
  top:-90px!important;
  width:280px!important;
  height:280px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.12)!important;
  pointer-events:none!important;
}
.sla-hero > *,
.sla-settings-hero > *{
  position:relative!important;
  z-index:1!important;
}
.sla-hero h1,
.sla-hero h2,
.sla-settings-hero h1,
.sla-settings-hero h2{
  color:#fff!important;
}
.sla-hero p,
.sla-settings-hero p{
  color:rgba(255,255,255,.84)!important;
}
.sla-hero .hero-kicker,
.sla-settings-hero .hero-kicker{
  border-color:rgba(255,255,255,.25)!important;
  background:rgba(255,255,255,.12)!important;
  color:#fff!important;
}
.sla-hero .hero-orbit-card,
.sla-settings-hero .hero-orbit-card{
  border-color:rgba(255,255,255,.25)!important;
  background:rgba(255,255,255,.13)!important;
  color:#fff!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18)!important;
}
.sla-hero .hero-orbit-card span,
.sla-settings-hero .hero-orbit-card span{
  color:rgba(255,255,255,.70)!important;
}
.sla-hero .hero-orbit-card strong,
.sla-settings-hero .hero-orbit-card strong{
  color:#fff!important;
}
.sla-hero .hero-orbit-card small,
.sla-settings-hero .hero-orbit-card small{
  color:rgba(255,255,255,.74)!important;
}
.sla-hero .page-hero-actions form{
  margin:0!important;
}
@media(max-width:760px){
  .sla-hero,
  .sla-settings-hero{
    align-items:flex-start!important;
  }
  .sla-hero .page-hero-actions,
  .sla-settings-hero .page-hero-actions{
    width:100%!important;
    align-items:stretch!important;
  }
  .sla-hero .page-hero-actions .btn,
  .sla-hero .page-hero-actions form,
  .sla-hero .page-hero-actions button,
  .sla-settings-hero .page-hero-actions .btn,
  .sla-settings-hero .page-hero-actions form,
  .sla-settings-hero .page-hero-actions button{
    width:100%!important;
  }
}

/* ========================================================================== 
 * Phase 2.8.6 — Unified Dashboard-style Hero System
 * ปรับ hero ทุกหน้าที่แสดงผลให้ใช้ทิศทางเดียวกับ Dashboard hero ตามภาพอ้างอิง
 * ทำเฉพาะ presentation layer ไม่แตะ workflow/backend/permission
 * ========================================================================== */
:root{
  --gov-hero-bg:linear-gradient(120deg,#063a5a 0%,#0a5c82 48%,#13a5c7 100%);
  --gov-hero-bg-hover:linear-gradient(120deg,#052f4c 0%,#0a5277 48%,#0f98bb 100%);
  --gov-hero-ink:#ffffff;
  --gov-hero-muted:rgba(255,255,255,.84);
  --gov-hero-line:rgba(255,255,255,.26);
  --gov-hero-glass:rgba(255,255,255,.13);
  --gov-hero-glass-strong:rgba(255,255,255,.18);
  --gov-hero-shadow:0 22px 48px rgba(6,36,58,.18);
}

/* Main hero containers across all render pages */
.page-hero,
.leave-calendar-hero,
.calendar-view-hero,
.report-center-hero,
.report-summary-hero,
.delegate-page-hero,
.approval-studio-hero,
.admin-pro-hero,
.profile-hero,
.qa-hero{
  position:relative!important;
  isolation:isolate!important;
  overflow:hidden!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(230px,auto)!important;
  align-items:center!important;
  gap:clamp(18px,2.6vw,34px)!important;
  margin:0 0 22px!important;
  padding:clamp(22px,2.35vw,34px)!important;
  border:1px solid rgba(191,222,233,.58)!important;
  border-radius:30px!important;
  background:var(--gov-hero-bg)!important;
  color:var(--gov-hero-ink)!important;
  box-shadow:var(--gov-hero-shadow)!important;
}
.page-hero::before,
.leave-calendar-hero::before,
.calendar-view-hero::before,
.report-center-hero::before,
.report-summary-hero::before,
.delegate-page-hero::before,
.approval-studio-hero::before,
.admin-pro-hero::before,
.profile-hero::before,
.qa-hero::before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  z-index:0!important;
  pointer-events:none!important;
  background:
    radial-gradient(circle at 96% 2%,rgba(255,255,255,.20) 0 0,rgba(255,255,255,.20) 120px,transparent 122px),
    radial-gradient(circle at 88% 55%,rgba(255,255,255,.12) 0 0,rgba(255,255,255,.12) 170px,transparent 172px),
    linear-gradient(90deg,rgba(255,255,255,.04),transparent 42%);
}
.page-hero::after,
.leave-calendar-hero::after,
.calendar-view-hero::after,
.report-center-hero::after,
.report-summary-hero::after,
.delegate-page-hero::after,
.approval-studio-hero::after,
.admin-pro-hero::after,
.profile-hero::after,
.qa-hero::after{
  content:""!important;
  position:absolute!important;
  right:-78px!important;
  top:-96px!important;
  width:292px!important;
  height:292px!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.10)!important;
  pointer-events:none!important;
  z-index:0!important;
}
.page-hero > *,
.leave-calendar-hero > *,
.calendar-view-hero > *,
.report-center-hero > *,
.report-summary-hero > *,
.delegate-page-hero > *,
.approval-studio-hero > *,
.admin-pro-hero > *,
.profile-hero > *,
.qa-hero > *{
  position:relative!important;
  z-index:1!important;
  min-width:0!important;
}

/* Hero text system */
.page-hero h1,.page-hero h2,.page-hero h3,
.leave-calendar-hero h1,.leave-calendar-hero h2,.leave-calendar-hero h3,
.calendar-view-hero h1,.calendar-view-hero h2,.calendar-view-hero h3,
.report-center-hero h1,.report-center-hero h2,.report-center-hero h3,
.report-summary-hero h1,.report-summary-hero h2,.report-summary-hero h3,
.delegate-page-hero h1,.delegate-page-hero h2,.delegate-page-hero h3,
.approval-studio-hero h1,.approval-studio-hero h2,.approval-studio-hero h3,
.admin-pro-hero h1,.admin-pro-hero h2,.admin-pro-hero h3,
.profile-hero h1,.profile-hero h2,.profile-hero h3,
.qa-hero h1,.qa-hero h2,.qa-hero h3{
  margin:.45rem 0 0!important;
  color:#fff!important;
  font-size:clamp(25px,2.05vw,34px)!important;
  line-height:1.18!important;
  font-weight:700!important;
  letter-spacing:-.035em!important;
  text-shadow:0 1px 0 rgba(0,0,0,.08)!important;
}
.page-hero p,
.leave-calendar-hero p,
.calendar-view-hero p,
.report-center-hero p,
.report-summary-hero p,
.delegate-page-hero p,
.approval-studio-hero p,
.admin-pro-hero p,
.profile-hero p,
.qa-hero p{
  max-width:920px!important;
  margin:.72rem 0 0!important;
  color:var(--gov-hero-muted)!important;
  font-size:14.5px!important;
  line-height:1.78!important;
  font-weight:500!important;
}

/* Kicker/pill: support every custom hero label class */
.page-hero .hero-kicker,
.leave-calendar-hero .hero-kicker,
.leave-calendar-hero .page-kicker,
.calendar-view-hero .hero-kicker,
.calendar-view-hero .calendar-view-kicker,
.report-center-hero .hero-kicker,
.report-summary-hero .hero-kicker,
.delegate-page-hero .delegate-kicker,
.approval-studio-hero .approval-studio-eyebrow,
.admin-pro-hero .admin-pro-kicker,
.profile-hero .profile-kicker,
.qa-hero .hero-kicker{
  display:inline-flex!important;
  width:max-content!important;
  max-width:100%!important;
  align-items:center!important;
  gap:7px!important;
  min-height:32px!important;
  padding:7px 13px!important;
  border:1px solid rgba(255,255,255,.42)!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.92)!important;
  color:#0e5d89!important;
  box-shadow:0 8px 22px rgba(6,36,58,.11)!important;
  font-size:12px!important;
  line-height:1.1!important;
  font-weight:700!important;
  letter-spacing:0!important;
}

/* Hero actions */
.page-hero-actions,
.leave-calendar-hero-actions,
.report-center-actions,
.approval-studio-hero-actions,
.delegate-hero-chips,
.admin-pro-hero-tags,
.qa-hero-meta{
  display:flex!important;
  align-items:center!important;
  flex-wrap:wrap!important;
  gap:10px!important;
  margin-top:18px!important;
}
.page-hero .btn,
.leave-calendar-hero .btn,
.calendar-view-hero .btn,
.report-center-hero .btn,
.report-summary-hero .btn,
.delegate-page-hero .btn,
.approval-studio-hero .btn,
.admin-pro-hero .btn,
.profile-hero .btn,
.qa-hero .btn{
  min-height:46px!important;
  border-radius:14px!important;
  padding:.72rem 1.08rem!important;
  font-weight:700!important;
  box-shadow:0 12px 24px rgba(4,24,40,.16)!important;
}
.page-hero .btn-primary,
.leave-calendar-hero .btn-primary,
.calendar-view-hero .btn-primary,
.report-center-hero .btn-primary,
.report-summary-hero .btn-primary,
.delegate-page-hero .btn-primary,
.approval-studio-hero .btn-primary,
.admin-pro-hero .btn-primary,
.profile-hero .btn-primary,
.qa-hero .btn-primary{
  background:linear-gradient(135deg,#075985 0%,#0284c7 55%,#22d3ee 100%)!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.20)!important;
}
.page-hero .btn-light,.page-hero .btn-secondary,
.leave-calendar-hero .btn-light,.leave-calendar-hero .btn-secondary,
.calendar-view-hero .btn-light,.calendar-view-hero .btn-secondary,
.report-center-hero .btn-light,.report-center-hero .btn-secondary,
.report-summary-hero .btn-light,.report-summary-hero .btn-secondary,
.delegate-page-hero .btn-light,.delegate-page-hero .btn-secondary,
.approval-studio-hero .btn-light,.approval-studio-hero .btn-secondary,
.admin-pro-hero .btn-light,.admin-pro-hero .btn-secondary,
.profile-hero .btn-light,.profile-hero .btn-secondary,
.qa-hero .btn-light,.qa-hero .btn-secondary{
  background:#fff!important;
  color:#063a5a!important;
  border-color:rgba(255,255,255,.52)!important;
}
.page-hero .btn-ghost,
.leave-calendar-hero .btn-ghost,
.calendar-view-hero .btn-ghost,
.report-center-hero .btn-ghost,
.report-summary-hero .btn-ghost,
.delegate-page-hero .btn-ghost,
.approval-studio-hero .btn-ghost,
.admin-pro-hero .btn-ghost,
.profile-hero .btn-ghost,
.qa-hero .btn-ghost{
  background:rgba(255,255,255,.14)!important;
  color:#fff!important;
  border-color:rgba(255,255,255,.40)!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16)!important;
}

/* Right-side summary/card inside heroes */
.hero-orbit-card,
.hero-stepper,
.report-center-period,
.report-summary-kpis,
.delegate-kpi-row,
.approval-studio-kpis,
.admin-pro-kpi-grid,
.qa-score-card{
  position:relative!important;
  z-index:1!important;
  align-self:center!important;
  min-width:min(100%,230px)!important;
  color:#fff!important;
}
.hero-orbit-card,
.hero-stepper,
.report-center-period,
.qa-score-card{
  border:1px solid var(--gov-hero-line)!important;
  background:var(--gov-hero-glass)!important;
  border-radius:24px!important;
  padding:18px!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18)!important;
  backdrop-filter:blur(12px)!important;
}
.hero-orbit-card span,.hero-stepper span,.report-center-period span,.qa-score-card span,
.hero-orbit-card small,.hero-stepper small,.report-center-period small,.qa-score-card small{
  color:rgba(255,255,255,.74)!important;
  font-weight:600!important;
}
.hero-orbit-card strong,.hero-stepper strong,.report-center-period strong,.qa-score-card strong{
  color:#fff!important;
  font-weight:700!important;
}
.hero-orbit-card strong,.report-center-period strong,.qa-score-card strong{
  display:block!important;
  margin:.22rem 0!important;
  font-size:clamp(24px,1.85vw,32px)!important;
  line-height:1.12!important;
}

/* Hero metric grids */
.report-summary-kpis,
.delegate-kpi-row,
.approval-studio-kpis,
.admin-pro-kpi-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(112px,1fr))!important;
  gap:10px!important;
  width:min(100%,440px)!important;
}
.report-summary-kpis > div,
.delegate-kpi,
.approval-studio-kpi,
.admin-pro-kpi{
  min-height:98px!important;
  display:grid!important;
  align-content:center!important;
  gap:5px!important;
  border:1px solid rgba(255,255,255,.24)!important;
  background:rgba(255,255,255,.12)!important;
  color:#fff!important;
  border-radius:20px!important;
  padding:14px!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16)!important;
}
.report-summary-kpis span,
.delegate-kpi span,
.approval-studio-kpi span,
.admin-pro-kpi span{
  color:rgba(255,255,255,.74)!important;
  font-size:12px!important;
  font-weight:600!important;
}
.report-summary-kpis strong,
.delegate-kpi strong,
.approval-studio-kpi strong,
.admin-pro-kpi strong{
  color:#fff!important;
  font-size:clamp(24px,1.8vw,31px)!important;
  line-height:1.05!important;
  font-weight:700!important;
}
.approval-studio-kpi small,
.admin-pro-kpi small,
.delegate-kpi small{
  color:rgba(255,255,255,.72)!important;
}

/* Hero chips/tags */
.delegate-page-hero .delegate-hero-chips span,
.admin-pro-hero .admin-pro-hero-tags span,
.qa-hero .qa-hero-meta span{
  display:inline-flex!important;
  align-items:center!important;
  min-height:32px!important;
  padding:7px 12px!important;
  border:1px solid rgba(255,255,255,.24)!important;
  border-radius:999px!important;
  background:rgba(255,255,255,.13)!important;
  color:rgba(255,255,255,.90)!important;
  font-size:12px!important;
  font-weight:600!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14)!important;
}

/* Calendar and report heroes with custom structures */
.calendar-view-hero .calendar-view-main,
.leave-calendar-hero .leave-calendar-hero-main,
.profile-hero .profile-hero-main,
.qa-hero .qa-hero-copy,
.admin-pro-hero .admin-pro-hero-main,
.approval-studio-hero .approval-studio-hero-main,
.delegate-page-hero .delegate-page-copy{
  min-width:0!important;
}
.calendar-view-hero .calendar-view-nav,
.calendar-view-hero .calendar-view-meta{
  justify-self:end!important;
  border:1px solid var(--gov-hero-line)!important;
  background:var(--gov-hero-glass)!important;
  border-radius:22px!important;
  padding:14px!important;
  color:#fff!important;
}
.calendar-view-hero .calendar-view-nav a,
.calendar-view-hero .calendar-view-nav .btn{
  color:#063a5a!important;
  background:#fff!important;
}

/* Prevent old light-hero overrides from leaking back in */
.sla-hero,.sla-settings-hero,
.approval-studio-hero,
.delegate-page-hero,
.calendar-view-hero,
.report-center-hero,
.report-summary-hero,
.admin-pro-hero,
.qa-hero{
  background:var(--gov-hero-bg)!important;
  border-color:rgba(191,222,233,.58)!important;
  color:#fff!important;
}

/* Responsive hero behavior */
@media(max-width:1180px){
  .page-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .report-center-hero,
  .report-summary-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .admin-pro-hero,
  .profile-hero,
  .qa-hero{
    grid-template-columns:1fr!important;
    align-items:start!important;
  }
  .hero-orbit-card,
  .hero-stepper,
  .report-center-period,
  .report-summary-kpis,
  .delegate-kpi-row,
  .approval-studio-kpis,
  .admin-pro-kpi-grid,
  .qa-score-card{
    width:100%!important;
    max-width:none!important;
    justify-self:stretch!important;
  }
}
@media(max-width:760px){
  .page-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .report-center-hero,
  .report-summary-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .admin-pro-hero,
  .profile-hero,
  .qa-hero{
    margin-bottom:16px!important;
    padding:18px!important;
    border-radius:24px!important;
  }
  .page-hero h1,.page-hero h2,.page-hero h3,
  .leave-calendar-hero h1,.leave-calendar-hero h2,.leave-calendar-hero h3,
  .calendar-view-hero h1,.calendar-view-hero h2,.calendar-view-hero h3,
  .report-center-hero h1,.report-center-hero h2,.report-center-hero h3,
  .report-summary-hero h1,.report-summary-hero h2,.report-summary-hero h3,
  .delegate-page-hero h1,.delegate-page-hero h2,.delegate-page-hero h3,
  .approval-studio-hero h1,.approval-studio-hero h2,.approval-studio-hero h3,
  .admin-pro-hero h1,.admin-pro-hero h2,.admin-pro-hero h3,
  .profile-hero h1,.profile-hero h2,.profile-hero h3,
  .qa-hero h1,.qa-hero h2,.qa-hero h3{
    font-size:23px!important;
  }
  .page-hero-actions,
  .leave-calendar-hero-actions,
  .report-center-actions,
  .approval-studio-hero-actions{
    width:100%!important;
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .page-hero-actions .btn,
  .page-hero-actions form,
  .page-hero-actions button,
  .leave-calendar-hero-actions .btn,
  .report-center-actions .btn,
  .approval-studio-hero-actions .btn{
    width:100%!important;
  }
  .report-summary-kpis,
  .delegate-kpi-row,
  .approval-studio-kpis,
  .admin-pro-kpi-grid{
    grid-template-columns:1fr!important;
  }
}

/* --------------------------------------------------------------------------
   Phase 2.8.7 — Approval Inbox Hero Orbit Card Consistency
   Keep /approvals right-side hero summary card visually aligned with /leave/my.
   Scope intentionally limited to the approval inbox hero to avoid touching
   approval detail print-action cards or other hero summary components.
---------------------------------------------------------------------------- */
.approval-inbox-hero .hero-orbit-card.no-print{
  min-width:210px!important;
  max-width:280px!important;
  justify-self:end!important;
  align-self:center!important;
  display:grid!important;
  gap:4px!important;
  padding:18px!important;
  border:1px solid #dbe5f0!important;
  border-radius:24px!important;
  background:rgba(255,255,255,.88)!important;
  color:#0f172a!important;
  box-shadow:0 10px 26px rgba(6,36,58,.06)!important;
  backdrop-filter:none!important;
}
.approval-inbox-hero .hero-orbit-card.no-print span{
  display:block!important;
  margin:0!important;
  color:#64748b!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:500!important;
}
.approval-inbox-hero .hero-orbit-card.no-print strong{
  display:block!important;
  margin:2px 0!important;
  color:#0e5d89!important;
  font-size:clamp(26px,2vw,34px)!important;
  line-height:1.05!important;
  font-weight:500!important;
  letter-spacing:-.02em!important;
}
.approval-inbox-hero .hero-orbit-card.no-print small{
  display:block!important;
  color:#64748b!important;
  font-size:12px!important;
  line-height:1.45!important;
  font-weight:400!important;
}
@media(max-width:1180px){
  .approval-inbox-hero .hero-orbit-card.no-print{
    width:100%!important;
    max-width:none!important;
    justify-self:stretch!important;
  }
}

/* --------------------------------------------------------------------------
   Phase 2.8.8 — Approval/SLA Hero Metric Card Consistency
   Make SLA pending tasks, approval routes, and approval delegations right-side
   hero metrics use the same clean white summary-card language as /leave/my.
   Scope is intentionally limited to these three render pages.
---------------------------------------------------------------------------- */
.sla-hero .hero-orbit-card.no-print,
.approval-studio-hero .approval-studio-kpi,
.delegate-page-hero .delegate-kpi{
  border:1px solid #dbe5f0!important;
  border-radius:24px!important;
  background:rgba(255,255,255,.88)!important;
  color:#0f172a!important;
  box-shadow:0 10px 26px rgba(6,36,58,.06)!important;
  backdrop-filter:none!important;
}
.sla-hero .hero-orbit-card.no-print{
  min-width:210px!important;
  max-width:280px!important;
  justify-self:end!important;
  align-self:center!important;
  display:grid!important;
  gap:4px!important;
  padding:18px!important;
}
.sla-hero .hero-orbit-card.no-print span,
.approval-studio-hero .approval-studio-kpi span,
.delegate-page-hero .delegate-kpi span{
  display:block!important;
  margin:0!important;
  color:#64748b!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:500!important;
}
.sla-hero .hero-orbit-card.no-print strong,
.approval-studio-hero .approval-studio-kpi strong,
.delegate-page-hero .delegate-kpi strong{
  display:block!important;
  margin:2px 0!important;
  color:#0e5d89!important;
  font-size:clamp(26px,2vw,34px)!important;
  line-height:1.05!important;
  font-weight:500!important;
  letter-spacing:-.02em!important;
}
.sla-hero .hero-orbit-card.no-print small,
.approval-studio-hero .approval-studio-kpi small,
.delegate-page-hero .delegate-kpi small{
  display:block!important;
  color:#64748b!important;
  font-size:12px!important;
  line-height:1.45!important;
  font-weight:400!important;
}
.approval-studio-hero .approval-studio-kpis,
.delegate-page-hero .delegate-kpi-row{
  align-self:center!important;
  width:min(100%,440px)!important;
  justify-self:end!important;
}
.approval-studio-hero .approval-studio-kpi,
.delegate-page-hero .delegate-kpi{
  min-height:102px!important;
  padding:16px!important;
  align-content:center!important;
}
.approval-studio-hero .approval-studio-kpi.is-warning{
  border-color:#fed7aa!important;
  background:linear-gradient(180deg,#fff 0%,#fff7ed 100%)!important;
}
.approval-studio-hero .approval-studio-kpi.is-ok,
.delegate-page-hero .delegate-kpi.is-active{
  border-color:#bbf7d0!important;
  background:linear-gradient(180deg,#fff 0%,#f0fdf4 100%)!important;
}
.delegate-page-hero .delegate-kpi.is-scheduled{
  border-color:#bfdbfe!important;
  background:linear-gradient(180deg,#fff 0%,#eff6ff 100%)!important;
}
.delegate-page-hero .delegate-kpi.is-expired,
.delegate-page-hero .delegate-kpi.is-inactive{
  border-color:#e2e8f0!important;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%)!important;
}
@media(max-width:1180px){
  .sla-hero .hero-orbit-card.no-print,
  .approval-studio-hero .approval-studio-kpis,
  .delegate-page-hero .delegate-kpi-row{
    width:100%!important;
    max-width:none!important;
    justify-self:stretch!important;
  }
}
@media(max-width:760px){
  .approval-studio-hero .approval-studio-kpis,
  .delegate-page-hero .delegate-kpi-row{
    grid-template-columns:1fr!important;
  }
  .sla-hero .hero-orbit-card.no-print,
  .approval-studio-hero .approval-studio-kpi,
  .delegate-page-hero .delegate-kpi{
    min-width:0!important;
  }
}

/* --------------------------------------------------------------------------
   Phase 2.8.9 — All Hero Summary Cards Match /leave/my
   Scope: presentation only. Keep the unified gradient hero, but make every
   hero-side summary / metric / action card use the same clean white card
   language as the /leave/my hero card.
---------------------------------------------------------------------------- */
:root{
  --hero-card-bg:rgba(255,255,255,.88);
  --hero-card-border:#dbe5f0;
  --hero-card-ink:#0f172a;
  --hero-card-muted:#64748b;
  --hero-card-accent:#0e5d89;
  --hero-card-shadow:0 10px 26px rgba(6,36,58,.06);
}

/* Single-card hero panels: /leave/my reference applied system-wide */
.page-hero .hero-orbit-card,
.page-hero .hero-stepper,
.leave-calendar-hero .hero-orbit-card,
.leave-calendar-hero .hero-stepper,
.calendar-view-hero .calendar-view-nav,
.calendar-view-hero .calendar-view-meta,
.report-center-hero .report-center-period,
.report-summary-hero .hero-orbit-card,
.delegate-page-hero .hero-orbit-card,
.approval-studio-hero .hero-orbit-card,
.admin-pro-hero .hero-orbit-card,
.profile-hero .hero-orbit-card,
.qa-hero .qa-score-card,
.health-hero .hero-orbit-card,
.notification-page-hero .hero-orbit-card,
.approval-detail-hero .hero-orbit-card,
.my-leave-detail-hero .hero-orbit-card,
.vacation-policy-hero .hero-orbit-card,
.working-day-hero .hero-orbit-card,
.sla-settings-hero .hero-orbit-card,
.sla-hero .hero-orbit-card{
  min-width:min(100%,210px)!important;
  max-width:320px!important;
  justify-self:end!important;
  align-self:center!important;
  display:grid!important;
  gap:4px!important;
  padding:18px!important;
  border:1px solid var(--hero-card-border)!important;
  border-radius:24px!important;
  background:var(--hero-card-bg)!important;
  color:var(--hero-card-ink)!important;
  box-shadow:var(--hero-card-shadow)!important;
  backdrop-filter:none!important;
  text-align:left!important;
}

/* Multi-metric hero groups: make each metric card use the /leave/my language */
.report-summary-hero .report-summary-kpis,
.delegate-page-hero .delegate-kpi-row,
.approval-studio-hero .approval-studio-kpis,
.admin-pro-hero .admin-pro-kpi-grid{
  width:min(100%,460px)!important;
  justify-self:end!important;
  align-self:center!important;
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(126px,1fr))!important;
  gap:10px!important;
}
.report-summary-hero .report-summary-kpis > *,
.delegate-page-hero .delegate-kpi,
.approval-studio-hero .approval-studio-kpi,
.admin-pro-hero .admin-pro-kpi{
  min-height:104px!important;
  display:grid!important;
  align-content:center!important;
  gap:5px!important;
  padding:16px!important;
  border:1px solid var(--hero-card-border)!important;
  border-radius:24px!important;
  background:var(--hero-card-bg)!important;
  color:var(--hero-card-ink)!important;
  box-shadow:var(--hero-card-shadow)!important;
  backdrop-filter:none!important;
}

/* Text tone inside all hero-side cards */
.page-hero .hero-orbit-card span,
.page-hero .hero-orbit-card small,
.page-hero .hero-stepper span,
.page-hero .hero-stepper small,
.leave-calendar-hero .hero-orbit-card span,
.leave-calendar-hero .hero-orbit-card small,
.calendar-view-hero .calendar-view-nav span,
.calendar-view-hero .calendar-view-nav small,
.calendar-view-hero .calendar-view-meta span,
.calendar-view-hero .calendar-view-meta small,
.report-center-hero .report-center-period span,
.report-center-hero .report-center-period small,
.report-summary-hero .report-summary-kpis span,
.report-summary-hero .report-summary-kpis small,
.delegate-page-hero .delegate-kpi span,
.delegate-page-hero .delegate-kpi small,
.approval-studio-hero .approval-studio-kpi span,
.approval-studio-hero .approval-studio-kpi small,
.admin-pro-hero .admin-pro-kpi span,
.admin-pro-hero .admin-pro-kpi small,
.qa-hero .qa-score-card span,
.qa-hero .qa-score-card small,
.health-hero .hero-orbit-card span,
.health-hero .hero-orbit-card small,
.notification-page-hero .hero-orbit-card span,
.notification-page-hero .hero-orbit-card small,
.sla-hero .hero-orbit-card span,
.sla-hero .hero-orbit-card small,
.sla-settings-hero .hero-orbit-card span,
.sla-settings-hero .hero-orbit-card small{
  display:block!important;
  color:var(--hero-card-muted)!important;
  font-size:12px!important;
  line-height:1.45!important;
  font-weight:400!important;
  letter-spacing:0!important;
}
.page-hero .hero-orbit-card strong,
.page-hero .hero-stepper strong,
.leave-calendar-hero .hero-orbit-card strong,
.calendar-view-hero .calendar-view-nav strong,
.calendar-view-hero .calendar-view-meta strong,
.report-center-hero .report-center-period strong,
.report-summary-hero .report-summary-kpis strong,
.delegate-page-hero .delegate-kpi strong,
.approval-studio-hero .approval-studio-kpi strong,
.admin-pro-hero .admin-pro-kpi strong,
.qa-hero .qa-score-card strong,
.health-hero .hero-orbit-card strong,
.notification-page-hero .hero-orbit-card strong,
.sla-hero .hero-orbit-card strong,
.sla-settings-hero .hero-orbit-card strong{
  display:block!important;
  margin:2px 0!important;
  color:var(--hero-card-accent)!important;
  font-size:clamp(26px,2vw,34px)!important;
  line-height:1.05!important;
  font-weight:500!important;
  letter-spacing:-.02em!important;
  text-shadow:none!important;
}

/* Keep special-state metric cards clean, not tinted blocks inside hero */
.approval-studio-hero .approval-studio-kpi.is-warning,
.approval-studio-hero .approval-studio-kpi.is-ok,
.delegate-page-hero .delegate-kpi.is-active,
.delegate-page-hero .delegate-kpi.is-scheduled,
.delegate-page-hero .delegate-kpi.is-expired,
.delegate-page-hero .delegate-kpi.is-inactive{
  background:var(--hero-card-bg)!important;
  border-color:var(--hero-card-border)!important;
}

/* Hero-stepper is a card, but its pills still need compact readable state */
.page-hero .hero-stepper div,
.form-hero .hero-stepper div{
  min-width:0!important;
  color:var(--hero-card-ink)!important;
}
.page-hero .hero-stepper span,
.form-hero .hero-stepper span{
  width:34px!important;
  height:30px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:999px!important;
  background:#e8f6fb!important;
  color:var(--hero-card-accent)!important;
  font-weight:700!important;
}
.page-hero .hero-stepper strong,
.form-hero .hero-stepper strong{
  color:var(--hero-card-ink)!important;
  font-size:13px!important;
}
.page-hero .hero-stepper small,
.form-hero .hero-stepper small{
  color:var(--hero-card-muted)!important;
}

/* Buttons inside white hero cards should not inherit dark/glass hero buttons */
.page-hero .hero-orbit-card .btn,
.approval-detail-hero .approval-print-actions .btn,
.my-leave-detail-hero .my-leave-print-card .btn,
.qa-hero .qa-score-card .btn{
  box-shadow:0 7px 18px rgba(6,36,58,.055)!important;
}
.page-hero .hero-orbit-card .btn-light,
.approval-detail-hero .approval-print-actions .btn-light,
.my-leave-detail-hero .my-leave-print-card .btn-light{
  background:#fff!important;
  color:#063a5a!important;
  border-color:#cbd8e6!important;
}

@media(max-width:1180px){
  .page-hero .hero-orbit-card,
  .page-hero .hero-stepper,
  .leave-calendar-hero .hero-orbit-card,
  .calendar-view-hero .calendar-view-nav,
  .calendar-view-hero .calendar-view-meta,
  .report-center-hero .report-center-period,
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid,
  .qa-hero .qa-score-card,
  .health-hero .hero-orbit-card,
  .notification-page-hero .hero-orbit-card,
  .sla-hero .hero-orbit-card,
  .sla-settings-hero .hero-orbit-card{
    width:100%!important;
    max-width:none!important;
    justify-self:stretch!important;
  }
}
@media(max-width:760px){
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid{
    grid-template-columns:1fr!important;
  }
}

/* ======================================================================
   Phase 2.8.10 — Left Sidebar Icon System Consistency
   Purpose: make all left navigation icons use one visual language.
   Scope: sidebar menu only; no workflow/permission change.
   ====================================================================== */
.sidebar .nav a{
    gap:12px;
}
.sidebar .nav-icon,
.sidebar .stock-nav-icon{
    width:36px !important;
    height:36px !important;
    min-width:36px !important;
    flex:0 0 36px !important;
    border-radius:14px !important;
    display:inline-grid !important;
    place-items:center !important;
    background:linear-gradient(135deg,#eef8fb 0%,#e5f1f7 100%) !important;
    border:1px solid rgba(191,222,233,.82) !important;
    color:#0e5d89 !important;
    font-family:'Kanit','Noto Sans Thai','Segoe UI Symbol',Arial,sans-serif !important;
    font-size:13px !important;
    font-weight:650 !important;
    line-height:1 !important;
    letter-spacing:-.02em !important;
    text-transform:uppercase !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 6px 14px rgba(6,36,58,.045) !important;
    overflow:hidden !important;
}
.sidebar .nav a:hover .nav-icon,
.sidebar .stock-nav-link:hover .stock-nav-icon{
    background:linear-gradient(135deg,#ffffff 0%,#e8f6fb 100%) !important;
    border-color:rgba(13,127,168,.30) !important;
    color:#064768 !important;
    transform:none !important;
}
.sidebar .nav a.is-active .nav-icon,
.sidebar .stock-nav-link.stock-nav-active .stock-nav-icon{
    background:rgba(255,255,255,.18) !important;
    border-color:rgba(255,255,255,.32) !important;
    color:#ffffff !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.24) !important;
}
.sidebar .nav-icon:empty::before{
    content:'•';
}
.sidebar .nav-text strong{
    line-height:1.24;
}
.sidebar .nav-text small{
    line-height:1.34;
}
@media(max-width:760px){
    .sidebar .nav-icon,
    .sidebar .stock-nav-icon{
        width:34px !important;
        height:34px !important;
        min-width:34px !important;
        flex-basis:34px !important;
        border-radius:13px !important;
        font-size:12.5px !important;
    }
}

/* ======================================================================
   Phase 2.8.11 — Compact Production Hero Copy & Layout
   Scope: hero sections only; keep the restored 2.6.4 theme and current icons.
   ====================================================================== */
:root{
  --hero-compact-radius:24px;
  --hero-compact-padding-y:18px;
  --hero-compact-padding-x:22px;
  --hero-compact-gap:18px;
  --hero-compact-card-bg:rgba(255,255,255,.91);
  --hero-compact-card-border:rgba(219,229,240,.96);
  --hero-compact-card-shadow:0 8px 20px rgba(6,36,58,.055);
}
.page-hero,
.leave-calendar-hero,
.calendar-view-hero,
.report-center-hero,
.report-summary-hero,
.delegate-page-hero,
.approval-studio-hero,
.admin-pro-hero,
.profile-hero,
.qa-hero{
  grid-template-columns:minmax(0,1fr) minmax(190px,auto)!important;
  gap:var(--hero-compact-gap)!important;
  margin:0 0 18px!important;
  padding:var(--hero-compact-padding-y) var(--hero-compact-padding-x)!important;
  border-radius:var(--hero-compact-radius)!important;
  box-shadow:0 16px 34px rgba(6,36,58,.15)!important;
}
.page-hero::before,
.leave-calendar-hero::before,
.calendar-view-hero::before,
.report-center-hero::before,
.report-summary-hero::before,
.delegate-page-hero::before,
.approval-studio-hero::before,
.admin-pro-hero::before,
.profile-hero::before,
.qa-hero::before{
  opacity:.72!important;
  background:
    radial-gradient(circle at 96% 2%,rgba(255,255,255,.16) 0 0,rgba(255,255,255,.16) 96px,transparent 98px),
    radial-gradient(circle at 90% 60%,rgba(255,255,255,.09) 0 0,rgba(255,255,255,.09) 126px,transparent 128px),
    linear-gradient(90deg,rgba(255,255,255,.04),transparent 38%)!important;
}
.page-hero::after,
.leave-calendar-hero::after,
.calendar-view-hero::after,
.report-center-hero::after,
.report-summary-hero::after,
.delegate-page-hero::after,
.approval-studio-hero::after,
.admin-pro-hero::after,
.profile-hero::after,
.qa-hero::after{
  right:-64px!important;
  top:-82px!important;
  width:220px!important;
  height:220px!important;
  opacity:.82!important;
}
.page-hero h1,.page-hero h2,.page-hero h3,
.leave-calendar-hero h1,.leave-calendar-hero h2,.leave-calendar-hero h3,
.calendar-view-hero h1,.calendar-view-hero h2,.calendar-view-hero h3,
.report-center-hero h1,.report-center-hero h2,.report-center-hero h3,
.report-summary-hero h1,.report-summary-hero h2,.report-summary-hero h3,
.delegate-page-hero h1,.delegate-page-hero h2,.delegate-page-hero h3,
.approval-studio-hero h1,.approval-studio-hero h2,.approval-studio-hero h3,
.admin-pro-hero h1,.admin-pro-hero h2,.admin-pro-hero h3,
.profile-hero h1,.profile-hero h2,.profile-hero h3,
.qa-hero h1,.qa-hero h2,.qa-hero h3{
  margin:.34rem 0 0!important;
  font-size:clamp(23px,1.68vw,30px)!important;
  line-height:1.16!important;
  font-weight:680!important;
  letter-spacing:-.026em!important;
}
.page-hero p,
.leave-calendar-hero p,
.calendar-view-hero p,
.report-center-hero p,
.report-summary-hero p,
.delegate-page-hero p,
.approval-studio-hero p,
.admin-pro-hero p,
.profile-hero p,
.qa-hero p{
  max-width:760px!important;
  margin:.46rem 0 0!important;
  color:rgba(255,255,255,.86)!important;
  font-size:13.5px!important;
  line-height:1.58!important;
  font-weight:450!important;
}
.page-hero .hero-kicker,
.leave-calendar-hero .hero-kicker,
.leave-calendar-hero .page-kicker,
.calendar-view-hero .hero-kicker,
.calendar-view-hero .calendar-view-kicker,
.report-center-hero .hero-kicker,
.report-summary-hero .hero-kicker,
.delegate-page-hero .delegate-kicker,
.approval-studio-hero .approval-studio-eyebrow,
.admin-pro-hero .admin-pro-kicker,
.profile-hero .profile-kicker,
.profile-hero .profile-eyebrow,
.qa-hero .hero-kicker{
  min-height:28px!important;
  padding:5px 10px!important;
  font-size:11.5px!important;
  line-height:1.1!important;
  font-weight:620!important;
  box-shadow:0 6px 16px rgba(6,36,58,.09)!important;
}
.page-hero-actions,
.leave-calendar-hero-actions,
.report-center-actions,
.approval-studio-hero-actions,
.delegate-hero-chips,
.admin-pro-hero-tags,
.qa-hero-meta{
  gap:8px!important;
  margin-top:12px!important;
}
.page-hero .btn,
.leave-calendar-hero .btn,
.calendar-view-hero .btn,
.report-center-hero .btn,
.report-summary-hero .btn,
.delegate-page-hero .btn,
.approval-studio-hero .btn,
.admin-pro-hero .btn,
.profile-hero .btn,
.qa-hero .btn{
  min-height:40px!important;
  border-radius:12px!important;
  padding:.58rem .88rem!important;
  font-size:13px!important;
  font-weight:620!important;
  box-shadow:0 8px 18px rgba(4,24,40,.12)!important;
}
.page-hero .hero-orbit-card,
.page-hero .hero-stepper,
.leave-calendar-hero .hero-orbit-card,
.leave-calendar-hero .hero-stepper,
.calendar-view-hero .calendar-view-nav,
.calendar-view-hero .calendar-view-meta,
.report-center-hero .report-center-period,
.report-summary-hero .hero-orbit-card,
.delegate-page-hero .hero-orbit-card,
.approval-studio-hero .hero-orbit-card,
.admin-pro-hero .hero-orbit-card,
.profile-hero .hero-orbit-card,
.qa-hero .qa-score-card,
.health-hero .hero-orbit-card,
.notification-page-hero .hero-orbit-card,
.approval-detail-hero .hero-orbit-card,
.my-leave-detail-hero .hero-orbit-card,
.vacation-policy-hero .hero-orbit-card,
.working-day-hero .hero-orbit-card,
.sla-settings-hero .hero-orbit-card,
.sla-hero .hero-orbit-card{
  min-width:min(100%,190px)!important;
  max-width:280px!important;
  padding:14px!important;
  border-radius:20px!important;
  background:var(--hero-compact-card-bg)!important;
  border-color:var(--hero-compact-card-border)!important;
  box-shadow:var(--hero-compact-card-shadow)!important;
}
.report-summary-hero .report-summary-kpis,
.delegate-page-hero .delegate-kpi-row,
.approval-studio-hero .approval-studio-kpis,
.admin-pro-hero .admin-pro-kpi-grid,
.leave-calendar-hero .leave-calendar-kpis{
  width:min(100%,420px)!important;
  gap:8px!important;
}
.report-summary-hero .report-summary-kpis > *,
.delegate-page-hero .delegate-kpi,
.approval-studio-hero .approval-studio-kpi,
.admin-pro-hero .admin-pro-kpi,
.leave-calendar-hero .leave-calendar-kpis > div{
  min-height:84px!important;
  padding:12px 13px!important;
  border-radius:20px!important;
  background:var(--hero-compact-card-bg)!important;
  border-color:var(--hero-compact-card-border)!important;
  box-shadow:var(--hero-compact-card-shadow)!important;
}
.page-hero .hero-orbit-card span,
.page-hero .hero-orbit-card small,
.page-hero .hero-stepper span,
.page-hero .hero-stepper small,
.report-center-hero .report-center-period span,
.report-center-hero .report-center-period small,
.report-summary-hero .report-summary-kpis span,
.report-summary-hero .report-summary-kpis small,
.delegate-page-hero .delegate-kpi span,
.delegate-page-hero .delegate-kpi small,
.approval-studio-hero .approval-studio-kpi span,
.approval-studio-hero .approval-studio-kpi small,
.admin-pro-hero .admin-pro-kpi span,
.admin-pro-hero .admin-pro-kpi small,
.leave-calendar-hero .leave-calendar-kpis span,
.leave-calendar-hero .leave-calendar-kpis small,
.qa-hero .qa-score-card span,
.qa-hero .qa-score-card small,
.health-hero .hero-orbit-card span,
.health-hero .hero-orbit-card small,
.notification-page-hero .hero-orbit-card span,
.notification-page-hero .hero-orbit-card small,
.sla-hero .hero-orbit-card span,
.sla-hero .hero-orbit-card small,
.sla-settings-hero .hero-orbit-card span,
.sla-settings-hero .hero-orbit-card small{
  font-size:11.5px!important;
  line-height:1.38!important;
  color:#64748b!important;
  font-weight:420!important;
}
.page-hero .hero-orbit-card strong,
.page-hero .hero-stepper strong,
.report-center-hero .report-center-period strong,
.report-summary-hero .report-summary-kpis strong,
.delegate-page-hero .delegate-kpi strong,
.approval-studio-hero .approval-studio-kpi strong,
.admin-pro-hero .admin-pro-kpi strong,
.leave-calendar-hero .leave-calendar-kpis strong,
.qa-hero .qa-score-card strong,
.health-hero .hero-orbit-card strong,
.notification-page-hero .hero-orbit-card strong,
.sla-hero .hero-orbit-card strong,
.sla-settings-hero .hero-orbit-card strong{
  margin:1px 0!important;
  font-size:clamp(22px,1.65vw,28px)!important;
  line-height:1.05!important;
  font-weight:560!important;
  color:#0e5d89!important;
}
.page-hero .hero-stepper{
  gap:6px!important;
}
.page-hero .hero-stepper div,
.form-hero .hero-stepper div{
  gap:7px!important;
}
.page-hero .hero-stepper span,
.form-hero .hero-stepper span{
  width:30px!important;
  height:28px!important;
  font-size:11px!important;
}
.delegate-page-hero .delegate-hero-chips span,
.admin-pro-hero .admin-pro-hero-tags span,
.qa-hero .qa-hero-meta span{
  min-height:28px!important;
  padding:5px 10px!important;
  font-size:11.5px!important;
  border-radius:999px!important;
}
.auth-hero-copy{
  max-width:760px!important;
}
.auth-hero-copy h1{
  font-size:clamp(2.4rem,4.35vw,4.9rem)!important;
  line-height:1.08!important;
}
.auth-hero-copy p{
  max-width:700px!important;
  font-size:1rem!important;
  line-height:1.72!important;
}
.auth-process-card{
  margin-top:2rem!important;
}
.auth-feature-pills{
  margin-top:1.4rem!important;
}
@media(max-width:1180px){
  .page-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .report-center-hero,
  .report-summary-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .admin-pro-hero,
  .profile-hero,
  .qa-hero{
    grid-template-columns:1fr!important;
  }
  .page-hero .hero-orbit-card,
  .page-hero .hero-stepper,
  .report-center-hero .report-center-period,
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid,
  .leave-calendar-hero .leave-calendar-kpis,
  .qa-hero .qa-score-card{
    width:100%!important;
    max-width:none!important;
    justify-self:stretch!important;
  }
}
@media(max-width:760px){
  .page-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .report-center-hero,
  .report-summary-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .admin-pro-hero,
  .profile-hero,
  .qa-hero{
    margin-bottom:14px!important;
    padding:15px!important;
    border-radius:20px!important;
    gap:14px!important;
  }
  .page-hero h1,.page-hero h2,.page-hero h3,
  .leave-calendar-hero h1,.leave-calendar-hero h2,.leave-calendar-hero h3,
  .calendar-view-hero h1,.calendar-view-hero h2,.calendar-view-hero h3,
  .report-center-hero h1,.report-center-hero h2,.report-center-hero h3,
  .report-summary-hero h1,.report-summary-hero h2,.report-summary-hero h3,
  .delegate-page-hero h1,.delegate-page-hero h2,.delegate-page-hero h3,
  .approval-studio-hero h1,.approval-studio-hero h2,.approval-studio-hero h3,
  .admin-pro-hero h1,.admin-pro-hero h2,.admin-pro-hero h3,
  .profile-hero h1,.profile-hero h2,.profile-hero h3,
  .qa-hero h1,.qa-hero h2,.qa-hero h3{
    font-size:21px!important;
  }
  .page-hero p,
  .leave-calendar-hero p,
  .calendar-view-hero p,
  .report-center-hero p,
  .report-summary-hero p,
  .delegate-page-hero p,
  .approval-studio-hero p,
  .admin-pro-hero p,
  .profile-hero p,
  .qa-hero p{
    font-size:13px!important;
    line-height:1.5!important;
  }
}

/* ======================================================================
   Phase 2.8.12 — Leave Create Hero Proportion Repair
   Scope: /leave/create and /leave/edit hero only. Keep the shared hero theme,
   but make the form stepper compact and balanced with the left title block.
   ====================================================================== */
.form-hero{
  grid-template-columns:minmax(0,1fr) minmax(260px,320px)!important;
  align-items:center!important;
  gap:24px!important;
  min-height:0!important;
  padding:22px 26px!important;
}
.form-hero > div:first-child{
  max-width:760px!important;
}
.form-hero .page-hero-actions{
  margin-top:14px!important;
}
.form-hero .btn{
  min-height:40px!important;
}
.form-hero .hero-stepper{
  width:100%!important;
  max-width:320px!important;
  min-width:260px!important;
  justify-self:end!important;
  align-self:center!important;
  display:grid!important;
  gap:9px!important;
  padding:15px 16px!important;
  border-radius:20px!important;
}
.form-hero .hero-stepper div{
  display:grid!important;
  grid-template-columns:34px minmax(0,1fr)!important;
  align-items:center!important;
  gap:10px!important;
  min-height:34px!important;
  padding:0!important;
  color:#0f172a!important;
}
.form-hero .hero-stepper span{
  width:34px!important;
  height:28px!important;
  min-width:34px!important;
  border-radius:999px!important;
  display:grid!important;
  place-items:center!important;
  background:#eef7fb!important;
  color:#0e5d89!important;
  font-size:11px!important;
  line-height:1!important;
  font-weight:700!important;
  letter-spacing:0!important;
}
.form-hero .hero-stepper strong{
  display:block!important;
  margin:0!important;
  color:#063a5a!important;
  font-size:15px!important;
  line-height:1.25!important;
  font-weight:700!important;
  letter-spacing:-.01em!important;
  text-shadow:none!important;
  white-space:normal!important;
}
.form-hero .hero-stepper small{
  color:#64748b!important;
  font-size:11.5px!important;
  line-height:1.35!important;
}
@media(max-width:1180px){
  .form-hero{
    grid-template-columns:1fr!important;
  }
  .form-hero .hero-stepper{
    max-width:none!important;
    min-width:0!important;
    justify-self:stretch!important;
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
  }
  .form-hero .hero-stepper div{
    grid-template-columns:1fr!important;
    justify-items:center!important;
    text-align:center!important;
    gap:6px!important;
  }
}
@media(max-width:760px){
  .form-hero{
    padding:16px!important;
    gap:14px!important;
  }
  .form-hero .page-hero-actions{
    margin-top:12px!important;
  }
  .form-hero .hero-stepper{
    grid-template-columns:1fr!important;
    padding:12px!important;
    gap:8px!important;
  }
  .form-hero .hero-stepper div{
    grid-template-columns:32px minmax(0,1fr)!important;
    justify-items:start!important;
    text-align:left!important;
  }
  .form-hero .hero-stepper strong{
    font-size:14px!important;
  }
}

/* ======================================================================
   Phase 2.8.13 — Equal KPI Card Sizing
   Scope: presentation only. KPI / metric / summary cards must have the
   same footprint in every grid. No first-card highlight, no card spanning,
   and no layout rule that makes the first card larger than the others.
   ====================================================================== */
:root{
  --kpi-equal-min-height:132px;
  --kpi-equal-radius:22px;
  --kpi-equal-gap:14px;
}

/* Body KPI grids: every direct child is one equal grid cell. */
:where(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid
){
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr))!important;
  gap:var(--kpi-equal-gap)!important;
  align-items:stretch!important;
}
:where(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid
) > *{
  grid-column:auto!important;
  grid-row:auto!important;
  align-self:stretch!important;
  justify-self:stretch!important;
  width:100%!important;
  max-width:none!important;
  min-width:0!important;
  height:100%!important;
  min-height:var(--kpi-equal-min-height)!important;
  display:grid!important;
  align-content:center!important;
  gap:6px!important;
  padding:16px!important;
  border-radius:var(--kpi-equal-radius)!important;
  box-sizing:border-box!important;
}
:where(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid
) > :first-child,
:where(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid
) > .is-featured,
:where(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid
) > .is-large{
  grid-column:auto!important;
  grid-row:auto!important;
  min-height:var(--kpi-equal-min-height)!important;
  transform:none!important;
}

/* Card typography must be consistent regardless of position. */
:where(.kpi-card,.report-kpi-card,.calendar-kpi,.qa-kpi,.carry-forward-summary-grid > div) span,
:where(.kpi-card,.report-kpi-card,.calendar-kpi,.qa-kpi,.carry-forward-summary-grid > div) small{
  font-size:12px!important;
  line-height:1.42!important;
}
:where(.kpi-card,.report-kpi-card,.calendar-kpi,.qa-kpi,.carry-forward-summary-grid > div) strong{
  font-size:clamp(24px,1.8vw,30px)!important;
  line-height:1.05!important;
}

/* Hero-side metric grids: still equal, but compact enough for hero width. */
:where(
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid,
  .leave-calendar-hero .leave-calendar-kpis
){
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(126px,1fr))!important;
  gap:10px!important;
  align-items:stretch!important;
}
:where(
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid,
  .leave-calendar-hero .leave-calendar-kpis
) > *{
  grid-column:auto!important;
  grid-row:auto!important;
  align-self:stretch!important;
  justify-self:stretch!important;
  width:100%!important;
  max-width:none!important;
  min-width:0!important;
  height:100%!important;
  min-height:96px!important;
  display:grid!important;
  align-content:center!important;
  gap:5px!important;
  padding:13px!important;
  border-radius:20px!important;
  box-sizing:border-box!important;
}
:where(
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid,
  .leave-calendar-hero .leave-calendar-kpis
) > :first-child,
:where(
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid,
  .leave-calendar-hero .leave-calendar-kpis
) > .is-featured,
:where(
  .report-summary-hero .report-summary-kpis,
  .delegate-page-hero .delegate-kpi-row,
  .approval-studio-hero .approval-studio-kpis,
  .admin-pro-hero .admin-pro-kpi-grid,
  .leave-calendar-hero .leave-calendar-kpis
) > .is-large{
  grid-column:auto!important;
  grid-row:auto!important;
  min-height:96px!important;
  transform:none!important;
}

@media(max-width:760px){
  :where(
    .kpi-grid,
    .my-leave-kpi-grid,
    .sla-kpi-grid,
    .working-day-kpi-grid,
    .vacation-policy-kpi-grid,
    .report-kpi-grid,
    .calendar-kpi-strip,
    .qa-kpi-grid,
    .carry-forward-summary-grid,
    .report-summary-hero .report-summary-kpis,
    .delegate-page-hero .delegate-kpi-row,
    .approval-studio-hero .approval-studio-kpis,
    .admin-pro-hero .admin-pro-kpi-grid,
    .leave-calendar-hero .leave-calendar-kpis
  ){
    grid-template-columns:1fr!important;
  }
}

/* ======================================================================
   Phase 2.8.14 — Remove Hero Orbit Cards + Equal KPI Cards Hard Fix
   Scope: presentation only. Hero orbit panels are removed from view files;
   this safety CSS prevents any cached/legacy orbit card from rendering and
   forces KPI/metric/summary cards to equal size even when earlier rules target
   :first-child, .is-featured, .is-large, or page-specific KPI classes.
   ====================================================================== */
body .hero-orbit-card{
  display:none!important;
}

body :is(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid,
  .report-summary-kpis,
  .delegate-kpi-row,
  .approval-studio-kpis,
  .admin-pro-kpi-grid,
  .hr-ref-kpi-grid,
  .user-employee-kpi-grid,
  .leave-calendar-kpis,
  .dashboard-kpi-grid,
  .health-kpi-grid,
  .notification-kpi-grid
){
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(184px,1fr))!important;
  gap:14px!important;
  align-items:stretch!important;
  justify-items:stretch!important;
}

body :is(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid,
  .report-summary-kpis,
  .delegate-kpi-row,
  .approval-studio-kpis,
  .admin-pro-kpi-grid,
  .hr-ref-kpi-grid,
  .user-employee-kpi-grid,
  .leave-calendar-kpis,
  .dashboard-kpi-grid,
  .health-kpi-grid,
  .notification-kpi-grid
) > :is(article,div,a,section),
body :is(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid,
  .report-summary-kpis,
  .delegate-kpi-row,
  .approval-studio-kpis,
  .admin-pro-kpi-grid,
  .hr-ref-kpi-grid,
  .user-employee-kpi-grid,
  .leave-calendar-kpis,
  .dashboard-kpi-grid,
  .health-kpi-grid,
  .notification-kpi-grid
) > *{
  grid-column:auto!important;
  grid-row:auto!important;
  align-self:stretch!important;
  justify-self:stretch!important;
  width:100%!important;
  max-width:none!important;
  min-width:0!important;
  height:auto!important;
  min-height:128px!important;
  transform:none!important;
  scale:1!important;
  padding:16px!important;
  box-sizing:border-box!important;
}

body :is(
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid,
  .report-summary-kpis,
  .delegate-kpi-row,
  .approval-studio-kpis,
  .admin-pro-kpi-grid,
  .hr-ref-kpi-grid,
  .user-employee-kpi-grid,
  .leave-calendar-kpis,
  .dashboard-kpi-grid,
  .health-kpi-grid,
  .notification-kpi-grid
) > :is(:first-child,:nth-child(1),.is-featured,.is-large,.featured,.large,.primary){
  grid-column:auto!important;
  grid-row:auto!important;
  width:100%!important;
  max-width:none!important;
  min-height:128px!important;
  height:auto!important;
  transform:none!important;
  scale:1!important;
  padding:16px!important;
}

body :is(.kpi-card,.report-kpi-card,.calendar-kpi,.qa-kpi,.delegate-kpi,.approval-studio-kpi,.admin-pro-kpi,.dashboard-kpi-card) strong,
body :is(.kpi-card,.report-kpi-card,.calendar-kpi,.qa-kpi,.delegate-kpi,.approval-studio-kpi,.admin-pro-kpi,.dashboard-kpi-card):first-child strong{
  font-size:clamp(24px,1.8vw,30px)!important;
  line-height:1.05!important;
}
body :is(.kpi-card,.report-kpi-card,.calendar-kpi,.qa-kpi,.delegate-kpi,.approval-studio-kpi,.admin-pro-kpi,.dashboard-kpi-card) span,
body :is(.kpi-card,.report-kpi-card,.calendar-kpi,.qa-kpi,.delegate-kpi,.approval-studio-kpi,.admin-pro-kpi,.dashboard-kpi-card) small{
  font-size:12px!important;
  line-height:1.42!important;
}

body .page-hero{
  grid-template-columns:minmax(0,1fr)!important;
}
body .page-hero > div:first-child{
  max-width:100%!important;
}

@media(max-width:760px){
  body :is(
    .kpi-grid,
    .my-leave-kpi-grid,
    .sla-kpi-grid,
    .working-day-kpi-grid,
    .vacation-policy-kpi-grid,
    .report-kpi-grid,
    .calendar-kpi-strip,
    .qa-kpi-grid,
    .carry-forward-summary-grid,
    .report-summary-kpis,
    .delegate-kpi-row,
    .approval-studio-kpis,
    .admin-pro-kpi-grid,
    .hr-ref-kpi-grid,
    .user-employee-kpi-grid,
    .leave-calendar-kpis,
    .dashboard-kpi-grid,
    .health-kpi-grid,
    .notification-kpi-grid
  ){
    grid-template-columns:1fr!important;
  }
}


/* =========================================================
   Phase 2.8.15 — Minimal Production Hero Cleanup
   Keep hero compact, useful, and consistent across all pages.
   ========================================================= */
:root{
  --hero-min-height: 132px;
  --hero-pad-y: clamp(22px, 2.1vw, 34px);
  --hero-pad-x: clamp(22px, 2.8vw, 42px);
}

body :is(
  .page-hero,
  .dashboard-hero,
  .form-hero,
  .my-leave-hero,
  .my-leave-detail-hero,
  .approval-inbox-hero,
  .approval-detail-hero,
  .sla-hero,
  .sla-settings-hero,
  .vacation-policy-hero,
  .working-day-hero,
  .notification-page-hero,
  .health-hero,
  .report-center-hero,
  .report-summary-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .admin-pro-hero,
  .profile-hero,
  .qa-hero
){
  position: relative !important;
  overflow: hidden !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  align-items: start !important;
  min-height: var(--hero-min-height) !important;
  padding: var(--hero-pad-y) var(--hero-pad-x) !important;
  margin: 0 0 clamp(18px, 2vw, 28px) !important;
  border-radius: 22px !important;
  border: 1px solid rgba(255,255,255,.24) !important;
  background: linear-gradient(135deg,#063a5a 0%,#0a5c8a 46%,#0d7fa8 100%) !important;
  box-shadow: 0 18px 42px rgba(6,58,90,.18) !important;
  color: #fff !important;
}

body :is(.page-hero,.report-center-hero,.report-summary-hero,.leave-calendar-hero,.calendar-view-hero,.delegate-page-hero,.approval-studio-hero,.admin-pro-hero,.profile-hero,.qa-hero)::before,
body :is(.page-hero,.report-center-hero,.report-summary-hero,.leave-calendar-hero,.calendar-view-hero,.delegate-page-hero,.approval-studio-hero,.admin-pro-hero,.profile-hero,.qa-hero)::after{
  content: none !important;
  display: none !important;
}

body :is(
  .page-hero,
  .report-center-hero,
  .report-summary-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .admin-pro-hero,
  .profile-hero,
  .qa-hero
) > :first-child,
body :is(.leave-calendar-hero-main,.calendar-view-copy,.delegate-page-copy,.approval-studio-hero-main,.admin-pro-hero-main,.profile-hero-main,.qa-hero-copy){
  width: min(100%, 980px) !important;
  max-width: 980px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px !important;
}

body :is(.hero-kicker,.page-kicker,.calendar-view-kicker,.delegate-kicker,.approval-studio-eyebrow,.admin-pro-kicker,.profile-eyebrow){
  display: inline-flex !important;
  align-items: center !important;
  min-height: 28px !important;
  padding: 5px 12px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.92) !important;
  color: #075985 !important;
  border: 1px solid rgba(255,255,255,.60) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  line-height: 1.2 !important;
  box-shadow: 0 8px 20px rgba(2,32,71,.10) !important;
}

body :is(.page-hero,.report-center-hero,.report-summary-hero,.leave-calendar-hero,.calendar-view-hero,.delegate-page-hero,.approval-studio-hero,.admin-pro-hero,.profile-hero,.qa-hero) h1,
body :is(.page-hero,.report-center-hero,.report-summary-hero,.leave-calendar-hero,.calendar-view-hero,.delegate-page-hero,.approval-studio-hero,.admin-pro-hero,.profile-hero,.qa-hero) h2{
  margin: 0 !important;
  max-width: 860px !important;
  color: #fff !important;
  font-size: clamp(25px, 2.1vw, 34px) !important;
  line-height: 1.16 !important;
  font-weight: 900 !important;
  letter-spacing: -.02em !important;
  text-shadow: 0 2px 12px rgba(0,0,0,.18) !important;
}

body :is(.page-hero,.report-center-hero,.report-summary-hero,.leave-calendar-hero,.calendar-view-hero,.delegate-page-hero,.approval-studio-hero,.admin-pro-hero,.profile-hero,.qa-hero) p{
  margin: 0 !important;
  max-width: 760px !important;
  color: rgba(255,255,255,.88) !important;
  font-size: clamp(14px, .98vw, 16px) !important;
  line-height: 1.65 !important;
  font-weight: 600 !important;
}

body :is(.page-hero-actions,.leave-calendar-hero-actions,.calendar-view-actions,.report-center-actions,.approval-studio-hero-actions){
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  margin-top: 8px !important;
}

body :is(.page-hero-actions,.leave-calendar-hero-actions,.calendar-view-actions,.report-center-actions,.approval-studio-hero-actions) :is(.btn,.button,button,a){
  min-height: 40px !important;
  padding: 9px 15px !important;
  border-radius: 12px !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

/* Nothing decorative or KPI-like should live inside hero after 2.8.15. */
body :is(
  .hero-stepper,
  .hero-orbit-card,
  .report-center-period,
  .calendar-view-meta,
  .delegate-hero-chips,
  .admin-pro-hero-tags,
  .profile-chip-row,
  .profile-avatar-card-pro,
  .qa-hero-meta,
  .qa-score-card
){
  display: none !important;
}

/* KPI blocks moved out of hero keep a normal card-grid rhythm. */
body :is(.leave-calendar-kpis,.report-summary-kpis,.delegate-kpi-row,.approval-studio-kpis,.admin-pro-kpi-grid){
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
  gap: 14px !important;
  margin: 0 0 24px !important;
  align-items: stretch !important;
}

body :is(.leave-calendar-kpis,.report-summary-kpis,.delegate-kpi-row,.approval-studio-kpis,.admin-pro-kpi-grid) > *{
  min-height: 112px !important;
  width: 100% !important;
  grid-column: auto !important;
  grid-row: auto !important;
  border-radius: 18px !important;
  border: 1px solid rgba(179,205,224,.72) !important;
  background: rgba(255,255,255,.92) !important;
  box-shadow: 0 12px 28px rgba(15,68,105,.08) !important;
  padding: 16px !important;
}

@media (max-width: 900px){
  body :is(
    .page-hero,
    .dashboard-hero,
    .form-hero,
    .report-center-hero,
    .report-summary-hero,
    .leave-calendar-hero,
    .calendar-view-hero,
    .delegate-page-hero,
    .approval-studio-hero,
    .admin-pro-hero,
    .profile-hero,
    .qa-hero
  ){
    min-height: auto !important;
    padding: 22px !important;
    border-radius: 20px !important;
  }
}

@media (max-width: 560px){
  body :is(.page-hero-actions,.leave-calendar-hero-actions,.calendar-view-actions,.report-center-actions,.approval-studio-hero-actions){
    width: 100% !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }
  body :is(.page-hero-actions,.leave-calendar-hero-actions,.calendar-view-actions,.report-center-actions,.approval-studio-hero-actions) :is(.btn,.button,button,a){
    width: 100% !important;
    justify-content: center !important;
  }
}


/* Phase 2.8.16 — Return KPI cards to hero with compact equal-card layout
   KPI blocks are intentionally inside the hero again, but rendered as a clean compact band.
   This overrides older phase rules that made the first KPI larger or pushed KPI cards outside. */
.page-hero,
.report-center-hero,
.report-summary-hero,
.calendar-view-hero,
.leave-calendar-hero,
.approval-studio-hero,
.delegate-page-hero,
.admin-pro-hero,
.qa-hero{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) !important;
  align-items:start !important;
  gap:1rem !important;
  min-height:0 !important;
  padding:1.25rem 1.45rem !important;
  overflow:hidden !important;
}
.page-hero > :not(.hero-kpi-shell),
.report-center-hero > :not(.hero-kpi-shell),
.report-summary-hero > :not(.hero-kpi-shell),
.calendar-view-hero > :not(.hero-kpi-shell),
.leave-calendar-hero > :not(.hero-kpi-shell),
.approval-studio-hero > :not(.hero-kpi-shell),
.delegate-page-hero > :not(.hero-kpi-shell),
.admin-pro-hero > :not(.hero-kpi-shell),
.qa-hero > :not(.hero-kpi-shell){
  min-width:0 !important;
  max-width:100% !important;
  position:relative !important;
  z-index:2 !important;
}
.hero-kpi-shell{
  position:relative !important;
  z-index:2 !important;
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  padding:0 !important;
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(170px,1fr)) !important;
  gap:.75rem !important;
  align-items:stretch !important;
}
.page-hero .hero-kpi-shell,
.report-center-hero .hero-kpi-shell,
.report-summary-hero .hero-kpi-shell,
.calendar-view-hero .hero-kpi-shell,
.leave-calendar-hero .hero-kpi-shell,
.approval-studio-hero .hero-kpi-shell,
.delegate-page-hero .hero-kpi-shell,
.admin-pro-hero .hero-kpi-shell,
.qa-hero .hero-kpi-shell{
  grid-column:1 / -1 !important;
}
.hero-kpi-shell > *,
.hero-kpi-shell .kpi-card,
.hero-kpi-shell .calendar-kpi,
.hero-kpi-shell .report-kpi-card,
.hero-kpi-shell .approval-studio-kpi,
.hero-kpi-shell .delegate-kpi,
.hero-kpi-shell .admin-pro-kpi,
.hero-kpi-shell .qa-kpi,
.hero-kpi-shell.report-summary-kpis > div,
.hero-kpi-shell.leave-calendar-kpis > div{
  width:100% !important;
  max-width:none !important;
  min-width:0 !important;
  min-height:104px !important;
  height:auto !important;
  grid-column:auto !important;
  grid-row:auto !important;
  transform:none !important;
  scale:1 !important;
  display:grid !important;
  align-content:center !important;
  gap:.34rem !important;
  padding:.92rem 1rem !important;
  border:1px solid rgba(255,255,255,.56) !important;
  border-radius:20px !important;
  background:rgba(255,255,255,.93) !important;
  box-shadow:0 14px 32px rgba(6,36,58,.12) !important;
  color:var(--brand-900,#06243a) !important;
  backdrop-filter:blur(10px) !important;
  overflow:hidden !important;
}
.hero-kpi-shell .kpi-card::after{display:none !important;}
.hero-kpi-shell span,
.hero-kpi-shell small,
.hero-kpi-shell .kpi-card span,
.hero-kpi-shell .kpi-card small,
.hero-kpi-shell .calendar-kpi span,
.hero-kpi-shell .calendar-kpi small,
.hero-kpi-shell .report-kpi-card span,
.hero-kpi-shell .report-kpi-card small,
.hero-kpi-shell .approval-studio-kpi span,
.hero-kpi-shell .approval-studio-kpi small,
.hero-kpi-shell .delegate-kpi span,
.hero-kpi-shell .delegate-kpi small,
.hero-kpi-shell .admin-pro-kpi span,
.hero-kpi-shell .admin-pro-kpi small,
.hero-kpi-shell .qa-kpi span,
.hero-kpi-shell .qa-kpi small{
  color:#5f7188 !important;
  font-size:.76rem !important;
  line-height:1.36 !important;
  font-weight:760 !important;
  margin:0 !important;
}
.hero-kpi-shell strong,
.hero-kpi-shell .kpi-card strong,
.hero-kpi-shell .calendar-kpi strong,
.hero-kpi-shell .report-kpi-card strong,
.hero-kpi-shell .approval-studio-kpi strong,
.hero-kpi-shell .delegate-kpi strong,
.hero-kpi-shell .admin-pro-kpi strong,
.hero-kpi-shell .qa-kpi strong{
  color:var(--brand-900,#06243a) !important;
  font-size:1.48rem !important;
  line-height:1.05 !important;
  font-weight:900 !important;
  letter-spacing:-.02em !important;
  margin:0 !important;
}
.hero-kpi-shell .kpi-icon{
  width:34px !important;
  height:34px !important;
  border-radius:13px !important;
  font-size:.72rem !important;
  margin:0 !important;
  background:#eaf7fc !important;
  color:var(--brand-700,#0e7490) !important;
}
.hero-kpi-shell.my-leave-kpi-grid,
.hero-kpi-shell.sla-kpi-grid,
.hero-kpi-shell.vacation-policy-kpi-grid,
.hero-kpi-shell.working-day-kpi-grid,
.hero-kpi-shell.calendar-kpi-strip,
.hero-kpi-shell.report-kpi-grid,
.hero-kpi-shell.report-summary-kpis,
.hero-kpi-shell.delegate-kpi-row,
.hero-kpi-shell.approval-studio-kpis,
.hero-kpi-shell.admin-pro-kpi-grid,
.hero-kpi-shell.qa-kpi-grid,
.hero-kpi-shell.leave-calendar-kpis{
  margin-top:.1rem !important;
}
.page-hero-actions,
.report-center-actions,
.leave-calendar-hero-actions,
.calendar-view-actions,
.approval-studio-hero-actions{
  margin-top:.72rem !important;
}
@media (min-width:1200px){
  .hero-kpi-shell{grid-template-columns:repeat(auto-fit,minmax(175px,1fr)) !important;}
  .dashboard-hero .hero-kpi-shell{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
  .sla-hero .hero-kpi-shell{grid-template-columns:repeat(5,minmax(0,1fr)) !important;}
  .my-leave-hero .hero-kpi-shell,
  .vacation-policy-hero .hero-kpi-shell,
  .working-day-hero .hero-kpi-shell,
  .report-center-hero .hero-kpi-shell,
  .calendar-view-hero .hero-kpi-shell,
  .qa-hero .hero-kpi-shell{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
  .approval-studio-hero .hero-kpi-shell,
  .hr-ref-hero .hero-kpi-shell{grid-template-columns:repeat(3,minmax(0,1fr)) !important;}
}
@media (max-width:900px){
  .hero-kpi-shell{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media (max-width:560px){
  .page-hero,
  .report-center-hero,
  .report-summary-hero,
  .calendar-view-hero,
  .leave-calendar-hero,
  .approval-studio-hero,
  .delegate-page-hero,
  .admin-pro-hero,
  .qa-hero{padding:1rem !important;border-radius:24px !important;}
  .hero-kpi-shell{grid-template-columns:1fr !important;gap:.65rem !important;}
  .hero-kpi-shell > *,
  .hero-kpi-shell .kpi-card,
  .hero-kpi-shell .calendar-kpi,
  .hero-kpi-shell .report-kpi-card,
  .hero-kpi-shell .approval-studio-kpi,
  .hero-kpi-shell .delegate-kpi,
  .hero-kpi-shell .admin-pro-kpi,
  .hero-kpi-shell .qa-kpi,
  .hero-kpi-shell.report-summary-kpis > div,
  .hero-kpi-shell.leave-calendar-kpis > div{min-height:88px !important;padding:.82rem .9rem !important;}
}

/* ========================================================================
   Phase 2.8.17 — Minimal Hero + Separate KPI Summary Section
   Hero must contain only badge, title, short description and essential actions.
   KPI/summary data is rendered as its own section below the hero.
   ======================================================================== */
.page-hero,
.leave-calendar-hero,
.calendar-view-hero,
.report-center-hero,
.report-summary-hero,
.approval-studio-hero,
.delegate-page-hero,
.admin-pro-hero,
.qa-hero,
.health-hero,
.notification-page-hero,
.profile-hero,
.form-hero,
.my-leave-hero,
.my-leave-detail-hero,
.approval-inbox-hero,
.approval-detail-hero,
.sla-hero,
.sla-settings-hero,
.vacation-policy-hero,
.working-day-hero{
  display:block !important;
  min-height:0 !important;
  padding:1.65rem 1.85rem !important;
  border-radius:28px !important;
  border:1px solid rgba(191,222,233,.72) !important;
  background:linear-gradient(135deg,#063a5a 0%,#0a5c8a 52%,#0d8dad 100%) !important;
  color:#fff !important;
  box-shadow:0 18px 44px rgba(6,58,90,.16) !important;
  overflow:hidden !important;
  grid-template-columns:1fr !important;
  align-items:start !important;
  justify-content:start !important;
}
.page-hero::before,.page-hero::after,
.leave-calendar-hero::before,.leave-calendar-hero::after,
.calendar-view-hero::before,.calendar-view-hero::after,
.report-center-hero::before,.report-center-hero::after,
.report-summary-hero::before,.report-summary-hero::after,
.approval-studio-hero::before,.approval-studio-hero::after,
.delegate-page-hero::before,.delegate-page-hero::after,
.admin-pro-hero::before,.admin-pro-hero::after,
.qa-hero::before,.qa-hero::after,
.health-hero::before,.health-hero::after,
.notification-page-hero::before,.notification-page-hero::after,
.profile-hero::before,.profile-hero::after{
  content:none !important;
  display:none !important;
}
.page-hero > div,
.leave-calendar-hero > div,
.calendar-view-hero > div,
.report-center-hero > div,
.report-summary-hero > div,
.approval-studio-hero > div,
.delegate-page-hero > div,
.admin-pro-hero > div,
.qa-hero > div,
.health-hero > div,
.notification-page-hero > div,
.profile-hero > div{
  width:100% !important;
  max-width:860px !important;
  min-width:0 !important;
  position:relative !important;
  z-index:2 !important;
}
.page-hero h1,.page-hero h2,.page-hero h3,
.leave-calendar-hero h1,.leave-calendar-hero h2,.leave-calendar-hero h3,
.calendar-view-hero h1,.calendar-view-hero h2,.calendar-view-hero h3,
.report-center-hero h1,.report-center-hero h2,.report-center-hero h3,
.report-summary-hero h1,.report-summary-hero h2,.report-summary-hero h3,
.approval-studio-hero h1,.approval-studio-hero h2,.approval-studio-hero h3,
.delegate-page-hero h1,.delegate-page-hero h2,.delegate-page-hero h3,
.admin-pro-hero h1,.admin-pro-hero h2,.admin-pro-hero h3,
.qa-hero h1,.qa-hero h2,.qa-hero h3,
.health-hero h1,.health-hero h2,.health-hero h3,
.notification-page-hero h1,.notification-page-hero h2,.notification-page-hero h3,
.profile-hero h1,.profile-hero h2,.profile-hero h3{
  margin:.62rem 0 0 !important;
  color:#fff !important;
  font-size:clamp(1.65rem,2.25vw,2.25rem) !important;
  line-height:1.15 !important;
  font-weight:900 !important;
  letter-spacing:-.035em !important;
}
.page-hero p,
.leave-calendar-hero p,
.calendar-view-hero p,
.report-center-hero p,
.report-summary-hero p,
.approval-studio-hero p,
.delegate-page-hero p,
.admin-pro-hero p,
.qa-hero p,
.health-hero p,
.notification-page-hero p,
.profile-hero p{
  max-width:780px !important;
  margin:.55rem 0 0 !important;
  color:rgba(255,255,255,.88) !important;
  font-size:.95rem !important;
  line-height:1.7 !important;
  font-weight:650 !important;
}
.hero-kicker,.page-kicker,.calendar-view-kicker,.delegate-kicker{
  display:inline-flex !important;
  align-items:center !important;
  width:auto !important;
  max-width:max-content !important;
  padding:.36rem .72rem !important;
  border-radius:999px !important;
  border:1px solid rgba(255,255,255,.32) !important;
  background:rgba(255,255,255,.92) !important;
  color:#075985 !important;
  font-size:.76rem !important;
  line-height:1.2 !important;
  font-weight:850 !important;
}
.page-hero-actions,
.report-center-actions,
.leave-calendar-hero-actions,
.calendar-view-actions,
.approval-studio-hero-actions,
.delegate-hero-actions{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  gap:.65rem !important;
  margin-top:1.05rem !important;
}
.page-hero .btn,
.leave-calendar-hero .btn,
.calendar-view-hero .btn,
.report-center-hero .btn,
.report-summary-hero .btn,
.approval-studio-hero .btn,
.delegate-page-hero .btn,
.admin-pro-hero .btn,
.qa-hero .btn,
.health-hero .btn,
.notification-page-hero .btn,
.profile-hero .btn{
  min-height:42px !important;
  border-radius:12px !important;
  font-weight:850 !important;
}
.page-hero .btn-light,.page-hero .btn-secondary,
.leave-calendar-hero .btn-light,.leave-calendar-hero .btn-secondary,
.calendar-view-hero .btn-light,.calendar-view-hero .btn-secondary,
.report-center-hero .btn-light,.report-center-hero .btn-secondary,
.report-summary-hero .btn-light,.report-summary-hero .btn-secondary,
.approval-studio-hero .btn-light,.approval-studio-hero .btn-secondary,
.delegate-page-hero .btn-light,.delegate-page-hero .btn-secondary,
.admin-pro-hero .btn-light,.admin-pro-hero .btn-secondary,
.qa-hero .btn-light,.qa-hero .btn-secondary,
.health-hero .btn-light,.health-hero .btn-secondary,
.notification-page-hero .btn-light,.notification-page-hero .btn-secondary,
.profile-hero .btn-light,.profile-hero .btn-secondary{
  background:#fff !important;
  color:#075985 !important;
  border-color:rgba(255,255,255,.72) !important;
  box-shadow:0 10px 24px rgba(6,36,58,.12) !important;
}
.page-hero .btn-ghost,
.leave-calendar-hero .btn-ghost,
.calendar-view-hero .btn-ghost,
.report-center-hero .btn-ghost,
.report-summary-hero .btn-ghost,
.approval-studio-hero .btn-ghost,
.delegate-page-hero .btn-ghost,
.admin-pro-hero .btn-ghost,
.qa-hero .btn-ghost,
.health-hero .btn-ghost,
.notification-page-hero .btn-ghost,
.profile-hero .btn-ghost{
  background:rgba(255,255,255,.12) !important;
  color:#fff !important;
  border-color:rgba(255,255,255,.35) !important;
}

.hero-support-section{
  margin-top:.95rem !important;
  margin-bottom:.2rem !important;
  width:100% !important;
}
.hero-support-section .hero-kpi-shell{
  display:grid !important;
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  padding:0 !important;
  gap:.85rem !important;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr)) !important;
  align-items:stretch !important;
}
.hero-support-section .hero-kpi-shell > *,
.hero-support-section .hero-kpi-shell .kpi-card,
.hero-support-section .hero-kpi-shell .calendar-kpi,
.hero-support-section .hero-kpi-shell .report-kpi-card,
.hero-support-section .hero-kpi-shell .approval-studio-kpi,
.hero-support-section .hero-kpi-shell .delegate-kpi,
.hero-support-section .hero-kpi-shell .admin-pro-kpi,
.hero-support-section .hero-kpi-shell .qa-kpi,
.hero-support-section .hero-kpi-shell.report-summary-kpis > div,
.hero-support-section .hero-kpi-shell.leave-calendar-kpis > div{
  display:grid !important;
  align-content:center !important;
  gap:.38rem !important;
  min-height:112px !important;
  height:auto !important;
  width:100% !important;
  min-width:0 !important;
  max-width:none !important;
  grid-column:auto !important;
  grid-row:auto !important;
  transform:none !important;
  scale:1 !important;
  padding:1rem 1.05rem !important;
  border:1px solid #d8e7f2 !important;
  border-radius:20px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f8fcff 100%) !important;
  box-shadow:0 12px 30px rgba(6,36,58,.07) !important;
  color:#0b2b45 !important;
  overflow:hidden !important;
}
.hero-support-section .hero-kpi-shell .kpi-card::after{content:none !important;display:none !important;}
.hero-support-section .hero-kpi-shell span,
.hero-support-section .hero-kpi-shell small,
.hero-support-section .hero-kpi-shell .kpi-card span,
.hero-support-section .hero-kpi-shell .kpi-card small,
.hero-support-section .hero-kpi-shell .calendar-kpi span,
.hero-support-section .hero-kpi-shell .calendar-kpi small,
.hero-support-section .hero-kpi-shell .report-kpi-card span,
.hero-support-section .hero-kpi-shell .report-kpi-card small,
.hero-support-section .hero-kpi-shell .approval-studio-kpi span,
.hero-support-section .hero-kpi-shell .approval-studio-kpi small,
.hero-support-section .hero-kpi-shell .delegate-kpi span,
.hero-support-section .hero-kpi-shell .delegate-kpi small,
.hero-support-section .hero-kpi-shell .admin-pro-kpi span,
.hero-support-section .hero-kpi-shell .admin-pro-kpi small,
.hero-support-section .hero-kpi-shell .qa-kpi span,
.hero-support-section .hero-kpi-shell .qa-kpi small{
  color:#667892 !important;
  font-size:.78rem !important;
  line-height:1.38 !important;
  font-weight:760 !important;
  margin:0 !important;
}
.hero-support-section .hero-kpi-shell strong,
.hero-support-section .hero-kpi-shell .kpi-card strong,
.hero-support-section .hero-kpi-shell .calendar-kpi strong,
.hero-support-section .hero-kpi-shell .report-kpi-card strong,
.hero-support-section .hero-kpi-shell .approval-studio-kpi strong,
.hero-support-section .hero-kpi-shell .delegate-kpi strong,
.hero-support-section .hero-kpi-shell .admin-pro-kpi strong,
.hero-support-section .hero-kpi-shell .qa-kpi strong{
  color:#06243a !important;
  font-size:1.58rem !important;
  line-height:1.04 !important;
  font-weight:900 !important;
  letter-spacing:-.025em !important;
  margin:0 !important;
}
.hero-support-section .hero-kpi-shell .kpi-icon{
  width:36px !important;
  height:36px !important;
  border-radius:14px !important;
  background:#e8f6fb !important;
  color:#0e5d89 !important;
  font-size:.72rem !important;
  font-weight:900 !important;
}
@media (min-width:1200px){
  .hero-support-section .hero-kpi-shell.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
  .hero-support-section .hero-kpi-shell.sla-kpi-grid{grid-template-columns:repeat(5,minmax(0,1fr)) !important;}
  .hero-support-section .hero-kpi-shell.approval-studio-kpis,
  .hero-support-section .hero-kpi-shell.hr-ref-kpi-grid,
  .hero-support-section .hero-kpi-shell.report-summary-kpis{grid-template-columns:repeat(3,minmax(0,1fr)) !important;}
  .hero-support-section .hero-kpi-shell.delegate-kpi-row,
  .hero-support-section .hero-kpi-shell.user-employee-kpi-grid,
  .hero-support-section .hero-kpi-shell.calendar-kpi-strip,
  .hero-support-section .hero-kpi-shell.leave-calendar-kpis,
  .hero-support-section .hero-kpi-shell.qa-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr)) !important;}
}
@media (max-width:900px){
  .page-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .report-center-hero,
  .report-summary-hero,
  .approval-studio-hero,
  .delegate-page-hero,
  .admin-pro-hero,
  .qa-hero,
  .health-hero,
  .notification-page-hero,
  .profile-hero{padding:1.35rem !important;border-radius:24px !important;}
  .hero-support-section .hero-kpi-shell{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media (max-width:560px){
  .page-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .report-center-hero,
  .report-summary-hero,
  .approval-studio-hero,
  .delegate-page-hero,
  .admin-pro-hero,
  .qa-hero,
  .health-hero,
  .notification-page-hero,
  .profile-hero{padding:1.1rem !important;border-radius:22px !important;}
  .page-hero-actions,
  .report-center-actions,
  .leave-calendar-hero-actions,
  .calendar-view-actions,
  .approval-studio-hero-actions,
  .delegate-hero-actions{flex-direction:column !important;align-items:stretch !important;}
  .page-hero-actions .btn,
  .report-center-actions .btn,
  .leave-calendar-hero-actions .btn,
  .calendar-view-actions .btn,
  .approval-studio-hero-actions .btn,
  .delegate-hero-actions .btn,
  .page-hero-actions form,
  .page-hero-actions button{width:100% !important;}
  .hero-support-section .hero-kpi-shell{grid-template-columns:1fr !important;gap:.7rem !important;}
  .hero-support-section .hero-kpi-shell > *,
  .hero-support-section .hero-kpi-shell .kpi-card,
  .hero-support-section .hero-kpi-shell .calendar-kpi,
  .hero-support-section .hero-kpi-shell .report-kpi-card,
  .hero-support-section .hero-kpi-shell .approval-studio-kpi,
  .hero-support-section .hero-kpi-shell .delegate-kpi,
  .hero-support-section .hero-kpi-shell .admin-pro-kpi,
  .hero-support-section .hero-kpi-shell .qa-kpi,
  .hero-support-section .hero-kpi-shell.report-summary-kpis > div,
  .hero-support-section .hero-kpi-shell.leave-calendar-kpis > div{min-height:94px !important;padding:.9rem !important;}
}

/* --------------------------------------------------------------------------
   Phase 2.8.18 — System-wide content/table/card spacing repair
   Scope: align main content with topbar and give every filter/table card
   professional inner spacing. This intentionally overrides older phase rules
   that set filter cards to padding:0 or centered the main content too far away.
   -------------------------------------------------------------------------- */
.app-shell .main-section > .content,
.content{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:clamp(16px,1.45vw,28px) !important;
  gap:clamp(14px,1.1vw,22px) !important;
  align-content:start !important;
}

/* All major data sections must have real inner padding. */
.card,
.soft-card,
.panel,
.summary-box,
.module-card,
.filter-card,
.table-card,
.report-card,
.premium-report-card,
.calendar-list-card,
.calendar-filter-card,
.calendar-control-panel,
.calendar-board-card,
.approval-inbox-card,
.approval-info-card,
.approval-steps-card,
.approval-timeline-card,
.admin-pro-card,
.user-employee-panel,
.user-employee-filter-card,
.report-filter-card,
.profile-card,
.health-card,
.command-card{
  padding:clamp(16px,1.15vw,22px) !important;
  border-radius:24px !important;
  overflow:visible !important;
}

/* Older CSS set filter-card padding to 0. Bring back spacing without breaking custom bars. */
.filter-card,
.search-card,
.user-employee-filter-card,
.report-filter-card,
.sla-filter-card{
  padding:clamp(16px,1.15vw,22px) !important;
  overflow:visible !important;
}
.filter-card > .section-header,
.report-filter-card > .section-header,
.user-employee-filter-card > .section-header,
.search-card > .section-header,
.sla-filter-card > .section-header,
.report-card > .section-header,
.table-card > .section-header,
.premium-report-card > .section-header{
  margin:0 0 16px !important;
  padding:0 0 14px !important;
  border-bottom:1px solid rgba(219,229,240,.92) !important;
}
.filter-card > .section-header h2,
.filter-card > .section-header h3,
.report-card > .section-header h2,
.report-card > .section-header h3,
.table-card > .section-header h2,
.table-card > .section-header h3,
.premium-report-card > .section-header h2,
.premium-report-card > .section-header h3{
  margin:0 !important;
  color:#06243a !important;
  line-height:1.25 !important;
}
.filter-card > .section-header p,
.report-card > .section-header p,
.table-card > .section-header p,
.premium-report-card > .section-header p{
  margin:.28rem 0 0 !important;
  color:#607086 !important;
  line-height:1.55 !important;
}

/* Filter forms should sit inside the card, not touch the border. */
.filter-card form,
.report-filter-card form,
.user-employee-filter-card form,
.search-card form,
.sla-filter-card form{
  margin:0 !important;
}
.filter-bar,
.search-bar,
.search-filter,
.user-employee-filter,
.report-filter-bar,
.sla-filter-bar{
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
}
.report-filter-grid{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:16px !important;
  align-items:end !important;
}
.report-filter-grid .form-group:first-child{
  grid-column:span 2 !important;
}
.report-filter-actions{
  grid-column:1 / -1 !important;
  display:flex !important;
  justify-content:flex-end !important;
  align-items:center !important;
  gap:10px !important;
  margin-top:2px !important;
}

/* Table containers: consistent gutter, safe horizontal scroll, and no clipped radii. */
.table-responsive,
.table-wrap,
.report-table-wrap,
.calendar-list-table{
  width:100% !important;
  max-width:100% !important;
  overflow:auto !important;
  border:1px solid rgba(219,229,240,.95) !important;
  border-radius:20px !important;
  background:#fff !important;
  margin-top:14px !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65) !important;
}
.card > .table-responsive:first-child,
.table-card > .table-responsive:first-child,
.report-card > .table-responsive:first-child,
.premium-report-card > .table-responsive:first-child,
.table-card > .table-wrap:first-child,
.report-card > .table-wrap:first-child{
  margin-top:0 !important;
}
.data-table,
.report-table,
.table-wrap table,
.calendar-list-table table{
  width:100% !important;
  border-collapse:separate !important;
  border-spacing:0 !important;
  min-width:920px;
}
.data-table th,
.report-table th,
.table-wrap th,
.calendar-list-table th{
  padding:13px 14px !important;
  background:#f8fbfd !important;
  border-bottom:1px solid #dbe5f0 !important;
  color:#31445f !important;
  font-size:.78rem !important;
  line-height:1.35 !important;
  font-weight:750 !important;
  white-space:nowrap !important;
}
.data-table td,
.report-table td,
.table-wrap td,
.calendar-list-table td{
  padding:13px 14px !important;
  border-bottom:1px solid #edf3f8 !important;
  color:#334155 !important;
  line-height:1.5 !important;
  vertical-align:top !important;
}
.data-table tr:last-child td,
.report-table tr:last-child td,
.table-wrap tr:last-child td,
.calendar-list-table tr:last-child td{
  border-bottom:0 !important;
}

/* Report summary page: keep hero, KPI, filter and table aligned on the same content rail. */
.report-summary-hero,
.report-center-hero,
.hero-support-section,
.filter-card,
.report-card,
.premium-report-card{
  width:100% !important;
  max-width:none !important;
}
.hero-support-section{
  margin:0 !important;
}
.hero-support-section + .filter-card,
.filter-card + .report-card,
.filter-card + .table-card,
.filter-card + .premium-report-card{
  margin-top:0 !important;
}

@media(max-width:1180px){
  .report-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .report-filter-grid .form-group:first-child{grid-column:1 / -1 !important;}
}
@media(max-width:720px){
  .app-shell .main-section > .content,
  .content{padding:12px !important;gap:12px !important;}
  .card,
  .soft-card,
  .panel,
  .filter-card,
  .table-card,
  .report-card,
  .premium-report-card,
  .calendar-filter-card,
  .calendar-list-card{padding:14px !important;border-radius:20px !important;}
  .report-filter-grid{grid-template-columns:1fr !important;gap:12px !important;}
  .report-filter-actions{flex-direction:column !important;align-items:stretch !important;}
  .report-filter-actions .btn,
  .report-filter-actions a{width:100% !important;}
  .table-responsive,
  .table-wrap,
  .report-table-wrap,
  .calendar-list-table{border-radius:16px !important;margin-top:12px !important;}
  .data-table th,.report-table th,.table-wrap th,.calendar-list-table th,
  .data-table td,.report-table td,.table-wrap td,.calendar-list-table td{padding:11px 12px !important;}
}

/*
 * Phase 2.8.19 — System-wide Responsive Hardening
 * ทำให้ layout ทุกหน้าใช้งานได้จริงบน desktop / tablet / mobile โดยแก้ที่ shell, grid, form, table และ menu กลาง
 * ไม่แตะ business logic, permission หรือ database
 */
:root{
  --responsive-sidebar-w: 286px;
  --responsive-content-x: clamp(14px, 2.1vw, 32px);
  --responsive-content-y: clamp(14px, 1.7vw, 26px);
  --responsive-gap: clamp(14px, 1.45vw, 22px);
  --responsive-card-pad: clamp(16px, 1.45vw, 24px);
  --responsive-hero-pad-x: clamp(22px, 3vw, 46px);
  --responsive-hero-pad-y: clamp(22px, 2.2vw, 34px);
}
html,
body{
  width:100% !important;
  max-width:100% !important;
  overflow-x:hidden !important;
}
img,
svg,
canvas,
video{
  max-width:100% !important;
  height:auto;
}
.app-shell{
  width:100% !important;
  min-height:100dvh !important;
  display:grid !important;
  grid-template-columns:var(--responsive-sidebar-w) minmax(0,1fr) !important;
  align-items:stretch !important;
  overflow:visible !important;
}
.main-section{
  min-width:0 !important;
  width:100% !important;
  display:flex !important;
  flex-direction:column !important;
  background:var(--canvas) !important;
}
.content{
  width:100% !important;
  max-width:none !important;
  min-width:0 !important;
  flex:1 1 auto !important;
  display:grid !important;
  gap:var(--responsive-gap) !important;
  padding:var(--responsive-content-y) var(--responsive-content-x) !important;
  overflow:visible !important;
}
.sidebar{
  position:sticky !important;
  top:0 !important;
  align-self:start !important;
  width:var(--responsive-sidebar-w) !important;
  height:100dvh !important;
  max-height:100dvh !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  z-index:40 !important;
  overscroll-behavior:contain !important;
}
.sidebar .nav,
.nav{
  min-width:0 !important;
}
.nav-group a,
.nav a,
.nav-link{
  min-width:0 !important;
}
.nav-text,
.nav-text strong,
.nav-text small{
  min-width:0 !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
}
.topbar{
  position:sticky !important;
  top:0 !important;
  z-index:35 !important;
  width:100% !important;
  min-width:0 !important;
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  padding:12px var(--responsive-content-x) !important;
  background:rgba(255,255,255,.92) !important;
  backdrop-filter:blur(14px) !important;
  border-bottom:1px solid rgba(219,229,240,.92) !important;
}
.topbar-title-wrap{
  min-width:0 !important;
  flex:1 1 auto !important;
}
.topbar-title-wrap h1{
  min-width:0 !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
}
.topbar-user{
  min-width:0 !important;
  flex:0 1 auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:8px !important;
}
.user-chip,
.topbar-chip{
  max-width:190px !important;
  min-width:0 !important;
}
.user-chip span,
.topbar-chip{
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
}
.notification-dropdown{
  max-width:calc(100vw - 24px) !important;
}

/* Minimal hero: same proportion on every page and safe wrapping. */
.page-hero,
.dashboard-hero,
.form-hero,
.my-leave-hero,
.sla-hero,
.approval-inbox-hero,
.approval-detail-hero,
.delegate-page-hero,
.approval-studio-hero,
.report-center-hero,
.report-summary-hero,
.leave-calendar-hero,
.calendar-view-hero,
.working-day-hero,
.vacation-policy-hero,
.notification-page-hero,
.profile-hero,
.qa-hero,
.health-hero,
.admin-pro-hero{
  width:100% !important;
  max-width:none !important;
  min-width:0 !important;
  display:grid !important;
  grid-template-columns:minmax(0,1fr) !important;
  gap:16px !important;
  padding:var(--responsive-hero-pad-y) var(--responsive-hero-pad-x) !important;
  border-radius:26px !important;
  overflow:hidden !important;
}
.page-hero > *,
.dashboard-hero > *,
.form-hero > *,
.my-leave-hero > *,
.sla-hero > *,
.approval-inbox-hero > *,
.approval-detail-hero > *,
.delegate-page-hero > *,
.approval-studio-hero > *,
.report-center-hero > *,
.report-summary-hero > *,
.leave-calendar-hero > *,
.calendar-view-hero > *,
.working-day-hero > *,
.vacation-policy-hero > *,
.notification-page-hero > *,
.profile-hero > *,
.qa-hero > *,
.health-hero > *,
.admin-pro-hero > *{
  min-width:0 !important;
}
.page-hero h1,
.page-hero h2,
.dashboard-hero h1,
.dashboard-hero h2,
.form-hero h1,
.form-hero h2,
.admin-pro-hero h1,
.admin-pro-hero h2,
.delegate-page-hero h1,
.delegate-page-hero h2,
.approval-studio-hero h1,
.approval-studio-hero h2{
  max-width:100% !important;
  overflow-wrap:anywhere !important;
}
.page-hero p,
.dashboard-hero p,
.form-hero p,
.admin-pro-hero p,
.delegate-page-hero p,
.approval-studio-hero p{
  max-width:min(100%, 940px) !important;
  overflow-wrap:anywhere !important;
}
.page-hero-actions{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  flex-wrap:wrap !important;
  max-width:100% !important;
}

/* Support/KPI sections: responsive equal cards, no first-card emphasis. */
.hero-support-section{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  min-width:0 !important;
}
.hero-kpi-shell,
.kpi-grid,
.my-leave-kpi-grid,
.sla-kpi-grid,
.working-day-kpi-grid,
.vacation-policy-kpi-grid,
.report-kpi-grid,
.calendar-kpi-strip,
.qa-kpi-grid,
.carry-forward-summary-grid,
.report-summary-kpis,
.delegate-kpi-row,
.approval-studio-kpis,
.admin-pro-kpi-grid,
.hr-ref-kpi-grid,
.user-employee-kpi-grid,
.leave-calendar-kpis{
  width:100% !important;
  max-width:100% !important;
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(min(100%, 220px),1fr)) !important;
  gap:14px !important;
  align-items:stretch !important;
  min-width:0 !important;
}
.hero-kpi-shell > *,
.kpi-grid > *,
.my-leave-kpi-grid > *,
.sla-kpi-grid > *,
.working-day-kpi-grid > *,
.vacation-policy-kpi-grid > *,
.report-kpi-grid > *,
.calendar-kpi-strip > *,
.qa-kpi-grid > *,
.carry-forward-summary-grid > *,
.report-summary-kpis > *,
.delegate-kpi-row > *,
.approval-studio-kpis > *,
.admin-pro-kpi-grid > *,
.hr-ref-kpi-grid > *,
.user-employee-kpi-grid > *,
.leave-calendar-kpis > *{
  grid-column:auto !important;
  grid-row:auto !important;
  width:100% !important;
  min-width:0 !important;
  min-height:118px !important;
  max-width:none !important;
}

/* Cards and sections: no clipped content. */
.card,
.soft-card,
.panel,
.form-card,
.filter-card,
.table-card,
.report-card,
.premium-report-card,
.admin-pro-card,
.profile-card,
.health-card,
.delegate-form-card,
.delegate-list-shell,
.approval-info-card,
.approval-steps-card,
.approval-timeline-card,
.calendar-board-card,
.calendar-control-panel,
.user-employee-panel,
.user-employee-card,
.hr-ref-section-clean,
.hr-api-source-card-clean,
.vacation-policy-card,
.working-day-card{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  overflow:visible !important;
}
.section-header{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:14px !important;
  min-width:0 !important;
  flex-wrap:wrap !important;
}
.section-header > *{
  min-width:0 !important;
}
.section-header h1,
.section-header h2,
.section-header h3,
.section-header p{
  max-width:100% !important;
  overflow-wrap:anywhere !important;
}

/* Forms: every filter/form grid collapses predictably. */
form,
.form-grid,
.premium-form-grid,
.compact-form-grid,
.filter-grid,
.report-filter-grid,
.my-leave-filter-grid,
.calendar-filter-grid,
.calendar-filter-card,
.sla-filter-bar,
.user-employee-filter,
.hr-ref-toolbar-clean,
.approval-studio-route-grid,
.approval-step-fields,
.approval-assignment-grid,
.approval-approver-grid,
.delegate-people-panel,
.delegate-scope-grid,
.delegate-condition-grid,
.sla-policy-grid,
.sla-policy-add-form,
.vacation-policy-grid,
.settings-grid-two,
.nested-grid,
.profile-grid,
.detail-grid,
.info-grid,
.approval-info-grid{
  min-width:0 !important;
  max-width:100% !important;
}
.form-grid,
.premium-form-grid,
.compact-form-grid,
.report-filter-grid,
.my-leave-filter-grid,
.approval-studio-route-grid,
.approval-step-fields,
.approval-assignment-grid,
.delegate-scope-grid,
.delegate-condition-grid,
.sla-policy-grid,
.sla-policy-add-form,
.vacation-policy-grid,
.nested-grid,
.profile-grid,
.detail-grid,
.info-grid,
.approval-info-grid{
  display:grid !important;
  grid-template-columns:repeat(12,minmax(0,1fr)) !important;
  gap:14px !important;
}
.form-grid > *,
.premium-form-grid > *,
.compact-form-grid > *,
.report-filter-grid > *,
.my-leave-filter-grid > *,
.approval-studio-route-grid > *,
.approval-step-fields > *,
.approval-assignment-grid > *,
.delegate-scope-grid > *,
.delegate-condition-grid > *,
.sla-policy-grid > *,
.sla-policy-add-form > *,
.vacation-policy-grid > *,
.nested-grid > *,
.profile-grid > *,
.detail-grid > *,
.info-grid > *,
.approval-info-grid > *{
  min-width:0 !important;
}
.form-span-2,
.field-wide,
.full-width,
.form-full,
.form-actions,
.report-filter-actions{
  grid-column:1 / -1 !important;
}
.form-grid > .form-group,
.premium-form-grid > .form-group,
.compact-form-grid > .form-group,
.nested-grid > .form-group,
.report-filter-grid > .form-group,
.my-leave-filter-grid > .form-group,
.approval-studio-route-grid > .form-group,
.approval-step-fields > .form-group,
.approval-assignment-grid > .form-group,
.delegate-scope-grid > .form-group,
.delegate-condition-grid > .form-group,
.sla-policy-grid > .field,
.sla-policy-add-form > .field,
.vacation-policy-grid > .form-group,
.profile-grid > .form-group{
  grid-column:span 6 !important;
}
input,
select,
textarea,
.input,
.select,
.form-control{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
}
input[type="checkbox"],
input[type="radio"]{
  width:auto !important;
  min-width:auto !important;
  max-width:none !important;
}
textarea{
  resize:vertical !important;
}
.leave-system-combobox,
.leave-suggestion-panel,
.leave-suggestion-chip-list{
  max-width:100% !important;
  min-width:0 !important;
}
.leave-suggestion-chip-list{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
}
.leave-suggestion-chip{
  max-width:100% !important;
  white-space:normal !important;
  text-align:left !important;
}
.leave-duration-options,
.leave-duration-extra{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
}

/* Tables: only table container scrolls horizontally, not the whole page. */
.table-responsive,
.table-wrap,
.report-table-wrap,
.calendar-list-table,
.table-container{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  overflow-x:auto !important;
  overflow-y:visible !important;
  -webkit-overflow-scrolling:touch !important;
  overscroll-behavior-x:contain !important;
}
.table-responsive table,
.table-wrap table,
.report-table-wrap table,
.calendar-list-table table,
.table-container table,
.data-table,
.report-table{
  width:100% !important;
  min-width:860px !important;
}
.table-responsive td,
.table-wrap td,
.report-table-wrap td,
.calendar-list-table td,
.table-responsive th,
.table-wrap th,
.report-table-wrap th,
.calendar-list-table th{
  max-width:340px !important;
  overflow-wrap:anywhere !important;
}

/* Page-specific responsive grids. */
.dashboard-layout,
.settings-grid-two,
.approval-detail-grid,
.my-leave-detail-grid,
.report-center-grid,
.report-card-grid,
.delegate-workspace,
.approval-studio-layout,
.hr-ref-grid,
.hr-ref-grid-clean,
.user-employee-grid,
.health-grid,
.qa-grid{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(min(100%, 360px),1fr)) !important;
  gap:var(--responsive-gap) !important;
}
.approval-studio-layout{
  grid-template-columns:minmax(260px,.36fr) minmax(0,1fr) !important;
}
.approval-studio-sidebar,
.approval-studio-main,
.delegate-workspace > *,
.dashboard-layout > *,
.settings-grid-two > *{
  min-width:0 !important;
}
.sla-filter-bar{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:14px !important;
}
.sla-task-item,
.dashboard-sla-row{
  min-width:0 !important;
}
.calendar-grid-v2,
.leave-calendar-grid{
  max-width:100% !important;
}
.calendar-grid-v2{
  overflow-x:auto !important;
  -webkit-overflow-scrolling:touch !important;
}
.calendar-grid-v2[role="table"]{
  grid-template-columns:repeat(7,minmax(118px,1fr)) !important;
}
.leave-calendar-grid{
  grid-template-columns:repeat(7,minmax(118px,1fr)) !important;
  overflow-x:auto !important;
}

@media(max-width:1280px){
  :root{--responsive-sidebar-w:270px;--responsive-content-x:18px;}
  .approval-studio-layout{grid-template-columns:1fr !important;}
  .approval-studio-sidebar{position:relative !important;top:auto !important;max-height:none !important;}
  .report-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .sla-filter-bar{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}

@media(max-width:1024px){
  .app-shell{
    display:block !important;
    min-height:100dvh !important;
  }
  .icon-btn{
    display:grid !important;
    flex:0 0 auto !important;
  }
  .sidebar{
    position:fixed !important;
    inset:0 auto 0 0 !important;
    width:min(86vw, 330px) !important;
    height:100dvh !important;
    max-height:100dvh !important;
    transform:translateX(-105%) !important;
    transition:transform .22s ease !important;
    box-shadow:24px 0 70px rgba(6,36,58,.24) !important;
    background:#fff !important;
    z-index:80 !important;
  }
  .sidebar.is-open,
  body.sidebar-open .sidebar{
    transform:translateX(0) !important;
  }
  body.sidebar-open{
    overflow:hidden !important;
  }
  body.sidebar-open::before{
    content:"" !important;
    position:fixed !important;
    inset:0 !important;
    z-index:70 !important;
    background:rgba(3,26,45,.42) !important;
    backdrop-filter:blur(3px) !important;
  }
  .main-section{
    min-height:100dvh !important;
  }
  .topbar{
    min-height:64px !important;
  }
  .topbar-user{
    overflow-x:auto !important;
    scrollbar-width:none !important;
  }
  .topbar-user::-webkit-scrollbar{display:none !important;}
  .topbar-user form .btn,
  .topbar-chip{
    display:none !important;
  }
  .page-hero,
  .dashboard-hero,
  .form-hero,
  .my-leave-hero,
  .sla-hero,
  .approval-inbox-hero,
  .approval-detail-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .report-center-hero,
  .report-summary-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .working-day-hero,
  .vacation-policy-hero,
  .notification-page-hero,
  .profile-hero,
  .qa-hero,
  .health-hero,
  .admin-pro-hero{
    border-radius:22px !important;
  }
  .form-grid > .form-group,
  .premium-form-grid > .form-group,
  .compact-form-grid > .form-group,
  .nested-grid > .form-group,
  .report-filter-grid > .form-group,
  .my-leave-filter-grid > .form-group,
  .approval-studio-route-grid > .form-group,
  .approval-step-fields > .form-group,
  .approval-assignment-grid > .form-group,
  .delegate-scope-grid > .form-group,
  .delegate-condition-grid > .form-group,
  .sla-policy-grid > .field,
  .sla-policy-add-form > .field,
  .vacation-policy-grid > .form-group,
  .profile-grid > .form-group{
    grid-column:1 / -1 !important;
  }
}

@media(max-width:760px){
  :root{
    --responsive-content-x:12px;
    --responsive-content-y:12px;
    --responsive-gap:12px;
    --responsive-card-pad:14px;
    --responsive-hero-pad-x:18px;
    --responsive-hero-pad-y:18px;
  }
  body{font-size:14px !important;}
  .content{padding:12px !important;gap:12px !important;}
  .topbar{padding:9px 12px !important;min-height:58px !important;}
  .topbar-title-wrap h1{font-size:1rem !important;}
  .user-chip{max-width:46px !important;padding:4px !important;}
  .user-chip span{display:none !important;}
  .notification-dropdown{right:-52px !important;width:calc(100vw - 18px) !important;}
  .page-hero,
  .dashboard-hero,
  .form-hero,
  .my-leave-hero,
  .sla-hero,
  .approval-inbox-hero,
  .approval-detail-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .report-center-hero,
  .report-summary-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .working-day-hero,
  .vacation-policy-hero,
  .notification-page-hero,
  .profile-hero,
  .qa-hero,
  .health-hero,
  .admin-pro-hero{
    padding:18px !important;
    border-radius:20px !important;
  }
  .page-hero h1,
  .page-hero h2,
  .dashboard-hero h1,
  .dashboard-hero h2,
  .form-hero h1,
  .form-hero h2{
    font-size:clamp(1.38rem, 7vw, 1.9rem) !important;
    line-height:1.18 !important;
  }
  .page-hero p,
  .dashboard-hero p,
  .form-hero p{
    font-size:.88rem !important;
    line-height:1.65 !important;
  }
  .page-hero-actions,
  .button-row,
  .form-actions,
  .report-filter-actions,
  .filter-actions{
    width:100% !important;
    display:grid !important;
    grid-template-columns:1fr !important;
    align-items:stretch !important;
    gap:9px !important;
  }
  .page-hero-actions .btn,
  .page-hero-actions .button,
  .button-row .btn,
  .button-row .button,
  .form-actions .btn,
  .form-actions .button,
  .report-filter-actions .btn,
  .report-filter-actions .button,
  .filter-actions .btn,
  .filter-actions .button{
    width:100% !important;
  }
  .card,
  .soft-card,
  .panel,
  .form-card,
  .filter-card,
  .table-card,
  .report-card,
  .premium-report-card,
  .admin-pro-card,
  .profile-card,
  .health-card,
  .delegate-form-card,
  .delegate-list-shell,
  .approval-info-card,
  .approval-steps-card,
  .approval-timeline-card,
  .calendar-board-card,
  .calendar-control-panel,
  .user-employee-panel,
  .user-employee-card,
  .hr-ref-section-clean,
  .hr-api-source-card-clean,
  .vacation-policy-card,
  .working-day-card{
    padding:14px !important;
    border-radius:18px !important;
  }
  .hero-kpi-shell,
  .kpi-grid,
  .my-leave-kpi-grid,
  .sla-kpi-grid,
  .working-day-kpi-grid,
  .vacation-policy-kpi-grid,
  .report-kpi-grid,
  .calendar-kpi-strip,
  .qa-kpi-grid,
  .carry-forward-summary-grid,
  .report-summary-kpis,
  .delegate-kpi-row,
  .approval-studio-kpis,
  .admin-pro-kpi-grid,
  .hr-ref-kpi-grid,
  .user-employee-kpi-grid,
  .leave-calendar-kpis{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .hero-kpi-shell > *,
  .kpi-grid > *,
  .my-leave-kpi-grid > *,
  .sla-kpi-grid > *,
  .working-day-kpi-grid > *,
  .vacation-policy-kpi-grid > *,
  .report-kpi-grid > *,
  .calendar-kpi-strip > *,
  .qa-kpi-grid > *,
  .carry-forward-summary-grid > *,
  .report-summary-kpis > *,
  .delegate-kpi-row > *,
  .approval-studio-kpis > *,
  .admin-pro-kpi-grid > *,
  .hr-ref-kpi-grid > *,
  .user-employee-kpi-grid > *,
  .leave-calendar-kpis > *{
    min-height:auto !important;
  }
  .form-grid,
  .premium-form-grid,
  .compact-form-grid,
  .report-filter-grid,
  .my-leave-filter-grid,
  .approval-studio-route-grid,
  .approval-step-fields,
  .approval-assignment-grid,
  .delegate-scope-grid,
  .delegate-condition-grid,
  .sla-policy-grid,
  .sla-policy-add-form,
  .vacation-policy-grid,
  .nested-grid,
  .profile-grid,
  .detail-grid,
  .info-grid,
  .approval-info-grid{
    grid-template-columns:1fr !important;
    gap:11px !important;
  }
  .form-grid > *,
  .premium-form-grid > *,
  .compact-form-grid > *,
  .report-filter-grid > *,
  .my-leave-filter-grid > *,
  .approval-studio-route-grid > *,
  .approval-step-fields > *,
  .approval-assignment-grid > *,
  .delegate-scope-grid > *,
  .delegate-condition-grid > *,
  .sla-policy-grid > *,
  .sla-policy-add-form > *,
  .vacation-policy-grid > *,
  .nested-grid > *,
  .profile-grid > *,
  .detail-grid > *,
  .info-grid > *,
  .approval-info-grid > *{
    grid-column:1 / -1 !important;
  }
  input,
  select,
  textarea,
  .input,
  .select,
  .form-control{
    min-height:44px !important;
    font-size:16px !important;
  }
  .table-responsive table,
  .table-wrap table,
  .report-table-wrap table,
  .calendar-list-table table,
  .table-container table,
  .data-table,
  .report-table{
    min-width:760px !important;
  }
  .sla-filter-bar{
    grid-template-columns:1fr !important;
    padding:14px !important;
  }
  .sla-task-item,
  .dashboard-sla-row,
  .delegate-row-card,
  .user-employee-card,
  .hr-ref-card-summary-pro{
    grid-template-columns:1fr !important;
  }
  .calendar-grid-v2[role="table"],
  .leave-calendar-grid{
    grid-template-columns:repeat(7, minmax(108px, 1fr)) !important;
    min-width:760px !important;
  }
}

@media(max-width:430px){
  .content{padding:10px !important;}
  .page-hero,
  .dashboard-hero,
  .form-hero,
  .my-leave-hero,
  .sla-hero,
  .approval-inbox-hero,
  .approval-detail-hero,
  .delegate-page-hero,
  .approval-studio-hero,
  .report-center-hero,
  .report-summary-hero,
  .leave-calendar-hero,
  .calendar-view-hero,
  .working-day-hero,
  .vacation-policy-hero,
  .notification-page-hero,
  .profile-hero,
  .qa-hero,
  .health-hero,
  .admin-pro-hero{
    padding:16px !important;
    border-radius:18px !important;
  }
  .hero-kicker{font-size:.72rem !important;}
  .card,
  .filter-card,
  .table-card,
  .report-card,
  .premium-report-card,
  .admin-pro-card,
  .form-card{
    padding:12px !important;
    border-radius:16px !important;
  }
  .table-responsive th,
  .table-responsive td,
  .table-wrap th,
  .table-wrap td,
  .report-table-wrap th,
  .report-table-wrap td{
    padding:10px !important;
  }
}

@media print{
  .sidebar,
  .topbar,
  .no-print,
  .page-hero-actions,
  .hero-support-section{display:none !important;}
  .app-shell{display:block !important;}
  .content{padding:0 !important;display:block !important;background:#fff !important;}
  .page-hero{box-shadow:none !important;background:#fff !important;color:#000 !important;border:0 !important;padding:0 0 12px !important;}
  .table-responsive,.table-wrap{overflow:visible !important;border:0 !important;box-shadow:none !important;}
  .table-responsive table,.table-wrap table,.data-table,.report-table{min-width:0 !important;}
}


/*
 * Phase 2.8.20 — Sidebar Full-height Rail Repair
 * แก้สาเหตุเมนูซ้ายดูจบสั้นเมื่อ content กลางยาวกว่า viewport
 * ใช้ background rail จาก app-shell ให้สูงตามความสูงจริงของหน้า และคง sidebar เป็น sticky scroll เฉพาะเมนู
 */
@media (min-width:1025px){
  .app-shell{
    position:relative !important;
    isolation:isolate !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    align-items:stretch !important;
    background:linear-gradient(90deg, rgba(247,251,253,.98) 0, rgba(247,251,253,.98) var(--responsive-sidebar-w,286px), transparent var(--responsive-sidebar-w,286px)) !important;
  }
  .app-shell::before{
    content:"" !important;
    position:absolute !important;
    inset:0 auto 0 0 !important;
    width:var(--responsive-sidebar-w,286px) !important;
    min-height:100% !important;
    background:linear-gradient(180deg, rgba(255,255,255,.97) 0%, rgba(247,251,253,.96) 100%) !important;
    border-right:1px solid rgba(219,229,240,.92) !important;
    box-shadow:10px 0 34px rgba(6,36,58,.045) !important;
    pointer-events:none !important;
    z-index:0 !important;
  }
  .sidebar{
    position:sticky !important;
    top:0 !important;
    align-self:start !important;
    width:var(--responsive-sidebar-w,286px) !important;
    height:100vh !important;
    height:100dvh !important;
    max-height:100vh !important;
    max-height:100dvh !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    overflow-y:auto !important;
    overflow-x:hidden !important;
    background:transparent !important;
    border-right:0 !important;
    box-shadow:none !important;
    z-index:2 !important;
  }
  .main-section{
    position:relative !important;
    z-index:1 !important;
    min-height:100vh !important;
    min-height:100dvh !important;
  }
}

@media (max-width:1024px){
  .app-shell{
    background:transparent !important;
  }
  .app-shell::before{
    display:none !important;
  }
}

/*
 * Phase 2.8.21 — Sidebar Rail Stretch Hard Fix
 * แก้จริงจุดเมนูซ้ายดูไม่เต็มเมื่อหน้าเนื้อหายาว: แยก rail พื้นหลังออกจาก scroll/height ของ sidebar
 * Desktop: rail ขาวอยู่เต็ม viewport เสมอ และ sidebar item ยืดตามความสูงเอกสารโดยไม่ถูกจำกัดแค่ 100dvh
 */
@media (min-width:1025px){
  :root{
    --responsive-sidebar-w:286px;
    --sidebar-rail-bg-start:rgba(255,255,255,.985);
    --sidebar-rail-bg-end:rgba(247,251,253,.965);
    --sidebar-rail-border:rgba(219,229,240,.92);
  }
  html,
  body,
  .app-body{
    min-height:100% !important;
  }
  body.app-body::before{
    content:"" !important;
    position:fixed !important;
    top:0 !important;
    left:0 !important;
    bottom:0 !important;
    width:var(--responsive-sidebar-w) !important;
    background:linear-gradient(180deg,var(--sidebar-rail-bg-start) 0%,var(--sidebar-rail-bg-end) 100%) !important;
    border-right:1px solid var(--sidebar-rail-border) !important;
    box-shadow:10px 0 34px rgba(6,36,58,.045) !important;
    pointer-events:none !important;
    z-index:0 !important;
  }
  .app-shell{
    position:relative !important;
    z-index:1 !important;
    isolation:auto !important;
    display:grid !important;
    grid-template-columns:var(--responsive-sidebar-w) minmax(0,1fr) !important;
    align-items:stretch !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    background:transparent !important;
    overflow:visible !important;
  }
  .app-shell::before{
    content:"" !important;
    position:absolute !important;
    inset:0 auto 0 0 !important;
    width:var(--responsive-sidebar-w) !important;
    min-height:100% !important;
    background:linear-gradient(180deg,var(--sidebar-rail-bg-start) 0%,var(--sidebar-rail-bg-end) 100%) !important;
    border-right:1px solid var(--sidebar-rail-border) !important;
    box-shadow:10px 0 34px rgba(6,36,58,.045) !important;
    pointer-events:none !important;
    z-index:0 !important;
  }
  .sidebar{
    position:relative !important;
    top:auto !important;
    align-self:stretch !important;
    width:var(--responsive-sidebar-w) !important;
    height:auto !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    max-height:none !important;
    overflow:visible !important;
    overscroll-behavior:auto !important;
    background:transparent !important;
    border-right:0 !important;
    box-shadow:none !important;
    z-index:2 !important;
  }
  .sidebar-glow{
    position:absolute !important;
    z-index:-1 !important;
  }
  .sidebar .nav{
    padding-bottom:24px !important;
  }
  .main-section{
    position:relative !important;
    z-index:1 !important;
    min-width:0 !important;
    min-height:100vh !important;
    min-height:100dvh !important;
    background:var(--canvas) !important;
  }
}

@media (min-width:1025px) and (max-width:1280px){
  :root{--responsive-sidebar-w:270px;}
}

@media (max-width:1024px){
  body.app-body::before,
  .app-shell::before{
    display:none !important;
  }
}

/*
 * Phase 2.8.22 — Mobile Sidebar Close Button + Mobile Table Cards
 * Scope: UI only. Adds an explicit close affordance to the mobile sidebar and converts data tables to readable cards on small screens.
 */
.sr-only{
  position:absolute !important;
  width:1px !important;
  height:1px !important;
  padding:0 !important;
  margin:-1px !important;
  overflow:hidden !important;
  clip:rect(0,0,0,0) !important;
  white-space:nowrap !important;
  border:0 !important;
}
.sidebar-mobile-head,
.sidebar-backdrop{
  display:none;
}
@media (max-width:1024px){
  .sidebar{
    z-index:92 !important;
    padding-top:0 !important;
  }
  .sidebar-mobile-head{
    position:sticky !important;
    top:0 !important;
    z-index:6 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:12px !important;
    margin:-1.05rem -1.05rem 14px !important;
    padding:15px 16px !important;
    background:rgba(255,255,255,.96) !important;
    backdrop-filter:blur(12px) !important;
    border-bottom:1px solid rgba(219,229,240,.95) !important;
    box-shadow:0 12px 26px rgba(6,36,58,.055) !important;
  }
  .sidebar-mobile-head strong{
    display:block !important;
    color:var(--ink,#06243a) !important;
    font-size:16px !important;
    font-weight:700 !important;
    line-height:1.25 !important;
  }
  .sidebar-mobile-head small{
    display:block !important;
    margin-top:2px !important;
    color:var(--muted,#64748b) !important;
    font-size:12px !important;
    font-weight:500 !important;
    line-height:1.25 !important;
  }
  .sidebar-close-button{
    width:42px !important;
    height:42px !important;
    flex:0 0 42px !important;
    display:grid !important;
    place-items:center !important;
    border:1px solid rgba(191,208,229,.95) !important;
    border-radius:16px !important;
    background:linear-gradient(180deg,#fff 0%,#f7fbfd 100%) !important;
    color:#0b4664 !important;
    font-size:26px !important;
    font-weight:700 !important;
    line-height:1 !important;
    box-shadow:0 10px 24px rgba(6,36,58,.085) !important;
    cursor:pointer !important;
  }
  .sidebar-close-button:hover,
  .sidebar-close-button:focus-visible{
    border-color:rgba(13,127,168,.55) !important;
    box-shadow:0 0 0 4px rgba(13,127,168,.13),0 10px 24px rgba(6,36,58,.085) !important;
    outline:0 !important;
  }
  .sidebar-backdrop{
    position:fixed !important;
    inset:0 !important;
    z-index:74 !important;
    width:100vw !important;
    height:100dvh !important;
    padding:0 !important;
    border:0 !important;
    background:rgba(3,26,45,.42) !important;
    backdrop-filter:blur(3px) !important;
    opacity:0 !important;
    pointer-events:none !important;
    transition:opacity .18s ease !important;
  }
  body.sidebar-open .sidebar-backdrop{
    display:block !important;
    opacity:1 !important;
    pointer-events:auto !important;
  }
  body.sidebar-open::before{
    display:none !important;
    content:none !important;
  }
}
@media (min-width:1025px){
  .sidebar-mobile-head,
  .sidebar-backdrop{
    display:none !important;
  }
}

@media (max-width:760px){
  .table-responsive,
  .table-wrap,
  .calendar-list-table,
  .qa-meta-table{
    width:100% !important;
    overflow:visible !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
  }
  .table-responsive.mobile-card-ready,
  .table-wrap.mobile-card-ready{
    padding:0 !important;
  }
  table.mobile-card-table{
    display:block !important;
    width:100% !important;
    min-width:0 !important;
    border:0 !important;
    border-collapse:separate !important;
    border-spacing:0 !important;
    background:transparent !important;
  }
  table.mobile-card-table thead,
  table.mobile-card-table tfoot{
    display:none !important;
  }
  table.mobile-card-table tbody{
    display:grid !important;
    width:100% !important;
    gap:12px !important;
  }
  table.mobile-card-table tr{
    display:grid !important;
    width:100% !important;
    gap:9px !important;
    padding:14px !important;
    border:1px solid rgba(191,208,229,.88) !important;
    border-radius:20px !important;
    background:rgba(255,255,255,.96) !important;
    box-shadow:0 12px 26px rgba(6,36,58,.065) !important;
  }
  table.mobile-card-table tr:hover td{
    background:transparent !important;
  }
  table.mobile-card-table td{
    display:grid !important;
    grid-template-columns:minmax(112px,38%) minmax(0,1fr) !important;
    align-items:start !important;
    gap:10px !important;
    width:100% !important;
    min-width:0 !important;
    min-height:26px !important;
    padding:0 !important;
    border:0 !important;
    background:transparent !important;
    color:#1e3a56 !important;
    font-size:14px !important;
    font-weight:600 !important;
    line-height:1.45 !important;
    word-break:break-word !important;
    overflow-wrap:anywhere !important;
  }
  table.mobile-card-table td + td{
    padding-top:8px !important;
    border-top:1px solid rgba(226,232,240,.82) !important;
  }
  table.mobile-card-table td::before{
    content:attr(data-cell-label) !important;
    color:#64748b !important;
    font-size:12px !important;
    font-weight:700 !important;
    line-height:1.35 !important;
    word-break:normal !important;
    overflow-wrap:normal !important;
  }
  table.mobile-card-table td:not([data-cell-label]),
  table.mobile-card-table td[data-cell-label=""],
  table.mobile-card-table td.mobile-card-full{
    grid-template-columns:1fr !important;
  }
  table.mobile-card-table td:not([data-cell-label])::before,
  table.mobile-card-table td[data-cell-label=""]::before,
  table.mobile-card-table td.mobile-card-full::before{
    display:none !important;
    content:"" !important;
  }
  table.mobile-card-table td.no-print,
  table.mobile-card-table th.no-print{
    display:none !important;
  }
  table.mobile-card-table .empty,
  table.mobile-card-table td[colspan]{
    display:block !important;
    text-align:center !important;
    padding:18px 10px !important;
    color:#64748b !important;
  }
  table.mobile-card-table td .btn,
  table.mobile-card-table td .button,
  table.mobile-card-table td button,
  table.mobile-card-table td form{
    max-width:100% !important;
  }
  table.mobile-card-table td form{
    display:block !important;
  }
  table.mobile-card-table td .btn,
  table.mobile-card-table td .button{
    width:100% !important;
    justify-content:center !important;
  }
  .table-card .section-header,
  .report-card .section-header,
  .premium-report-card .section-header{
    margin-bottom:12px !important;
  }
}
@media (max-width:430px){
  table.mobile-card-table tr{
    padding:12px !important;
    border-radius:18px !important;
  }
  table.mobile-card-table td{
    grid-template-columns:1fr !important;
    gap:3px !important;
    font-size:14px !important;
  }
  table.mobile-card-table td::before{
    font-size:11.5px !important;
  }
}

/* Phase 2.8.23 — Dashboard Analytics Chart Rebuild */
.dashboard-summary-section{margin-top:1.1rem!important;margin-bottom:1.1rem!important}.dashboard-summary-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important}.dashboard-chart-studio{display:grid!important;grid-template-columns:minmax(360px,1fr) minmax(360px,1.15fr)!important;gap:1rem!important;margin:1rem 0 1.1rem!important}.dashboard-chart-card{position:relative!important;overflow:hidden!important;min-height:340px!important;padding:1.25rem!important;border-radius:28px!important;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,252,255,.94))!important;border:1px solid rgba(191,208,229,.92)!important;box-shadow:0 18px 42px rgba(6,36,58,.08)!important}.dashboard-chart-card::after{content:"";position:absolute;right:-70px;top:-70px;width:190px;height:190px;border-radius:999px;background:radial-gradient(circle,rgba(13,127,168,.12),rgba(13,127,168,0) 68%);pointer-events:none}.dashboard-chart-card>*{position:relative;z-index:1}.dashboard-chart-card-status,.dashboard-chart-card-types{min-height:380px!important}.dashboard-card-head{display:flex!important;align-items:flex-start!important;justify-content:space-between!important;gap:1rem!important;margin-bottom:1.1rem!important}.dashboard-card-head h2{margin:.18rem 0 0!important;color:var(--brand-900,#063a5a)!important;font-size:1.18rem!important;line-height:1.22!important;font-weight:1000!important;letter-spacing:-.025em!important}.dashboard-card-head>strong{display:grid!important;place-items:center!important;min-width:62px!important;height:46px!important;padding:0 .75rem!important;border-radius:16px!important;background:rgba(13,127,168,.09)!important;color:var(--brand-800,#0b5f85)!important;font-size:1.35rem!important;font-weight:1000!important;border:1px solid rgba(13,127,168,.14)!important}.dashboard-eyebrow{display:inline-flex!important;align-items:center!important;width:max-content!important;padding:.28rem .65rem!important;border-radius:999px!important;background:rgba(13,127,168,.09)!important;color:var(--brand-800,#0b5f85)!important;font-size:.72rem!important;font-weight:1000!important;letter-spacing:.01em!important}.dashboard-donut-layout{display:grid!important;grid-template-columns:190px minmax(0,1fr)!important;align-items:center!important;gap:1.2rem!important}.dashboard-donut{width:188px!important;height:188px!important;border-radius:999px!important;display:grid!important;place-items:center!important;box-shadow:inset 0 0 0 1px rgba(255,255,255,.5),0 18px 34px rgba(6,36,58,.11)!important}.dashboard-donut::before{content:"";position:absolute;width:118px;height:118px;border-radius:999px;background:#fff;box-shadow:inset 0 0 0 1px rgba(219,229,240,.95)}.dashboard-donut{position:relative!important}.dashboard-donut span{position:relative!important;z-index:1!important;display:grid!important;place-items:center!important;color:var(--brand-900,#063a5a)!important;font-weight:1000!important;font-size:2rem!important;line-height:1!important}.dashboard-donut small{display:block!important;margin-top:.25rem!important;color:#64748b!important;font-size:.72rem!important;font-weight:850!important}.dashboard-chart-legend{display:grid!important;gap:.55rem!important}.dashboard-legend-row{display:grid!important;grid-template-columns:14px minmax(0,1fr) auto auto!important;align-items:center!important;gap:.55rem!important;padding:.62rem .7rem!important;border:1px solid rgba(219,229,240,.86)!important;border-radius:15px!important;background:rgba(255,255,255,.76)!important}.dashboard-legend-row i{width:12px!important;height:12px!important;border-radius:999px!important;box-shadow:0 0 0 3px rgba(255,255,255,.9)!important}.dashboard-legend-row span{min-width:0!important;color:#31506b!important;font-weight:850!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.dashboard-legend-row b{color:var(--brand-900,#063a5a)!important;font-weight:1000!important}.dashboard-legend-row small{color:#64748b!important;font-weight:850!important}.dashboard-column-chart{height:258px!important;display:grid!important;grid-template-columns:repeat(6,minmax(0,1fr))!important;gap:.72rem!important;align-items:end!important;padding:.35rem .2rem 0!important}.dashboard-column-item{height:100%!important;display:grid!important;grid-template-rows:26px minmax(0,1fr) 38px!important;align-items:end!important;gap:.45rem!important;text-align:center!important;min-width:0!important}.dashboard-column-item>b{color:var(--brand-900,#063a5a)!important;font-size:.95rem!important;font-weight:1000!important}.dashboard-column-item small{align-self:start!important;color:#64748b!important;font-size:.72rem!important;font-weight:850!important;line-height:1.2!important}.dashboard-column-track{height:100%!important;min-height:150px!important;border-radius:18px!important;background:linear-gradient(180deg,rgba(13,127,168,.07),rgba(13,127,168,.035))!important;border:1px solid rgba(191,208,229,.78)!important;display:flex!important;align-items:flex-end!important;overflow:hidden!important}.dashboard-column-track i{display:block!important;width:100%!important;min-height:8px!important;border-radius:16px 16px 0 0!important;background:linear-gradient(180deg,#16b7d6,#0d7fa8 68%,#075d84)!important;box-shadow:0 -10px 20px rgba(13,127,168,.17)!important}.dashboard-bar-list{display:grid!important;gap:.9rem!important}.dashboard-bar-row{display:grid!important;gap:.42rem!important}.dashboard-bar-meta{display:flex!important;align-items:baseline!important;justify-content:space-between!important;gap:.8rem!important}.dashboard-bar-meta span{min-width:0!important;color:#1f3f59!important;font-weight:950!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.dashboard-bar-meta b{white-space:nowrap!important;color:var(--brand-800,#0b5f85)!important;font-size:.85rem!important;font-weight:1000!important}.dashboard-bar-track{height:12px!important;border-radius:999px!important;background:rgba(13,127,168,.08)!important;border:1px solid rgba(191,208,229,.75)!important;overflow:hidden!important}.dashboard-bar-track i{display:block!important;height:100%!important;min-width:7px!important;border-radius:999px!important;background:linear-gradient(90deg,#075d84,#16b7d6)!important}.dashboard-bar-row small{color:#64748b!important;font-weight:800!important}.dashboard-empty-mini{display:grid!important;place-items:center!important;min-height:180px!important;border:1px dashed rgba(148,163,184,.5)!important;border-radius:20px!important;color:#64748b!important;font-weight:850!important;background:rgba(248,250,252,.75)!important}.dashboard-sla-chart-list{display:grid!important;gap:.85rem!important}.dashboard-sla-chart-row{display:grid!important;grid-template-columns:minmax(0,1fr) auto!important;gap:.45rem .75rem!important;align-items:center!important;padding:.75rem!important;border:1px solid rgba(219,229,240,.86)!important;border-radius:16px!important;background:rgba(255,255,255,.74)!important}.dashboard-sla-chart-row span{color:#31506b!important;font-weight:900!important}.dashboard-sla-chart-row strong{color:var(--brand-900,#063a5a)!important;font-size:1.15rem!important;font-weight:1000!important}.dashboard-sla-chart-row i{grid-column:1/-1!important;height:10px!important;border-radius:999px!important;background:rgba(13,127,168,.08)!important;overflow:hidden!important}.dashboard-sla-chart-row em{display:block!important;height:100%!important;min-width:6px!important;border-radius:999px!important;background:#0d7fa8!important}.dashboard-sla-chart-overdue em,.dashboard-sla-chart-escalated em{background:#ef4444!important}.dashboard-sla-chart-warning em{background:#f59e0b!important}.dashboard-sla-chart-normal em{background:#16a34a!important}.dashboard-action-layout{display:grid!important;grid-template-columns:minmax(0,1.1fr) minmax(330px,.9fr)!important;gap:1rem!important;margin:1rem 0!important}.dashboard-process-card,.dashboard-quick-card,.dashboard-sla-panel,.dashboard-recent-card{border-radius:28px!important}.dashboard-quick-card .quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))!important}.dashboard-quick-card .quick-actions a{min-height:104px!important}.dashboard-sla-panel{margin-top:1rem!important}.dashboard-recent-card{margin-top:1rem!important}
@media(max-width:1280px){.dashboard-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))!important}.dashboard-chart-studio{grid-template-columns:1fr!important}.dashboard-chart-card{min-height:auto!important}.dashboard-action-layout{grid-template-columns:1fr!important}.dashboard-quick-card .quick-actions{grid-template-columns:repeat(3,minmax(0,1fr))!important}}
@media(max-width:900px){.dashboard-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.dashboard-donut-layout{grid-template-columns:1fr!important;justify-items:center!important}.dashboard-chart-legend{width:100%!important}.dashboard-column-chart{overflow-x:auto!important;grid-template-columns:repeat(6,minmax(86px,1fr))!important;padding-bottom:.45rem!important}.dashboard-quick-card .quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))!important}.dashboard-card-head{flex-direction:column!important}.dashboard-card-head>strong{align-self:flex-start!important}}
@media(max-width:560px){.dashboard-summary-grid{grid-template-columns:1fr!important}.dashboard-chart-studio{gap:.85rem!important}.dashboard-chart-card{border-radius:22px!important;padding:1rem!important}.dashboard-card-head h2{font-size:1.06rem!important}.dashboard-donut{width:162px!important;height:162px!important}.dashboard-donut::before{width:102px;height:102px}.dashboard-donut span{font-size:1.65rem!important}.dashboard-legend-row{grid-template-columns:12px minmax(0,1fr) auto!important}.dashboard-legend-row small{display:none!important}.dashboard-quick-card .quick-actions{grid-template-columns:1fr!important}.dashboard-sla-chart-row{padding:.68rem!important}.dashboard-column-chart{height:230px!important}.dashboard-column-track{min-height:132px!important}}

/* --------------------------------------------------------------------------
   Phase 2.8.24 — Approval detail display repair
   Fix /approvals/show and /leave/detail detail cards after global form-grid
   responsive rules accidentally converted detail fields into 12 narrow columns.
   -------------------------------------------------------------------------- */
.approval-detail-grid,
.my-leave-detail-grid{
  display:grid !important;
  grid-template-columns:minmax(0,1.18fr) minmax(340px,.82fr) !important;
  gap:clamp(16px,1.3vw,24px) !important;
  align-items:start !important;
  width:100% !important;
  max-width:100% !important;
  margin-top:clamp(16px,1.2vw,22px) !important;
}

.approval-info-card,
.my-leave-detail-card,
.approval-action-card,
.approval-steps-card,
.approval-timeline-card,
.leave-cancellation-card,
.approval-cancellation-card,
.leave-attachment-detail-card{
  min-width:0 !important;
  overflow:hidden !important;
}

.detail-grid.approval-info-grid,
.approval-info-grid{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(min(100%, 190px),1fr)) !important;
  gap:12px !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
}

.detail-grid.approval-info-grid > *,
.approval-info-grid > *{
  grid-column:auto !important;
  min-width:0 !important;
  max-width:100% !important;
  padding:13px 15px !important;
  border:1px solid #dbe7f3 !important;
  border-radius:16px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbfd 100%) !important;
  box-shadow:0 8px 20px rgba(15,23,42,.035) !important;
  align-content:start !important;
  overflow:hidden !important;
}

.detail-grid.approval-info-grid > .full,
.approval-info-grid > .full,
.detail-grid.approval-info-grid > .last-leave-detail-row,
.approval-info-grid > .last-leave-detail-row{
  grid-column:1 / -1 !important;
}

.approval-info-grid span{
  display:block !important;
  margin:0 0 5px !important;
  color:#64748b !important;
  font-size:12px !important;
  line-height:1.35 !important;
  font-weight:600 !important;
}

.approval-info-grid strong{
  display:block !important;
  color:#06243a !important;
  font-size:14px !important;
  line-height:1.55 !important;
  font-weight:700 !important;
  white-space:normal !important;
  overflow-wrap:break-word !important;
  word-break:normal !important;
}

.approval-info-grid small{
  display:block !important;
  margin-top:4px !important;
  color:#64748b !important;
  font-size:12px !important;
  line-height:1.45 !important;
  white-space:normal !important;
  overflow-wrap:break-word !important;
  word-break:normal !important;
}

.creator-audit-row.is-other-requester{
  border-color:#fed7aa !important;
  background:linear-gradient(180deg,#fff7ed 0%,#fff 100%) !important;
}

.approval-action-form,
.cancellation-decision-form{
  display:grid !important;
  gap:14px !important;
  width:100% !important;
}

.approval-action-card textarea,
.approval-cancellation-card textarea{
  min-height:132px !important;
  resize:vertical !important;
}

.approval-action-buttons{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}

.approval-action-buttons.two-actions{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
}

.approval-action-buttons .btn{
  width:100% !important;
  justify-content:center !important;
  min-height:42px !important;
}

.approval-stepper{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(min(100%, 180px),1fr)) !important;
  gap:12px !important;
}

.approval-step{
  min-width:0 !important;
  min-height:96px !important;
}

.approval-timeline-item{
  min-width:0 !important;
}

.approval-timeline-item > div{
  min-width:0 !important;
  overflow-wrap:break-word !important;
}

.leave-attachment-list.is-detail,
.cancellation-history-list{
  display:grid !important;
  gap:12px !important;
}

@media (max-width:1180px){
  .approval-detail-grid,
  .my-leave-detail-grid{
    grid-template-columns:1fr !important;
  }
  .approval-action-card{
    order:-1 !important;
  }
}

@media (max-width:760px){
  .detail-grid.approval-info-grid,
  .approval-info-grid{
    grid-template-columns:1fr !important;
    gap:10px !important;
  }
  .detail-grid.approval-info-grid > *,
  .approval-info-grid > *{
    grid-column:1 / -1 !important;
    padding:12px 13px !important;
  }
  .approval-action-buttons.two-actions{
    grid-template-columns:1fr !important;
  }
  .approval-detail-grid,
  .my-leave-detail-grid{
    gap:12px !important;
  }
}

/* ======================================================================
   Phase 2.8.24 — Approval Detail Page Layout Repair
   Scope: /approvals/show only. Fix the 12-column responsive grid guard that
   made approval detail fields render as narrow vertical cards.
   ====================================================================== */
.approval-detail-hero{
  min-height:auto !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
  padding:1.45rem 1.65rem !important;
}
.approval-detail-hero > div{
  width:100% !important;
  max-width:1040px !important;
}
.approval-detail-hero h2{
  max-width:100% !important;
  word-break:break-word !important;
}
.approval-detail-hero p{
  max-width:980px !important;
  margin-top:.58rem !important;
}
.approval-detail-hero .approval-tag-row{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  gap:.55rem !important;
  margin-top:.9rem !important;
}
.approval-detail-hero .page-hero-actions{
  display:flex !important;
  flex-wrap:wrap !important;
  align-items:center !important;
  gap:.55rem !important;
  margin-top:.9rem !important;
}
.approval-detail-grid{
  display:grid !important;
  grid-template-columns:minmax(0,1.08fr) minmax(380px,.92fr) !important;
  gap:1rem !important;
  align-items:start !important;
  margin-top:1rem !important;
}
.approval-detail-grid > .card{
  min-width:0 !important;
  max-width:100% !important;
  align-self:start !important;
}
.approval-info-card,
.approval-action-card,
.approval-steps-card,
.approval-timeline-card,
.approval-cancellation-card,
.leave-attachment-detail-card{
  padding:1.15rem !important;
  border-radius:24px !important;
}
.approval-info-grid.detail-grid,
.detail-grid.approval-info-grid,
.approval-info-grid{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(240px,1fr)) !important;
  gap:.75rem !important;
  min-width:0 !important;
  max-width:100% !important;
}
.approval-info-grid > *,
.detail-grid.approval-info-grid > *{
  grid-column:auto !important;
  min-width:0 !important;
  width:100% !important;
  min-height:0 !important;
  padding:.78rem .85rem !important;
  border:1px solid rgba(219,229,240,.94) !important;
  border-radius:16px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbfd 100%) !important;
  box-shadow:none !important;
}
.approval-info-grid > .full,
.detail-grid.approval-info-grid > .full{
  grid-column:1 / -1 !important;
}
.approval-info-grid span{
  display:block !important;
  margin:0 0 .28rem !important;
  color:#64748b !important;
  font-size:.78rem !important;
  line-height:1.35 !important;
  font-weight:650 !important;
}
.approval-info-grid strong{
  display:block !important;
  color:#0f2537 !important;
  font-size:.94rem !important;
  line-height:1.55 !important;
  font-weight:650 !important;
  word-break:normal !important;
  overflow-wrap:anywhere !important;
  white-space:normal !important;
}
.approval-info-grid small{
  display:block !important;
  margin-top:.28rem !important;
  color:#64748b !important;
  line-height:1.45 !important;
  word-break:normal !important;
  overflow-wrap:anywhere !important;
}
.approval-action-card{
  position:sticky !important;
  top:86px !important;
}
.approval-action-form,
.cancellation-decision-form{
  display:grid !important;
  gap:.85rem !important;
}
.approval-action-card textarea,
.approval-cancellation-card textarea{
  min-height:108px !important;
}
.approval-action-buttons{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:.55rem !important;
}
.approval-action-buttons.two-actions{
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
}
.approval-action-buttons .btn{
  width:100% !important;
  justify-content:center !important;
  white-space:normal !important;
}
.approval-stepper{
  display:grid !important;
  grid-template-columns:repeat(auto-fit,minmax(190px,1fr)) !important;
  gap:.75rem !important;
}
.approval-step{
  min-width:0 !important;
  min-height:118px !important;
  align-content:start !important;
}
.approval-timeline-item{
  min-width:0 !important;
}
.approval-timeline-item > div{
  min-width:0 !important;
}
.approval-timeline-item small,
.approval-timeline-item p{
  word-break:normal !important;
  overflow-wrap:anywhere !important;
}
.leave-attachment-item{
  min-width:0 !important;
}
.leave-attachment-item > div:first-child{
  min-width:0 !important;
}
.leave-attachment-item span,
.leave-attachment-item small{
  word-break:normal !important;
  overflow-wrap:anywhere !important;
}
@media(max-width:1280px){
  .approval-detail-grid{
    grid-template-columns:minmax(0,1fr) !important;
  }
  .approval-action-card{
    position:static !important;
  }
}
@media(max-width:820px){
  .approval-detail-hero{
    padding:1.15rem !important;
    border-radius:24px !important;
  }
  .approval-detail-hero h2{
    font-size:1.5rem !important;
  }
  .approval-info-grid.detail-grid,
  .detail-grid.approval-info-grid,
  .approval-info-grid{
    grid-template-columns:1fr !important;
  }
  .approval-info-grid > *,
  .detail-grid.approval-info-grid > *,
  .approval-info-grid > .full,
  .detail-grid.approval-info-grid > .full{
    grid-column:1 / -1 !important;
  }
  .approval-action-buttons.two-actions{
    grid-template-columns:1fr !important;
  }
  .leave-attachment-item{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:.75rem !important;
  }
  .leave-attachment-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
  }
  .leave-attachment-actions .btn{
    width:100% !important;
  }
}

/* ======================================================================
   Phase 2.8.25 — Approval detail information architecture rethink
   Scope: /approvals/show. Replace cramped field-card layout with a
   decision-friendly summary strip + definition panels.
   ====================================================================== */
.approval-review-layout{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(360px,430px) !important;
  gap:clamp(16px,1.35vw,24px) !important;
  align-items:start !important;
  margin-top:clamp(16px,1.25vw,24px) !important;
  width:100% !important;
  max-width:100% !important;
}
.approval-review-card,
.approval-review-layout .approval-action-card{
  min-width:0 !important;
  border-radius:24px !important;
  padding:clamp(16px,1.15vw,22px) !important;
  overflow:hidden !important;
}
.approval-review-header{
  align-items:center !important;
  gap:1rem !important;
  margin-bottom:1rem !important;
}
.approval-summary-strip{
  display:grid !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:12px !important;
  margin:0 0 16px !important;
}
.approval-summary-item{
  min-width:0 !important;
  border:1px solid rgba(191,208,229,.94) !important;
  border-radius:18px !important;
  padding:14px 15px !important;
  background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%) !important;
  box-shadow:0 10px 24px rgba(6,36,58,.045) !important;
}
.approval-summary-item span{
  display:block !important;
  margin:0 0 5px !important;
  color:#64748b !important;
  font-size:12px !important;
  line-height:1.35 !important;
  font-weight:800 !important;
}
.approval-summary-item strong{
  display:block !important;
  color:#06243a !important;
  font-size:clamp(14px,.82vw,16px) !important;
  line-height:1.42 !important;
  font-weight:900 !important;
  overflow-wrap:anywhere !important;
}
.approval-summary-item small{
  display:block !important;
  margin-top:5px !important;
  color:#64748b !important;
  font-size:12px !important;
  line-height:1.4 !important;
  font-weight:650 !important;
  overflow-wrap:anywhere !important;
}
.approval-detail-panels{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:14px !important;
}
.approval-detail-panel{
  min-width:0 !important;
  border:1px solid rgba(219,229,240,.95) !important;
  border-radius:20px !important;
  background:#fff !important;
  overflow:hidden !important;
}
.approval-detail-panel h3{
  margin:0 !important;
  padding:13px 15px !important;
  color:#063a5a !important;
  font-size:15px !important;
  line-height:1.35 !important;
  font-weight:950 !important;
  background:linear-gradient(180deg,#f8fbfd 0%,#eef7fb 100%) !important;
  border-bottom:1px solid rgba(219,229,240,.95) !important;
}
.approval-definition-list{
  display:grid !important;
  gap:0 !important;
  margin:0 !important;
  padding:0 !important;
}
.approval-definition-list > div{
  display:grid !important;
  grid-template-columns:140px minmax(0,1fr) !important;
  gap:12px !important;
  align-items:start !important;
  padding:12px 15px !important;
  border-bottom:1px solid rgba(226,236,246,.92) !important;
}
.approval-definition-list > div:last-child{border-bottom:0 !important;}
.approval-definition-list > div.wide{
  grid-template-columns:140px minmax(0,1fr) !important;
}
.approval-definition-list > div.highlight-warning{
  background:#fff7ed !important;
}
.approval-definition-list dt{
  margin:0 !important;
  color:#64748b !important;
  font-size:12px !important;
  line-height:1.4 !important;
  font-weight:850 !important;
}
.approval-definition-list dd{
  margin:0 !important;
  color:#0f2537 !important;
  font-size:14px !important;
  line-height:1.55 !important;
  font-weight:750 !important;
  min-width:0 !important;
  overflow-wrap:anywhere !important;
}
.approval-definition-list dd small{
  display:block !important;
  margin-top:4px !important;
  color:#64748b !important;
  font-size:12px !important;
  line-height:1.45 !important;
  font-weight:650 !important;
}
.approval-review-layout .approval-action-card{
  position:sticky !important;
  top:86px !important;
}
.approval-review-layout .approval-action-card textarea{
  min-height:150px !important;
  font-size:15px !important;
  line-height:1.6 !important;
}
.approval-decision-buttons{
  display:grid !important;
  grid-template-columns:1fr !important;
  gap:10px !important;
}
.approval-decision-buttons .btn{
  width:100% !important;
  min-height:44px !important;
  border-radius:14px !important;
  justify-content:center !important;
  font-weight:900 !important;
}
@media(max-width:1320px){
  .approval-summary-strip{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
  .approval-detail-panels{grid-template-columns:1fr !important;}
}
@media(max-width:1180px){
  .approval-review-layout{grid-template-columns:1fr !important;}
  .approval-review-layout .approval-action-card{position:static !important;}
}
@media(max-width:760px){
  .approval-review-layout{gap:12px !important;margin-top:12px !important;}
  .approval-review-card,
  .approval-review-layout .approval-action-card{border-radius:20px !important;padding:14px !important;}
  .approval-summary-strip{grid-template-columns:1fr !important;gap:10px !important;}
  .approval-detail-panel{border-radius:18px !important;}
  .approval-definition-list > div,
  .approval-definition-list > div.wide{grid-template-columns:1fr !important;gap:4px !important;padding:11px 13px !important;}
  .approval-definition-list dd{font-size:14px !important;}
}

/* Phase 2.8.26 — Approval Route Step Editor Readability Repair
   Scope: /settings/approval-routes > กำหนดขั้นตอนอนุมัติ
   Fixes the step editor layout without changing workflow, permissions, or data. */
.approval-step-workspace{
    --step-blue:#0e5d89;
    --step-blue-soft:#e8f6fb;
    --step-border:#dbe5f0;
    --step-muted:#607086;
}
.approval-step-workspace .approval-studio-section-head.is-step-head{
    align-items:center !important;
    gap:16px !important;
}
.approval-step-workspace .approval-step-guide{
    align-items:center !important;
    gap:12px !important;
    margin:0 0 18px !important;
    padding:13px 15px !important;
    border-radius:18px !important;
    background:#eff6ff !important;
    border-color:#cfe3ff !important;
}
.approval-step-workspace .approval-step-guide span{
    min-width:38px !important;
    height:32px !important;
    padding:0 10px !important;
    border-radius:999px !important;
    font-size:12px !important;
}
.approval-step-workspace .approval-step-guide strong{
    font-size:13.5px !important;
    line-height:1.65 !important;
    font-weight:600 !important;
    overflow-wrap:anywhere !important;
}
.approval-step-workspace .approval-step-flow{
    display:grid !important;
    gap:16px !important;
}
.approval-step-workspace .approval-step-card{
    display:grid !important;
    grid-template-columns:72px minmax(0,1fr) !important;
    gap:16px !important;
    align-items:start !important;
    padding:18px !important;
    border-radius:24px !important;
    border:1px solid var(--step-border) !important;
    background:#fff !important;
    box-shadow:0 12px 28px rgba(6,36,58,.055) !important;
    overflow:visible !important;
}
.approval-step-workspace .approval-step-card.is-final{
    border-color:#b7efc5 !important;
    background:linear-gradient(180deg,#ffffff 0%,#f5fff8 100%) !important;
}
.approval-step-workspace .approval-step-no{
    width:64px !important;
    min-height:64px !important;
    height:auto !important;
    border-radius:20px !important;
    padding:10px !important;
    background:var(--step-blue-soft) !important;
    color:var(--step-blue) !important;
    display:grid !important;
    align-content:center !important;
    justify-items:center !important;
    gap:2px !important;
}
.approval-step-workspace .approval-step-card.is-final .approval-step-no{
    background:#dcfce7 !important;
    color:#15803d !important;
}
.approval-step-workspace .approval-step-no span{
    font-size:11px !important;
    line-height:1 !important;
    font-weight:700 !important;
}
.approval-step-workspace .approval-step-no strong{
    font-size:26px !important;
    line-height:1 !important;
    font-weight:700 !important;
}
.approval-step-workspace .approval-step-body{
    display:grid !important;
    gap:12px !important;
    min-width:0 !important;
    overflow:visible !important;
}
.approval-step-workspace .approval-step-titlebar{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) auto !important;
    align-items:start !important;
    gap:12px !important;
    margin:0 !important;
}
.approval-step-workspace .approval-step-titlebar h4{
    margin:0 !important;
    color:#06243a !important;
    font-size:18px !important;
    line-height:1.35 !important;
    font-weight:700 !important;
    overflow-wrap:anywhere !important;
}
.approval-step-workspace .approval-step-titlebar p{
    margin:5px 0 0 !important;
    color:var(--step-muted) !important;
    font-size:12.5px !important;
    line-height:1.6 !important;
    font-weight:500 !important;
    overflow-wrap:anywhere !important;
}
.approval-step-workspace .approval-step-badges{
    display:flex !important;
    flex-wrap:wrap !important;
    justify-content:flex-end !important;
    gap:7px !important;
    min-width:0 !important;
}
.approval-step-workspace .approval-step-form{
    display:grid !important;
    gap:14px !important;
    padding:16px !important;
    border-radius:22px !important;
    border:1px solid #e5edf5 !important;
    background:#f8fbfd !important;
    overflow:visible !important;
}
.approval-step-workspace .approval-step-fields{
    display:flex !important;
    flex-wrap:wrap !important;
    align-items:flex-end !important;
    gap:14px !important;
    grid-template-columns:none !important;
    overflow:visible !important;
}
.approval-step-workspace .approval-step-fields > .field{
    display:grid !important;
    gap:7px !important;
    grid-column:auto !important;
    min-width:0 !important;
    margin:0 !important;
}
.approval-step-workspace .approval-step-fields > .field.is-order{
    flex:0 0 92px !important;
}
.approval-step-workspace .approval-step-fields > .field.is-code{
    flex:1 1 180px !important;
    max-width:260px !important;
}
.approval-step-workspace .approval-step-fields > .field.is-name{
    flex:2 1 270px !important;
    max-width:520px !important;
}
.approval-step-workspace .approval-step-fields > .field.is-permission{
    flex:1.5 1 250px !important;
    max-width:380px !important;
}
.approval-step-workspace .approval-step-fields > .field.is-scope{
    flex:1 1 190px !important;
    max-width:260px !important;
}
.approval-step-workspace .approval-step-fields > .field.is-final{
    flex:0 0 148px !important;
}
.approval-step-workspace .approval-step-fields label:not(.approval-studio-switch){
    display:flex !important;
    align-items:center !important;
    gap:4px !important;
    min-height:18px !important;
    color:#334155 !important;
    font-size:12.5px !important;
    line-height:1.35 !important;
    font-weight:700 !important;
}
.approval-step-workspace .approval-step-fields .input,
.approval-step-workspace .approval-step-fields .select{
    width:100% !important;
    min-width:0 !important;
    min-height:46px !important;
    border-radius:15px !important;
    background:#fff !important;
    font-size:14px !important;
    line-height:1.35 !important;
    padding-inline:13px !important;
    text-overflow:ellipsis !important;
}
.approval-step-workspace .approval-studio-switch{
    min-height:46px !important;
    height:46px !important;
    justify-content:flex-start !important;
    border-radius:15px !important;
    background:#fff !important;
    white-space:nowrap !important;
}
.approval-step-workspace .approval-step-actions{
    display:flex !important;
    justify-content:flex-end !important;
    margin:0 !important;
    padding-top:2px !important;
}
.approval-step-workspace .approval-step-actions .btn{
    min-height:42px !important;
    padding-inline:18px !important;
}
.approval-step-workspace .approval-add-step{
    margin-top:18px !important;
    padding:16px !important;
    border-radius:22px !important;
    background:#fbfdff !important;
}
.approval-step-workspace .approval-add-step summary{
    min-height:42px !important;
    display:flex !important;
    align-items:center !important;
    color:#06243a !important;
    font-weight:700 !important;
}
.approval-step-workspace .approval-add-step .approval-step-form{
    margin-top:12px !important;
}
@media (max-width:1280px){
    .approval-step-workspace .approval-step-card{
        grid-template-columns:64px minmax(0,1fr) !important;
    }
    .approval-step-workspace .approval-step-fields > .field.is-code,
    .approval-step-workspace .approval-step-fields > .field.is-name,
    .approval-step-workspace .approval-step-fields > .field.is-permission,
    .approval-step-workspace .approval-step-fields > .field.is-scope{
        flex:1 1 calc(50% - 8px) !important;
        max-width:none !important;
    }
    .approval-step-workspace .approval-step-fields > .field.is-order,
    .approval-step-workspace .approval-step-fields > .field.is-final{
        flex:1 1 calc(50% - 8px) !important;
    }
}
@media (max-width:760px){
    .approval-step-workspace .approval-studio-section-head.is-step-head{
        display:grid !important;
        align-items:start !important;
    }
    .approval-step-workspace .approval-studio-section-head.is-step-head .btn{
        width:100% !important;
    }
    .approval-step-workspace .approval-step-guide{
        display:grid !important;
        gap:8px !important;
        padding:12px !important;
    }
    .approval-step-workspace .approval-step-guide span{
        width:max-content !important;
    }
    .approval-step-workspace .approval-step-card{
        grid-template-columns:1fr !important;
        gap:12px !important;
        padding:14px !important;
        border-radius:22px !important;
    }
    .approval-step-workspace .approval-step-no{
        width:100% !important;
        min-height:52px !important;
        display:flex !important;
        justify-content:flex-start !important;
        align-items:center !important;
        gap:8px !important;
        padding:10px 12px !important;
    }
    .approval-step-workspace .approval-step-no strong{
        font-size:21px !important;
    }
    .approval-step-workspace .approval-step-titlebar{
        grid-template-columns:1fr !important;
    }
    .approval-step-workspace .approval-step-badges{
        justify-content:flex-start !important;
    }
    .approval-step-workspace .approval-step-form{
        padding:12px !important;
        border-radius:18px !important;
    }
    .approval-step-workspace .approval-step-fields{
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:11px !important;
    }
    .approval-step-workspace .approval-step-fields > .field,
    .approval-step-workspace .approval-step-fields > .field.is-order,
    .approval-step-workspace .approval-step-fields > .field.is-code,
    .approval-step-workspace .approval-step-fields > .field.is-name,
    .approval-step-workspace .approval-step-fields > .field.is-permission,
    .approval-step-workspace .approval-step-fields > .field.is-scope,
    .approval-step-workspace .approval-step-fields > .field.is-final{
        grid-column:1 / -1 !important;
        flex:none !important;
        max-width:none !important;
        width:100% !important;
    }
    .approval-step-workspace .approval-step-fields .input,
    .approval-step-workspace .approval-step-fields .select{
        min-height:48px !important;
        font-size:16px !important;
    }
    .approval-step-workspace .approval-studio-switch{
        width:100% !important;
        height:48px !important;
    }
    .approval-step-workspace .approval-step-actions{
        display:grid !important;
        grid-template-columns:1fr !important;
    }
    .approval-step-workspace .approval-step-actions .btn{
        width:100% !important;
    }
}

/* Phase 2.8.27 — Approval route assignment editor readability
   Scope: /settings/approval-routes, section: กำหนดผู้อนุมัติในแต่ละขั้นตอน */
.approval-assignment-workspace{
    padding:24px !important;
    overflow:visible !important;
}
.approval-assignment-workspace .approval-assignment-head{
    display:flex !important;
    align-items:flex-start !important;
    justify-content:space-between !important;
    gap:18px !important;
    margin-bottom:18px !important;
    padding-bottom:16px !important;
    border-bottom:1px solid #dbe5f0 !important;
}
.approval-assignment-workspace .approval-assignment-head h3{
    font-size:22px !important;
    line-height:1.25 !important;
    letter-spacing:-.01em !important;
}
.approval-assignment-head-note{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    min-height:34px;
    padding:7px 12px;
    border:1px solid #cfe1ee;
    border-radius:999px;
    background:#f8fbfd;
    color:#0e5d89;
    font-size:12px;
    font-weight:700;
    white-space:nowrap;
}
.approval-assignment-workspace .approval-assignment-form{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) auto !important;
    align-items:end !important;
    gap:16px !important;
    margin:0 0 22px !important;
    padding:18px !important;
    border:1px solid #cfe1ee !important;
    border-radius:24px !important;
    background:linear-gradient(180deg,#f8fcff 0%,#eef7fd 100%) !important;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.82) !important;
}
.approval-assignment-workspace .approval-assignment-grid{
    display:grid !important;
    grid-template-columns:minmax(240px,1.05fr) minmax(320px,1.35fr) minmax(190px,.75fr) minmax(260px,1.05fr) !important;
    gap:14px 16px !important;
    align-items:end !important;
    min-width:0 !important;
    overflow:visible !important;
}
.approval-assignment-workspace .approval-assignment-grid .field{
    display:grid !important;
    gap:7px !important;
    min-width:0 !important;
}
.approval-assignment-workspace .approval-assignment-grid label{
    min-height:18px !important;
    color:#06243a !important;
    font-size:12.5px !important;
    line-height:1.25 !important;
    font-weight:700 !important;
}
.approval-assignment-workspace .approval-assignment-grid .select,
.approval-assignment-workspace .approval-assignment-grid select{
    width:100% !important;
    min-width:0 !important;
    max-width:none !important;
    min-height:48px !important;
    padding:0 42px 0 14px !important;
    border-radius:16px !important;
    font-size:14px !important;
    font-weight:650 !important;
    color:#06243a !important;
    background-color:#fff !important;
}
.approval-assignment-workspace .approval-studio-actions{
    display:flex !important;
    align-items:end !important;
    justify-content:flex-end !important;
    margin:0 !important;
    min-width:148px !important;
}
.approval-assignment-workspace .approval-studio-actions .btn{
    min-height:48px !important;
    width:100% !important;
    padding-inline:18px !important;
    border-radius:16px !important;
    white-space:nowrap !important;
}
.approval-assignment-workspace .approval-assignment-groups{
    gap:16px !important;
}
.approval-assignment-workspace .approval-assignment-group{
    border-radius:24px !important;
    border-color:#dbe5f0 !important;
    box-shadow:0 10px 26px rgba(6,36,58,.045) !important;
}
.approval-assignment-workspace .approval-assignment-group > header{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:14px !important;
    padding:15px 18px !important;
    background:linear-gradient(180deg,#ffffff 0%,#f8fbfd 100%) !important;
}
.approval-assignment-workspace .approval-assignment-group > header strong{
    font-size:15.5px !important;
    line-height:1.35 !important;
    font-weight:750 !important;
}
.approval-assignment-workspace .approval-assignment-group > header small{
    font-size:12px !important;
    line-height:1.45 !important;
}
.approval-assignment-workspace .approval-approver-grid{
    display:grid !important;
    grid-template-columns:repeat(auto-fit,minmax(320px,1fr)) !important;
    gap:12px !important;
    padding:16px !important;
}
.approval-assignment-workspace .approval-approver-card{
    display:grid !important;
    grid-template-columns:46px minmax(0,1fr) auto !important;
    gap:13px !important;
    align-items:center !important;
    min-height:76px !important;
    padding:13px !important;
    border-radius:20px !important;
    background:#fff !important;
}
.approval-assignment-workspace .approval-approver-avatar{
    width:46px !important;
    height:46px !important;
    border-radius:17px !important;
    font-size:15px !important;
}
.approval-assignment-workspace .approval-approver-info strong{
    font-size:14px !important;
    line-height:1.35 !important;
    font-weight:750 !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
}
.approval-assignment-workspace .approval-approver-info small,
.approval-assignment-workspace .approval-approver-info span{
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
}
.approval-assignment-workspace .approval-assignment-empty{
    margin:16px !important;
    padding:18px !important;
    border:1px dashed #cfe1ee !important;
    border-radius:18px !important;
    background:#f8fbfd !important;
}
@media(max-width:1440px){
    .approval-assignment-workspace .approval-assignment-form{
        grid-template-columns:1fr !important;
        align-items:stretch !important;
    }
    .approval-assignment-workspace .approval-assignment-grid{
        grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    }
    .approval-assignment-workspace .approval-studio-actions{
        justify-content:flex-end !important;
        min-width:0 !important;
    }
    .approval-assignment-workspace .approval-studio-actions .btn{
        width:auto !important;
        min-width:180px !important;
    }
}
@media(max-width:760px){
    .approval-assignment-workspace{
        padding:14px !important;
        border-radius:22px !important;
    }
    .approval-assignment-workspace .approval-assignment-head{
        display:grid !important;
        gap:10px !important;
        margin-bottom:14px !important;
    }
    .approval-assignment-head-note{
        width:max-content !important;
        max-width:100% !important;
    }
    .approval-assignment-workspace .approval-assignment-form{
        padding:14px !important;
        border-radius:20px !important;
        gap:13px !important;
    }
    .approval-assignment-workspace .approval-assignment-grid{
        grid-template-columns:1fr !important;
        gap:12px !important;
    }
    .approval-assignment-workspace .approval-assignment-grid .select,
    .approval-assignment-workspace .approval-assignment-grid select{
        min-height:50px !important;
        font-size:16px !important;
    }
    .approval-assignment-workspace .approval-studio-actions{
        display:grid !important;
        grid-template-columns:1fr !important;
    }
    .approval-assignment-workspace .approval-studio-actions .btn{
        width:100% !important;
        min-width:0 !important;
    }
    .approval-assignment-workspace .approval-assignment-group > header{
        display:grid !important;
        justify-items:start !important;
        padding:14px !important;
    }
    .approval-assignment-workspace .approval-approver-grid{
        grid-template-columns:1fr !important;
        padding:12px !important;
    }
    .approval-assignment-workspace .approval-approver-card{
        grid-template-columns:42px minmax(0,1fr) !important;
        min-height:0 !important;
        padding:12px !important;
    }
    .approval-assignment-workspace .approval-approver-avatar{
        width:42px !important;
        height:42px !important;
    }
    .approval-assignment-workspace .approval-approver-actions{
        grid-column:1 / -1 !important;
        display:grid !important;
        grid-template-columns:1fr !important;
        justify-content:stretch !important;
        gap:8px !important;
    }
    .approval-assignment-workspace .approval-approver-actions form,
    .approval-assignment-workspace .approval-approver-actions button{
        width:100% !important;
    }
}

/* Phase 2.8.28 — Approval route core settings readability */
.approval-route-core-panel{
  overflow:visible !important;
}
.route-core-head{
  align-items:flex-start !important;
}
.route-core-form{
  display:grid !important;
  gap:16px !important;
}
.route-core-editor{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) minmax(280px,340px) !important;
  gap:16px !important;
  align-items:stretch !important;
  width:100% !important;
  min-width:0 !important;
}
.route-core-primary{
  min-width:0 !important;
  border:1px solid #dbe5f0 !important;
  border-radius:24px !important;
  background:linear-gradient(180deg,#f8fbfd 0%,#ffffff 100%) !important;
  padding:16px !important;
}
.route-core-grid{
  display:grid !important;
  grid-template-columns:repeat(12,minmax(0,1fr)) !important;
  gap:14px !important;
  width:100% !important;
  min-width:0 !important;
}
.route-core-field{
  display:grid !important;
  align-content:start !important;
  gap:7px !important;
  min-width:0 !important;
}
.route-core-field label{
  color:#06243a !important;
  font-size:13px !important;
  font-weight:650 !important;
  line-height:1.35 !important;
}
.route-core-field small{
  color:#607086 !important;
  font-size:12px !important;
  line-height:1.45 !important;
}
.route-core-field .input,
.route-core-field .select{
  min-height:50px !important;
  border-radius:16px !important;
  background:#fff !important;
  font-weight:560 !important;
}
.route-core-field.is-code{grid-column:span 4 !important;}
.route-core-field.is-condition{grid-column:span 4 !important;}
.route-core-field.is-leave-type{grid-column:span 4 !important;}
.route-core-field.is-name{grid-column:1 / -1 !important;}
.route-core-status-card{
  display:grid !important;
  align-content:start !important;
  gap:12px !important;
  min-width:0 !important;
  border:1px solid #dbe5f0 !important;
  border-radius:24px !important;
  background:linear-gradient(180deg,#ffffff 0%,#f2fbfd 100%) !important;
  padding:16px !important;
  box-shadow:0 10px 24px rgba(6,36,58,.045) !important;
}
.route-core-status-label{
  display:inline-flex !important;
  width:max-content !important;
  align-items:center !important;
  border:1px solid #b9dfee !important;
  border-radius:999px !important;
  background:#e8f6fb !important;
  color:#0e5d89 !important;
  padding:5px 10px !important;
  font-size:12px !important;
  font-weight:700 !important;
}
.route-core-toggle{
  display:grid !important;
  grid-template-columns:22px minmax(0,1fr) !important;
  gap:11px !important;
  align-items:start !important;
  min-height:auto !important;
  margin:0 !important;
  padding:14px !important;
  border:1px solid #cfe0ee !important;
  border-radius:18px !important;
  background:#fff !important;
  cursor:pointer !important;
}
.route-core-toggle input[type="checkbox"]{
  width:20px !important;
  height:20px !important;
  min-width:20px !important;
  max-width:20px !important;
  min-height:20px !important;
  margin:2px 0 0 !important;
  padding:0 !important;
  border-radius:7px !important;
  accent-color:#0e5d89 !important;
}
.route-core-toggle strong{
  display:block !important;
  color:#06243a !important;
  font-size:14px !important;
  font-weight:700 !important;
  line-height:1.35 !important;
}
.route-core-toggle small{
  display:block !important;
  margin-top:4px !important;
  color:#607086 !important;
  font-size:12px !important;
  line-height:1.5 !important;
}
.route-core-status-note{
  display:grid !important;
  gap:4px !important;
  border:1px dashed #b9dfee !important;
  border-radius:18px !important;
  background:rgba(232,246,251,.64) !important;
  padding:13px 14px !important;
}
.route-core-status-note strong{
  color:#0e5d89 !important;
  font-size:13px !important;
  font-weight:700 !important;
}
.route-core-status-note span{
  color:#526478 !important;
  font-size:12px !important;
  line-height:1.55 !important;
}
.route-core-actions{
  margin-top:0 !important;
  padding-top:14px !important;
  border-top:1px solid #edf3f8 !important;
}
@media(max-width:1180px){
  .route-core-editor{
    grid-template-columns:1fr !important;
  }
  .route-core-status-card{
    grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr) !important;
    align-items:start !important;
  }
  .route-core-status-label{
    grid-column:1 / -1 !important;
  }
}
@media(max-width:760px){
  .route-core-primary,
  .route-core-status-card{
    border-radius:20px !important;
    padding:14px !important;
  }
  .route-core-grid,
  .route-core-status-card{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
  .route-core-field.is-code,
  .route-core-field.is-condition,
  .route-core-field.is-leave-type,
  .route-core-field.is-name{
    grid-column:1 / -1 !important;
  }
  .route-core-actions{
    display:grid !important;
  }
  .route-core-actions .btn{
    width:100% !important;
  }
}

/* =====================================================================
   Phase 2.8.29 — Approval Delegation Assignment Form Readability
   Target: /settings/approval-delegations
   Scope: form layout only. Keeps workflow/backend untouched.
   ===================================================================== */
.delegate-form-v3{
  display:grid!important;
  gap:18px!important;
  min-width:0!important;
}
.delegate-transfer-panel,
.delegate-config-card,
.delegate-submit-bar-v3{
  border:1px solid #dbe7f0!important;
  border-radius:24px!important;
  background:#fff!important;
  box-shadow:0 10px 28px rgba(6,36,58,.045)!important;
  min-width:0!important;
}
.delegate-transfer-panel{
  padding:18px!important;
  background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%)!important;
}
.delegate-transfer-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:14px!important;
  padding-bottom:14px!important;
  margin-bottom:16px!important;
  border-bottom:1px solid #edf3f8!important;
}
.delegate-section-eyebrow{
  display:inline-flex!important;
  align-items:center!important;
  width:max-content!important;
  border-radius:999px!important;
  background:#e8f6fb!important;
  color:#0e5d89!important;
  padding:5px 10px!important;
  font-size:12px!important;
  font-weight:650!important;
  line-height:1.2!important;
}
.delegate-transfer-head h4,
.delegate-config-head h4{
  margin:7px 0 0!important;
  color:#06243a!important;
  font-size:17px!important;
  font-weight:700!important;
  line-height:1.35!important;
  letter-spacing:-.01em!important;
}
.delegate-transfer-head p,
.delegate-config-head p{
  margin:4px 0 0!important;
  color:#607086!important;
  font-size:13px!important;
  line-height:1.6!important;
  font-weight:450!important;
}
.delegate-transfer-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) 92px minmax(0,1fr)!important;
  gap:16px!important;
  align-items:stretch!important;
}
.delegate-person-card{
  display:grid!important;
  gap:8px!important;
  padding:16px!important;
  border:1px solid #dbe7f0!important;
  border-radius:20px!important;
  background:#fff!important;
  min-width:0!important;
}
.delegate-person-card-from{
  background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%)!important;
}
.delegate-person-card-to{
  border-color:#bfe7d0!important;
  background:linear-gradient(180deg,#fff 0%,#f5fff9 100%)!important;
}
.delegate-form-v3 .field label{
  margin:0!important;
  color:#0f2a44!important;
  font-size:13px!important;
  font-weight:700!important;
  line-height:1.35!important;
}
.delegate-form-v3 .field small{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.5!important;
}
.delegate-form-v3 .input,
.delegate-form-v3 .select,
.delegate-form-v3 input,
.delegate-form-v3 select,
.delegate-form-v3 textarea{
  width:100%!important;
  max-width:none!important;
  min-width:0!important;
  min-height:48px!important;
  border-radius:16px!important;
  border-color:#cbd9e8!important;
  background:#fff!important;
  color:#06243a!important;
  font-size:14px!important;
  font-weight:520!important;
  line-height:1.45!important;
  box-shadow:0 1px 2px rgba(6,36,58,.025)!important;
}
.delegate-form-v3 textarea.input{
  min-height:96px!important;
  padding-top:12px!important;
  resize:vertical!important;
}
.delegate-form-v3 select.select{
  padding-right:36px!important;
  text-overflow:ellipsis!important;
}
.delegate-form-v3 input[type="datetime-local"]{
  min-width:0!important;
  padding-right:12px!important;
}
.delegate-transfer-arrow{
  display:grid!important;
  align-content:center!important;
  justify-items:center!important;
  gap:8px!important;
  min-width:0!important;
  color:#607086!important;
  text-align:center!important;
  font-size:12px!important;
  font-weight:600!important;
}
.delegate-transfer-arrow strong{
  width:46px!important;
  height:46px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:16px!important;
  background:linear-gradient(135deg,#064768,#0d7fa8)!important;
  color:#fff!important;
  font-size:20px!important;
  font-weight:700!important;
  box-shadow:0 14px 26px rgba(13,127,168,.18)!important;
}
.delegate-setup-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:16px!important;
  min-width:0!important;
}
.delegate-config-card{
  padding:18px!important;
  display:grid!important;
  gap:15px!important;
  align-content:start!important;
}
.delegate-config-condition{
  grid-column:1 / -1!important;
}
.delegate-config-head{
  display:grid!important;
  grid-template-columns:38px minmax(0,1fr)!important;
  gap:12px!important;
  align-items:start!important;
  min-width:0!important;
}
.delegate-config-head>span{
  width:34px!important;
  height:34px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:14px!important;
  background:#e8f6fb!important;
  color:#0e5d89!important;
  font-size:13px!important;
  font-weight:750!important;
}
.delegate-date-grid,
.delegate-scope-grid-v3,
.delegate-condition-grid-v3{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  align-items:start!important;
  min-width:0!important;
}
.delegate-condition-grid-v3{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;
}
.delegate-reason-field-v3{
  grid-column:1 / -1!important;
}
.delegate-submit-bar-v3{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:16px!important;
  padding:16px 18px!important;
  background:linear-gradient(135deg,#f8fbfd 0%,#fff 100%)!important;
}
.delegate-submit-bar-v3 strong{
  display:block!important;
  color:#06243a!important;
  font-size:14px!important;
  font-weight:700!important;
  line-height:1.35!important;
}
.delegate-submit-bar-v3 span{
  display:block!important;
  color:#607086!important;
  font-size:12.5px!important;
  line-height:1.55!important;
  margin-top:2px!important;
}
.delegate-submit-bar-v3 .btn{
  min-width:180px!important;
  min-height:44px!important;
  border-radius:15px!important;
  white-space:nowrap!important;
}
.delegate-form-card .delegate-card-head{
  border-bottom:1px solid #edf3f8!important;
  padding-bottom:16px!important;
  margin-bottom:18px!important;
}
.delegate-form-card .delegate-card-head h3{
  font-size:22px!important;
  line-height:1.3!important;
  color:#06243a!important;
}
.delegate-form-card .delegate-card-head p{
  max-width:760px!important;
}
@media(max-width:1180px){
  .delegate-transfer-grid{
    grid-template-columns:minmax(0,1fr) 76px minmax(0,1fr)!important;
    gap:12px!important;
  }
  .delegate-setup-grid{
    grid-template-columns:1fr!important;
  }
  .delegate-config-condition{
    grid-column:auto!important;
  }
}
@media(max-width:820px){
  .delegate-transfer-panel,
  .delegate-config-card,
  .delegate-submit-bar-v3{
    border-radius:20px!important;
  }
  .delegate-transfer-grid{
    grid-template-columns:1fr!important;
  }
  .delegate-transfer-arrow{
    grid-template-columns:auto auto!important;
    justify-content:center!important;
    align-items:center!important;
    padding:2px 0!important;
  }
  .delegate-transfer-arrow strong{
    width:40px!important;
    height:40px!important;
    border-radius:14px!important;
    transform:rotate(90deg)!important;
  }
  .delegate-date-grid,
  .delegate-scope-grid-v3,
  .delegate-condition-grid-v3{
    grid-template-columns:1fr!important;
  }
  .delegate-submit-bar-v3{
    display:grid!important;
    align-items:stretch!important;
  }
  .delegate-submit-bar-v3 .btn{
    width:100%!important;
    min-width:0!important;
  }
}
@media(max-width:560px){
  .delegate-transfer-panel,
  .delegate-config-card{
    padding:14px!important;
  }
  .delegate-form-card .delegate-card-head{
    display:grid!important;
  }
  .delegate-form-card .delegate-card-head h3{
    font-size:19px!important;
  }
  .delegate-transfer-head{
    display:grid!important;
  }
}

/* ======================================================================
   Phase 2.8.30 — Working Calendar Readability + Mobile Month Cards
   Scope: /calendar/working-days only. Desktop keeps a true monthly calendar;
   mobile switches the month body to readable day cards instead of a cramped
   seven-column grid.
   ====================================================================== */
.calendar-board-card{
  overflow:hidden!important;
}
.calendar-board-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:18px!important;
  border-bottom:1px solid #dbe7f0!important;
}
.calendar-board-head h3{
  margin:4px 0 0!important;
  color:#06243a!important;
  font-size:clamp(22px,2vw,30px)!important;
  line-height:1.2!important;
  font-weight:700!important;
  letter-spacing:-.025em!important;
}
.calendar-board-head p{
  max-width:780px!important;
  margin:6px 0 0!important;
  color:#5f7187!important;
  line-height:1.55!important;
}
.calendar-legend-v2{
  display:flex!important;
  flex-wrap:wrap!important;
  justify-content:flex-end!important;
  align-items:center!important;
  gap:8px!important;
  max-width:620px!important;
  margin-top:0!important;
}
.calendar-legend-v2 span{
  display:inline-flex!important;
  align-items:center!important;
  gap:7px!important;
  min-height:30px!important;
  padding:6px 10px!important;
  border:1px solid #dbe7f0!important;
  border-radius:999px!important;
  background:#fff!important;
  color:#456174!important;
  font-size:12px!important;
  font-weight:600!important;
  white-space:nowrap!important;
}
.calendar-legend-v2 i{
  width:10px!important;
  height:10px!important;
  border-radius:999px!important;
  display:inline-block!important;
}
.legend-working{background:#16a34a!important}.legend-holiday{background:#dc2626!important}.legend-special{background:#0d7fa8!important}.legend-half{background:#f59e0b!important}.legend-today{background:#7c3aed!important}
.calendar-grid-v2{
  display:grid!important;
  grid-template-columns:repeat(7,minmax(0,1fr))!important;
  gap:8px!important;
  padding:16px!important;
  background:linear-gradient(180deg,#f8fbfd 0%,#ffffff 100%)!important;
}
.calendar-weekday-v2{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:38px!important;
  border:1px solid #dbe7f0!important;
  border-radius:14px!important;
  background:#eef7fb!important;
  color:#0e5d89!important;
  font-size:12px!important;
  font-weight:800!important;
}
.calendar-day-v2{
  position:relative!important;
  min-height:132px!important;
  display:flex!important;
  flex-direction:column!important;
  gap:8px!important;
  border:1px solid #dbe7f0!important;
  border-radius:18px!important;
  background:#fff!important;
  box-shadow:0 8px 18px rgba(6,36,58,.035)!important;
}
.calendar-day-v2.is-outside-month{
  opacity:.42!important;
  background:#f8fafc!important;
}
.calendar-day-v2.is-today{
  border-color:#0d7fa8!important;
  box-shadow:0 0 0 3px rgba(13,127,168,.13),0 10px 22px rgba(6,36,58,.06)!important;
}
.calendar-day-top-v2{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:8px!important;
}
.calendar-day-top-v2 time{
  width:34px!important;
  height:34px!important;
  border-radius:13px!important;
  display:grid!important;
  place-items:center!important;
  background:#eff6ff!important;
  color:#063a5a!important;
  font-weight:800!important;
  font-size:14px!important;
}
.calendar-day-v2.is-today .calendar-day-top-v2 time{
  background:#0d7fa8!important;
  color:#fff!important;
}
.calendar-day-top-v2 span{
  max-width:calc(100% - 42px)!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  padding:5px 8px!important;
  border-radius:999px!important;
  background:#f1f7fb!important;
  color:#456174!important;
  font-size:10.5px!important;
  font-weight:700!important;
}
.calendar-day-v2 > strong{
  color:#0f263a!important;
  font-size:13px!important;
  line-height:1.35!important;
  font-weight:700!important;
}
.calendar-day-v2 > small,
.calendar-day-v2 > em{
  color:#607086!important;
  font-size:11px!important;
  line-height:1.35!important;
  font-style:normal!important;
}
.calendar-day-working{border-left:4px solid #16a34a!important}.calendar-day-holiday,.calendar-day-weekend{border-left:4px solid #dc2626!important}.calendar-day-half{border-left:4px solid #f59e0b!important}.calendar-day-special-working{border-left:4px solid #0d7fa8!important}
.working-month-mobile-list{
  display:none!important;
}
.working-month-day-card{
  border:1px solid #dbe7f0!important;
  border-left-width:5px!important;
  border-radius:18px!important;
  background:#fff!important;
  padding:13px!important;
  box-shadow:0 8px 18px rgba(6,36,58,.035)!important;
}
.working-month-day-card.is-today{
  border-color:#0d7fa8!important;
  box-shadow:0 0 0 3px rgba(13,127,168,.13),0 10px 22px rgba(6,36,58,.06)!important;
}
.working-month-date{
  display:grid!important;
  place-items:center!important;
  align-content:center!important;
  width:56px!important;
  min-width:56px!important;
  min-height:64px!important;
  border-radius:16px!important;
  background:#eef7fb!important;
  color:#0e5d89!important;
}
.working-month-date span{
  font-size:11px!important;
  font-weight:700!important;
  line-height:1!important;
}
.working-month-date strong{
  font-size:25px!important;
  line-height:1.08!important;
  font-weight:800!important;
}
.working-month-info{
  min-width:0!important;
  display:grid!important;
  gap:5px!important;
}
.working-month-info-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:10px!important;
}
.working-month-info-head strong{
  min-width:0!important;
  color:#0f263a!important;
  font-size:14px!important;
  line-height:1.35!important;
  font-weight:800!important;
}
.working-month-info-head span{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:26px!important;
  padding:5px 9px!important;
  border-radius:999px!important;
  background:#f1f7fb!important;
  color:#456174!important;
  font-size:11px!important;
  font-weight:800!important;
  white-space:nowrap!important;
}
.working-month-info p,
.working-month-info small{
  margin:0!important;
  color:#607086!important;
  font-size:12px!important;
  line-height:1.4!important;
}
.calendar-control-panel{
  border:1px solid #dbe7f0!important;
  background:#fff!important;
  box-shadow:0 8px 24px rgba(6,36,58,.045)!important;
}
.calendar-control-form{
  display:grid!important;
  grid-template-columns:minmax(280px,1.15fr) minmax(220px,.75fr) auto!important;
  gap:14px!important;
  align-items:end!important;
}
.calendar-control-buttons{
  display:flex!important;
  gap:10px!important;
  justify-content:flex-end!important;
}
.calendar-footnote{
  border:1px solid #dbe7f0!important;
  border-radius:18px!important;
  background:#fff!important;
  padding:14px 16px!important;
}
.calendar-footnote strong{
  color:#0f263a!important;
}
.calendar-footnote p{
  margin:4px 0 0!important;
  color:#607086!important;
  line-height:1.55!important;
}
@media(max-width:1180px){
  .calendar-board-head{
    flex-direction:column!important;
  }
  .calendar-legend-v2{
    justify-content:flex-start!important;
    max-width:none!important;
  }
  .calendar-control-form{
    grid-template-columns:1fr 1fr!important;
  }
  .calendar-control-buttons{
    grid-column:1/-1!important;
    justify-content:flex-start!important;
  }
  .calendar-grid-v2{
    overflow-x:auto!important;
    grid-template-columns:repeat(7,minmax(132px,1fr))!important;
  }
}
@media(max-width:760px){
  .calendar-view-hero{
    padding:16px!important;
  }
  .calendar-view-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    width:100%!important;
  }
  .calendar-view-actions .btn{
    width:100%!important;
  }
  .calendar-control-form{
    grid-template-columns:1fr!important;
    gap:12px!important;
  }
  .calendar-control-buttons{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .calendar-control-buttons .btn,
  .calendar-control-buttons button{
    width:100%!important;
  }
  .calendar-board-card{
    padding:12px!important;
  }
  .calendar-board-head{
    padding-bottom:12px!important;
    margin-bottom:12px!important;
  }
  .calendar-board-head h3{
    font-size:21px!important;
  }
  .calendar-legend-v2{
    display:grid!important;
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:7px!important;
    width:100%!important;
  }
  .calendar-legend-v2 span{
    width:100%!important;
    justify-content:flex-start!important;
    min-width:0!important;
  }
  .calendar-grid-v2{
    display:none!important;
  }
  .working-month-mobile-list{
    display:grid!important;
    gap:10px!important;
    padding:0!important;
  }
  .working-month-day-card{
    display:grid!important;
    grid-template-columns:56px minmax(0,1fr)!important;
    gap:12px!important;
    align-items:center!important;
  }
  .working-month-info-head{
    align-items:flex-start!important;
  }
}
@media(max-width:420px){
  .calendar-legend-v2{
    grid-template-columns:1fr!important;
  }
  .working-month-day-card{
    grid-template-columns:50px minmax(0,1fr)!important;
    padding:11px!important;
  }
  .working-month-date{
    width:50px!important;
    min-width:50px!important;
    min-height:58px!important;
  }
  .working-month-date strong{
    font-size:22px!important;
  }
  .working-month-info-head{
    display:grid!important;
    justify-content:stretch!important;
  }
  .working-month-info-head span{
    width:max-content!important;
  }
}

/* =========================================================
   Phase 2.8.31 — Working calendar mobile desktop-like color view
   Keep monthly calendar on mobile as the same colored grid used on desktop.
   ========================================================= */
.calendar-day-v2.calendar-day-working,
.working-month-day-card.calendar-day-working{
  background:linear-gradient(180deg,#f0fdf4 0%,#ffffff 100%)!important;
  border-color:#bbf7d0!important;
  border-left-color:#16a34a!important;
}
.calendar-day-v2.calendar-day-weekend,
.calendar-day-v2.calendar-day-holiday,
.working-month-day-card.calendar-day-weekend,
.working-month-day-card.calendar-day-holiday{
  background:linear-gradient(180deg,#fff1f2 0%,#ffffff 100%)!important;
  border-color:#fecaca!important;
  border-left-color:#dc2626!important;
}
.calendar-day-v2.calendar-day-half,
.working-month-day-card.calendar-day-half{
  background:linear-gradient(180deg,#fffbeb 0%,#ffffff 100%)!important;
  border-color:#fde68a!important;
  border-left-color:#f59e0b!important;
}
.calendar-day-v2.calendar-day-special-working,
.working-month-day-card.calendar-day-special-working{
  background:linear-gradient(180deg,#ecfeff 0%,#ffffff 100%)!important;
  border-color:#bae6fd!important;
  border-left-color:#0d7fa8!important;
}
.calendar-day-v2.calendar-day-working .calendar-day-top-v2 span,
.working-month-day-card.calendar-day-working .working-month-info-head span{
  background:#dcfce7!important;
  color:#166534!important;
}
.calendar-day-v2.calendar-day-weekend .calendar-day-top-v2 span,
.calendar-day-v2.calendar-day-holiday .calendar-day-top-v2 span,
.working-month-day-card.calendar-day-weekend .working-month-info-head span,
.working-month-day-card.calendar-day-holiday .working-month-info-head span{
  background:#fee2e2!important;
  color:#991b1b!important;
}
.calendar-day-v2.calendar-day-half .calendar-day-top-v2 span,
.working-month-day-card.calendar-day-half .working-month-info-head span{
  background:#fef3c7!important;
  color:#92400e!important;
}
.calendar-day-v2.calendar-day-special-working .calendar-day-top-v2 span,
.working-month-day-card.calendar-day-special-working .working-month-info-head span{
  background:#cffafe!important;
  color:#155e75!important;
}
@media(max-width:760px){
  .calendar-board-card{
    overflow:hidden!important;
  }
  .calendar-grid-v2[role="table"]{
    display:grid!important;
    grid-template-columns:repeat(7,minmax(118px,1fr))!important;
    min-width:880px!important;
    overflow-x:auto!important;
    overflow-y:visible!important;
    padding:12px!important;
    border:1px solid #dbe7f0!important;
    border-radius:18px!important;
    background:linear-gradient(180deg,#f8fbfd 0%,#ffffff 100%)!important;
    -webkit-overflow-scrolling:touch!important;
    scrollbar-width:thin!important;
  }
  .calendar-weekday-v2{
    min-width:118px!important;
    min-height:34px!important;
    border-radius:12px!important;
  }
  .calendar-day-v2{
    min-width:118px!important;
    min-height:116px!important;
    padding:9px!important;
    border-radius:15px!important;
  }
  .calendar-day-top-v2{
    display:grid!important;
    grid-template-columns:auto minmax(0,1fr)!important;
  }
  .calendar-day-top-v2 time{
    width:30px!important;
    height:30px!important;
    border-radius:11px!important;
    font-size:13px!important;
  }
  .calendar-day-top-v2 span{
    max-width:100%!important;
    font-size:10px!important;
    padding:4px 6px!important;
  }
  .calendar-day-v2 > strong{
    font-size:12px!important;
    min-height:32px!important;
  }
  .calendar-day-v2 > small,
  .calendar-day-v2 > em{
    font-size:10.5px!important;
  }
  .working-month-mobile-list{
    display:none!important;
  }
  .calendar-board-head::after{
    content:'เลื่อนซ้าย-ขวาเพื่อดูปฏิทินทั้งเดือน';
    display:inline-flex!important;
    align-items:center!important;
    width:max-content!important;
    max-width:100%!important;
    margin-top:6px!important;
    padding:7px 10px!important;
    border-radius:999px!important;
    background:#eef7fb!important;
    color:#0e5d89!important;
    font-size:12px!important;
    font-weight:700!important;
  }
}

/* =========================================================
   Phase 2.8.32 — Working calendar mobile card view restore
   Scope: /calendar/working-days only. Desktop keeps the monthly grid;
   mobile renders the month as color-coded day cards for readability.
   ========================================================= */
@media (max-width:760px){
  .calendar-board-card{
    overflow:visible!important;
  }
  .calendar-board-head::after{
    content:''!important;
    display:none!important;
  }
  .calendar-grid-v2[role="table"]{
    display:none!important;
  }
  .working-month-mobile-list{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding:2px 0 0!important;
  }
  .working-month-day-card{
    display:grid!important;
    grid-template-columns:58px minmax(0,1fr)!important;
    gap:12px!important;
    align-items:center!important;
    width:100%!important;
    min-width:0!important;
    border:1px solid #dbe7f0!important;
    border-left-width:6px!important;
    border-radius:18px!important;
    padding:12px!important;
    background:#fff!important;
    box-shadow:0 8px 18px rgba(6,36,58,.035)!important;
  }
  .working-month-day-card.is-today{
    border-color:#0d7fa8!important;
    box-shadow:0 0 0 3px rgba(13,127,168,.14),0 10px 22px rgba(6,36,58,.06)!important;
  }
  .working-month-date{
    width:58px!important;
    min-width:58px!important;
    min-height:66px!important;
    border-radius:16px!important;
    display:grid!important;
    place-items:center!important;
    align-content:center!important;
    background:#eef7fb!important;
    color:#0e5d89!important;
  }
  .working-month-date span{
    font-size:11px!important;
    line-height:1!important;
    font-weight:800!important;
  }
  .working-month-date strong{
    margin-top:4px!important;
    font-size:26px!important;
    line-height:1!important;
    font-weight:900!important;
    letter-spacing:-.03em!important;
  }
  .working-month-info{
    min-width:0!important;
    display:grid!important;
    gap:5px!important;
  }
  .working-month-info-head{
    display:flex!important;
    align-items:flex-start!important;
    justify-content:space-between!important;
    gap:10px!important;
    min-width:0!important;
  }
  .working-month-info-head strong{
    min-width:0!important;
    color:#0f263a!important;
    font-size:14px!important;
    line-height:1.35!important;
    font-weight:800!important;
    word-break:break-word!important;
  }
  .working-month-info-head span{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    min-height:26px!important;
    flex:0 0 auto!important;
    padding:5px 9px!important;
    border-radius:999px!important;
    font-size:11px!important;
    line-height:1!important;
    font-weight:800!important;
    white-space:nowrap!important;
  }
  .working-month-info p,
  .working-month-info small{
    margin:0!important;
    color:#607086!important;
    font-size:12px!important;
    line-height:1.45!important;
  }
  .working-month-day-card.calendar-day-working{
    background:linear-gradient(180deg,#f0fdf4 0%,#ffffff 100%)!important;
    border-color:#bbf7d0!important;
    border-left-color:#16a34a!important;
  }
  .working-month-day-card.calendar-day-weekend,
  .working-month-day-card.calendar-day-holiday{
    background:linear-gradient(180deg,#fff1f2 0%,#ffffff 100%)!important;
    border-color:#fecaca!important;
    border-left-color:#dc2626!important;
  }
  .working-month-day-card.calendar-day-half{
    background:linear-gradient(180deg,#fffbeb 0%,#ffffff 100%)!important;
    border-color:#fde68a!important;
    border-left-color:#f59e0b!important;
  }
  .working-month-day-card.calendar-day-special-working{
    background:linear-gradient(180deg,#ecfeff 0%,#ffffff 100%)!important;
    border-color:#bae6fd!important;
    border-left-color:#0d7fa8!important;
  }
  .working-month-day-card.calendar-day-working .working-month-date{
    background:#dcfce7!important;
    color:#166534!important;
  }
  .working-month-day-card.calendar-day-weekend .working-month-date,
  .working-month-day-card.calendar-day-holiday .working-month-date{
    background:#fee2e2!important;
    color:#991b1b!important;
  }
  .working-month-day-card.calendar-day-half .working-month-date{
    background:#fef3c7!important;
    color:#92400e!important;
  }
  .working-month-day-card.calendar-day-special-working .working-month-date{
    background:#cffafe!important;
    color:#155e75!important;
  }
  .working-month-day-card.calendar-day-working .working-month-info-head span{
    background:#dcfce7!important;
    color:#166534!important;
  }
  .working-month-day-card.calendar-day-weekend .working-month-info-head span,
  .working-month-day-card.calendar-day-holiday .working-month-info-head span{
    background:#fee2e2!important;
    color:#991b1b!important;
  }
  .working-month-day-card.calendar-day-half .working-month-info-head span{
    background:#fef3c7!important;
    color:#92400e!important;
  }
  .working-month-day-card.calendar-day-special-working .working-month-info-head span{
    background:#cffafe!important;
    color:#155e75!important;
  }
}
@media (max-width:420px){
  .working-month-day-card{
    grid-template-columns:52px minmax(0,1fr)!important;
    padding:11px!important;
    border-radius:16px!important;
  }
  .working-month-date{
    width:52px!important;
    min-width:52px!important;
    min-height:60px!important;
    border-radius:14px!important;
  }
  .working-month-date strong{
    font-size:23px!important;
  }
  .working-month-info-head{
    display:grid!important;
    gap:6px!important;
  }
  .working-month-info-head span{
    width:max-content!important;
    max-width:100%!important;
  }
}

/* =========================================================
   Phase 2.8.33 — Working calendar restrained color system
   Scope: /calendar/working-days only. Reduce excessive full-card colors;
   keep status recognition through small badges, subtle accent lines and labels.
   ========================================================= */
.calendar-grid-v2,
.calendar-board-card .working-month-mobile-list{
  --cal-border:#dbe7f0;
  --cal-text:#0f263a;
  --cal-muted:#64748b;
  --cal-soft:#f8fafc;
  --cal-working:#15803d;
  --cal-working-soft:#edf7ef;
  --cal-holiday:#b42318;
  --cal-holiday-soft:#fff4f3;
  --cal-half:#b45309;
  --cal-half-soft:#fff8e6;
  --cal-special:#0e7490;
  --cal-special-soft:#eefaff;
}
.calendar-board-card{
  background:#fff!important;
}
.calendar-board-head p{
  color:#607086!important;
}
.calendar-legend-v2 span{
  background:#fff!important;
  border-color:#e2e8f0!important;
  color:#53677a!important;
  font-weight:600!important;
}
.calendar-legend-v2 i{
  border:0!important;
  opacity:.9!important;
}
.legend-working{background:var(--cal-working)!important}
.legend-holiday{background:var(--cal-holiday)!important}
.legend-special{background:var(--cal-special)!important}
.legend-half{background:var(--cal-half)!important}
.legend-today{background:#0d7fa8!important}
.calendar-day-v2,
.calendar-day-v2.calendar-day-working,
.calendar-day-v2.calendar-day-weekend,
.calendar-day-v2.calendar-day-holiday,
.calendar-day-v2.calendar-day-half,
.calendar-day-v2.calendar-day-special-working{
  background:#fff!important;
  border:1px solid var(--cal-border)!important;
  border-left-width:3px!important;
  box-shadow:0 8px 18px rgba(6,36,58,.028)!important;
}
.calendar-day-v2.calendar-day-working{border-left-color:rgba(21,128,61,.78)!important}
.calendar-day-v2.calendar-day-weekend,
.calendar-day-v2.calendar-day-holiday{border-left-color:rgba(180,35,24,.78)!important}
.calendar-day-v2.calendar-day-half{border-left-color:rgba(180,83,9,.78)!important}
.calendar-day-v2.calendar-day-special-working{border-left-color:rgba(14,116,144,.78)!important}
.calendar-day-v2.is-outside-month{
  opacity:.52!important;
  background:#fbfdff!important;
  border-left-color:#cbd5e1!important;
}
.calendar-day-v2.is-today{
  border-color:#9bd7ea!important;
  border-left-color:#0d7fa8!important;
  box-shadow:0 0 0 2px rgba(13,127,168,.10),0 8px 18px rgba(6,36,58,.04)!important;
}
.calendar-day-top-v2 time,
.calendar-day-v2.calendar-day-working .calendar-day-top-v2 time,
.calendar-day-v2.calendar-day-weekend .calendar-day-top-v2 time,
.calendar-day-v2.calendar-day-holiday .calendar-day-top-v2 time,
.calendar-day-v2.calendar-day-half .calendar-day-top-v2 time,
.calendar-day-v2.calendar-day-special-working .calendar-day-top-v2 time{
  background:#f1f5f9!important;
  color:#0f263a!important;
}
.calendar-day-v2.is-today .calendar-day-top-v2 time{
  background:#0d7fa8!important;
  color:#fff!important;
}
.calendar-day-v2.calendar-day-working .calendar-day-top-v2 span{
  background:var(--cal-working-soft)!important;
  color:var(--cal-working)!important;
}
.calendar-day-v2.calendar-day-weekend .calendar-day-top-v2 span,
.calendar-day-v2.calendar-day-holiday .calendar-day-top-v2 span{
  background:var(--cal-holiday-soft)!important;
  color:var(--cal-holiday)!important;
}
.calendar-day-v2.calendar-day-half .calendar-day-top-v2 span{
  background:var(--cal-half-soft)!important;
  color:var(--cal-half)!important;
}
.calendar-day-v2.calendar-day-special-working .calendar-day-top-v2 span{
  background:var(--cal-special-soft)!important;
  color:var(--cal-special)!important;
}
.calendar-day-v2 > strong{
  color:var(--cal-text)!important;
}
.calendar-day-v2 > small,
.calendar-day-v2 > em{
  color:var(--cal-muted)!important;
}
@media (max-width:760px){
  .working-month-day-card,
  .working-month-day-card.calendar-day-working,
  .working-month-day-card.calendar-day-weekend,
  .working-month-day-card.calendar-day-holiday,
  .working-month-day-card.calendar-day-half,
  .working-month-day-card.calendar-day-special-working{
    background:#fff!important;
    border:1px solid var(--cal-border)!important;
    border-left-width:4px!important;
    box-shadow:0 8px 18px rgba(6,36,58,.028)!important;
  }
  .working-month-day-card.calendar-day-working{border-left-color:rgba(21,128,61,.78)!important}
  .working-month-day-card.calendar-day-weekend,
  .working-month-day-card.calendar-day-holiday{border-left-color:rgba(180,35,24,.78)!important}
  .working-month-day-card.calendar-day-half{border-left-color:rgba(180,83,9,.78)!important}
  .working-month-day-card.calendar-day-special-working{border-left-color:rgba(14,116,144,.78)!important}
  .working-month-day-card.is-today{
    border-color:#9bd7ea!important;
    border-left-color:#0d7fa8!important;
    box-shadow:0 0 0 2px rgba(13,127,168,.10),0 8px 18px rgba(6,36,58,.04)!important;
  }
  .working-month-date,
  .working-month-day-card.calendar-day-working .working-month-date,
  .working-month-day-card.calendar-day-weekend .working-month-date,
  .working-month-day-card.calendar-day-holiday .working-month-date,
  .working-month-day-card.calendar-day-half .working-month-date,
  .working-month-day-card.calendar-day-special-working .working-month-date{
    background:#f1f5f9!important;
    color:#0f263a!important;
  }
  .working-month-day-card.is-today .working-month-date{
    background:#0d7fa8!important;
    color:#fff!important;
  }
  .working-month-day-card.calendar-day-working .working-month-info-head span{
    background:var(--cal-working-soft)!important;
    color:var(--cal-working)!important;
  }
  .working-month-day-card.calendar-day-weekend .working-month-info-head span,
  .working-month-day-card.calendar-day-holiday .working-month-info-head span{
    background:var(--cal-holiday-soft)!important;
    color:var(--cal-holiday)!important;
  }
  .working-month-day-card.calendar-day-half .working-month-info-head span{
    background:var(--cal-half-soft)!important;
    color:var(--cal-half)!important;
  }
  .working-month-day-card.calendar-day-special-working .working-month-info-head span{
    background:var(--cal-special-soft)!important;
    color:var(--cal-special)!important;
  }
  .working-month-info-head strong{
    color:#0f263a!important;
  }
  .working-month-info p,
  .working-month-info small{
    color:#64748b!important;
  }
}

/* ========================================================================
   Phase 2.8.34 — Profile page layout repair
   Scope: /profile only. Fixes generic 12-column grid rules from responsive
   hardening that made profile cards collapse into narrow vertical columns.
   ======================================================================== */
.profile-page{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  display:grid !important;
  gap:clamp(16px,1.4vw,24px) !important;
}
.profile-page .profile-hero{
  margin:0 !important;
}
.profile-page .profile-grid{
  display:grid !important;
  grid-template-columns:minmax(320px,.82fr) minmax(0,1.18fr) !important;
  gap:clamp(16px,1.35vw,24px) !important;
  align-items:start !important;
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
}
.profile-page .profile-grid > .profile-card,
.profile-page .profile-grid > form.profile-card{
  grid-column:auto !important;
  grid-row:auto !important;
  width:100% !important;
  min-width:0 !important;
  max-width:100% !important;
}
.profile-page .profile-grid > .profile-avatar-manage-card{
  grid-column:1 / -1 !important;
}
.profile-page .profile-card{
  padding:clamp(18px,1.35vw,26px) !important;
  border-radius:24px !important;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%) !important;
  border:1px solid rgba(191,219,234,.92) !important;
  box-shadow:0 14px 34px rgba(6,36,58,.055) !important;
}
.profile-page .profile-card .section-header.compact{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:14px !important;
  padding:0 0 14px !important;
  margin:0 0 16px !important;
  border-bottom:1px solid rgba(219,229,240,.9) !important;
}
.profile-page .profile-card .section-header.compact h3{
  font-size:clamp(1.08rem,1.25vw,1.28rem) !important;
  line-height:1.25 !important;
  margin:0 !important;
  color:#06243a !important;
  font-weight:850 !important;
  letter-spacing:-.02em !important;
}
.profile-page .profile-card .section-header.compact p{
  max-width:720px !important;
  margin:.28rem 0 0 !important;
  color:#607086 !important;
  font-size:.9rem !important;
  line-height:1.62 !important;
}
.profile-page .profile-info-list{
  display:grid !important;
  grid-template-columns:1fr !important;
  border:1px solid rgba(219,229,240,.95) !important;
  border-radius:18px !important;
  overflow:hidden !important;
  background:#fff !important;
}
.profile-page .profile-info-list > div{
  display:grid !important;
  grid-template-columns:minmax(128px,.42fr) minmax(0,1fr) !important;
  align-items:start !important;
  gap:14px !important;
  padding:13px 15px !important;
  border-bottom:1px solid rgba(237,243,248,.95) !important;
  background:#fff !important;
}
.profile-page .profile-info-list > div:nth-child(2n){
  background:#f8fbfd !important;
}
.profile-page .profile-info-list > div:last-child{
  border-bottom:0 !important;
}
.profile-page .profile-info-list span{
  color:#607086 !important;
  font-size:.82rem !important;
  line-height:1.45 !important;
  font-weight:650 !important;
}
.profile-page .profile-info-list strong{
  min-width:0 !important;
  color:#06243a !important;
  font-size:.92rem !important;
  line-height:1.55 !important;
  font-weight:760 !important;
  text-align:left !important;
  overflow-wrap:anywhere !important;
}
.profile-page .profile-edit-note{
  display:grid !important;
  grid-template-columns:auto minmax(0,1fr) !important;
  gap:10px !important;
  align-items:start !important;
  padding:13px 15px !important;
  margin:0 0 16px !important;
  border:1px solid rgba(183,216,232,.95) !important;
  border-radius:18px !important;
  background:#f4fbff !important;
}
.profile-page .profile-edit-note strong{
  color:#0e5d89 !important;
  font-weight:850 !important;
  white-space:nowrap !important;
}
.profile-page .profile-edit-note span{
  color:#405269 !important;
  line-height:1.6 !important;
  overflow-wrap:anywhere !important;
}
.profile-page form.profile-card .form-grid.two{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:16px !important;
}
.profile-page form.profile-card .form-grid.two > .form-group{
  grid-column:auto !important;
  min-width:0 !important;
}
.profile-page form.profile-card .form-grid.two > .form-span-2{
  grid-column:1 / -1 !important;
}
.profile-page .profile-avatar-manage{
  display:grid !important;
  grid-template-columns:132px minmax(0,1fr) !important;
  gap:18px !important;
  align-items:start !important;
}
.profile-page .profile-avatar-upload-form{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  gap:12px !important;
  align-items:center !important;
}
.profile-page .profile-upload-dropzone{
  min-width:0 !important;
}
.profile-page .form-actions{
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:flex-end !important;
  gap:10px !important;
  margin-top:18px !important;
}
@media(max-width:1180px){
  .profile-page .profile-grid{
    grid-template-columns:1fr !important;
  }
  .profile-page .profile-grid > .profile-card,
  .profile-page .profile-grid > form.profile-card,
  .profile-page .profile-grid > .profile-avatar-manage-card{
    grid-column:1 / -1 !important;
  }
}
@media(max-width:760px){
  .profile-page{
    gap:12px !important;
  }
  .profile-page .profile-card{
    padding:14px !important;
    border-radius:20px !important;
  }
  .profile-page .profile-info-list > div{
    grid-template-columns:1fr !important;
    gap:4px !important;
    padding:12px 13px !important;
  }
  .profile-page form.profile-card .form-grid.two{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
  .profile-page form.profile-card .form-grid.two > *,
  .profile-page form.profile-card .form-grid.two > .form-span-2{
    grid-column:1 / -1 !important;
  }
  .profile-page .profile-avatar-manage,
  .profile-page .profile-avatar-upload-form,
  .profile-page .profile-edit-note{
    grid-template-columns:1fr !important;
  }
  .profile-page .profile-avatar-upload-form .btn,
  .profile-page .form-actions .btn,
  .profile-page .form-actions a{
    width:100% !important;
  }
  .profile-page .form-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
  }
}

/* Phase 2.8.35 — LDAP username provisioning on user/employee settings */
.user-employee-notice {
    margin: 0 0 1rem;
}

.user-employee-provision-card {
    display: grid;
    grid-template-columns: minmax(260px, .9fr) minmax(320px, 1.1fr);
    gap: 1.25rem;
    align-items: start;
    margin-bottom: 1rem;
}

.user-employee-provision-main {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: .9rem;
    align-items: start;
}

.user-employee-provision-main strong {
    display: block;
    color: var(--text-strong, #08253f);
    font-size: 1.04rem;
    margin-bottom: .25rem;
}

.user-employee-provision-main p {
    color: var(--text-muted, #58708c);
    line-height: 1.65;
    margin: 0;
}

.user-employee-provision-form {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(190px, .65fr) auto;
    gap: .85rem;
    align-items: end;
    width: 100%;
}

.user-employee-provision-form .field {
    min-width: 0;
}

.user-employee-provision-form .button {
    min-height: 46px;
    white-space: nowrap;
}

.provision-toggle-field .checkline {
    min-height: 46px;
    border: 1px solid var(--border, #cfe0ee);
    border-radius: 16px;
    background: #fff;
    padding: .65rem .85rem;
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    width: 100%;
    color: var(--text-strong, #08253f);
    font-weight: 700;
}

.provision-toggle-field input[type="checkbox"] {
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
}

@media (max-width: 1100px) {
    .user-employee-provision-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .user-employee-provision-card {
        padding: 1rem;
        border-radius: 20px;
    }

    .user-employee-provision-main {
        grid-template-columns: 1fr;
    }

    .user-employee-provision-form {
        grid-template-columns: 1fr;
    }

    .user-employee-provision-form .button {
        width: 100%;
    }
}

/* Phase 2.8.36 — Permanent delete controls for user/employee management */
.user-employee-danger-zone {
    min-width: min(100%, 520px);
    border: 1px solid rgba(220, 38, 38, .22);
    border-radius: 16px;
    background: linear-gradient(180deg, #fff 0%, #fff7f7 100%);
    overflow: hidden;
}

.user-employee-danger-zone summary {
    cursor: pointer;
    padding: 10px 12px;
    color: #b91c1c;
    font-size: 13px;
    font-weight: 800;
    list-style: none;
}

.user-employee-danger-zone summary::-webkit-details-marker {
    display: none;
}

.user-employee-danger-zone[open] summary {
    border-bottom: 1px solid rgba(220, 38, 38, .16);
    background: #fff;
}

.user-employee-danger-zone form {
    display: grid;
    gap: 12px;
    padding: 12px;
}

.user-employee-danger-note {
    color: #991b1b;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.55;
    padding: 12px;
}

.user-employee-delete-option {
    align-items: flex-start;
    border: 1px solid rgba(220, 38, 38, .16);
    border-radius: 14px;
    background: #fff;
    color: #7f1d1d;
    padding: 10px 12px;
    line-height: 1.5;
}

.user-employee-delete-option input[type="checkbox"] {
    margin-top: 2px;
    width: 18px;
    height: 18px;
    flex: 0 0 auto;
}

.button.button-danger {
    background: linear-gradient(135deg, #b91c1c, #dc2626) !important;
    border-color: rgba(185, 28, 28, .65) !important;
    color: #fff !important;
    box-shadow: 0 12px 24px rgba(185, 28, 28, .18) !important;
}

.button.button-danger:hover {
    filter: brightness(.98);
    transform: translateY(-1px);
}

@media (max-width: 760px) {
    .user-employee-danger-zone,
    .user-employee-danger-zone .button {
        width: 100%;
    }
}

/* Phase 2.8.37 — HR Mapping search toolbar compact repair
   Keep the HR reference search/filter controls compact and prevent the
   global filter-bar rules from stretching this two-field toolbar across
   the full page width. */
.hr-ref-section-clean .hr-ref-toolbar-clean{
  display:grid!important;
  grid-template-columns:minmax(240px,420px) minmax(150px,190px)!important;
  justify-content:start!important;
  align-items:end!important;
  gap:12px!important;
  width:100%!important;
  max-width:680px!important;
  padding:14px 18px!important;
  margin:0!important;
  background:#fbfdff!important;
  border-top:1px solid rgba(219,229,240,.72)!important;
  border-bottom:1px solid rgba(219,229,240,.72)!important;
  border-radius:0!important;
}
.hr-ref-section-clean .hr-ref-toolbar-clean::before,
.hr-ref-section-clean .hr-ref-toolbar-clean::after{
  content:none!important;
  display:none!important;
}
.hr-ref-section-clean .hr-ref-search-field,
.hr-ref-section-clean .hr-ref-status-field{
  display:grid!important;
  gap:6px!important;
  min-width:0!important;
  margin:0!important;
}
.hr-ref-section-clean .hr-ref-search-field>span,
.hr-ref-section-clean .hr-ref-status-field>span{
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:600!important;
  color:#405269!important;
  min-height:auto!important;
}
.hr-ref-section-clean .hr-ref-toolbar-clean .input,
.hr-ref-section-clean .hr-ref-toolbar-clean .select{
  width:100%!important;
  min-width:0!important;
  max-width:100%!important;
  min-height:42px!important;
  height:42px!important;
  padding:0 13px!important;
  border-radius:14px!important;
  font-size:14px!important;
  line-height:1.25!important;
  box-shadow:0 1px 2px rgba(6,36,58,.025)!important;
}
.hr-ref-section-clean .hr-ref-toolbar-clean .select{
  padding-right:36px!important;
}

@media(max-width:900px){
  .hr-ref-section-clean .hr-ref-toolbar-clean{
    grid-template-columns:minmax(0,1fr) minmax(150px,200px)!important;
    max-width:none!important;
  }
}

@media(max-width:640px){
  .hr-ref-section-clean .hr-ref-toolbar-clean{
    grid-template-columns:1fr!important;
    gap:10px!important;
    max-width:none!important;
    padding:12px!important;
  }
  .hr-ref-section-clean .hr-ref-toolbar-clean .input,
  .hr-ref-section-clean .hr-ref-toolbar-clean .select{
    min-height:44px!important;
    height:44px!important;
    font-size:16px!important;
  }
}

/* Phase 2.8.38 — Permission management page restore */
.permission-hero .admin-pro-hero-main{max-width:860px}
.permission-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))!important}
.permission-sync-card,
.permission-note-card,
.permission-section-card{margin-top:18px}
.permission-sync-card{display:flex;align-items:center;justify-content:space-between;gap:16px;border-color:rgba(245,158,11,.28);background:linear-gradient(180deg,#fff,#fffbeb)}
.permission-sync-main{display:flex;align-items:flex-start;gap:12px;min-width:0}
.permission-sync-main p{margin:4px 0 0;color:#6b7280;word-break:break-word}
.permission-note-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.permission-note-grid>div{border:1px solid rgba(203,219,235,.86);border-radius:18px;padding:16px;background:#fbfdff;display:grid;gap:8px;align-content:start}
.permission-note-grid strong{font-size:15px;color:#0b2a43}
.permission-note-grid p{margin:0;color:#5c7088;font-size:13px;line-height:1.65}
.permission-section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(219,229,240,.86)}
.permission-section-header h3{margin:4px 0 2px;font-size:22px;color:#0b2a43}
.permission-section-header p{margin:0;color:#60748a;line-height:1.6}
.permission-role-list{display:grid;gap:16px}
.permission-role-card{border:1px solid rgba(203,219,235,.92);border-radius:22px;background:#fff;box-shadow:0 14px 34px rgba(12,40,66,.05);padding:16px}
.permission-role-card.is-super-admin{background:linear-gradient(180deg,#f7fcff,#fff);border-color:rgba(14,165,233,.26)}
.permission-role-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}
.permission-role-head h4{margin:0 0 4px;font-size:18px;color:#0b2a43}
.permission-role-head p{margin:0;color:#5f7188;font-size:13px;line-height:1.55}
.permission-role-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.permission-role-meta span,.permission-action-note{display:inline-flex;align-items:center;border:1px solid rgba(203,219,235,.9);background:#f8fbff;border-radius:999px;padding:5px 10px;color:#42566e;font-size:12px;font-weight:700}
.permission-superadmin-note{border:1px solid rgba(34,197,94,.18);background:#f0fdf4;color:#166534;border-radius:16px;padding:12px 14px;font-size:13px;font-weight:700;line-height:1.6}
.permission-module-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;align-items:start}
.permission-module-card{border:1px solid rgba(213,225,238,.9);border-radius:18px;background:#fbfdff;margin:0;padding:12px;min-width:0}
.permission-module-card legend{font-size:13px;font-weight:800;color:#0c577a;padding:0 8px}
.permission-checkline{display:flex;align-items:flex-start;gap:10px;padding:9px 8px;border-radius:12px;cursor:pointer;min-width:0}
.permission-checkline:hover{background:#eef8ff}
.permission-checkline input{width:18px!important;height:18px!important;flex:0 0 auto;margin-top:2px;accent-color:#0787bd}
.permission-checkline span{display:grid;gap:2px;min-width:0}
.permission-checkline strong{font-size:13px;color:#0b2a43;line-height:1.35}
.permission-checkline small{font-size:11px;color:#64748b;word-break:break-word}
.permission-form-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:14px;padding-top:12px;border-top:1px solid rgba(219,229,240,.78)}
.permission-user-filter{margin-bottom:16px!important}
.permission-user-list{display:grid;gap:12px}
.permission-user-card{border:1px solid rgba(203,219,235,.92);border-radius:18px;background:#fff;overflow:hidden;box-shadow:0 12px 28px rgba(12,40,66,.04)}
.permission-user-card summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 16px;cursor:pointer;background:#fbfdff}
.permission-user-card summary::-webkit-details-marker{display:none}
.permission-user-card summary strong{display:block;color:#0b2a43;font-size:15px}
.permission-user-card summary span{display:block;color:#60748a;font-size:12px;margin-top:2px}
.permission-user-summary-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;max-width:48%;text-align:right}
.permission-user-summary-meta em{font-style:normal;color:#0c577a;font-weight:800;font-size:12px}
.permission-user-card form{padding:16px;border-top:1px solid rgba(219,229,240,.8)}
.permission-user-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.permission-multi-select{min-height:240px!important;height:auto!important;padding:10px!important;border-radius:16px!important;line-height:1.45!important;overflow:auto!important}
.permission-multi-select option{padding:6px 8px;border-radius:8px;margin:2px 0}
.permission-multi-select optgroup{font-weight:800;color:#0c577a;margin-top:4px}
.nav-icon{font-size:11px;letter-spacing:-.02em}
@media(max-width:1180px){.permission-module-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.permission-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}.permission-note-grid{grid-template-columns:1fr}}
@media(max-width:760px){.permission-sync-card{display:grid}.permission-section-header{display:block}.permission-role-head,.permission-user-card summary{display:grid}.permission-user-summary-meta{align-items:flex-start;text-align:left;max-width:none}.permission-module-grid,.permission-user-form-grid,.permission-kpi-grid{grid-template-columns:1fr!important}.permission-form-actions{display:grid;justify-content:stretch}.permission-form-actions .button,.permission-sync-card .button{width:100%}.permission-multi-select{min-height:190px!important;font-size:16px!important}}

/* Phase 2.8.39 — User/employee inline access editor + vacation policy layout polish */
.user-employee-actions{
  align-items:flex-start!important;
}
.user-employee-access-panel{
  width:min(100%,980px);
  border:1px solid rgba(14,116,144,.18);
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%,#f7fbff 100%);
  box-shadow:0 12px 26px rgba(12,40,66,.045);
  overflow:hidden;
}
.user-employee-access-panel summary{
  list-style:none;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  cursor:pointer;
  padding:12px 14px;
  color:#0b3f5f;
  font-weight:800;
}
.user-employee-access-panel summary::-webkit-details-marker{display:none}
.user-employee-access-panel summary small{
  color:#5e7187;
  font-size:12px;
  font-weight:700;
  text-align:right;
}
.user-employee-access-panel[open] summary{
  background:#fff;
  border-bottom:1px solid rgba(203,219,235,.82);
}
.user-employee-access-panel form{
  padding:14px;
  display:grid;
  gap:14px;
}
.user-access-editor-grid{
  display:grid;
  grid-template-columns:minmax(230px,.8fr) minmax(0,1fr) minmax(0,1fr);
  gap:14px;
  align-items:start;
}
.user-access-role-card{
  border:1px solid rgba(203,219,235,.92);
  border-radius:18px;
  padding:14px;
  margin:0;
  background:#fff;
  min-width:0;
}
.user-access-role-card legend{
  padding:0 8px;
  font-size:13px;
  color:#0c577a;
  font-weight:900;
}
.user-access-role-card p{
  margin:0 0 10px;
  color:#60748a;
  font-size:12px;
  line-height:1.55;
}
.user-access-role-list{
  display:grid;
  gap:6px;
  max-height:310px;
  overflow:auto;
  padding-right:3px;
}
.user-access-role-item{
  border:1px solid rgba(219,229,240,.8);
  background:#fbfdff;
}
.user-access-select-field .permission-multi-select{
  min-height:285px!important;
}
.user-access-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding-top:12px;
  border-top:1px solid rgba(219,229,240,.82);
}
.user-access-actions span{
  color:#5e7187;
  font-size:12px;
  line-height:1.45;
  font-weight:700;
}
@media(max-width:1180px){
  .user-access-editor-grid{grid-template-columns:1fr 1fr}
  .user-access-role-card{grid-column:1/-1}
}
@media(max-width:760px){
  .user-employee-access-panel,
  .user-employee-access-panel .button{width:100%}
  .user-employee-access-panel summary{display:grid;justify-content:stretch}
  .user-employee-access-panel summary small{text-align:left}
  .user-access-editor-grid{grid-template-columns:1fr}
  .user-access-role-list{max-height:240px}
  .user-access-select-field .permission-multi-select{min-height:210px!important;font-size:16px!important}
  .user-access-actions{display:grid}
}

.vacation-policy-notice{margin-top:16px}
.vacation-policy-dashboard{
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(300px,.85fr);
  gap:18px;
  align-items:start;
  margin-top:18px;
}
.vacation-year-card,
.vacation-rule-card,
.vacation-policy-editor-card,
.carry-forward-card-v2,
.vacation-history-card{
  border:1px solid rgba(203,219,235,.9)!important;
  border-radius:24px!important;
  background:#fff!important;
  box-shadow:0 16px 36px rgba(12,40,66,.055)!important;
  overflow:hidden;
}
.vacation-section-header{
  padding-bottom:14px;
  margin-bottom:16px;
  border-bottom:1px solid rgba(219,229,240,.82);
}
.vacation-section-header h2{
  margin:5px 0 3px;
  color:#0b2a43;
  font-size:clamp(20px,2vw,25px);
  letter-spacing:-.02em;
}
.vacation-section-header p{
  margin:0;
  color:#60748a;
  line-height:1.62;
}
.vacation-year-picker{
  margin-bottom:16px;
  padding:14px;
  border:1px solid rgba(14,116,144,.14);
  border-radius:18px;
  background:#f8fcff;
}
.vacation-year-form{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.vacation-field-span-2{grid-column:1/-1}
.vacation-form-actions{
  display:flex;
  justify-content:flex-end;
}
.policy-rule-list-v2{
  display:grid;
  gap:10px;
}
.policy-rule-list-v2>div{
  display:grid;
  grid-template-columns:46px 1fr;
  gap:12px;
  align-items:center;
  padding:12px;
  border:1px solid rgba(203,219,235,.82);
  border-radius:16px;
  background:#fbfdff;
}
.policy-rule-list-v2 strong{
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:linear-gradient(135deg,#0b3f5f,#0d7fa8);
  color:#fff;
  font-size:12px;
  letter-spacing:.03em;
}
.policy-rule-list-v2 span{
  color:#40566d;
  font-size:13px;
  line-height:1.55;
  font-weight:700;
}
.vacation-rule-note{
  margin-top:14px;
  display:grid;
  gap:4px;
}
.vacation-policy-editor-card,
.carry-forward-card-v2,
.vacation-history-card{margin-top:18px}
.vacation-policy-list-v2{
  display:grid;
  gap:16px;
}
.vacation-policy-row-v2{
  display:grid;
  gap:16px;
  padding:16px;
  border:1px solid rgba(203,219,235,.9);
  border-radius:22px;
  background:linear-gradient(180deg,#fff,#fbfdff);
  box-shadow:0 10px 26px rgba(12,40,66,.04);
}
.vacation-policy-row-head-v2{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(219,229,240,.82);
}
.vacation-policy-row-head-v2 h3{
  margin:4px 0 3px;
  color:#0b2a43;
  font-size:20px;
}
.vacation-policy-row-head-v2 p{
  margin:0;
  color:#60748a;
  font-size:13px;
  line-height:1.55;
}
.vacation-policy-grid-v2{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  align-items:end;
}
.policy-checkbox-group-v2{
  grid-column:1/-1;
  border:1px solid rgba(14,116,144,.14);
  border-radius:18px;
  background:#f8fcff;
  padding:14px;
  margin:0;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:10px;
}
.policy-checkbox-group-v2 legend{
  padding:0 8px;
  font-size:13px;
  font-weight:900;
  color:#0c577a;
}
.policy-checkbox-group-v2 label{
  display:flex;
  align-items:center;
  gap:8px;
  min-height:42px;
  padding:9px 11px;
  border:1px solid rgba(203,219,235,.82);
  border-radius:14px;
  background:#fff;
  color:#344b63;
  font-size:13px;
  font-weight:800;
}
.policy-checkbox-group-v2 input[type="checkbox"]{
  width:18px!important;
  height:18px!important;
  flex:0 0 auto;
  accent-color:#0787bd;
}
.carry-forward-header-v2{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
}
.carry-forward-filter-v2{
  min-width:min(100%,280px);
  padding:12px;
  border:1px solid rgba(203,219,235,.82);
  border-radius:18px;
  background:#fbfdff;
}
.carry-forward-summary-grid-v2{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:12px;
  margin-bottom:16px;
}
.carry-forward-summary-grid-v2>div{
  padding:14px;
  border:1px solid rgba(203,219,235,.86);
  border-radius:18px;
  background:#fbfdff;
  display:grid;
  gap:4px;
  min-width:0;
}
.carry-forward-summary-grid-v2 span{
  color:#60748a;
  font-size:12px;
  font-weight:800;
}
.carry-forward-summary-grid-v2 strong{
  color:#0b2a43;
  font-size:18px;
  word-break:break-word;
}
.carry-forward-summary-grid-v2 small{
  color:#74879d;
  line-height:1.35;
}
.carry-forward-actions-v2{
  margin-top:16px;
  padding:14px;
  border:1px solid rgba(245,158,11,.22);
  border-radius:18px;
  background:#fffbeb;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.carry-forward-actions-v2 span{
  color:#7c5d1b;
  font-size:13px;
  line-height:1.5;
  font-weight:700;
}
@media(max-width:1180px){
  .vacation-policy-dashboard{grid-template-columns:1fr}
  .vacation-policy-grid-v2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .policy-checkbox-group-v2{grid-template-columns:repeat(2,minmax(0,1fr))}
  .carry-forward-summary-grid-v2{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:760px){
  .vacation-year-card,
  .vacation-rule-card,
  .vacation-policy-editor-card,
  .carry-forward-card-v2,
  .vacation-history-card{border-radius:20px!important}
  .vacation-year-form,
  .vacation-policy-grid-v2,
  .policy-checkbox-group-v2,
  .carry-forward-summary-grid-v2{grid-template-columns:1fr}
  .vacation-policy-row-head-v2,
  .carry-forward-header-v2,
  .carry-forward-actions-v2{display:grid;justify-content:stretch}
  .vacation-policy-row-head-v2 .btn,
  .vacation-form-actions .btn,
  .carry-forward-actions-v2 .btn{width:100%}
  .carry-forward-filter-v2{min-width:0;width:100%}
  .policy-rule-list-v2>div{grid-template-columns:40px 1fr}
}


/* Phase 2.8.40 — Leave Period Management */
.leave-period-hero .page-hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.leave-period-workspace{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,.75fr);gap:18px;align-items:start;margin-top:18px}
.leave-period-form-card,.leave-period-guide-card,.leave-period-list-card{border:1px solid rgba(203,219,235,.92);box-shadow:0 18px 42px rgba(12,40,66,.06)}
.leave-period-section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.leave-period-section-header h2{margin:4px 0 4px;color:#0b2a43;font-size:22px;line-height:1.25}
.leave-period-section-header p{margin:0;color:#60748a;line-height:1.6;font-size:14px}
.leave-period-form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:end}
.leave-period-field-span-2{grid-column:span 2}
.leave-period-field-span-3{grid-column:1/-1}
.leave-period-form-grid .field-hint{display:block;margin-top:6px;color:#718399;font-size:12px;line-height:1.45}
.leave-period-active-card{display:flex;gap:12px;align-items:flex-start;padding:14px;border:1px solid rgba(14,116,144,.18);border-radius:18px;background:#f8fcff;color:#344b63;cursor:pointer}
.leave-period-active-card input{width:20px!important;height:20px!important;flex:0 0 auto;margin-top:2px;accent-color:#0787bd}
.leave-period-active-card strong{display:block;color:#0b2a43;font-weight:900;margin-bottom:2px}
.leave-period-active-card small{display:block;color:#60748a;line-height:1.5}
.leave-period-form-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:10px;padding-top:4px}
.leave-period-guide-list{display:grid;gap:10px}
.leave-period-list-card{margin-top:18px}
.leave-period-card-list{display:grid;gap:14px}
.leave-period-row{display:grid;gap:14px;padding:16px;border:1px solid rgba(203,219,235,.88);border-radius:22px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 10px 28px rgba(12,40,66,.045)}
.leave-period-row.is-active{border-color:rgba(14,116,144,.32);box-shadow:0 16px 34px rgba(14,116,144,.10)}
.leave-period-row-main{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:16px;align-items:start}
.leave-period-title-block{min-width:0}
.leave-period-title-block h3{margin:8px 0 4px;color:#0b2a43;font-size:20px;line-height:1.3;word-break:break-word}
.leave-period-title-block p{margin:0;color:#60748a;font-size:13px;line-height:1.55}
.leave-period-usage-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.leave-period-usage-grid>div{min-width:0;padding:12px;border:1px solid rgba(219,229,240,.9);border-radius:16px;background:#fff;display:grid;gap:2px}
.leave-period-usage-grid span{font-size:11px;font-weight:900;color:#718399;text-transform:none}
.leave-period-usage-grid strong{font-size:18px;color:#0b2a43;line-height:1.1}
.leave-period-note{padding:12px 14px;border:1px solid rgba(203,219,235,.76);border-radius:16px;background:#f8fafc;color:#475569;line-height:1.6;font-size:13px}
.leave-period-row-actions{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding-top:2px}
.leave-period-row-actions form{margin:0}
.leave-period-delete-panel{border:1px solid rgba(239,68,68,.16);border-radius:16px;background:#fffafa;overflow:hidden}
.leave-period-delete-panel summary{cursor:pointer;padding:12px 14px;color:#9f1239;font-weight:900;list-style:none}
.leave-period-delete-panel summary::-webkit-details-marker{display:none}
.leave-period-delete-panel[open] summary{border-bottom:1px solid rgba(239,68,68,.12)}
.leave-period-delete-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end;padding:14px}
.leave-period-delete-panel .notice{margin:14px}
@media(max-width:1180px){
  .leave-period-workspace{grid-template-columns:1fr}
  .leave-period-row-main{grid-template-columns:1fr}
}
@media(max-width:760px){
  .leave-period-section-header{display:grid;gap:12px}
  .leave-period-form-grid{grid-template-columns:1fr}
  .leave-period-field-span-2,.leave-period-field-span-3{grid-column:auto}
  .leave-period-form-actions{display:grid;justify-content:stretch}
  .leave-period-form-actions .btn{width:100%}
  .leave-period-usage-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .leave-period-row-actions{display:grid;grid-template-columns:1fr}
  .leave-period-row-actions .btn,.leave-period-row-actions button{width:100%}
  .leave-period-delete-form{grid-template-columns:1fr}
  .leave-period-delete-form .btn{width:100%}
}

/* Phase 2.8.41 — LDAP username lookup by name */
.user-employee-provision-form{
    align-items: stretch;
}
.ldap-lookup-panel{
    grid-column: 1 / -1;
    display: grid;
    gap: .75rem;
    min-width: 0;
}
.ldap-lookup-search-field,
.ldap-username-target-field{
    min-width: 0;
}
.ldap-lookup-results{
    display: grid;
    gap: .55rem;
    min-height: 48px;
    max-height: 360px;
    overflow: auto;
    border: 1px solid rgba(203, 213, 225, .82);
    border-radius: 18px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fbfd 100%);
    padding: .65rem;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.82);
}
.ldap-lookup-empty{
    display: flex;
    align-items: center;
    min-height: 42px;
    padding: .55rem .75rem;
    border-radius: 14px;
    color: #64748b;
    background: #f8fafc;
    font-weight: 750;
    font-size: .86rem;
}
.ldap-lookup-empty.is-loading{
    color: var(--brand-700);
    background: var(--brand-soft);
}
.ldap-lookup-empty.is-error{
    color: #b91c1c;
    background: #fef2f2;
}
.ldap-lookup-result{
    width: 100%;
    display: grid;
    grid-template-columns: minmax(220px, 1.1fr) minmax(220px, 1fr) auto;
    gap: .75rem;
    align-items: center;
    text-align: left;
    border: 1px solid rgba(203, 213, 225, .86);
    border-radius: 16px;
    background: #fff;
    color: #0f172a;
    padding: .78rem .85rem;
    cursor: pointer;
    transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease, background .16s ease;
}
.ldap-lookup-result:hover,
.ldap-lookup-result:focus-visible,
.ldap-lookup-result.is-selected{
    border-color: rgba(14, 93, 137, .45);
    background: linear-gradient(180deg, #ffffff 0%, #f1f8fc 100%);
    box-shadow: 0 12px 28px rgba(6, 36, 58, .10);
    transform: translateY(-1px);
    outline: none;
}
.ldap-lookup-result-main{
    min-width: 0;
    display: grid;
    gap: .12rem;
}
.ldap-lookup-result-main strong{
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--brand-900);
    font-size: .96rem;
    font-weight: 1000;
}
.ldap-lookup-result-main small{
    color: var(--brand-700);
    font-weight: 900;
    font-size: .78rem;
}
.ldap-lookup-result-meta{
    min-width: 0;
    color: #64748b;
    font-size: .8rem;
    font-weight: 760;
    line-height: 1.45;
}
.ldap-lookup-result-tags{
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .35rem;
}
.ldap-lookup-result-tags span,
.ldap-lookup-used,
.ldap-lookup-new{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 26px;
    border-radius: 999px;
    padding: .18rem .55rem;
    font-size: .68rem;
    font-weight: 1000;
    white-space: nowrap;
    background: #eef2ff;
    color: #3730a3;
}
.ldap-lookup-used{
    background: #f1f5f9 !important;
    color: #475569 !important;
}
.ldap-lookup-new{
    background: #ecfdf5 !important;
    color: #047857 !important;
}
@media (max-width: 920px){
    .ldap-lookup-result{
        grid-template-columns: 1fr;
        gap: .45rem;
    }
    .ldap-lookup-result-main strong{
        white-space: normal;
    }
    .ldap-lookup-result-tags{
        justify-content: flex-start;
    }
}
@media (max-width: 640px){
    .ldap-lookup-results{
        max-height: 420px;
        padding: .55rem;
    }
    .ldap-lookup-result{
        padding: .75rem;
        border-radius: 15px;
    }
}

/* Phase 2.8.42 — Live Tutorial / Guided Tour */
.topbar-tutorial-button{
    display:inline-flex;
    align-items:center;
    gap:.42rem;
    min-height:38px;
    padding:.42rem .72rem;
    border:1px solid rgba(14,93,137,.20);
    border-radius:999px;
    background:linear-gradient(180deg,#ffffff 0%,#eef8fc 100%);
    color:var(--brand-800,#0f5e87);
    font-weight:950;
    cursor:pointer;
    box-shadow:0 8px 20px rgba(6,36,58,.08);
    transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.topbar-tutorial-button:hover,
.topbar-tutorial-button:focus-visible{
    transform:translateY(-1px);
    border-color:rgba(14,93,137,.38);
    box-shadow:0 12px 28px rgba(6,36,58,.12);
    outline:none;
}
.topbar-tutorial-button span{
    display:inline-grid;
    place-items:center;
    width:22px;
    height:22px;
    border-radius:999px;
    background:var(--brand-700,#0e5d89);
    color:#fff;
    font-weight:1000;
    font-size:.76rem;
}
.live-tutorial-backdrop{
    position:fixed;
    inset:0;
    z-index:9050;
    background:rgba(2,6,23,.42);
    opacity:0;
    pointer-events:none;
    transition:opacity .18s ease;
}
.live-tutorial-backdrop.is-visible{
    opacity:1;
    pointer-events:auto;
}
.live-tutorial-open{
    overflow:hidden;
}
.live-tutorial-target{
    position:relative !important;
    z-index:9060 !important;
    border-radius:18px !important;
    box-shadow:0 0 0 4px rgba(255,255,255,.96), 0 0 0 9px rgba(14,93,137,.52), 0 22px 70px rgba(2,6,23,.32) !important;
    transition:box-shadow .18s ease, transform .18s ease;
}
.live-tutorial-panel{
    position:fixed;
    z-index:9070;
    width:min(390px,calc(100vw - 32px));
    border-radius:22px;
    border:1px solid rgba(203,213,225,.94);
    background:#fff;
    color:#0f172a;
    box-shadow:0 28px 80px rgba(2,6,23,.30);
    padding:1rem;
    opacity:0;
    transform:translateY(8px) scale(.98);
    pointer-events:none;
    transition:opacity .18s ease, transform .18s ease;
}
.live-tutorial-panel.is-visible{
    opacity:1;
    transform:translateY(0) scale(1);
    pointer-events:auto;
}
.live-tutorial-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:.75rem;
    margin-bottom:.55rem;
}
.live-tutorial-head span{
    display:inline-flex;
    align-items:center;
    min-height:28px;
    border-radius:999px;
    background:var(--brand-soft,#e8f5fb);
    color:var(--brand-800,#0f5e87);
    padding:.18rem .58rem;
    font-size:.76rem;
    font-weight:1000;
}
.live-tutorial-close{
    display:inline-grid;
    place-items:center;
    width:32px;
    height:32px;
    border:0;
    border-radius:999px;
    background:#f1f5f9;
    color:#334155;
    font-size:1.15rem;
    font-weight:900;
    cursor:pointer;
}
.live-tutorial-close:hover,
.live-tutorial-close:focus-visible{
    background:#e2e8f0;
    outline:none;
}
.live-tutorial-panel h2{
    margin:.1rem 0 .35rem;
    color:var(--brand-950,#07354f);
    font-size:1.12rem;
    line-height:1.35;
    font-weight:1000;
}
.live-tutorial-panel p{
    margin:0;
    color:#475569;
    line-height:1.62;
    font-size:.92rem;
    font-weight:720;
}
.live-tutorial-progress{
    height:7px;
    border-radius:999px;
    background:#e2e8f0;
    overflow:hidden;
    margin:.9rem 0 .8rem;
}
.live-tutorial-progress i{
    display:block;
    height:100%;
    border-radius:inherit;
    background:linear-gradient(90deg,var(--brand-700,#0e5d89),#16a3c7);
    transition:width .18s ease;
}
.live-tutorial-actions{
    display:flex;
    justify-content:flex-end;
    gap:.5rem;
    flex-wrap:wrap;
}
.live-tutorial-actions .btn{
    min-height:38px;
}
.tutorial-settings-layout{
    display:grid;
    grid-template-columns:minmax(0,1.45fr) minmax(290px,.55fr);
    gap:1rem;
    align-items:start;
}
.tutorial-settings-card,
.tutorial-preview-card{
    padding:1.1rem;
}
.tutorial-toggle-list{
    display:grid;
    gap:.72rem;
    margin:.95rem 0 1rem;
}
.tutorial-toggle-card{
    display:grid;
    grid-template-columns:auto minmax(0,1fr);
    gap:.75rem;
    align-items:flex-start;
    padding:.9rem;
    border:1px solid rgba(203,213,225,.86);
    border-radius:18px;
    background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
    cursor:pointer;
}
.tutorial-toggle-card input{
    width:20px !important;
    height:20px !important;
    margin-top:.15rem;
    accent-color:var(--brand-700,#0e5d89);
}
.tutorial-toggle-card strong{
    display:block;
    color:#0f172a;
    font-weight:1000;
    margin-bottom:.15rem;
}
.tutorial-toggle-card small{
    display:block;
    color:#64748b;
    line-height:1.55;
    font-weight:700;
}
.tutorial-settings-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
}
.tutorial-preview-card ol{
    margin:.85rem 0;
    padding-left:1.25rem;
    color:#334155;
    font-weight:780;
    line-height:1.65;
}
.tutorial-preview-card p{
    color:#64748b;
    line-height:1.6;
    font-weight:720;
}
@media (max-width:1080px){
    .tutorial-settings-layout{
        grid-template-columns:1fr;
    }
}
@media (max-width:760px){
    .topbar-tutorial-button strong{
        display:none;
    }
    .topbar-tutorial-button{
        width:38px;
        padding:.35rem;
        justify-content:center;
    }
    .live-tutorial-panel{
        left:16px !important;
        right:16px;
        top:auto !important;
        bottom:16px;
        width:auto;
        border-radius:20px;
    }
    .live-tutorial-target{
        box-shadow:0 0 0 3px rgba(255,255,255,.96), 0 0 0 7px rgba(14,93,137,.46), 0 18px 54px rgba(2,6,23,.28) !important;
    }
    .live-tutorial-actions{
        display:grid;
        grid-template-columns:1fr 1fr;
    }
    .live-tutorial-actions [data-tutorial-next]{
        grid-column:1 / -1;
        order:-1;
    }
    .tutorial-settings-card,
    .tutorial-preview-card{
        padding:.9rem;
    }
    .tutorial-settings-grid{
        grid-template-columns:1fr;
    }
}
@media print{
    .topbar-tutorial-button,
    .live-tutorial-backdrop,
    .live-tutorial-panel{
        display:none !important;
    }
}

/* =======================================================================
 * Phase 2.8.43 — Dashboard SLA Pending Readability Repair
 * Keep SLA urgency visible without using full dark-red row fills that reduce readability.
 * Applies only to the Dashboard pending SLA panel.
 * ======================================================================= */
.dashboard-sla-panel{
  border:1px solid rgba(219,229,240,.96) !important;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%) !important;
  box-shadow:0 16px 36px rgba(6,36,58,.065) !important;
}
.dashboard-sla-panel .section-header{
  border-bottom:1px solid rgba(219,229,240,.78) !important;
  padding-bottom:14px !important;
  margin-bottom:14px !important;
}
.dashboard-sla-panel .dashboard-sla-list{
  gap:12px !important;
}
.dashboard-sla-panel .dashboard-sla-row{
  position:relative !important;
  display:grid !important;
  grid-template-columns:minmax(0,1.45fr) minmax(220px,.75fr) max-content !important;
  align-items:center !important;
  gap:14px !important;
  min-height:64px !important;
  padding:14px 16px 14px 18px !important;
  border:1px solid rgba(219,229,240,.95) !important;
  border-left:6px solid #0d7fa8 !important;
  border-radius:18px !important;
  background:#ffffff !important;
  color:#0f2437 !important;
  text-decoration:none !important;
  box-shadow:0 8px 20px rgba(6,36,58,.045) !important;
  transition:border-color .16s ease, box-shadow .16s ease, transform .16s ease, background .16s ease !important;
}
.dashboard-sla-panel .dashboard-sla-row:hover{
  transform:translateY(-1px) !important;
  border-color:rgba(14,93,137,.34) !important;
  box-shadow:0 14px 26px rgba(6,36,58,.075) !important;
  background:#fbfdff !important;
}
.dashboard-sla-panel .dashboard-sla-row.sla-status-normal{
  border-left-color:#16a34a !important;
  background:linear-gradient(90deg,rgba(22,163,74,.055),#fff 32%) !important;
}
.dashboard-sla-panel .dashboard-sla-row.sla-status-warning{
  border-left-color:#d97706 !important;
  border-color:#fde68a !important;
  background:linear-gradient(90deg,rgba(245,158,11,.105),#fff 34%) !important;
}
.dashboard-sla-panel .dashboard-sla-row.sla-status-overdue,
.dashboard-sla-panel .dashboard-sla-row.sla-status-escalated{
  border-left-color:#dc2626 !important;
  border-color:#fecaca !important;
  background:linear-gradient(90deg,rgba(220,38,38,.09),#fff 34%) !important;
  color:#0f2437 !important;
}
.dashboard-sla-panel .dashboard-sla-row > div{
  min-width:0 !important;
  display:grid !important;
  gap:3px !important;
}
.dashboard-sla-panel .dashboard-sla-row strong{
  color:#06243a !important;
  font-size:14.5px !important;
  line-height:1.25 !important;
  font-weight:800 !important;
  letter-spacing:.01em !important;
}
.dashboard-sla-panel .dashboard-sla-row small{
  color:#64748b !important;
  font-size:12.5px !important;
  line-height:1.45 !important;
  font-weight:600 !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
  white-space:nowrap !important;
}
.dashboard-sla-panel .dashboard-sla-row span{
  justify-self:center !important;
  max-width:100% !important;
  padding:6px 10px !important;
  border:1px solid rgba(203,213,225,.9) !important;
  border-radius:999px !important;
  background:#f8fafc !important;
  color:#334155 !important;
  font-size:12.5px !important;
  line-height:1.2 !important;
  font-weight:750 !important;
  white-space:nowrap !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
}
.dashboard-sla-panel .dashboard-sla-row b{
  justify-self:end !important;
  min-width:72px !important;
  padding:7px 10px !important;
  border-radius:999px !important;
  background:#eef8fb !important;
  border:1px solid #c8e8f2 !important;
  color:#0b5f85 !important;
  text-align:center !important;
  font-size:12.5px !important;
  line-height:1.1 !important;
  font-weight:850 !important;
  white-space:nowrap !important;
}
.dashboard-sla-panel .dashboard-sla-row.sla-status-warning b{
  background:#fff7ed !important;
  border-color:#fed7aa !important;
  color:#9a3412 !important;
}
.dashboard-sla-panel .dashboard-sla-row.sla-status-overdue b,
.dashboard-sla-panel .dashboard-sla-row.sla-status-escalated b{
  background:#fff1f2 !important;
  border-color:#fecaca !important;
  color:#b91c1c !important;
}
.dashboard-sla-panel .dashboard-sla-row.sla-status-overdue span,
.dashboard-sla-panel .dashboard-sla-row.sla-status-escalated span{
  background:#fff7f7 !important;
  border-color:#fecaca !important;
  color:#7f1d1d !important;
}
@media(max-width:760px){
  .dashboard-sla-panel .dashboard-sla-row{
    grid-template-columns:1fr !important;
    align-items:start !important;
    gap:10px !important;
    padding:14px !important;
    border-left-width:5px !important;
  }
  .dashboard-sla-panel .dashboard-sla-row span,
  .dashboard-sla-panel .dashboard-sla-row b{
    justify-self:start !important;
    max-width:100% !important;
  }
  .dashboard-sla-panel .dashboard-sla-row small{
    white-space:normal !important;
  }
}

/* Phase 2.8.47: System QA migration registry action */
.qa-action-buttons .qa-inline-action {
  display: inline-flex;
  margin: 0;
}
.qa-action-buttons .qa-inline-action .btn {
  white-space: nowrap;
}
@media (max-width: 760px) {
  .qa-action-buttons,
  .qa-action-buttons .qa-inline-action,
  .qa-action-buttons .qa-inline-action .btn {
    width: 100%;
  }
}

/* Phase 2.8.62 — Dashboard by Leave Entitlement Year */
.dashboard-fiscal-year-panel{
  margin:0 0 18px;
  padding:18px;
  border:1px solid rgba(203,219,235,.92);
  border-radius:26px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fcff 100%);
  box-shadow:0 18px 42px rgba(6,36,58,.07);
}
.dashboard-fiscal-year-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(219,229,240,.82)}
.dashboard-fiscal-year-head h2{margin:4px 0;color:#082f49;font-size:clamp(20px,2vw,26px);letter-spacing:-.02em}
.dashboard-fiscal-year-head p{margin:0;color:#60748a;line-height:1.6;font-weight:650}
.dashboard-fiscal-year-filter{display:grid;gap:7px;min-width:min(100%,340px);padding:12px;border:1px solid rgba(203,219,235,.88);border-radius:18px;background:#fff}
.dashboard-fiscal-year-filter label{color:#344b63;font-weight:850;font-size:13px}
.dashboard-fiscal-year-filter select{min-height:42px;border:1px solid rgba(203,219,235,.96);border-radius:14px;padding:0 12px;background:#fff;color:#0f2437;font-weight:750}
.dashboard-fiscal-year-empty{display:grid;gap:8px;padding:18px;border:1px solid rgba(245,158,11,.24);border-radius:20px;background:#fffbeb;color:#7c5d1b}
.dashboard-fiscal-year-empty strong{color:#713f12;font-size:16px}
.dashboard-fiscal-year-kpi{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:14px}
.dashboard-fiscal-year-kpi article{padding:16px;border:1px solid rgba(203,219,235,.88);border-radius:20px;background:#fff;display:grid;gap:4px;min-width:0;box-shadow:0 10px 24px rgba(6,36,58,.045)}
.dashboard-fiscal-year-kpi span{color:#64748b;font-weight:850;font-size:12px}
.dashboard-fiscal-year-kpi strong{color:#082f49;font-size:clamp(22px,3vw,34px);line-height:1;font-weight:1000;letter-spacing:-.03em}
.dashboard-fiscal-year-kpi small{color:#7890a6;font-weight:650;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dashboard-fiscal-year-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}
.dashboard-fiscal-year-card{padding:16px;border:1px solid rgba(203,219,235,.9);border-radius:22px;background:#fff;box-shadow:0 12px 28px rgba(6,36,58,.05);min-width:0}
.dashboard-fiscal-year-card-wide{grid-column:1/-1}
.dashboard-fiscal-year-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.dashboard-fiscal-year-card-head h3{margin:0;color:#082f49;font-size:17px;letter-spacing:-.01em}
.dashboard-fiscal-year-card-head span{padding:5px 10px;border-radius:999px;background:#eef8fb;color:#0b5f85;font-size:12px;font-weight:900;white-space:nowrap}
.dashboard-fiscal-year-bars{display:grid;gap:10px}
.dashboard-fiscal-year-bar{display:grid;gap:6px}
.dashboard-fiscal-year-bar div{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#334155;font-size:13px;font-weight:800}
.dashboard-fiscal-year-bar strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#1e3a50}
.dashboard-fiscal-year-bar span{color:#0b5f85;font-weight:950}
.dashboard-fiscal-year-bar i{display:block;height:9px;border-radius:999px;background:linear-gradient(90deg,#0d7fa8,#16a3c7);min-width:12px}
.dashboard-fiscal-year-months{display:flex;gap:10px;align-items:end;min-height:165px;overflow-x:auto;padding:8px 2px 2px}
.dashboard-fiscal-year-month{min-width:70px;display:grid;grid-template-rows:1fr auto auto;align-items:end;gap:6px;text-align:center;color:#475569;font-size:12px;font-weight:750}
.dashboard-fiscal-year-month i{display:block;width:100%;border-radius:12px 12px 5px 5px;background:linear-gradient(180deg,#0d7fa8,#bfeaf4);min-height:10px}
.dashboard-fiscal-year-month strong{color:#334155;font-size:11px;white-space:nowrap}
.dashboard-fiscal-year-month span{color:#0b5f85;font-weight:950}
.dashboard-fiscal-year-latest{display:grid;gap:9px}
.dashboard-fiscal-year-latest>div{display:grid;gap:2px;padding:11px 12px;border:1px solid rgba(219,229,240,.9);border-radius:15px;background:#fbfdff}
.dashboard-fiscal-year-latest strong{color:#0f2437;font-size:13.5px}
.dashboard-fiscal-year-latest span{color:#64748b;font-size:12.5px;font-weight:650;line-height:1.45}
.dashboard-fiscal-year-muted{margin:0;color:#64748b;background:#f8fafc;border:1px dashed rgba(148,163,184,.6);border-radius:14px;padding:12px;font-weight:700}
@media(max-width:1180px){.dashboard-fiscal-year-kpi{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-fiscal-year-grid{grid-template-columns:1fr}}
@media(max-width:760px){.dashboard-fiscal-year-panel{padding:14px;border-radius:22px}.dashboard-fiscal-year-head{display:grid}.dashboard-fiscal-year-filter{min-width:0}.dashboard-fiscal-year-kpi{grid-template-columns:1fr}.dashboard-fiscal-year-card-head{display:grid;justify-content:stretch}.dashboard-fiscal-year-card-head span{justify-self:start}.dashboard-fiscal-year-month{min-width:64px}.dashboard-fiscal-year-kpi small{white-space:normal}}


/* Phase 2.8.68 — Executive Dashboard UX/UI */
.executive-dashboard-hero{
  grid-template-columns:minmax(0,1fr) minmax(300px,380px) !important;
  align-items:stretch !important;
  background:linear-gradient(135deg,#063a5a 0%,#0a5c8a 48%,#0d7fa8 100%) !important;
  box-shadow:0 22px 58px rgba(6,36,58,.18) !important;
}
.executive-hero-main{min-width:0;display:grid;align-content:center;gap:10px}
.executive-dashboard-hero h2{font-size:clamp(28px,3.2vw,44px) !important;letter-spacing:-.04em !important;line-height:1.05 !important;margin:0 !important}
.executive-dashboard-hero p{font-size:15px !important;line-height:1.72 !important;max-width:900px !important;color:rgba(255,255,255,.92) !important}
.executive-hero-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:4px}
.executive-year-filter{align-self:center;display:grid;gap:9px;min-width:0;padding:18px;border:1px solid rgba(255,255,255,.30);border-radius:24px;background:rgba(255,255,255,.15);backdrop-filter:blur(16px);box-shadow:inset 0 1px 0 rgba(255,255,255,.22)}
.executive-year-filter label{color:#fff;font-weight:900;font-size:13px;letter-spacing:.01em}
.executive-year-filter select{width:100%;min-height:48px;border:1px solid rgba(255,255,255,.46);border-radius:16px;padding:0 14px;background:#fff;color:#082f49;font-weight:850;box-shadow:0 10px 24px rgba(6,36,58,.12)}
.executive-year-filter small{color:rgba(255,255,255,.88);font-size:12.5px;line-height:1.45;font-weight:750}
.executive-empty-state{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:16px;padding:18px 20px;border:1px solid rgba(245,158,11,.26);border-radius:24px;background:#fffbeb;color:#7c5d1b;box-shadow:0 14px 34px rgba(120,53,15,.06)}
.executive-empty-state div{display:grid;gap:4px}.executive-empty-state strong{font-size:17px;color:#713f12}.executive-empty-state span{font-weight:700;line-height:1.55}
.executive-kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-top:18px}
.executive-kpi-card{position:relative;min-width:0;overflow:hidden;padding:18px;border:1px solid rgba(203,219,235,.9);border-radius:24px;background:#fff;box-shadow:0 16px 38px rgba(6,36,58,.065);display:grid;gap:8px;min-height:146px}
.executive-kpi-card:after{content:"";position:absolute;right:-24px;top:-28px;width:96px;height:96px;border-radius:999px;background:rgba(13,127,168,.10)}
.executive-kpi-card span{position:relative;color:#64748b;font-size:12.5px;font-weight:900;letter-spacing:.01em}.executive-kpi-card strong{position:relative;color:#06243a;font-size:clamp(28px,3vw,42px);line-height:1;font-weight:1000;letter-spacing:-.04em}.executive-kpi-card small{position:relative;color:#7890a6;line-height:1.45;font-size:12.5px;font-weight:750}
.executive-kpi-card.is-primary{border-color:#bfe6f3}.executive-kpi-card.is-primary:after{background:rgba(13,127,168,.13)}.executive-kpi-card.is-warning{border-color:#fde68a}.executive-kpi-card.is-warning:after{background:rgba(245,158,11,.14)}.executive-kpi-card.is-success{border-color:#bbf7d0}.executive-kpi-card.is-success:after{background:rgba(22,163,74,.13)}.executive-kpi-card.is-info{border-color:#dbeafe}.executive-kpi-card.is-info:after{background:rgba(59,130,246,.12)}.executive-kpi-card.is-danger{border-color:#fecaca}.executive-kpi-card.is-danger:after{background:rgba(220,38,38,.12)}
.executive-insight-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:16px;margin-top:16px;align-items:stretch}.executive-insight-card,.executive-chart-card,.executive-latest-section,.executive-support-card{border:1px solid rgba(203,219,235,.9);border-radius:26px;background:#fff;box-shadow:0 16px 38px rgba(6,36,58,.06);padding:18px;min-width:0}.executive-insight-card.is-wide{background:linear-gradient(180deg,#fff 0%,#f8fcff 100%)}
.executive-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px}.executive-section-head.compact{margin-bottom:12px}.executive-section-head span{display:inline-flex;color:#0b6f98;font-size:11.5px;font-weight:1000;letter-spacing:.08em;text-transform:uppercase}.executive-section-head h3{margin:3px 0;color:#06243a;font-size:clamp(18px,1.7vw,22px);line-height:1.22;letter-spacing:-.025em}.executive-section-head p{margin:0;color:#64748b;font-weight:700;line-height:1.6;max-width:760px}.executive-section-head>strong{font-size:30px;color:#06243a;letter-spacing:-.04em}
.executive-focus-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.executive-focus-list>div{padding:16px;border:1px solid rgba(219,229,240,.9);border-radius:20px;background:#fff;display:grid;gap:4px}.executive-focus-list b{font-size:32px;line-height:1;color:#0a5c8a;letter-spacing:-.04em}.executive-focus-list span{font-weight:950;color:#06243a}.executive-focus-list small{color:#64748b;line-height:1.5;font-weight:700}
.executive-status-list,.executive-bar-list,.executive-sla-list{display:grid;gap:11px}.executive-status-row,.executive-bar-row{display:grid;gap:7px}.executive-status-row>div,.executive-bar-row>div{display:flex;align-items:center;justify-content:space-between;gap:12px}.executive-status-row span,.executive-bar-row strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#334155;font-weight:900}.executive-status-row b,.executive-bar-row span{color:#0b5f85;font-weight:1000}.executive-status-row i,.executive-bar-row i{display:block;height:10px;border-radius:999px;background:#e2e8f0;overflow:hidden}.executive-status-row em,.executive-bar-row em{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#0d7fa8,#16a3c7)}.executive-status-row.is-warning em{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.executive-status-row.is-success em{background:linear-gradient(90deg,#16a34a,#86efac)}.executive-status-row.is-danger em{background:linear-gradient(90deg,#dc2626,#fca5a5)}.executive-status-row.is-neutral em{background:linear-gradient(90deg,#64748b,#cbd5e1)}
.executive-chart-grid{display:grid;grid-template-columns:minmax(320px,.8fr) minmax(0,1.2fr) minmax(320px,.8fr);gap:16px;margin-top:16px;align-items:stretch}.executive-chart-card.is-wide{min-height:260px}.executive-month-chart{display:flex;align-items:end;gap:10px;min-height:210px;overflow-x:auto;padding:8px 2px 4px}.executive-month-item{min-width:74px;display:grid;grid-template-rows:auto 1fr auto;gap:7px;text-align:center;color:#64748b;font-weight:800}.executive-month-item b{font-size:12px;color:#0b5f85}.executive-month-item i{height:150px;border-radius:16px;background:#eef6fb;display:flex;align-items:end;overflow:hidden}.executive-month-item em{display:block;width:100%;min-height:8px;border-radius:16px 16px 4px 4px;background:linear-gradient(180deg,#0d7fa8,#bfeaf4)}.executive-month-item span{font-size:11.5px;line-height:1.25;white-space:normal;color:#475569}
.executive-sla-list a{display:grid;grid-template-columns:minmax(0,1fr) minmax(140px,.7fr) max-content;gap:10px;align-items:center;padding:12px;border:1px solid rgba(219,229,240,.92);border-radius:16px;background:#fbfdff;text-decoration:none;color:#0f2437}.executive-sla-list a strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#06243a}.executive-sla-list a span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#64748b;font-weight:750}.executive-sla-list a b{padding:6px 9px;border-radius:999px;background:#fff1f2;border:1px solid #fecaca;color:#b91c1c;font-size:12px;white-space:nowrap}
.executive-latest-section{margin-top:16px}.executive-latest-list{display:grid;gap:10px}.executive-latest-list article{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;border:1px solid rgba(219,229,240,.9);border-radius:18px;background:#fbfdff}.executive-latest-list article div{display:grid;gap:3px;min-width:0}.executive-latest-list strong{color:#06243a}.executive-latest-list span{color:#64748b;font-weight:720}.executive-latest-list time{color:#0b5f85;font-weight:900;white-space:nowrap}
.executive-support-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:16px;margin-top:16px}.executive-mini-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.executive-mini-kpis div{padding:13px;border-radius:17px;background:#f8fafc;border:1px solid rgba(219,229,240,.9);display:grid;gap:4px}.executive-mini-kpis span{color:#64748b;font-size:12px;font-weight:850}.executive-mini-kpis b{font-size:22px;color:#06243a;letter-spacing:-.03em}.executive-quick-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.executive-quick-actions a{display:grid;gap:5px;padding:13px;border:1px solid rgba(203,219,235,.9);border-radius:18px;background:#fff;text-decoration:none;color:#06243a}.executive-quick-actions span{width:34px;height:34px;border-radius:14px;display:grid;place-items:center;background:#e8f6fb;color:#0d7fa8;font-weight:1000}.executive-quick-actions strong{font-size:14px}.executive-quick-actions small{color:#64748b;font-weight:700;line-height:1.4}.executive-muted{margin:0;padding:13px;border:1px dashed rgba(148,163,184,.65);border-radius:16px;background:#f8fafc;color:#64748b;font-weight:760;line-height:1.5}
@media(max-width:1280px){.executive-dashboard-hero{grid-template-columns:1fr !important}.executive-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.executive-insight-grid,.executive-chart-grid,.executive-support-grid{grid-template-columns:1fr}.executive-focus-list,.executive-quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.executive-dashboard-hero{border-radius:22px !important}.executive-hero-actions,.executive-section-head,.executive-empty-state,.executive-latest-list article{display:grid;align-items:stretch}.executive-hero-actions .btn,.executive-empty-state .btn{width:100%}.executive-kpi-grid,.executive-focus-list,.executive-mini-kpis,.executive-quick-actions{grid-template-columns:1fr}.executive-kpi-card{min-height:auto}.executive-insight-card,.executive-chart-card,.executive-latest-section,.executive-support-card{padding:14px;border-radius:22px}.executive-sla-list a{grid-template-columns:1fr}.executive-sla-list a b{justify-self:start}.executive-latest-list time{white-space:normal}.executive-month-item{min-width:66px}.executive-year-filter{padding:14px;border-radius:20px}}

/* =======================================================================
 * Phase 2.8.69 — Executive Dashboard Mobile UX/Button Polish
 * Improve tap targets, responsive spacing, action buttons, filters, charts,
 * and card readability for mobile/tablet executive use.
 * ======================================================================= */
.executive-dashboard-hero .btn,
.executive-empty-state .btn,
.executive-section-head .btn,
.executive-hero-actions .btn,
.executive-year-filter .btn,
.executive-latest-section .btn{
  min-height:44px;
  align-items:center;
  justify-content:center;
  line-height:1.2;
  font-weight:900;
}
.executive-dashboard-hero .btn,
.executive-section-head .btn,
.executive-empty-state .btn{
  box-shadow:0 10px 22px rgba(6,36,58,.08);
}
.executive-year-filter select{
  appearance:auto;
  -webkit-appearance:menulist;
  font-size:15px;
}
.executive-year-filter .btn{
  width:100%;
}
.executive-quick-actions a,
.executive-sla-list a,
.executive-latest-list article{
  -webkit-tap-highlight-color:rgba(13,127,168,.14);
}
@media(max-width:1024px){
  .executive-dashboard-hero{
    gap:18px !important;
  }
  .executive-hero-main{
    min-width:0 !important;
  }
  .executive-year-filter{
    width:100% !important;
    max-width:100% !important;
  }
  .executive-hero-actions{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:10px !important;
  }
  .executive-hero-actions .btn{
    width:100%;
    min-width:0;
    padding-inline:12px;
    text-align:center;
    white-space:normal;
  }
  .executive-chart-grid,
  .executive-insight-grid,
  .executive-support-grid{
    gap:14px !important;
  }
}
@media(max-width:760px){
  .page-hero.dashboard-hero.executive-dashboard-hero{
    margin-top:10px !important;
    padding:18px !important;
    border-radius:22px !important;
    min-height:auto !important;
    gap:16px !important;
  }
  .executive-dashboard-hero h2{
    font-size:clamp(24px,8vw,34px) !important;
    line-height:1.12 !important;
    word-break:normal !important;
  }
  .executive-dashboard-hero p{
    font-size:14px !important;
    line-height:1.62 !important;
  }
  .executive-hero-actions{
    grid-template-columns:1fr !important;
    gap:9px !important;
    width:100%;
  }
  .executive-hero-actions .btn{
    min-height:48px;
    border-radius:16px;
    padding:12px 14px;
  }
  .executive-year-filter{
    padding:14px !important;
    border-radius:20px !important;
    background:rgba(255,255,255,.18) !important;
  }
  .executive-year-filter label{
    font-size:13px !important;
  }
  .executive-year-filter select{
    min-height:50px !important;
    border-radius:16px !important;
    font-size:16px !important;
    padding:0 12px !important;
  }
  .executive-year-filter small{
    font-size:12px !important;
    line-height:1.45 !important;
    overflow-wrap:anywhere;
  }
  .executive-empty-state{
    display:grid !important;
    padding:15px !important;
    border-radius:20px !important;
    gap:12px !important;
  }
  .executive-empty-state .btn{
    width:100%;
    min-height:48px;
  }
  .executive-kpi-grid{
    gap:10px !important;
    margin-top:12px !important;
  }
  .executive-kpi-card{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) auto;
    grid-template-areas:"label value" "hint value";
    align-items:center;
    gap:4px 12px !important;
    min-height:96px !important;
    padding:15px !important;
    border-radius:20px !important;
  }
  .executive-kpi-card span{grid-area:label;font-size:12px !important;line-height:1.35 !important;}
  .executive-kpi-card strong{grid-area:value;font-size:clamp(28px,9vw,40px) !important;text-align:right;}
  .executive-kpi-card small{grid-area:hint;font-size:12px !important;line-height:1.35 !important;}
  .executive-kpi-card:after{
    width:74px !important;
    height:74px !important;
    right:-24px !important;
    top:-24px !important;
  }
  .executive-insight-grid,
  .executive-chart-grid,
  .executive-support-grid{
    margin-top:12px !important;
    gap:12px !important;
  }
  .executive-insight-card,
  .executive-chart-card,
  .executive-latest-section,
  .executive-support-card{
    padding:14px !important;
    border-radius:20px !important;
  }
  .executive-section-head{
    display:grid !important;
    gap:10px !important;
    margin-bottom:12px !important;
  }
  .executive-section-head h3{
    font-size:19px !important;
    line-height:1.28 !important;
  }
  .executive-section-head p{
    font-size:13px !important;
    line-height:1.55 !important;
  }
  .executive-section-head .btn,
  .executive-latest-section .btn{
    width:100% !important;
    min-height:46px !important;
    border-radius:15px !important;
    justify-self:stretch !important;
  }
  .executive-focus-list{
    gap:10px !important;
  }
  .executive-focus-list>div{
    grid-template-columns:auto minmax(0,1fr);
    grid-template-areas:"num title" "num hint";
    align-items:center;
    padding:14px !important;
    border-radius:18px !important;
    gap:2px 12px !important;
  }
  .executive-focus-list b{grid-area:num;font-size:30px !important;min-width:48px;text-align:center;}
  .executive-focus-list span{grid-area:title;line-height:1.35;}
  .executive-focus-list small{grid-area:hint;font-size:12px !important;line-height:1.4 !important;}
  .executive-status-list,
  .executive-bar-list,
  .executive-sla-list{
    gap:10px !important;
  }
  .executive-status-row>div,
  .executive-bar-row>div{
    gap:8px !important;
  }
  .executive-status-row span,
  .executive-bar-row strong{
    white-space:normal !important;
    font-size:13px !important;
    line-height:1.35 !important;
  }
  .executive-status-row b,
  .executive-bar-row span{
    font-size:13px !important;
  }
  .executive-month-chart{
    min-height:190px !important;
    gap:8px !important;
    padding:6px 0 8px !important;
    scroll-snap-type:x proximity;
  }
  .executive-month-item{
    min-width:62px !important;
    scroll-snap-align:start;
  }
  .executive-month-item i{
    height:126px !important;
    border-radius:14px !important;
  }
  .executive-month-item span{
    font-size:11px !important;
  }
  .executive-sla-list a{
    grid-template-columns:1fr auto !important;
    grid-template-areas:"doc time" "step step" !important;
    gap:6px 10px !important;
    padding:13px !important;
    border-radius:16px !important;
  }
  .executive-sla-list a strong{grid-area:doc;white-space:normal !important;line-height:1.35 !important;}
  .executive-sla-list a span{grid-area:step;white-space:normal !important;line-height:1.45 !important;font-size:12.5px !important;}
  .executive-sla-list a b{grid-area:time;justify-self:end !important;align-self:start;}
  .executive-latest-list{
    gap:9px !important;
  }
  .executive-latest-list article{
    display:grid !important;
    grid-template-columns:minmax(0,1fr) auto;
    gap:8px !important;
    align-items:start !important;
    padding:13px !important;
    border-radius:16px !important;
  }
  .executive-latest-list strong,
  .executive-latest-list span{
    line-height:1.4 !important;
  }
  .executive-latest-list time{
    justify-self:end;
    text-align:right;
    font-size:12px !important;
    line-height:1.35 !important;
  }
  .executive-mini-kpis{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
    gap:9px !important;
  }
  .executive-mini-kpis div{
    padding:12px !important;
    border-radius:16px !important;
  }
  .executive-quick-actions{
    grid-template-columns:1fr !important;
    gap:9px !important;
  }
  .executive-quick-actions a{
    grid-template-columns:42px minmax(0,1fr);
    grid-template-areas:"icon title" "icon desc";
    align-items:center;
    min-height:64px;
    padding:12px !important;
    border-radius:17px !important;
  }
  .executive-quick-actions span{grid-area:icon;width:42px !important;height:42px !important;border-radius:16px !important;}
  .executive-quick-actions strong{grid-area:title;font-size:14px !important;line-height:1.25 !important;}
  .executive-quick-actions small{grid-area:desc;font-size:12px !important;line-height:1.35 !important;}
}
@media(max-width:430px){
  .page-hero.dashboard-hero.executive-dashboard-hero{
    padding:15px !important;
    border-radius:20px !important;
  }
  .executive-dashboard-hero h2{
    font-size:25px !important;
  }
  .executive-dashboard-hero p{
    font-size:13.5px !important;
  }
  .executive-kpi-card{
    grid-template-columns:1fr;
    grid-template-areas:"label" "value" "hint";
    text-align:left;
  }
  .executive-kpi-card strong{
    text-align:left;
  }
  .executive-mini-kpis{
    grid-template-columns:1fr !important;
  }
  .executive-latest-list article{
    grid-template-columns:1fr;
  }
  .executive-latest-list time{
    justify-self:start;
    text-align:left;
  }
}

/* Phase 2.8.70 — Google Calendar Sync foundation */
.google-calendar-hero .page-hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.google-calendar-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:18px 0}
.google-calendar-status-card{display:grid;gap:6px;padding:18px;border-radius:22px;border:1px solid rgba(203,213,225,.9);background:#fff;box-shadow:0 14px 34px rgba(6,36,58,.055)}
.google-calendar-status-card span{font-size:12px;font-weight:900;color:#64748b;text-transform:uppercase;letter-spacing:.04em}
.google-calendar-status-card strong{font-size:22px;color:#0f172a;letter-spacing:-.02em}
.google-calendar-status-card small{color:#64748b;line-height:1.5;font-weight:700;word-break:break-word}
.google-calendar-status-card.is-on{border-color:rgba(22,163,74,.28);background:linear-gradient(180deg,#fff,#f0fdf4)}
.google-calendar-status-card.is-off{border-color:rgba(148,163,184,.34);background:linear-gradient(180deg,#fff,#f8fafc)}
.google-calendar-status-card.is-warn{border-color:rgba(245,158,11,.32);background:linear-gradient(180deg,#fff,#fffbeb)}
.google-calendar-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.55fr);gap:18px;align-items:start}
.google-calendar-settings-card,.google-calendar-guide-card,.google-calendar-sync-card{border:1px solid rgba(203,213,225,.9);border-radius:24px;box-shadow:0 16px 38px rgba(6,36,58,.055)}
.google-calendar-settings-card{padding:18px}
.google-calendar-guide-card{padding:18px;display:grid;gap:10px}
.google-calendar-guide-card h3{margin:0;color:#0f172a;font-size:20px}
.google-calendar-guide-card ol{margin:0;padding-left:22px;color:#334155;font-weight:750;line-height:1.65}
.google-calendar-guide-card p{margin:0;color:#64748b;line-height:1.6;font-weight:700}
.google-calendar-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:10px}
.google-calendar-credential-field{display:grid;gap:8px;margin-top:14px}
.google-calendar-credential-field textarea{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:12.5px;line-height:1.55}
.google-calendar-clear-secret{margin-top:10px;padding:12px 14px;border:1px solid rgba(239,68,68,.18);border-radius:16px;background:#fff7f7;color:#991b1b;font-weight:800}
.google-calendar-actions{margin-top:16px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.google-calendar-sync-card{margin-top:18px;padding:18px}
.google-calendar-sync-card .data-table td small.text-danger{color:#b91c1c;font-weight:750;line-height:1.35;display:inline-block;margin-top:4px;max-width:320px;word-break:break-word}
.google-calendar-sync-card form{margin:0}
.google-calendar-sync-card .btn-sm{min-height:34px;padding:6px 10px;font-size:12px}
@media(max-width:1080px){.google-calendar-layout{grid-template-columns:1fr}.google-calendar-status-grid{grid-template-columns:1fr 1fr}}
@media(max-width:760px){.google-calendar-status-grid,.google-calendar-form-grid{grid-template-columns:1fr}.google-calendar-settings-card,.google-calendar-guide-card,.google-calendar-sync-card{padding:14px;border-radius:20px}.google-calendar-actions{display:grid;justify-content:stretch}.google-calendar-actions .btn{width:100%}.google-calendar-sync-card .table-responsive{border:0;box-shadow:none}.google-calendar-sync-card .data-table,.google-calendar-sync-card .data-table thead,.google-calendar-sync-card .data-table tbody,.google-calendar-sync-card .data-table th,.google-calendar-sync-card .data-table td,.google-calendar-sync-card .data-table tr{display:block}.google-calendar-sync-card .data-table thead{display:none}.google-calendar-sync-card .data-table tr{border:1px solid rgba(203,213,225,.9);border-radius:18px;background:#fff;margin-bottom:12px;padding:12px}.google-calendar-sync-card .data-table td{border:0!important;padding:6px 0!important}.google-calendar-sync-card .data-table td:before{display:block;color:#64748b;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.google-calendar-sync-card .data-table td:nth-child(1):before{content:'ใบลา'}.google-calendar-sync-card .data-table td:nth-child(2):before{content:'ผู้ลา'}.google-calendar-sync-card .data-table td:nth-child(3):before{content:'ช่วงวันที่'}.google-calendar-sync-card .data-table td:nth-child(4):before{content:'Action'}.google-calendar-sync-card .data-table td:nth-child(5):before{content:'สถานะ'}.google-calendar-sync-card .data-table td:nth-child(6):before{content:'Event ID'}.google-calendar-sync-card .data-table td:nth-child(7):before{content:'ล่าสุด'}.google-calendar-sync-card .data-table td:nth-child(8):before{content:'จัดการ'}.google-calendar-sync-card .btn{width:100%}}

/* Phase 2.8.71 — Google Calendar Settings UX/UI Layout Polish */
.google-calendar-hero-v2{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:24px!important;
  min-height:220px!important;
}
.google-calendar-hero-v2>div{min-width:0;max-width:900px}
.google-calendar-hero-actions-v2{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.google-calendar-hero-panel-v2{
  flex:0 0 220px;
  border:1px solid rgba(255,255,255,.32);
  border-radius:24px;
  background:rgba(255,255,255,.14);
  color:#fff;
  padding:18px;
  display:grid;
  gap:6px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 16px 36px rgba(2,6,23,.16);
}
.google-calendar-hero-panel-v2 span{font-size:12px;font-weight:900;opacity:.86;text-transform:uppercase;letter-spacing:.08em}
.google-calendar-hero-panel-v2 strong{font-size:34px;line-height:1;font-weight:1000;letter-spacing:-.04em}
.google-calendar-hero-panel-v2 small{font-size:13px;line-height:1.5;font-weight:700;opacity:.92}
.google-calendar-status-grid-v2{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:18px 0}
.google-calendar-status-card-v2{
  display:grid;
  grid-template-columns:46px minmax(0,1fr);
  gap:14px;
  align-items:start;
  padding:16px;
  border:1px solid rgba(203,213,225,.92);
  border-radius:22px;
  background:#fff;
  box-shadow:0 14px 34px rgba(6,36,58,.055);
  min-width:0;
}
.google-calendar-status-card-v2 .gcal-status-icon{
  width:42px;height:42px;border-radius:16px;display:grid;place-items:center;font-weight:1000;background:#e2f3f8;color:#0e5d89;
}
.google-calendar-status-card-v2 small{display:block;color:#64748b;font-size:12px;font-weight:900;margin-bottom:3px;text-transform:uppercase;letter-spacing:.04em}
.google-calendar-status-card-v2 strong{display:block;color:#0f172a;font-size:19px;line-height:1.25;letter-spacing:-.02em}
.google-calendar-status-card-v2 p{margin:4px 0 0;color:#64748b;font-size:13px;line-height:1.45;font-weight:700;word-break:break-word}
.google-calendar-status-card-v2.is-on{border-color:rgba(22,163,74,.26);background:linear-gradient(180deg,#fff 0%,#f0fdf4 100%)}
.google-calendar-status-card-v2.is-on .gcal-status-icon{background:#dcfce7;color:#15803d}
.google-calendar-status-card-v2.is-off{border-color:rgba(148,163,184,.32);background:linear-gradient(180deg,#fff,#f8fafc)}
.google-calendar-status-card-v2.is-warn{border-color:rgba(245,158,11,.32);background:linear-gradient(180deg,#fff,#fffbeb)}
.google-calendar-status-card-v2.is-warn .gcal-status-icon{background:#fef3c7;color:#b45309}
.google-calendar-layout-v2{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.55fr);gap:18px;align-items:start;margin-top:18px}
.google-calendar-settings-card-v2,.google-calendar-guide-card-v2,.google-calendar-sync-card-v2{border:1px solid rgba(203,213,225,.92);border-radius:24px;box-shadow:0 16px 38px rgba(6,36,58,.055);background:#fff}
.google-calendar-settings-card-v2{padding:18px;display:grid;gap:16px}
.google-calendar-section-header-v2{margin-bottom:0!important;padding-bottom:14px!important;border-bottom:1px solid rgba(226,232,240,.9)!important}
.google-calendar-section-header-v2 h3{margin:4px 0 3px;color:#0f172a;font-size:22px;line-height:1.25;letter-spacing:-.02em}
.google-calendar-section-header-v2 p{margin:0;color:#64748b;font-size:14px;line-height:1.6;font-weight:700}
.gcal-section-card-v2{border:1px solid rgba(203,213,225,.86);border-radius:22px;background:linear-gradient(180deg,#fff,#fbfdff);padding:18px;margin:0;min-width:0}
.gcal-section-card-v2 legend{padding:0 9px;color:#0f5e87;font-size:13px;font-weight:1000;letter-spacing:.02em}
.gcal-toggle-grid-v2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.gcal-toggle-card-v2{
  display:grid;
  grid-template-columns:26px minmax(0,1fr);
  gap:12px;
  align-items:start;
  min-height:92px;
  padding:14px;
  border:1px solid rgba(203,213,225,.82);
  border-radius:18px;
  background:#fff;
  cursor:pointer;
  transition:border-color .16s ease,box-shadow .16s ease,background .16s ease;
}
.gcal-toggle-card-v2:hover{border-color:rgba(14,93,137,.28);box-shadow:0 12px 28px rgba(6,36,58,.06);background:#fbfdff}
.gcal-toggle-card-v2 input{width:22px!important;height:22px!important;margin-top:2px!important;accent-color:#0e5d89;flex:0 0 auto}
.gcal-toggle-card-v2 strong{display:block;color:#0f172a;font-size:14px;line-height:1.35;font-weight:1000;margin-bottom:4px}
.gcal-toggle-card-v2 small{display:block;color:#64748b;font-size:12.5px;line-height:1.48;font-weight:700}
.gcal-toggle-card-v2.is-sensitive-option{border-color:rgba(245,158,11,.22);background:#fffdf7}
.gcal-field-grid-v2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}
.gcal-field-grid-v2 .field{display:grid;gap:7px;min-width:0;margin:0}
.gcal-field-span-2-v2{grid-column:1/-1}
.gcal-field-grid-v2 .form-label,.google-calendar-credential-field-v2 .form-label{font-size:13px;font-weight:1000;color:#0f172a;line-height:1.35}
.gcal-field-grid-v2 .input,.gcal-field-grid-v2 select,.google-calendar-credential-field-v2 .textarea{
  width:100%;min-height:46px;border:1px solid rgba(203,213,225,.96);border-radius:15px;background:#fff;color:#0f172a;font-weight:800;padding:10px 13px;box-shadow:0 1px 0 rgba(255,255,255,.8) inset;
}
.gcal-field-grid-v2 .input:focus,.gcal-field-grid-v2 select:focus,.google-calendar-credential-field-v2 .textarea:focus{outline:none;border-color:rgba(14,93,137,.52);box-shadow:0 0 0 4px rgba(14,93,137,.10)}
.gcal-field-grid-v2 .field-help,.google-calendar-credential-field-v2 .field-help{color:#64748b;font-size:12.5px;line-height:1.5;font-weight:700}
.gcal-credential-section-v2{background:linear-gradient(180deg,#fff,#f8fafc)}
.gcal-credential-grid-v2{display:grid;grid-template-columns:minmax(0,1fr) minmax(240px,.42fr);gap:14px;align-items:stretch}
.google-calendar-credential-field-v2{display:grid;gap:8px;margin:0;min-width:0}
.google-calendar-credential-field-v2 textarea{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:12.5px;line-height:1.55;resize:vertical;min-height:190px}
.gcal-credential-help-v2{border:1px solid rgba(203,213,225,.86);border-radius:18px;background:#fff;padding:14px;display:grid;gap:8px;align-content:start}
.gcal-credential-help-v2 strong{color:#0f172a;font-size:16px;font-weight:1000;line-height:1.35}
.gcal-credential-help-v2 p{margin:0;color:#64748b;font-size:13px;line-height:1.55;font-weight:700}
.gcal-clear-secret-v2{display:flex;align-items:flex-start;gap:9px;margin-top:6px;padding:11px;border:1px solid rgba(239,68,68,.18);border-radius:14px;background:#fff7f7;color:#991b1b;font-size:13px;font-weight:850;line-height:1.45;cursor:pointer}
.gcal-clear-secret-v2 input{width:18px!important;height:18px!important;margin-top:2px!important;accent-color:#dc2626}
.google-calendar-actions-v2{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;padding-top:4px}
.google-calendar-guide-card-v2{padding:18px;display:grid;gap:12px;align-content:start;position:sticky;top:86px}
.google-calendar-guide-card-v2 h3{margin:0;color:#0f172a;font-size:21px;line-height:1.25;letter-spacing:-.02em}
.google-calendar-guide-card-v2 ol{margin:0;padding:0;display:grid;gap:10px;counter-reset:gcal-step;list-style:none}
.google-calendar-guide-card-v2 li{counter-increment:gcal-step;display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;padding:12px;border:1px solid rgba(203,213,225,.82);border-radius:16px;background:#fbfdff}
.google-calendar-guide-card-v2 li:before{content:counter(gcal-step);width:30px;height:30px;border-radius:12px;display:grid;place-items:center;background:#e2f3f8;color:#0e5d89;font-size:12px;font-weight:1000}
.google-calendar-guide-card-v2 li strong{display:block;color:#0f172a;font-size:13.5px;line-height:1.3;font-weight:1000;margin-bottom:2px}
.google-calendar-guide-card-v2 li span{display:block;color:#64748b;font-size:12.5px;line-height:1.45;font-weight:700}
.gcal-privacy-note-v2{border:1px solid rgba(14,93,137,.15);border-radius:16px;background:#f0f9ff;padding:12px;color:#0f5e87}
.gcal-privacy-note-v2 strong{display:block;margin-bottom:3px;font-size:13px;font-weight:1000}
.gcal-privacy-note-v2 p{margin:0;font-size:12.5px;line-height:1.5;font-weight:750}
.google-calendar-sync-card-v2{margin-top:18px;padding:18px}
.google-calendar-sync-card-v2 .text-danger{color:#b91c1c;font-weight:800;line-height:1.35;display:inline-block;margin-top:4px;max-width:360px;word-break:break-word}
.google-calendar-sync-card-v2 form{margin:0}.google-calendar-sync-card-v2 .btn-sm{min-height:34px;padding:6px 10px;font-size:12px}
.google-calendar-sync-table-v2 td small{word-break:break-word}
@media(max-width:1180px){
  .google-calendar-hero-v2{align-items:flex-start!important}.google-calendar-hero-panel-v2{flex-basis:190px}
  .google-calendar-layout-v2{grid-template-columns:1fr}.google-calendar-guide-card-v2{position:static}.google-calendar-status-grid-v2{grid-template-columns:1fr 1fr}.gcal-credential-grid-v2{grid-template-columns:1fr}
}
@media(max-width:760px){
  .google-calendar-hero-v2{display:grid!important;min-height:0!important;gap:16px!important;padding:24px!important}.google-calendar-hero-panel-v2{width:100%;box-sizing:border-box}.google-calendar-hero-actions-v2{display:grid}.google-calendar-hero-actions-v2 .btn{width:100%}
  .google-calendar-status-grid-v2,.gcal-toggle-grid-v2,.gcal-field-grid-v2{grid-template-columns:1fr}.google-calendar-status-card-v2{grid-template-columns:40px 1fr;padding:14px}.google-calendar-status-card-v2 .gcal-status-icon{width:38px;height:38px;border-radius:14px}
  .google-calendar-settings-card-v2,.google-calendar-guide-card-v2,.google-calendar-sync-card-v2{padding:14px;border-radius:20px}.gcal-section-card-v2{padding:14px;border-radius:18px}.gcal-toggle-card-v2{min-height:0;padding:13px}.google-calendar-actions-v2{display:grid;justify-content:stretch}.google-calendar-actions-v2 .btn{width:100%}
  .google-calendar-sync-card-v2 .table-responsive{border:0;box-shadow:none}.google-calendar-sync-card-v2 .data-table,.google-calendar-sync-card-v2 .data-table thead,.google-calendar-sync-card-v2 .data-table tbody,.google-calendar-sync-card-v2 .data-table th,.google-calendar-sync-card-v2 .data-table td,.google-calendar-sync-card-v2 .data-table tr{display:block}.google-calendar-sync-card-v2 .data-table thead{display:none}.google-calendar-sync-card-v2 .data-table tr{border:1px solid rgba(203,213,225,.9);border-radius:18px;background:#fff;margin-bottom:12px;padding:12px}.google-calendar-sync-card-v2 .data-table td{border:0!important;padding:7px 0!important}.google-calendar-sync-card-v2 .data-table td:before{display:block;color:#64748b;font-size:11px;font-weight:1000;text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}.google-calendar-sync-card-v2 .data-table td:nth-child(1):before{content:'ใบลา'}.google-calendar-sync-card-v2 .data-table td:nth-child(2):before{content:'ผู้ลา'}.google-calendar-sync-card-v2 .data-table td:nth-child(3):before{content:'ช่วงวันที่'}.google-calendar-sync-card-v2 .data-table td:nth-child(4):before{content:'Action'}.google-calendar-sync-card-v2 .data-table td:nth-child(5):before{content:'สถานะ'}.google-calendar-sync-card-v2 .data-table td:nth-child(6):before{content:'Event ID'}.google-calendar-sync-card-v2 .data-table td:nth-child(7):before{content:'ล่าสุด'}.google-calendar-sync-card-v2 .data-table td:nth-child(8):before{content:'จัดการ'}.google-calendar-sync-card-v2 .btn{width:100%}
}
@media(max-width:430px){.google-calendar-hero-v2{padding:18px!important}.gcal-toggle-card-v2{grid-template-columns:24px 1fr}.google-calendar-guide-card-v2 li{grid-template-columns:1fr}.google-calendar-guide-card-v2 li:before{margin-bottom:2px}}

/* Phase 2.8.72 — Google Calendar settings layout rebalance */
.google-calendar-layout-v3{grid-template-columns:1fr;gap:0;margin-top:18px}
.google-calendar-settings-card-v3{padding:20px;gap:18px}
.gcal-setup-overview-v3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.gcal-setup-pill-v3{border:1px solid rgba(203,213,225,.9);border-radius:18px;background:linear-gradient(180deg,#fff,#fbfdff);padding:14px 15px;display:grid;gap:4px;min-width:0}
.gcal-setup-pill-v3 small{display:block;color:#64748b;font-size:11.5px;font-weight:1000;letter-spacing:.05em;text-transform:uppercase}
.gcal-setup-pill-v3 strong{display:block;color:#0f172a;font-size:17px;font-weight:1000;line-height:1.35}
.gcal-setup-pill-v3 span{display:block;color:#64748b;font-size:12.5px;font-weight:700;line-height:1.48;word-break:break-word}
.gcal-setup-pill-v3.is-ready{border-color:rgba(22,163,74,.24);background:linear-gradient(180deg,#fff,#f0fdf4)}
.gcal-setup-pill-v3.is-warn{border-color:rgba(245,158,11,.25);background:linear-gradient(180deg,#fff,#fffbeb)}
.gcal-setup-pill-v3.is-muted{border-color:rgba(148,163,184,.25);background:linear-gradient(180deg,#fff,#f8fafc)}
.gcal-config-grid-v3{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(280px,.8fr);gap:16px;align-items:start}
.gcal-config-card-v3,.gcal-side-note-card-v3{min-width:0}
.gcal-field-grid-v3{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px}
.gcal-field-span-full-v3{grid-column:1/-1}
.gcal-side-note-card-v3{display:grid;gap:14px;background:linear-gradient(180deg,#fff,#f8fbff)}
.gcal-checklist-v3{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.gcal-checklist-v3 li{position:relative;padding-left:28px;color:#334155;font-size:13px;font-weight:800;line-height:1.52}
.gcal-checklist-v3 li::before{content:'•';position:absolute;left:10px;top:0;color:#0e5d89;font-size:18px;line-height:1}
.gcal-checklist-v3 li.is-done::before{content:'✓';color:#15803d;font-size:15px;top:1px;left:8px}
.gcal-side-note-box-v3{border:1px solid rgba(14,93,137,.16);border-radius:16px;background:#f0f9ff;padding:13px}
.gcal-side-note-box-v3 strong{display:block;color:#0f5e87;font-size:13.5px;font-weight:1000;margin-bottom:3px}
.gcal-side-note-box-v3 p{margin:0;color:#0f5e87;font-size:12.5px;font-weight:750;line-height:1.55}
.gcal-credential-section-v3{padding-top:18px}
.gcal-credential-grid-v3{grid-template-columns:minmax(0,1.3fr) minmax(260px,.7fr);gap:16px}
.gcal-credential-help-v3{gap:12px}
.gcal-privacy-note-v3{margin-top:2px}
.google-calendar-help-grid-v3{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:18px}
.google-calendar-guide-card-v3{position:static;top:auto;padding:18px}
.gcal-scope-card-v3{background:linear-gradient(180deg,#fff,#f8fbff)}
@media (max-width:1100px){
  .gcal-config-grid-v3,.gcal-credential-grid-v3,.google-calendar-help-grid-v3{grid-template-columns:1fr}
}
@media (max-width:820px){
  .gcal-setup-overview-v3,.gcal-field-grid-v3{grid-template-columns:1fr}
  .google-calendar-settings-card-v3{padding:16px}
}
@media (max-width:640px){
  .gcal-setup-pill-v3,.gcal-side-note-box-v3,.gcal-side-note-card-v3{border-radius:16px}
  .gcal-config-grid-v3{gap:14px}
}

/* Phase 2.8.73 — Google Calendar settings simplify help/scope sections */
.google-calendar-help-grid-v3.is-removed{display:none!important}
.gcal-side-note-box-v3.is-removed{display:none!important}

/* Phase 2.8.85 — Super Admin full user/employee editor */
.user-employee-full-edit-panel{
  width:100%;
  border:1px solid rgba(14,93,137,.16);
  border-radius:18px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbfd 100%);
  overflow:hidden;
}
.user-employee-full-edit-panel>summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  cursor:pointer;
  color:#0b2a43;
  font-weight:900;
  list-style:none;
}
.user-employee-full-edit-panel>summary::-webkit-details-marker{display:none}
.user-employee-full-edit-panel>summary small{
  color:#64748b;
  font-weight:700;
}
.user-employee-full-edit-panel[open]>summary{
  border-bottom:1px solid rgba(203,213,225,.84);
  background:#f8fafc;
}
.user-full-edit-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
  padding:14px;
}
.user-full-edit-section{
  border:1px solid rgba(203,213,225,.84);
  border-radius:18px;
  background:#fff;
  padding:14px;
  box-shadow:0 8px 20px rgba(6,36,58,.035);
}
.user-full-edit-title{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  margin-bottom:12px;
  padding-bottom:10px;
  border-bottom:1px solid #eef2f7;
}
.user-full-edit-title strong{
  color:#0f172a;
  font-size:15px;
  font-weight:950;
}
.user-full-edit-title small{
  color:#64748b;
  font-size:12px;
  line-height:1.45;
  text-align:right;
}
.user-full-edit-fields{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  align-items:start;
}
.user-full-edit-fields-3{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.user-full-edit-span-2{grid-column:span 2}
.user-full-edit-toggle{
  min-height:44px;
  padding:10px 12px;
  border:1px solid rgba(203,213,225,.76);
  border-radius:14px;
  background:#f8fafc;
  color:#334155;
  font-weight:800;
}
.user-full-edit-warning{margin:0!important}
.user-full-edit-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px 14px;
  border-top:1px solid rgba(203,213,225,.84);
  background:#fbfdff;
}
.user-full-edit-actions span{
  color:#64748b;
  font-size:12.5px;
  line-height:1.5;
  font-weight:700;
}
@media(max-width:980px){
  .user-full-edit-fields,
  .user-full-edit-fields-3{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .user-employee-full-edit-panel>summary,
  .user-full-edit-title,
  .user-full-edit-actions{display:grid;gap:8px;text-align:left}
  .user-full-edit-title small{text-align:left}
  .user-full-edit-fields,
  .user-full-edit-fields-3{grid-template-columns:1fr}
  .user-full-edit-span-2{grid-column:auto}
  .user-full-edit-actions .button{width:100%}
}

/* Phase 2.8.88 — User employee editable master dropdown create fields */
.user-master-option-field{
    display:grid;
    gap:.55rem;
    min-width:0;
    padding:.72rem;
    border:1px solid rgba(203,213,225,.78);
    border-radius:16px;
    background:linear-gradient(180deg,#fff 0%,#f8fbfd 100%);
}
.user-master-option-field > label{
    display:grid;
    gap:.32rem;
    margin:0;
    min-width:0;
}
.user-master-option-field select,
.user-master-option-field input{
    width:100%;
    min-width:0;
}
.user-master-option-new{
    padding-top:.38rem;
    border-top:1px dashed rgba(148,163,184,.56);
}
.user-master-option-new .form-label{
    color:#475569;
    font-size:.78rem;
    font-weight:850;
}
.user-master-option-new .input{
    min-height:42px;
    background:#fff;
}
@media (max-width:760px){
    .user-master-option-field{
        padding:.65rem;
        border-radius:14px;
    }
}

/* Phase 2.8.89 — Super Admin user/employee avatar edit */
.user-employee-avatar.has-photo {
  padding: 0 !important;
  overflow: hidden;
  background: #eaf7fb !important;
}
.user-employee-avatar.has-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: inherit;
}
.user-full-edit-avatar-panel {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
  padding: 1rem;
  border: 1px solid rgba(203, 213, 225, .86);
  border-radius: 20px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbfd 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.88);
}
.user-full-edit-avatar-preview {
  width: 104px;
  height: 124px;
  border-radius: 18px;
  border: 1px solid rgba(14, 93, 137, .22);
  background: linear-gradient(135deg, #eaf7fb 0%, #dff3fa 100%);
  display: grid;
  place-items: center;
  color: var(--brand-800, #0e5d89);
  font-size: 2.35rem;
  font-weight: 1000;
  overflow: hidden;
}
.user-full-edit-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.user-full-edit-avatar-controls {
  display: grid;
  gap: .7rem;
  min-width: 0;
}
.user-full-edit-avatar-controls input[type="file"] {
  min-height: 46px;
  padding: .62rem .72rem;
}
@media (max-width: 720px) {
  .user-full-edit-avatar-panel {
    grid-template-columns: 1fr;
    justify-items: stretch;
  }
  .user-full-edit-avatar-preview {
    width: 96px;
    height: 112px;
    justify-self: center;
  }
}

/* Phase 2.8.92 — Login PDPA-safe balanced presentation */
.auth-login-showcase-pdpa .auth-hero-copy{
  max-width: 780px;
}
.auth-login-showcase-pdpa .auth-hero-copy h1{
  max-width: 760px;
}
.auth-login-showcase-pdpa .auth-hero-copy p{
  max-width: 720px;
  color: #334155;
}
.auth-process-card-compact .auth-process-step{
  min-height: 144px;
}
.auth-feature-pills-pdpa span{
  background: rgba(255,255,255,.92);
  border-color: rgba(14,93,137,.16);
  color: #334155;
}
.auth-login-card-pdpa{
  width:min(100%, 480px);
}
.auth-card-header-pdpa{
  align-items:flex-start;
}
.auth-card-header-pdpa h2{
  letter-spacing:-.035em;
}
.auth-card-header-pdpa p{
  color:#475569;
  line-height:1.55;
}
.auth-login-card-pdpa .auth-field label{
  color:#10263d;
  font-weight:950;
}
.auth-login-card-pdpa .auth-input-wrap{
  min-height:56px;
  border-color:#c9d9e9;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
}
.auth-login-card-pdpa .auth-input-wrap input::placeholder{
  color:#8a9bb0;
  font-weight:760;
}
.auth-login-card-pdpa .auth-submit{
  min-height:52px;
  border-radius:16px;
  font-size:1rem;
  font-weight:1000;
  box-shadow:0 16px 32px rgba(14,93,137,.18);
}
.auth-system-note-pdpa{
  border-color:#c8e8f2;
  background:linear-gradient(180deg,#f0fbff 0%,#f8fcff 100%);
}
.auth-system-note-pdpa strong{
  color:#075985;
}
.auth-system-note-pdpa span{
  line-height:1.6;
  color:#526477;
}
.auth-mini-grid-pdpa div{
  min-height:78px;
  display:grid;
  place-items:center;
  align-content:center;
  gap:.15rem;
  border-color:#dbe7f2;
  background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%);
}
.auth-mini-grid-pdpa span{
  color:#334155;
}
@media(max-width:1180px){
  .auth-login-showcase-pdpa .auth-hero-copy{
    margin-top:3.2rem;
  }
}
@media(max-width:760px){
  .auth-login-showcase-pdpa .auth-hero-copy h1{
    font-size:2.15rem;
    line-height:1.15;
  }
  .auth-login-showcase-pdpa .auth-hero-copy p{
    font-size:.98rem;
    line-height:1.72;
  }
  .auth-process-card-compact .auth-process-step{
    min-height:0;
    padding:.9rem;
  }
  .auth-login-card-pdpa{
    border-radius:24px;
  }
  .auth-card-header-pdpa{
    gap:.85rem;
  }
  .auth-card-header-pdpa .auth-card-logo{
    width:52px;
    height:52px;
    border-radius:18px;
  }
  .auth-system-note-pdpa{
    padding:.8rem;
  }
}


/* Phase 2.9.0 — system logo + favicon + PWA install support */
.brand-mark.brand-mark-image,.auth-card-logo.brand-mark-image,.auth-brand-mark.brand-mark-image{padding:0;overflow:hidden;background:transparent!important;box-shadow:none!important;text-shadow:none!important;border:0!important}
.brand-mark.brand-mark-image img,.auth-card-logo.brand-mark-image img,.auth-brand-mark.brand-mark-image img{display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit;box-shadow:0 16px 34px rgba(6,36,58,.16)}
.brand-mark.brand-mark-image{width:48px;height:48px;border-radius:18px}
.auth-brand-mark.brand-mark-image{width:64px;height:64px;border-radius:22px}
.auth-card-logo.brand-mark-image{width:58px;height:58px;border-radius:20px}
@media (max-width: 640px){.auth-brand-mark.brand-mark-image{width:56px;height:56px;border-radius:20px}}


/* Phase 2.9.1 — polished mobile splash, app name and complete logo placement */
:root{--app-splash-gradient:linear-gradient(135deg,#031a2d 0%,#063a5a 46%,#0d7fa8 100%)}
.topbar-title-wrap{display:flex;align-items:center;gap:12px;min-width:0}
.topbar-app-mark{width:42px;height:42px;flex:0 0 auto;border-radius:16px;overflow:hidden;display:grid;place-items:center;background:#06243a;box-shadow:0 12px 26px rgba(6,36,58,.14)}
.topbar-app-mark img{width:100%;height:100%;object-fit:cover;display:block}
.app-boot-splash{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:var(--app-splash-gradient);transition:opacity .38s ease,visibility .38s ease;overflow:hidden}
.app-boot-splash::before{content:"";position:absolute;inset:-25%;background:radial-gradient(circle at 28% 16%,rgba(19,165,199,.42),transparent 28%),radial-gradient(circle at 84% 86%,rgba(255,153,0,.16),transparent 30%);filter:blur(2px)}
.app-boot-splash-card{position:relative;display:grid;justify-items:center;gap:14px;text-align:center;color:#fff;padding:24px;min-width:230px}
.app-boot-splash-logo{width:104px;height:104px;border-radius:30px;display:block;box-shadow:0 24px 72px rgba(0,0,0,.34),0 0 0 1px rgba(255,255,255,.18)}
.app-boot-splash-title{font-size:24px;font-weight:700;letter-spacing:-.02em;line-height:1.2;text-shadow:0 2px 10px rgba(0,0,0,.24)}
.app-boot-splash-subtitle{font-size:13px;line-height:1.55;color:rgba(255,255,255,.82);font-weight:400}
.app-boot-splash-loader{width:58px;height:4px;border-radius:999px;background:rgba(255,255,255,.24);overflow:hidden;margin-top:4px}
.app-boot-splash-loader::after{content:"";display:block;width:42%;height:100%;border-radius:inherit;background:#ff9900;animation:appSplashLoader 1.1s ease-in-out infinite}
body.app-splash-ready .app-boot-splash{opacity:0;visibility:hidden;pointer-events:none}
.error-card .system-logo,.verify-card .system-logo{width:82px;height:82px;border-radius:24px;display:block;margin:0 auto 14px;box-shadow:0 16px 42px rgba(6,36,58,.16)}
.verify-mark.has-logo{background:transparent!important;box-shadow:none!important;width:auto;height:auto;border-radius:0;margin-bottom:8px}
@keyframes appSplashLoader{0%{transform:translateX(-110%)}50%{transform:translateX(82%)}100%{transform:translateX(240%)}}
@media (prefers-reduced-motion:reduce){.app-boot-splash,.app-boot-splash-loader::after{animation:none!important;transition:none!important}}
@media (max-width:760px){.topbar-app-mark{width:38px;height:38px;border-radius:14px}.app-boot-splash-logo{width:96px;height:96px}.app-boot-splash-title{font-size:22px}}


/* Phase 2.9.2 — Mobile topbar action fix
   Fixes notification dropdown clipping on mobile and keeps logout reachable without adding an install button. */
.topbar-user .topbar-logout-form{margin:0;display:inline-flex;align-items:center;flex:0 0 auto}
.topbar-logout-button{white-space:nowrap}
.topbar-logout-text{display:inline}

@media (max-width: 760px){
  .topbar{
    align-items:center!important;
    overflow:visible!important;
    gap:8px!important;
    padding:9px 10px!important;
  }
  .topbar-title-wrap{
    flex:1 1 auto!important;
    min-width:0!important;
    gap:8px!important;
  }
  .topbar-title-wrap h1{
    white-space:nowrap!important;
    overflow:hidden!important;
    text-overflow:ellipsis!important;
    max-width:100%!important;
  }
  .topbar-user{
    flex:0 0 auto!important;
    overflow:visible!important;
    gap:6px!important;
    min-width:auto!important;
    scrollbar-width:auto!important;
  }
  .topbar-user::-webkit-scrollbar{display:none!important}
  .topbar-user .topbar-chip{
    display:none!important;
  }
  .notification-menu{
    position:static!important;
    z-index:120!important;
    flex:0 0 auto!important;
  }
  .notification-bell,
  .user-chip,
  .topbar-logout-button{
    width:42px!important;
    height:42px!important;
    min-width:42px!important;
    min-height:42px!important;
    border-radius:15px!important;
  }
  .notification-bell{
    display:grid!important;
    place-items:center!important;
  }
  .notification-dropdown{
    position:fixed!important;
    top:66px!important;
    left:10px!important;
    right:10px!important;
    width:auto!important;
    max-width:none!important;
    max-height:calc(100dvh - 82px)!important;
    z-index:999!important;
    border-radius:20px!important;
    overflow:hidden!important;
    box-shadow:0 24px 70px rgba(3,26,45,.28)!important;
  }
  .notification-dropdown-list{
    max-height:calc(100dvh - 178px)!important;
    overflow:auto!important;
  }
  .notification-dropdown-head{
    padding:13px 14px!important;
  }
  .notification-dropdown-head a{
    min-height:34px!important;
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    padding:0 10px!important;
    border-radius:999px!important;
    background:#e8f6fb!important;
    color:#0e5d89!important;
    text-decoration:none!important;
  }
  .user-chip{
    padding:0!important;
    justify-content:center!important;
    border-radius:15px!important;
    flex:0 0 auto!important;
  }
  .user-chip .user-avatar{
    width:34px!important;
    height:34px!important;
    border-radius:12px!important;
  }
  .user-chip span{
    display:none!important;
  }
  .topbar-user form.topbar-logout-form .topbar-logout-button{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    padding:0!important;
    background:#fff7f7!important;
    color:#b91c1c!important;
    border:1px solid #fecaca!important;
    box-shadow:0 8px 20px rgba(185,28,28,.08)!important;
    font-size:0!important;
  }
  .topbar-logout-button::before{
    content:"ออก";
    font-size:12px!important;
    line-height:1!important;
    font-weight:700!important;
    letter-spacing:-.01em!important;
  }
  .topbar-logout-text{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
  }
}

@media (max-width: 420px){
  .topbar-app-mark{
    display:none!important;
  }
  .topbar-title-wrap h1{
    font-size:.94rem!important;
  }
  .notification-bell,
  .user-chip,
  .topbar-logout-button{
    width:40px!important;
    height:40px!important;
    min-width:40px!important;
    min-height:40px!important;
  }
}


/* Phase 2.9.3 — Leave create subject/recipient suggestion stacking fix
   Keep the suggestion list inside normal form flow so it never overlaps the next field. */
.form-card,
.premium-form-card,
.form-grid,
.premium-form-grid,
.leave-text-suggestion-group,
.leave-system-combobox {
  overflow: visible !important;
}
.leave-text-suggestion-group {
  position: relative;
  z-index: 1;
}
.leave-text-suggestion-group.is-suggest-open {
  z-index: 60 !important;
}
.leave-text-suggestion-group.is-suggest-open .leave-system-combobox {
  z-index: 61 !important;
}
.leave-text-suggestion-group.is-suggest-open .leave-system-suggest-menu {
  position: relative !important;
  inset: auto !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  display: block;
  width: 100% !important;
  margin-top: 8px !important;
  max-height: min(320px, 42vh) !important;
  z-index: 62 !important;
}
.leave-text-suggestion-group.is-suggest-open .leave-system-suggest-menu[hidden] {
  display: none !important;
}
.leave-text-suggestion-group.is-suggest-open .leave-suggestion-panel {
  margin-top: 10px;
}
@media (max-width: 760px) {
  .leave-text-suggestion-group.is-suggest-open .leave-system-suggest-menu {
    max-height: min(300px, 44vh) !important;
    border-radius: 18px !important;
    box-shadow: 0 18px 44px rgba(6,36,58,.18) !important;
  }
}


/* Phase 2.9.4 — debug-only impersonation tool for manual capture */
.debug-impersonation-login-panel,
.debug-impersonation-panel{
  border:1px solid #d7dde6;
  background:#fff;
  border-radius:18px;
  padding:14px;
  margin:16px 0 0;
  color:#26364a;
  box-shadow:0 10px 24px rgba(15,23,42,.055);
}
.debug-impersonation-login-panel{
  border-left:4px solid #7c3aed;
}
.debug-impersonation-login-panel[open]{
  border-color:#c9d2df;
  box-shadow:0 14px 30px rgba(15,23,42,.075);
}
.debug-impersonation-login-panel summary{
  list-style:none;
  cursor:pointer;
}
.debug-impersonation-login-panel summary::-webkit-details-marker{display:none}
.debug-capture-summary{
  display:flex;
  align-items:center;
  gap:12px;
}
.debug-capture-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:58px;
  height:30px;
  border-radius:999px;
  border:1px solid #ddd6fe;
  background:#f5f3ff;
  color:#6d28d9;
  font-size:12px;
  font-weight:650;
  letter-spacing:.02em;
}
.debug-capture-title-wrap{
  display:grid;
  gap:2px;
  min-width:0;
}
.debug-capture-title-wrap strong,
.debug-impersonation-panel strong{
  color:#1f2937;
  font-size:15px;
  font-weight:650;
}
.debug-capture-title-wrap small,
.debug-impersonation-panel p{
  color:#64748b;
  font-size:12.5px;
  line-height:1.45;
}
.debug-impersonation-form,
.debug-impersonation-inline-form{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.debug-capture-login-form{
  padding-top:14px;
  border-top:1px solid #edf1f6;
}
.debug-capture-note{
  display:grid;
  gap:3px;
  border:1px solid #e6eaf0;
  background:#f8fafc;
  border-radius:14px;
  padding:11px 12px;
}
.debug-capture-note strong{
  color:#334155;
  font-size:13px;
  font-weight:650;
}
.debug-capture-note span{
  color:#667085;
  font-size:12.5px;
  line-height:1.5;
}
.debug-capture-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,1fr) minmax(120px,.65fr);
  gap:12px;
  align-items:end;
}
.debug-capture-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.debug-capture-actions .button{
  min-height:42px;
}
.debug-capture-help{
  color:#667085;
  font-size:12.5px;
  line-height:1.4;
}
.debug-impersonation-panel{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,1.55fr);
  align-items:end;
  gap:14px;
  border-left:4px solid #7c3aed;
}
.debug-impersonation-inline-form{
  grid-template-columns:minmax(160px,1fr) minmax(180px,1fr) minmax(110px,.7fr) auto;
  align-items:end;
}
.topbar-chip-inspect{
  background:#f5f3ff!important;
  color:#6d28d9!important;
  border:1px solid #ddd6fe!important;
}
@media (max-width:900px){
  .debug-impersonation-panel{grid-template-columns:1fr}
  .debug-impersonation-inline-form{grid-template-columns:1fr}
  .debug-capture-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .debug-impersonation-login-panel{padding:12px;border-radius:16px}
  .debug-capture-summary{align-items:flex-start;gap:10px}
  .debug-capture-badge{min-width:auto;height:28px;padding:0 9px}
  .debug-capture-actions{display:grid;grid-template-columns:1fr}
  .debug-capture-actions .button{width:100%}
  .topbar-chip-inspect{display:inline-flex!important;font-size:10px;padding:5px 7px}
}


/* Phase 2.9.6 — embed protected interactive manual in /settings/tutorial */
.tutorial-manual-embed-card{
  margin-bottom:18px;
  padding:18px;
  overflow:hidden;
}
.tutorial-manual-embed-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line-soft,#edf3f8);
}
.tutorial-manual-embed-head h3{
  margin:4px 0 6px;
  color:var(--brand-900,#06243a);
  font-size:22px;
  font-weight:650;
}
.tutorial-manual-embed-head p{
  margin:0;
  max-width:820px;
  color:var(--muted,#607086);
  line-height:1.65;
}
.tutorial-manual-embed-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.tutorial-manual-embed-toolbar{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  gap:10px;
  margin:14px 0;
  padding:10px 12px;
  border:1px solid #dbeafe;
  border-radius:16px;
  background:#eff6ff;
  color:#0b3b5f;
  font-size:13px;
  font-weight:520;
}
.tutorial-manual-frame{
  width:100%;
  min-height:82vh;
  height:980px;
  border:1px solid var(--line,#dbe5f0);
  border-radius:22px;
  background:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.65),0 16px 36px rgba(6,36,58,.08);
}
@media (max-width:900px){
  .tutorial-manual-embed-head{display:grid}
  .tutorial-manual-embed-actions{justify-content:flex-start}
  .tutorial-manual-frame{height:86vh;min-height:720px;border-radius:18px}
}
@media (max-width:640px){
  .tutorial-manual-embed-card{padding:12px;border-radius:20px}
  .tutorial-manual-embed-head h3{font-size:18px}
  .tutorial-manual-frame{height:82vh;min-height:640px;border-radius:16px}
}


/* Phase 2.9.7 — split Interactive Manual and Live Tutorial settings into separate menus */
.tutorial-manual-hero .page-hero-actions,
.tutorial-settings-hero .page-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.tutorial-manual-standalone-card{
  min-height:calc(100vh - 180px);
}
.tutorial-manual-frame-standalone{
  min-height:78vh;
}
@media (max-width:760px){
  .tutorial-manual-frame-standalone{min-height:72vh}
  .tutorial-manual-hero .page-hero-actions,
  .tutorial-settings-hero .page-hero-actions{width:100%}
}

/* Phase 2.9.11 — role default home page selector */
.permission-role-home-card{
  border:1px solid #dbeafe;
  background:linear-gradient(135deg,#eff6ff 0%,#ffffff 100%);
  border-radius:20px;
  padding:14px;
  margin:14px 0 16px;
}
.permission-role-home-field{display:grid;gap:7px;margin:0!important}
.permission-role-home-field .select{min-height:46px;background:#fff}
@media (max-width:720px){
  .permission-role-home-card{padding:12px;border-radius:18px}
}


/* Phase 2.9.15 — pending approval count badge in sidebar menu */
.nav-label-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:8px;
  min-width:0;
}
.nav-label-row strong{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.nav-count-badge{
  flex:0 0 auto;
  min-width:22px;
  height:22px;
  padding:0 7px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#dc2626;
  color:#fff;
  font-size:11px;
  line-height:1;
  font-weight:700;
  box-shadow:0 8px 18px rgba(220,38,38,.22);
}
.nav a.is-active .nav-count-badge{
  background:#fff;
  color:#b91c1c;
  box-shadow:0 8px 18px rgba(255,255,255,.16);
}
@media (max-width: 720px){
  .nav-count-badge{
    min-width:24px;
    height:24px;
    font-size:11px;
  }
}


/* Phase 2.9.17 — approval reject/return comment validation */
.approval-comment-required-note{display:inline-flex;margin-left:6px;vertical-align:middle}
.approval-comment-help{display:block;margin-top:6px;color:#7b8794;font-size:12px;line-height:1.45}
.approval-action-form textarea.is-invalid{border-color:#dc2626!important;box-shadow:0 0 0 3px rgba(220,38,38,.12)!important;background:#fff7f7!important}


/* Phase 2.9.18 — approval validation must use system toast/inline alert, never browser alert() */
.approval-comment-inline-error{
  margin-top:8px;
  padding:10px 12px;
  border:1px solid #fed7aa;
  border-radius:14px;
  background:#fff7ed;
  color:#9a3412;
  font-size:13px;
  line-height:1.55;
  font-weight:500;
  box-shadow:0 10px 22px rgba(154,52,18,.08);
}
.approval-comment-inline-error[hidden]{display:none!important}


/* Phase 2.9.19 — Employee signature management for official documents */
.user-employee-signature-panel{width:100%;border:1px solid #dbeafe;background:linear-gradient(135deg,#eff6ff 0%,#fff 100%);border-radius:18px;padding:0;overflow:hidden}
.user-employee-signature-panel>summary{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;padding:12px 14px;color:#06243a;font-weight:600}
.user-employee-signature-panel>summary small{font-weight:400;color:#607086;text-align:right}.signature-admin-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:14px;padding:14px;border-top:1px solid #dbeafe}.signature-current-card,.signature-manage-form{border:1px solid #dbe5f0;border-radius:18px;background:#fff;padding:14px;display:grid;gap:12px}.signature-current-card strong{color:#06243a;font-size:14px}.signature-preview-box{min-height:118px;border:1px dashed #bfd0e5;border-radius:16px;background:#f8fbfd;display:grid;place-items:center;color:#64748b;text-align:center;padding:12px}.signature-preview-box.has-signature{background:#fff;border-style:solid}.signature-preview-box img{max-width:100%;max-height:112px;object-fit:contain}.signature-draw-field{display:grid;gap:8px}.signature-draw-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.signature-canvas{width:100%;height:170px;border:1px solid #cbd5e1;border-radius:16px;background:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.65);touch-action:none;cursor:crosshair}.button-danger{background:#fee2e2!important;border-color:#fecaca!important;color:#991b1b!important}.button-danger:hover{background:#fecaca!important}@media(max-width:900px){.signature-admin-layout{grid-template-columns:1fr}.signature-canvas{height:150px}.user-employee-signature-panel>summary{align-items:flex-start;flex-direction:column}.user-employee-signature-panel>summary small{text-align:left}}


/* Phase 2.9.23 — realtime signature preview no-cache controls */
.signature-refresh-button{margin-top:.75rem;width:100%;justify-content:center}
.signature-preview-box.has-signature img{cursor:pointer}
.signature-preview-box.has-signature img:hover{filter:contrast(1.05);transform:translateY(-1px)}

/* Phase 2.9.31 — User employee list sort note */
.user-employee-sort-note{
  margin:10px 0 0;
  color:var(--muted, #64748b);
  font-size:13px;
  line-height:1.5;
}


/* Phase 2.9.32 — readable approval history timeline */
.my-approval-history-card{overflow:hidden}
.approval-history-summary{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 14px;
}
.approval-history-summary span{
  display:inline-flex;
  align-items:center;
  gap:6px;
  border:1px solid var(--line);
  background:#f8fafc;
  border-radius:999px;
  padding:7px 10px;
  color:var(--muted);
  font-size:12px;
}
.approval-history-summary strong{color:var(--ink);font-weight:650}
.approval-readable-timeline{
  position:relative;
  display:grid;
  gap:14px;
}
.approval-readable-item{
  position:relative;
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  gap:12px;
}
.approval-readable-item::before{
  content:"";
  position:absolute;
  left:20px;
  top:42px;
  bottom:-18px;
  width:2px;
  background:#dbe5ee;
}
.approval-readable-item:last-child::before{display:none}
.approval-readable-marker{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:center;
}
.approval-readable-marker span{
  width:40px;
  height:40px;
  border-radius:16px;
  display:grid;
  place-items:center;
  color:#334155;
  background:#eef2f7;
  border:1px solid #d9e2ec;
  font-weight:750;
  box-shadow:0 8px 18px rgba(15,23,42,.08);
}
.approval-readable-item.is-done .approval-readable-marker span,
.approval-readable-item.is-info .approval-readable-marker span{background:#e0f2fe;border-color:#7dd3fc;color:#075985}
.approval-readable-item.is-current .approval-readable-marker span{background:#fff7ed;border-color:#fdba74;color:#9a3412}
.approval-readable-item.is-rejected .approval-readable-marker span{background:#fee2e2;border-color:#fca5a5;color:#991b1b}
.approval-readable-item.is-returned .approval-readable-marker span{background:#fef3c7;border-color:#fbbf24;color:#92400e}
.approval-readable-item.is-upcoming .approval-readable-marker span,
.approval-readable-item.is-skipped .approval-readable-marker span{background:#f8fafc;border-color:#e2e8f0;color:#94a3b8}
.approval-readable-content{
  border:1px solid var(--line);
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);
  border-radius:20px;
  padding:14px;
  box-shadow:0 12px 26px rgba(15,23,42,.06);
}
.approval-readable-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.approval-readable-head strong{
  display:block;
  color:var(--ink);
  font-size:15px;
  font-weight:700;
}
.approval-readable-head small{
  display:block;
  color:var(--muted);
  margin-top:2px;
  font-size:12px;
}
.approval-readable-badge{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  padding:5px 9px;
  font-size:12px;
  font-weight:700;
  border:1px solid #dbeafe;
  background:#eff6ff;
  color:#1d4ed8;
  white-space:nowrap;
}
.approval-readable-badge.is-done{background:#ecfdf5;border-color:#a7f3d0;color:#047857}
.approval-readable-badge.is-current{background:#fff7ed;border-color:#fed7aa;color:#c2410c}
.approval-readable-badge.is-rejected{background:#fef2f2;border-color:#fecaca;color:#b91c1c}
.approval-readable-badge.is-returned{background:#fffbeb;border-color:#fde68a;color:#b45309}
.approval-readable-badge.is-upcoming,
.approval-readable-badge.is-skipped{background:#f8fafc;border-color:#e2e8f0;color:#64748b}
.approval-readable-hint{
  margin:6px 0 0;
  color:var(--muted);
  font-size:13px;
  line-height:1.55;
}
.approval-readable-actions{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.approval-readable-action{
  border:1px solid #e2e8f0;
  background:#fff;
  border-radius:16px;
  padding:11px 12px;
}
.approval-readable-action.is-success{border-color:#bbf7d0;background:#f0fdf4}
.approval-readable-action.is-danger{border-color:#fecaca;background:#fef2f2}
.approval-readable-action.is-warning{border-color:#fde68a;background:#fffbeb}
.approval-readable-action.is-info{border-color:#bae6fd;background:#f0f9ff}
.approval-readable-action-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.approval-readable-action-top strong{
  color:var(--ink);
  font-size:14px;
  font-weight:700;
}
.approval-readable-action-top time{
  color:var(--muted);
  font-size:12px;
  white-space:nowrap;
}
.approval-readable-action small{
  display:block;
  margin-top:4px;
  color:#475569;
  line-height:1.45;
}
.approval-readable-action p{
  margin:8px 0 0;
  padding:9px 10px;
  border-radius:12px;
  background:rgba(255,255,255,.76);
  color:#334155;
  line-height:1.55;
}
.approval-readable-extra{
  margin-left:54px;
  border:1px dashed #cbd5e1;
  background:#f8fafc;
  border-radius:18px;
  padding:12px;
  display:grid;
  gap:10px;
}
.approval-readable-extra>strong{color:var(--ink);font-weight:700}
@media (max-width:640px){
  .approval-readable-item{grid-template-columns:34px minmax(0,1fr);gap:10px}
  .approval-readable-item::before{left:16px}
  .approval-readable-marker span{width:34px;height:34px;border-radius:14px;font-size:13px}
  .approval-readable-content{padding:12px;border-radius:18px}
  .approval-readable-head{display:grid;gap:8px}
  .approval-readable-badge{justify-self:start}
  .approval-readable-action-top{display:grid;gap:3px}
  .approval-readable-action-top time{white-space:normal}
  .approval-readable-extra{margin-left:0}
}

/* Phase 2.9.38 — Guard master employee data changes */
.user-master-change-confirm{
  grid-column:1 / -1;
  padding:12px 14px;
  border:1px solid rgba(245,158,11,.35);
  background:linear-gradient(135deg, rgba(255,247,237,.95), rgba(255,255,255,.98));
  border-radius:14px;
}
.user-master-change-confirm .checkline{
  align-items:flex-start;
  gap:10px;
  font-weight:650;
  color:#92400e;
}
.user-master-change-confirm input[type="checkbox"]{
  margin-top:4px;
}

/* Phase 2.9.39 — Live Tutorial Settings modern layout */
.tutorial-pro-hero{
  position:relative;
  overflow:hidden;
}
.tutorial-pro-hero:after{
  content:"";
  position:absolute;
  inset:auto -80px -130px auto;
  width:280px;
  height:280px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(19,165,199,.28),rgba(19,165,199,0) 68%);
  pointer-events:none;
}
.tutorial-pro-hero-copy{
  position:relative;
  z-index:1;
  max-width:860px;
}
.tutorial-pro-hero-actions{
  position:relative;
  z-index:1;
  align-items:center;
}
.tutorial-pro-status-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}
.tutorial-pro-status,
.tutorial-pro-chip{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 11px;
  border-radius:999px;
  font-size:12px;
  font-weight:760;
  border:1px solid rgba(219,229,240,.88);
  background:rgba(255,255,255,.88);
  color:#334155;
  box-shadow:0 6px 18px rgba(6,36,58,.08);
}
.tutorial-pro-status.is-on{
  background:#ecfdf5;
  border-color:#bbf7d0;
  color:#047857;
}
.tutorial-pro-status.is-off{
  background:#fff1f2;
  border-color:#fecdd3;
  color:#be123c;
}
.tutorial-pro-overview{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
  margin:18px 0;
}
.tutorial-pro-metric{
  display:flex;
  align-items:flex-start;
  gap:13px;
  padding:16px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:22px;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  box-shadow:0 16px 38px rgba(6,36,58,.07);
}
.tutorial-pro-metric-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  height:48px;
  padding:0 9px;
  border-radius:16px;
  color:#fff;
  font-size:11px;
  font-weight:900;
  letter-spacing:.04em;
  background:linear-gradient(135deg,#0b3b5f,#0d7fa8);
  box-shadow:0 10px 22px rgba(13,127,168,.24);
}
.tutorial-pro-metric.is-success .tutorial-pro-metric-icon{background:linear-gradient(135deg,#047857,#10b981)}
.tutorial-pro-metric.is-info .tutorial-pro-metric-icon,
.tutorial-pro-metric.is-blue .tutorial-pro-metric-icon{background:linear-gradient(135deg,#075985,#0284c7)}
.tutorial-pro-metric.is-muted .tutorial-pro-metric-icon{background:linear-gradient(135deg,#64748b,#94a3b8)}
.tutorial-pro-metric strong{
  display:block;
  color:#0f172a;
  font-size:15px;
  font-weight:860;
  margin:2px 0 5px;
}
.tutorial-pro-metric p{
  margin:0;
  color:#64748b;
  line-height:1.55;
  font-size:13px;
  font-weight:560;
}
.tutorial-pro-layout{
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(310px,.7fr);
  gap:18px;
  align-items:start;
}
.tutorial-pro-card{
  border:1px solid rgba(219,229,240,.95)!important;
  border-radius:26px!important;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)!important;
  box-shadow:0 18px 46px rgba(6,36,58,.08)!important;
}
.tutorial-pro-settings-card{
  padding:20px!important;
}
.tutorial-pro-card-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  padding-bottom:16px;
  border-bottom:1px solid rgba(219,229,240,.75);
}
.tutorial-pro-card-head h3,
.tutorial-pro-flow-card h3,
.tutorial-pro-note-card h3{
  margin:4px 0 7px;
  color:#06243a;
  font-size:22px;
  font-weight:760;
}
.tutorial-pro-card-head p{
  margin:0;
  color:#607086;
  line-height:1.62;
  max-width:720px;
}
.tutorial-pro-mini-badge{
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
  padding:7px 10px;
  border-radius:999px;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  color:#0b3b5f;
  font-size:12px;
  font-weight:780;
}
.tutorial-pro-toggle-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin:18px 0;
}
.tutorial-pro-toggle-card{
  position:relative;
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:12px;
  min-height:140px;
  padding:16px;
  border:1px solid rgba(203,213,225,.9);
  border-radius:22px;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
  cursor:pointer;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.tutorial-pro-toggle-card:hover{
  transform:translateY(-1px);
  border-color:rgba(13,127,168,.36);
  box-shadow:0 16px 34px rgba(6,36,58,.09);
}
.tutorial-pro-toggle-card input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.tutorial-pro-toggle-mark{
  width:42px;
  height:24px;
  border-radius:999px;
  background:#cbd5e1;
  border:1px solid rgba(148,163,184,.8);
  box-shadow:inset 0 1px 2px rgba(15,23,42,.12);
  position:relative;
  margin-top:2px;
}
.tutorial-pro-toggle-mark:after{
  content:"";
  position:absolute;
  width:18px;
  height:18px;
  left:2px;
  top:2px;
  border-radius:999px;
  background:#fff;
  box-shadow:0 2px 7px rgba(15,23,42,.24);
  transition:left .18s ease;
}
.tutorial-pro-toggle-card input:checked + .tutorial-pro-toggle-mark{
  background:linear-gradient(135deg,#0e5d89,#0d7fa8);
  border-color:#0d7fa8;
}
.tutorial-pro-toggle-card input:checked + .tutorial-pro-toggle-mark:after{
  left:20px;
}
.tutorial-pro-toggle-card.is-warning input:checked + .tutorial-pro-toggle-mark{
  background:linear-gradient(135deg,#c2410c,#f59e0b);
  border-color:#f59e0b;
}
.tutorial-pro-toggle-body strong{
  display:block;
  color:#0f172a;
  font-weight:820;
  line-height:1.35;
  margin-bottom:6px;
}
.tutorial-pro-toggle-body small{
  display:block;
  color:#64748b;
  line-height:1.55;
  font-weight:540;
}
.tutorial-pro-fields{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
  margin-top:8px;
}
.tutorial-pro-field{
  margin:0!important;
  padding:14px;
  border:1px solid rgba(219,229,240,.86);
  border-radius:20px;
  background:#fff;
}
.tutorial-pro-field .select,
.tutorial-pro-field .input{
  min-height:46px;
  background:#f8fafc;
}
.tutorial-pro-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:flex-end;
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid rgba(219,229,240,.75);
}
.tutorial-pro-side{
  display:grid;
  gap:18px;
}
.tutorial-pro-flow-card,
.tutorial-pro-note-card{
  padding:18px!important;
}
.tutorial-pro-flow{
  display:grid;
  gap:12px;
  margin-top:14px;
}
.tutorial-pro-flow-step{
  display:grid;
  grid-template-columns:38px minmax(0,1fr);
  gap:12px;
  align-items:start;
  padding:12px;
  border:1px solid rgba(219,229,240,.8);
  border-radius:18px;
  background:#fff;
}
.tutorial-pro-flow-step > span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:14px;
  background:linear-gradient(135deg,#0b3b5f,#0d7fa8);
  color:#fff;
  font-weight:900;
}
.tutorial-pro-flow-step strong{
  display:block;
  color:#0f172a;
  font-weight:780;
  margin-bottom:4px;
}
.tutorial-pro-flow-step p{
  margin:0;
  color:#64748b;
  line-height:1.52;
  font-size:13px;
}
.tutorial-pro-note-card ul{
  display:grid;
  gap:9px;
  margin:13px 0 0;
  padding:0;
  list-style:none;
}
.tutorial-pro-note-card li{
  position:relative;
  padding-left:24px;
  color:#475569;
  line-height:1.55;
  font-weight:560;
}
.tutorial-pro-note-card li:before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  background:#ecfdf5;
  color:#047857;
  font-size:11px;
  font-weight:900;
}
@media (max-width:1180px){
  .tutorial-pro-layout{grid-template-columns:1fr}
  .tutorial-pro-side{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:900px){
  .tutorial-pro-overview,
  .tutorial-pro-toggle-grid,
  .tutorial-pro-side{grid-template-columns:1fr}
  .tutorial-pro-card-head{display:grid}
  .tutorial-pro-mini-badge{justify-self:start}
}
@media (max-width:640px){
  .tutorial-pro-hero-actions,
  .tutorial-pro-actions{width:100%;justify-content:stretch}
  .tutorial-pro-hero-actions .btn,
  .tutorial-pro-actions .btn{width:100%;justify-content:center}
  .tutorial-pro-fields{grid-template-columns:1fr}
  .tutorial-pro-settings-card{padding:14px!important;border-radius:22px!important}
  .tutorial-pro-toggle-card{min-height:auto}
  .tutorial-pro-overview{margin:14px 0}
}

/* Phase 2.9.41 — Permission management quick search/filter */
.permission-search-card{
  margin-bottom:18px;
  border:1px solid rgba(191,219,254,.95)!important;
  background:linear-gradient(135deg,#eff6ff 0%,#ffffff 54%,#f8fbff 100%)!important;
}
.permission-search-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:14px;
}
.permission-search-head h3{
  margin:4px 0 6px;
  color:var(--brand-900,#06243a);
  font-size:21px;
  font-weight:760;
}
.permission-search-head p{
  margin:0;
  color:var(--muted,#607086);
  line-height:1.62;
}
.permission-search-counter{
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:7px 12px;
  border-radius:999px;
  border:1px solid #bfdbfe;
  background:#fff;
  color:#0b3b5f;
  font-size:12px;
  font-weight:820;
  box-shadow:0 8px 20px rgba(13,127,168,.08);
}
.permission-search-grid{
  display:grid;
  grid-template-columns:minmax(260px,1.25fr) minmax(220px,.55fr) auto;
  gap:12px;
  align-items:end;
}
.permission-search-main .input{
  min-height:48px;
  font-weight:650;
}
.permission-search-actions{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.permission-search-actions .button{
  min-height:44px;
}
.permission-search-tips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.permission-search-tips span{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 9px;
  border-radius:999px;
  border:1px solid rgba(219,229,240,.9);
  background:rgba(255,255,255,.86);
  color:#64748b;
  font-size:12px;
  font-weight:640;
}
.permission-role-card.is-filter-hidden,
.permission-module-card.is-filter-hidden,
.permission-checkline.is-filter-hidden,
.permission-user-card.is-filter-hidden{
  display:none!important;
}
.permission-checkline.is-search-hit{
  border-color:rgba(13,127,168,.35)!important;
  background:linear-gradient(135deg,#eff6ff 0%,#ffffff 100%)!important;
  box-shadow:0 8px 20px rgba(13,127,168,.08);
}
.permission-role-card.is-search-hit,
.permission-user-card.is-search-hit{
  outline:2px solid rgba(13,127,168,.18);
  outline-offset:3px;
}
.permission-checkline.has-permission-checked strong:after{
  content:"ใช้งาน";
  display:inline-flex;
  margin-left:7px;
  padding:2px 6px;
  border-radius:999px;
  background:#ecfdf5;
  color:#047857;
  font-size:10px;
  font-weight:820;
  vertical-align:middle;
}
@media (max-width:1120px){
  .permission-search-grid{
    grid-template-columns:1fr 1fr;
  }
  .permission-search-actions{
    grid-column:1 / -1;
    justify-content:flex-start;
  }
}
@media (max-width:720px){
  .permission-search-head{
    display:grid;
  }
  .permission-search-counter{
    justify-self:start;
    white-space:normal;
    border-radius:14px;
  }
  .permission-search-grid{
    grid-template-columns:1fr;
  }
  .permission-search-actions .button{
    width:100%;
  }
}

/* Phase 2.9.42 — Vacation year default entitlement panel */
.vacation-default-year-panel{
  margin:4px 0 8px;
  padding:16px;
  border:1px solid rgba(13,127,168,.18);
  border-radius:22px;
  background:linear-gradient(135deg,#eff6ff 0%,#ffffff 55%,#f8fbff 100%);
  box-shadow:0 14px 34px rgba(6,36,58,.06);
}
.vacation-default-year-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(219,229,240,.78);
}
.vacation-default-year-head h3{
  margin:3px 0 5px;
  color:var(--brand-900,#06243a);
  font-size:20px;
  font-weight:760;
}
.vacation-default-year-head p{
  margin:0;
  color:var(--muted,#607086);
  line-height:1.55;
}
.vacation-default-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.vacation-default-apply{
  margin-top:12px;
  padding:12px;
  border:1px solid rgba(22,129,90,.22);
  border-radius:18px;
  background:#f0fdf4;
}
.vacation-default-apply strong{
  display:block;
  color:#065f46;
  margin-bottom:2px;
}
.vacation-default-apply small{
  display:block;
  color:#047857;
  line-height:1.5;
}
@media (max-width:1180px){
  .vacation-default-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:720px){
  .vacation-default-year-head{display:grid}
  .vacation-default-grid{grid-template-columns:1fr}
  .vacation-default-year-panel{padding:13px;border-radius:18px}
}

/* Phase 2.9.44 — Vacation policy premium layout */
.vacation-pro-hero{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(13,127,168,.16);
}
.vacation-pro-hero:before{
  content:"";
  position:absolute;
  inset:-80px -120px auto auto;
  width:340px;
  height:340px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(13,127,168,.26),rgba(13,127,168,0) 68%);
  pointer-events:none;
}
.vacation-pro-hero-copy{
  position:relative;
  z-index:1;
  max-width:850px;
}
.vacation-pro-hero-actions{
  position:relative;
  z-index:2;
  align-items:center;
}
.vacation-pro-hero-badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}
.vacation-pro-hero-badges span,
.vacation-pro-soft-badge{
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 11px;
  border-radius:999px;
  border:1px solid rgba(219,229,240,.92);
  background:rgba(255,255,255,.9);
  color:#334155;
  font-size:12px;
  font-weight:760;
  box-shadow:0 6px 18px rgba(6,36,58,.08);
}
.vacation-pro-kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:18px 0;
}
.vacation-pro-kpi-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:13px;
  align-items:start;
  padding:16px;
  border:1px solid rgba(219,229,240,.95);
  border-radius:22px;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  box-shadow:0 16px 38px rgba(6,36,58,.07);
}
.vacation-pro-kpi-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:50px;
  height:50px;
  border-radius:16px;
  color:#fff;
  font-size:13px;
  font-weight:900;
  background:linear-gradient(135deg,#0b3b5f,#0d7fa8);
  box-shadow:0 10px 22px rgba(13,127,168,.24);
}
.vacation-pro-kpi-card.is-success .vacation-pro-kpi-icon{background:linear-gradient(135deg,#047857,#10b981)}
.vacation-pro-kpi-card.is-info .vacation-pro-kpi-icon{background:linear-gradient(135deg,#075985,#0284c7)}
.vacation-pro-kpi-card.is-warning .vacation-pro-kpi-icon{background:linear-gradient(135deg,#c2410c,#f59e0b)}
.vacation-pro-kpi-card small{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:740;
  margin-bottom:4px;
}
.vacation-pro-kpi-card strong{
  display:block;
  color:#0f172a;
  font-size:21px;
  font-weight:860;
  line-height:1.25;
}
.vacation-pro-kpi-card p{
  margin:4px 0 0;
  color:#64748b;
  font-size:13px;
  line-height:1.45;
}
.vacation-pro-layout{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(300px,.65fr);
  gap:18px;
  align-items:start;
  margin-bottom:18px;
}
.vacation-pro-side{
  display:grid;
  gap:18px;
}
.vacation-pro-card{
  border:1px solid rgba(219,229,240,.96)!important;
  border-radius:26px!important;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)!important;
  box-shadow:0 18px 46px rgba(6,36,58,.08)!important;
}
.vacation-pro-year-card,
.vacation-pro-policy-card,
.vacation-pro-carry-card,
.vacation-pro-history-card,
.vacation-pro-rule-card,
.vacation-pro-calc-card{
  padding:20px!important;
}
.vacation-pro-card-head{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin-bottom:16px;
  padding-bottom:16px;
  border-bottom:1px solid rgba(219,229,240,.76);
}
.vacation-pro-card-head h3,
.vacation-pro-rule-card h3,
.vacation-pro-calc-card h3{
  margin:4px 0 7px;
  color:#06243a;
  font-size:22px;
  font-weight:780;
}
.vacation-pro-card-head p,
.vacation-pro-rule-card p,
.vacation-pro-calc-card p{
  margin:0;
  color:#607086;
  line-height:1.62;
}
.vacation-pro-year-picker{
  margin:0 0 14px;
  padding:14px;
  border:1px solid rgba(219,229,240,.88);
  border-radius:20px;
  background:#f8fbff;
}
.vacation-pro-year-picker .field,
.vacation-pro-year-form .field,
.vacation-pro-carry-filter .field{
  margin:0;
}
.vacation-pro-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.vacation-pro-span-2{
  grid-column:1 / -1;
}
.vacation-pro-default-panel{
  margin:16px 0;
  padding:16px;
  border:1px solid rgba(13,127,168,.18);
  border-radius:24px;
  background:linear-gradient(135deg,#eff6ff 0%,#ffffff 55%,#f8fbff 100%);
}
.vacation-pro-default-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:14px;
  padding-bottom:12px;
  border-bottom:1px solid rgba(219,229,240,.8);
}
.vacation-pro-default-head h4{
  margin:3px 0 5px;
  color:#06243a;
  font-size:20px;
  font-weight:760;
}
.vacation-pro-default-head p{
  margin:0;
  color:#607086;
  line-height:1.55;
}
.vacation-pro-default-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.vacation-pro-checkline{
  margin-top:12px;
  padding:12px;
  border:1px solid rgba(22,129,90,.22);
  border-radius:18px;
  background:#f0fdf4;
}
.vacation-pro-checkline strong{
  display:block;
  color:#065f46;
  margin-bottom:2px;
}
.vacation-pro-checkline small{
  display:block;
  color:#047857;
  line-height:1.5;
}
.vacation-pro-form-actions,
.vacation-pro-policy-actions,
.vacation-pro-carry-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(219,229,240,.76);
}
.vacation-pro-form-actions span,
.vacation-pro-policy-actions span,
.vacation-pro-carry-actions span{
  color:#64748b;
  font-size:13px;
  line-height:1.55;
  font-weight:560;
}
.vacation-pro-rule-list{
  display:grid;
  gap:10px;
  margin-top:14px;
}
.vacation-pro-rule-list div{
  display:grid;
  grid-template-columns:42px minmax(0,1fr);
  gap:11px;
  padding:12px;
  border:1px solid rgba(219,229,240,.82);
  border-radius:18px;
  background:#fff;
}
.vacation-pro-rule-list span{
  grid-row:1 / span 2;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:14px;
  background:linear-gradient(135deg,#0b3b5f,#0d7fa8);
  color:#fff;
  font-size:12px;
  font-weight:900;
}
.vacation-pro-rule-list strong{
  color:#0f172a;
  font-weight:780;
  margin-top:1px;
}
.vacation-pro-rule-list small{
  color:#64748b;
  line-height:1.45;
}
.vacation-pro-formula{
  display:grid;
  gap:8px;
  margin:14px 0;
}
.vacation-pro-formula div{
  padding:11px 12px;
  border-radius:16px;
  border:1px solid rgba(191,219,254,.8);
  background:#eff6ff;
  color:#0b3b5f;
  font-weight:760;
}
.vacation-pro-formula b{
  justify-self:center;
  color:#0d7fa8;
}
.vacation-pro-policy-list{
  display:grid;
  gap:16px;
}
.vacation-pro-policy-row{
  padding:16px;
  border:1px solid rgba(219,229,240,.94);
  border-radius:24px;
  background:#fff;
  box-shadow:0 10px 28px rgba(6,36,58,.055);
}
.vacation-pro-policy-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:14px;
}
.vacation-pro-policy-head h4{
  margin:3px 0 5px;
  color:#0f172a;
  font-size:19px;
  font-weight:800;
}
.vacation-pro-policy-head p{
  margin:0;
  color:#64748b;
  line-height:1.48;
}
.vacation-pro-policy-sections{
  display:grid;
  gap:12px;
}
.vacation-pro-policy-fieldset,
.vacation-pro-check-grid{
  border:1px solid rgba(219,229,240,.86);
  border-radius:20px;
  padding:14px;
  background:linear-gradient(180deg,#fff,#f8fafc);
}
.vacation-pro-policy-fieldset legend,
.vacation-pro-check-grid legend{
  padding:0 8px;
  color:#0b3b5f;
  font-weight:800;
  font-size:13px;
}
.vacation-pro-policy-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.vacation-pro-policy-grid .field{
  margin:0;
}
.vacation-pro-check-grid{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.vacation-pro-check-grid legend{
  width:auto;
}
.vacation-pro-check-grid label{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:38px;
  padding:8px 11px;
  border:1px solid rgba(203,213,225,.88);
  border-radius:999px;
  background:#fff;
  color:#334155;
  font-weight:680;
}
.vacation-pro-check-grid input{
  width:16px;
  height:16px;
}
.vacation-pro-carry-head{
  align-items:flex-start;
}
.vacation-pro-carry-filter{
  min-width:260px;
  padding:12px;
  border-radius:18px;
  background:#f8fbff;
  border:1px solid rgba(219,229,240,.86);
}
.vacation-pro-summary-grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:10px;
  margin-bottom:14px;
}
.vacation-pro-summary-grid div{
  padding:14px;
  border:1px solid rgba(219,229,240,.88);
  border-radius:18px;
  background:linear-gradient(180deg,#fff,#f8fafc);
}
.vacation-pro-summary-grid span{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:760;
  margin-bottom:5px;
}
.vacation-pro-summary-grid strong{
  display:block;
  color:#0f172a;
  font-size:20px;
  font-weight:850;
}
.vacation-pro-summary-grid small{
  display:block;
  margin-top:4px;
  color:#64748b;
  line-height:1.4;
}
.vacation-pro-alert{
  margin:0 0 14px!important;
  border-radius:18px!important;
}
.vacation-pro-table{
  border:1px solid rgba(219,229,240,.86);
  border-radius:20px;
  overflow:auto;
}
.vacation-pro-table table{
  margin:0;
}
@media (max-width:1220px){
  .vacation-pro-kpi-grid,
  .vacation-pro-default-grid,
  .vacation-pro-policy-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .vacation-pro-summary-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}
@media (max-width:980px){
  .vacation-pro-layout{
    grid-template-columns:1fr;
  }
  .vacation-pro-side{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .vacation-pro-card-head,
  .vacation-pro-default-head,
  .vacation-pro-policy-head,
  .vacation-pro-carry-head{
    display:grid;
  }
  .vacation-pro-carry-filter{
    width:100%;
    min-width:0;
  }
}
@media (max-width:720px){
  .vacation-pro-kpi-grid,
  .vacation-pro-side,
  .vacation-pro-form-grid,
  .vacation-pro-default-grid,
  .vacation-pro-policy-grid,
  .vacation-pro-summary-grid{
    grid-template-columns:1fr;
  }
  .vacation-pro-year-card,
  .vacation-pro-policy-card,
  .vacation-pro-carry-card,
  .vacation-pro-history-card,
  .vacation-pro-rule-card,
  .vacation-pro-calc-card{
    padding:14px!important;
    border-radius:22px!important;
  }
  .vacation-pro-hero-actions,
  .vacation-pro-form-actions,
  .vacation-pro-policy-actions,
  .vacation-pro-carry-actions{
    align-items:stretch;
    justify-content:stretch;
  }
  .vacation-pro-hero-actions .btn,
  .vacation-pro-form-actions .btn,
  .vacation-pro-policy-actions .btn,
  .vacation-pro-carry-actions .btn{
    width:100%;
    justify-content:center;
  }
  .vacation-pro-policy-row{
    padding:13px;
    border-radius:20px;
  }
  .vacation-pro-check-grid{
    display:grid;
  }
  .vacation-pro-check-grid label{
    border-radius:14px;
    justify-content:flex-start;
  }
}

/* Phase 2.9.45 — Vacation default entitlement layout fix */
.vacation-pro-default-panel{
  overflow:hidden;
}
.vacation-pro-default-grid .field{
  min-width:0;
}
.vacation-pro-default-grid .input{
  width:100%;
  box-sizing:border-box;
}
.vacation-pro-checkline{
  display:flex!important;
  width:100%!important;
  max-width:100%!important;
  box-sizing:border-box!important;
  align-items:flex-start!important;
  gap:12px!important;
  margin:14px 0 0!important;
  padding:13px 14px!important;
  border:1px solid rgba(22,129,90,.22)!important;
  border-radius:18px!important;
  background:linear-gradient(135deg,#f0fdf4 0%,#ffffff 100%)!important;
  color:#065f46!important;
  line-height:1.5!important;
}
.vacation-pro-checkline input[type="checkbox"]{
  flex:0 0 auto!important;
  width:18px!important;
  height:18px!important;
  margin:3px 0 0!important;
  accent-color:#047857;
}
.vacation-pro-checkline-copy{
  display:block!important;
  min-width:0!important;
  flex:1 1 auto!important;
}
.vacation-pro-checkline-copy strong,
.vacation-pro-checkline strong{
  display:block!important;
  margin:0 0 3px!important;
  color:#065f46!important;
  font-weight:820!important;
}
.vacation-pro-checkline-copy small,
.vacation-pro-checkline small{
  display:block!important;
  margin:0!important;
  color:#047857!important;
  line-height:1.55!important;
  font-size:12.5px!important;
  white-space:normal!important;
}
@media (max-width:720px){
  .vacation-pro-default-head .status-badge{
    justify-self:start;
  }
  .vacation-pro-checkline{
    border-radius:16px!important;
    padding:12px!important;
  }
}

/* Phase 2.9.46 — Approval route assignment edit/delete */
.approval-approver-actions-v2{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  justify-content:flex-end;
}
.approval-approver-edit{
  position:relative;
}
.approval-approver-edit > summary{
  list-style:none;
  cursor:pointer;
}
.approval-approver-edit > summary::-webkit-details-marker{
  display:none;
}
.approval-assignment-edit-form{
  position:absolute;
  z-index:30;
  right:0;
  top:calc(100% + 10px);
  width:min(720px, calc(100vw - 48px));
  padding:16px;
  border:1px solid rgba(13,127,168,.22);
  border-radius:22px;
  background:#fff;
  box-shadow:0 26px 70px rgba(6,36,58,.18);
}
.approval-assignment-edit-form:before{
  content:"";
  position:absolute;
  top:-8px;
  right:34px;
  width:16px;
  height:16px;
  transform:rotate(45deg);
  background:#fff;
  border-left:1px solid rgba(13,127,168,.22);
  border-top:1px solid rgba(13,127,168,.22);
}
.approval-assignment-edit-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.approval-assignment-edit-grid .field{
  margin:0;
}
.approval-assignment-active-check{
  margin:12px 0 0!important;
  padding:10px 12px;
  border:1px solid rgba(22,129,90,.22);
  border-radius:16px;
  background:#f0fdf4;
  color:#065f46;
  font-weight:760;
}
.approval-assignment-edit-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(219,229,240,.78);
}
.approval-assignment-create-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.btn-danger,
button.btn-danger,
a.btn-danger{
  background:linear-gradient(135deg,#dc2626,#ef4444)!important;
  color:#fff!important;
  border-color:#dc2626!important;
  box-shadow:0 10px 22px rgba(220,38,38,.18)!important;
}
.btn-danger:hover,
button.btn-danger:hover,
a.btn-danger:hover{
  filter:brightness(.98);
  transform:translateY(-1px);
}
@media (max-width:900px){
  .approval-approver-actions-v2{
    justify-content:flex-start;
  }
  .approval-assignment-edit-form{
    position:fixed;
    left:14px;
    right:14px;
    top:90px;
    width:auto;
    max-height:calc(100vh - 120px);
    overflow:auto;
  }
  .approval-assignment-edit-form:before{
    display:none;
  }
}
@media (max-width:640px){
  .approval-assignment-edit-grid{
    grid-template-columns:1fr;
  }
  .approval-assignment-create-actions .btn,
  .approval-assignment-edit-actions .btn,
  .approval-approver-actions-v2 .btn{
    width:100%;
    justify-content:center;
  }
  .approval-approver-actions-v2 form{
    width:100%;
  }
}

/* Phase 2.9.47 — Approval assignment form/button overlap fix */
.approval-assignment-workspace{
  overflow:visible!important;
}
.approval-assignment-workspace .approval-assignment-form{
  display:grid!important;
  gap:14px!important;
  overflow:visible!important;
}
.approval-assignment-workspace .approval-assignment-grid{
  grid-template-columns:minmax(180px,.95fr) minmax(260px,1.35fr) minmax(150px,.65fr) minmax(220px,1fr)!important;
  gap:14px!important;
  align-items:end!important;
}
.approval-assignment-workspace .approval-assignment-grid .field{
  min-width:0!important;
}
.approval-assignment-workspace .approval-assignment-grid .select,
.approval-assignment-workspace .approval-assignment-grid .input{
  width:100%!important;
  min-width:0!important;
  box-sizing:border-box!important;
}
.approval-assignment-create-actions{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:center!important;
  gap:12px!important;
  margin-top:0!important;
  padding-top:14px!important;
  border-top:1px solid rgba(191,219,254,.85)!important;
}
.approval-assignment-create-actions .approval-studio-check{
  min-width:0!important;
  margin:0!important;
}
.approval-assignment-create-actions .btn{
  white-space:nowrap!important;
}
.approval-approver-card{
  overflow:visible!important;
}
.approval-approver-actions-v2{
  min-width:0!important;
  max-width:100%!important;
  align-self:start!important;
}
.approval-approver-edit{
  position:static!important;
  min-width:0!important;
}
.approval-approver-edit[open]{
  flex:1 1 100%!important;
  width:100%!important;
  order:20!important;
}
.approval-assignment-edit-form{
  position:static!important;
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  margin-top:10px!important;
  box-sizing:border-box!important;
  box-shadow:0 16px 38px rgba(6,36,58,.11)!important;
}
.approval-assignment-edit-form:before{
  display:none!important;
}
.approval-assignment-edit-grid{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
}
.approval-assignment-edit-grid .field,
.approval-assignment-edit-grid .select,
.approval-assignment-edit-grid .input{
  min-width:0!important;
}
.approval-assignment-edit-actions{
  justify-content:flex-end!important;
}
@media (max-width:1320px){
  .approval-assignment-workspace .approval-assignment-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}
@media (max-width:900px){
  .approval-approver-card{
    grid-template-columns:44px minmax(0,1fr)!important;
  }
  .approval-approver-actions-v2{
    grid-column:1 / -1!important;
    justify-content:flex-start!important;
    width:100%!important;
  }
  .approval-assignment-edit-form{
    position:static!important;
    left:auto!important;
    right:auto!important;
    top:auto!important;
    max-height:none!important;
    overflow:visible!important;
  }
}
@media (max-width:720px){
  .approval-assignment-workspace .approval-assignment-grid,
  .approval-assignment-edit-grid{
    grid-template-columns:1fr!important;
  }
  .approval-assignment-create-actions{
    grid-template-columns:1fr!important;
    align-items:stretch!important;
  }
  .approval-assignment-create-actions .btn,
  .approval-assignment-edit-actions .btn,
  .approval-approver-actions-v2 .btn{
    width:100%!important;
    justify-content:center!important;
  }
  .approval-approver-actions-v2,
  .approval-approver-actions-v2 form,
  .approval-approver-edit{
    width:100%!important;
  }
}

/* Phase 2.9.48 — User employee department/unit fields */
.user-employee-info-grid div:nth-child(3) strong{
  color:#0b3b5f;
}
.user-master-option-field .field-help{
  margin-top:4px;
}

/* Phase 2.9.49 — Approval routes full layout redesign */
.approval-v3-hero{
  display:flex;
  align-items:stretch;
  justify-content:space-between;
  gap:20px;
  margin:0 0 18px;
  padding:26px;
  border:1px solid rgba(191,219,254,.88);
  border-radius:30px;
  background:
    radial-gradient(circle at right top,rgba(13,127,168,.20),rgba(13,127,168,0) 36%),
    linear-gradient(135deg,#06243a 0%,#0b3b5f 46%,#0d7fa8 100%);
  color:#fff;
  box-shadow:0 22px 60px rgba(6,36,58,.18);
  overflow:hidden;
}
.approval-v3-hero-main{
  max-width:880px;
  position:relative;
  z-index:1;
}
.approval-v3-kicker{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:#0d7fa8;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.approval-v3-hero .approval-v3-kicker{
  color:#b8f0ff;
}
.approval-v3-hero h2{
  margin:8px 0 8px;
  font-size:clamp(26px,4vw,40px);
  font-weight:860;
  line-height:1.12;
}
.approval-v3-hero p{
  margin:0;
  max-width:760px;
  color:rgba(255,255,255,.82);
  line-height:1.7;
}
.approval-v3-hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}
.approval-v3-hero-note{
  align-self:center;
  min-width:160px;
  padding:18px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:24px;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  text-align:center;
}
.approval-v3-hero-note strong{
  display:block;
  font-size:42px;
  font-weight:900;
  line-height:1;
}
.approval-v3-hero-note span{
  display:block;
  margin-top:6px;
  color:rgba(255,255,255,.82);
  font-weight:700;
}
.approval-v3-kpi-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin-bottom:18px;
}
.approval-v3-kpi{
  padding:16px;
  border:1px solid rgba(219,229,240,.95);
  border-radius:22px;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  box-shadow:0 14px 34px rgba(6,36,58,.075);
}
.approval-v3-kpi span{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:800;
}
.approval-v3-kpi strong{
  display:block;
  margin:3px 0;
  color:#0f172a;
  font-size:30px;
  font-weight:900;
  line-height:1.05;
}
.approval-v3-kpi small{
  display:block;
  color:#64748b;
  line-height:1.45;
}
.approval-v3-kpi.is-blue{border-color:rgba(13,127,168,.22)}
.approval-v3-kpi.is-green{border-color:rgba(16,185,129,.22)}
.approval-v3-kpi.is-warning{border-color:rgba(245,158,11,.34);background:linear-gradient(180deg,#fff 0%,#fffbeb 100%)}
.approval-v3-kpi.is-ok{border-color:rgba(16,185,129,.28);background:linear-gradient(180deg,#fff 0%,#ecfdf5 100%)}
.approval-v3-layout{
  display:grid;
  grid-template-columns:minmax(310px,360px) minmax(0,1fr);
  gap:18px;
  align-items:start;
}
.approval-v3-sidebar{
  position:sticky;
  top:88px;
  max-height:calc(100vh - 110px);
  overflow:auto;
  padding:16px;
  border:1px solid rgba(219,229,240,.95);
  border-radius:28px;
  background:linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow:0 18px 46px rgba(6,36,58,.08);
}
.approval-v3-sidebar-head{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding-bottom:12px;
  margin-bottom:12px;
  border-bottom:1px solid rgba(219,229,240,.82);
}
.approval-v3-sidebar-head h3,
.approval-v3-section-title h3,
.approval-v3-selected-header h3{
  margin:4px 0 5px;
  color:#06243a;
  font-size:22px;
  font-weight:820;
  line-height:1.25;
}
.approval-v3-sidebar-head p,
.approval-v3-section-title p{
  margin:0;
  color:#64748b;
  line-height:1.55;
}
.approval-v3-search{
  margin-bottom:12px;
}
.approval-v3-route-list{
  display:grid;
  gap:10px;
}
.approval-v3-route-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  padding:12px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:18px;
  background:#fff;
  color:inherit;
  text-decoration:none;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
}
.approval-v3-route-card:hover{
  transform:translateY(-1px);
  border-color:rgba(13,127,168,.32);
  box-shadow:0 12px 26px rgba(6,36,58,.08);
}
.approval-v3-route-card.is-active{
  border-color:rgba(13,127,168,.44);
  background:linear-gradient(135deg,#eff6ff,#ffffff);
  box-shadow:0 14px 30px rgba(13,127,168,.12);
}
.approval-v3-route-avatar,
.approval-v3-approver-avatar{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:15px;
  background:linear-gradient(135deg,#06243a,#0d7fa8);
  color:#fff;
  font-size:16px;
  font-weight:900;
  box-shadow:0 10px 24px rgba(13,127,168,.2);
}
.approval-v3-route-content{
  min-width:0;
}
.approval-v3-route-content strong{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#0f172a;
  font-weight:820;
}
.approval-v3-route-content small{
  display:block;
  margin-top:2px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#64748b;
}
.approval-v3-route-status{
  display:inline-flex;
  align-items:center;
  white-space:nowrap;
  min-height:28px;
  padding:5px 9px;
  border-radius:999px;
  font-size:11px;
  font-weight:860;
}
.approval-v3-route-status.is-ready{
  background:#ecfdf5;
  color:#047857;
}
.approval-v3-route-status.is-warning{
  background:#fffbeb;
  color:#b45309;
}
.approval-v3-empty-filter{
  margin-top:10px;
  padding:12px;
  border-radius:16px;
  background:#f8fafc;
  color:#64748b;
  text-align:center;
}
.approval-v3-create-route{
  margin-top:14px;
  border-top:1px solid rgba(219,229,240,.82);
  padding-top:14px;
}
.approval-v3-create-route > summary,
.approval-v3-add-step > summary,
.approval-v3-edit-box > summary{
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:9px 12px;
  border-radius:16px;
  border:1px solid rgba(13,127,168,.22);
  background:#eff6ff;
  color:#0b3b5f;
  font-weight:820;
  list-style:none;
}
.approval-v3-create-route > summary::-webkit-details-marker,
.approval-v3-add-step > summary::-webkit-details-marker,
.approval-v3-edit-box > summary::-webkit-details-marker{
  display:none;
}
.approval-v3-create-route-form{
  display:grid;
  gap:10px;
  margin-top:12px;
}
.approval-v3-main{
  display:grid;
  gap:18px;
  min-width:0;
}
.approval-v3-empty-state{
  padding:44px 22px;
  border:1px dashed rgba(148,163,184,.7);
  border-radius:28px;
  background:linear-gradient(180deg,#fff,#f8fafc);
  text-align:center;
}
.approval-v3-empty-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:64px;
  height:64px;
  border-radius:22px;
  background:#eff6ff;
  color:#0d7fa8;
  font-size:28px;
  font-weight:900;
}
.approval-v3-empty-state h3{
  margin:14px 0 6px;
  color:#0f172a;
}
.approval-v3-empty-state p{
  margin:0 auto;
  max-width:520px;
  color:#64748b;
  line-height:1.65;
}
.approval-v3-selected-header,
.approval-v3-card,
.approval-v3-process-card,
.approval-v3-warning-card,
.approval-v3-ready-card{
  padding:18px;
  border:1px solid rgba(219,229,240,.96);
  border-radius:28px;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%);
  box-shadow:0 18px 46px rgba(6,36,58,.075);
}
.approval-v3-selected-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
}
.approval-v3-status{
  display:inline-flex;
  min-height:30px;
  padding:6px 11px;
  border-radius:999px;
  font-size:12px;
  font-weight:860;
}
.approval-v3-status.is-ready{
  background:#ecfdf5;
  color:#047857;
}
.approval-v3-status.is-warning{
  background:#fffbeb;
  color:#b45309;
}
.approval-v3-pills{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.approval-v3-pills span{
  display:inline-flex;
  align-items:center;
  gap:5px;
  min-height:30px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(219,229,240,.9);
  background:#fff;
  color:#64748b;
  font-size:12px;
  font-weight:700;
}
.approval-v3-pills strong{
  color:#0f172a;
}
.approval-v3-quick-nav{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  justify-content:flex-end;
}
.approval-v3-quick-nav a{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(191,219,254,.9);
  background:#eff6ff;
  color:#0b3b5f;
  text-decoration:none;
  font-size:13px;
  font-weight:800;
}
.approval-v3-warning-card{
  background:linear-gradient(180deg,#fff 0%,#fff7ed 100%);
  border-color:rgba(251,146,60,.32);
}
.approval-v3-warning-card strong{
  color:#9a3412;
}
.approval-v3-warning-card ul{
  margin:8px 0 0;
  padding-left:20px;
  color:#7c2d12;
}
.approval-v3-ready-card{
  background:linear-gradient(180deg,#fff 0%,#ecfdf5 100%);
  color:#047857;
  font-weight:800;
}
.approval-v3-section-title{
  margin-bottom:14px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(219,229,240,.82);
}
.approval-v3-process{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.approval-v3-process-step{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:4px 10px;
  min-width:min(240px,100%);
  flex:1 1 230px;
  padding:12px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:18px;
  background:#fff;
  color:inherit;
  text-decoration:none;
}
.approval-v3-process-step span,
.approval-v3-step-no{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;
  height:44px;
  border-radius:16px;
  background:#eff6ff;
  color:#0b3b5f;
  font-weight:900;
}
.approval-v3-process-step.is-final span{
  background:#ecfdf5;
  color:#047857;
}
.approval-v3-process-step strong{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#0f172a;
}
.approval-v3-process-step small{
  grid-column:2;
  color:#64748b;
}
.approval-v3-form-grid,
.approval-v3-step-form-grid,
.approval-v3-assignment-grid,
.approval-v3-assignment-edit-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.approval-v3-assignment-grid{
  grid-template-columns:minmax(180px,.9fr) minmax(260px,1.4fr) minmax(160px,.7fr) minmax(220px,1fr);
}
.approval-v3-span-2{
  grid-column:span 2;
}
.approval-v3-form-grid .field,
.approval-v3-step-form-grid .field,
.approval-v3-assignment-grid .field,
.approval-v3-assignment-edit-grid .field{
  margin:0;
  min-width:0;
}
.approval-v3-form-grid .input,
.approval-v3-form-grid .select,
.approval-v3-step-form-grid .input,
.approval-v3-step-form-grid .select,
.approval-v3-assignment-grid .input,
.approval-v3-assignment-grid .select,
.approval-v3-assignment-edit-grid .input,
.approval-v3-assignment-edit-grid .select{
  width:100%;
  min-width:0;
}
.approval-v3-route-status-panel,
.approval-v3-inline-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(219,229,240,.82);
}
.approval-v3-check{
  display:inline-flex;
  align-items:flex-start;
  gap:9px;
  min-height:38px;
  padding:8px 11px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:16px;
  background:#fff;
  color:#334155;
  font-size:13px;
  font-weight:760;
}
.approval-v3-check input{
  flex:0 0 auto;
  width:17px;
  height:17px;
  margin-top:2px;
  accent-color:#0d7fa8;
}
.approval-v3-check-strong{
  background:#f0fdf4;
  border-color:rgba(16,185,129,.22);
}
.approval-v3-check strong{
  display:block;
  color:#065f46;
}
.approval-v3-check small{
  display:block;
  color:#047857;
  line-height:1.4;
}
.approval-v3-step-guide{
  margin-bottom:14px;
  padding:12px 14px;
  border:1px solid rgba(191,219,254,.82);
  border-radius:18px;
  background:#eff6ff;
  color:#0b3b5f;
  line-height:1.55;
}
.approval-v3-step-list{
  display:grid;
  gap:12px;
}
.approval-v3-step-row{
  display:grid;
  grid-template-columns:64px minmax(0,1fr);
  gap:12px;
  padding:14px;
  border:1px solid rgba(219,229,240,.95);
  border-radius:22px;
  background:#fff;
}
.approval-v3-step-row.is-final{
  border-color:rgba(16,185,129,.28);
  background:linear-gradient(180deg,#fff 0%,#f0fdf4 100%);
}
.approval-v3-step-no{
  width:54px;
  height:54px;
  flex-direction:column;
  align-self:start;
}
.approval-v3-step-no span{
  font-size:10px;
  font-weight:800;
}
.approval-v3-step-no strong{
  font-size:22px;
}
.approval-v3-step-content header{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:flex-start;
  margin-bottom:10px;
}
.approval-v3-step-content h4{
  margin:0 0 4px;
  color:#0f172a;
  font-size:18px;
  font-weight:820;
}
.approval-v3-step-content p{
  margin:0;
  color:#64748b;
  line-height:1.48;
}
.approval-v3-step-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
.approval-v3-edit-box{
  margin-top:10px;
}
.approval-v3-edit-box > summary{
  justify-content:flex-start;
  max-width:max-content;
  min-height:36px;
  padding:7px 11px;
  background:#fff;
}
.approval-v3-step-form,
.approval-v3-assignment-form,
.approval-v3-assignment-edit-form{
  margin-top:12px;
  padding:14px;
  border:1px solid rgba(219,229,240,.88);
  border-radius:20px;
  background:#f8fbff;
}
.approval-v3-add-step{
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(219,229,240,.82);
}
.approval-v3-add-step > summary{
  background:#ecfdf5;
  color:#047857;
  border-color:rgba(16,185,129,.26);
}
.approval-v3-empty-mini,
.approval-v3-assignment-empty{
  padding:14px;
  border:1px dashed rgba(148,163,184,.65);
  border-radius:18px;
  background:#f8fafc;
  color:#64748b;
  text-align:center;
}
.approval-v3-assignment-form{
  margin-top:0;
  margin-bottom:16px;
  background:linear-gradient(135deg,#eff6ff 0%,#fff 100%);
  border-color:rgba(191,219,254,.92);
}
.approval-v3-assignment-groups{
  display:grid;
  gap:14px;
}
.approval-v3-assignment-group{
  border:1px solid rgba(219,229,240,.96);
  border-radius:24px;
  background:#fff;
  overflow:hidden;
}
.approval-v3-assignment-group > header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid rgba(219,229,240,.82);
  background:linear-gradient(180deg,#fbfdff,#f8fafc);
}
.approval-v3-assignment-group > header strong{
  display:block;
  color:#0f172a;
  font-size:17px;
  font-weight:820;
}
.approval-v3-assignment-group > header small{
  display:block;
  margin-top:3px;
  color:#64748b;
}
.approval-v3-step-mini{
  display:inline-flex;
  min-height:26px;
  padding:4px 8px;
  margin-bottom:5px;
  border-radius:999px;
  background:#eff6ff;
  color:#0b3b5f;
  font-size:12px;
  font-weight:860;
}
.approval-v3-approver-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  padding:14px;
}
.approval-v3-approver-card{
  display:grid;
  gap:12px;
  padding:13px;
  border:1px solid rgba(219,229,240,.92);
  border-radius:20px;
  background:#fff;
}
.approval-v3-approver-card.is-disabled{
  opacity:.72;
  background:#f8fafc;
}
.approval-v3-approver-main{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:11px;
  align-items:center;
}
.approval-v3-approver-main strong{
  display:block;
  color:#0f172a;
  font-weight:820;
}
.approval-v3-approver-main small,
.approval-v3-approver-main span{
  display:block;
  margin-top:2px;
  color:#64748b;
  line-height:1.35;
}
.approval-v3-approver-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.approval-v3-approver-edit{
  position:relative;
}
.approval-v3-approver-edit > summary{
  list-style:none;
  cursor:pointer;
}
.approval-v3-approver-edit > summary::-webkit-details-marker{
  display:none;
}
.approval-v3-approver-edit[open]{
  flex:1 1 100%;
  width:100%;
}
.approval-v3-assignment-edit-form{
  width:100%;
  box-sizing:border-box;
  margin-top:10px;
  background:#fff;
}
[data-route-assignment-department].is-muted{
  opacity:.55;
}
[data-route-assignment-department].is-muted select{
  background:#f1f5f9;
}
@media (max-width:1280px){
  .approval-v3-kpi-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .approval-v3-layout{
    grid-template-columns:1fr;
  }
  .approval-v3-sidebar{
    position:relative;
    top:auto;
    max-height:none;
  }
  .approval-v3-route-list{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .approval-v3-assignment-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media (max-width:980px){
  .approval-v3-hero,
  .approval-v3-selected-header,
  .approval-v3-step-content header{
    display:grid;
  }
  .approval-v3-hero-note{
    justify-self:start;
  }
  .approval-v3-quick-nav{
    justify-content:flex-start;
  }
  .approval-v3-form-grid,
  .approval-v3-step-form-grid,
  .approval-v3-assignment-edit-grid,
  .approval-v3-approver-list{
    grid-template-columns:1fr;
  }
  .approval-v3-span-2{
    grid-column:auto;
  }
}
@media (max-width:720px){
  .approval-v3-hero,
  .approval-v3-sidebar,
  .approval-v3-selected-header,
  .approval-v3-card,
  .approval-v3-process-card,
  .approval-v3-warning-card,
  .approval-v3-ready-card{
    border-radius:22px;
    padding:14px;
  }
  .approval-v3-kpi-grid,
  .approval-v3-route-list,
  .approval-v3-assignment-grid{
    grid-template-columns:1fr;
  }
  .approval-v3-process-step{
    min-width:100%;
  }
  .approval-v3-step-row{
    grid-template-columns:1fr;
  }
  .approval-v3-step-no{
    width:100%;
    height:auto;
    min-height:48px;
    flex-direction:row;
    gap:6px;
  }
  .approval-v3-route-status-panel,
  .approval-v3-inline-actions,
  .approval-v3-approver-actions{
    align-items:stretch;
    justify-content:stretch;
  }
  .approval-v3-route-status-panel .btn,
  .approval-v3-inline-actions .btn,
  .approval-v3-approver-actions .btn,
  .approval-v3-approver-actions form,
  .approval-v3-approver-edit{
    width:100%;
  }
  .approval-v3-route-status-panel .btn,
  .approval-v3-inline-actions .btn,
  .approval-v3-approver-actions .btn{
    justify-content:center;
  }
}

/* Phase 2.9.50 — Approval routes simplified usable layout */
.approval-v4-page{
  display:grid;
  gap:18px;
}
.approval-v4-hero{
  display:flex;
  align-items:stretch;
  justify-content:space-between;
  gap:18px;
  padding:22px;
  border:1px solid rgba(191,219,254,.9);
  border-radius:28px;
  background:linear-gradient(135deg,#06243a 0%,#0b3b5f 50%,#0d7fa8 100%);
  color:#fff;
  box-shadow:0 20px 52px rgba(6,36,58,.18);
}
.approval-v4-kicker{
  display:inline-flex;
  color:#0d7fa8;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.approval-v4-hero .approval-v4-kicker{
  color:#b8f0ff;
}
.approval-v4-hero h2{
  margin:6px 0 7px;
  font-size:clamp(25px,4vw,38px);
  line-height:1.12;
  font-weight:860;
}
.approval-v4-hero p{
  margin:0;
  max-width:760px;
  color:rgba(255,255,255,.82);
  line-height:1.68;
}
.approval-v4-stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(92px,1fr));
  gap:10px;
  align-self:center;
}
.approval-v4-stats div{
  min-width:92px;
  padding:13px 12px;
  border:1px solid rgba(255,255,255,.23);
  border-radius:18px;
  background:rgba(255,255,255,.12);
  text-align:center;
}
.approval-v4-stats strong{
  display:block;
  font-size:28px;
  font-weight:900;
  line-height:1;
}
.approval-v4-stats span{
  display:block;
  margin-top:5px;
  color:rgba(255,255,255,.82);
  font-size:12px;
  font-weight:760;
}
.approval-v4-route-picker,
.approval-v4-card,
.approval-v4-selected,
.approval-v4-warning,
.approval-v4-empty-state{
  padding:18px;
  border:1px solid rgba(219,229,240,.96);
  border-radius:26px;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%);
  box-shadow:0 16px 42px rgba(6,36,58,.07);
}
.approval-v4-section-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(219,229,240,.82);
}
.approval-v4-section-head h3,
.approval-v4-selected h3{
  margin:4px 0 5px;
  color:#06243a;
  font-size:22px;
  line-height:1.25;
  font-weight:820;
}
.approval-v4-section-head p{
  margin:0;
  color:#64748b;
  line-height:1.55;
}
.approval-v4-add-route{
  position:relative;
  flex:0 0 auto;
}
.approval-v4-add-route > summary{
  list-style:none;
  cursor:pointer;
}
.approval-v4-add-route > summary::-webkit-details-marker{
  display:none;
}
.approval-v4-add-route-form{
  position:absolute;
  z-index:30;
  right:0;
  top:calc(100% + 10px);
  width:min(760px, calc(100vw - 44px));
  padding:16px;
  border:1px solid rgba(13,127,168,.22);
  border-radius:22px;
  background:#fff;
  box-shadow:0 26px 72px rgba(6,36,58,.18);
}
.approval-v4-route-search{
  margin-bottom:12px;
}
.approval-v4-route-scroll{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.approval-v4-route-tile{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  gap:10px;
  align-items:center;
  padding:12px;
  border:1px solid rgba(219,229,240,.92);
  border-radius:18px;
  background:#fff;
  color:inherit;
  text-decoration:none;
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.approval-v4-route-tile:hover{
  transform:translateY(-1px);
  border-color:rgba(13,127,168,.34);
  box-shadow:0 12px 26px rgba(6,36,58,.08);
}
.approval-v4-route-tile.is-active{
  border-color:rgba(13,127,168,.48);
  background:linear-gradient(135deg,#eff6ff,#fff);
  box-shadow:0 14px 30px rgba(13,127,168,.12);
}
.approval-v4-route-icon,
.approval-v4-avatar{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:15px;
  background:linear-gradient(135deg,#06243a,#0d7fa8);
  color:#fff;
  font-weight:900;
  box-shadow:0 10px 24px rgba(13,127,168,.18);
}
.approval-v4-route-title{
  min-width:0;
}
.approval-v4-route-title strong{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#0f172a;
  font-weight:820;
}
.approval-v4-route-title small{
  display:block;
  margin-top:2px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#64748b;
}
.approval-v4-route-badge,
.approval-v4-status{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 9px;
  border-radius:999px;
  font-size:11px;
  font-weight:860;
  white-space:nowrap;
}
.approval-v4-route-badge.is-ready,
.approval-v4-status.is-ready{
  background:#ecfdf5;
  color:#047857;
}
.approval-v4-route-badge.is-warning,
.approval-v4-status.is-warning{
  background:#fffbeb;
  color:#b45309;
}
.approval-v4-empty-filter{
  margin-top:10px;
  padding:12px;
  border-radius:16px;
  background:#f8fafc;
  color:#64748b;
  text-align:center;
}
.approval-v4-empty-state{
  padding:44px 20px;
  text-align:center;
  border-style:dashed;
}
.approval-v4-empty-state div{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:58px;
  height:58px;
  border-radius:20px;
  background:#eff6ff;
  color:#0d7fa8;
  font-size:26px;
  font-weight:900;
}
.approval-v4-empty-state h3{
  margin:14px 0 6px;
  color:#0f172a;
}
.approval-v4-empty-state p{
  margin:0 auto;
  max-width:520px;
  color:#64748b;
  line-height:1.62;
}
.approval-v4-selected{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
}
.approval-v4-selected-main{
  min-width:0;
}
.approval-v4-selected h3{
  margin-top:8px;
}
.approval-v4-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.approval-v4-meta span{
  display:inline-flex;
  gap:5px;
  min-height:30px;
  align-items:center;
  padding:6px 10px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:999px;
  background:#fff;
  color:#64748b;
  font-size:12px;
  font-weight:720;
}
.approval-v4-meta strong{
  color:#0f172a;
}
.approval-v4-nav{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
}
.approval-v4-nav a{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(191,219,254,.9);
  background:#eff6ff;
  color:#0b3b5f;
  text-decoration:none;
  font-size:13px;
  font-weight:820;
}
.approval-v4-warning{
  background:linear-gradient(180deg,#fff 0%,#fff7ed 100%);
  border-color:rgba(251,146,60,.34);
}
.approval-v4-warning strong{
  color:#9a3412;
}
.approval-v4-warning ul{
  margin:8px 0 0;
  padding-left:20px;
  color:#7c2d12;
}
.approval-v4-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.approval-v4-form-grid.is-step{
  grid-template-columns:minmax(110px,.45fr) minmax(180px,.8fr) minmax(260px,1.4fr) minmax(220px,1fr) minmax(180px,.85fr);
}
.approval-v4-form-grid .field,
.approval-v4-assignment-grid .field{
  min-width:0;
  margin:0;
}
.approval-v4-form-grid .input,
.approval-v4-form-grid .select,
.approval-v4-assignment-grid .input,
.approval-v4-assignment-grid .select{
  width:100%;
  min-width:0;
}
.approval-v4-form-grid .is-wide{
  grid-column:auto;
}
.approval-v4-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(219,229,240,.82);
}
.approval-v4-check{
  display:inline-flex;
  align-items:flex-start;
  gap:9px;
  min-height:38px;
  padding:8px 11px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:16px;
  background:#fff;
  color:#334155;
  font-size:13px;
  font-weight:760;
}
.approval-v4-check input{
  flex:0 0 auto;
  width:17px;
  height:17px;
  margin-top:2px;
  accent-color:#0d7fa8;
}
.approval-v4-check.is-green{
  background:#f0fdf4;
  border-color:rgba(16,185,129,.22);
}
.approval-v4-check strong{
  display:block;
  color:#065f46;
}
.approval-v4-check small{
  display:block;
  color:#047857;
  line-height:1.4;
}
.approval-v4-workflow{
  display:grid;
  gap:16px;
}
.approval-v4-step-card{
  border:1px solid rgba(219,229,240,.96);
  border-radius:24px;
  background:#fff;
  overflow:hidden;
}
.approval-v4-step-card.is-final{
  border-color:rgba(16,185,129,.30);
}
.approval-v4-step-header{
  display:grid;
  grid-template-columns:64px minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:14px 16px;
  border-bottom:1px solid rgba(219,229,240,.82);
  background:linear-gradient(180deg,#fbfdff,#f8fafc);
}
.approval-v4-step-number{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:54px;
  min-height:54px;
  border-radius:18px;
  background:#eff6ff;
  color:#0b3b5f;
}
.approval-v4-step-number span{
  font-size:10px;
  font-weight:860;
}
.approval-v4-step-number strong{
  font-size:24px;
  font-weight:900;
}
.approval-v4-step-title h4{
  margin:0 0 3px;
  color:#0f172a;
  font-size:19px;
  font-weight:840;
}
.approval-v4-step-title p{
  margin:0;
  color:#64748b;
  line-height:1.42;
}
.approval-v4-step-status{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:flex-end;
}
.approval-v4-step-tools{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  padding:14px;
  border-bottom:1px solid rgba(219,229,240,.82);
  background:#fff;
}
.approval-v4-step-tools details{
  min-width:0;
}
.approval-v4-step-tools summary,
.approval-v4-add-step > summary,
.approval-v4-approver-edit > summary{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:9px 12px;
  border:1px solid rgba(191,219,254,.9);
  border-radius:16px;
  background:#eff6ff;
  color:#0b3b5f;
  cursor:pointer;
  font-weight:840;
  list-style:none;
}
.approval-v4-step-tools summary::-webkit-details-marker,
.approval-v4-add-step > summary::-webkit-details-marker,
.approval-v4-approver-edit > summary::-webkit-details-marker{
  display:none;
}
.approval-v4-step-tools details[open]{
  grid-column:1 / -1;
}
.approval-v4-step-form,
.approval-v4-assignment-form,
.approval-v4-assignment-edit-form,
.approval-v4-add-step .approval-v4-step-form{
  margin-top:12px;
  padding:14px;
  border:1px solid rgba(219,229,240,.88);
  border-radius:20px;
  background:#f8fbff;
}
.approval-v4-assignment-grid{
  display:grid;
  grid-template-columns:minmax(260px,1.4fr) minmax(160px,.75fr) minmax(220px,1fr);
  gap:12px;
}
.approval-v4-approver-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  padding:14px;
}
.approval-v4-approver{
  display:grid;
  gap:12px;
  padding:13px;
  border:1px solid rgba(219,229,240,.92);
  border-radius:20px;
  background:#fff;
}
.approval-v4-approver.is-disabled{
  opacity:.72;
  background:#f8fafc;
}
.approval-v4-approver-main{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:11px;
  align-items:center;
}
.approval-v4-approver-main strong{
  display:block;
  color:#0f172a;
  font-weight:820;
}
.approval-v4-approver-main small,
.approval-v4-approver-main span{
  display:block;
  margin-top:2px;
  color:#64748b;
  line-height:1.35;
}
.approval-v4-approver-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.approval-v4-approver-edit{
  position:relative;
}
.approval-v4-approver-edit[open]{
  flex:1 1 100%;
  width:100%;
}
.approval-v4-assignment-edit-form{
  width:100%;
  box-sizing:border-box;
  background:#fff;
}
.approval-v4-empty-mini{
  padding:14px;
  border:1px dashed rgba(148,163,184,.65);
  border-radius:18px;
  background:#f8fafc;
  color:#64748b;
  text-align:center;
}
.approval-v4-add-step{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(219,229,240,.82);
}
.approval-v4-add-step > summary{
  background:#ecfdf5;
  border-color:rgba(16,185,129,.28);
  color:#047857;
}
[data-route-assignment-department].is-muted{
  opacity:.55;
}
[data-route-assignment-department].is-muted select{
  background:#f1f5f9;
}
@media (max-width:1220px){
  .approval-v4-route-scroll{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .approval-v4-form-grid.is-step,
  .approval-v4-assignment-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .approval-v4-approver-list{
    grid-template-columns:1fr;
  }
}
@media (max-width:900px){
  .approval-v4-hero,
  .approval-v4-selected,
  .approval-v4-section-head{
    display:grid;
  }
  .approval-v4-stats{
    grid-template-columns:repeat(3,1fr);
  }
  .approval-v4-nav,
  .approval-v4-step-status{
    justify-content:flex-start;
  }
  .approval-v4-add-route-form{
    position:fixed;
    left:14px;
    right:14px;
    top:82px;
    width:auto;
    max-height:calc(100vh - 110px);
    overflow:auto;
  }
  .approval-v4-step-header{
    grid-template-columns:56px minmax(0,1fr);
  }
  .approval-v4-step-status{
    grid-column:1 / -1;
  }
  .approval-v4-step-tools{
    grid-template-columns:1fr;
  }
  .approval-v4-step-tools details[open]{
    grid-column:auto;
  }
}
@media (max-width:720px){
  .approval-v4-hero,
  .approval-v4-route-picker,
  .approval-v4-card,
  .approval-v4-selected,
  .approval-v4-warning,
  .approval-v4-empty-state{
    padding:14px;
    border-radius:22px;
  }
  .approval-v4-stats,
  .approval-v4-route-scroll,
  .approval-v4-form-grid,
  .approval-v4-form-grid.is-step,
  .approval-v4-assignment-grid{
    grid-template-columns:1fr;
  }
  .approval-v4-route-tile{
    grid-template-columns:auto minmax(0,1fr);
  }
  .approval-v4-route-badge{
    grid-column:1 / -1;
    justify-content:center;
  }
  .approval-v4-actions,
  .approval-v4-approver-actions{
    align-items:stretch;
    justify-content:stretch;
  }
  .approval-v4-actions .btn,
  .approval-v4-approver-actions .btn,
  .approval-v4-approver-actions form,
  .approval-v4-approver-edit{
    width:100%;
  }
  .approval-v4-actions .btn,
  .approval-v4-approver-actions .btn{
    justify-content:center;
  }
}

/* Phase 2.9.51 — Approval routes production UX layout */
.approval-prod-page{
  display:grid;
  gap:18px;
}
.approval-prod-header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:20px;
  padding:22px;
  border:1px solid rgba(191,219,254,.9);
  border-radius:26px;
  background:
    linear-gradient(135deg,rgba(6,58,90,.98),rgba(10,92,138,.98) 50%,rgba(13,127,168,.98)),
    radial-gradient(circle at right top,rgba(255,255,255,.18),rgba(255,255,255,0) 36%);
  color:#fff;
  box-shadow:0 20px 52px rgba(6,36,58,.17);
}
.approval-prod-title{
  max-width:880px;
}
.approval-prod-kicker{
  display:inline-flex;
  color:#0d7fa8;
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.approval-prod-header .approval-prod-kicker{
  color:#b8f0ff;
}
.approval-prod-header h2{
  margin:6px 0 8px;
  font-size:clamp(26px,4vw,38px);
  font-weight:860;
  line-height:1.12;
}
.approval-prod-header p{
  margin:0;
  color:rgba(255,255,255,.82);
  line-height:1.68;
}
.approval-prod-header-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
  min-width:max-content;
}
.approval-prod-add-route{
  position:relative;
}
.approval-prod-add-route > summary{
  list-style:none;
  cursor:pointer;
}
.approval-prod-add-route > summary::-webkit-details-marker{
  display:none;
}
.approval-prod-popover-form{
  position:absolute;
  z-index:40;
  right:0;
  top:calc(100% + 10px);
  width:min(780px, calc(100vw - 44px));
  padding:16px;
  border:1px solid rgba(13,127,168,.22);
  border-radius:22px;
  background:#fff;
  color:#0f172a;
  box-shadow:0 26px 72px rgba(6,36,58,.2);
}
.approval-prod-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.approval-prod-stats article{
  padding:16px;
  border:1px solid rgba(219,229,240,.96);
  border-radius:22px;
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
  box-shadow:0 14px 34px rgba(6,36,58,.065);
}
.approval-prod-stats span{
  display:block;
  color:#64748b;
  font-size:12px;
  font-weight:800;
}
.approval-prod-stats strong{
  display:block;
  margin:4px 0;
  color:#0f172a;
  font-size:30px;
  font-weight:900;
  line-height:1.05;
}
.approval-prod-stats small{
  color:#64748b;
  line-height:1.42;
}
.approval-prod-stats article.is-warning{
  border-color:rgba(245,158,11,.34);
  background:linear-gradient(180deg,#fff 0%,#fffbeb 100%);
}
.approval-prod-stats article.is-ready{
  border-color:rgba(16,185,129,.30);
  background:linear-gradient(180deg,#fff 0%,#ecfdf5 100%);
}
.approval-prod-panel,
.approval-prod-selected,
.approval-prod-warning,
.approval-prod-empty-state{
  padding:18px;
  border:1px solid rgba(219,229,240,.96);
  border-radius:24px;
  background:linear-gradient(180deg,#fff 0%,#fbfdff 100%);
  box-shadow:0 16px 42px rgba(6,36,58,.07);
}
.approval-prod-section-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  margin-bottom:14px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(219,229,240,.82);
}
.approval-prod-section-head h3,
.approval-prod-selected h3{
  margin:4px 0 5px;
  color:#06243a;
  font-size:22px;
  font-weight:820;
  line-height:1.25;
}
.approval-prod-section-head p{
  margin:0;
  color:#64748b;
  line-height:1.55;
}
.approval-prod-search{
  display:flex;
  align-items:center;
  gap:8px;
  min-width:300px;
  padding:8px 10px;
  border:1px solid rgba(219,229,240,.95);
  border-radius:16px;
  background:#fff;
}
.approval-prod-search span{
  color:#64748b;
  font-size:12px;
  font-weight:800;
}
.approval-prod-search input{
  width:100%;
  border:0;
  outline:0;
  color:#0f172a;
  font-weight:650;
  background:transparent;
}
.approval-prod-route-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
}
.approval-prod-route-card{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
  padding:12px;
  border:1px solid rgba(219,229,240,.92);
  border-radius:18px;
  background:#fff;
  color:inherit;
  text-decoration:none;
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.approval-prod-route-card:hover{
  transform:translateY(-1px);
  border-color:rgba(13,127,168,.34);
  box-shadow:0 12px 26px rgba(6,36,58,.08);
}
.approval-prod-route-card.is-active{
  border-color:rgba(13,127,168,.50);
  background:linear-gradient(135deg,#eff6ff,#fff);
  box-shadow:0 14px 30px rgba(13,127,168,.12);
}
.approval-prod-route-mark,
.approval-prod-avatar{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:15px;
  background:linear-gradient(135deg,#06243a,#0d7fa8);
  color:#fff;
  font-weight:900;
  box-shadow:0 10px 24px rgba(13,127,168,.18);
}
.approval-prod-route-copy{
  min-width:0;
}
.approval-prod-route-copy strong{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#0f172a;
  font-weight:820;
}
.approval-prod-route-copy small{
  display:block;
  margin-top:2px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#64748b;
}
.approval-prod-route-state,
.approval-prod-status{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:5px 9px;
  border-radius:999px;
  white-space:nowrap;
  font-size:11px;
  font-weight:860;
}
.approval-prod-route-state.is-ready,
.approval-prod-status.is-ready{
  background:#ecfdf5;
  color:#047857;
}
.approval-prod-route-state.is-warning,
.approval-prod-status.is-warning{
  background:#fffbeb;
  color:#b45309;
}
.approval-prod-empty-filter{
  margin-top:10px;
  padding:12px;
  border-radius:16px;
  background:#f8fafc;
  color:#64748b;
  text-align:center;
}
.approval-prod-empty-state{
  padding:46px 20px;
  text-align:center;
  border-style:dashed;
}
.approval-prod-empty-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:60px;
  height:60px;
  border-radius:20px;
  background:#eff6ff;
  color:#0d7fa8;
  font-size:26px;
  font-weight:900;
}
.approval-prod-empty-state h3{
  margin:14px 0 6px;
  color:#0f172a;
}
.approval-prod-empty-state p{
  margin:0 auto;
  max-width:560px;
  color:#64748b;
  line-height:1.62;
}
.approval-prod-selected{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:16px;
}
.approval-prod-selected h3{
  margin-top:8px;
}
.approval-prod-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:10px;
}
.approval-prod-meta span{
  display:inline-flex;
  align-items:center;
  gap:5px;
  min-height:30px;
  padding:6px 10px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:999px;
  background:#fff;
  color:#64748b;
  font-size:12px;
  font-weight:720;
}
.approval-prod-meta strong{
  color:#0f172a;
}
.approval-prod-selected nav{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
}
.approval-prod-selected nav a{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(191,219,254,.9);
  background:#eff6ff;
  color:#0b3b5f;
  text-decoration:none;
  font-size:13px;
  font-weight:820;
}
.approval-prod-warning{
  border-color:rgba(251,146,60,.34);
  background:linear-gradient(180deg,#fff 0%,#fff7ed 100%);
}
.approval-prod-warning strong{
  color:#9a3412;
}
.approval-prod-warning ul{
  margin:8px 0 0;
  padding-left:20px;
  color:#7c2d12;
}
.approval-prod-two-col{
  display:grid;
  grid-template-columns:minmax(0,1.5fr) minmax(280px,.7fr);
  gap:18px;
}
.approval-prod-form-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.approval-prod-form-grid .field,
.approval-prod-step-grid .field,
.approval-prod-assignment-grid .field{
  margin:0;
  min-width:0;
}
.approval-prod-form-grid .input,
.approval-prod-form-grid .select,
.approval-prod-step-grid .input,
.approval-prod-step-grid .select,
.approval-prod-assignment-grid .select{
  width:100%;
  min-width:0;
}
.approval-prod-form-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  margin-top:14px;
  padding-top:14px;
  border-top:1px solid rgba(219,229,240,.82);
}
.approval-prod-check{
  display:inline-flex;
  align-items:flex-start;
  gap:9px;
  min-height:38px;
  padding:8px 11px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:16px;
  background:#fff;
  color:#334155;
  font-size:13px;
  font-weight:760;
}
.approval-prod-check input{
  flex:0 0 auto;
  width:17px;
  height:17px;
  margin-top:2px;
  accent-color:#0d7fa8;
}
.approval-prod-check.is-green{
  background:#f0fdf4;
  border-color:rgba(16,185,129,.24);
}
.approval-prod-check strong{
  display:block;
  color:#065f46;
}
.approval-prod-check small{
  display:block;
  color:#047857;
  line-height:1.4;
}
.approval-prod-guide .approval-prod-section-head{
  margin-bottom:12px;
}
.approval-prod-checklist{
  display:grid;
  gap:10px;
}
.approval-prod-checklist div{
  display:grid;
  grid-template-columns:36px minmax(0,1fr);
  gap:4px 10px;
  padding:12px;
  border:1px solid rgba(219,229,240,.9);
  border-radius:18px;
  background:#fff;
}
.approval-prod-checklist div.is-ok{
  border-color:rgba(16,185,129,.24);
  background:#f0fdf4;
}
.approval-prod-checklist div.is-warn{
  border-color:rgba(245,158,11,.28);
  background:#fffbeb;
}
.approval-prod-checklist span{
  grid-row:1 / span 2;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  border-radius:12px;
  background:#eff6ff;
  color:#0b3b5f;
  font-weight:900;
}
.approval-prod-checklist strong{
  color:#0f172a;
}
.approval-prod-checklist small{
  color:#64748b;
}
.approval-prod-workflow-list{
  display:grid;
  gap:16px;
}
.approval-prod-step{
  border:1px solid rgba(219,229,240,.96);
  border-radius:22px;
  background:#fff;
  overflow:hidden;
}
.approval-prod-step.is-final{
  border-color:rgba(16,185,129,.30);
}
.approval-prod-step > header{
  display:grid;
  grid-template-columns:64px minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
  padding:14px 16px;
  border-bottom:1px solid rgba(219,229,240,.82);
  background:linear-gradient(180deg,#fbfdff,#f8fafc);
}
.approval-prod-step-no{
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:54px;
  min-height:54px;
  border-radius:18px;
  background:#eff6ff;
  color:#0b3b5f;
}
.approval-prod-step-no span{
  font-size:10px;
  font-weight:860;
}
.approval-prod-step-no strong{
  font-size:24px;
  font-weight:900;
}
.approval-prod-step-title h4{
  margin:0 0 3px;
  color:#0f172a;
  font-size:19px;
  font-weight:840;
}
.approval-prod-step-title p{
  margin:0;
  color:#64748b;
  line-height:1.42;
}
.approval-prod-step-badges{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:6px;
}
.approval-prod-step-tools{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  padding:14px;
  border-bottom:1px solid rgba(219,229,240,.82);
}
.approval-prod-step-tools details{
  min-width:0;
}
.approval-prod-step-tools details[open]{
  grid-column:1 / -1;
}
.approval-prod-step-tools summary,
.approval-prod-approver-edit > summary,
.approval-prod-add-step > summary{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:9px 12px;
  border:1px solid rgba(191,219,254,.9);
  border-radius:16px;
  background:#eff6ff;
  color:#0b3b5f;
  cursor:pointer;
  font-weight:840;
  list-style:none;
}
.approval-prod-step-tools summary::-webkit-details-marker,
.approval-prod-approver-edit > summary::-webkit-details-marker,
.approval-prod-add-step > summary::-webkit-details-marker{
  display:none;
}
.approval-prod-step-form,
.approval-prod-assignment-form,
.approval-prod-assignment-edit-form{
  margin-top:12px;
  padding:14px;
  border:1px solid rgba(219,229,240,.88);
  border-radius:20px;
  background:#f8fbff;
}
.approval-prod-step-grid{
  display:grid;
  grid-template-columns:minmax(110px,.45fr) minmax(170px,.75fr) minmax(240px,1.25fr) minmax(220px,1fr) minmax(180px,.8fr);
  gap:12px;
}
.approval-prod-assignment-grid{
  display:grid;
  grid-template-columns:minmax(260px,1.3fr) minmax(160px,.7fr) minmax(220px,1fr);
  gap:12px;
}
.approval-prod-approver-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  padding:14px;
}
.approval-prod-approver{
  display:grid;
  gap:12px;
  padding:13px;
  border:1px solid rgba(219,229,240,.92);
  border-radius:20px;
  background:#fff;
}
.approval-prod-approver.is-disabled{
  opacity:.72;
  background:#f8fafc;
}
.approval-prod-approver-main{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:11px;
  align-items:center;
}
.approval-prod-approver-main strong{
  display:block;
  color:#0f172a;
  font-weight:820;
}
.approval-prod-approver-main small,
.approval-prod-approver-main span{
  display:block;
  margin-top:2px;
  color:#64748b;
  line-height:1.35;
}
.approval-prod-approver-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
  gap:8px;
}
.approval-prod-approver-edit[open]{
  flex:1 1 100%;
  width:100%;
}
.approval-prod-assignment-edit-form{
  background:#fff;
  width:100%;
  box-sizing:border-box;
}
.approval-prod-empty-mini{
  padding:14px;
  border:1px dashed rgba(148,163,184,.65);
  border-radius:18px;
  background:#f8fafc;
  color:#64748b;
  text-align:center;
}
.approval-prod-add-step{
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(219,229,240,.82);
}
.approval-prod-add-step > summary{
  background:#ecfdf5;
  border-color:rgba(16,185,129,.28);
  color:#047857;
}
[data-route-assignment-department].is-muted{
  opacity:.55;
}
[data-route-assignment-department].is-muted select{
  background:#f1f5f9;
}
@media (max-width:1240px){
  .approval-prod-stats,
  .approval-prod-route-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .approval-prod-two-col{
    grid-template-columns:1fr;
  }
  .approval-prod-step-grid,
  .approval-prod-assignment-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .approval-prod-approver-list{
    grid-template-columns:1fr;
  }
}
@media (max-width:900px){
  .approval-prod-header,
  .approval-prod-section-head,
  .approval-prod-selected{
    display:grid;
  }
  .approval-prod-header-actions{
    justify-content:flex-start;
    min-width:0;
  }
  .approval-prod-popover-form{
    position:fixed;
    left:14px;
    right:14px;
    top:82px;
    width:auto;
    max-height:calc(100vh - 110px);
    overflow:auto;
  }
  .approval-prod-search{
    min-width:0;
    width:100%;
  }
  .approval-prod-selected nav,
  .approval-prod-step-badges{
    justify-content:flex-start;
  }
  .approval-prod-step > header{
    grid-template-columns:56px minmax(0,1fr);
  }
  .approval-prod-step-badges{
    grid-column:1 / -1;
  }
  .approval-prod-step-tools{
    grid-template-columns:1fr;
  }
  .approval-prod-step-tools details[open]{
    grid-column:auto;
  }
}
@media (max-width:720px){
  .approval-prod-header,
  .approval-prod-panel,
  .approval-prod-selected,
  .approval-prod-warning,
  .approval-prod-empty-state{
    padding:14px;
    border-radius:22px;
  }
  .approval-prod-stats,
  .approval-prod-route-grid,
  .approval-prod-form-grid,
  .approval-prod-step-grid,
  .approval-prod-assignment-grid{
    grid-template-columns:1fr;
  }
  .approval-prod-route-card{
    grid-template-columns:auto minmax(0,1fr);
  }
  .approval-prod-route-state{
    grid-column:1 / -1;
    justify-content:center;
  }
  .approval-prod-form-actions,
  .approval-prod-approver-actions{
    align-items:stretch;
    justify-content:stretch;
  }
  .approval-prod-form-actions .btn,
  .approval-prod-approver-actions .btn,
  .approval-prod-approver-actions form,
  .approval-prod-approver-edit{
    width:100%;
  }
  .approval-prod-form-actions .btn,
  .approval-prod-approver-actions .btn{
    justify-content:center;
  }
}

/* Phase 2.9.52 — Approval approver real avatar fix */
.approval-prod-avatar{
  overflow:hidden;
  flex:0 0 auto;
  line-height:1;
}
.approval-prod-avatar.has-photo{
  background:#e2e8f0!important;
  color:transparent!important;
}
.approval-prod-avatar.has-photo img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  border-radius:inherit;
}
.approval-prod-approver.is-disabled .approval-prod-avatar.has-photo img{
  filter:grayscale(.15);
}

/* Phase 2.9.54 — User employee professional level */
.user-professional-level-field .field-help{
  margin-top:4px;
}
.user-professional-level-field .input{
  width:100%;
}

/* Phase 2.9.55 — Vacation minimum advance working-days policy */
.vacation-pro-policy-fieldset .field-help{
  display:block;
  margin-top:4px;
  color:#64748b;
  font-size:12px;
  line-height:1.45;
}

/* --------------------------------------------------------------------------
   Approval inbox — user action history
   Scope: /approvals only. Uses existing workflow timeline data; no schema change.
---------------------------------------------------------------------------- */
.approval-history-card{
  margin-top:var(--section-gap, 16px);
}
.approval-history-responsive{
  overflow:auto;
}
.approval-history-table{
  min-width:1120px;
}
.approval-history-action{
  display:inline-flex;
  align-items:center;
  gap:6px;
  max-width:100%;
  border:1px solid #dbe4ef;
  border-radius:999px;
  background:#f8fafc;
  color:#334155;
  padding:6px 10px;
  font-size:12px;
  line-height:1.25;
  font-weight:500;
  white-space:nowrap;
}
.approval-history-action::before{
  content:"";
  width:7px;
  height:7px;
  border-radius:999px;
  background:currentColor;
  opacity:.72;
}
.history-action-approve,
.history-action-recommend_approve,
.history-action-cancel_approve{
  border-color:#bbf7d0;
  background:#f0fdf4;
  color:#047857;
}
.history-action-reject,
.history-action-recommend_reject,
.history-action-cancel_reject{
  border-color:#fecdd3;
  background:#fff1f2;
  color:#be123c;
}
.history-action-return{
  border-color:#fed7aa;
  background:#fff7ed;
  color:#c2410c;
}
.history-action-cancel_request{
  border-color:#bfdbfe;
  background:#eff6ff;
  color:#0e5d89;
}
.approval-history-comment{
  display:block;
  max-width:260px;
  color:#334155;
  line-height:1.55;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.approval-history-delegated{
  margin-top:6px;
}
@media(max-width:760px){
  .approval-history-card .section-header .status-badge,
  .approval-inbox-card .section-header .status-badge,
  .cancellation-inbox-card .section-header .status-badge{
    align-self:flex-start;
  }
  .approval-history-comment{
    max-width:220px;
  }
}

/* Phase 2.8 — Central Activity History / Audit Trail */
.activity-history-hero{align-items:center}.activity-kpi-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:20px}.activity-kpi-card{border:1px solid var(--line);background:#fff;border-radius:20px;padding:16px 18px;box-shadow:0 8px 22px rgba(6,36,58,.055)}.activity-kpi-card span{display:block;color:var(--muted);font-size:12px;font-weight:700}.activity-kpi-card strong{display:block;margin-top:6px;color:var(--brand-900);font-size:28px;line-height:1;font-weight:800}.activity-kpi-card small{display:block;margin-top:8px;color:var(--muted);font-size:12px}.activity-filter-card{margin-bottom:20px}.activity-filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;align-items:end}.activity-filter-grid .form-group{display:grid;gap:6px;min-width:0}.activity-filter-grid .span-2{grid-column:span 2}.activity-filter-grid label{font-size:13px;font-weight:800;color:var(--ink)}.activity-filter-grid input,.activity-filter-grid select{width:100%;min-height:44px;border:1px solid #cbd9e6;border-radius:14px;background:#fff;color:var(--ink);padding:0 12px;outline:none}.activity-filter-grid input:focus,.activity-filter-grid select:focus{border-color:var(--brand-600);box-shadow:var(--focus-ring)}.activity-filter-actions{grid-column:1/-1;display:flex;gap:10px;justify-content:flex-end}.activity-history-responsive{overflow:auto}.activity-history-table{min-width:1320px}.activity-history-table th{white-space:nowrap}.activity-history-table td{vertical-align:top}.activity-history-comment{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:340px;color:#334155;line-height:1.55}.activity-summary-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:18px}.activity-summary-card{padding:16px 18px}.activity-summary-card span{display:block;color:var(--muted);font-size:12px;font-weight:800}.activity-summary-card strong{display:block;margin-top:5px;color:var(--brand-900);font-size:18px;line-height:1.35;font-weight:850}.activity-summary-card small{display:block;margin-top:7px;color:var(--muted);font-size:12px}.activity-timeline-card{padding:22px}.activity-timeline-list{position:relative;display:grid;gap:14px}.activity-timeline-list::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:#dbe5f0}.activity-timeline-item{position:relative;display:grid;grid-template-columns:24px minmax(0,1fr);gap:14px}.activity-timeline-marker{position:relative;z-index:1;width:24px;height:24px;border-radius:999px;background:#fff;border:5px solid var(--brand-600);box-shadow:0 0 0 4px #e8f6fb}.activity-timeline-body{border:1px solid var(--line);background:#fff;border-radius:18px;padding:14px 16px;box-shadow:0 7px 18px rgba(6,36,58,.045)}.activity-timeline-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.activity-timeline-head strong{display:block;color:var(--brand-900);font-size:16px;font-weight:850}.activity-timeline-head small{display:block;margin-top:2px;color:var(--muted);font-size:12px}.activity-timeline-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.activity-timeline-meta span{display:inline-flex;gap:4px;align-items:center;border:1px solid #e3edf5;background:#f8fbfd;border-radius:999px;padding:5px 9px;color:#475569;font-size:12px}.activity-timeline-meta strong{color:#0f172a}.activity-timeline-note{margin-top:12px;border-left:3px solid var(--brand-600);background:#f8fbfd;border-radius:12px;padding:10px 12px;color:#334155;line-height:1.65}.activity-sensitive-box{display:grid;gap:4px;margin-top:10px;border:1px dashed #cbd5e1;background:#f8fafc;border-radius:12px;padding:9px 10px;color:#64748b;font-size:12px;word-break:break-word}@media(max-width:1320px){.activity-kpi-grid,.activity-summary-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.activity-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:900px){.activity-kpi-grid,.activity-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.activity-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.activity-filter-grid .span-2{grid-column:1/-1}.activity-filter-actions{justify-content:flex-start}.activity-timeline-head{display:grid}.activity-timeline-meta{display:grid}.activity-timeline-list::before{left:10px}}@media(max-width:640px){.activity-kpi-grid,.activity-summary-grid,.activity-filter-grid{grid-template-columns:1fr}.activity-filter-actions{display:grid}.activity-filter-actions .btn{width:100%}.activity-timeline-card{padding:16px}.activity-timeline-item{grid-template-columns:22px minmax(0,1fr);gap:10px}.activity-timeline-marker{width:22px;height:22px}.activity-timeline-body{padding:12px}.activity-history-hero .hero-orbit-card{width:100%}}

/* Phase 2.8.1 — SLA scope-aware pending tasks */
.sla-scope-filter-grid{
  grid-template-columns:repeat(4,minmax(180px,1fr));
  align-items:end;
}
.sla-scope-filter-grid .filter-field-wide{
  grid-column:span 2;
}
.sla-scope-filter-grid .filter-actions{
  align-self:end;
  display:flex;
  gap:10px;
  justify-content:flex-end;
}
.sla-task-step strong{
  word-break:break-word;
  line-height:1.35;
}
.sla-task-meta span{
  max-width:100%;
}
@media(max-width:1180px){
  .sla-scope-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .sla-scope-filter-grid .filter-field-wide{grid-column:1 / -1;}
  .sla-scope-filter-grid .filter-actions{justify-content:flex-start;}
}
@media(max-width:680px){
  .sla-scope-filter-grid{grid-template-columns:1fr;}
  .sla-scope-filter-grid .filter-field-wide{grid-column:auto;}
  .sla-scope-filter-grid .filter-actions{width:100%;flex-direction:column;align-items:stretch;}
}

/* --------------------------------------------------------------------------
   Phase 2.9.7 — Notification Center UI polish
   Scope: /notifications only. Restrained production layout, readable cards,
   mobile-safe actions, and clear read/unread states.
---------------------------------------------------------------------------- */
.notification-center-hero{
  min-height:0;
  padding:clamp(20px,3vw,30px);
  border:1px solid #d8e3ee;
  border-radius:28px;
  background:#ffffff;
  color:#0f172a;
  box-shadow:0 10px 28px rgba(15,23,42,.055);
}
.notification-center-hero::before,
.notification-center-hero::after{
  display:none;
}
.notification-center-hero .hero-kicker{
  color:#0e5d89;
  background:#e8f6fb;
  border-color:#c8e8f2;
}
.notification-center-hero h2{
  color:#0f172a;
  text-shadow:none;
}
.notification-center-hero p{
  max-width:720px;
  color:#526477;
}
.notification-hero-actions{
  gap:10px;
}
.notification-hero-actions form{
  margin:0;
}
.notification-summary-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:16px 0;
}
.notification-summary-card{
  min-width:0;
  padding:16px 18px;
  border:1px solid #d8e3ee;
  border-radius:22px;
  background:#fff;
  box-shadow:0 6px 18px rgba(15,23,42,.045);
}
.notification-summary-card span,
.notification-summary-card small{
  display:block;
  color:#64748b;
  line-height:1.5;
}
.notification-summary-card span{
  font-size:12px;
  font-weight:700;
}
.notification-summary-card strong{
  display:block;
  margin:.18rem 0;
  color:#0f172a;
  font-size:clamp(24px,2.3vw,34px);
  line-height:1.1;
  font-weight:650;
  letter-spacing:-.03em;
}
.notification-summary-card.is-unread{
  border-color:#bfdbfe;
}
.notification-summary-card.is-unread strong{
  color:#075985;
}
.notification-summary-card.is-read strong{
  color:#166534;
}
.notification-summary-card.is-latest strong{
  font-size:clamp(18px,1.5vw,24px);
  line-height:1.28;
  letter-spacing:-.02em;
}
.notification-center-card{
  padding:clamp(16px,2vw,22px);
  border-color:#d8e3ee;
  box-shadow:0 10px 28px rgba(15,23,42,.05);
}
.notification-center-header{
  align-items:flex-start;
  gap:18px;
  margin-bottom:18px;
}
.notification-center-header .section-kicker{
  display:inline-flex;
  align-items:center;
  width:max-content;
  min-height:26px;
  padding:0 10px;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:12px;
  font-weight:700;
}
.notification-center-header h2{
  margin-top:8px;
}
.notification-center-header p{
  max-width:760px;
  color:#64748b;
  line-height:1.65;
}
.notification-filter-tabs{
  flex:0 0 auto;
  display:flex;
  align-items:stretch;
  gap:8px;
  padding:6px;
  border:1px solid #dbe4ef;
  border-radius:18px;
  background:#f8fafc;
}
.notification-filter-tab{
  min-width:94px;
  display:grid;
  gap:2px;
  align-content:center;
  padding:9px 12px;
  border:1px solid transparent;
  border-radius:14px;
  color:#475569;
  text-decoration:none;
  transition:background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease;
}
.notification-filter-tab:hover{
  background:#fff;
  color:#0e5d89;
  border-color:#d8e3ee;
}
.notification-filter-tab.active{
  background:#fff;
  color:#063a5a;
  border-color:#c8d8e8;
  box-shadow:0 6px 16px rgba(15,23,42,.06);
}
.notification-filter-tab span{
  font-size:12px;
  font-weight:700;
  line-height:1.2;
}
.notification-filter-tab strong{
  font-size:18px;
  line-height:1.1;
  font-weight:700;
}
.notification-feed{
  display:grid;
  gap:12px;
}
.notification-feed-item{
  position:relative;
  display:grid;
  grid-template-columns:48px minmax(0,1fr);
  gap:14px;
  padding:16px;
  border:1px solid #d8e3ee;
  border-radius:22px;
  background:#fff;
  box-shadow:0 2px 8px rgba(15,23,42,.035);
}
.notification-feed-item::before{
  content:"";
  position:absolute;
  inset:14px auto 14px 0;
  width:4px;
  border-radius:999px;
  background:#cbd5e1;
}
.notification-feed-item.is-unread{
  border-color:#bfdced;
  background:#fbfdff;
}
.notification-feed-item.is-unread::before{
  background:#0e5d89;
}
.notification-feed-item.is-success::before{background:#16a34a;}
.notification-feed-item.is-warning::before{background:#d97706;}
.notification-feed-item.is-danger::before{background:#dc2626;}
.notification-feed-item.is-info::before{background:#0e5d89;}
.notification-feed-item.is-neutral::before{background:#64748b;}
.notification-feed-state{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:#f1f5f9;
  color:#334155;
  font-weight:800;
  line-height:1;
}
.notification-feed-item.is-success .notification-feed-state{background:#ecfdf3;color:#166534;}
.notification-feed-item.is-warning .notification-feed-state{background:#fffbeb;color:#92400e;}
.notification-feed-item.is-danger .notification-feed-state{background:#fef2f2;color:#991b1b;}
.notification-feed-item.is-info .notification-feed-state{background:#e8f6fb;color:#075985;}
.notification-feed-item.is-neutral .notification-feed-state{background:#f1f5f9;color:#475569;}
.notification-feed-content{
  min-width:0;
}
.notification-feed-title-row{
  display:flex;
  justify-content:space-between;
  gap:14px;
  align-items:flex-start;
}
.notification-feed-title-row h3{
  margin:8px 0 0;
  color:#0f172a;
  font-size:16px;
  line-height:1.42;
  font-weight:650;
}
.notification-feed-title-row time{
  flex:0 0 auto;
  color:#64748b;
  font-size:12px;
  line-height:1.5;
  text-align:right;
  white-space:nowrap;
}
.notification-feed-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
}
.notification-status-badge,
.notification-type-badge{
  display:inline-flex;
  align-items:center;
  min-height:24px;
  padding:0 9px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  line-height:1;
}
.notification-status-badge.is-unread{
  background:#e8f6fb;
  color:#075985;
}
.notification-status-badge.is-read{
  background:#ecfdf3;
  color:#166534;
}
.notification-type-badge{
  background:#f1f5f9;
  color:#475569;
}
.notification-feed-content p{
  margin:9px 0 0;
  color:#475569;
  line-height:1.72;
}
.notification-muted-text{
  color:#94a3b8!important;
}
.notification-feed-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid #edf2f7;
}
.notification-read-meta{
  min-width:0;
  color:#64748b;
  font-size:12px;
  line-height:1.5;
}
.notification-feed-actions{
  justify-content:flex-end;
  margin-top:0;
}
.notification-feed-actions .btn{
  min-height:34px;
}
.notification-empty-state{
  border:1px dashed #cbd5e1;
  border-radius:22px;
  background:#fbfdff;
}
@media(max-width:1180px){
  .notification-summary-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .notification-center-header{
    display:grid;
  }
  .notification-filter-tabs{
    width:100%;
    overflow:auto;
    justify-content:flex-start;
  }
  .notification-filter-tab{
    min-width:110px;
  }
}
@media(max-width:760px){
  .notification-center-hero{
    padding:18px;
    border-radius:22px;
  }
  .notification-hero-actions,
  .notification-hero-actions form,
  .notification-hero-actions .btn,
  .notification-hero-actions button{
    width:100%;
  }
  .notification-summary-grid{
    grid-template-columns:1fr;
    gap:10px;
  }
  .notification-summary-card{
    border-radius:18px;
    padding:14px 15px;
  }
  .notification-center-card{
    padding:14px;
    border-radius:22px;
  }
  .notification-filter-tabs{
    padding:5px;
    border-radius:16px;
  }
  .notification-filter-tab{
    min-width:104px;
    padding:8px 10px;
  }
  .notification-feed-item{
    grid-template-columns:1fr;
    gap:10px;
    padding:14px;
    border-radius:18px;
  }
  .notification-feed-state{
    width:40px;
    height:40px;
    border-radius:14px;
  }
  .notification-feed-title-row{
    display:grid;
    gap:10px;
  }
  .notification-feed-title-row time{
    text-align:left;
    white-space:normal;
  }
  .notification-feed-footer{
    display:grid;
    align-items:stretch;
  }
  .notification-feed-actions,
  .notification-feed-actions form,
  .notification-feed-actions .btn,
  .notification-feed-actions button{
    width:100%;
  }
}

/* --------------------------------------------------------------------------
   Phase 2.9.8 — Notification Center simplification
   Scope: /notifications only. Reduce stacked cards/badges and use a calm
   row-based layout for easier scanning on desktop and mobile.
---------------------------------------------------------------------------- */
.notifications-page-v2{
  display:grid;
  gap:14px;
}
.notification-page-hero .page-hero-actions form{
  margin:0;
}
.notification-page-hero .hero-orbit-card strong{
  font-variant-numeric:tabular-nums;
}
.notifications-summary-v2{
  display:flex;
  align-items:center;
  gap:8px 14px;
  flex-wrap:wrap;
  padding:10px 14px;
  border:1px solid #d8e3ee;
  border-radius:16px;
  background:#fff;
  color:#64748b;
  font-size:13px;
  line-height:1.5;
}
.notifications-summary-v2 span{
  display:inline-flex;
  align-items:center;
  gap:5px;
  min-width:0;
}
.notifications-summary-v2 strong{
  color:#0f172a;
  font-size:16px;
  font-weight:750;
}
.notifications-latest-v2{
  margin-left:auto;
  color:#64748b;
}
.notifications-panel-v2{
  padding:0;
  overflow:hidden;
  border:1px solid #d8e3ee;
  box-shadow:none;
}
.notifications-toolbar-v2{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-bottom:1px solid #e6edf5;
  background:#fff;
}
.notifications-tabs-v2{
  display:flex;
  align-items:center;
  gap:6px;
  overflow:auto;
  scrollbar-width:thin;
}
.notifications-tab-v2{
  display:inline-flex;
  align-items:center;
  gap:7px;
  min-height:36px;
  padding:0 12px;
  border:1px solid transparent;
  border-radius:999px;
  color:#475569;
  text-decoration:none;
  font-size:13px;
  font-weight:700;
  white-space:nowrap;
}
.notifications-tab-v2 span{
  min-width:24px;
  height:22px;
  padding:0 7px;
  display:inline-grid;
  place-items:center;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:12px;
  line-height:1;
}
.notifications-tab-v2:hover{
  background:#f8fafc;
  color:#0e5d89;
}
.notifications-tab-v2.active{
  border-color:#c8d8e8;
  background:#eef8fb;
  color:#063a5a;
}
.notifications-tab-v2.active span{
  background:#fff;
  color:#063a5a;
}
.notifications-list-v2{
  display:grid;
}
.notifications-item-v2{
  display:grid;
  grid-template-columns:10px minmax(0,1fr);
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid #edf2f7;
  background:#fff;
}
.notifications-item-v2:last-child{
  border-bottom:0;
}
.notifications-item-v2.is-unread{
  background:#fbfdff;
}
.notifications-dot-v2{
  width:8px;
  height:8px;
  margin-top:8px;
  border-radius:999px;
  background:#cbd5e1;
}
.notifications-item-v2.is-unread .notifications-dot-v2{
  background:#0e5d89;
  box-shadow:0 0 0 4px rgba(14,93,137,.09);
}
.notifications-item-v2.is-success.is-unread .notifications-dot-v2{background:#16a34a;box-shadow:0 0 0 4px rgba(22,163,74,.09);}
.notifications-item-v2.is-warning.is-unread .notifications-dot-v2{background:#d97706;box-shadow:0 0 0 4px rgba(217,119,6,.1);}
.notifications-item-v2.is-danger.is-unread .notifications-dot-v2{background:#dc2626;box-shadow:0 0 0 4px rgba(220,38,38,.09);}
.notifications-content-v2{
  min-width:0;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(150px,220px) auto;
  gap:14px;
  align-items:start;
}
.notifications-main-v2{
  min-width:0;
}
.notifications-main-v2 h3{
  margin:0;
  color:#0f172a;
  font-size:15px;
  line-height:1.45;
  font-weight:700;
}
.notifications-main-v2 p{
  margin:4px 0 0;
  color:#475569;
  font-size:14px;
  line-height:1.62;
  word-break:break-word;
}
.notifications-main-v2 small{
  display:block;
  margin-top:6px;
  color:#94a3b8;
  font-size:12px;
  line-height:1.45;
}
.notifications-meta-v2{
  display:grid;
  gap:6px;
  justify-items:end;
  color:#64748b;
  font-size:12px;
  line-height:1.5;
  text-align:right;
}
.notifications-meta-v2 time{
  max-width:220px;
}
.notifications-read-state-v2{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:24px;
  padding:0 9px;
  border-radius:999px;
  background:#f1f5f9;
  color:#475569;
  font-size:11px;
  font-weight:750;
  line-height:1;
  white-space:nowrap;
}
.notifications-read-state-v2.is-unread{
  background:#e8f6fb;
  color:#075985;
}
.notifications-read-state-v2.is-read{
  background:#f1f5f9;
  color:#64748b;
}
.notifications-actions-v2{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
}
.notifications-actions-v2 form{
  margin:0;
}
.notifications-actions-v2 .btn{
  min-height:34px;
  white-space:nowrap;
}
.notifications-empty-v2{
  padding:28px 18px;
  text-align:center;
  background:#fff;
}
.notifications-empty-v2 strong{
  display:block;
  color:#0f172a;
  font-size:16px;
}
.notifications-empty-v2 p{
  max-width:560px;
  margin:8px auto 14px;
  color:#64748b;
  line-height:1.65;
}
@media(max-width:1180px){
  .notifications-content-v2{
    grid-template-columns:minmax(0,1fr) auto;
  }
  .notifications-actions-v2{
    grid-column:1 / -1;
    justify-content:flex-start;
  }
}
@media(max-width:760px){
  .notification-page-hero .page-hero-actions,
  .notification-page-hero .page-hero-actions form,
  .notification-page-hero .page-hero-actions .btn,
  .notification-page-hero .page-hero-actions button{
    width:100%;
  }
  .notifications-summary-v2{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:8px;
    padding:10px;
  }
  .notifications-summary-v2 span{
    display:grid;
    gap:1px;
    align-content:center;
  }
  .notifications-latest-v2{
    grid-column:1 / -1;
    margin-left:0;
  }
  .notifications-toolbar-v2{
    padding:10px;
  }
  .notifications-tabs-v2{
    width:100%;
  }
  .notifications-item-v2{
    grid-template-columns:8px minmax(0,1fr);
    gap:10px;
    padding:13px 12px;
  }
  .notifications-content-v2{
    grid-template-columns:1fr;
    gap:8px;
  }
  .notifications-meta-v2{
    justify-items:start;
    text-align:left;
  }
  .notifications-actions-v2,
  .notifications-actions-v2 form,
  .notifications-actions-v2 .btn,
  .notifications-actions-v2 button{
    width:100%;
  }
}

/* --------------------------------------------------------------------------
   Phase 2.9.11 — Notification header uses shared page/form hero system
   Scope: /notifications only. Keep markup on page-hero form-hero and only align
   the action column so notification buttons do not need a separate header system.
---------------------------------------------------------------------------- */
.notification-page-hero.notifications-page-hero,
.notification-page-hero.form-hero{
  margin-bottom:14px!important;
}
.notification-page-hero .notifications-hero-actions{
  justify-self:end!important;
  justify-content:flex-end!important;
  align-self:center!important;
  margin-top:0!important;
}
.notification-page-hero .notifications-hero-actions form{
  margin:0!important;
}
@media(max-width:1180px){
  .notification-page-hero .notifications-hero-actions{
    justify-self:start!important;
    justify-content:flex-start!important;
    margin-top:14px!important;
  }
}
@media(max-width:760px){
  .notification-page-hero .notifications-hero-actions,
  .notification-page-hero .notifications-hero-actions form,
  .notification-page-hero .notifications-hero-actions .btn,
  .notification-page-hero .notifications-hero-actions button{
    width:100%!important;
  }
}

/* --------------------------------------------------------------------------
   Phase 2.9.12 — Dashboard hero redesign
   Scope: /dashboard only. Use shared page-hero form-hero markup, but keep the
   visual treatment restrained so the dashboard header does not overpower data.
---------------------------------------------------------------------------- */
.dashboard-summary-hero.page-hero.form-hero{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(300px,390px)!important;
  align-items:center!important;
  gap:clamp(16px,2vw,28px)!important;
  margin:0 0 18px!important;
  padding:clamp(18px,2vw,26px)!important;
  border:1px solid var(--line,#dbe5f0)!important;
  border-radius:24px!important;
  color:var(--ink,#0b1728)!important;
  box-shadow:0 12px 30px rgba(6,36,58,.06)!important;
}
.dashboard-summary-hero.page-hero.form-hero::before,
.dashboard-summary-hero.page-hero.form-hero::after{
  display:none!important;
  content:none!important;
}
.dashboard-summary-hero .dashboard-summary-hero-copy{
  display:grid!important;
  gap:8px!important;
  align-content:center!important;
}
.dashboard-summary-hero .hero-kicker{
  width:max-content!important;
  border:1px solid #cde8f3!important;
  background:#eff9fc!important;
  color:#0e5d89!important;
  font-size:12px!important;
  font-weight:600!important;
  letter-spacing:.01em!important;
  text-transform:none!important;
  padding:5px 10px!important;
}
.dashboard-summary-hero h2{
  margin:0!important;
  color:#06243a!important;
  font-size:clamp(26px,2.3vw,36px)!important;
  line-height:1.18!important;
  font-weight:650!important;
  letter-spacing:-.025em!important;
  text-shadow:none!important;
}
.dashboard-summary-hero p{
  max-width:760px!important;
  margin:0!important;
  color:#607086!important;
  font-size:14.5px!important;
  line-height:1.72!important;
  font-weight:400!important;
}
.dashboard-summary-actions.page-hero-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:10px!important;
  margin-top:8px!important;
}
.dashboard-summary-actions .btn{
  min-height:42px!important;
  border-radius:14px!important;
  box-shadow:none!important;
}
.dashboard-summary-actions .btn-light,
.dashboard-summary-actions .btn-ghost{
  background:#fff!important;
  color:#26364b!important;
  border-color:#cbd8e6!important;
}
.dashboard-summary-actions .btn-light:hover,
.dashboard-summary-actions .btn-ghost:hover{
  background:#f8fbfd!important;
  color:#0e5d89!important;
  border-color:#9ecddd!important;
}
.dashboard-summary-period{
  display:grid!important;
  gap:8px!important;
  min-width:0!important;
  padding:16px!important;
  border:1px solid #dbe7f0!important;
  border-radius:18px!important;
  background:#f8fbfd!important;
}
.dashboard-summary-period label{
  color:#334155!important;
  font-size:13px!important;
  font-weight:600!important;
  line-height:1.35!important;
}
.dashboard-summary-period select{
  width:100%!important;
  min-height:44px!important;
  border:1px solid #cbd9e6!important;
  border-radius:14px!important;
  background:#fff!important;
  color:#0f2437!important;
  padding:0 12px!important;
  font-size:14px!important;
  font-weight:400!important;
  box-shadow:none!important;
}
.dashboard-summary-period select:focus{
  border-color:#0d7fa8!important;
  outline:none!important;
  box-shadow:0 0 0 4px rgba(13,127,168,.12)!important;
}
.dashboard-summary-period small{
  color:#607086!important;
  font-size:12.5px!important;
  line-height:1.5!important;
  font-weight:400!important;
}
.dashboard-summary-period .btn{
  width:100%!important;
  min-height:42px!important;
  border-radius:14px!important;
}
@media(max-width:1180px){
  .dashboard-summary-hero.page-hero.form-hero{
    grid-template-columns:1fr!important;
  }
  .dashboard-summary-period{
    width:100%!important;
  }
}
@media(max-width:760px){
  .dashboard-summary-hero.page-hero.form-hero{
    padding:16px!important;
    border-radius:20px!important;
    gap:14px!important;
  }
  .dashboard-summary-hero h2{
    font-size:24px!important;
    line-height:1.24!important;
  }
  .dashboard-summary-hero p{
    font-size:13.5px!important;
    line-height:1.65!important;
  }
  .dashboard-summary-actions.page-hero-actions,
  .dashboard-summary-actions .btn{
    width:100%!important;
  }
  .dashboard-summary-actions.page-hero-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  .dashboard-summary-period{
    padding:13px!important;
    border-radius:16px!important;
  }
  .dashboard-summary-period select{
    min-height:48px!important;
    font-size:16px!important;
  }
}

/* Phase 2.8.23 — User employee management UX readability polish
   Scope: /settings/user-employees only. Keep workflow, permissions and forms intact. */
.user-employee-page-hero.page-hero.form-hero{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:end!important;
  gap:clamp(16px,2vw,28px)!important;
  padding:clamp(18px,2vw,28px)!important;
  margin:0!important;
  border:1px solid #dbe5f0!important;
  border-radius:22px!important;
  box-shadow:0 1px 2px rgba(6,36,58,.04)!important;
  overflow:hidden!important;
}
.user-employee-page-hero.page-hero.form-hero:before,
.user-employee-page-hero.page-hero.form-hero:after{display:none!important}
.user-employee-page-hero .hero-kicker,
.user-employee-section-header .section-kicker,
.user-employee-list-header .section-kicker,
.data-authority-card .section-kicker{
  display:inline-flex!important;
  align-items:center!important;
  width:max-content!important;
  min-height:24px!important;
  padding:3px 9px!important;
  border-radius:999px!important;
  background:#eef7fb!important;
  color:#0e5d89!important;
  font-size:12px!important;
  font-weight:500!important;
  line-height:1.35!important;
  letter-spacing:0!important;
  text-transform:none!important;
}
.user-employee-page-hero h1,
.user-employee-page-hero h2{
  margin:8px 0 0!important;
  color:#06243a!important;
  font-size:clamp(24px,2.25vw,34px)!important;
  line-height:1.22!important;
  letter-spacing:-.025em!important;
  font-weight:600!important;
}
.user-employee-page-hero p{
  max-width:780px!important;
  margin:8px 0 0!important;
  color:#607086!important;
  font-size:14px!important;
  line-height:1.7!important;
  font-weight:400!important;
}
.user-employee-hero-actions.page-hero-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:10px!important;
  margin:0!important;
}
.user-employee-hero-actions .button{
  min-height:42px!important;
  border-radius:14px!important;
  white-space:nowrap!important;
}
.user-employee-summary-strip{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:12px!important;
  margin:0!important;
}
.user-employee-summary-item{
  min-width:0!important;
  min-height:86px!important;
  display:grid!important;
  align-content:center!important;
  gap:6px!important;
  padding:14px 16px!important;
  border:1px solid #dbe5f0!important;
  border-radius:18px!important;
  background:#fff!important;
  box-shadow:0 1px 2px rgba(6,36,58,.035)!important;
}
.user-employee-summary-item span{
  color:#607086!important;
  font-size:12.5px!important;
  line-height:1.4!important;
  font-weight:500!important;
}
.user-employee-summary-item strong{
  color:#06243a!important;
  font-size:clamp(22px,2vw,30px)!important;
  line-height:1!important;
  font-weight:600!important;
  letter-spacing:-.02em!important;
}
.user-employee-summary-item.is-good{border-color:#bbf7d0!important;background:#f7fef9!important}
.user-employee-summary-item.is-warning{border-color:#fed7aa!important;background:#fffaf4!important}
.user-employee-setup-grid{
  display:grid!important;
  grid-template-columns:minmax(0,1.5fr) minmax(320px,.78fr)!important;
  gap:16px!important;
  align-items:start!important;
  margin:0!important;
}
.user-employee-section-header,
.user-employee-list-header{
  align-items:flex-start!important;
  margin:0 0 14px!important;
  padding:0 0 12px!important;
  border-bottom:1px solid #e6eef5!important;
}
.user-employee-section-header h2,
.user-employee-list-header h2,
.data-authority-card h2{
  margin:7px 0 0!important;
  color:#06243a!important;
  font-size:clamp(18px,1.4vw,22px)!important;
  line-height:1.32!important;
  font-weight:600!important;
  letter-spacing:-.015em!important;
}
.user-employee-section-header p,
.user-employee-list-header p,
.data-authority-card p{
  margin:5px 0 0!important;
  color:#607086!important;
  font-size:13.5px!important;
  line-height:1.65!important;
}
.user-employee-provision-card,
.data-authority-card,
.user-employee-filter-card{
  background:#fff!important;
  border:1px solid #dbe5f0!important;
  border-radius:22px!important;
  box-shadow:0 1px 2px rgba(6,36,58,.04)!important;
}
.user-employee-provision-card{
  display:grid!important;
  gap:14px!important;
}
.user-employee-provision-main{
  display:flex!important;
  align-items:flex-start!important;
  gap:12px!important;
  padding:12px!important;
  border:1px solid #e6eef5!important;
  border-radius:18px!important;
  background:#f8fbfd!important;
}
.user-employee-provision-main .admin-pro-icon,
.user-employee-authority-icon{
  width:42px!important;
  height:42px!important;
  min-width:42px!important;
  border-radius:14px!important;
  display:grid!important;
  place-items:center!important;
  background:#eef7fb!important;
  color:#0e5d89!important;
  font-size:12px!important;
  font-weight:700!important;
  letter-spacing:.02em!important;
}
.user-employee-provision-main strong{
  display:block!important;
  color:#06243a!important;
  font-size:14px!important;
  line-height:1.45!important;
  font-weight:600!important;
}
.user-employee-provision-main p{
  margin:4px 0 0!important;
  color:#607086!important;
  font-size:13px!important;
  line-height:1.62!important;
}
.user-employee-provision-form{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
  align-items:end!important;
}
.user-employee-provision-form .ldap-lookup-panel,
.user-employee-provision-form .ldap-lookup-search-field{
  grid-column:1/-1!important;
}
.user-employee-provision-form .provision-toggle-field{
  align-self:stretch!important;
  padding:12px!important;
  border:1px solid #e6eef5!important;
  border-radius:16px!important;
  background:#f8fafc!important;
}
.user-employee-provision-form > .button{
  min-height:46px!important;
  border-radius:14px!important;
}
.data-authority-card{
  display:grid!important;
  grid-template-columns:42px minmax(0,1fr)!important;
  gap:12px!important;
  align-content:start!important;
}
.data-authority-card form{
  grid-column:1/-1!important;
  margin-top:4px!important;
}
.data-authority-card .button{width:100%!important;min-height:42px!important;border-radius:14px!important}
.user-employee-filter-card .user-employee-filter{
  display:grid!important;
  grid-template-columns:minmax(280px,1fr) minmax(190px,.35fr) auto auto!important;
  gap:12px!important;
  align-items:end!important;
}
.user-employee-filter-card .field{margin:0!important;min-width:0!important}
.user-employee-filter-card .input,
.user-employee-filter-card .select{
  min-height:44px!important;
  border-radius:14px!important;
}
.user-employee-filter-card .button{
  min-height:44px!important;
  border-radius:14px!important;
  white-space:nowrap!important;
}
.user-employee-sort-note{
  margin:12px 0 0!important;
  padding:11px 12px!important;
  border:1px solid #e6eef5!important;
  border-radius:14px!important;
  background:#f8fbfd!important;
  color:#607086!important;
  font-size:12.8px!important;
  line-height:1.65!important;
}
.user-employee-list-section{
  display:grid!important;
  gap:14px!important;
}
.user-employee-list-header{margin-bottom:0!important}
.user-employee-result-count{
  display:inline-flex!important;
  align-items:center!important;
  min-height:34px!important;
  padding:7px 11px!important;
  border:1px solid #dbe5f0!important;
  border-radius:999px!important;
  background:#fff!important;
  color:#405269!important;
  font-size:12.5px!important;
  font-weight:500!important;
  white-space:nowrap!important;
}
.user-employee-list{
  display:grid!important;
  gap:12px!important;
}
.user-employee-card{
  display:grid!important;
  gap:14px!important;
  padding:16px!important;
  border:1px solid #dbe5f0!important;
  border-radius:22px!important;
  background:#fff!important;
  box-shadow:0 1px 2px rgba(6,36,58,.035)!important;
}
.user-employee-card.is-unlinked{
  border-color:#fed7aa!important;
  background:#fffaf4!important;
}
.user-employee-main{
  display:grid!important;
  grid-template-columns:52px minmax(0,1fr)!important;
  gap:12px!important;
  align-items:start!important;
}
.user-employee-avatar{
  width:52px!important;
  height:52px!important;
  border-radius:16px!important;
  background:#eef7fb!important;
  color:#0e5d89!important;
  font-size:20px!important;
  font-weight:600!important;
  overflow:hidden!important;
}
.user-employee-avatar img{width:100%!important;height:100%!important;object-fit:cover!important;display:block!important}
.user-employee-title{gap:7px!important;min-width:0!important}
.user-employee-topline{display:flex!important;align-items:center!important;gap:8px!important;flex-wrap:wrap!important}
.user-employee-topline strong{
  color:#06243a!important;
  font-size:17px!important;
  line-height:1.35!important;
  font-weight:600!important;
  overflow-wrap:anywhere!important;
}
.user-employee-meta{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:6px!important;
  color:#607086!important;
}
.user-employee-meta span{
  display:inline-flex!important;
  min-height:26px!important;
  align-items:center!important;
  padding:4px 8px!important;
  border:1px solid #e6eef5!important;
  border-radius:999px!important;
  background:#f8fafc!important;
  font-size:12px!important;
  line-height:1.35!important;
  max-width:100%!important;
  overflow-wrap:anywhere!important;
}
.user-employee-issues{
  display:grid!important;
  gap:6px!important;
}
.user-employee-issues span{
  display:block!important;
  width:max-content!important;
  max-width:100%!important;
  padding:6px 9px!important;
  border:1px solid #fed7aa!important;
  border-radius:12px!important;
  background:#fff7ed!important;
  color:#9a3412!important;
  font-size:12px!important;
  line-height:1.5!important;
  font-weight:500!important;
}
.user-employee-info-grid{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(min(100%, 190px),1fr))!important;
  gap:8px!important;
}
.user-employee-info-grid>div{
  min-width:0!important;
  padding:10px 11px!important;
  border:1px solid #e6eef5!important;
  border-radius:14px!important;
  background:#f8fafc!important;
  display:grid!important;
  gap:4px!important;
}
.user-employee-info-grid span{
  color:#607086!important;
  font-size:11.5px!important;
  line-height:1.4!important;
  font-weight:500!important;
}
.user-employee-info-grid strong{
  color:#0b1728!important;
  font-size:13px!important;
  line-height:1.5!important;
  font-weight:500!important;
  overflow-wrap:anywhere!important;
}
.user-employee-actions{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(min(100%, 260px),1fr))!important;
  gap:10px!important;
  align-items:start!important;
  padding-top:12px!important;
  border-top:1px solid #edf3f8!important;
}
.user-employee-actions > form,
.user-employee-actions > details{
  width:100%!important;
  margin:0!important;
}
.user-employee-actions > form .button{
  width:100%!important;
  min-height:42px!important;
  border-radius:14px!important;
}
.user-employee-relink,
.user-employee-signature-panel,
.user-employee-full-edit-panel,
.user-employee-access-panel,
.user-employee-danger-zone{
  width:100%!important;
  border:1px solid #dbe5f0!important;
  border-radius:16px!important;
  background:#fff!important;
  overflow:hidden!important;
  box-shadow:none!important;
}
.user-employee-relink summary,
.user-employee-signature-panel>summary,
.user-employee-full-edit-panel>summary,
.user-employee-access-panel summary,
.user-employee-danger-zone summary{
  min-height:42px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:10px!important;
  padding:10px 12px!important;
  cursor:pointer!important;
  color:#06243a!important;
  font-size:13px!important;
  font-weight:600!important;
  list-style:none!important;
  background:#fff!important;
}
.user-employee-relink summary::-webkit-details-marker,
.user-employee-signature-panel>summary::-webkit-details-marker,
.user-employee-full-edit-panel>summary::-webkit-details-marker,
.user-employee-access-panel summary::-webkit-details-marker,
.user-employee-danger-zone summary::-webkit-details-marker{display:none!important}
.user-employee-relink summary:after,
.user-employee-signature-panel>summary:after,
.user-employee-full-edit-panel>summary:after,
.user-employee-access-panel summary:after,
.user-employee-danger-zone summary:after{
  content:'›'!important;
  width:24px!important;
  height:24px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:999px!important;
  background:#f1f5f9!important;
  color:#607086!important;
  transform:rotate(90deg)!important;
  flex:0 0 auto!important;
}
.user-employee-relink[open] summary:after,
.user-employee-signature-panel[open]>summary:after,
.user-employee-full-edit-panel[open]>summary:after,
.user-employee-access-panel[open] summary:after,
.user-employee-danger-zone[open] summary:after{transform:rotate(-90deg)!important}
.user-employee-relink[open] summary,
.user-employee-signature-panel[open]>summary,
.user-employee-full-edit-panel[open]>summary,
.user-employee-access-panel[open] summary,
.user-employee-danger-zone[open] summary{
  background:#f8fbfd!important;
  border-bottom:1px solid #e6eef5!important;
}
.user-employee-signature-panel>summary small,
.user-employee-full-edit-panel>summary small,
.user-employee-access-panel summary small{
  color:#607086!important;
  font-size:12px!important;
  font-weight:400!important;
  text-align:right!important;
  min-width:0!important;
}
.user-employee-relink form,
.user-employee-danger-zone form{
  display:grid!important;
  gap:10px!important;
  padding:12px!important;
}
.user-employee-relink .button,
.user-employee-danger-zone .button{width:100%!important;min-height:42px!important;border-radius:14px!important}
.signature-admin-layout{
  grid-template-columns:minmax(240px,.36fr) minmax(0,1fr)!important;
  gap:12px!important;
  padding:12px!important;
  background:#fff!important;
}
.signature-current-card,
.signature-manage-form{
  border-radius:16px!important;
  box-shadow:none!important;
}
.user-full-edit-grid,
.user-access-editor-grid{
  gap:14px!important;
}
.user-full-edit-fields{
  gap:12px!important;
}
.user-full-edit-actions,
.user-access-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
  flex-wrap:wrap!important;
}
.user-full-edit-actions .button,
.user-access-actions .button{min-height:42px!important;border-radius:14px!important}
@media(max-width:1180px){
  .user-employee-page-hero.page-hero.form-hero,
  .user-employee-setup-grid{
    grid-template-columns:1fr!important;
  }
  .user-employee-hero-actions.page-hero-actions{
    justify-content:flex-start!important;
  }
  .user-employee-summary-strip{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .data-authority-card{
    grid-template-columns:42px minmax(0,1fr)!important;
  }
  .user-employee-filter-card .user-employee-filter{
    grid-template-columns:1fr 220px!important;
  }
  .user-employee-filter-card .button{
    width:100%!important;
  }
}
@media(max-width:760px){
  .user-employee-page-hero.page-hero.form-hero{
    padding:16px!important;
    border-radius:18px!important;
    gap:14px!important;
  }
  .user-employee-page-hero h1,
  .user-employee-page-hero h2{
    font-size:23px!important;
    line-height:1.28!important;
  }
  .user-employee-page-hero p{
    font-size:13.5px!important;
    line-height:1.65!important;
  }
  .user-employee-hero-actions.page-hero-actions,
  .user-employee-hero-actions .button,
  .user-employee-summary-strip,
  .user-employee-provision-form,
  .user-employee-filter-card .user-employee-filter,
  .data-authority-card{
    display:grid!important;
    grid-template-columns:1fr!important;
    width:100%!important;
  }
  .user-employee-summary-strip{gap:10px!important}
  .user-employee-summary-item{
    min-height:76px!important;
    padding:13px 14px!important;
  }
  .user-employee-provision-main{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .user-employee-provision-main .admin-pro-icon,
  .user-employee-authority-icon{width:40px!important;height:40px!important;min-width:40px!important}
  .user-employee-filter-card .button,
  .user-employee-provision-form > .button{
    width:100%!important;
    min-height:46px!important;
  }
  .user-employee-list-header{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .user-employee-result-count{width:max-content!important}
  .user-employee-card{
    padding:14px!important;
    border-radius:18px!important;
  }
  .user-employee-main{
    grid-template-columns:44px minmax(0,1fr)!important;
  }
  .user-employee-avatar{width:44px!important;height:44px!important;border-radius:14px!important;font-size:18px!important}
  .user-employee-topline strong{font-size:15.5px!important}
  .user-employee-meta{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .user-employee-meta span{width:100%!important;border-radius:12px!important}
  .user-employee-actions{
    grid-template-columns:1fr!important;
  }
  .user-employee-signature-panel>summary,
  .user-employee-full-edit-panel>summary,
  .user-employee-access-panel summary{
    align-items:flex-start!important;
    flex-direction:column!important;
  }
  .user-employee-signature-panel>summary:after,
  .user-employee-full-edit-panel>summary:after,
  .user-employee-access-panel summary:after{
    position:absolute!important;
    right:10px!important;
    top:10px!important;
  }
  .user-employee-signature-panel>summary,
  .user-employee-full-edit-panel>summary,
  .user-employee-access-panel summary{position:relative!important;padding-right:42px!important}
  .user-employee-signature-panel>summary small,
  .user-employee-full-edit-panel>summary small,
  .user-employee-access-panel summary small{text-align:left!important}
  .signature-admin-layout,
  .user-full-edit-grid,
  .user-access-editor-grid{
    grid-template-columns:1fr!important;
  }
  .user-full-edit-actions,
  .user-access-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .user-full-edit-actions .button,
  .user-access-actions .button{width:100%!important}
}

/* User employee expandable panels - clearer accordion controls */
.user-employee-actions{
  grid-template-columns:1fr!important;
  gap:12px!important;
  padding-top:14px!important;
  border-top:1px solid #e6eef5!important;
}
.user-employee-actions-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:12px!important;
  padding:12px 14px!important;
  border:1px solid #dbe5f0!important;
  border-radius:16px!important;
  background:#f8fbfd!important;
  color:#0b1728!important;
}
.user-employee-actions-head strong{
  display:block!important;
  color:#06243a!important;
  font-size:14px!important;
  line-height:1.4!important;
  font-weight:700!important;
}
.user-employee-actions-head span{
  display:block!important;
  margin-top:3px!important;
  color:#607086!important;
  font-size:12.5px!important;
  line-height:1.55!important;
}
.user-employee-quick-action{
  width:100%!important;
}
.user-employee-quick-action .button{
  width:auto!important;
  min-width:190px!important;
  min-height:42px!important;
}
.user-employee-expand-panel,
.user-employee-relink.user-employee-expand-panel,
.user-employee-signature-panel.user-employee-expand-panel,
.user-employee-full-edit-panel.user-employee-expand-panel,
.user-employee-access-panel.user-employee-expand-panel,
.user-employee-danger-zone.user-employee-expand-panel{
  width:100%!important;
  border:1px solid #cbddec!important;
  border-left:4px solid #0e7490!important;
  border-radius:16px!important;
  background:#fff!important;
  box-shadow:0 1px 2px rgba(6,36,58,.045)!important;
  overflow:hidden!important;
}
.user-employee-danger-zone.user-employee-expand-panel{
  border-color:#fecaca!important;
  border-left-color:#dc2626!important;
  background:#fffafa!important;
}
.user-employee-expand-panel>summary,
.user-employee-relink.user-employee-expand-panel>summary,
.user-employee-signature-panel.user-employee-expand-panel>summary,
.user-employee-full-edit-panel.user-employee-expand-panel>summary,
.user-employee-access-panel.user-employee-expand-panel>summary,
.user-employee-danger-zone.user-employee-expand-panel>summary{
  min-height:58px!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:center!important;
  gap:12px!important;
  padding:13px 14px!important;
  cursor:pointer!important;
  color:#06243a!important;
  background:#fff!important;
  list-style:none!important;
}
.user-employee-expand-panel>summary:hover,
.user-employee-relink.user-employee-expand-panel>summary:hover,
.user-employee-signature-panel.user-employee-expand-panel>summary:hover,
.user-employee-full-edit-panel.user-employee-expand-panel>summary:hover,
.user-employee-access-panel.user-employee-expand-panel>summary:hover,
.user-employee-danger-zone.user-employee-expand-panel>summary:hover{
  background:#f8fbfd!important;
}
.user-employee-expand-panel>summary:focus-visible,
.user-employee-relink.user-employee-expand-panel>summary:focus-visible,
.user-employee-signature-panel.user-employee-expand-panel>summary:focus-visible,
.user-employee-full-edit-panel.user-employee-expand-panel>summary:focus-visible,
.user-employee-access-panel.user-employee-expand-panel>summary:focus-visible,
.user-employee-danger-zone.user-employee-expand-panel>summary:focus-visible{
  outline:3px solid rgba(14,116,144,.22)!important;
  outline-offset:-3px!important;
}
.user-employee-expand-panel>summary span,
.user-employee-relink.user-employee-expand-panel>summary span,
.user-employee-signature-panel.user-employee-expand-panel>summary span,
.user-employee-full-edit-panel.user-employee-expand-panel>summary span,
.user-employee-access-panel.user-employee-expand-panel>summary span,
.user-employee-danger-zone.user-employee-expand-panel>summary span{
  display:block!important;
  min-width:0!important;
  color:#06243a!important;
  font-size:14px!important;
  line-height:1.4!important;
  font-weight:700!important;
  overflow-wrap:anywhere!important;
}
.user-employee-expand-panel>summary small,
.user-employee-relink.user-employee-expand-panel>summary small,
.user-employee-signature-panel.user-employee-expand-panel>summary small,
.user-employee-full-edit-panel.user-employee-expand-panel>summary small,
.user-employee-access-panel.user-employee-expand-panel>summary small,
.user-employee-danger-zone.user-employee-expand-panel>summary small{
  display:block!important;
  margin-top:3px!important;
  color:#607086!important;
  font-size:12px!important;
  line-height:1.45!important;
  font-weight:500!important;
  text-align:left!important;
}
.user-employee-expand-panel>summary:after,
.user-employee-relink.user-employee-expand-panel>summary:after,
.user-employee-signature-panel.user-employee-expand-panel>summary:after,
.user-employee-full-edit-panel.user-employee-expand-panel>summary:after,
.user-employee-access-panel.user-employee-expand-panel>summary:after,
.user-employee-danger-zone.user-employee-expand-panel>summary:after{
  content:'ขยาย'!important;
  width:auto!important;
  min-width:54px!important;
  height:30px!important;
  padding:0 11px!important;
  display:inline-grid!important;
  place-items:center!important;
  border:1px solid #cbddec!important;
  border-radius:999px!important;
  background:#f8fbfd!important;
  color:#0e5d89!important;
  font-size:12px!important;
  font-weight:700!important;
  line-height:1!important;
  transform:none!important;
  position:static!important;
}
.user-employee-expand-panel[open]>summary:after,
.user-employee-relink.user-employee-expand-panel[open]>summary:after,
.user-employee-signature-panel.user-employee-expand-panel[open]>summary:after,
.user-employee-full-edit-panel.user-employee-expand-panel[open]>summary:after,
.user-employee-access-panel.user-employee-expand-panel[open]>summary:after,
.user-employee-danger-zone.user-employee-expand-panel[open]>summary:after{
  content:'ย่อ'!important;
  background:#0e5d89!important;
  border-color:#0e5d89!important;
  color:#fff!important;
  transform:none!important;
}
.user-employee-expand-panel[open]>summary,
.user-employee-relink.user-employee-expand-panel[open]>summary,
.user-employee-signature-panel.user-employee-expand-panel[open]>summary,
.user-employee-full-edit-panel.user-employee-expand-panel[open]>summary,
.user-employee-access-panel.user-employee-expand-panel[open]>summary,
.user-employee-danger-zone.user-employee-expand-panel[open]>summary{
  background:#f8fbfd!important;
  border-bottom:1px solid #dbe5f0!important;
}
.user-employee-expand-panel>form,
.user-employee-relink.user-employee-expand-panel>form,
.user-employee-danger-zone.user-employee-expand-panel>form,
.user-employee-expand-panel>.signature-admin-layout,
.user-employee-expand-panel>.user-full-edit-grid,
.user-employee-expand-panel>.user-access-editor-grid{
  border-top:0!important;
}
.user-employee-danger-zone.user-employee-expand-panel>summary:after{
  border-color:#fecaca!important;
  background:#fff1f2!important;
  color:#991b1b!important;
}
.user-employee-danger-zone.user-employee-expand-panel[open]>summary:after{
  border-color:#dc2626!important;
  background:#dc2626!important;
  color:#fff!important;
}
@media(max-width:760px){
  .user-employee-actions-head{
    padding:11px 12px!important;
    border-radius:14px!important;
  }
  .user-employee-quick-action .button{
    width:100%!important;
  }
  .user-employee-expand-panel>summary,
  .user-employee-relink.user-employee-expand-panel>summary,
  .user-employee-signature-panel.user-employee-expand-panel>summary,
  .user-employee-full-edit-panel.user-employee-expand-panel>summary,
  .user-employee-access-panel.user-employee-expand-panel>summary,
  .user-employee-danger-zone.user-employee-expand-panel>summary{
    grid-template-columns:1fr!important;
    gap:8px!important;
    padding:13px 12px!important;
    padding-right:12px!important;
  }
  .user-employee-expand-panel>summary:after,
  .user-employee-relink.user-employee-expand-panel>summary:after,
  .user-employee-signature-panel.user-employee-expand-panel>summary:after,
  .user-employee-full-edit-panel.user-employee-expand-panel>summary:after,
  .user-employee-access-panel.user-employee-expand-panel>summary:after,
  .user-employee-danger-zone.user-employee-expand-panel>summary:after{
    justify-self:start!important;
    position:static!important;
  }
}

/* User employees layout refresh - workflow based tool grouping */
.user-employee-setup-grid{
  grid-template-columns:minmax(0,1.35fr) minmax(300px,420px)!important;
  gap:18px!important;
}
.user-employee-card{
  gap:16px!important;
  padding:18px!important;
  border-radius:20px!important;
}
.user-employee-main{
  padding-bottom:4px!important;
}
.user-employee-info-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,210px),1fr))!important;
  gap:10px!important;
}
.user-employee-info-grid>div{
  background:#fbfdff!important;
  border-color:#e4edf5!important;
}
.user-employee-actions{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:14px!important;
  padding-top:16px!important;
  border-top:1px solid #e4edf5!important;
}
.user-employee-actions-head{
  padding:0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
}
.user-employee-actions-head strong{
  font-size:15px!important;
  font-weight:700!important;
}
.user-employee-actions-head span{
  max-width:780px!important;
  font-size:12.8px!important;
}
.user-employee-tool-layout{
  display:grid!important;
  gap:14px!important;
}
.user-employee-tool-group{
  display:grid!important;
  gap:12px!important;
  padding:14px!important;
  border:1px solid #dbe5f0!important;
  border-radius:18px!important;
  background:#fff!important;
}
.user-employee-tool-group-primary{
  background:#fbfdff!important;
}
.user-employee-tool-group-advanced{
  background:#f8fafc!important;
}
.user-employee-tool-group-title{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:12px!important;
  padding-bottom:10px!important;
  border-bottom:1px solid #e6eef5!important;
}
.user-employee-tool-group-title strong{
  color:#06243a!important;
  font-size:14px!important;
  line-height:1.4!important;
  font-weight:700!important;
}
.user-employee-tool-group-title span{
  max-width:560px!important;
  color:#607086!important;
  font-size:12.5px!important;
  line-height:1.55!important;
  text-align:right!important;
}
.user-employee-tool-grid{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:12px!important;
  align-items:start!important;
}
.user-employee-advanced-stack{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:10px!important;
}
.user-employee-tool-card,
.user-employee-relink.user-employee-tool-card,
.user-employee-signature-panel.user-employee-tool-card{
  min-height:100%!important;
  margin:0!important;
  border:1px solid #dbe5f0!important;
  border-left:0!important;
  border-radius:16px!important;
  background:#fff!important;
  box-shadow:0 1px 2px rgba(6,36,58,.035)!important;
  overflow:hidden!important;
}
.user-employee-quick-action.user-employee-tool-card{
  display:grid!important;
  gap:12px!important;
  align-content:space-between!important;
  padding:13px!important;
}
.user-employee-quick-action.user-employee-tool-card>div{
  display:grid!important;
  gap:4px!important;
}
.user-employee-quick-action.user-employee-tool-card strong{
  color:#06243a!important;
  font-size:14px!important;
  line-height:1.4!important;
  font-weight:700!important;
}
.user-employee-quick-action.user-employee-tool-card span{
  color:#607086!important;
  font-size:12.2px!important;
  line-height:1.5!important;
}
.user-employee-quick-action.user-employee-tool-card .button{
  width:100%!important;
  min-width:0!important;
  min-height:38px!important;
}
.user-employee-tool-card>summary,
.user-employee-relink.user-employee-tool-card>summary,
.user-employee-signature-panel.user-employee-tool-card>summary{
  min-height:112px!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  align-content:space-between!important;
  gap:10px!important;
  padding:13px!important;
  background:#fff!important;
  border-bottom:0!important;
}
.user-employee-tool-card>summary span,
.user-employee-relink.user-employee-tool-card>summary span,
.user-employee-signature-panel.user-employee-tool-card>summary span{
  color:#06243a!important;
  font-size:14px!important;
  line-height:1.4!important;
  font-weight:700!important;
}
.user-employee-tool-card>summary small,
.user-employee-relink.user-employee-tool-card>summary small,
.user-employee-signature-panel.user-employee-tool-card>summary small{
  color:#607086!important;
  font-size:12.2px!important;
  line-height:1.5!important;
}
.user-employee-tool-card>summary:after,
.user-employee-relink.user-employee-tool-card>summary:after,
.user-employee-signature-panel.user-employee-tool-card>summary:after{
  justify-self:start!important;
  min-width:72px!important;
  height:30px!important;
  margin-top:4px!important;
}
.user-employee-tool-card[open],
.user-employee-relink.user-employee-tool-card[open],
.user-employee-signature-panel.user-employee-tool-card[open]{
  grid-column:1/-1!important;
}
.user-employee-tool-card[open]>summary,
.user-employee-relink.user-employee-tool-card[open]>summary,
.user-employee-signature-panel.user-employee-tool-card[open]>summary{
  min-height:auto!important;
  border-bottom:1px solid #dbe5f0!important;
  background:#f8fbfd!important;
}
.user-employee-tool-card>form,
.user-employee-relink.user-employee-tool-card>form,
.user-employee-tool-card>.signature-admin-layout,
.user-employee-signature-panel.user-employee-tool-card>.signature-admin-layout{
  padding:14px!important;
  background:#fff!important;
}
.user-employee-advanced-stack .user-employee-expand-panel,
.user-employee-full-edit-panel.user-employee-expand-panel,
.user-employee-access-panel.user-employee-expand-panel,
.user-employee-danger-zone.user-employee-expand-panel{
  margin:0!important;
  border-left-width:0!important;
  border-radius:16px!important;
  background:#fff!important;
}
.user-employee-advanced-stack .user-employee-expand-panel>summary,
.user-employee-full-edit-panel.user-employee-expand-panel>summary,
.user-employee-access-panel.user-employee-expand-panel>summary,
.user-employee-danger-zone.user-employee-expand-panel>summary{
  min-height:54px!important;
  padding:12px 14px!important;
}
.user-employee-danger-zone.user-employee-expand-panel{
  border-color:#fecaca!important;
}
.user-employee-danger-zone.user-employee-expand-panel>summary{
  background:#fff7f7!important;
}
.user-full-edit-grid,
.user-access-editor-grid{
  gap:14px!important;
}
@media(max-width:1180px){
  .user-employee-setup-grid{
    grid-template-columns:1fr!important;
  }
  .user-employee-tool-grid{
    grid-template-columns:1fr!important;
  }
  .user-employee-tool-card>summary,
  .user-employee-relink.user-employee-tool-card>summary,
  .user-employee-signature-panel.user-employee-tool-card>summary{
    min-height:0!important;
  }
}
@media(max-width:760px){
  .user-employee-card{
    padding:14px!important;
    border-radius:18px!important;
  }
  .user-employee-tool-group{
    padding:12px!important;
    border-radius:16px!important;
  }
  .user-employee-tool-group-title{
    display:grid!important;
    gap:4px!important;
  }
  .user-employee-tool-group-title span{
    max-width:none!important;
    text-align:left!important;
  }
  .user-employee-tool-card>summary,
  .user-employee-relink.user-employee-tool-card>summary,
  .user-employee-signature-panel.user-employee-tool-card>summary{
    padding:12px!important;
  }
  .user-employee-tool-card>form,
  .user-employee-relink.user-employee-tool-card>form,
  .user-employee-tool-card>.signature-admin-layout,
  .user-employee-signature-panel.user-employee-tool-card>.signature-admin-layout{
    padding:12px!important;
  }
}

/* Phase 2.8.25 — User employees easier card workflow
   Keep record scanning clean: show data first, keep management tools in one obvious drawer. */
.user-employee-card-toolbar{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(220px,auto)!important;
  gap:12px!important;
  align-items:start!important;
  padding-top:14px!important;
  border-top:1px solid #e4edf5!important;
}
.user-employee-card-toolbar-text{
  min-height:48px!important;
  display:grid!important;
  align-content:center!important;
  gap:3px!important;
  padding:11px 13px!important;
  border:1px solid #e6eef5!important;
  border-radius:15px!important;
  background:#fbfdff!important;
}
.user-employee-card-toolbar-text strong{
  color:#06243a!important;
  font-size:13.5px!important;
  line-height:1.4!important;
  font-weight:700!important;
}
.user-employee-card-toolbar-text span{
  color:#607086!important;
  font-size:12.2px!important;
  line-height:1.45!important;
}
.user-employee-management-drawer{
  width:100%!important;
  min-width:220px!important;
  margin:0!important;
  border:1px solid #cbddec!important;
  border-radius:15px!important;
  background:#fff!important;
  overflow:hidden!important;
  box-shadow:0 1px 2px rgba(6,36,58,.035)!important;
}
.user-employee-management-drawer>summary{
  min-height:48px!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:center!important;
  gap:12px!important;
  padding:10px 13px!important;
  cursor:pointer!important;
  list-style:none!important;
  background:#fff!important;
  color:#06243a!important;
}
.user-employee-management-drawer>summary::-webkit-details-marker{display:none!important}
.user-employee-management-drawer>summary span{
  display:block!important;
  color:#06243a!important;
  font-size:13.5px!important;
  line-height:1.35!important;
  font-weight:700!important;
}
.user-employee-management-drawer>summary small{
  display:block!important;
  margin-top:2px!important;
  color:#607086!important;
  font-size:11.8px!important;
  line-height:1.35!important;
  font-weight:500!important;
}
.user-employee-management-drawer>summary:after{
  content:'เปิด'!important;
  display:inline-grid!important;
  place-items:center!important;
  min-width:48px!important;
  height:28px!important;
  padding:0 10px!important;
  border:1px solid #0e5d89!important;
  border-radius:999px!important;
  background:#0e5d89!important;
  color:#fff!important;
  font-size:12px!important;
  font-weight:700!important;
  line-height:1!important;
}
.user-employee-management-drawer[open]{
  grid-column:1/-1!important;
}
.user-employee-management-drawer[open]>summary{
  background:#f8fbfd!important;
  border-bottom:1px solid #dbe5f0!important;
}
.user-employee-management-drawer[open]>summary:after{
  content:'ปิด'!important;
  background:#fff!important;
  color:#0e5d89!important;
}
.user-employee-management-drawer .user-employee-actions{
  padding:14px!important;
  border-top:0!important;
}
.user-employee-management-drawer .user-employee-actions-head{
  padding:10px 0 12px!important;
  border-bottom:1px solid #e6eef5!important;
}
.user-employee-tool-layout{
  gap:12px!important;
}
.user-employee-tool-group{
  padding:12px!important;
  border-radius:16px!important;
}
.user-employee-tool-group-title{
  align-items:flex-start!important;
  padding-bottom:9px!important;
}
.user-employee-tool-group-title span{
  max-width:720px!important;
}
.user-employee-tool-grid{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr))!important;
  gap:10px!important;
}
.user-employee-tool-card>summary,
.user-employee-relink.user-employee-tool-card>summary,
.user-employee-signature-panel.user-employee-tool-card>summary{
  min-height:84px!important;
}
.user-employee-quick-action.user-employee-tool-card{
  min-height:84px!important;
  padding:12px!important;
}
.user-employee-advanced-stack{
  gap:8px!important;
}
.user-employee-advanced-stack .user-employee-expand-panel>summary,
.user-employee-full-edit-panel.user-employee-expand-panel>summary,
.user-employee-access-panel.user-employee-expand-panel>summary,
.user-employee-danger-zone.user-employee-expand-panel>summary{
  min-height:48px!important;
}
@media(max-width:900px){
  .user-employee-card-toolbar{
    grid-template-columns:1fr!important;
  }
  .user-employee-management-drawer{
    min-width:0!important;
  }
}
@media(max-width:760px){
  .user-employee-card-toolbar-text{
    padding:10px 12px!important;
  }
  .user-employee-management-drawer>summary{
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  .user-employee-management-drawer>summary:after{
    justify-self:start!important;
  }
  .user-employee-management-drawer .user-employee-actions{
    padding:12px!important;
  }
  .user-employee-tool-card>summary,
  .user-employee-relink.user-employee-tool-card>summary,
  .user-employee-signature-panel.user-employee-tool-card>summary,
  .user-employee-quick-action.user-employee-tool-card{
    min-height:0!important;
  }
}

/* Phase 2.8.26 — SLA Policies layout polish
   Rebuild the SLA policy settings page into a cleaner two-column workflow without changing backend behavior. */
.sla-policy-hero-v2{
  grid-template-columns:minmax(0,1fr) minmax(260px,340px)!important;
  align-items:center!important;
}
.sla-policy-hero-copy{
  min-width:0!important;
}
.sla-policy-hero-status{
  justify-self:end!important;
  width:100%!important;
  max-width:340px!important;
}
.sla-policy-summary-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:14px!important;
  margin:0 0 18px!important;
}
.sla-policy-summary-card{
  min-width:0!important;
  border:1px solid #dbe5f0!important;
  border-radius:20px!important;
  background:#fff!important;
  padding:15px 16px!important;
  box-shadow:0 8px 20px rgba(6,36,58,.045)!important;
}
.sla-policy-summary-card span{
  display:block!important;
  color:#607086!important;
  font-size:12px!important;
  line-height:1.3!important;
  font-weight:650!important;
}
.sla-policy-summary-card strong{
  display:block!important;
  margin-top:7px!important;
  color:#06243a!important;
  font-size:28px!important;
  line-height:1!important;
  font-weight:720!important;
  letter-spacing:-.025em!important;
}
.sla-policy-summary-card small{
  display:block!important;
  margin-top:7px!important;
  color:#607086!important;
  font-size:12px!important;
  line-height:1.45!important;
  font-weight:430!important;
}
.sla-policy-summary-card.is-success{
  border-color:#bbf7d0!important;
  background:linear-gradient(180deg,#ffffff 0%,#f6fef9 100%)!important;
}
.sla-policy-summary-card.is-info{
  border-color:#cde8f3!important;
  background:linear-gradient(180deg,#ffffff 0%,#f4fbff 100%)!important;
}
.sla-policy-summary-card.is-muted{
  background:#fbfdff!important;
}
.sla-policy-workspace{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(330px,390px)!important;
  gap:18px!important;
  align-items:start!important;
}
.sla-policy-list-card-v2,
.sla-policy-add-card-v2,
.sla-policy-guide-card-v2{
  border-color:#dbe5f0!important;
  background:#fff!important;
  box-shadow:0 10px 26px rgba(6,36,58,.045)!important;
}
.sla-policy-list-card-v2{
  padding:18px!important;
  overflow:hidden!important;
}
.sla-policy-section-head{
  align-items:flex-start!important;
  border-bottom:1px solid #e7eef6!important;
  padding-bottom:15px!important;
  margin-bottom:15px!important;
}
.sla-policy-section-head h2,
.sla-policy-add-card-v2 h2{
  font-size:20px!important;
  font-weight:700!important;
  letter-spacing:-.02em!important;
}
.sla-policy-section-head p,
.sla-policy-add-card-v2 p{
  max-width:760px!important;
  color:#607086!important;
  font-size:13px!important;
  line-height:1.62!important;
  font-weight:430!important;
}
.sla-policy-count-pill{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:32px!important;
  white-space:nowrap!important;
  border:1px solid #dbe5f0!important;
  border-radius:999px!important;
  background:#f8fbfd!important;
  color:#405269!important;
  padding:6px 11px!important;
  font-size:12px!important;
  font-weight:650!important;
}
.sla-policy-list-v2{
  display:grid!important;
  gap:13px!important;
}
.sla-policy-item-v2{
  display:grid!important;
  gap:14px!important;
  border:1px solid #dbe5f0!important;
  border-radius:22px!important;
  background:#fff!important;
  padding:15px!important;
  box-shadow:0 1px 2px rgba(6,36,58,.035)!important;
  position:relative!important;
  overflow:hidden!important;
}
.sla-policy-item-v2:before{
  content:''!important;
  position:absolute!important;
  left:0!important;
  top:0!important;
  bottom:0!important;
  width:4px!important;
  background:#cbd5e1!important;
}
.sla-policy-item-v2.is-active:before{
  background:#16815a!important;
}
.sla-policy-item-v2.is-inactive{
  background:#fbfdff!important;
}
.sla-policy-card-head-v2{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  gap:14px!important;
  align-items:start!important;
}
.sla-policy-identity-v2{
  display:flex!important;
  gap:12px!important;
  align-items:flex-start!important;
  min-width:0!important;
}
.sla-policy-code-v2{
  flex:0 0 auto!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:78px!important;
  min-height:38px!important;
  max-width:150px!important;
  padding:8px 10px!important;
  border:1px solid #cde8f3!important;
  border-radius:14px!important;
  background:#e8f6fb!important;
  color:#0e5d89!important;
  font-size:12px!important;
  line-height:1.15!important;
  font-weight:720!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
}
.sla-policy-identity-v2 h3{
  margin:0!important;
  color:#06243a!important;
  font-size:17px!important;
  line-height:1.35!important;
  font-weight:700!important;
  letter-spacing:-.015em!important;
}
.sla-policy-identity-v2 p{
  margin:4px 0 0!important;
  color:#607086!important;
  font-size:12.5px!important;
  line-height:1.55!important;
  font-weight:430!important;
}
.sla-policy-switch-v2{
  display:inline-flex!important;
  align-items:center!important;
  gap:9px!important;
  cursor:pointer!important;
  user-select:none!important;
  border:1px solid #dbe5f0!important;
  border-radius:999px!important;
  background:#f8fbfd!important;
  padding:7px 10px!important;
  color:#405269!important;
  font-size:12.5px!important;
  font-weight:650!important;
}
.sla-policy-switch-v2 input{
  position:absolute!important;
  opacity:0!important;
  pointer-events:none!important;
}
.sla-policy-switch-v2 span{
  width:38px!important;
  height:22px!important;
  border-radius:999px!important;
  background:#cbd5e1!important;
  position:relative!important;
  transition:.16s ease!important;
}
.sla-policy-switch-v2 span:before{
  content:''!important;
  position:absolute!important;
  top:3px!important;
  left:3px!important;
  width:16px!important;
  height:16px!important;
  border-radius:999px!important;
  background:#fff!important;
  box-shadow:0 2px 7px rgba(15,23,42,.20)!important;
  transition:.16s ease!important;
}
.sla-policy-switch-v2 input:checked + span{
  background:#16815a!important;
}
.sla-policy-switch-v2 input:checked + span:before{
  transform:translateX(16px)!important;
}
.sla-policy-switch-v2 em{
  font-style:normal!important;
  white-space:nowrap!important;
}
.sla-policy-timeline-v2{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:8px!important;
  padding:10px!important;
  border:1px solid #e6eef5!important;
  border-radius:17px!important;
  background:#fbfdff!important;
}
.sla-policy-timeline-v2 div{
  min-width:0!important;
  display:grid!important;
  gap:4px!important;
  padding:9px 10px!important;
  border:1px solid #edf3f8!important;
  border-radius:14px!important;
  background:#fff!important;
}
.sla-policy-timeline-v2 span{
  color:#607086!important;
  font-size:11.5px!important;
  line-height:1.2!important;
  font-weight:620!important;
}
.sla-policy-timeline-v2 strong{
  color:#06243a!important;
  font-size:15px!important;
  line-height:1.15!important;
  font-weight:720!important;
}
.sla-policy-form-grid-v2,
.sla-policy-side-grid-v2{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:12px!important;
}
.sla-policy-field-v2{
  display:grid!important;
  gap:7px!important;
  min-width:0!important;
}
.sla-policy-field-v2.is-wide{
  grid-column:1/-1!important;
}
.sla-policy-field-v2 span{
  display:flex!important;
  align-items:center!important;
  gap:7px!important;
  flex-wrap:wrap!important;
  color:#334155!important;
  font-size:12.5px!important;
  line-height:1.35!important;
  font-weight:680!important;
}
.sla-policy-field-v2 span small{
  display:inline-flex!important;
  align-items:center!important;
  min-height:20px!important;
  border-radius:999px!important;
  background:#fff7ed!important;
  color:#c2410c!important;
  padding:2px 7px!important;
  font-size:10.5px!important;
  line-height:1!important;
  font-weight:700!important;
}
.sla-policy-field-v2 .input,
.sla-policy-field-v2 .select,
.sla-policy-field-v2 input,
.sla-policy-field-v2 select,
.sla-policy-field-v2 textarea{
  min-height:44px!important;
  border-radius:14px!important;
  background:#fff!important;
}
.sla-policy-field-v2 textarea{
  line-height:1.6!important;
}
.sla-policy-card-actions-v2{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  gap:12px!important;
  align-items:center!important;
  border-top:1px solid #e7eef6!important;
  padding-top:12px!important;
}
.sla-policy-card-actions-v2 small{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.55!important;
  font-weight:430!important;
}
.sla-policy-card-actions-v2 .btn{
  white-space:nowrap!important;
}
.sla-policy-side-v2{
  display:grid!important;
  gap:14px!important;
  position:sticky!important;
  top:92px!important;
  align-self:start!important;
}
.sla-policy-add-card-v2{
  padding:16px!important;
}
.sla-policy-add-form-v2{
  display:grid!important;
  gap:13px!important;
}
.sla-policy-side-grid-v2{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
}
.sla-policy-add-form-v2 .btn{
  width:100%!important;
}
.sla-policy-guide-card-v2{
  padding:16px!important;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%)!important;
}
.sla-policy-guide-head-v2 span{
  display:inline-flex!important;
  width:max-content!important;
  border:1px solid #cde8f3!important;
  border-radius:999px!important;
  background:#e8f6fb!important;
  color:#0e5d89!important;
  padding:5px 10px!important;
  font-size:11.5px!important;
  font-weight:720!important;
}
.sla-policy-guide-head-v2 h3{
  margin:10px 0 0!important;
  color:#06243a!important;
  font-size:17px!important;
  line-height:1.35!important;
  font-weight:720!important;
}
.sla-policy-guide-head-v2 p{
  margin:6px 0 0!important;
  color:#607086!important;
  font-size:12.5px!important;
  line-height:1.65!important;
}
.sla-policy-guide-list-v2{
  counter-reset:slaGuide!important;
  list-style:none!important;
  display:grid!important;
  gap:9px!important;
  margin:14px 0 0!important;
  padding:0!important;
}
.sla-policy-guide-list-v2 li{
  counter-increment:slaGuide!important;
  display:grid!important;
  grid-template-columns:32px minmax(0,1fr)!important;
  gap:10px!important;
  align-items:start!important;
  border:1px solid #e6eef5!important;
  border-radius:15px!important;
  background:#fff!important;
  padding:10px!important;
}
.sla-policy-guide-list-v2 li:before{
  content:counter(slaGuide)!important;
  display:grid!important;
  place-items:center!important;
  width:32px!important;
  height:32px!important;
  border-radius:999px!important;
  background:#f1f5f9!important;
  color:#405269!important;
  font-size:12px!important;
  font-weight:720!important;
  grid-row:1 / span 2!important;
}
.sla-policy-guide-list-v2 strong{
  color:#06243a!important;
  font-size:13px!important;
  line-height:1.3!important;
  font-weight:700!important;
}
.sla-policy-guide-list-v2 span{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.5!important;
}
.sla-policy-empty-state{
  border:1px dashed #bfd0e5!important;
  border-radius:20px!important;
  background:#f8fbfd!important;
  padding:22px!important;
  text-align:center!important;
}
.sla-policy-empty-state strong{
  display:block!important;
  color:#06243a!important;
  font-size:17px!important;
  font-weight:720!important;
}
.sla-policy-empty-state p{
  margin:6px auto 0!important;
  max-width:560px!important;
  color:#607086!important;
  font-size:13px!important;
  line-height:1.65!important;
}
@media(max-width:1180px){
  .sla-policy-summary-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .sla-policy-workspace,
  .sla-policy-hero-v2{
    grid-template-columns:1fr!important;
  }
  .sla-policy-hero-status{
    justify-self:start!important;
    max-width:none!important;
  }
  .sla-policy-side-v2{
    position:static!important;
    grid-template-columns:1fr 1fr!important;
  }
}
@media(max-width:900px){
  .sla-policy-form-grid-v2{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .sla-policy-timeline-v2{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .sla-policy-side-v2{
    grid-template-columns:1fr!important;
  }
}
@media(max-width:760px){
  .sla-policy-summary-grid,
  .sla-policy-form-grid-v2,
  .sla-policy-side-grid-v2,
  .sla-policy-timeline-v2{
    grid-template-columns:1fr!important;
  }
  .sla-policy-list-card-v2,
  .sla-policy-add-card-v2,
  .sla-policy-guide-card-v2{
    padding:14px!important;
    border-radius:18px!important;
  }
  .sla-policy-section-head{
    display:grid!important;
    gap:10px!important;
  }
  .sla-policy-count-pill{
    width:max-content!important;
  }
  .sla-policy-item-v2{
    padding:13px!important;
    border-radius:18px!important;
  }
  .sla-policy-card-head-v2,
  .sla-policy-card-actions-v2{
    grid-template-columns:1fr!important;
  }
  .sla-policy-identity-v2{
    display:grid!important;
    gap:9px!important;
  }
  .sla-policy-code-v2{
    justify-content:flex-start!important;
    min-width:0!important;
    width:max-content!important;
    max-width:100%!important;
  }
  .sla-policy-switch-v2{
    width:max-content!important;
    max-width:100%!important;
  }
  .sla-policy-card-actions-v2 .btn{
    width:100%!important;
  }
  .sla-policy-summary-card strong{
    font-size:24px!important;
  }
}

/* ========================================================================
   Phase 2.8.23 — SLA Pending Tasks Layout Refresh
   ======================================================================== */
.sla-pending-hero-v2{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(260px,340px)!important;
  gap:20px!important;
  align-items:center!important;
}
.sla-pending-hero-main{
  max-width:850px!important;
}
.sla-pending-hero-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:10px!important;
  align-items:center!important;
}
.sla-pending-hero-actions form{
  margin:0!important;
}
.sla-pending-scope-box{
  display:grid!important;
  gap:6px!important;
  border:1px solid rgba(255,255,255,.26)!important;
  background:rgba(255,255,255,.13)!important;
  border-radius:20px!important;
  padding:16px!important;
  color:#fff!important;
  min-width:0!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12)!important;
}
.sla-pending-scope-box span{
  color:rgba(255,255,255,.74)!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:720!important;
}
.sla-pending-scope-box strong{
  color:#fff!important;
  font-size:17px!important;
  line-height:1.35!important;
  font-weight:760!important;
}
.sla-pending-scope-box small{
  color:rgba(255,255,255,.78)!important;
  font-size:12.5px!important;
  line-height:1.55!important;
}
.sla-pending-summary-grid{
  display:grid!important;
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  gap:12px!important;
  margin:18px 0!important;
}
.sla-pending-summary-card{
  border:1px solid #dce7f1!important;
  border-radius:18px!important;
  background:#fff!important;
  padding:14px!important;
  display:grid!important;
  gap:5px!important;
  min-width:0!important;
  box-shadow:0 6px 18px rgba(6,36,58,.035)!important;
  border-left-width:4px!important;
}
.sla-pending-summary-card span{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:720!important;
}
.sla-pending-summary-card strong{
  color:#06243a!important;
  font-size:26px!important;
  line-height:1.05!important;
  font-weight:820!important;
  letter-spacing:-.025em!important;
}
.sla-pending-summary-card small{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.45!important;
}
.sla-pending-summary-card.summary-neutral{border-left-color:#7aa8bd!important;}
.sla-pending-summary-card.summary-success{border-left-color:#33a76f!important;}
.sla-pending-summary-card.summary-warning{border-left-color:#d99a28!important;}
.sla-pending-summary-card.summary-danger{border-left-color:#c94c4c!important;}
.sla-pending-filter-card,
.sla-pending-list-card{
  padding:0!important;
  overflow:hidden!important;
  border-radius:22px!important;
}
.sla-pending-section-head{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:14px!important;
  padding:18px 20px!important;
  border-bottom:1px solid #e6eef5!important;
  background:#fff!important;
}
.sla-pending-section-head h2{
  margin:0!important;
  color:#06243a!important;
  font-size:20px!important;
  line-height:1.3!important;
  font-weight:760!important;
}
.sla-pending-section-head p{
  margin:5px 0 0!important;
  color:#607086!important;
  font-size:13px!important;
  line-height:1.6!important;
  max-width:720px!important;
}
.sla-pending-result-pill{
  display:inline-grid!important;
  grid-template-columns:auto auto!important;
  gap:7px!important;
  align-items:baseline!important;
  border:1px solid #cde8f3!important;
  border-radius:999px!important;
  background:#eef9fd!important;
  color:#0e5d89!important;
  padding:8px 12px!important;
  white-space:nowrap!important;
}
.sla-pending-result-pill.soft{
  border-color:#dce7f1!important;
  background:#f8fbfd!important;
  color:#405269!important;
}
.sla-pending-result-pill strong{
  font-size:18px!important;
  line-height:1!important;
  font-weight:800!important;
}
.sla-pending-result-pill span{
  font-size:12px!important;
  line-height:1!important;
  font-weight:720!important;
}
.sla-pending-filter-form{
  display:grid!important;
  gap:0!important;
  background:#fff!important;
}
.sla-pending-quick-filter{
  display:grid!important;
  grid-template-columns:minmax(300px,1.35fr) minmax(180px,.65fr) minmax(190px,.7fr) auto!important;
  gap:14px!important;
  align-items:end!important;
  padding:18px 20px!important;
}
.sla-pending-filter-form .filter-field,
.sla-pending-filter-form label.filter-field{
  display:grid!important;
  gap:7px!important;
  min-width:0!important;
}
.sla-pending-filter-form .filter-field > span,
.sla-pending-filter-form label.filter-field > span{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:720!important;
}
.sla-pending-search-field input{
  min-height:42px!important;
}
.sla-pending-filter-actions{
  display:flex!important;
  justify-content:flex-end!important;
  align-items:center!important;
  gap:10px!important;
  min-width:max-content!important;
}
.sla-pending-advanced-filter{
  border-top:1px solid #e6eef5!important;
}
.sla-pending-advanced-filter summary{
  list-style:none!important;
  cursor:pointer!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:center!important;
  gap:12px!important;
  padding:13px 20px!important;
  background:#f8fbfd!important;
  color:#06243a!important;
  font-weight:760!important;
}
.sla-pending-advanced-filter summary::-webkit-details-marker{display:none!important;}
.sla-pending-advanced-filter summary:after{
  content:'เปิดตัวกรอง'!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:94px!important;
  border:1px solid #dce7f1!important;
  border-radius:999px!important;
  background:#fff!important;
  color:#405269!important;
  padding:6px 10px!important;
  font-size:12px!important;
  font-weight:720!important;
}
.sla-pending-advanced-filter[open] summary:after{content:'ย่อตัวกรอง'!important;}
.sla-pending-advanced-filter summary span{
  font-size:14px!important;
}
.sla-pending-advanced-filter summary small{
  margin-left:auto!important;
  color:#607086!important;
  font-size:12px!important;
  line-height:1.4!important;
  font-weight:620!important;
}
.sla-pending-advanced-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:14px!important;
  padding:18px 20px 20px!important;
  background:#fff!important;
}
.sla-pending-list{
  display:grid!important;
  gap:12px!important;
  padding:16px 20px 20px!important;
  background:#fbfdff!important;
}
.sla-pending-empty{
  margin:0!important;
  border:1px dashed #bfd0e5!important;
  background:#fff!important;
}
.sla-pending-item{
  display:grid!important;
  grid-template-columns:minmax(0,1.1fr) minmax(280px,.95fr) minmax(175px,.42fr)!important;
  gap:16px!important;
  align-items:stretch!important;
  border:1px solid #dce7f1!important;
  border-left-width:5px!important;
  border-radius:18px!important;
  background:#fff!important;
  padding:15px!important;
  box-shadow:0 7px 18px rgba(6,36,58,.035)!important;
}
.sla-pending-item.sla-status-normal{border-left-color:#33a76f!important;}
.sla-pending-item.sla-status-warning{border-left-color:#d99a28!important;background:linear-gradient(180deg,#fffdf8 0%,#fff 100%)!important;}
.sla-pending-item.sla-status-overdue{border-left-color:#c94c4c!important;background:linear-gradient(180deg,#fffafa 0%,#fff 100%)!important;}
.sla-pending-item.sla-status-escalated{border-left-color:#b42318!important;background:linear-gradient(180deg,#fff8f8 0%,#fff 100%)!important;}
.sla-pending-item-main{
  display:grid!important;
  gap:8px!important;
  min-width:0!important;
  align-content:start!important;
}
.sla-pending-item-top{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  align-items:center!important;
}
.sla-pending-item-top strong{
  color:#06243a!important;
  font-size:15px!important;
  line-height:1.3!important;
  font-weight:790!important;
}
.sla-pending-item-top small{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:650!important;
}
.sla-pending-item h3{
  margin:0!important;
  color:#0b1728!important;
  font-size:18px!important;
  line-height:1.35!important;
  font-weight:760!important;
}
.sla-pending-item p{
  margin:0!important;
  color:#607086!important;
  font-size:13px!important;
  line-height:1.55!important;
}
.sla-pending-tags{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:7px!important;
}
.sla-pending-tags span{
  display:inline-flex!important;
  max-width:100%!important;
  border:1px solid #e2eaf3!important;
  border-radius:999px!important;
  background:#f8fbfd!important;
  color:#405269!important;
  padding:4px 9px!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:620!important;
}
.sla-pending-item-detail{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:8px!important;
  min-width:0!important;
}
.sla-pending-item-detail > div{
  display:grid!important;
  gap:3px!important;
  border:1px solid #e6eef5!important;
  border-radius:14px!important;
  background:#fbfdff!important;
  padding:9px 11px!important;
  min-width:0!important;
}
.sla-pending-item-detail span,
.sla-pending-item-side span{
  color:#607086!important;
  font-size:11.5px!important;
  line-height:1.35!important;
  font-weight:760!important;
}
.sla-pending-item-detail strong{
  overflow-wrap:anywhere!important;
  color:#06243a!important;
  font-size:13px!important;
  line-height:1.4!important;
  font-weight:720!important;
}
.sla-pending-item-detail small{
  overflow-wrap:anywhere!important;
  color:#607086!important;
  font-size:12px!important;
  line-height:1.35!important;
}
.sla-pending-item-side{
  display:grid!important;
  gap:6px!important;
  align-content:center!important;
  justify-items:start!important;
  border-left:1px solid #e6eef5!important;
  padding-left:16px!important;
  min-width:0!important;
}
.sla-pending-item-side strong{
  color:#06243a!important;
  font-size:24px!important;
  line-height:1.1!important;
  font-weight:820!important;
  letter-spacing:-.025em!important;
}
.sla-pending-item-side small{
  color:#607086!important;
  font-size:12px!important;
  line-height:1.35!important;
}
.sla-pending-item-side .btn{
  margin-top:7px!important;
  white-space:nowrap!important;
}
@media(max-width:1180px){
  .sla-pending-hero-v2,
  .sla-pending-item{
    grid-template-columns:1fr!important;
  }
  .sla-pending-scope-box{
    max-width:none!important;
  }
  .sla-pending-summary-grid{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
  }
  .sla-pending-quick-filter{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .sla-pending-advanced-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
  .sla-pending-item-side{
    border-left:0!important;
    border-top:1px solid #e6eef5!important;
    padding-left:0!important;
    padding-top:12px!important;
  }
}
@media(max-width:760px){
  .sla-pending-hero-v2{
    gap:14px!important;
  }
  .sla-pending-hero-actions,
  .sla-pending-hero-actions .btn,
  .sla-pending-hero-actions form,
  .sla-pending-hero-actions button{
    width:100%!important;
  }
  .sla-pending-summary-grid,
  .sla-pending-quick-filter,
  .sla-pending-advanced-grid{
    grid-template-columns:1fr!important;
  }
  .sla-pending-summary-card{
    border-radius:16px!important;
    padding:13px!important;
  }
  .sla-pending-section-head{
    display:grid!important;
    padding:15px!important;
  }
  .sla-pending-result-pill{
    width:max-content!important;
  }
  .sla-pending-quick-filter,
  .sla-pending-advanced-grid,
  .sla-pending-list{
    padding:15px!important;
  }
  .sla-pending-filter-actions,
  .sla-pending-filter-actions .btn{
    width:100%!important;
  }
  .sla-pending-filter-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    min-width:0!important;
  }
  .sla-pending-advanced-filter summary{
    display:grid!important;
    justify-items:start!important;
  }
  .sla-pending-advanced-filter summary small{
    margin-left:0!important;
  }
  .sla-pending-item{
    padding:13px!important;
    border-radius:16px!important;
    gap:12px!important;
  }
  .sla-pending-item h3{
    font-size:16px!important;
  }
  .sla-pending-item-detail > div{
    padding:9px!important;
  }
  .sla-pending-item-side .btn{
    width:100%!important;
  }
}

/* ========================================================================
   Phase 2.8.24 — SLA Pending Tasks Minimal Visual Pass
   Keep the existing layout, reduce visual weight, and remove decorative layers.
   ======================================================================== */
.sla-pending-hero-v2{
  color:#102033!important;
  background:#fff!important;
  border:1px solid #dbe6ef!important;
  border-radius:20px!important;
  box-shadow:none!important;
  padding:20px!important;
}
.sla-pending-hero-v2::before,
.sla-pending-hero-v2::after{
  display:none!important;
}
.sla-pending-hero-v2 h1,
.sla-pending-hero-v2 h2,
.sla-pending-hero-v2 h3{
  color:#102033!important;
  font-weight:600!important;
  letter-spacing:-.015em!important;
}
.sla-pending-hero-v2 p{
  color:#5f6f80!important;
  font-weight:400!important;
  max-width:780px!important;
}
.sla-pending-hero-v2 .hero-kicker{
  border:0!important;
  background:transparent!important;
  color:#64748b!important;
  padding:0!important;
  font-weight:500!important;
  letter-spacing:0!important;
}
.sla-pending-hero-v2 .btn-light,
.sla-pending-hero-v2 .btn-secondary{
  color:#25364a!important;
  background:#fff!important;
  border-color:#d6e1eb!important;
  box-shadow:none!important;
}
.sla-pending-hero-v2 .btn-primary{
  box-shadow:none!important;
}
.sla-pending-scope-box{
  color:#25364a!important;
  background:#f8fafc!important;
  border:1px solid #dbe6ef!important;
  border-radius:14px!important;
  box-shadow:none!important;
  padding:14px!important;
}
.sla-pending-scope-box span,
.sla-pending-scope-box small{
  color:#64748b!important;
  font-weight:400!important;
}
.sla-pending-scope-box strong{
  color:#102033!important;
  font-size:15px!important;
  font-weight:600!important;
}
.sla-pending-summary-grid{
  gap:10px!important;
  margin:14px 0!important;
}
.sla-pending-summary-card{
  border-color:#dbe6ef!important;
  border-radius:14px!important;
  box-shadow:none!important;
  padding:12px 13px!important;
  border-left-width:3px!important;
}
.sla-pending-summary-card span,
.sla-pending-summary-card small{
  color:#64748b!important;
  font-weight:400!important;
}
.sla-pending-summary-card strong{
  color:#102033!important;
  font-size:23px!important;
  font-weight:650!important;
  letter-spacing:-.015em!important;
}
.sla-pending-filter-card,
.sla-pending-list-card{
  border-color:#dbe6ef!important;
  border-radius:16px!important;
  box-shadow:none!important;
}
.sla-pending-section-head{
  padding:16px 18px!important;
  border-bottom-color:#e5edf5!important;
  background:#fff!important;
}
.sla-pending-section-head h2{
  color:#102033!important;
  font-size:18px!important;
  font-weight:600!important;
}
.sla-pending-section-head p{
  color:#64748b!important;
  font-weight:400!important;
}
.sla-pending-result-pill{
  border-color:#dbe6ef!important;
  background:#fff!important;
  color:#334155!important;
  border-radius:12px!important;
  padding:7px 10px!important;
}
.sla-pending-result-pill strong{
  color:#102033!important;
  font-weight:650!important;
}
.sla-pending-result-pill span{
  color:#64748b!important;
  font-weight:500!important;
}
.sla-pending-quick-filter{
  padding:16px 18px!important;
}
.sla-pending-filter-form .filter-field > span,
.sla-pending-filter-form label.filter-field > span{
  color:#475569!important;
  font-weight:500!important;
}
.sla-pending-advanced-filter{
  border-top-color:#e5edf5!important;
}
.sla-pending-advanced-filter summary{
  background:#fff!important;
  color:#102033!important;
  padding:12px 18px!important;
  font-weight:500!important;
}
.sla-pending-advanced-filter summary:after{
  border-color:#dbe6ef!important;
  background:#f8fafc!important;
  color:#475569!important;
  font-weight:500!important;
  box-shadow:none!important;
}
.sla-pending-advanced-filter summary small{
  color:#64748b!important;
  font-weight:400!important;
}
.sla-pending-advanced-grid{
  padding:16px 18px 18px!important;
  background:#fff!important;
}
.sla-pending-list{
  gap:10px!important;
  padding:14px 18px 18px!important;
  background:#fff!important;
}
.sla-pending-item{
  border-color:#dbe6ef!important;
  border-left-width:3px!important;
  border-radius:14px!important;
  box-shadow:none!important;
  padding:14px!important;
}
.sla-pending-item.sla-status-warning,
.sla-pending-item.sla-status-overdue,
.sla-pending-item.sla-status-escalated{
  background:#fff!important;
}
.sla-pending-item-top strong{
  color:#102033!important;
  font-weight:600!important;
}
.sla-pending-item-top small,
.sla-pending-item p,
.sla-pending-item-detail small,
.sla-pending-item-side small{
  color:#64748b!important;
  font-weight:400!important;
}
.sla-pending-item h3{
  color:#102033!important;
  font-size:17px!important;
  font-weight:600!important;
}
.sla-pending-tags span{
  border-color:#e5edf5!important;
  background:#fff!important;
  color:#475569!important;
  border-radius:10px!important;
  font-weight:400!important;
}
.sla-pending-item-detail > div{
  border-color:#e5edf5!important;
  background:#fff!important;
  border-radius:12px!important;
  padding:8px 10px!important;
}
.sla-pending-item-detail span,
.sla-pending-item-side span{
  color:#64748b!important;
  font-weight:500!important;
  letter-spacing:0!important;
}
.sla-pending-item-detail strong{
  color:#102033!important;
  font-weight:500!important;
}
.sla-pending-item-side{
  border-left-color:#e5edf5!important;
}
.sla-pending-item-side strong{
  color:#102033!important;
  font-size:21px!important;
  font-weight:650!important;
  letter-spacing:-.015em!important;
}
.sla-pending-item-side .btn{
  box-shadow:none!important;
}
@media(max-width:760px){
  .sla-pending-hero-v2,
  .sla-pending-filter-card,
  .sla-pending-list-card,
  .sla-pending-item{
    border-radius:14px!important;
  }
  .sla-pending-section-head,
  .sla-pending-quick-filter,
  .sla-pending-advanced-grid,
  .sla-pending-list{
    padding:14px!important;
  }
}

/* ========================================================================
   Phase 2.8.25 — SLA Pending Tasks Item Layout Readability
   Refine only the pending-task cards: clearer hierarchy, fewer columns, better mobile reading.
   ======================================================================== */
.sla-pending-list-card .sla-pending-list{
  gap:12px!important;
}
.sla-pending-list-card .sla-pending-item{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:0!important;
  padding:0!important;
  overflow:hidden!important;
  border:1px solid #dbe6ef!important;
  border-left-width:3px!important;
  border-radius:14px!important;
  background:#fff!important;
  box-shadow:none!important;
}
.sla-pending-list-card .sla-pending-item.sla-status-warning,
.sla-pending-list-card .sla-pending-item.sla-status-overdue,
.sla-pending-list-card .sla-pending-item.sla-status-escalated{
  background:#fff!important;
}
.sla-pending-item-header{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:16px!important;
  padding:14px 16px!important;
  border-bottom:1px solid #edf2f7!important;
  background:#fff!important;
}
.sla-pending-item-title{
  display:grid!important;
  gap:7px!important;
  min-width:0!important;
}
.sla-pending-item-meta{
  display:flex!important;
  align-items:center!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  min-width:0!important;
}
.sla-pending-task-type{
  display:inline-flex!important;
  align-items:center!important;
  min-height:24px!important;
  border:1px solid #e5edf5!important;
  border-radius:999px!important;
  background:#fff!important;
  color:#475569!important;
  padding:3px 9px!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:500!important;
}
.sla-pending-doc-line{
  display:flex!important;
  align-items:center!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  min-width:0!important;
}
.sla-pending-doc-line strong{
  color:#102033!important;
  font-size:16px!important;
  line-height:1.35!important;
  font-weight:650!important;
  overflow-wrap:anywhere!important;
}
.sla-pending-doc-line span{
  color:#64748b!important;
  font-size:13px!important;
  line-height:1.45!important;
  font-weight:400!important;
}
.sla-pending-time-box{
  display:grid!important;
  gap:3px!important;
  min-width:160px!important;
  justify-items:end!important;
  text-align:right!important;
}
.sla-pending-time-box span,
.sla-pending-field-label,
.sla-pending-workflow-row span{
  color:#64748b!important;
  font-size:11.5px!important;
  line-height:1.35!important;
  font-weight:500!important;
}
.sla-pending-time-box strong{
  color:#102033!important;
  font-size:21px!important;
  line-height:1.1!important;
  font-weight:650!important;
  letter-spacing:-.015em!important;
}
.sla-pending-time-box small{
  color:#64748b!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:400!important;
}
.sla-pending-item-body{
  display:grid!important;
  grid-template-columns:minmax(0,1.45fr) minmax(300px,.95fr)!important;
  gap:16px!important;
  padding:16px!important;
  align-items:stretch!important;
}
.sla-pending-person-block,
.sla-pending-workflow-block{
  min-width:0!important;
}
.sla-pending-person-block{
  display:grid!important;
  gap:7px!important;
  align-content:start!important;
}
.sla-pending-person-block h3{
  margin:0!important;
  color:#102033!important;
  font-size:17px!important;
  line-height:1.4!important;
  font-weight:650!important;
  overflow-wrap:anywhere!important;
}
.sla-pending-person-block p{
  margin:0!important;
  color:#64748b!important;
  font-size:13px!important;
  line-height:1.55!important;
  font-weight:400!important;
  overflow-wrap:anywhere!important;
}
.sla-pending-list-card .sla-pending-tags{
  gap:6px!important;
  margin-top:2px!important;
}
.sla-pending-list-card .sla-pending-tags span{
  border-color:#e5edf5!important;
  background:#f8fafc!important;
  color:#475569!important;
  border-radius:8px!important;
  padding:4px 8px!important;
  font-size:12px!important;
  font-weight:400!important;
}
.sla-pending-workflow-block{
  display:grid!important;
  gap:10px!important;
  border:1px solid #e5edf5!important;
  border-radius:12px!important;
  background:#fbfdff!important;
  padding:12px!important;
}
.sla-pending-workflow-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:10px!important;
}
.sla-pending-workflow-row{
  display:grid!important;
  gap:4px!important;
  min-width:0!important;
}
.sla-pending-workflow-row.primary{
  padding-bottom:10px!important;
  border-bottom:1px solid #edf2f7!important;
}
.sla-pending-workflow-row strong{
  color:#102033!important;
  font-size:13px!important;
  line-height:1.45!important;
  font-weight:550!important;
  overflow-wrap:anywhere!important;
}
.sla-pending-workflow-row.primary strong{
  font-size:14px!important;
  font-weight:650!important;
}
.sla-pending-item-footer{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
  padding:12px 16px!important;
  border-top:1px solid #edf2f7!important;
  background:#fbfdff!important;
}
.sla-pending-item-footer span{
  color:#64748b!important;
  font-size:12.5px!important;
  line-height:1.45!important;
  font-weight:400!important;
}
.sla-pending-item-footer .btn{
  white-space:nowrap!important;
  box-shadow:none!important;
}
@media(max-width:1180px){
  .sla-pending-item-body{
    grid-template-columns:1fr!important;
  }
  .sla-pending-workflow-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}
@media(max-width:760px){
  .sla-pending-item-header{
    display:grid!important;
    gap:12px!important;
    padding:13px!important;
  }
  .sla-pending-time-box{
    min-width:0!important;
    justify-items:start!important;
    text-align:left!important;
    width:100%!important;
    border-top:1px solid #edf2f7!important;
    padding-top:10px!important;
  }
  .sla-pending-item-body{
    padding:13px!important;
    gap:13px!important;
  }
  .sla-pending-workflow-grid{
    grid-template-columns:1fr!important;
  }
  .sla-pending-item-footer{
    display:grid!important;
    padding:13px!important;
  }
  .sla-pending-item-footer .btn{
    width:100%!important;
  }
}

/* ========================================================================
   Phase 2.8.26 — SLA Pending Tasks Empty State Focus
   Refine only .empty-state-pro.sla-pending-empty for clearer empty-result guidance.
   ======================================================================== */
.sla-pending-list .empty-state-pro.sla-pending-empty{
  display:grid!important;
  grid-template-columns:auto minmax(0,1fr)!important;
  align-items:start!important;
  gap:14px!important;
  margin:0!important;
  padding:22px!important;
  border:1px solid #dbe6ef!important;
  border-left:3px solid #64748b!important;
  border-radius:14px!important;
  background:#fff!important;
  box-shadow:none!important;
  text-align:left!important;
  color:#475569!important;
}
.sla-pending-empty-mark{
  display:grid!important;
  place-items:center!important;
  width:38px!important;
  height:38px!important;
  border:1px solid #dbe6ef!important;
  border-radius:12px!important;
  background:#f8fafc!important;
  color:#0f766e!important;
  font-size:18px!important;
  line-height:1!important;
  font-weight:650!important;
}
.sla-pending-empty-content{
  display:grid!important;
  gap:8px!important;
  min-width:0!important;
}
.sla-pending-empty-kicker{
  color:#64748b!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:500!important;
}
.sla-pending-empty.sla-pending-empty h3{
  margin:0!important;
  color:#102033!important;
  font-size:17px!important;
  line-height:1.35!important;
  font-weight:650!important;
}
.sla-pending-empty.sla-pending-empty p{
  margin:0!important;
  max-width:680px!important;
  color:#64748b!important;
  font-size:13px!important;
  line-height:1.7!important;
  font-weight:400!important;
}
.sla-pending-empty-hints{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:6px!important;
  margin-top:2px!important;
}
.sla-pending-empty-hints span{
  display:inline-flex!important;
  align-items:center!important;
  min-height:24px!important;
  border:1px solid #e5edf5!important;
  border-radius:999px!important;
  background:#f8fafc!important;
  color:#475569!important;
  padding:3px 9px!important;
  font-size:12px!important;
  line-height:1.35!important;
  font-weight:400!important;
}
.sla-pending-empty-actions{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  margin-top:4px!important;
}
.sla-pending-empty-actions .btn{
  box-shadow:none!important;
}
@media(max-width:760px){
  .sla-pending-list .empty-state-pro.sla-pending-empty{
    grid-template-columns:1fr!important;
    gap:12px!important;
    padding:16px!important;
    border-radius:14px!important;
  }
  .sla-pending-empty-mark{
    width:34px!important;
    height:34px!important;
    border-radius:10px!important;
  }
  .sla-pending-empty-actions,
  .sla-pending-empty-actions .btn{
    width:100%!important;
  }
  .sla-pending-empty-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
}

/* Phase 2.8.57 — Web controlled system inspection mode */
.inspect-mode-hero {
    align-items: stretch;
}

.inspect-mode-status-card.is-enabled {
    border-color: rgba(245, 158, 11, 0.36);
}

.inspect-mode-status-card.is-enabled strong {
    color: #92400e;
}

.inspect-mode-status-card.is-disabled {
    border-color: rgba(22, 163, 74, 0.26);
}

.inspect-mode-status-card.is-disabled strong {
    color: #166534;
}

.inspect-mode-production-alert {
    margin: var(--space-4, 1rem) 0;
    display: flex;
    gap: var(--space-3, .75rem);
    align-items: flex-start;
    border-radius: var(--radius-md, 12px);
}

.inspect-mode-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(300px, .75fr);
    gap: var(--space-5, 1.25rem);
    align-items: start;
    margin-top: var(--space-5, 1.25rem);
}

.inspect-mode-control-card,
.inspect-mode-info-card {
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: var(--radius-lg, 16px);
    box-shadow: none;
}

.inspect-mode-form {
    display: grid;
    gap: var(--space-4, 1rem);
}

.inspect-mode-choice-group {
    border: 0;
    padding: 0;
    margin: 0;
    display: grid;
    gap: var(--space-3, .75rem);
}

.inspect-mode-choice {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: var(--space-3, .75rem);
    align-items: flex-start;
    padding: var(--space-4, 1rem);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: var(--radius-md, 12px);
    background: #fff;
    cursor: pointer;
}

.inspect-mode-choice:hover {
    border-color: rgba(14, 116, 144, 0.34);
    background: #f8fafc;
}

.inspect-mode-choice.is-selected {
    border-color: rgba(14, 116, 144, 0.46);
    background: #f0f9ff;
}

.inspect-mode-choice input {
    margin-top: .25rem;
}

.inspect-mode-choice strong,
.inspect-mode-choice small {
    display: block;
}

.inspect-mode-choice small {
    color: var(--text-muted, #64748b);
    margin-top: .2rem;
    line-height: 1.55;
}

.inspect-mode-reason-field {
    display: grid;
    gap: .45rem;
}

.inspect-mode-actions {
    display: flex;
    gap: var(--space-3, .75rem);
    flex-wrap: wrap;
    justify-content: flex-end;
}

.inspect-mode-info-list {
    display: grid;
    gap: 0;
    margin: 0;
}

.inspect-mode-info-list > div {
    display: grid;
    gap: .25rem;
    padding: .85rem 0;
    border-bottom: 1px solid var(--border-color, #e5e7eb);
}

.inspect-mode-info-list > div:first-child {
    padding-top: 0;
}

.inspect-mode-info-list > div:last-child {
    border-bottom: 0;
}

.inspect-mode-info-list dt {
    color: var(--text-muted, #64748b);
    font-size: .84rem;
    margin: 0;
}

.inspect-mode-info-list dd {
    margin: 0;
    color: var(--text-primary, #0f172a);
    font-weight: 700;
    line-height: 1.5;
}

.inspect-mode-note {
    margin-top: var(--space-4, 1rem);
    padding: var(--space-4, 1rem);
    border-radius: var(--radius-md, 12px);
    background: #f8fafc;
    border: 1px solid var(--border-color, #e5e7eb);
}

.inspect-mode-note strong {
    display: block;
    margin-bottom: .35rem;
}

.inspect-mode-note p {
    margin: 0;
    color: var(--text-muted, #64748b);
    line-height: 1.6;
}

@media (max-width: 991.98px) {
    .inspect-mode-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 575.98px) {
    .inspect-mode-actions,
    .inspect-mode-actions .btn,
    .inspect-mode-hero .page-hero-actions,
    .inspect-mode-hero .page-hero-actions .btn {
        width: 100%;
    }

    .inspect-mode-actions .btn,
    .inspect-mode-hero .page-hero-actions .btn {
        justify-content: center;
    }
}

/* Phase 2.9.8 — secure salted proof for login debug capture */
.debug-capture-note-secure{
  border-color:#dbeafe;
  background:#f8fbff;
}
.debug-capture-note-secure strong{
  color:#1e3a8a;
}
.debug-capture-warning,
.debug-capture-client-error{
  border:1px solid #fde68a;
  background:#fffbeb;
  color:#92400e;
  border-radius:12px;
  padding:10px 12px;
  font-size:12.5px;
  line-height:1.55;
}
.debug-capture-client-error{
  border-color:#fecaca;
  background:#fff5f5;
  color:#991b1b;
}
.debug-capture-client-error[hidden]{
  display:none!important;
}
.debug-capture-actions .button:disabled{
  opacity:.7;
  cursor:wait;
}

/* Phase 2.9.9 — login debug capture CSS integration */
.debug-impersonation-login-panel {
  --debug-accent: #4f46e5;
  --debug-accent-soft: #eef2ff;
  --debug-border: #d8deea;
  --debug-text: #1f2937;
  --debug-muted: #64748b;
  border: 1px solid var(--debug-border);
  border-left: 4px solid var(--debug-accent);
  background: #ffffff;
  border-radius: 16px;
  padding: 12px 14px;
  margin-top: 18px;
  box-shadow: none;
}

.debug-impersonation-login-panel[open] {
  border-color: #c7d2fe;
  background: #ffffff;
}

.debug-capture-summary {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 34px;
  outline: none;
}

.debug-capture-summary:focus-visible {
  border-radius: 12px;
  box-shadow: 0 0 0 3px rgba(79, 70, 229, .16);
}

.debug-capture-badge {
  min-width: 0;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid #c7d2fe;
  background: var(--debug-accent-soft);
  color: #3730a3;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .02em;
}

.debug-capture-title-wrap strong {
  color: var(--debug-text);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
}

.debug-capture-title-wrap small {
  color: var(--debug-muted);
  font-size: 12px;
  line-height: 1.45;
}

.debug-capture-login-form {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #edf1f6;
}

.debug-capture-note,
.debug-capture-note-secure,
.debug-capture-warning,
.debug-capture-client-error {
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 12.5px;
  line-height: 1.55;
}

.debug-capture-note-secure {
  border: 1px solid #bfdbfe;
  background: #f8fbff;
}

.debug-capture-note-secure strong {
  color: #1e3a8a;
}

.debug-capture-note-secure span {
  color: #475569;
}

.debug-capture-warning {
  border-color: #fde68a;
  background: #fffbeb;
  color: #92400e;
}

.debug-capture-client-error {
  border-color: #fecaca;
  background: #fff5f5;
  color: #991b1b;
}

.debug-capture-client-error[hidden] {
  display: none !important;
}

.debug-capture-grid {
  grid-template-columns: minmax(220px, 1.1fr) minmax(180px, 1fr) minmax(120px, .7fr);
  gap: 10px;
}

.debug-capture-grid .field {
  margin: 0;
}

.debug-capture-grid .input {
  width: 100%;
}

.debug-capture-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-top: 2px;
}

.debug-capture-actions .button {
  min-height: 40px;
  padding-inline: 14px;
  border-radius: 10px;
}

.debug-capture-actions .button:disabled {
  opacity: .72;
  cursor: wait;
}

.debug-capture-help {
  color: var(--debug-muted);
  font-size: 12px;
  line-height: 1.45;
}

@media (max-width: 760px) {
  .debug-impersonation-login-panel {
    padding: 12px;
    border-radius: 14px;
  }

  .debug-capture-summary {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .debug-capture-badge {
    width: fit-content;
  }

  .debug-capture-grid {
    grid-template-columns: 1fr;
  }

  .debug-capture-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .debug-capture-actions .button {
    width: 100%;
    justify-content: center;
  }
}

/* Leave create/edit compact header -------------------------------------------------
   Keep the standard page-hero/form-hero structure while reducing visual weight for
   the leave request form, especially on mobile where the form itself needs priority.
---------------------------------------------------------------------------- */
.leave-form-compact-hero{
  grid-template-columns:minmax(0,1fr) auto!important;
  align-items:center!important;
  gap:14px!important;
  padding:18px 20px!important;
  margin-bottom:14px!important;
  border-radius:20px!important;
  background:#fff!important;
  color:#0f172a!important;
  border:1px solid #dbe4ef!important;
  box-shadow:0 8px 20px rgba(15,23,42,.045)!important;
}
.leave-form-compact-hero::before,
.leave-form-compact-hero::after{
  display:none!important;
}
.leave-form-compact-hero .hero-kicker{
  min-height:24px!important;
  padding:4px 9px!important;
  border-color:#cbdde8!important;
  background:#f8fafc!important;
  color:#0f5f86!important;
  box-shadow:none!important;
  font-size:11.5px!important;
  font-weight:600!important;
}
.leave-form-compact-hero h1,
.leave-form-compact-hero h2,
.leave-form-compact-hero h3{
  margin:7px 0 0!important;
  color:#0f172a!important;
  font-size:clamp(21px,1.55vw,26px)!important;
  line-height:1.26!important;
  font-weight:600!important;
  letter-spacing:-.02em!important;
  text-shadow:none!important;
}
.leave-form-compact-hero p{
  max-width:720px!important;
  margin:5px 0 0!important;
  color:#526273!important;
  font-size:13.5px!important;
  line-height:1.55!important;
  font-weight:400!important;
}
.leave-form-compact-hero .page-hero-actions,
.leave-form-compact-hero .leave-form-hero-actions{
  justify-self:end!important;
  align-self:center!important;
  display:flex!important;
  align-items:center!important;
  gap:8px!important;
  width:auto!important;
  margin-top:0!important;
}
.leave-form-compact-hero .btn{
  min-height:38px!important;
  padding:.52rem .88rem!important;
  border-radius:12px!important;
  box-shadow:none!important;
  font-weight:600!important;
}
.leave-form-compact-hero .btn-ghost{
  background:#f8fafc!important;
  color:#0f5f86!important;
  border-color:#cbdde8!important;
}
.leave-form-compact-hero .btn-ghost:hover{
  background:#eef6fa!important;
  border-color:#9cc9dc!important;
}

@media(max-width:760px){
  .leave-form-compact-hero{
    grid-template-columns:1fr!important;
    gap:10px!important;
    padding:14px!important;
    margin-bottom:12px!important;
    border-radius:16px!important;
  }
  .leave-form-compact-hero .hero-kicker{
    min-height:22px!important;
    padding:3px 8px!important;
    font-size:11px!important;
  }
  .leave-form-compact-hero h1,
  .leave-form-compact-hero h2,
  .leave-form-compact-hero h3{
    margin-top:6px!important;
    font-size:20px!important;
    line-height:1.25!important;
  }
  .leave-form-compact-hero p{
    margin-top:4px!important;
    font-size:12.75px!important;
    line-height:1.48!important;
  }
  .leave-form-compact-hero .page-hero-actions,
  .leave-form-compact-hero .leave-form-hero-actions{
    justify-self:stretch!important;
    width:100%!important;
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .leave-form-compact-hero .page-hero-actions .btn,
  .leave-form-compact-hero .leave-form-hero-actions .btn{
    width:100%!important;
    min-height:38px!important;
  }
}

/* Phase 2.9.76 — Approval route create form redesign
   Scope: /settings/approval-routes only. Keeps existing save-route workflow. */
.approval-route-create-jump{
  white-space:nowrap;
}
.approval-route-create-panel{
  border:1px solid rgba(203,213,225,.95);
  border-radius:20px;
  background:#fff;
  box-shadow:0 10px 28px rgba(15,23,42,.06);
  overflow:hidden;
  scroll-margin-top:18px;
}
.approval-route-create-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:16px 18px;
  cursor:pointer;
  list-style:none;
  background:linear-gradient(180deg,#fff 0%,#f8fafc 100%);
}
.approval-route-create-summary::-webkit-details-marker{
  display:none;
}
.approval-route-create-summary-copy{
  display:grid;
  gap:3px;
  min-width:0;
}
.approval-route-create-summary-copy strong{
  color:#0f172a;
  font-size:18px;
  font-weight:850;
  line-height:1.2;
}
.approval-route-create-summary-copy small{
  color:#64748b;
  font-size:13px;
  line-height:1.5;
}
.approval-route-create-state{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 auto;
  min-width:92px;
  min-height:36px;
  padding:7px 12px;
  border:1px solid rgba(13,127,168,.20);
  border-radius:999px;
  background:#eff6ff;
  color:#0b5f86;
  font-size:12px;
  font-weight:850;
}
.approval-route-create-panel[open] .approval-route-create-state{
  border-color:rgba(15,118,110,.18);
  background:#ecfdf5;
  color:#047857;
}
.approval-route-create-panel[open] .approval-route-create-state::before{
  content:'กำลังกรอก';
}
.approval-route-create-panel[open] .approval-route-create-state{
  font-size:0;
}
.approval-route-create-panel[open] .approval-route-create-state::before{
  font-size:12px;
}
.approval-route-create-form{
  border-top:1px solid rgba(226,232,240,.95);
  padding:18px;
}
.approval-route-create-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.approval-route-create-section{
  display:grid;
  gap:14px;
  min-width:0;
  padding:16px;
  border:1px solid rgba(226,232,240,.95);
  border-radius:18px;
  background:#fff;
}
.approval-route-create-section-head{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:12px;
  align-items:start;
}
.approval-route-create-section-head > span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  border-radius:999px;
  background:#f1f5f9;
  color:#0f172a;
  font-size:13px;
  font-weight:900;
}
.approval-route-create-section-head h3{
  margin:0 0 4px;
  color:#0f172a;
  font-size:15px;
  font-weight:850;
  line-height:1.3;
}
.approval-route-create-section-head p{
  margin:0;
  color:#64748b;
  font-size:13px;
  line-height:1.5;
}
.approval-route-create-fields{
  display:grid;
  gap:12px;
}
.approval-route-create-fields .field{
  margin:0;
}
.approval-route-create-fields .input,
.approval-route-create-fields .select{
  width:100%;
}
.approval-route-create-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:16px;
  padding-top:16px;
  border-top:1px solid rgba(226,232,240,.95);
}
.approval-route-create-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
}
.approval-route-create-actions .btn{
  min-height:40px;
}
@media (max-width:900px){
  .approval-route-create-summary,
  .approval-route-create-footer{
    align-items:stretch;
    flex-direction:column;
  }
  .approval-route-create-state{
    width:100%;
  }
  .approval-route-create-grid{
    grid-template-columns:1fr;
  }
  .approval-route-create-actions{
    justify-content:stretch;
  }
  .approval-route-create-actions .btn,
  .approval-route-create-actions button{
    width:100%;
    justify-content:center;
  }
}
@media (max-width:720px){
  .approval-route-create-summary,
  .approval-route-create-form{
    padding:14px;
  }
  .approval-route-create-section{
    padding:14px;
    border-radius:16px;
  }
  .approval-route-create-summary-copy strong{
    font-size:16px;
  }
}

/* Phase: user employee provision card refresh */
.user-employee-provision-card.admin-pro-card{
  padding:20px!important;
  display:grid!important;
  gap:18px!important;
  border-radius:18px!important;
  background:#fff!important;
  border:1px solid #d9e4ee!important;
  box-shadow:0 1px 2px rgba(15,23,42,.04)!important;
}
.user-employee-provision-head{
  display:flex!important;
  justify-content:space-between!important;
  align-items:flex-start!important;
  gap:16px!important;
  padding-bottom:14px!important;
  border-bottom:1px solid #e6edf5!important;
}
.user-employee-provision-title h2{
  margin:6px 0 0!important;
  color:#0f2537!important;
  font-size:clamp(18px,1.35vw,22px)!important;
  line-height:1.35!important;
  font-weight:650!important;
  letter-spacing:-.01em!important;
}
.user-employee-provision-title p{
  max-width:760px!important;
  margin:6px 0 0!important;
  color:#64748b!important;
  font-size:13.5px!important;
  line-height:1.7!important;
}
.user-employee-provision-badge{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:30px!important;
  padding:5px 10px!important;
  border:1px solid #cfe0ec!important;
  border-radius:999px!important;
  background:#f7fafc!important;
  color:#0f5f88!important;
  font-size:12px!important;
  font-weight:700!important;
  white-space:nowrap!important;
}
.user-employee-provision-layout{
  display:grid!important;
  grid-template-columns:minmax(250px,.36fr) minmax(0,1fr)!important;
  gap:18px!important;
  align-items:start!important;
}
.user-employee-provision-guide{
  display:grid!important;
  grid-template-columns:44px minmax(0,1fr)!important;
  gap:12px!important;
  padding:16px!important;
  border:1px solid #e2ebf3!important;
  border-radius:16px!important;
  background:#f8fafc!important;
}
.user-employee-provision-guide-icon{
  width:44px!important;
  height:44px!important;
  border-radius:12px!important;
  display:grid!important;
  place-items:center!important;
  background:#eaf4f8!important;
  color:#0b5e86!important;
  font-size:11px!important;
  font-weight:800!important;
  letter-spacing:.04em!important;
}
.user-employee-provision-guide strong,
.user-employee-provision-note strong{
  display:block!important;
  color:#0f2537!important;
  font-size:14px!important;
  line-height:1.45!important;
  font-weight:650!important;
}
.user-employee-provision-guide p,
.user-employee-provision-note p{
  margin:4px 0 0!important;
  color:#64748b!important;
  font-size:13px!important;
  line-height:1.65!important;
}
.user-employee-provision-steps{
  grid-column:1/-1!important;
  display:grid!important;
  gap:8px!important;
  margin:6px 0 0!important;
  padding:0!important;
  list-style:none!important;
}
.user-employee-provision-steps li{
  display:grid!important;
  grid-template-columns:26px minmax(0,1fr)!important;
  gap:9px!important;
  align-items:start!important;
  margin:0!important;
  padding:10px!important;
  border:1px solid #e6eef5!important;
  border-radius:12px!important;
  background:#fff!important;
}
.user-employee-provision-steps li span{
  width:26px!important;
  height:26px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:999px!important;
  background:#f1f6fa!important;
  color:#31556c!important;
  font-size:12px!important;
  font-weight:800!important;
}
.user-employee-provision-steps li p{
  margin:2px 0 0!important;
  color:#334155!important;
  font-size:13px!important;
  line-height:1.55!important;
}
.user-employee-provision-note{
  grid-column:1/-1!important;
  margin-top:4px!important;
  padding:12px!important;
  border-radius:12px!important;
  border:1px solid #dce8f1!important;
  background:#f4f8fb!important;
}
.user-employee-provision-form{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:14px!important;
  align-items:stretch!important;
  min-width:0!important;
}
.user-employee-provision-form .ldap-lookup-panel.user-employee-provision-search{
  grid-column:1/-1!important;
  padding:14px!important;
  border:1px solid #dce8f1!important;
  border-radius:16px!important;
  background:#fff!important;
}
.user-employee-provision-form .ldap-lookup-search-field{
  grid-column:auto!important;
  margin:0!important;
}
.user-employee-provision-fields{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
}
.user-employee-provision-fields .field,
.user-employee-provision-footer .field{
  margin:0!important;
  min-width:0!important;
}
.user-employee-provision-form .input{
  min-height:44px!important;
  border-radius:12px!important;
}
.user-employee-provision-footer{
  display:grid!important;
  grid-template-columns:minmax(240px,.45fr) minmax(0,1fr)!important;
  gap:14px!important;
  align-items:stretch!important;
  padding-top:2px!important;
}
.user-employee-provision-form .provision-toggle-field{
  display:grid!important;
  gap:7px!important;
  padding:12px!important;
  border:1px solid #dce8f1!important;
  border-radius:14px!important;
  background:#f8fafc!important;
}
.user-employee-provision-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:12px!important;
  padding:12px!important;
  border:1px solid #e6eef5!important;
  border-radius:14px!important;
  background:#fff!important;
}
.user-employee-provision-actions .button{
  min-height:44px!important;
  border-radius:12px!important;
  white-space:nowrap!important;
}
.user-employee-provision-actions span{
  color:#64748b!important;
  font-size:12.5px!important;
  line-height:1.55!important;
}
@media(max-width:1120px){
  .user-employee-provision-layout{
    grid-template-columns:1fr!important;
  }
  .user-employee-provision-guide{
    grid-template-columns:44px minmax(0,1fr)!important;
  }
  .user-employee-provision-steps{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
  }
}
@media(max-width:760px){
  .user-employee-provision-card.admin-pro-card{
    padding:15px!important;
    gap:14px!important;
    border-radius:16px!important;
  }
  .user-employee-provision-head{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:10px!important;
  }
  .user-employee-provision-badge{
    width:max-content!important;
  }
  .user-employee-provision-guide,
  .user-employee-provision-fields,
  .user-employee-provision-footer,
  .user-employee-provision-actions,
  .user-employee-provision-steps{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .user-employee-provision-guide-icon{
    width:40px!important;
    height:40px!important;
  }
  .user-employee-provision-form .ldap-lookup-panel.user-employee-provision-search{
    padding:12px!important;
  }
  .user-employee-provision-actions .button{
    width:100%!important;
  }
}

/* Phase: user employee provision card breathing-room repair
   Scope: /settings/user-employees, block .admin-pro-card.user-employee-provision-card only */
.user-employee-provision-card.admin-pro-card{
  grid-column:1 / -1!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:18px!important;
  padding:20px!important;
  border:1px solid #dbe6ef!important;
  border-radius:18px!important;
  background:#fff!important;
  box-shadow:none!important;
}
.user-employee-provision-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:18px!important;
  padding:0 0 14px!important;
  border-bottom:1px solid #e8eef4!important;
}
.user-employee-provision-title{
  min-width:0!important;
}
.user-employee-provision-title h2{
  margin:5px 0 0!important;
  color:#102638!important;
  font-size:clamp(18px,1.25vw,21px)!important;
  line-height:1.35!important;
  font-weight:650!important;
}
.user-employee-provision-title p{
  max-width:820px!important;
  margin:6px 0 0!important;
  color:#64748b!important;
  font-size:13.5px!important;
  line-height:1.65!important;
}
.user-employee-provision-badge{
  flex:0 0 auto!important;
  min-height:28px!important;
  padding:4px 10px!important;
  border:1px solid #d5e3ed!important;
  border-radius:999px!important;
  background:#f8fafc!important;
  color:#31556c!important;
  font-size:11.5px!important;
  font-weight:700!important;
  letter-spacing:.01em!important;
}
.user-employee-provision-form{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:14px!important;
  min-width:0!important;
}
.user-employee-provision-form .ldap-lookup-panel.user-employee-provision-search{
  padding:0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
}
.user-employee-provision-form .ldap-lookup-search-field{
  margin:0!important;
}
.user-employee-provision-form .ldap-lookup-search-field .input{
  min-height:46px!important;
}
.user-employee-provision-form .ldap-lookup-results{
  margin-top:8px!important;
}
.user-employee-provision-fields{
  display:grid!important;
  grid-template-columns:minmax(240px,.42fr) minmax(0,1fr)!important;
  gap:14px!important;
}
.user-employee-provision-fields .field,
.user-employee-provision-submit-row .field{
  margin:0!important;
  min-width:0!important;
}
.user-employee-provision-form .input{
  min-height:44px!important;
  border-radius:10px!important;
}
.user-employee-provision-submit-row{
  display:grid!important;
  grid-template-columns:minmax(260px,.38fr) minmax(0,1fr)!important;
  gap:14px!important;
  align-items:stretch!important;
  padding-top:2px!important;
}
.user-employee-provision-form .provision-toggle-field{
  display:grid!important;
  gap:6px!important;
  padding:12px!important;
  border:1px solid #e3ebf3!important;
  border-radius:12px!important;
  background:#f8fafc!important;
}
.user-employee-provision-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-start!important;
  gap:14px!important;
  padding:12px 0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
}
.user-employee-provision-actions .button{
  flex:0 0 auto!important;
  min-height:44px!important;
  border-radius:10px!important;
  white-space:nowrap!important;
}
.user-employee-provision-actions span{
  max-width:520px!important;
  color:#64748b!important;
  font-size:12.5px!important;
  line-height:1.6!important;
}
.user-employee-provision-guide{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr)) minmax(260px,.95fr)!important;
  gap:10px!important;
  padding:12px!important;
  border:1px solid #e6edf4!important;
  border-radius:14px!important;
  background:#f8fafc!important;
}
.user-employee-provision-step{
  display:grid!important;
  grid-template-columns:26px minmax(0,1fr)!important;
  align-items:center!important;
  gap:9px!important;
  min-width:0!important;
  padding:10px!important;
  border:1px solid #e7eef5!important;
  border-radius:12px!important;
  background:#fff!important;
}
.user-employee-provision-step span{
  width:26px!important;
  height:26px!important;
  display:grid!important;
  place-items:center!important;
  border-radius:999px!important;
  background:#eef5f9!important;
  color:#31556c!important;
  font-size:12px!important;
  line-height:1!important;
  font-weight:800!important;
}
.user-employee-provision-step p{
  margin:0!important;
  color:#334155!important;
  font-size:12.75px!important;
  line-height:1.45!important;
  font-weight:520!important;
}
.user-employee-provision-note{
  display:grid!important;
  align-content:center!important;
  gap:3px!important;
  margin:0!important;
  padding:10px 12px!important;
  border:0!important;
  border-left:3px solid #d5e3ed!important;
  border-radius:0!important;
  background:transparent!important;
}
.user-employee-provision-note strong{
  margin:0!important;
  color:#334155!important;
  font-size:12.5px!important;
  line-height:1.35!important;
  font-weight:700!important;
}
.user-employee-provision-note p{
  margin:0!important;
  color:#64748b!important;
  font-size:12.25px!important;
  line-height:1.55!important;
}
@media(max-width:1040px){
  .user-employee-provision-fields,
  .user-employee-provision-submit-row{
    grid-template-columns:1fr!important;
  }
  .user-employee-provision-actions{
    padding:0!important;
  }
  .user-employee-provision-guide{
    grid-template-columns:1fr!important;
  }
}
@media(max-width:760px){
  .user-employee-provision-card.admin-pro-card{
    padding:14px!important;
    gap:14px!important;
    border-radius:16px!important;
  }
  .user-employee-provision-head{
    display:grid!important;
    gap:8px!important;
    padding-bottom:12px!important;
  }
  .user-employee-provision-title p{
    font-size:13px!important;
    line-height:1.55!important;
  }
  .user-employee-provision-badge{
    width:max-content!important;
  }
  .user-employee-provision-actions{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
  }
  .user-employee-provision-actions .button{
    width:100%!important;
  }
  .user-employee-provision-guide{
    padding:10px!important;
    gap:8px!important;
  }
  .user-employee-provision-step{
    padding:9px!important;
  }
  .user-employee-provision-note{
    padding:8px 10px!important;
  }
}

/* Phase: user employee data authority card breathing-room refresh
   Scope: /settings/user-employees, block .admin-pro-card.data-authority-card only */
.data-authority-card.admin-pro-card{
  grid-column:1 / -1!important;
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:16px!important;
  padding:20px!important;
  border:1px solid #dbe6ef!important;
  border-radius:18px!important;
  background:#fff!important;
  box-shadow:none!important;
}
.data-authority-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:18px!important;
  padding-bottom:14px!important;
  border-bottom:1px solid #e8eef4!important;
}
.data-authority-title{
  min-width:0!important;
}
.data-authority-title h2{
  margin:5px 0 0!important;
  color:#102638!important;
  font-size:clamp(18px,1.25vw,21px)!important;
  line-height:1.35!important;
  font-weight:650!important;
  letter-spacing:-.01em!important;
}
.data-authority-title p{
  max-width:860px!important;
  margin:6px 0 0!important;
  color:#64748b!important;
  font-size:13.5px!important;
  line-height:1.65!important;
}
.data-authority-badge{
  flex:0 0 auto!important;
  min-height:28px!important;
  padding:4px 10px!important;
  border:1px solid #d5e3ed!important;
  border-radius:999px!important;
  background:#f8fafc!important;
  color:#31556c!important;
  font-size:11.5px!important;
  font-weight:700!important;
  letter-spacing:.01em!important;
  white-space:nowrap!important;
}
.data-authority-flow{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto minmax(0,1fr)!important;
  gap:12px!important;
  align-items:stretch!important;
}
.data-authority-item{
  min-width:0!important;
  padding:14px!important;
  border:1px solid #e4edf5!important;
  border-radius:14px!important;
  background:#fbfdff!important;
}
.data-authority-item-label{
  display:inline-flex!important;
  width:max-content!important;
  min-height:24px!important;
  align-items:center!important;
  padding:3px 8px!important;
  border:1px solid #e2ebf3!important;
  border-radius:999px!important;
  background:#f8fafc!important;
  color:#475569!important;
  font-size:11.5px!important;
  line-height:1!important;
  font-weight:700!important;
}
.data-authority-item strong{
  display:block!important;
  margin:10px 0 0!important;
  color:#102638!important;
  font-size:14.5px!important;
  line-height:1.45!important;
  font-weight:650!important;
}
.data-authority-item p{
  margin:5px 0 0!important;
  color:#64748b!important;
  font-size:13px!important;
  line-height:1.6!important;
}
.data-authority-link{
  align-self:center!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:58px!important;
  min-height:30px!important;
  padding:4px 10px!important;
  border:1px solid #dce8f1!important;
  border-radius:999px!important;
  background:#f8fafc!important;
  color:#64748b!important;
  font-size:12px!important;
  font-weight:700!important;
  white-space:nowrap!important;
}
.data-authority-action{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:16px!important;
  margin:0!important;
  padding:14px!important;
  border:1px solid #e4edf5!important;
  border-radius:14px!important;
  background:#f8fafc!important;
}
.data-authority-action strong{
  display:block!important;
  color:#102638!important;
  font-size:14px!important;
  line-height:1.45!important;
  font-weight:650!important;
}
.data-authority-action p{
  margin:3px 0 0!important;
  color:#64748b!important;
  font-size:12.75px!important;
  line-height:1.55!important;
}
.data-authority-action .button{
  flex:0 0 auto!important;
  width:auto!important;
  min-height:42px!important;
  border-radius:10px!important;
  white-space:nowrap!important;
}
@media(max-width:920px){
  .data-authority-flow{
    grid-template-columns:1fr!important;
  }
  .data-authority-link{
    justify-self:start!important;
    min-width:0!important;
  }
  .data-authority-action{
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .data-authority-action .button{
    width:max-content!important;
  }
}
@media(max-width:760px){
  .data-authority-card.admin-pro-card{
    padding:14px!important;
    gap:14px!important;
    border-radius:16px!important;
  }
  .data-authority-head{
    display:grid!important;
    grid-template-columns:1fr!important;
    gap:8px!important;
    padding-bottom:12px!important;
  }
  .data-authority-badge{
    width:max-content!important;
  }
  .data-authority-title p{
    font-size:13px!important;
    line-height:1.55!important;
  }
  .data-authority-item,
  .data-authority-action{
    padding:12px!important;
    border-radius:12px!important;
  }
  .data-authority-action .button{
    width:100%!important;
  }
}

/* Leave form employee profile source */
.leave-employee-picker-field {
    gap: var(--space-2, .5rem);
}
.leave-employee-source-card {
    margin-top: .65rem;
    padding: .8rem .9rem;
    border: 1px solid var(--border, #d9e2ec);
    border-radius: var(--radius-md, 10px);
    background: var(--surface-muted, #f7fafc);
    color: var(--text-muted, #64748b);
    display: grid;
    gap: .25rem;
    line-height: 1.55;
}
.leave-employee-source-card strong {
    color: var(--text, #1f2937);
    font-size: .92rem;
    font-weight: 700;
}
.leave-employee-source-card span {
    font-size: .86rem;
}
.leave-employee-source-card.is-ready {
    background: #fff;
    border-color: rgba(15, 92, 138, .22);
}
@media (max-width: 640px) {
    .leave-employee-source-card {
        padding: .75rem;
        border-radius: 9px;
    }
}

/* Phase 2.9.10 — stabilize login Debug Capture Mode expand panel
   The login card is intentionally narrow, so the debug form must not use
   multi-column desktop grids that overflow the card when the details panel opens. */
.auth-login-card .debug-impersonation-login-panel{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  overflow:hidden;
  padding:0;
  margin-top:16px;
  border:1px solid #d9e1ec;
  border-left:3px solid #4f46e5;
  border-radius:14px;
  background:#fff;
  box-shadow:none;
}
.auth-login-card .debug-impersonation-login-panel[open]{
  border-color:#cbd5e1;
  background:#fff;
}
.auth-login-card .debug-impersonation-login-panel summary{
  list-style:none;
  cursor:pointer;
  user-select:none;
}
.auth-login-card .debug-impersonation-login-panel summary::-webkit-details-marker{display:none}
.auth-login-card .debug-capture-summary{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
  width:100%;
  min-height:0;
  padding:12px;
  box-sizing:border-box;
  outline:none;
}
.auth-login-card .debug-capture-summary::after{
  content:'ขยาย';
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:48px;
  min-height:28px;
  padding:0 9px;
  border:1px solid #d7dce5;
  border-radius:999px;
  color:#475569;
  background:#f8fafc;
  font-size:11.5px;
  font-weight:750;
  line-height:1;
}
.auth-login-card .debug-impersonation-login-panel[open] .debug-capture-summary::after{content:'ย่อ'}
.auth-login-card .debug-capture-summary:focus-visible{
  box-shadow:inset 0 0 0 3px rgba(79,70,229,.16);
  border-radius:12px;
}
.auth-login-card .debug-capture-badge{
  height:26px;
  min-width:0;
  padding:0 9px;
  border:1px solid #c7d2fe;
  border-radius:999px;
  background:#eef2ff;
  color:#3730a3;
  font-size:11px;
  font-weight:800;
  white-space:nowrap;
}
.auth-login-card .debug-capture-title-wrap{
  min-width:0;
  display:grid;
  gap:2px;
}
.auth-login-card .debug-capture-title-wrap strong{
  color:#1f2937;
  font-size:13.5px;
  font-weight:800;
  line-height:1.35;
}
.auth-login-card .debug-capture-title-wrap small{
  color:#64748b;
  font-size:11.75px;
  line-height:1.45;
}
.auth-login-card .debug-capture-login-form{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  width:100%;
  box-sizing:border-box;
  margin:0;
  padding:12px;
  border-top:1px solid #edf1f6;
  background:#fff;
}
.auth-login-card .debug-capture-note,
.auth-login-card .debug-capture-note-secure,
.auth-login-card .debug-capture-warning,
.auth-login-card .debug-capture-client-error{
  width:100%;
  box-sizing:border-box;
  border-radius:11px;
  padding:9px 10px;
  font-size:12px;
  line-height:1.5;
}
.auth-login-card .debug-capture-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  width:100%;
}
.auth-login-card .debug-capture-grid .field{
  width:100%;
  min-width:0;
  margin:0;
}
.auth-login-card .debug-capture-grid .input{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}
.auth-login-card .debug-capture-actions{
  display:grid;
  grid-template-columns:1fr;
  align-items:stretch;
  gap:8px;
  width:100%;
  padding-top:0;
}
.auth-login-card .debug-capture-actions .button{
  width:100%;
  justify-content:center;
  min-height:40px;
  border-radius:10px;
}
.auth-login-card .debug-capture-help{
  color:#64748b;
  font-size:11.75px;
  line-height:1.45;
  text-align:left;
}
@media (max-width:480px){
  .auth-login-card .debug-capture-summary{
    grid-template-columns:1fr auto;
    gap:8px;
  }
  .auth-login-card .debug-capture-badge{
    grid-column:1 / 2;
    width:max-content;
  }
  .auth-login-card .debug-capture-title-wrap{
    grid-column:1 / 3;
    grid-row:2;
  }
  .auth-login-card .debug-capture-summary::after{
    grid-column:2;
    grid-row:1;
  }
}


/* Google Calendar sync visibility diagnostics */
.gcal-visibility-note {
    display: grid;
    gap: .35rem;
    margin: 0 0 1rem;
    padding: .85rem 1rem;
    border: 1px solid var(--border-color, #d9e2ec);
    border-left: 4px solid var(--primary-color, #0f5e8c);
    border-radius: 12px;
    background: #f8fafc;
    color: var(--text-color, #1f2937);
}
.gcal-visibility-note strong {
    font-size: .95rem;
    color: var(--heading-color, #0f172a);
}
.gcal-visibility-note span {
    font-size: .88rem;
    line-height: 1.65;
    color: var(--muted-color, #475569);
}
.gcal-event-id {
    display: inline-block;
    max-width: 220px;
    overflow-wrap: anywhere;
}
.gcal-event-status {
    color: var(--muted-color, #64748b);
}
.gcal-open-event-btn {
    margin-top: .4rem;
    white-space: nowrap;
}
@media (max-width: 768px) {
    .gcal-visibility-note {
        padding: .75rem .85rem;
        border-radius: 10px;
    }
    .gcal-open-event-btn {
        width: 100%;
        justify-content: center;
    }
}

/* Google Calendar 404 recovery / access diagnostics */
.gcal-service-account-email-v4 {
    display: grid;
    gap: .35rem;
    margin: .75rem 0;
    padding: .75rem .85rem;
    border: 1px solid #dbe4ee;
    border-radius: 10px;
    background: #f8fafc;
}
.gcal-service-account-email-v4 span {
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .02em;
    color: #475569;
    text-transform: uppercase;
}
.gcal-service-account-email-v4 code {
    display: block;
    padding: .45rem .55rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    background: #fff;
    color: #0f172a;
    font-size: .82rem;
    overflow-wrap: anywhere;
}
.gcal-service-account-email-v4 small {
    color: #64748b;
    line-height: 1.5;
}
.gcal-visibility-note-warning-v4 {
    border-left-color: #b45309;
    background: #fffbeb;
}
.hidden-form {
    display: none !important;
}
@media (max-width: 768px) {
    .google-calendar-actions-v2 .btn {
        width: 100%;
        justify-content: center;
    }
}


/* Google Calendar visibility diagnostics */
.google-calendar-diagnostic-card,
.google-calendar-candidates-card {
  margin-top: 1rem;
}
.gcal-diagnostic-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}
.gcal-diagnostic-grid article {
  border: 1px solid var(--border-color, #e5e7eb);
  border-radius: .75rem;
  padding: .85rem .95rem;
  background: var(--surface-muted, #f8fafc);
}
.gcal-diagnostic-grid strong {
  display: block;
  font-size: .95rem;
  color: var(--text-strong, #111827);
  margin-bottom: .25rem;
}
.gcal-diagnostic-grid span {
  display: block;
  font-size: .82rem;
  line-height: 1.55;
  color: var(--text-muted, #64748b);
}
@media (max-width: 900px) {
  .gcal-diagnostic-grid {
    grid-template-columns: 1fr;
  }
}

/* Google Calendar target guard */
.gcal-target-warning-card {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
  border: 1px solid rgba(180, 83, 9, 0.26);
  background: #fffbeb;
  color: #78350f;
}
.gcal-target-warning-card h3 {
  margin: 4px 0 6px;
  font-size: 1.05rem;
  line-height: 1.35;
  color: #78350f;
}
.gcal-target-warning-card p {
  margin: 0;
  color: #92400e;
  line-height: 1.65;
}
.gcal-target-warning-card code {
  display: inline-block;
  max-width: 100%;
  padding: 2px 6px;
  border: 1px solid rgba(180, 83, 9, 0.18);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.72);
  color: #78350f;
  word-break: break-all;
}
.gcal-target-warning-card ol {
  margin: 0;
  padding-left: 1.25rem;
  display: grid;
  gap: 6px;
  color: #92400e;
  line-height: 1.55;
}
@media (max-width: 640px) {
  .gcal-target-warning-card {
    margin-bottom: 14px;
  }
}

/* Approval route: explicit acting staff / delegated operator inside an approver assignment */
.approval-prod-acting-delegation{
  margin: .75rem 0 0 3.25rem;
  padding: .8rem .9rem;
  border: 1px solid var(--border-color, #d9e2ec);
  border-radius: .75rem;
  background: #fafcff;
}
.approval-prod-acting-head{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  margin-bottom: .65rem;
}
.approval-prod-acting-head span{
  font-weight: 700;
  color: var(--text-strong, #1f2937);
}
.approval-prod-acting-head small{
  max-width: 560px;
  color: var(--text-muted, #64748b);
  line-height: 1.45;
  text-align: right;
}
.approval-prod-acting-list{
  display: grid;
  gap: .5rem;
}
.approval-prod-acting-chip{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .55rem .65rem;
  border: 1px solid #dbeafe;
  border-radius: .65rem;
  background: #f8fbff;
}
.approval-prod-acting-chip strong{
  color: #1e3a8a;
  font-weight: 700;
}
.approval-prod-acting-chip small{
  color: #64748b;
  text-align: right;
}
.approval-prod-acting-empty{
  padding: .55rem .65rem;
  border: 1px dashed #cbd5e1;
  border-radius: .65rem;
  color: #64748b;
  background: #fff;
  font-size: .92rem;
}
.approval-prod-acting-create{
  margin-top: .65rem;
}
.approval-prod-acting-create > summary{
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .45rem .7rem;
  border: 1px solid #cbd5e1;
  border-radius: .65rem;
  background: #fff;
  color: #334155;
  font-weight: 700;
  list-style: none;
}
.approval-prod-acting-create > summary::-webkit-details-marker{display:none;}
.approval-prod-acting-create[open] > summary{
  border-color: #93c5fd;
  color: #1d4ed8;
  background: #eff6ff;
}
.approval-prod-acting-form{
  margin-top: .75rem;
  padding-top: .75rem;
  border-top: 1px solid #e2e8f0;
}
.approval-prod-acting-grid{
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) minmax(150px, .8fr) minmax(150px, .8fr);
  gap: .75rem;
  align-items: start;
}
.approval-prod-acting-reason{
  grid-column: 1 / -1;
}
@media (max-width: 900px){
  .approval-prod-acting-delegation{margin-left: 0;}
  .approval-prod-acting-head,
  .approval-prod-acting-chip{
    flex-direction: column;
    align-items: flex-start;
  }
  .approval-prod-acting-head small,
  .approval-prod-acting-chip small{
    text-align: left;
  }
  .approval-prod-acting-grid{
    grid-template-columns: 1fr;
  }
}

/* Approval decision attachments */
.approval-attachment-upload{
  border: 1px solid #e2e8f0;
  border-radius: .85rem;
  padding: .85rem;
  background: #f8fafc;
}
.approval-attachment-upload input[type="file"]{
  width: 100%;
  min-height: 2.75rem;
  padding: .55rem .7rem;
  border: 1px dashed #94a3b8;
  border-radius: .7rem;
  background: #fff;
}
.approval-attachment-upload .optional-mark{
  display: inline-flex;
  align-items: center;
  margin-left: .35rem;
  padding: .12rem .45rem;
  border-radius: 999px;
  background: #eef2ff;
  color: #3730a3;
  font-size: .78rem;
  font-weight: 700;
}
.approval-timeline-attachments{
  margin-top: .6rem;
  display: grid;
  gap: .4rem;
  padding: .65rem;
  border: 1px solid #e2e8f0;
  border-radius: .75rem;
  background: #fff;
}
.approval-timeline-attachments > span{
  color: #475569;
  font-size: .86rem;
  font-weight: 700;
}
.approval-timeline-attachment-link{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
  padding: .45rem .55rem;
  border: 1px solid #e5e7eb;
  border-radius: .6rem;
  color: #0f172a;
  text-decoration: none;
  background: #f8fafc;
}
.approval-timeline-attachment-link:hover{
  border-color: #bfdbfe;
  color: #1d4ed8;
  background: #eff6ff;
}
.approval-timeline-attachment-link small{
  flex: 0 0 auto;
  color: #64748b;
  font-size: .78rem;
}
@media (max-width: 640px){
  .approval-timeline-attachment-link{
    align-items: flex-start;
    flex-direction: column;
    gap: .15rem;
  }
}

/* Phase: Leave calendar search usability refresh */
.leave-calendar-page .calendar-search-panel{
  border:1px solid #dbe4ef !important;
  background:#fff !important;
  border-radius:22px !important;
  padding:18px !important;
  box-shadow:0 8px 24px rgba(15,23,42,.045) !important;
}
.leave-calendar-page .calendar-search-head{
  display:flex !important;
  align-items:flex-start !important;
  justify-content:space-between !important;
  gap:16px !important;
  padding-bottom:14px !important;
  border-bottom:1px solid #e7edf5 !important;
  margin-bottom:16px !important;
}
.leave-calendar-page .calendar-search-head h3{
  margin:4px 0 5px !important;
  color:#082f49 !important;
  font-size:1.15rem !important;
  font-weight:700 !important;
  letter-spacing:-.01em !important;
}
.leave-calendar-page .calendar-search-head p{
  margin:0 !important;
  color:#64748b !important;
  font-size:.9rem !important;
  line-height:1.65 !important;
  max-width:720px !important;
}
.leave-calendar-page .calendar-search-result{
  min-width:136px !important;
  padding:12px 14px !important;
  border:1px solid #e2e8f0 !important;
  border-radius:16px !important;
  background:#f8fafc !important;
  display:grid !important;
  gap:2px !important;
  text-align:right !important;
}
.leave-calendar-page .calendar-search-result span,
.leave-calendar-page .calendar-search-result small{
  color:#64748b !important;
  font-size:.76rem !important;
  font-weight:600 !important;
}
.leave-calendar-page .calendar-search-result strong{
  color:#082f49 !important;
  font-size:1.45rem !important;
  line-height:1 !important;
  font-weight:800 !important;
}
.leave-calendar-page .calendar-search-form{
  display:grid !important;
  grid-template-columns:minmax(280px,1.45fr) minmax(170px,.62fr) minmax(220px,.9fr) minmax(180px,.72fr) auto !important;
  gap:14px !important;
  align-items:end !important;
}
.leave-calendar-page .calendar-search-form .field{
  min-width:0 !important;
  margin:0 !important;
}
.leave-calendar-page .calendar-search-form label{
  display:block !important;
  margin:0 0 6px !important;
  color:#334155 !important;
  font-size:.83rem !important;
  font-weight:700 !important;
}
.leave-calendar-page .calendar-search-form :is(.input,.select){
  width:100% !important;
  border:1px solid #cbd5e1 !important;
  border-radius:12px !important;
  background:#fff !important;
  min-height:44px !important;
  box-shadow:none !important;
}
.leave-calendar-page .calendar-search-form :is(.input,.select):focus{
  border-color:#0d7fa8 !important;
  box-shadow:0 0 0 3px rgba(13,127,168,.12) !important;
  outline:none !important;
}
.leave-calendar-page .calendar-field-hint{
  display:block !important;
  margin-top:5px !important;
  color:#64748b !important;
  font-size:.76rem !important;
  line-height:1.45 !important;
}
.leave-calendar-page .calendar-search-actions{
  display:flex !important;
  gap:8px !important;
  align-items:center !important;
  justify-content:flex-end !important;
  min-width:max-content !important;
}
.leave-calendar-page .calendar-search-actions .btn{
  min-height:44px !important;
  border-radius:12px !important;
  white-space:nowrap !important;
}
.leave-calendar-page .calendar-active-filter-row{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:8px !important;
  align-items:center !important;
  margin-top:14px !important;
  padding-top:14px !important;
  border-top:1px solid #eef2f7 !important;
}
.leave-calendar-page .calendar-active-filter-label{
  color:#475569 !important;
  font-size:.78rem !important;
  font-weight:700 !important;
  margin-right:2px !important;
}
.leave-calendar-page .calendar-filter-chip,
.leave-calendar-page .calendar-scope-chip{
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
  min-height:30px !important;
  max-width:100% !important;
  padding:5px 10px !important;
  border:1px solid #dbe4ef !important;
  border-radius:999px !important;
  background:#f8fafc !important;
  color:#334155 !important;
  font-size:.78rem !important;
  font-weight:700 !important;
  line-height:1.25 !important;
}
.leave-calendar-page .calendar-filter-chip small{
  color:#64748b !important;
  font-size:.72rem !important;
  font-weight:700 !important;
}
.leave-calendar-page .calendar-filter-chip.is-muted{
  color:#64748b !important;
  font-weight:600 !important;
}
.leave-calendar-page .calendar-scope-chip{
  margin-left:auto !important;
  background:#eef7fb !important;
  color:#0b5f7e !important;
  border-color:#cdebf5 !important;
}
.leave-calendar-page .calendar-legend-card{
  margin-top:0 !important;
}
@media(max-width:1280px){
  .leave-calendar-page .calendar-search-form{
    grid-template-columns:minmax(0,1.4fr) minmax(165px,.7fr) minmax(220px,1fr) !important;
  }
  .leave-calendar-page .calendar-search-actions{
    grid-column:1 / -1 !important;
    justify-content:flex-start !important;
  }
}
@media(max-width:860px){
  .leave-calendar-page .calendar-search-panel{
    padding:14px !important;
    border-radius:18px !important;
  }
  .leave-calendar-page .calendar-search-head{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
  .leave-calendar-page .calendar-search-result{
    text-align:left !important;
    width:100% !important;
    grid-template-columns:auto auto 1fr !important;
    align-items:end !important;
  }
  .leave-calendar-page .calendar-search-form{
    grid-template-columns:1fr !important;
    gap:12px !important;
  }
  .leave-calendar-page .calendar-search-actions{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    min-width:0 !important;
  }
  .leave-calendar-page .calendar-search-actions .btn{
    width:100% !important;
  }
  .leave-calendar-page .calendar-scope-chip{
    margin-left:0 !important;
    width:100% !important;
    justify-content:center !important;
  }
}
@media(max-width:520px){
  .leave-calendar-page .calendar-search-head h3{
    font-size:1.04rem !important;
  }
  .leave-calendar-page .calendar-search-result{
    grid-template-columns:1fr !important;
    gap:3px !important;
  }
  .leave-calendar-page .calendar-search-actions{
    grid-template-columns:1fr !important;
  }
  .leave-calendar-page .calendar-active-filter-row{
    align-items:stretch !important;
  }
  .leave-calendar-page .calendar-filter-chip,
  .leave-calendar-page .calendar-scope-chip{
    width:100% !important;
    justify-content:flex-start !important;
    border-radius:12px !important;
  }
}

/* Phase: Leave calendar search/filter UX refinement */
.leave-calendar-page .calendar-search-panel-v2{
    border:1px solid var(--line,#dbe4ef);
    border-radius:20px;
    background:#fff;
    padding:18px;
    box-shadow:0 6px 18px rgba(15,23,42,.045);
}
.leave-calendar-page .calendar-search-panel-v2 .calendar-search-head{
    align-items:flex-start;
    border-bottom:1px solid var(--line-soft,#edf2f7);
    padding-bottom:14px;
    margin-bottom:14px;
}
.leave-calendar-page .calendar-search-panel-v2 .calendar-search-head h3{
    margin-top:6px;
    font-size:20px;
    letter-spacing:-.01em;
}
.leave-calendar-page .calendar-search-panel-v2 .calendar-search-head p{
    max-width:820px;
    margin-top:4px;
}
.leave-calendar-page .calendar-search-form-v2{
    display:grid;
    gap:12px;
}
.leave-calendar-page .calendar-search-primary-row{
    display:grid;
    grid-template-columns:minmax(280px,1fr) 180px auto;
    gap:12px;
    align-items:end;
}
.leave-calendar-page .calendar-search-panel-v2 .field{
    display:grid;
    gap:6px;
}
.leave-calendar-page .calendar-search-panel-v2 label{
    color:#172033;
    font-size:13px;
    font-weight:650;
}
.leave-calendar-page .calendar-search-panel-v2 .calendar-field-hint{
    color:#6b7688;
    font-size:12px;
    line-height:1.45;
}
.leave-calendar-page .calendar-search-panel-v2 :is(.input,.select){
    min-height:42px;
    border-radius:12px;
    border-color:#d6e0eb;
    background:#fff;
}
.leave-calendar-page .calendar-search-panel-v2 :is(.input,.select):focus{
    border-color:#0d7fa8;
    box-shadow:0 0 0 3px rgba(13,127,168,.12);
}
.leave-calendar-page .calendar-search-panel-v2 .calendar-search-actions{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:8px;
    padding:0;
    border:0;
    background:transparent;
}
.leave-calendar-page .calendar-search-panel-v2 .calendar-search-actions .btn{
    min-height:42px;
    white-space:nowrap;
}
.leave-calendar-page .calendar-advanced-filter{
    border:1px solid #e2e8f0;
    border-radius:16px;
    background:#f8fafc;
    overflow:hidden;
}
.leave-calendar-page .calendar-advanced-filter summary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    min-height:48px;
    padding:11px 14px;
    cursor:pointer;
    color:#172033;
    font-weight:650;
    list-style:none;
}
.leave-calendar-page .calendar-advanced-filter summary::-webkit-details-marker{display:none;}
.leave-calendar-page .calendar-advanced-filter summary::after{
    content:'ขยาย';
    flex:0 0 auto;
    border:1px solid #cbd5e1;
    border-radius:999px;
    padding:4px 9px;
    background:#fff;
    color:#475569;
    font-size:12px;
    font-weight:600;
}
.leave-calendar-page .calendar-advanced-filter[open] summary::after{content:'ย่อ';}
.leave-calendar-page .calendar-advanced-filter summary small{
    color:#64748b;
    font-size:12px;
    font-weight:500;
    line-height:1.35;
}
.leave-calendar-page .calendar-advanced-filter-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:12px;
    padding:14px;
    border-top:1px solid #e2e8f0;
    background:#fff;
}
.leave-calendar-page .calendar-active-filter-row{
    align-items:center;
    gap:8px;
    margin-top:12px;
    padding-top:12px;
    border-top:1px solid var(--line-soft,#edf2f7);
}
.leave-calendar-page .calendar-active-filter-label{
    color:#475569;
    font-size:12px;
    font-weight:650;
}
.leave-calendar-page .calendar-filter-chip{
    border-color:#dbeafe;
    background:#f8fbff;
    color:#0f3754;
}
.leave-calendar-page .calendar-filter-chip small{
    color:#64748b;
}
.leave-calendar-page .calendar-scope-chip{
    border-color:#dbeafe;
    background:#eff6ff;
    color:#0e5d89!important;
}
.leave-calendar-page .calendar-list-table .stack-cell small + small{
    margin-top:2px;
}
@media(max-width:1180px){
    .leave-calendar-page .calendar-search-primary-row{
        grid-template-columns:minmax(240px,1fr) 180px;
    }
    .leave-calendar-page .calendar-search-primary-row .calendar-search-actions{
        grid-column:1/-1;
        justify-content:flex-start;
    }
    .leave-calendar-page .calendar-advanced-filter-grid{
        grid-template-columns:repeat(2,minmax(0,1fr));
    }
}
@media(max-width:720px){
    .leave-calendar-page .calendar-search-panel-v2{
        padding:14px;
        border-radius:16px;
    }
    .leave-calendar-page .calendar-search-panel-v2 .calendar-search-head{
        display:grid;
        gap:10px;
    }
    .leave-calendar-page .calendar-search-panel-v2 .calendar-search-result{
        justify-self:stretch;
        width:100%;
    }
    .leave-calendar-page .calendar-search-primary-row,
    .leave-calendar-page .calendar-advanced-filter-grid{
        grid-template-columns:1fr;
    }
    .leave-calendar-page .calendar-search-panel-v2 .calendar-search-actions{
        display:grid;
        grid-template-columns:1fr;
    }
    .leave-calendar-page .calendar-search-panel-v2 .calendar-search-actions .btn{
        width:100%;
    }
    .leave-calendar-page .calendar-advanced-filter summary{
        align-items:flex-start;
        flex-direction:column;
    }
    .leave-calendar-page .calendar-advanced-filter summary::after{
        align-self:flex-start;
    }
    .leave-calendar-page .calendar-active-filter-row{
        display:flex;
        align-items:flex-start;
    }
    .leave-calendar-page .calendar-scope-chip{
        width:100%;
        margin-left:0;
    }
}

/* Phase: Calendar leave filter production layout reset */
.leave-calendar-page .calendar-filter-suite{
  width:100%;
  max-width:none;
  border:1px solid #dbe4ef;
  border-radius:18px;
  background:#fff;
  padding:18px;
  box-shadow:0 6px 18px rgba(15,23,42,.04);
}
.leave-calendar-page .calendar-filter-suite-head{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:16px;
  align-items:start;
  padding-bottom:14px;
  border-bottom:1px solid #edf2f7;
  margin-bottom:14px;
}
.leave-calendar-page .calendar-filter-suite-title{
  min-width:0;
}
.leave-calendar-page .calendar-filter-suite-title h3{
  margin:7px 0 4px;
  color:#06243a;
  font-size:20px;
  line-height:1.25;
  font-weight:650;
  letter-spacing:-.015em;
}
.leave-calendar-page .calendar-filter-suite-title p{
  margin:0;
  color:#64748b;
  font-size:13px;
  line-height:1.65;
  max-width:860px;
}
.leave-calendar-page .calendar-filter-suite-meta{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:8px;
}
.leave-calendar-page .calendar-filter-suite-meta span{
  min-width:112px;
  min-height:58px;
  display:grid;
  align-content:center;
  gap:2px;
  border:1px solid #e2e8f0;
  border-radius:14px;
  background:#f8fafc;
  padding:9px 12px;
}
.leave-calendar-page .calendar-filter-suite-meta small{
  color:#64748b;
  font-size:11px;
  font-weight:600;
}
.leave-calendar-page .calendar-filter-suite-meta strong{
  color:#0f172a;
  font-size:16px;
  line-height:1.2;
  font-weight:700;
  max-width:220px;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.leave-calendar-page .calendar-filter-form-pro{
  display:grid;
  grid-template-columns:minmax(260px,2fr) minmax(150px,.75fr) minmax(190px,1fr) minmax(190px,1fr);
  gap:12px;
  align-items:end;
}
.leave-calendar-page .calendar-filter-form-pro .field{
  display:grid;
  gap:6px;
  min-width:0;
}
.leave-calendar-page .calendar-filter-form-pro label{
  color:#172033;
  font-size:13px;
  font-weight:650;
}
.leave-calendar-page .calendar-filter-form-pro :is(.input,.select){
  width:100%;
  min-height:42px;
  border:1px solid #d6e0eb;
  border-radius:12px;
  background:#fff;
  color:#0f172a;
  font-size:14px;
}
.leave-calendar-page .calendar-filter-form-pro :is(.input,.select):focus{
  border-color:#0d7fa8;
  box-shadow:0 0 0 3px rgba(13,127,168,.12);
}
.leave-calendar-page .calendar-filter-keyword-pro{
  grid-column:span 2;
}
.leave-calendar-page .calendar-filter-actions-pro{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  gap:8px;
  min-width:0;
}
.leave-calendar-page .calendar-filter-actions-pro .btn{
  min-height:42px;
  white-space:nowrap;
}
.leave-calendar-page .calendar-filter-active-strip{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px;
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid #edf2f7;
}
.leave-calendar-page .calendar-filter-active-label{
  color:#475569;
  font-size:12px;
  font-weight:700;
}
.leave-calendar-page .calendar-filter-active-empty{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  border:1px solid #e2e8f0;
  border-radius:999px;
  background:#f8fafc;
  color:#64748b;
  padding:6px 11px;
  font-size:12px;
  font-weight:600;
}
.leave-calendar-page .calendar-filter-chip{
  display:inline-flex;
  align-items:center;
  gap:7px;
  max-width:100%;
  min-height:32px;
  border:1px solid #dbeafe;
  border-radius:999px;
  background:#f8fbff;
  color:#0f3754;
  padding:6px 10px;
  font-size:12px;
  font-weight:650;
}
.leave-calendar-page .calendar-filter-chip small{
  color:#64748b;
  font-weight:650;
}
@media(max-width:1240px){
  .leave-calendar-page .calendar-filter-form-pro{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .leave-calendar-page .calendar-filter-keyword-pro{
    grid-column:1/-1;
  }
  .leave-calendar-page .calendar-filter-actions-pro{
    justify-content:flex-start;
  }
}
@media(max-width:760px){
  .leave-calendar-page .calendar-filter-suite{
    padding:14px;
    border-radius:16px;
  }
  .leave-calendar-page .calendar-filter-suite-head{
    grid-template-columns:1fr;
    gap:10px;
  }
  .leave-calendar-page .calendar-filter-suite-meta{
    justify-content:stretch;
  }
  .leave-calendar-page .calendar-filter-suite-meta span{
    flex:1 1 140px;
  }
  .leave-calendar-page .calendar-filter-form-pro{
    grid-template-columns:1fr;
  }
  .leave-calendar-page .calendar-filter-actions-pro{
    display:grid;
    grid-template-columns:1fr;
  }
  .leave-calendar-page .calendar-filter-actions-pro .btn{
    width:100%;
  }
  .leave-calendar-page .calendar-filter-active-strip{
    align-items:stretch;
  }
  .leave-calendar-page .calendar-filter-active-label,
  .leave-calendar-page .calendar-filter-active-empty,
  .leave-calendar-page .calendar-filter-chip{
    width:100%;
    border-radius:12px;
    justify-content:flex-start;
  }
}

/* Super Admin impersonation (production-safe, POST + CSRF + audit) */
.super-admin-impersonation-banner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin:14px 24px 0;
  padding:12px 14px;
  border:1px solid #f4c56a;
  border-radius:14px;
  background:#fff8e6;
  color:#5f3d00;
  box-shadow:0 4px 14px rgba(95,61,0,.08);
}
.super-admin-impersonation-banner strong{display:block;font-size:14px;line-height:1.25}
.super-admin-impersonation-banner span{display:block;margin-top:2px;font-size:12px;line-height:1.45;color:#7a5200}
.super-admin-impersonation-banner form{margin:0;flex:0 0 auto}
.super-admin-impersonation-action{
  border-color:#f4c56a!important;
  background:#fffaf0!important;
}
.super-admin-impersonation-action strong{color:#5f3d00}
.super-admin-impersonation-action span{color:#7a5200}
.button.button-warning{
  border-color:#d99a00;
  background:#f6b51d;
  color:#3d2900;
}
.button.button-warning:hover{background:#e6a500;color:#2f2000}
@media(max-width:760px){
  .super-admin-impersonation-banner{margin:10px 12px 0;align-items:stretch;flex-direction:column}
  .super-admin-impersonation-banner form,.super-admin-impersonation-banner button{width:100%}
}

/* Phase 2.9.42 — approval delegation real avatar display */
.delegate-avatar-v2.has-photo{
  padding:0;
  overflow:hidden;
  background:#eef4f8;
  border:1px solid #d8e3ee;
}
.delegate-avatar-v2.has-photo img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
}
.delegate-avatar-v2.has-photo.is-delegate{
  background:#edfdf6;
  border-color:#c7f0df;
}


/* System backup page */
.system-backup-hero .hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.system-backup-card{margin-top:18px}
.system-backup-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(260px,.9fr) minmax(260px,.9fr);gap:16px;align-items:stretch}
.system-backup-panel{border:1px solid var(--border-color,#dbe4ef);border-radius:16px;background:#fff;padding:18px;box-shadow:0 8px 22px rgba(15,23,42,.04)}
.system-backup-panel-primary{background:#f8fbfd;border-color:#cbdde8}
.system-backup-panel-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}
.system-backup-panel h2,.system-backup-panel h3,.system-backup-note h2{margin:0 0 8px;color:#0f172a;line-height:1.25}
.system-backup-panel p,.system-backup-note p{margin:0 0 10px;color:#475569;line-height:1.65}
.system-backup-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:14px;background:#0f5f7f;color:#fff;font-weight:700;letter-spacing:.02em;flex:0 0 auto}
.system-backup-list{margin:0;padding:0;list-style:none;display:grid;gap:9px}
.system-backup-list li{position:relative;padding-left:22px;color:#334155;line-height:1.55}
.system-backup-list li::before{position:absolute;left:0;top:.15em;font-weight:700}
.system-backup-list.is-ok li::before{content:'✓';color:#15803d}
.system-backup-list.is-warn li::before{content:'!';color:#b45309}
.system-backup-note{margin-top:16px;border-left:4px solid #b45309;background:#fffdf7}
@media(max-width:1100px){.system-backup-grid{grid-template-columns:1fr}}
@media(max-width:640px){.system-backup-panel{padding:14px;border-radius:14px}.system-backup-panel-head{flex-direction:column}.system-backup-card .btn{width:100%}}

/* Vacation opening balances — scoped production UI */
.vacation-opening-hero .hero-meta-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.9rem}.vacation-opening-hero .hero-meta-row span{border:1px solid rgba(255,255,255,.28);border-radius:999px;padding:.32rem .7rem;background:rgba(255,255,255,.1);font-size:.82rem}.vacation-opening-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.8fr);gap:1rem;align-items:start}.vacation-opening-card{margin-bottom:1rem}.vacation-opening-form{display:grid;gap:1rem}.vacation-opening-number-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem}.vacation-opening-checkline{display:flex;gap:.75rem;align-items:flex-start;padding:.85rem 1rem;border:1px solid var(--border-color,#d9e2ec);border-radius:.8rem;background:#f8fafc}.vacation-opening-checkline input{margin-top:.18rem}.vacation-opening-checkline span{display:grid;gap:.15rem}.vacation-opening-checkline small{color:var(--muted-color,#64748b)}.vacation-opening-actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-top:.35rem}.vacation-opening-actions>span{color:var(--muted-color,#64748b);font-size:.9rem}.vacation-opening-search{margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-color,#d9e2ec);display:grid;gap:.75rem}.vacation-opening-table td small{display:block;color:var(--muted-color,#64748b);margin-top:.2rem}.vacation-opening-table .empty-cell{text-align:center;color:var(--muted-color,#64748b);padding:2rem}.text-right{text-align:right}@media (max-width: 1100px){.vacation-opening-grid{grid-template-columns:1fr}.vacation-opening-number-grid{grid-template-columns:1fr 1fr}}@media (max-width: 640px){.vacation-opening-number-grid,.form-grid.two-columns{grid-template-columns:1fr}.vacation-opening-actions{align-items:stretch}.vacation-opening-actions .btn{width:100%;justify-content:center}.vacation-opening-table{min-width:760px}}

/* Vacation opening balances — production UI polish */
.vacation-opening-hero.is-minimal{
  align-items:flex-start;
  gap:1rem;
}
.vacation-opening-hero.is-minimal p{
  max-width:760px;
}
.vacation-opening-summary{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.85rem;
  margin:0 0 1rem;
}
.vacation-opening-stat-card{
  background:#fff;
  border:1px solid var(--border-color,#d9e2ec);
  border-radius:14px;
  padding:1rem 1.1rem;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
  display:grid;
  gap:.25rem;
}
.vacation-opening-stat-card span{
  color:var(--muted-color,#64748b);
  font-size:.82rem;
  font-weight:600;
}
.vacation-opening-stat-card strong{
  color:var(--text-color,#0f172a);
  font-size:1.08rem;
  line-height:1.25;
}
.vacation-opening-stat-card small{
  color:var(--muted-color,#64748b);
  line-height:1.35;
}
.vacation-opening-layout{
  display:grid;
  grid-template-columns:minmax(0,1.45fr) minmax(340px,.85fr);
  gap:1rem;
  align-items:start;
}
.vacation-opening-side-panel{
  display:grid;
  gap:1rem;
}
.vacation-opening-card{
  margin-bottom:1rem;
  border-radius:16px;
}
.vacation-opening-section-head{
  align-items:flex-start;
  gap:1rem;
  padding-bottom:.85rem;
  border-bottom:1px solid var(--border-color,#d9e2ec);
  margin-bottom:1rem;
}
.vacation-opening-section-head h3{
  margin:.15rem 0 .25rem;
  font-size:1.08rem;
}
.vacation-opening-section-head p{
  margin:0;
  color:var(--muted-color,#64748b);
  line-height:1.5;
}
.vacation-opening-form{
  display:grid;
  gap:1rem;
}
.vacation-opening-number-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.85rem;
}
.vacation-opening-checkline{
  display:flex;
  gap:.75rem;
  align-items:flex-start;
  padding:.9rem 1rem;
  border:1px solid #dbe4ee;
  border-radius:12px;
  background:#f8fafc;
}
.vacation-opening-checkline input{
  margin-top:.22rem;
  width:1rem;
  height:1rem;
  flex:0 0 auto;
}
.vacation-opening-checkline span{
  display:grid;
  gap:.18rem;
  line-height:1.35;
}
.vacation-opening-checkline small{
  color:var(--muted-color,#64748b);
}
.vacation-opening-actions{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  flex-wrap:wrap;
  padding-top:.25rem;
}
.vacation-opening-actions.is-compact{
  justify-content:flex-end;
}
.vacation-opening-actions>span{
  color:var(--muted-color,#64748b);
  font-size:.9rem;
  line-height:1.4;
}
.vacation-opening-template-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem;
  margin-bottom:1rem;
  border:1px solid #cfe0f3;
  border-radius:14px;
  background:#f8fbff;
}
.vacation-opening-template-box p{
  margin:.18rem 0 0;
  color:var(--muted-color,#64748b);
  line-height:1.45;
}
.vacation-opening-search{
  display:grid;
  gap:.75rem;
}
.vacation-opening-table-wrap{
  border:1px solid var(--border-color,#d9e2ec);
  border-radius:14px;
  overflow:auto;
}
.vacation-opening-table{
  margin:0;
}
.vacation-opening-table td small{
  display:block;
  color:var(--muted-color,#64748b);
  margin-top:.2rem;
  line-height:1.35;
}
.vacation-opening-table .empty-cell{
  text-align:center;
  color:var(--muted-color,#64748b);
  padding:2rem;
}
.text-right{text-align:right}
@media (max-width: 1180px){
  .vacation-opening-layout{grid-template-columns:1fr}
  .vacation-opening-side-panel{grid-template-columns:1fr 1fr}
}
@media (max-width: 820px){
  .vacation-opening-summary{grid-template-columns:1fr}
  .vacation-opening-side-panel{grid-template-columns:1fr}
  .vacation-opening-number-grid{grid-template-columns:1fr}
  .vacation-opening-template-box{align-items:stretch;flex-direction:column}
}
@media (max-width: 640px){
  .vacation-opening-actions{align-items:stretch}
  .vacation-opening-actions .btn,.vacation-opening-template-box .btn{width:100%;justify-content:center}
  .vacation-opening-table{min-width:760px}
}


/* Vacation opening balances — Manual Entry layout fix */
.vacation-opening-manual-card{
  overflow:hidden;
}
.vacation-opening-manual-form{
  gap:1rem;
}
.manual-entry-block{
  border:1px solid #dbe4ee;
  border-radius:14px;
  background:#fff;
  padding:1rem;
}
.manual-entry-person-block{
  background:#f8fbff;
  border-color:#cfe0f3;
}
.manual-entry-block-head{
  display:flex;
  align-items:flex-start;
  gap:.8rem;
  margin-bottom:.9rem;
}
.manual-entry-step{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:30px;
  height:30px;
  border-radius:999px;
  background:#0f5f7f;
  color:#fff;
  font-weight:700;
  font-size:.88rem;
  flex:0 0 auto;
}
.manual-entry-block-head h4{
  margin:0 0 .16rem;
  font-size:1rem;
  line-height:1.3;
  color:#0f172a;
}
.manual-entry-block-head p{
  margin:0;
  color:#64748b;
  line-height:1.45;
  font-size:.9rem;
}
.manual-entry-main-grid{
  display:grid;
  grid-template-columns:minmax(0,1.55fr) minmax(260px,.85fr);
  gap:1rem;
  align-items:start;
}
.manual-entry-balance-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.85rem;
}
.manual-number-field{
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:12px;
  padding:.85rem;
}
.manual-number-field .input{
  font-size:1.12rem;
  font-weight:700;
  text-align:right;
  background:#fff;
}
.manual-entry-formula{
  display:grid;
  gap:.18rem;
  margin-top:.85rem;
  padding:.85rem 1rem;
  border-radius:12px;
  background:#f7fbf9;
  border:1px solid #cfe7d6;
  color:#14532d;
}
.manual-entry-formula span{
  font-size:.78rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.manual-entry-formula strong{
  font-size:.95rem;
  color:#166534;
}
.manual-entry-formula small{
  color:#3f7d4d;
  line-height:1.35;
}
.manual-entry-confirm-block{
  background:#fff;
}
.manual-entry-overwrite{
  margin-top:.85rem;
}
.manual-entry-submit-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem;
  border:1px solid #bfd8ee;
  border-radius:14px;
  background:#f8fbff;
}
.manual-entry-submit-bar div{
  display:grid;
  gap:.16rem;
}
.manual-entry-submit-bar strong{
  color:#0f172a;
  line-height:1.3;
}
.manual-entry-submit-bar span{
  color:#64748b;
  line-height:1.4;
  font-size:.9rem;
}
.manual-entry-submit-bar .btn{
  white-space:nowrap;
}
@media (max-width: 1080px){
  .manual-entry-main-grid{grid-template-columns:1fr}
  .manual-entry-balance-grid{grid-template-columns:1fr 1fr 1fr}
}
@media (max-width: 760px){
  .manual-entry-block{padding:.9rem;border-radius:12px}
  .manual-entry-block-head{gap:.65rem}
  .manual-entry-step{width:28px;height:28px}
  .manual-entry-balance-grid{grid-template-columns:1fr}
  .manual-entry-submit-bar{flex-direction:column;align-items:stretch}
  .manual-entry-submit-bar .btn{width:100%;justify-content:center}
}


/* Global back-to-top button */
.back-to-top-button{
  position:fixed;
  right:clamp(14px,2vw,24px);
  bottom:calc(18px + env(safe-area-inset-bottom,0px));
  z-index:1050;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.35rem;
  min-width:44px;
  min-height:44px;
  padding:.62rem .82rem;
  border:1px solid rgba(15,95,127,.22);
  border-radius:999px;
  background:#ffffff;
  color:#0f5f7f;
  box-shadow:0 8px 22px rgba(15,23,42,.16);
  font:inherit;
  font-weight:700;
  line-height:1;
  cursor:pointer;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s ease,background-color .18s ease,border-color .18s ease;
}
.back-to-top-button.is-visible{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.back-to-top-button:hover{
  background:#f0f9ff;
  border-color:rgba(15,95,127,.36);
}
.back-to-top-button:focus-visible{
  outline:3px solid rgba(13,127,168,.25);
  outline-offset:3px;
}
.back-to-top-button span[aria-hidden="true"]{
  font-size:1.15rem;
  line-height:1;
  transform:translateY(-1px);
}
.back-to-top-text{
  font-size:.82rem;
}
@media (max-width: 720px){
  .back-to-top-button{
    right:14px;
    bottom:calc(14px + env(safe-area-inset-bottom,0px));
    width:44px;
    padding:0;
  }
  .back-to-top-text{
    position:absolute;
    width:1px;
    height:1px;
    padding:0;
    margin:-1px;
    overflow:hidden;
    clip:rect(0,0,0,0);
    white-space:nowrap;
    border:0;
  }
}
@media print{
  .back-to-top-button{
    display:none!important;
  }
}


/* Force system-wide back-to-top button — final global component */
.global-back-to-top,
.back-to-top-button{
  position:fixed!important;
  right:22px!important;
  bottom:22px!important;
  z-index:2147483000!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
  min-width:48px!important;
  min-height:48px!important;
  padding:0 14px!important;
  border:1px solid rgba(15,95,127,.32)!important;
  border-radius:999px!important;
  background:#ffffff!important;
  color:#0f5f7f!important;
  box-shadow:0 10px 28px rgba(15,23,42,.22)!important;
  font:inherit!important;
  font-size:14px!important;
  font-weight:700!important;
  line-height:1!important;
  cursor:pointer!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
  transform:translateY(10px)!important;
  transition:opacity .18s ease,transform .18s ease,visibility .18s ease!important;
}
.global-back-to-top.is-visible,
.back-to-top-button.is-visible{
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  transform:translateY(0)!important;
}
.global-back-to-top:hover,
.back-to-top-button:hover{
  background:#f0f9ff!important;
  border-color:rgba(15,95,127,.48)!important;
}
.global-back-to-top:focus-visible,
.back-to-top-button:focus-visible{
  outline:3px solid rgba(13,127,168,.28)!important;
  outline-offset:3px!important;
}
.global-back-to-top span[aria-hidden="true"],
.back-to-top-button span[aria-hidden="true"]{
  font-size:19px!important;
  line-height:1!important;
  transform:translateY(-1px)!important;
}
.global-back-to-top-label,
.back-to-top-text{
  font-size:13px!important;
  white-space:nowrap!important;
}
@media(max-width:720px){
  .global-back-to-top,
  .back-to-top-button{
    right:14px!important;
    bottom:14px!important;
    width:48px!important;
    min-width:48px!important;
    padding:0!important;
  }
  .global-back-to-top-label,
  .back-to-top-text{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
  }
}
@media print{
  .global-back-to-top,
  .back-to-top-button{
    display:none!important;
  }
}


/* User employees — collapsible admin cards */
.user-employee-setup-grid{
  align-items:start;
}
.user-employee-collapsible-card{
  padding:0!important;
  overflow:hidden;
}
.user-employee-collapsible-card > .user-employee-collapsible-summary{
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:1rem 1.15rem;
  background:#fff;
  border-radius:inherit;
  transition:background-color .16s ease;
}
.user-employee-collapsible-card > .user-employee-collapsible-summary::-webkit-details-marker{
  display:none;
}
.user-employee-collapsible-card > .user-employee-collapsible-summary:hover{
  background:#f8fafc;
}
.user-employee-collapsible-copy{
  display:grid;
  gap:.18rem;
  min-width:0;
}
.user-employee-collapsible-copy strong{
  color:#0f172a;
  font-size:1rem;
  line-height:1.35;
}
.user-employee-collapsible-copy small{
  color:#64748b;
  line-height:1.45;
}
.user-employee-collapsible-button{
  flex:0 0 auto;
  pointer-events:none;
  white-space:nowrap;
}
.user-employee-collapsible-card[open] > .user-employee-collapsible-summary{
  border-bottom:1px solid #dbe4ee;
  border-bottom-left-radius:0;
  border-bottom-right-radius:0;
  background:#f8fbff;
}
.user-employee-collapsible-card[open] > .user-employee-collapsible-summary .user-employee-collapsible-button::after{
  content:'';
}
.user-employee-collapsible-card[open] > .user-employee-collapsible-summary .user-employee-collapsible-button{
  opacity:.88;
}
.user-employee-collapsible-card > .user-employee-provision-head,
.user-employee-collapsible-card > .user-employee-provision-form,
.user-employee-collapsible-card > .user-employee-provision-guide,
.user-employee-collapsible-card > .data-authority-head,
.user-employee-collapsible-card > .data-authority-flow,
.user-employee-collapsible-card > .data-authority-action{
  margin-left:1.15rem;
  margin-right:1.15rem;
}
.user-employee-collapsible-card > .user-employee-provision-head,
.user-employee-collapsible-card > .data-authority-head{
  margin-top:1rem;
}
.user-employee-collapsible-card > .user-employee-provision-guide,
.user-employee-collapsible-card > .data-authority-action{
  margin-bottom:1.15rem;
}
@media(max-width:760px){
  .user-employee-collapsible-card > .user-employee-collapsible-summary{
    align-items:stretch;
    flex-direction:column;
    padding:.95rem;
  }
  .user-employee-collapsible-button{
    width:100%;
    justify-content:center;
  }
  .user-employee-collapsible-card > .user-employee-provision-head,
  .user-employee-collapsible-card > .user-employee-provision-form,
  .user-employee-collapsible-card > .user-employee-provision-guide,
  .user-employee-collapsible-card > .data-authority-head,
  .user-employee-collapsible-card > .data-authority-flow,
  .user-employee-collapsible-card > .data-authority-action{
    margin-left:.95rem;
    margin-right:.95rem;
  }
}

/* User employees — data authority visible by default */
#user-employee-data-authority-panel.data-authority-card{
  display:block;
}
#user-employee-data-authority-panel .data-authority-head{
  margin-top:0;
}

/* Restore visible system-wide To Top button */
.global-back-to-top,
.back-to-top-button{
  position:fixed!important;
  right:22px!important;
  bottom:22px!important;
  z-index:2147483000!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:6px!important;
  min-width:48px!important;
  min-height:48px!important;
  padding:0 14px!important;
  border:1px solid rgba(15,95,127,.32)!important;
  border-radius:999px!important;
  background:#ffffff!important;
  color:#0f5f7f!important;
  box-shadow:0 10px 28px rgba(15,23,42,.22)!important;
  font:inherit!important;
  font-size:14px!important;
  font-weight:700!important;
  line-height:1!important;
  cursor:pointer!important;
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  transform:none!important;
}
.global-back-to-top:hover,
.back-to-top-button:hover{background:#f0f9ff!important;border-color:rgba(15,95,127,.48)!important}
.global-back-to-top:focus-visible,
.back-to-top-button:focus-visible{outline:3px solid rgba(13,127,168,.28)!important;outline-offset:3px!important}
.global-back-to-top span[aria-hidden="true"],
.back-to-top-button span[aria-hidden="true"]{font-size:19px!important;line-height:1!important;transform:translateY(-1px)!important}
.global-back-to-top-label,.back-to-top-text{font-size:13px!important;white-space:nowrap!important}
@media(max-width:720px){.global-back-to-top,.back-to-top-button{right:14px!important;bottom:14px!important;width:48px!important;min-width:48px!important;padding:0!important}.global-back-to-top-label,.back-to-top-text{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}}
@media print{.global-back-to-top,.back-to-top-button{display:none!important}}


/* Back-to-top visibility rule — hidden at page top, visible after scroll */
.global-back-to-top,
.back-to-top-button{
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
  transform:translateY(10px)!important;
}
.global-back-to-top.is-visible,
.back-to-top-button.is-visible{
  opacity:1!important;
  visibility:visible!important;
  pointer-events:auto!important;
  transform:translateY(0)!important;
}
@media print{
  .global-back-to-top,
  .back-to-top-button{
    display:none!important;
  }
}


/* Clear leave data maintenance page */
.system-maintenance-hero .hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.clear-leave-plan-card,.clear-leave-danger-card,.clear-leave-result-card{margin-top:18px}
.clear-leave-options{display:flex;gap:10px 16px;align-items:center;flex-wrap:wrap;margin:0 0 16px;padding:12px;border:1px solid var(--border-color,#dbe4ef);border-radius:14px;background:#f8fbfd}
.clear-leave-options label{display:inline-flex;align-items:center;gap:7px;color:#334155;font-size:13px;font-weight:600}
.clear-leave-options input[type=checkbox]{width:16px;height:16px;accent-color:#0d7fa8}
.clear-leave-table code{font-size:12px;color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:3px 6px}
.clear-leave-danger-card{border-color:#fecaca;background:#fffafa}
.clear-leave-execute-form{display:grid;gap:14px;max-width:680px}
.clear-leave-result-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;margin:12px 0}
.clear-leave-result-item{display:flex;justify-content:space-between;gap:10px;align-items:center;border:1px solid #dbe4ef;border-radius:12px;padding:10px 12px;background:#fff}
.clear-leave-result-item strong{color:#0f172a;font-size:13px}
.clear-leave-result-item span{color:#0f766e;font-size:13px;font-weight:700}
@media (max-width: 720px){
  .clear-leave-options{display:grid;grid-template-columns:1fr}
  .clear-leave-execute-form .button-row{display:grid;grid-template-columns:1fr}
}

/* SLA policy duplicate detection */
.sla-policy-duplicate-alert,
.sla-policy-duplicate-ok{
  margin:16px 0;
  border:1px solid #dbe4ef;
  border-radius:18px;
  padding:16px;
  background:#fff;
  display:flex;
  gap:14px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
}
.sla-policy-duplicate-alert{
  border-color:#fecaca;
  background:#fff7f7;
}
.sla-policy-duplicate-ok{
  border-color:#bbf7d0;
  background:#f7fef9;
}
.sla-policy-duplicate-alert h3,
.sla-policy-duplicate-ok strong{
  display:block;
  margin:8px 0 4px;
  color:#0f172a;
  font-size:17px;
  line-height:1.35;
}
.sla-policy-duplicate-alert p,
.sla-policy-duplicate-ok small{
  display:block;
  margin:0;
  color:#475569;
  line-height:1.6;
}
.sla-policy-duplicate-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.sla-policy-duplicate-list span{
  display:inline-flex;
  gap:6px;
  align-items:center;
  padding:6px 9px;
  border:1px solid #fecaca;
  border-radius:999px;
  background:#fff;
  color:#7f1d1d;
  font-size:12px;
  font-weight:650;
}
.sla-policy-duplicate-mini{
  display:inline-flex;
  vertical-align:middle;
  margin-left:6px;
  padding:2px 7px;
  border-radius:999px;
  background:#fee2e2;
  color:#991b1b;
  font-size:11px;
  font-weight:800;
}
@media (max-width:720px){
  .sla-policy-duplicate-alert,.sla-policy-duplicate-ok{display:grid}
  .sla-policy-duplicate-alert .btn{width:100%}
}

/* Master data management page */
.master-data-hero .page-hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.master-data-hero-status{text-align:center}
.master-data-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px;margin:16px 0}
.master-data-summary-card{display:block;border:1px solid #dbe4ef;border-radius:16px;background:#fff;padding:14px;text-decoration:none;box-shadow:0 6px 18px rgba(15,23,42,.035)}
.master-data-summary-card span{display:block;color:#64748b;font-size:12px;font-weight:700}
.master-data-summary-card strong{display:block;color:#0f172a;font-size:28px;line-height:1.1;margin:5px 0}
.master-data-summary-card small{display:block;color:#64748b;line-height:1.45}
.master-data-tabs{position:sticky;top:0;z-index:4;display:flex;gap:8px;overflow:auto;padding:10px 0;margin:4px 0 14px;background:rgba(246,249,252,.94);backdrop-filter:blur(6px)}
.master-data-tabs a{white-space:nowrap;text-decoration:none;border:1px solid #dbe4ef;border-radius:999px;background:#fff;color:#334155;font-size:13px;font-weight:700;padding:8px 12px}
.master-data-stack{display:grid;gap:18px}
.master-data-section{padding:18px;border-radius:18px}
.master-data-section-head{align-items:flex-start}
.master-data-icon{display:inline-grid;place-items:center;min-width:38px;height:32px;padding:0 8px;border-radius:10px;background:#e8f6fb;color:#0e5d89;font-size:12px;font-weight:800;margin-bottom:8px}
.master-data-section-meta{display:grid;gap:5px;text-align:right;color:#64748b;font-size:13px}
.master-data-section-meta strong{font-size:12px}
.master-data-add-card{border:1px solid #dbe4ef;border-radius:14px;background:#f8fbfd;margin:14px 0;overflow:hidden}
.master-data-add-card summary{cursor:pointer;padding:12px 14px;font-weight:800;color:#0f172a;list-style:none}
.master-data-add-card summary::-webkit-details-marker{display:none}
.master-data-add-card[open] summary{border-bottom:1px solid #dbe4ef;background:#fff}
.master-data-form{padding:14px;display:grid;gap:12px}
.master-data-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;align-items:end}
.master-data-field,.master-data-check-field{display:grid;gap:6px;color:#334155;font-size:13px;font-weight:700}
.master-data-field span small{color:#b45309;font-size:11px}
.master-data-check-field{align-self:end;display:flex;align-items:center;gap:8px;min-height:42px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;padding:9px 10px}
.master-data-check-field input{width:16px;height:16px;accent-color:#0d7fa8}
.master-data-list{display:grid;gap:12px;margin-top:12px}
.master-data-row{border:1px solid #dbe4ef;border-radius:16px;background:#fff;padding:14px;display:grid;gap:12px}
.master-data-row.is-inactive{background:#f8fafc}
.master-data-row-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.master-data-row-head strong{display:block;color:#0f172a;font-size:16px}
.master-data-row-head small{display:block;color:#64748b;margin-top:3px;line-height:1.45}
.master-data-row-actions{display:flex;justify-content:space-between;gap:12px;align-items:center;border-top:1px solid #eef2f7;padding-top:10px}
.master-data-row-actions small{color:#64748b;line-height:1.45}
.text-danger{color:#b91c1c!important}
.text-success{color:#047857!important}
@media (max-width:720px){
  .master-data-section-meta{text-align:left}
  .master-data-row-head,.master-data-row-actions{display:grid}
  .master-data-row-actions .btn{width:100%}
  .master-data-tabs{top:0}
}

.master-data-inline-action{
  margin:10px 0 14px;
  display:flex;
  justify-content:flex-start;
}
