:root {
  --green:      #1D9E75;
  --green-dark: #0F6E56;
  --green-bg:   #E1F5EE;
  --green-text: #085041;
  --blue:       #378ADD;
  --blue-bg:    #E6F1FB;
  --blue-text:  #0C447C;
  --purple:     #7F77DD;
  --purple-bg:  #EEEDFE;
  --purple-text:#3C3489;
  --red:        #E24B4A;
  --red-bg:     #FCEBEB;
  --red-text:   #791F1F;
  --amber:      #EF9F27;
  --amber-bg:   #FAEEDA;
  --amber-text: #633806;
  --coral:      #D85A30;
  --bg:         #F5F5F3;
  --white:      #FFFFFF;
  --border:     rgba(0,0,0,0.08);
  --border-md:  rgba(0,0,0,0.14);
  --text-1:     #1A1A1A;
  --text-2:     #5A5A5A;
  --text-3:     #9A9A9A;
  --radius:     12px;
  --radius-sm:  8px;
  --shadow:     0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body { font-family: 'Prompt', sans-serif; background: var(--bg); color: var(--text-1); min-height: 100vh; -webkit-font-smoothing: antialiased; }
button { font-family: inherit; cursor: pointer; border: none; outline: none; }
button:focus-visible { outline: 2px solid var(--green); outline-offset: 2px; }
select { font-family: inherit; }

/* LOADING */
#loadingScreen { display: none; min-height: 100vh; align-items: center; justify-content: center; flex-direction: column; gap: 16px; }
.spinner { width: 32px; height: 32px; border: 3px solid var(--border-md); border-top-color: var(--green); border-radius: 50%; animation: spin 0.7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.loading-text { font-size: 13px; color: var(--text-2); }

/* SHARED TOPBAR */
.topbar { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,0.94); backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.topbar-inner { max-width: 900px; margin: 0 auto; height: 56px; display: flex; align-items: center; padding: 0 1.5rem; gap: 12px; }
.topbar-logo { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.topbar-logo svg { width: 32px; height: 32px; }
.topbar-brand { font-size: 14px; font-weight: 700; color: var(--text-1); flex: 1; letter-spacing: -0.01em; }
.topbar-divider { width: 1px; height: 20px; background: var(--border-md); flex-shrink: 0; }
.topbar-user { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.user-avatar { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, var(--green), var(--green-dark)); display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: white; flex-shrink: 0; }
.user-name { font-size: 12px; color: var(--text-2); max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.btn-logout { height: 26px; padding: 0 10px; font-size: 11px; color: var(--text-3); background: none; border: 0.5px solid var(--border-md); border-radius: 6px; transition: all 0.1s; }
.btn-logout:hover { background: var(--bg); color: var(--text-2); }
.btn-login { height: 32px; padding: 0 14px; background: #0078D4; color: white; border-radius: 7px; font-size: 12px; font-weight: 600; display: flex; align-items: center; gap: 7px; transition: background 0.15s, box-shadow 0.15s; flex-shrink: 0; box-shadow: 0 1px 3px rgba(0,120,212,0.3); }
.btn-login:hover { background: #006CBE; box-shadow: 0 3px 8px rgba(0,120,212,0.35); }
.btn-login svg { width: 14px; height: 14px; flex-shrink: 0; }
.btn-back { height: 26px; padding: 0 10px; font-size: 11px; color: var(--text-2); background: none; border: 0.5px solid var(--border-md); border-radius: 6px; display: flex; align-items: center; gap: 4px; flex-shrink: 0; transition: background 0.1s; }
.btn-back:hover { background: var(--bg); }
.btn-back svg { width: 12px; height: 12px; }
@media (max-width: 640px) {
  .topbar-inner { padding: 0 0.85rem; gap: 8px; }
  .btn-back-text { display: none; }
  .btn-back { padding: 0 8px; }
  .app-topbar-logo { display: none; }
  .topbar-brand { font-size: 13px; }
  .user-name { display: none; }
  .role-badge { display: none !important; }
  .admin-select { max-width: 100%; }
}

/* PORTAL */
.portal-content { padding: 2.5rem 1.5rem 3rem; max-width: 900px; margin: 0 auto; }
.portal-hero { display: flex; align-items: flex-end; justify-content: space-between; gap: 1rem; margin-bottom: 2.5rem; }
.portal-hero-eyebrow { font-size: 11px; font-weight: 600; color: var(--green); letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
.portal-greeting { font-size: 26px; font-weight: 700; color: var(--text-1); margin-bottom: 6px; letter-spacing: -0.02em; line-height: 1.2; }
.portal-subtitle { font-size: 14px; color: var(--text-2); line-height: 1.5; }
.portal-hero-date { text-align: right; flex-shrink: 0; }
.portal-date-day { font-size: 36px; font-weight: 700; color: var(--text-1); line-height: 1; letter-spacing: -0.03em; }
.portal-date-info { font-size: 12px; color: var(--text-2); margin-top: 4px; }
@media (max-width: 600px) { .portal-hero { flex-direction: column; align-items: flex-start; } .portal-hero-date { text-align: left; } }
#portalError { display: none; background: var(--red-bg); color: var(--red-text); font-size: 12px; padding: 10px 14px; border-radius: var(--radius-sm); margin-bottom: 1.5rem; }
#portalProfile { display: none; margin-bottom: 2rem; }
.profile-card { background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 1.25rem 1.5rem; box-shadow: 0 1px 3px rgba(0,0,0,0.05); display: flex; align-items: center; gap: 1.1rem; }
.profile-photo-wrap { flex-shrink: 0; position: relative; width: 60px; height: 60px; }
.profile-photo { width: 60px; height: 60px; border-radius: 50%; object-fit: cover; display: none; }
.profile-photo-fallback { width: 60px; height: 60px; border-radius: 50%; background: linear-gradient(135deg, var(--green), var(--green-dark)); display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 700; color: white; position: absolute; top: 0; left: 0; }
.profile-info { flex: 1; min-width: 0; }
.profile-name { font-size: 16px; font-weight: 700; color: var(--text-1); letter-spacing: -0.01em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.profile-role { font-size: 13px; color: var(--text-2); margin-top: 2px; margin-bottom: 10px; }
.profile-divider { height: 1px; background: var(--border); margin-bottom: 10px; }
.profile-meta { display: flex; flex-wrap: wrap; gap: 6px 20px; }
.profile-meta-item { display: flex; align-items: center; gap: 5px; font-size: 12px; color: var(--text-2); }
.profile-meta-item svg { width: 13px; height: 13px; color: var(--text-3); flex-shrink: 0; }
@media (max-width: 600px) { .profile-card { flex-direction: column; align-items: flex-start; } }
.portal-section-label { font-size: 11px; font-weight: 600; color: var(--text-3); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 14px; }
.portal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 700px) { .portal-grid { grid-template-columns: 1fr; } }
.portal-card { background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 1.5rem; box-shadow: 0 1px 3px rgba(0,0,0,0.05); cursor: pointer; transition: box-shadow 0.18s, transform 0.14s, border-color 0.18s; display: block; position: relative; overflow: hidden; }
.portal-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; }
.portal-card.card-green::before  { background: var(--green); }
.portal-card.card-blue::before   { background: var(--blue); }
.portal-card.card-purple::before { background: var(--purple); }
.portal-card.card-gray::before   { background: #C8C8C6; }
.portal-card.card-amber::before  { background: var(--amber); }
.portal-card:hover:not(.disabled) { box-shadow: 0 8px 28px rgba(0,0,0,0.1); transform: translateY(-3px); border-color: rgba(0,0,0,0.1); }
.portal-card.disabled { cursor: default; opacity: 0.5; }
.portal-card.disabled:hover { box-shadow: 0 1px 3px rgba(0,0,0,0.05); transform: none; }
.portal-card-icon { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; margin-bottom: 1.1rem; }
.portal-card-icon svg { width: 22px; height: 22px; }
.portal-card-icon.green  { background: var(--green-bg);  color: var(--green-dark); }
.portal-card-icon.blue   { background: var(--blue-bg);   color: var(--blue-text); }
.portal-card-icon.purple { background: var(--purple-bg); color: var(--purple-text); }
.portal-card-icon.gray   { background: #EEEEED; color: var(--text-3); }
.portal-card-icon.amber  { background: var(--amber-bg);  color: var(--amber-text); }
.portal-card-title { font-size: 15px; font-weight: 700; color: var(--text-1); margin-bottom: 5px; letter-spacing: -0.01em; }
.portal-card-desc { font-size: 12px; color: var(--text-2); line-height: 1.6; margin-bottom: 1.5rem; }
.portal-card-footer { display: flex; align-items: center; }
.portal-card-action { font-size: 12px; font-weight: 600; color: var(--green); display: flex; align-items: center; gap: 5px; }
.portal-card-action.blue   { color: var(--blue); }
.portal-card-action.purple { color: var(--purple); }
.portal-card-action.amber  { color: var(--amber); }
.portal-card-action svg { width: 13px; height: 13px; transition: transform 0.15s; }
.portal-card:hover:not(.disabled) .portal-card-action svg { transform: translateX(3px); }
.coming-soon-badge { display: inline-flex; align-items: center; padding: 3px 10px; background: #F0F0EE; color: var(--text-3); border-radius: 20px; font-size: 10px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; }
.portal-section + .portal-section { margin-top: 28px; }
.portal-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
@media (max-width: 700px) { .portal-grid-2 { grid-template-columns: 1fr; } }

/* CALENDAR */
#calendarScreen { display: none; }
.cal-nav { display: flex; align-items: center; justify-content: center; gap: 12px; margin-bottom: 20px; }
.cal-nav-btn { width: 34px; height: 34px; border-radius: 8px; background: var(--white); border: 1px solid var(--border-md); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background 0.15s; }
.cal-nav-btn:hover { background: var(--bg); }
.cal-nav-btn svg { width: 16px; height: 16px; }
.btn-cal-today { font-size: 12px; padding: 5px 12px; border-radius: 6px; border: 1px solid var(--border-md); background: var(--white); color: var(--text-2); cursor: pointer; font-family: inherit; transition: all 0.15s; margin-left: 6px; }
.btn-cal-today:hover { border-color: var(--green); color: var(--green); background: var(--green-bg); }
.cal-month-label { font-size: 16px; font-weight: 600; color: var(--text-1); min-width: 170px; text-align: center; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; margin-bottom: 20px; }
.cal-day-header { background: var(--bg); padding: 8px 4px; text-align: center; font-size: 11px; font-weight: 600; color: var(--text-3); }
.cal-cell { background: var(--white); min-height: 76px; padding: 6px; }
.cal-cell.other-month { background: #fafaf9; }
.cal-cell.today-cell { background: #f0fdf4; }
.cal-cell.cal-cell-holiday { background: #fef2f2; }
.cal-cell.cal-cell-holiday.today-cell { background: #fee2e2; }
.cal-holiday-label { font-size: 9px; padding: 1px 4px; margin-bottom: 2px; border-radius: 3px; background: #fee2e2; color: #b91c1c; font-weight: 600; line-height: 1.3; word-break: break-word; cursor: help; }
.cal-cell-clickable { cursor: pointer; transition: background 0.15s; }
.cal-cell-clickable:hover { background: #f5f5f4; }
.cal-cell-clickable.today-cell:hover { background: #dcfce7; }
.cal-cell-clickable.cal-cell-holiday:hover { background: #fecaca; }
.cal-day-num { font-size: 12px; font-weight: 600; color: var(--text-2); margin-bottom: 3px; width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; border-radius: 50%; }
.cal-day-num.today-num { background: var(--green); color: #fff; font-size: 11px; }
.cal-cell.other-month .cal-day-num { color: var(--text-3); }
.cal-chip { font-size: 10px; padding: 2px 5px; border-radius: 4px; margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 500; display: block; }
.chip-vac  { background: var(--green-bg);  color: var(--green-text); }
.chip-sick { background: var(--blue-bg);   color: var(--blue-text); }
.chip-pers { background: var(--purple-bg); color: var(--purple-text); }
.chip-more { background: #F0F0EE; color: var(--text-3); }
.cal-legend { display: flex; gap: 16px; flex-wrap: wrap; }
.cal-legend-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-2); }
.cal-legend-dot { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; }

.cal-list-section { margin-top: 24px; border-top: 1px solid var(--border); padding-top: 16px; }
.cal-list-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.cal-list-tabs { display: flex; gap: 6px; }
.cal-list-tab { font-size: 12px; padding: 5px 14px; border-radius: 20px; border: 1px solid var(--border-md); background: var(--white); color: var(--text-2); cursor: pointer; user-select: none; transition: all 0.15s; font-family: inherit; }
.cal-list-tab:hover { border-color: var(--green); color: var(--green); }
.cal-list-tab.active { background: var(--green-bg); border-color: var(--green); color: var(--green-text); font-weight: 600; }
.cal-list-count { font-size: 12px; color: var(--text-3); }
.cal-list-empty { font-size: 13px; color: var(--text-3); text-align: center; padding: 24px 0; }
.cal-list-day { margin-bottom: 14px; }
.cal-list-day-label { font-size: 11px; font-weight: 700; color: var(--text-3); letter-spacing: 0.02em; text-transform: uppercase; margin-bottom: 6px; }
.cal-list-row { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border: 1px solid var(--border-lt); border-radius: 8px; margin-bottom: 4px; cursor: pointer; transition: background 0.12s, border-color 0.12s; background: var(--white); }
.cal-list-row:hover { background: var(--bg); border-color: var(--border-md); }
.cal-list-row-name { flex: 1; font-size: 13px; font-weight: 600; color: var(--text-1); }
.cal-list-row-range { font-size: 11px; color: var(--text-3); margin-left: 6px; font-weight: 400; }

@keyframes cal-flash {
  0%, 100% { background: var(--white); }
  30%      { background: #fef3c7; }
}
.cal-cell.cal-flash { animation: cal-flash 1.6s ease; }

@media (max-width: 600px) { .cal-cell { min-height: 54px; padding: 4px 3px; } .cal-chip { font-size: 9px; padding: 1px 4px; } }

/* APP SHELL */
#appScreen { display: none; }
.admin-bar { display: none; align-items: center; gap: 8px; margin-bottom: 0.75rem; }
.admin-bar.visible { display: flex; }
.admin-label { font-size: 13px; color: var(--text-2); white-space: nowrap; }
.admin-select { height: 30px; padding: 0 8px; font-size: 13px; border: 0.5px solid var(--border-md); border-radius: 6px; background: var(--white); color: var(--text-1); max-width: 260px; }
.role-badge { display: none; padding: 1px 7px; border-radius: 8px; font-size: 10px; font-weight: 600; background: var(--purple-bg); color: var(--purple-text); }
.role-badge.visible { display: inline-block; }
.content { padding: 1.25rem; max-width: 900px; margin: 0 auto; }
.year-row { display: flex; align-items: center; gap: 10px; margin-bottom: 1.25rem; }
.year-row label { font-size: 13px; color: var(--text-2); }
.year-select { height: 30px; padding: 0 8px; font-size: 13px; border: 0.5px solid var(--border-md); border-radius: 6px; background: var(--white); color: var(--text-1); }
.year-tag { font-size: 11px; color: var(--text-3); }
.sec-title { font-size: 11px; font-weight: 600; color: var(--text-3); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 10px; }
.cards-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 1.25rem; }
@media (max-width: 900px) { .cards-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .cards-grid { grid-template-columns: 1fr; } }
.quota-card { background: var(--white); border: 0.5px solid var(--border); border-radius: var(--radius); padding: 14px 16px; box-shadow: var(--shadow); }
.card-head { display: flex; align-items: center; gap: 9px; margin-bottom: 10px; }
.card-icon { width: 26px; height: 26px; border-radius: 6px; display: flex; align-items: center; justify-content: center; }
.card-icon svg { width: 15px; height: 15px; }
.card-icon.v { background: var(--green-bg); color: var(--green-dark); }
.card-icon.s { background: var(--blue-bg); color: var(--blue-text); }
.card-icon.p { background: var(--purple-bg); color: var(--purple-text); }
.card-icon.o { background: #EEEEED; color: var(--text-2); }
.card-title { font-size: 13px; font-weight: 600; }
.card-subtitle { font-size: 11px; color: var(--text-3); margin-top: 1px; }
.card-big { font-size: 28px; font-weight: 600; line-height: 1; margin: 4px 0 2px; }
.card-big.green { color: var(--green); }
.card-big.blue  { color: var(--blue); }
.card-big.purple{ color: var(--purple); }
.card-big.red   { color: var(--red); }
.card-remain-lbl { font-size: 11px; color: var(--text-3); margin-bottom: 8px; }
.card-row { display: flex; justify-content: space-between; margin-bottom: 4px; }
.card-row-lbl { font-size: 12px; color: var(--text-2); }
.card-row-val { font-size: 12px; font-weight: 500; }
.card-row-val.used { color: var(--coral); }
.progress-bg { height: 3px; background: #EBEBEB; border-radius: 2px; margin-top: 8px; overflow: hidden; }
.progress-fill { height: 100%; border-radius: 2px; transition: width 0.4s ease; }
.progress-fill.v { background: var(--green); }
.progress-fill.s { background: var(--blue); }
.progress-fill.p { background: var(--purple); }
.progress-fill.over { background: var(--red); }
.detail-box { background: var(--white); border: 0.5px solid var(--border); border-radius: var(--radius); padding: 14px 16px; margin-bottom: 1.25rem; box-shadow: var(--shadow); }
.note-banner { display: flex; align-items: flex-start; gap: 8px; padding: 8px 12px; border-radius: var(--radius-sm); margin-bottom: 10px; font-size: 12px; line-height: 1.55; }
.note-banner.amber { background: var(--amber-bg); color: var(--amber-text); }
.note-banner.green { background: var(--green-bg); color: var(--green-text); }
.note-banner.muted { background: var(--bg); color: var(--text-2); }
.note-banner svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 1px; }
.detail-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--border); border: 0.5px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; }
.detail-cell { background: var(--white); padding: 9px 12px; }
.detail-cell-lbl { font-size: 11px; color: var(--text-3); margin-bottom: 3px; }
.detail-cell-val { font-size: 14px; font-weight: 600; color: var(--text-1); }
.detail-cell-val.used  { color: var(--coral); }
.detail-cell-val.green { color: var(--green); }
.detail-cell-val.red   { color: var(--red); }
.records-box { background: var(--white); border: 0.5px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); overflow: hidden; margin-bottom: 2rem; }
.filter-row { display: flex; gap: 8px; padding: 12px 16px; border-bottom: 0.5px solid var(--border); flex-wrap: wrap; }
.record-chip-row { display: flex; gap: 6px; padding: 12px 16px; border-bottom: 0.5px solid var(--border); flex-wrap: wrap; }
.filter-btn { height: 28px; padding: 0 14px; border-radius: 20px; font-size: 12px; font-weight: 500; background: none; border: 0.5px solid var(--border-md); color: var(--text-2); transition: all 0.15s; }
.filter-btn:hover { background: var(--bg); }
.filter-btn.active-all    { background: #EEEEE9; border-color: rgba(0,0,0,0.2); color: var(--text-1); }
.filter-btn.active-vac    { background: var(--green-bg); border-color: #5DCAA5; color: var(--green-text); }
.filter-btn.active-sick   { background: var(--blue-bg);  border-color: #85B7EB; color: var(--blue-text); }
.filter-btn.active-person { background: var(--purple-bg);border-color: #AFA9EC; color: var(--purple-text); }
.record-item { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 0.5px solid var(--border); transition: background 0.1s; }
.record-item:last-child { border-bottom: none; }
.record-item:hover { background: #FAFAF8; }
.record-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.record-dot.v { background: var(--green); }
.record-dot.s { background: var(--blue); }
.record-dot.p { background: var(--purple); }
.record-date { font-size: 12px; color: var(--text-2); min-width: 130px; }
.record-badge { display: inline-block; padding: 2px 8px; border-radius: 10px; font-size: 11px; font-weight: 600; }
.record-badge.v { background: var(--green-bg); color: var(--green-text); }
.record-badge.s { background: var(--blue-bg);  color: var(--blue-text); }
.record-badge.p { background: var(--purple-bg);color: var(--purple-text); }
.record-days { margin-left: auto; font-size: 13px; font-weight: 600; color: var(--text-1); white-space: nowrap; }
.records-empty { padding: 36px 16px; text-align: center; font-size: 13px; color: var(--text-3); }

/* EXPENSE SCREEN */
#expenseScreen { display: none; }
.exp-tabs { display: flex; gap: 4px; margin-bottom: 20px; border-bottom: 1px solid var(--border); }
.exp-tab { padding: 8px 16px; font-size: 13px; font-weight: 600; cursor: pointer; color: var(--text-3); border-bottom: 2px solid transparent; background: none; border-left: none; border-right: none; border-top: none; }
.exp-tab.active { color: var(--amber); border-bottom: 2px solid var(--amber); }

/* doc type selector */
.exp-doctype-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 4px; }
.exp-doctype-label { display: flex; align-items: flex-start; gap: 12px; padding: 12px 14px; border: 2px solid var(--border-md); border-radius: var(--radius-sm); cursor: pointer; transition: border-color 0.15s, background 0.15s; background: var(--white); }
.exp-doctype-label:has(input:checked) { border-color: var(--green); background: var(--green-bg); }
.exp-doctype-radio { margin-top: 2px; flex-shrink: 0; accent-color: var(--green); width: 16px; height: 16px; cursor: pointer; }
.exp-doctype-title { font-size: 13px; font-weight: 600; color: var(--text-1); margin-bottom: 3px; }
.exp-doctype-desc { font-size: 12px; color: var(--text-2); line-height: 1.55; }
.btn-company-info { margin-top: 8px; font-size: 11px; color: var(--green); background: none; border: 1px solid var(--green); border-radius: 4px; padding: 2px 10px; cursor: pointer; font-family: inherit; white-space: nowrap; }
.btn-company-info:hover { background: var(--green-bg); }
.exp-kx-reminder { font-size: 12px; color: #78350F; background: #FFF7ED; border: 1px solid #FDE68A; border-radius: var(--radius-sm); padding: 9px 12px; margin-top: 4px; margin-bottom: 8px; }
/* doc type badge on card */
.exp-doctype-badge { display: inline-block; font-size: 11px; font-weight: 500; padding: 2px 8px; border-radius: 4px; }
.badge-invoice { background: var(--blue-bg); color: var(--blue-text); }
.badge-cert    { background: #F0F0EE; color: var(--text-3); }
.exp-kx-note { font-size: 11px; color: #78350F; background: #FFF7ED; border-radius: 4px; padding: 5px 9px; margin: 6px 0 2px; }

/* form card */
.exp-form-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; max-width: 560px; box-shadow: var(--shadow); }
.exp-form-card--wide { max-width: 960px; }
.exp-form-title { font-size: 15px; font-weight: 700; color: var(--text-1); margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--border); }
.exp-form { display: flex; flex-direction: column; gap: 16px; }
.exp-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 560px) { .exp-form-row { grid-template-columns: 1fr; } }
.exp-field { display: flex; flex-direction: column; gap: 5px; }
.exp-label { font-size: 12px; font-weight: 600; color: var(--text-2); display: flex; align-items: center; gap: 3px; }
.exp-required { color: var(--amber); font-size: 13px; line-height: 1; }
.exp-input, .exp-select, .exp-textarea {
  width: 100%; padding: 9px 12px; border: 1.5px solid var(--border-md);
  border-radius: var(--radius-sm); font-family: inherit; font-size: 14px;
  background: var(--white); color: var(--text-1);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.exp-input:focus, .exp-select:focus, .exp-textarea:focus {
  outline: none; border-color: var(--amber); box-shadow: 0 0 0 3px var(--amber-bg);
}
.exp-input-wrap { position: relative; }
.exp-input-prefix { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); font-size: 13px; font-weight: 600; color: var(--text-3); pointer-events: none; }
.exp-input-wrap .exp-input { padding-left: 26px; }
.exp-textarea { resize: vertical; min-height: 80px; }
.btn-submit-expense {
  background: var(--amber); color: var(--white); border: none; border-radius: var(--radius-sm);
  padding: 11px 24px; font-size: 14px; font-weight: 600; cursor: pointer;
  font-family: inherit; display: inline-flex; align-items: center; gap: 8px;
  transition: background 0.15s, box-shadow 0.15s; align-self: flex-start;
}
.btn-submit-expense:hover { background: #D88C1A; box-shadow: 0 3px 8px rgba(239,159,39,0.35); }
.btn-submit-expense:disabled { opacity: 0.6; cursor: not-allowed; }
/* filter card */
.exp-filter-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; margin-bottom: 0; display: flex; flex-direction: column; gap: 14px; }
.exp-filter-row { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; }
.exp-filter-field { display: flex; flex-direction: column; gap: 5px; }
.exp-filter-label { font-size: 11px; color: var(--text-3); font-weight: 600; letter-spacing: 0.02em; text-transform: uppercase; }
.exp-filter-divider { height: 1px; background: var(--border); margin: 0 -16px; }
.exp-filter-input { border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 7px 10px; font-size: 13px; font-family: inherit; color: var(--text-1); background: var(--white); outline: none; }
.exp-filter-input:focus { border-color: var(--green); }
.exp-status-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.exp-status-tag { font-size: 12px; padding: 4px 12px; border-radius: 20px; border: 1px solid var(--border-md); background: var(--white); color: var(--text-2); cursor: pointer; user-select: none; transition: all 0.15s; font-family: inherit; }
.exp-status-tag:hover { border-color: var(--green); color: var(--green); }
.exp-status-tag.active { background: var(--green-bg); border-color: var(--green); color: var(--green-text); font-weight: 600; }
.btn-clear-filter { font-size: 12px; color: var(--text-3); background: none; border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 6px 12px; cursor: pointer; font-family: inherit; white-space: nowrap; }
.btn-clear-filter:hover { color: var(--red); border-color: var(--red); }
/* result section */
.exp-result-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 2px 6px; }
.exp-result-title { font-size: 13px; font-weight: 600; color: var(--text-2); }
.exp-result-count { font-size: 12px; color: var(--text-3); }
/* card meta & files */
.exp-card-meta { font-size: 12px; color: var(--text-3); margin-bottom: 8px; margin-top: 2px; }
.exp-files-section { margin: 8px 0; display: flex; flex-direction: column; gap: 6px; padding: 10px 12px; background: var(--bg); border-radius: var(--radius-sm); }
.exp-files-group { display: flex; align-items: flex-start; gap: 8px; min-width: 0; }
.exp-files-label { font-size: 12px; color: var(--text-2); white-space: nowrap; padding-top: 2px; flex-shrink: 0; }
.exp-files-links { display: flex; flex-wrap: wrap; gap: 6px; min-width: 0; flex: 1; }
.exp-request-list { display: flex; flex-direction: column; gap: 10px; }
.exp-request-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; transition: box-shadow 0.3s, border-color 0.3s; }
.exp-card-highlight { animation: exp-highlight 3s ease-out forwards; }
@keyframes exp-highlight { 0% { box-shadow: 0 0 0 3px var(--amber); border-color: var(--amber); } 100% { box-shadow: none; border-color: var(--border); } }
.exp-request-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.exp-request-title { font-size: 14px; font-weight: 600; color: var(--text-1); }
.exp-request-meta { font-size: 12px; color: var(--text-3); margin-bottom: 8px; }
.exp-request-amount { font-size: 18px; font-weight: 700; color: var(--amber); text-align: right; margin-top: 4px; }
.status-badge { display: inline-flex; align-items: center; padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; }
.status-wait   { background: var(--amber-bg);  color: var(--amber-text); }
.status-paid   { background: #E8F5E9; color: #1B5E20; }
.status-return { background: var(--red-bg);    color: var(--red-text); }
.exp-action-row { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.btn-status { padding: 6px 14px; border-radius: var(--radius-sm); font-size: 12px; font-weight: 600; cursor: pointer; border: 1px solid var(--border-md); background: var(--white); font-family: inherit; }
.exp-note { font-size: 12px; color: var(--text-3); font-style: italic; margin-top: 6px; }

/* MODAL */
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); display: flex; align-items: center; justify-content: center; z-index: 500; }
.modal-box { background: var(--white); border-radius: 16px; padding: 24px; width: 90%; max-width: 360px; box-shadow: 0 8px 32px rgba(0,0,0,0.16); }
.modal-title { font-size: 15px; font-weight: 700; color: var(--text-1); margin-bottom: 4px; }
.modal-desc { font-size: 13px; color: var(--text-2); margin-bottom: 12px; }
.modal-textarea { width: 100%; border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 10px 12px; font-family: inherit; font-size: 13px; color: var(--text-1); resize: none; outline: none; background: var(--bg); }
.modal-textarea:focus { border-color: var(--green); }
.modal-actions { display: flex; gap: 8px; margin-top: 16px; justify-content: flex-end; }
.btn-modal-cancel { padding: 8px 16px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 500; background: var(--bg); color: var(--text-2); border: 1px solid var(--border-md); font-family: inherit; cursor: pointer; }
.btn-modal-confirm { padding: 8px 16px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 600; background: var(--red); color: var(--white); border: none; font-family: inherit; cursor: pointer; }

/* FILE UPLOAD */
.exp-upload-area { border: 2px dashed var(--border-md); border-radius: var(--radius-sm); padding: 18px 12px; text-align: center; cursor: pointer; background: var(--bg); display: flex; flex-direction: column; align-items: center; gap: 4px; transition: border-color 0.15s; }
.exp-upload-area:hover { border-color: var(--green); }
.exp-upload-hint { font-size: 11px; color: var(--text-3); }
.exp-file-item { display: flex; align-items: center; gap: 8px; padding: 6px 2px; border-bottom: 1px solid var(--border); font-size: 13px; }
.exp-file-item:last-child { border-bottom: none; }
.exp-file-name { flex: 1; color: var(--text-1); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.exp-file-size { color: var(--text-3); font-size: 11px; flex-shrink: 0; }
.exp-attachments { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.exp-attachment-link { font-size: 12px; color: var(--blue); text-decoration: none; background: var(--blue-bg); padding: 3px 10px; border-radius: 20px; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: inline-block; }
.exp-attachment-link:hover { text-decoration: underline; }

/* multi-item expense form table */
.exp-items-wrap { overflow-x: auto; margin: 0 -4px; }
.exp-items-tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.exp-items-tbl th { text-align: left; padding: 6px 6px; background: var(--bg); font-size: 11px; font-weight: 700; color: var(--text-2); border-bottom: 1px solid var(--border-md); white-space: nowrap; text-transform: uppercase; letter-spacing: 0.03em; }
.exp-items-tbl td { padding: 3px 3px; vertical-align: top; }
.exp-item-row .exp-input, .exp-item-row .exp-select { padding: 7px 8px; font-size: 13px; }
.exp-input-wide { min-width: 160px; }
.exp-input-num { width: 100px; text-align: right; }
.exp-select-sm { min-width: 110px; }
.btn-add-row { margin-top: 10px; background: transparent; border: 1.5px dashed var(--border-md); color: var(--green); font-size: 13px; font-weight: 600; padding: 7px 18px; border-radius: var(--radius-sm); cursor: pointer; font-family: inherit; transition: background 0.15s; }
.btn-add-row:hover { background: var(--green-bg); border-color: var(--green); }
.btn-remove-row { background: none; border: none; color: var(--text-3); cursor: pointer; font-size: 18px; padding: 4px 6px; line-height: 1; border-radius: 4px; font-family: inherit; }
.btn-remove-row:hover { color: var(--red); background: var(--red-bg); }
.exp-total-bar { display: flex; justify-content: flex-end; align-items: baseline; gap: 12px; margin-top: 12px; padding: 10px 14px; background: var(--bg); border-radius: var(--radius-sm); }
.exp-total-label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.exp-total-amount { font-size: 20px; font-weight: 700; color: var(--amber); }

/* line items summary in card */
.exp-items-summary { width: 100%; border-collapse: collapse; font-size: 12px; margin: 6px 0 8px; table-layout: fixed; }
.exp-items-summary td { padding: 4px 6px; vertical-align: middle; }
.exp-items-summary tr:not(:last-child) td { border-bottom: 1px solid var(--border); }
.exp-sum-seq { color: var(--text-3); width: 24px; font-size: 11px; }
.exp-sum-date { color: var(--text-2); white-space: nowrap; width: 92px; }
.exp-sum-cat-col { width: 22%; }
.exp-sum-desc { color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.exp-sum-proj { color: var(--text-3); font-size: 11px; }
.exp-sum-cat { display: inline-block; max-width: 100%; font-size: 10px; font-weight: 500; color: var(--text-2); background: var(--bg); border: 1px solid var(--border-md); border-radius: 4px; padding: 1px 6px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; vertical-align: middle; }
.exp-sum-amt { text-align: right; white-space: nowrap; font-weight: 600; color: var(--text-1); width: 95px; }
@media (max-width: 640px) {
  .exp-sum-date { width: 70px; font-size: 11px; }
  .exp-sum-cat-col { width: 100px; }
  .exp-sum-amt { width: 78px; font-size: 11px; }
}
.exp-item-count-label { font-size: 11px; font-weight: 600; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.03em; margin-bottom: 4px; margin-top: 6px; }

/* mobile: transform expense item table into stacked cards */
@media (max-width: 640px) {
  .exp-items-wrap { overflow-x: visible; }
  .exp-items-tbl,
  .exp-items-tbl tbody { display: block; }
  .exp-items-tbl thead { display: none; }
  .exp-items-tbl tr.exp-item-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px 12px;
    padding: 12px 12px 12px 12px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    margin-bottom: 10px;
    background: var(--white);
    position: relative;
  }
  .exp-items-tbl td {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 0;
    border: none;
    vertical-align: unset;
  }
  .exp-items-tbl td[data-label]::before {
    content: attr(data-label);
    font-size: 11px;
    color: var(--text-3);
    font-weight: 600;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }
  /* รายละเอียด — full width */
  .exp-items-tbl td:nth-child(3) { grid-column: 1 / -1; }
  /* หมายเหตุ — full width */
  .exp-items-tbl td:nth-child(6) { grid-column: 1 / -1; }
  /* delete button — absolute top-right */
  .exp-items-tbl td:nth-child(7) {
    position: absolute;
    top: 8px;
    right: 8px;
    display: block;
  }
  /* make all inputs & selects fill their cell */
  .exp-items-tbl .exp-input,
  .exp-items-tbl .exp-select,
  .exp-items-tbl .exp-input-wide,
  .exp-items-tbl .exp-input-num,
  .exp-items-tbl .exp-select-sm { width: 100%; min-width: 0; text-align: left; }
}

/* ============ LEAVE SYSTEM TABS + FORM ============ */
.lv-tab-nav { display: flex; gap: 4px; margin-bottom: 20px; border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.lv-tab { padding: 8px 16px; font-size: 13px; font-weight: 600; cursor: pointer; color: var(--text-3); border-bottom: 2px solid transparent; background: none; border-left: none; border-right: none; border-top: none; font-family: inherit; }
.lv-tab.active { color: var(--blue); border-bottom: 2px solid var(--blue); }
.lv-tab:hover { color: var(--text-1); }

.lv-form-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.5rem; max-width: 560px; box-shadow: var(--shadow); }
.lv-form-title { font-size: 15px; font-weight: 700; color: var(--text-1); margin-bottom: 1rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--border); }
.lv-form { display: flex; flex-direction: column; gap: 14px; }
.lv-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lv-field { display: flex; flex-direction: column; gap: 5px; }
.lv-field-half { flex: 1; }
.lv-label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.lv-required { color: var(--red); margin-left: 2px; }
.lv-hint { font-size: 11px; color: var(--text-3); font-weight: 400; margin-left: 4px; }
.lv-days-note { font-size: 11px; color: var(--blue-text); margin-top: 6px; line-height: 1.5; }
.lv-days-note:empty { display: none; }
.lv-days-note strong { color: var(--blue-text); }
.lv-input, .lv-select, .lv-textarea {
  border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 8px 12px; font-size: 13px; font-family: inherit; color: var(--text-1); background: var(--white); outline: none; width: 100%;
}
.lv-input:focus, .lv-select:focus, .lv-textarea:focus { border-color: var(--blue); }
.lv-input-num { text-align: right; max-width: 120px; }
.lv-textarea { resize: vertical; min-height: 60px; }
.lv-input:disabled, .lv-input[readonly] { background: var(--bg); color: var(--text-3); }
.lv-radio-group { display: flex; gap: 12px; flex-wrap: wrap; }
.lv-radio-label { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-1); cursor: pointer; padding: 8px 12px; border: 1px solid var(--border-md); border-radius: var(--radius-sm); flex: 1; min-width: 120px; }
.lv-radio-label:hover { border-color: var(--blue); }
.lv-radio-label input[type="radio"] { accent-color: var(--blue); }
.lv-radio-label:has(input:checked) { border-color: var(--blue); background: var(--blue-bg); }

.lv-beta-banner { background: var(--amber-bg); border: 1px solid var(--amber); border-radius: var(--radius-sm); padding: 10px 14px; margin-bottom: 16px; font-size: 12px; color: var(--amber-text); line-height: 1.6; }
.lv-beta-link { color: var(--blue); text-decoration: underline; font-weight: 600; }
.lv-beta-link:hover { color: var(--blue-text); }

.lv-upload-area { border: 1.5px dashed var(--border-md); border-radius: var(--radius-sm); padding: 16px; display: flex; flex-direction: column; align-items: center; gap: 6px; cursor: pointer; transition: border-color 0.15s; background: var(--bg); }
.lv-upload-area:hover { border-color: var(--blue); }
.lv-upload-hint { font-size: 11px; color: var(--text-3); }
.lv-file-item { display: flex; align-items: center; gap: 8px; padding: 6px 10px; border-radius: var(--radius-sm); background: var(--bg); margin-top: 6px; font-size: 12px; }
.lv-file-name { color: var(--text-1); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.lv-file-size { color: var(--text-3); font-size: 11px; }

.btn-submit-leave { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 10px 20px; background: var(--blue); color: var(--white); border-radius: var(--radius-sm); font-size: 13px; font-weight: 600; font-family: inherit; cursor: pointer; border: none; transition: background 0.15s; }
.btn-submit-leave:hover:not(:disabled) { background: var(--blue-text); }
.btn-submit-leave:disabled { opacity: 0.6; cursor: not-allowed; }

/* LEAVE LIST + CARD */
.lv-filter-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; margin-bottom: 16px; display: flex; flex-direction: column; gap: 14px; }
.lv-filter-row { display: flex; align-items: flex-end; gap: 10px; flex-wrap: wrap; }
.lv-filter-field { display: flex; flex-direction: column; gap: 5px; }
.lv-filter-label { font-size: 11px; color: var(--text-3); font-weight: 600; letter-spacing: 0.02em; text-transform: uppercase; }
.lv-filter-divider { height: 1px; background: var(--border); margin: 0 -16px; }
.lv-filter-input { border: 1px solid var(--border-md); border-radius: var(--radius-sm); padding: 7px 10px; font-size: 13px; font-family: inherit; color: var(--text-1); background: var(--white); outline: none; }
.lv-filter-input:focus { border-color: var(--blue); }
.lv-status-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.lv-status-tag { font-size: 12px; padding: 4px 12px; border-radius: 20px; border: 1px solid var(--border-md); background: var(--white); color: var(--text-2); cursor: pointer; user-select: none; font-family: inherit; }
.lv-status-tag:hover { border-color: var(--blue); color: var(--blue); }
.lv-status-tag.active { background: var(--blue-bg); border-color: var(--blue); color: var(--blue-text); font-weight: 600; }

.lv-result-header { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; padding-top: 4px; }
.lv-result-title { font-size: 13px; font-weight: 600; color: var(--text-2); }
.lv-result-count { font-size: 12px; color: var(--text-3); }
.lv-request-list { display: flex; flex-direction: column; gap: 12px; }
.lv-request-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--radius); padding: 14px 16px; box-shadow: var(--shadow); display: flex; flex-direction: column; gap: 8px; transition: box-shadow 0.2s; }
.lv-card-highlight { box-shadow: 0 0 0 2px var(--blue), var(--shadow); animation: lvFlash 1.2s ease-out; }
@keyframes lvFlash { 0% { background: var(--blue-bg); } 100% { background: var(--white); } }
.lv-request-header { display: flex; justify-content: space-between; align-items: center; gap: 8px; flex-wrap: wrap; }
.lv-request-title { font-size: 14px; font-weight: 700; color: var(--text-1); }
.lv-type-chip { font-size: 11px; padding: 2px 8px; border-radius: 10px; background: var(--blue-bg); color: var(--blue-text); font-weight: 600; }
.lv-halfday-badge { font-size: 11px; padding: 2px 8px; border-radius: 10px; background: var(--amber-bg); color: var(--amber-text); font-weight: 600; }
.lv-card-meta { font-size: 12px; color: var(--text-3); }
.lv-request-row { display: flex; gap: 8px; font-size: 12px; align-items: baseline; }
.lv-row-label { color: var(--text-3); min-width: 60px; }
.lv-row-val { color: var(--text-1); flex: 1; }
.lv-card-approver { font-size: 11px; color: var(--text-3); padding-top: 6px; border-top: 1px dashed var(--border); }

.lv-status-badge { font-size: 11px; padding: 3px 10px; border-radius: 12px; font-weight: 600; }
.lv-status-pending  { background: var(--amber-bg);  color: var(--amber-text); }
.lv-status-approved { background: var(--green-bg);  color: var(--green-text); }
.lv-status-rejected { background: var(--red-bg);    color: var(--red-text); }

.lv-files-section { padding-top: 6px; border-top: 1px dashed var(--border); display: flex; flex-direction: column; gap: 4px; }
.lv-files-label { font-size: 11px; color: var(--text-3); font-weight: 600; }
.lv-files-links { display: flex; flex-direction: column; gap: 2px; }
.lv-attachment-link { font-size: 12px; color: var(--blue); text-decoration: none; }
.lv-attachment-link:hover { text-decoration: underline; }

@media (max-width: 600px) {
  .lv-row { grid-template-columns: 1fr; }
  .lv-form-card { padding: 1rem; }
  .lv-radio-label { min-width: 100px; font-size: 12px; padding: 6px 10px; }
}
