:root{
  --primary:#080738;
  --primary2:#15146b;
  --accent:#8b8cff;
  --bg:#f6f7fb;
  --surface:#fff;
  --line:#e6e8f0;
  --text:#101828;
  --muted:#667085;
  --danger:#b42318;
  --success:#067647;
  --warning:#92400e;
  --shadow:0 18px 50px rgba(8,7,56,.12);
}
*{box-sizing:border-box}
body{margin:0;font-family:'Sarabun',sans-serif;background:radial-gradient(circle at top left,rgba(139,140,255,.18),transparent 30%),var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}
.layout{min-height:100vh;display:flex}
.sidebar{width:280px;background:linear-gradient(180deg,#080738,#050421);color:#fff;padding:18px;box-shadow:16px 0 40px rgba(8,7,56,.18)}
.brand{display:flex;gap:12px;align-items:center;padding:12px 6px 22px}
.brand-icon{width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.12);display:grid;place-items:center;font-weight:800}
.brand small{display:block;color:#c9c9ff}
.profile{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:22px;padding:16px;margin-bottom:16px}
.profile small,.profile span{display:block;color:#d7d8ff}
.profile strong{display:block;margin:4px 0}
.sidebar nav{display:grid;gap:6px}
.sidebar nav a{padding:12px 14px;border-radius:14px;color:#ededff}
.sidebar nav a:hover{background:rgba(255,255,255,.12)}
.sidebar nav a.danger{color:#ffb4ab}
.main{flex:1;padding:28px;overflow:auto}
.page-title{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;border-radius:26px;padding:22px 24px;margin-bottom:22px;box-shadow:var(--shadow)}
.page-title h1{margin:0;font-size:28px}
.page-title p{margin:6px 0 0;color:#d7d8ff}
.card{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:24px;box-shadow:0 10px 30px rgba(8,7,56,.08);padding:22px;margin-bottom:18px}
.grid{display:grid;gap:16px}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.stat h2{font-size:36px;margin:8px 0 0;color:var(--primary)}
.stat span{color:var(--muted);font-weight:700}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.full{grid-column:1/-1}
label{display:block;font-weight:700;margin-bottom:6px}
input,select,textarea{width:100%;border:1px solid #d5d9e6;border-radius:14px;padding:12px 14px;font-family:inherit;font-size:15px;background:#fff}
textarea{min-height:110px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary2);box-shadow:0 0 0 4px rgba(8,7,56,.09)}
.btn{border:0;border-radius:14px;padding:11px 16px;font-family:inherit;font-weight:800;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff;box-shadow:0 10px 24px rgba(8,7,56,.22)}
.btn-secondary{background:#fff;color:var(--primary);border:1px solid #d8daeb}
.btn-danger{background:#fef3f2;color:var(--danger);border:1px solid #fecdca}
.actions{display:flex;gap:8px;flex-wrap:wrap}
table{width:100%;border-collapse:separate;border-spacing:0}
th,td{padding:13px 14px;border-bottom:1px solid #edf0f7;text-align:left;vertical-align:top}
th{background:#f6f7ff;color:#34345f;font-weight:800}
tr:hover td{background:#fbfbff}
.badge{display:inline-flex;border:1px solid;border-radius:999px;padding:3px 10px;font-weight:800;font-size:13px}
.badge-Pending{background:#fffbeb;color:var(--warning);border-color:#fde68a}
.badge-Approved{background:#ecfdf3;color:var(--success);border-color:#abefc6}
.badge-Rejected{background:#fef3f2;color:var(--danger);border-color:#fecdca}
.alert{padding:14px 16px;border-radius:16px;margin-bottom:16px}
.alert-error{background:#fef3f2;color:#b42318;border:1px solid #fecdca}
.alert-success{background:#ecfdf3;color:#067647;border:1px solid #abefc6}
.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 20% 20%,rgba(139,140,255,.35),transparent 25%),linear-gradient(135deg,#080738,#050421)}
.login-card{width:min(440px,calc(100% - 30px));background:rgba(255,255,255,.96);border-radius:28px;padding:32px;box-shadow:0 35px 100px rgba(0,0,0,.35)}
.login-logo{width:72px;height:72px;border-radius:24px;background:linear-gradient(135deg,#080738,#23217d);color:#fff;display:grid;place-items:center;margin:0 auto 18px;font-weight:800;font-size:24px}
.files-list{display:grid;gap:8px}
.file-item{display:flex;justify-content:space-between;gap:12px;border:1px solid #e6e8f0;border-radius:14px;padding:10px 12px;background:#fbfbff}
.comment-log{border-left:4px solid var(--primary);padding:12px 14px;background:#fbfbff;border-radius:12px;margin-bottom:10px}
.print-only{display:none}
@media(max-width:900px){.layout{display:block}.sidebar{width:auto}.grid-4{grid-template-columns:repeat(2,1fr)}.form-grid{grid-template-columns:1fr}}
@media print{
  body{background:#fff}
  .sidebar,.no-print,.actions,.btn{display:none!important}
  .layout{display:block}
  .main{padding:0}
  .card,.page-title{box-shadow:none;border:0}
  .page-title{background:#fff;color:#000;padding:0}
  .page-title p{color:#333}
  .print-only{display:block}
}

.attach-choice{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.choice-card{border:1px solid #dfe1ff;border-radius:18px;padding:14px;display:flex;gap:10px;align-items:flex-start;cursor:pointer;background:#fbfbff}
.choice-card small{display:block;color:#667085}
.upload-status{margin-top:10px;padding:12px;border-radius:14px;background:#f5f6ff;border:1px solid #dfe1ff;color:#080738;font-weight:700}
.selected-files{display:grid;gap:8px;margin-top:10px}
.selected-file{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #e6e8f0;border-radius:14px;background:#fff;padding:10px 12px}
.chart-card canvas{max-height:260px}
.signature-box{border:1px dashed #080738;border-radius:16px;padding:14px;background:#fbfbff;margin:8px 0}
.pdf-page{font-family:'Sarabun',sans-serif;color:#111;font-size:14px}
.pdf-header{text-align:center;border-bottom:2px solid #080738;padding-bottom:12px;margin-bottom:16px}

/* Smooth Form & Rich Text */
.smooth-form{padding:0;overflow:hidden}
.form-section{padding:24px;border-bottom:1px solid #edf0f7}
.form-section:last-of-type{border-bottom:0}
.section-title{display:flex;gap:14px;align-items:flex-start;margin-bottom:18px}
.section-title span{width:36px;height:36px;border-radius:14px;background:linear-gradient(135deg,#080738,#23217d);color:#fff;display:grid;place-items:center;font-weight:800;flex:0 0 36px}
.section-title h2{margin:0;color:#080738;font-size:20px}
.section-title p{margin:4px 0 0;color:#667085}
.form-footer{padding:20px 24px;background:#fbfbff;display:flex;gap:10px;justify-content:flex-end}

.rich-editor-wrap{border:1px solid #dfe1ff;border-radius:18px;overflow:hidden;background:#fff}
.toolbar{display:flex;gap:6px;flex-wrap:wrap;padding:10px;background:#f5f6ff;border-bottom:1px solid #dfe1ff}
.toolbar button{border:1px solid #d8daeb;background:#fff;border-radius:10px;padding:7px 10px;font-family:inherit;font-weight:800;cursor:pointer;color:#080738}
.toolbar button:hover{background:#eef0ff}
.toolbar input[type=color]{width:38px;height:34px;padding:3px;border-radius:10px;border:1px solid #d8daeb}
.rich-editor{min-height:150px;padding:14px;outline:none;line-height:1.7}
.rich-editor:empty:before{content:attr(data-placeholder);color:#98a2b3}
.rich-editor ul,.rich-editor ol{padding-left:24px}

.attach-switch{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.attach-card{position:relative;border:1px solid #dfe1ff;border-radius:20px;padding:16px;cursor:pointer;background:#fff;transition:.2s;display:block}
.attach-card input{position:absolute;opacity:0;pointer-events:none}
.attach-card strong{display:block;color:#080738;font-size:16px}
.attach-card small{display:block;color:#667085;margin-top:4px;line-height:1.35}
.attach-card:hover,.attach-card.active{border-color:#080738;box-shadow:0 12px 30px rgba(8,7,56,.10);background:linear-gradient(180deg,#fff,#f7f7ff)}
.attach-card.active:after{content:"✓";position:absolute;right:14px;top:12px;width:24px;height:24px;border-radius:999px;background:#080738;color:#fff;display:grid;place-items:center;font-weight:800}
.attach-panel{margin-top:16px;border:1px solid #dfe1ff;border-radius:20px;padding:16px;background:#fbfbff}
.upload-status{margin-top:10px;padding:12px;border-radius:14px;background:#f5f6ff;border:1px solid #dfe1ff;color:#080738;font-weight:700}
.selected-files{display:grid;gap:8px;margin-top:10px}
.selected-file{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid #e6e8f0;border-radius:14px;background:#fff;padding:10px 12px}
.selected-file small{color:#667085}
.rich-content{line-height:1.75}
.rich-content p{margin:0 0 8px}
.rich-content ul,.rich-content ol{padding-left:24px}
@media(max-width:900px){.attach-switch{grid-template-columns:1fr}.form-footer{flex-direction:column}.form-footer .btn{width:100%}}

/* Colorful Dashboard + Table Tools */
.dashboard-hero{
  background:
    radial-gradient(circle at 15% 20%,rgba(139,140,255,.35),transparent 28%),
    radial-gradient(circle at 85% 10%,rgba(6,118,71,.20),transparent 24%),
    linear-gradient(135deg,#080738 0%,#15146b 58%,#2b1d85 100%);
}
.stat{position:relative;overflow:hidden}
.stat:after{content:"";position:absolute;right:-28px;top:-28px;width:110px;height:110px;border-radius:999px;background:rgba(255,255,255,.38)}
.stat-blue{background:linear-gradient(135deg,#ffffff,#f1f2ff)}
.stat-amber{background:linear-gradient(135deg,#fff7ed,#ffffff)}
.stat-green{background:linear-gradient(135deg,#ecfdf3,#ffffff)}
.stat-red{background:linear-gradient(135deg,#fef3f2,#ffffff)}
.stat-purple{background:linear-gradient(135deg,#f5f3ff,#ffffff)}
.stat-icon{width:42px;height:42px;border-radius:16px;display:grid;place-items:center;color:#fff;font-weight:900;margin-bottom:8px}
.bg-navy{background:#080738}.bg-amber{background:#d97706}.bg-green{background:#067647}.bg-red{background:#b42318}.bg-purple{background:#6d28d9}

.table-toolbar{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap}
.table-search{max-width:360px}
.table-meta{color:#667085;font-weight:700}
.sortable th{cursor:pointer;user-select:none}
.sortable th:hover{color:#080738}
.pivot-controls{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}
.pivot-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.pivot-summary .card{margin-bottom:0}
.chart-row{display:grid;grid-template-columns:1.5fr 1fr;gap:18px}
.donut-wrap{display:grid;place-items:center;min-height:260px}
@media(max-width:900px){.pivot-controls,.pivot-summary,.chart-row{grid-template-columns:1fr}.table-toolbar{align-items:stretch}.table-search{max-width:100%}}

/* Structured layout + animation */
.card,.page-title{animation:fadeSlideUp .35s ease both}
.animated-card{animation:fadeSlideUp .45s ease both}
@keyframes fadeSlideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.main{scroll-behavior:smooth}
table.sortable th.sort-asc:after{content:" ▲";font-size:11px;color:#080738}
table.sortable th.sort-desc:after{content:" ▼";font-size:11px;color:#080738}
.table-search{border:1px solid #dfe1ff;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23667085' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E") no-repeat 12px center;padding-left:42px}
.flow-step-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.flow-step-card{border:1px solid #dfe1ff;border-radius:18px;padding:14px;background:#fff;display:flex;gap:10px;align-items:flex-start;cursor:pointer;transition:.2s}
.flow-step-card:hover{border-color:#080738;box-shadow:0 12px 28px rgba(8,7,56,.10);transform:translateY(-1px)}
.flow-step-card small{display:block;color:#667085}
.admin-step{background:linear-gradient(180deg,#f7f7ff,#fff);border-color:#080738}
@media(max-width:900px){.flow-step-grid{grid-template-columns:1fr}}

/* Typography + table usability refinements */
body{font-size:15.5px;line-height:1.6}
.page-title h1{font-size:clamp(24px,2.2vw,32px);letter-spacing:-.02em}
.page-title p{font-size:15px}
.card h2{font-size:20px;letter-spacing:-.01em;color:#080738;margin-top:0}
.card h3{font-size:17px;color:#080738}
table{font-size:14.5px}
th{font-size:13.5px;text-transform:none;letter-spacing:.01em}
td{font-size:14.5px}
.table-toolbar{background:#fbfbff;border:1px solid #edf0f7;border-radius:18px;padding:12px}
.table-search{height:44px;font-size:14.5px}
.table-meta{font-size:14px}
.actions .btn, td .btn{padding:8px 12px;font-size:13.5px}
.badge{font-size:12.5px;padding:4px 10px}
.sortable th{position:relative;padding-right:28px}
.sortable th:not([data-no-sort="1"])::before{content:"↕";position:absolute;right:10px;color:#98a2b3;font-size:12px}
.sortable th.sort-asc::before,.sortable th.sort-desc::before{content:"";display:none}
.chart-card canvas,#statusDonut{width:100%}
.stat h2{letter-spacing:-.04em}
.stat span{font-size:14.5px}
@media(max-width:900px){body{font-size:15px}.main{padding:18px}table{font-size:13.5px}td,th{padding:10px}}

/* Notifications, better overview tables, typography */
.notify-banner{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#fff7ed,#fff);border:1px solid #fed7aa;color:#92400e;box-shadow:0 10px 26px rgba(217,119,6,.12);animation:fadeSlideUp .3s ease both}
.notify-banner a{background:#080738;color:#fff;padding:8px 12px;border-radius:12px;font-weight:800}
.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;margin-left:6px;border-radius:999px;background:#ef4444;color:#fff;font-size:12px;font-weight:800}
.chart-tooltip{position:fixed;z-index:99999;pointer-events:none;background:#080738;color:#fff;border-radius:12px;padding:8px 10px;font-size:13px;box-shadow:0 14px 35px rgba(8,7,56,.25);opacity:0;transition:opacity .12s}
.card table{border-radius:18px;overflow:hidden}
.card table thead th{background:linear-gradient(180deg,#f8f8ff,#f1f2ff);color:#080738;border-bottom:1px solid #dfe1ff}
.card table tbody tr:nth-child(even) td{background:#fcfcff}
.card table tbody tr:hover td{background:#f5f6ff}
.table-toolbar{box-shadow:inset 0 0 0 1px rgba(8,7,56,.03)}
td:first-child,th:first-child{padding-left:18px}
td:last-child,th:last-child{padding-right:18px}
body{font-size:16px}
.sidebar nav a{font-size:15px}
.profile strong{font-size:16px}
.profile span{font-size:13px}

.grouped-nav{display:grid;gap:16px}.nav-heading{font-size:12px;color:#bfc1ff;text-transform:uppercase;margin:8px 10px 4px;font-weight:800}.profile-avatar{width:58px;height:58px;border-radius:20px;object-fit:cover;margin-bottom:10px;background:rgba(255,255,255,.12);display:grid;place-items:center;font-weight:900}.profile-avatar.placeholder{color:#fff}.profile-large{width:120px;height:120px;border-radius:34px;object-fit:cover;box-shadow:0 15px 40px rgba(8,7,56,.18)}.modal{position:fixed;inset:0;background:rgba(8,7,56,.55);display:none;align-items:flex-start;justify-content:center;padding:30px;z-index:9999;overflow:auto}.modal.show{display:flex}.modal-card{width:min(920px,100%)}.show-on-edit.show{display:flex}.crop-box{background:#fbfbff;border:1px solid #dfe1ff;padding:12px;border-radius:18px;margin-top:8px}.badge-Draft{background:#f5f3ff;color:#6d28d9;border-color:#ddd6fe}.badge-Cancelled{background:#f2f4f7;color:#475467;border-color:#d0d5dd}.badge-Returned,.badge-Recalled{background:#eff8ff;color:#175cd3;border-color:#b2ddff}.badge-ลับ,.secret-badge{background:#fef3f2;color:#b42318}

/* Classic ordered menu with configurable group headings */
.classic-nav{display:grid;gap:5px}
.classic-nav a{padding:12px 14px;border-radius:14px;color:#ededff;display:flex;align-items:center;justify-content:space-between}
.classic-nav a:hover{background:rgba(255,255,255,.12)}
.classic-nav a.danger{color:#ffb4ab}
.grouped-nav{display:none}
.nav-heading{font-size:11px;color:#bfc1ff;text-transform:uppercase;margin:14px 10px 4px;font-weight:800;letter-spacing:.06em}

/* Social profile */
.social-profile{animation:fadeSlideUp .32s ease both}
.profile-cover{height:190px;border-radius:30px;background:radial-gradient(circle at 20% 20%,rgba(139,140,255,.45),transparent 30%),linear-gradient(135deg,#080738,#23217d 55%,#6d28d9);box-shadow:0 20px 60px rgba(8,7,56,.18)}
.profile-main-card{display:flex;align-items:flex-end;gap:22px;background:#fff;border:1px solid #e6e8f0;border-radius:28px;padding:0 24px 24px;margin:-68px 20px 18px;position:relative;box-shadow:0 16px 40px rgba(8,7,56,.10)}
.profile-photo-wrap{padding:6px;background:#fff;border-radius:34px;margin-top:-34px}
.social-avatar{width:132px;height:132px;border-radius:30px;object-fit:cover;display:grid;place-items:center;background:#080738;color:#fff;font-size:46px;font-weight:900}
.social-info h1{margin:0;color:#080738;font-size:30px;letter-spacing:-.03em}
.social-info p{margin:4px 0;color:#344054;font-weight:800}
.social-info span{color:#667085}
.profile-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:0 20px 18px}
.profile-content-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:18px;margin:0 20px}
.profile-list{display:grid;gap:12px}
.profile-list div{padding:12px 14px;border:1px solid #edf0f7;border-radius:16px;background:#fbfbff}
.profile-list b{display:block;color:#080738}
.profile-list span{display:block;color:#475467;margin-top:3px}

/* Faster smoother popup */
.modal{transition:opacity .12s ease, transform .12s ease;animation:none}
.modal.show{animation:modalFadeFast .12s ease both}
.modal-card{animation:modalCardFast .14s cubic-bezier(.2,.8,.2,1) both}
@keyframes modalFadeFast{from{opacity:0}to{opacity:1}}
@keyframes modalCardFast{from{opacity:0;transform:translateY(6px) scale(.992)}to{opacity:1;transform:translateY(0) scale(1)}}

.toolbar button{transition:background .1s ease, transform .1s ease}
.toolbar button:active{transform:scale(.97)}
@media(max-width:900px){.profile-main-card{display:block;text-align:center}.profile-stat-grid,.profile-content-grid{grid-template-columns:1fr}.social-avatar{margin:auto}}

.brand-logo{width:46px;height:46px;border-radius:16px;object-fit:cover;background:#fff}.menu-label-wrap{display:flex;align-items:center;gap:8px}.menu-icon{width:20px;height:20px;border-radius:6px;object-fit:cover}.menu-icon-preview{width:34px;height:34px;border-radius:10px;object-fit:cover;display:block;margin-bottom:6px}.copyright-footer{text-align:center;color:#667085;font-size:13px;padding:22px}.category-badge{display:inline-flex;align-items:center;border:1px solid;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:900;margin-left:5px;vertical-align:middle}input[type=color]{min-height:42px}.external-consent{font-weight:800}

.material-icon{font-family:'Material Symbols Rounded';font-weight:normal;font-style:normal;font-size:20px;line-height:1;vertical-align:middle}
.pin-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(8,7,56,.55);z-index:100000;backdrop-filter:blur(8px)}
.pin-modal.show{display:flex;animation:modalFadeFast .12s ease both}.pin-card{width:min(380px,calc(100% - 30px));background:#fff;border-radius:26px;padding:24px;box-shadow:0 30px 90px rgba(0,0,0,.28)}.pin-card h2{color:#080738;margin:0}.pin-card input{font-size:28px;text-align:center;letter-spacing:8px;font-weight:800}.lock-page{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#080738,#050421)}.lock-card{width:min(480px,calc(100% - 30px));background:#fff;border-radius:30px;padding:34px;text-align:center;box-shadow:0 35px 100px rgba(0,0,0,.35)}.lock-icon{width:72px;height:72px;border-radius:999px;background:#b42318;color:#fff;display:grid;place-items:center;font-size:42px;font-weight:900;margin:0 auto 16px}
.app-group-title{font-weight:900;color:#080738;font-size:20px;margin:18px 4px 12px}.app-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.app-card{background:#fff;border:1px solid #e6e8f0;border-radius:26px;padding:18px;display:flex;gap:14px;align-items:center;box-shadow:0 12px 28px rgba(8,7,56,.08);transition:.16s}.app-card:hover{transform:translateY(-3px);box-shadow:0 20px 42px rgba(8,7,56,.14)}.app-logo{width:62px;height:62px;border-radius:20px;background:#f5f6ff;display:grid;place-items:center;flex:0 0 62px}.app-logo img{width:62px;height:62px;border-radius:20px;object-fit:cover}.app-logo span{font-weight:900;color:#080738;font-size:24px}.app-card h2{font-size:17px;margin:0;color:#080738}.app-card p{font-size:13px;color:#667085;margin:4px 0 0}.role-check-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.orbis-login{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 50% 20%,rgba(139,140,255,.24),transparent 28%),linear-gradient(135deg,#080738,#050421);background-size:cover;background-position:center;font-family:'Sarabun',sans-serif}.orbis-panel{width:min(460px,calc(100% - 34px));text-align:center;color:#fff}.orbis-logo{width:112px;height:112px;border-radius:32px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;margin:0 auto 24px;font-weight:900;font-size:34px;box-shadow:0 25px 80px rgba(0,0,0,.25)}.orbis-logo img{width:100%;height:100%;object-fit:cover;border-radius:32px}.orbis-panel h2{font-size:18px;letter-spacing:.18em;margin:0 0 8px;color:#d7d8ff}.orbis-panel h1{font-size:34px;margin:0 0 6px}.orbis-panel p{color:#d7d8ff}.orbis-panel form{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);border-radius:28px;padding:22px;backdrop-filter:blur(16px);display:grid;gap:12px}.orbis-panel input{background:rgba(255,255,255,.96)}.forgot-link{display:inline-block;color:#d7d8ff;margin-top:14px}
@media(max-width:1100px){.app-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:700px){.app-grid,.role-check-grid{grid-template-columns:1fr}}

.pin-card .actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.pin-card .btn{width:100%;min-height:44px}.pin-card p{color:#667085;margin-top:4px}.announcement-list{display:grid;gap:10px}.announcement-item{border:1px solid #edf0f7;border-left-width:6px;border-radius:18px;padding:14px;background:#fff;display:flex;justify-content:space-between;gap:14px}.announcement-item b{color:#080738}.announcement-item p{margin:5px 0;color:#475467}.announcement-item small{color:#667085}.announcement-item span{display:inline-flex;margin-left:8px;border-radius:999px;padding:2px 8px;font-size:12px;font-weight:800}.announcement-item.read{opacity:.72}.announcement-item.unread{box-shadow:0 10px 28px rgba(8,7,56,.08)}.realtime-toast{position:fixed;right:20px;bottom:20px;background:#080738;color:#fff;border-radius:18px;padding:14px 18px;font-weight:800;box-shadow:0 20px 60px rgba(8,7,56,.3);z-index:99999;opacity:0;transform:translateY(10px);transition:.2s}.realtime-toast.show{opacity:1;transform:translateY(0)}

.confirm-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(8,7,56,.55);z-index:100001;backdrop-filter:blur(8px)}.confirm-modal.show{display:flex}.confirm-card{width:min(420px,calc(100% - 30px));background:#fff;border-radius:26px;padding:24px;box-shadow:0 30px 90px rgba(0,0,0,.28)}.confirm-card h2{color:#080738;margin:0}.confirm-card p{color:#667085}.confirm-card .actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.announcement-page-grid{display:grid;gap:12px}.announcement-full-item{border:1px solid #edf0f7;border-left-width:7px;border-radius:22px;background:#fff;padding:18px;display:grid;grid-template-columns:1fr auto;gap:14px}.announcement-level-badge{display:inline-flex;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:900;margin-left:6px}.dashboard-popup-modal{position:fixed;inset:0;background:rgba(8,7,56,.66);display:none;align-items:center;justify-content:center;z-index:99998;backdrop-filter:blur(10px)}.dashboard-popup-modal.show{display:flex}.dashboard-popup-card{width:min(860px,calc(100% - 32px));background:#fff;border-radius:30px;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,.35)}.dashboard-popup-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}.dashboard-popup-content{padding:18px 22px;display:flex;justify-content:space-between;gap:12px;align-items:center}.sound-preview{display:flex;align-items:center;gap:10px}

.pagination{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:18px;flex-wrap:wrap}.page-num{min-width:38px;height:38px;border:1px solid #dfe1ff;border-radius:12px;display:grid;place-items:center;color:#080738;font-weight:800;background:#fff}.page-num.active{background:#080738;color:#fff}.page-ellipsis{color:#667085;padding:0 6px}.modal .form-grid{margin-top:8px}.modal-card{max-height:calc(100vh - 60px);overflow:auto}.actions{gap:10px}.btn{white-space:nowrap}.btn-danger,.classic-nav a.danger{background:#b42318!important;color:#fff!important;border-color:#b42318!important;box-shadow:0 10px 22px rgba(180,35,24,.20)}.org-info-row{border:1px solid #edf0f7;border-radius:16px;background:#fbfbff;padding:10px 12px;margin-bottom:8px}.org-info-row b{display:block;color:#080738}.org-info-row span{color:#475467}.language-switcher{display:flex;justify-content:flex-end;gap:8px;margin-bottom:12px}.language-switcher a{border:1px solid #dfe1ff;background:#fff;border-radius:999px;padding:7px 12px;font-weight:800}.language-switcher a.active{background:#080738;color:#fff}.announcement-full-item h2{margin:0 0 6px;color:#080738;font-size:19px}

/* Requested V3 refinements */
.classic-nav a.active{
  background:rgba(255,255,255,.18);
  box-shadow:inset 4px 0 0 #fff;
  color:#fff;
  font-weight:900;
}

.dashboard-grid-reordered{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-top:22px;
}

.dashboard-grid-reordered .card{
  margin-bottom:0;
}

.pager-actions{
  justify-content:center;
  margin-top:14px;
  min-height:38px;
}

.chart-row{
  gap:22px;
  margin-bottom:22px;
}

.grid{
  gap:18px;
}

.card{
  margin-bottom:22px;
}

.page-title{
  margin-bottom:24px;
}

.app-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}

.app-card{
  height:116px;
  min-height:116px;
  overflow:hidden;
}

.app-card h2{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
  font-size:16px;
  margin-bottom:3px;
}

.app-card p{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
  line-height:1.4;
}

.role-check-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  padding:12px;
  border:1px solid #edf0f7;
  border-radius:18px;
  background:#fbfbff;
}

.role-check-grid label{
  background:#fff;
  border:1px solid #e6e8f0;
  border-radius:14px;
  padding:10px 12px;
  margin:0;
}

.form-grid{
  gap:18px;
}

.actions{
  gap:12px;
}

.btn{
  margin:2px;
}

.org-info-block,
.login-history-block{
  height:100%;
}

.btn-danger,
.classic-nav a.danger{
  background:#b42318!important;
  color:#fff!important;
  border-color:#b42318!important;
  box-shadow:0 10px 22px rgba(180,35,24,.20);
}

@media(max-width:1100px){
  .dashboard-grid-reordered{grid-template-columns:1fr}
  .app-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:700px){
  .app-grid,
  .role-check-grid{grid-template-columns:1fr}
}

/* Hosting-safe final UI fixes */
.classic-nav a.active{
  background:rgba(255,255,255,.18);
  box-shadow:inset 4px 0 0 #fff;
  color:#fff;
  font-weight:900;
}

.dashboard-grid-reordered{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-top:22px;
}

.dashboard-grid-reordered .card{
  margin-bottom:0;
}

.pager-actions{
  justify-content:center;
  margin-top:14px;
  min-height:38px;
}

.chart-row{
  gap:22px;
  margin-bottom:22px;
}

.card{
  margin-bottom:22px;
}

.page-title{
  margin-bottom:24px;
}

.app-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:18px;
}

.app-card{
  height:116px;
  min-height:116px;
  overflow:hidden;
}

.app-card h2{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
  font-size:16px;
  margin-bottom:3px;
}

.app-card p{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:100%;
  line-height:1.4;
}

.role-check-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  padding:12px;
  border:1px solid #edf0f7;
  border-radius:18px;
  background:#fbfbff;
}

.role-check-grid label{
  background:#fff;
  border:1px solid #e6e8f0;
  border-radius:14px;
  padding:10px 12px;
  margin:0;
}

.actions{
  gap:12px;
}

.btn{
  margin:2px;
}

.btn-danger,
.classic-nav a.danger{
  background:#b42318!important;
  color:#fff!important;
  border-color:#b42318!important;
  box-shadow:0 10px 22px rgba(180,35,24,.20);
}

@media(max-width:1100px){
  .dashboard-grid-reordered{grid-template-columns:1fr}
  .app-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:700px){
  .app-grid,
  .role-check-grid{grid-template-columns:1fr}
}

.pin-required-notice{border-left:6px solid #b42318;font-weight:800}

/* Upload status */
.upload-status{
  margin-top:8px;
  padding:9px 12px;
  border-radius:14px;
  background:#f2f4f7;
  color:#667085;
  font-weight:700;
  font-size:13px;
}
.upload-status.done{
  background:#ecfdf3;
  color:#067647;
  border:1px solid #abefc6;
}
.upload-box{
  border:1px solid #edf0f7;
  background:#fbfbff;
  border-radius:18px;
  padding:14px;
}
.profile-preview-existing{
  width:84px;
  height:84px;
  border-radius:22px;
  object-fit:cover;
  display:block;
  margin-bottom:10px;
}
.table-avatar{
  width:42px;
  height:42px;
  border-radius:14px;
  object-fit:cover;
  display:grid;
  place-items:center;
  background:#080738;
  color:#fff;
  font-weight:900;
}

/* Internal app text ellipsis */
.app-card h2,
.app-card p{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Smooth sidebar */
.sidebar{
  transition:width .22s ease, transform .22s ease, opacity .18s ease;
}
.main{
  transition:margin-left .22s ease, padding .22s ease;
}
.sidebar-toggle{
  width:38px;
  height:38px;
  border:0;
  border-radius:12px;
  background:rgba(255,255,255,.12);
  color:#fff;
  cursor:pointer;
  font-size:18px;
  margin-bottom:12px;
}
body.sidebar-collapsed .sidebar{
  width:76px;
}
body.sidebar-collapsed .brand b,
body.sidebar-collapsed .brand small,
body.sidebar-collapsed .profile,
body.sidebar-collapsed .nav-heading,
body.sidebar-collapsed .classic-nav a .menu-label-wrap,
body.sidebar-collapsed .classic-nav a:not(.danger){
  overflow:hidden;
}
body.sidebar-collapsed .brand div:not(.brand-icon),
body.sidebar-collapsed .profile strong,
body.sidebar-collapsed .profile span,
body.sidebar-collapsed .nav-heading,
body.sidebar-collapsed .classic-nav a span:not(.material-icon):not(.nav-badge){
  display:none!important;
}
body.sidebar-collapsed .classic-nav a{
  justify-content:center;
  padding:12px 8px;
}
.hamburger-btn{
  display:none;
  position:fixed;
  top:14px;
  left:14px;
  z-index:10001;
  width:44px;
  height:44px;
  border:0;
  border-radius:14px;
  background:#080738;
  color:#fff;
  font-size:22px;
  box-shadow:0 14px 34px rgba(8,7,56,.25);
}
.sidebar-overlay{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(8,7,56,.45);
  z-index:9998;
  opacity:0;
  transition:opacity .2s ease;
}
@media(max-width:900px){
  .hamburger-btn{display:block}
  .sidebar{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    z-index:9999;
    transform:translateX(-105%);
    width:286px!important;
    opacity:.98;
  }
  body.sidebar-mobile-open .sidebar{
    transform:translateX(0);
  }
  body.sidebar-mobile-open .sidebar-overlay{
    display:block;
    opacity:1;
  }
  .main{
    margin-left:0!important;
    padding-top:70px;
  }
  body.sidebar-collapsed .sidebar{
    width:286px!important;
  }
  body.sidebar-collapsed .brand div:not(.brand-icon),
  body.sidebar-collapsed .profile strong,
  body.sidebar-collapsed .profile span,
  body.sidebar-collapsed .nav-heading,
  body.sidebar-collapsed .classic-nav a span:not(.material-icon):not(.nav-badge){
    display:initial!important;
  }
}
.modal-header-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}

/* Removed sidebar toggle and hamburger; keep responsive layout stable */
.sidebar-toggle,.hamburger-btn,.sidebar-overlay{display:none!important}
body.sidebar-collapsed .sidebar{width:var(--sidebar-width, 280px)!important}
body.sidebar-collapsed .brand div:not(.brand-icon),
body.sidebar-collapsed .profile strong,
body.sidebar-collapsed .profile span,
body.sidebar-collapsed .nav-heading,
body.sidebar-collapsed .classic-nav a span:not(.material-icon):not(.nav-badge){display:initial!important}
body.sidebar-collapsed .classic-nav a{justify-content:flex-start!important;padding:12px 14px!important}

/* Responsive Web base */
img,video,canvas,svg{max-width:100%;height:auto}
.table-responsive{width:100%;overflow-x:auto}
@media(max-width:1024px){
  .layout{display:block}
  .sidebar{position:relative!important;width:100%!important;min-height:auto!important;transform:none!important}
  .main{margin-left:0!important;padding:18px!important}
  .classic-nav{grid-template-columns:repeat(2,minmax(0,1fr));display:grid}
  .profile{display:none}
  .brand{margin-bottom:12px}
}
@media(max-width:640px){
  .classic-nav{grid-template-columns:1fr}
  .form-grid,.dashboard-grid-reordered,.chart-row,.grid{grid-template-columns:1fr!important}
  .card{padding:16px!important;border-radius:20px!important}
  table{min-width:760px}
  .actions{flex-wrap:wrap}
}

/* HRM UI */
.hrm-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.hrm-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.hrm-person-card{border:1px solid #e6e8f0;border-radius:24px;background:#fff;padding:16px;box-shadow:0 12px 28px rgba(8,7,56,.08);display:grid;gap:12px}
.hrm-person-head{display:flex;gap:12px;align-items:center}
.hrm-avatar-small{width:58px;height:58px;border-radius:14px;object-fit:cover;background:#f2f4f7;border:1px solid #d0d5dd;display:grid;place-items:center;font-weight:900;color:#080738;flex:0 0 58px}
.hrm-person-meta h3{margin:0;color:#080738;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hrm-person-meta p{margin:2px 0;color:#667085;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hrm-badge{display:inline-flex;border-radius:999px;background:#f5f6ff;color:#080738;padding:4px 10px;font-size:12px;font-weight:800}
.hrm-actions{display:flex;gap:8px;flex-wrap:wrap}
.hrm-profile-photo{width:110px;height:110px;border-radius:24px;object-fit:cover;border:1px solid #d0d5dd;background:#f2f4f7;display:grid;place-items:center;font-weight:900;color:#080738;font-size:38px}
.hrm-profile-layout{display:grid;grid-template-columns:150px 1fr;gap:20px;align-items:start}
.print-date{font-size:13px;color:#667085;margin-top:4px}
@media(max-width:1000px){.hrm-card-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.hrm-card-grid,.hrm-profile-layout{grid-template-columns:1fr}.hrm-profile-photo{width:96px;height:96px}}
@media print{
  .sidebar,.no-print,.actions,.btn,.table-toolbar{display:none!important}
  .main{margin:0!important;padding:0!important}
  .card{box-shadow:none!important;border:0!important}
}

/* HRM requested final polish */
.table-avatar{
  width:46px!important;
  height:46px!important;
  border-radius:12px!important;
  object-fit:cover!important;
  border:1px solid #dfe1ff!important;
  background:#f5f6ff!important;
  color:#080738!important;
  box-shadow:0 6px 16px rgba(8,7,56,.10);
}

.form-section-title{
  display:flex;
  align-items:center;
  gap:12px;
  margin:18px 0 12px;
  padding:14px;
  border-radius:18px;
  background:linear-gradient(135deg,#f8f8ff,#fff);
  border:1px solid #e6e8f0;
}
.form-section-title span{
  width:34px;
  height:34px;
  border-radius:12px;
  display:grid;
  place-items:center;
  background:#080738;
  color:#fff;
  font-weight:900;
}
.form-section-title b{
  color:#080738;
  display:block;
}
.form-section-title small{
  color:#667085;
}
.modal-card form > .form-grid{
  padding:2px 4px 8px;
}
.modal-card input,
.modal-card select,
.modal-card textarea{
  min-height:44px;
}
.modal-card label{
  font-weight:800;
  color:#080738;
}

/* Professional resume */
.resume-sheet{
  background:#fff;
  border-radius:30px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(8,7,56,.14);
  border:1px solid #e6e8f0;
}
.resume-header{
  display:grid;
  grid-template-columns:170px 1fr;
  gap:24px;
  align-items:center;
  padding:34px;
  background:
    radial-gradient(circle at 10% 20%,rgba(255,255,255,.18),transparent 24%),
    linear-gradient(135deg,#080738,#25247d);
  color:#fff;
}
.resume-photo{
  width:138px;
  height:138px;
  border-radius:30px;
  object-fit:cover;
  border:5px solid rgba(255,255,255,.28);
  background:#fff;
  display:grid;
  place-items:center;
  color:#080738;
  font-size:44px;
  font-weight:900;
}
.resume-label{
  font-size:12px;
  letter-spacing:.18em;
  opacity:.78;
  font-weight:900;
}
.resume-title h1{
  margin:4px 0 2px;
  font-size:34px;
  letter-spacing:-.03em;
}
.resume-title h2{
  margin:0;
  font-size:19px;
  font-weight:700;
  opacity:.92;
}
.resume-tags{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:14px;
}
.resume-tags span{
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  padding:6px 12px;
  border-radius:999px;
  font-weight:800;
}
.resume-body{
  display:grid;
  grid-template-columns:280px 1fr;
}
.resume-sidebar{
  background:#fbfbff;
  border-right:1px solid #edf0f7;
  padding:26px;
}
.resume-sidebar section,
.resume-section{
  margin-bottom:24px;
}
.resume-sidebar h3,
.resume-section h3{
  color:#080738;
  font-size:17px;
  margin:0 0 14px;
  padding-bottom:8px;
  border-bottom:2px solid #edf0f7;
}
.resume-sidebar p{
  color:#475467;
  line-height:1.6;
}
.resume-main{
  padding:26px;
}
.resume-info-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.resume-info-grid div{
  border:1px solid #edf0f7;
  background:#fff;
  border-radius:18px;
  padding:14px;
}
.resume-info-grid .wide{
  grid-column:1/-1;
}
.resume-info-grid b{
  display:block;
  color:#080738;
  margin-bottom:4px;
}
.resume-info-grid span{
  color:#475467;
}
.resume-file-list{
  display:grid;
  gap:10px;
}
.resume-file-list a{
  padding:12px 14px;
  border:1px solid #edf0f7;
  border-radius:16px;
  background:#fbfbff;
}
.resume-file-list small{
  display:block;
  color:#667085;
  margin-top:3px;
}
.muted{color:#667085}

@media(max-width:800px){
  .resume-header,.resume-body{grid-template-columns:1fr}
  .resume-sidebar{border-right:0;border-bottom:1px solid #edf0f7}
  .resume-info-grid{grid-template-columns:1fr}
}
@media print{
  body{background:#fff!important}
  .resume-sheet{box-shadow:none!important;border:0!important;border-radius:0!important}
  .resume-header{background:#080738!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .resume-body{grid-template-columns:240px 1fr}
  .resume-info-grid{grid-template-columns:repeat(2,1fr)}
}

.signature-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.signature-card{
  border:1px solid #dfe1ff;
  background:linear-gradient(135deg,#fbfbff,#fff);
  border-radius:20px;
  padding:16px;
  box-shadow:0 10px 24px rgba(8,7,56,.08);
}
.signature-card b{
  display:block;
  color:#080738;
  font-size:17px;
}
.signature-card span{
  display:block;
  color:#475467;
  margin-top:2px;
}
.signature-card small{
  display:block;
  color:#667085;
  margin-top:8px;
}
.signature-card code{
  display:inline-block;
  margin-top:10px;
  background:#f2f4f7;
  border-radius:10px;
  padding:5px 8px;
  font-size:12px;
}
@media(max-width:900px){.signature-grid{grid-template-columns:1fr}}

.alert-success{
  padding:12px 14px;
  border-radius:16px;
  background:#ecfdf3;
  color:#067647;
  border:1px solid #abefc6;
  margin-bottom:14px;
  font-weight:800;
}
.approval-form textarea{
  min-height:110px;
}
.approval-actions{
  margin-top:14px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.approval-panel{
  border:1px solid #dfe1ff;
  background:linear-gradient(135deg,#ffffff,#fbfbff);
}
.approval-panel .muted{
  color:#667085;
  margin-top:-4px;
}
.approval-form textarea{
  width:100%;
  min-height:130px;
  resize:vertical;
}
.approval-actions{
  margin-top:14px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.pin-error{
  min-height:22px;
  margin-top:8px;
  color:#b42318;
  font-weight:800;
  text-align:center;
}
#documentPinModal.pin-modal.show{
  display:flex;
}

/* document-pin-modal-fix */
#documentPinModal{
  z-index:200000!important;
  pointer-events:auto!important;
}
#documentPinModal .pin-card{
  pointer-events:auto!important;
}
#documentPinConfirmBtn:disabled{
  opacity:.65;
  cursor:not-allowed;
}
.doc-pin-success{
  position:relative;
  z-index:20;
}

/* Smooth INV PIN modal */
.invpin-smooth-modal{backdrop-filter:blur(12px)}
.invpin-smooth-card{max-width:430px;animation:invpinPop .16s cubic-bezier(.2,.8,.2,1)}
.invpin-icon{width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,#080738,#25247d);color:#fff;display:grid;place-items:center;font-size:28px;margin:0 auto 12px;box-shadow:0 16px 34px rgba(8,7,56,.25)}
.invpin-smooth-card h2,.invpin-smooth-card p{text-align:center}
.invpin-smooth-card input[name="pin"]{letter-spacing:10px;font-size:28px;text-align:center;font-weight:900}
.invpin-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:12px!important;margin-top:16px}
.invpin-progress{height:6px;background:#edf0f7;border-radius:999px;overflow:hidden;margin-top:12px}
.invpin-progress span{display:block;width:40%;height:100%;border-radius:999px;background:#080738;animation:invpinLoading 1s ease-in-out infinite}
@keyframes invpinLoading{0%{transform:translateX(-110%)}100%{transform:translateX(260%)}}
@keyframes invpinPop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Attendance module */
.attendance-page{display:grid;gap:22px}
.attendance-hero{display:flex;justify-content:space-between;align-items:center;gap:18px;background:linear-gradient(135deg,#fff,#f7f7ff)}
.attendance-hero h2{margin:0;color:#080738;font-size:28px}
.attendance-hero p{margin:6px 0 0;color:#667085}
.att-clock{text-align:right;font-size:42px;font-weight:900;color:#080738;letter-spacing:1px}
.att-date{text-align:right;color:#667085}
.att-stamp-card{text-align:center}
.att-actions-main{display:flex;justify-content:center;gap:18px;flex-wrap:wrap}
.btn-lg{font-size:18px;padding:14px 32px;border-radius:18px}
.att-message{margin-top:14px;font-weight:800}
.att-message.ok{color:#067647}.att-message.bad{color:#b42318}
.att-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.att-tabs button{border:1px solid #d0d5dd;background:#fff;color:#080738;border-radius:999px;padding:10px 16px;font-weight:800;cursor:pointer}
.att-tabs button.active,.att-tabs button:hover{background:#080738;color:#fff}
.modal.show{display:flex!important}
@media(max-width:700px){.attendance-hero{display:block}.att-clock,.att-date{text-align:left;margin-top:12px}.att-actions-main .btn{width:100%}}

/* Attendance request detail + INV PIN */
.att-pin-card{max-width:420px;text-align:center}
.att-pin-card input{font-size:28px;text-align:center;letter-spacing:10px;font-weight:900}
.att-detail-card{max-width:760px}
.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.detail-grid>div{border:1px solid #edf0f7;border-radius:16px;padding:12px;background:#fbfbff}
.detail-grid .full{grid-column:1/-1}
.detail-grid b{display:block;color:#080738;margin-bottom:4px}
.detail-grid span{color:#475467;word-break:break-word}
.pin-error{min-height:22px;color:#b42318;font-weight:800;margin-top:8px}
@media(max-width:700px){.detail-grid{grid-template-columns:1fr}}

/* Download Center + modern request detail */
.download-toolbar{display:flex;gap:12px;justify-content:space-between;align-items:center;margin-bottom:18px;flex-wrap:wrap}.download-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.download-card{border:1px solid #e6e8f0;border-radius:24px;padding:18px;background:linear-gradient(135deg,#fff,#fbfbff);box-shadow:0 12px 28px rgba(8,7,56,.08);display:flex;flex-direction:column;justify-content:space-between;gap:14px}.download-card span{display:inline-block;background:#f5f6ff;color:#080738;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:900}.download-card h3{margin:10px 0 4px;color:#080738;font-size:18px}.download-card p{color:#667085;min-height:42px}.stat-row{border:1px solid #edf0f7;border-radius:16px;padding:12px;margin-bottom:8px;background:#fbfbff}.stat-row b{display:block;color:#080738}.stat-row span{color:#667085}.request-detail-hero{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:16px;border-radius:20px;background:linear-gradient(135deg,#080738,#25247d);color:#fff;margin-bottom:14px}.request-detail-hero small{display:block;opacity:.75}.request-detail-hero b{font-size:18px}.request-status{border-radius:999px;padding:8px 12px;font-weight:900;background:#fff;color:#080738}.request-status.ok{color:#067647}.request-status.bad{color:#b42318}.request-status.wait{color:#92400e}.detail-grid.modern>div{box-shadow:0 8px 20px rgba(8,7,56,.05)}.pin-modal.show{display:flex!important}@media(max-width:1000px){.download-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.download-grid{grid-template-columns:1fr}}

/* Final unified INV PIN */
.pin-modal{position:fixed;inset:0;background:rgba(8,7,56,.48);display:none;align-items:center;justify-content:center;z-index:200000;padding:18px;backdrop-filter:blur(10px)}
.pin-modal.show{display:flex!important}
.pin-card{width:min(430px,100%);background:#fff;border-radius:28px;padding:28px;box-shadow:0 28px 90px rgba(8,7,56,.28);text-align:center;animation:pinPop .16s ease}
.pin-card h2{margin:6px 0;color:#080738}.pin-card p{color:#667085}
.pin-card input[type=password]{width:100%;box-sizing:border-box;border:1px solid #d0d5dd;border-radius:18px;padding:14px 16px;font-size:28px;text-align:center;letter-spacing:10px;font-weight:900;color:#080738}
.invpin-lock{width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,#080738,#25247d);display:grid;place-items:center;margin:0 auto 12px;font-size:28px;box-shadow:0 16px 34px rgba(8,7,56,.25)}
.pin-error{min-height:22px;color:#b42318;font-weight:800;margin-top:8px}.pin-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}
.pin-progress{height:6px;background:#edf0f7;border-radius:999px;overflow:hidden;margin-top:12px}.pin-progress span{display:block;width:40%;height:100%;background:#080738;border-radius:999px;animation:pinLoading 1s ease-in-out infinite}
@keyframes pinLoading{0%{transform:translateX(-110%)}100%{transform:translateX(260%)}}@keyframes pinPop{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

.sound-enable-banner{
  background:#fffbeb;
  border:1px solid #fedf89;
  border-radius:18px;
  padding:10px 12px;
  margin-bottom:14px;
  display:flex;
  justify-content:flex-end;
}
.realtime-toast{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:999999;
  background:#080738;
  color:#fff;
  border-radius:18px;
  padding:14px 18px;
  box-shadow:0 18px 50px rgba(8,7,56,.25);
  font-weight:800;
  opacity:0;
  transform:translateY(10px);
  transition:.18s ease;
}
.realtime-toast.show{opacity:1;transform:translateY(0)}
.nav-badge:empty{display:none}

/* Dashboard circular expanded after removing login history */
.dashboard-grid-reordered{
  align-items:stretch;
}
.circular-expanded-block{
  grid-column:span 1;
  min-height:360px;
}
.circular-expanded-block .announcement-list{
  min-height:260px;
}
@media(min-width:900px){
  .dashboard-grid-reordered{
    grid-template-columns:1fr 1fr;
  }
  .circular-expanded-block{
    grid-column:span 1;
  }
}

/* FAQ */
.faq-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.faq-card{border:1px solid #e6e8f0;border-radius:24px;padding:18px;background:linear-gradient(135deg,#fff,#fbfbff);box-shadow:0 12px 28px rgba(8,7,56,.08);display:flex;flex-direction:column;gap:10px}
.faq-card-head{display:flex;justify-content:space-between;gap:8px}.faq-card-head span,.faq-card-head small{background:#f5f6ff;color:#080738;border-radius:999px;padding:4px 10px;font-weight:900;font-size:12px}
.faq-card h3{margin:4px 0;color:#080738}.faq-card p{color:#667085;min-height:60px}.faq-meta{color:#475467;font-size:13px}.faq-tags{display:flex;flex-wrap:wrap;gap:6px}.faq-tags b{background:#ecfdf3;color:#067647;border-radius:999px;padding:4px 8px;font-size:12px}
.faq-detail-card{max-width:860px}
select[multiple]{min-height:120px}
@media(max-width:1000px){.faq-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.faq-grid{grid-template-columns:1fr}}

/* Multi Role / Department checkbox selector */
.multi-check-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  max-height:260px;
  overflow:auto;
  padding:10px;
  border:1px solid #e6e8f0;
  border-radius:18px;
  background:#fbfbff;
}
.check-card{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px;
  border:1px solid #e6e8f0;
  border-radius:16px;
  background:#fff;
  cursor:pointer;
  transition:.16s ease;
}
.check-card:hover{
  border-color:#080738;
  box-shadow:0 8px 18px rgba(8,7,56,.08);
  transform:translateY(-1px);
}
.check-card input{
  width:18px;
  height:18px;
  accent-color:#080738;
}
.check-card span{
  color:#080738;
  font-weight:800;
  line-height:1.25;
}
.check-card small{
  display:block;
  color:#667085;
  font-weight:600;
  margin-top:2px;
}
.field-help{
  display:block;
  color:#667085;
  font-weight:600;
  margin-top:3px;
}
@media(max-width:700px){
  .multi-check-grid{grid-template-columns:1fr}
}
