:root{
  --uv-blau:#0D52A0;
  --uv-dunkel:#133478;
  --uv-rot:#E4003C;
  --uv-gelb:#FFE400;
  --uv-schwarz:#1D1D1B;
  --uv-blau-hell:#E8F1FA;
  --grau-hell:#F4F6F8;
  --line:#E5E7EB;
  --muted:#6B7280;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","SF Pro Display",Arial,sans-serif;
  background:var(--grau-hell);
  color:var(--uv-schwarz);
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.staging-banner{
  min-height:36px;
  padding:8px 18px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:12px;
  background:#facc15;
  color:#111827;
  border-bottom:2px solid #b45309;
  font-size:13px;
  font-weight:800;
  letter-spacing:0;
  text-align:center;
  position:relative;
  z-index:100;
  box-shadow:0 2px 10px rgba(0,0,0,.14);
}
.staging-banner strong{
  background:#111827;
  color:#fff;
  border-radius:4px;
  padding:3px 8px;
  font-size:12px;
}
.staging-banner span{font-weight:800}
.staging-banner em{
  font-style:normal;
  color:#7c2d12;
  font-weight:900;
}
.staging-banner-login{
  position:fixed;
  top:0;
  left:0;
  right:0;
}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#c1c7d0;border-radius:3px}
.page-fade-in{animation:fadeIn .2s ease-in-out}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}

.app-frame{height:100vh;display:flex;overflow:hidden;background:var(--grau-hell)}
.env-staging .app-frame{height:calc(100vh - 36px)}
.sidebar{
  width:220px;
  flex-shrink:0;
  background:#fff;
  border-right:1px solid var(--line);
  display:flex;
  flex-direction:column;
}
.brand{
  height:73px;
  padding:16px 20px;
  border-bottom:1px solid #F3F4F6;
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
}
.brand:hover{background:#F8FAFC}
.brand img{height:36px;width:auto;object-fit:contain}
.brand strong{font-size:14px;line-height:1.05;color:var(--uv-dunkel)}
.sidebar nav{flex:1;padding:12px 0;overflow:auto}
.sidebar nav a,
.nav-heading{
  min-height:40px;
  display:flex;
  align-items:center;
  padding:10px 20px;
  color:#4B5563;
  font-size:14px;
  transition:background .15s,color .15s,border .15s;
}
.sidebar nav a{text-decoration:none}
.sidebar nav a span{width:20px;text-align:center;color:#6B7280}
.sidebar nav a:hover,
.nav-heading:hover{background:#EEF2F7;color:var(--uv-schwarz)}
.sidebar nav a:hover span,
.nav-heading:hover .nav-icon{color:var(--uv-blau)}
.sidebar nav a.active{
  background:var(--uv-blau-hell);
  color:var(--uv-blau);
  font-weight:700;
  border-right:2px solid var(--uv-blau);
}
.sidebar nav a.active span{color:var(--uv-blau)}
.nav-group{margin:4px 0}
.nav-heading{
  width:100%;
  border:0;
  background:transparent;
  gap:9px;
  color:#374151;
  font-size:12px;
  font-weight:800;
  letter-spacing:0;
  text-align:left;
  border-radius:0;
}
.nav-heading .nav-icon{width:20px;text-align:center;color:#6B7280;flex:0 0 20px}
.nav-heading .nav-label{min-width:0;flex:1;letter-spacing:.08em}
.nav-heading em{
  margin-left:auto;
  font-style:normal;
  color:#9CA3AF;
  font-size:18px;
  line-height:1;
  transition:transform .15s,color .15s;
}
.nav-group.is-open .nav-heading{background:#F8FAFC;color:#111827}
.nav-group.is-open .nav-heading em{transform:rotate(90deg);color:var(--uv-blau)}
.nav-children{
  display:none;
  margin-left:30px;
  padding:2px 0 5px;
  border-left:2px solid #D1D5DB;
}
.nav-group.is-open .nav-children{display:block}
.sidebar nav a.nav-child{
  min-height:34px;
  padding:8px 14px 8px 12px;
  margin-left:0;
  font-size:14px;
}
.sidebar nav a.nav-child.active{border-right:2px solid var(--uv-blau)}
.sidebar nav a.nav-child span{width:18px}
.sidebar-user{
  border-top:1px solid #F3F4F6;
  padding:13px 16px;
  display:grid;
  grid-template-columns:32px 1fr;
  gap:9px;
  align-items:center;
}
.avatar{
  width:32px;height:32px;border-radius:999px;background:var(--uv-blau);
  color:#fff;display:grid;place-items:center;font-size:12px;font-weight:800;
}
.sidebar-user strong{display:block;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user span{display:block;font-size:12px;color:#9CA3AF}
.logout{grid-column:1/-1;color:#6B7280;text-decoration:none;font-size:12px;padding-top:4px}
.logout:hover{color:var(--uv-rot)}

.main-area{min-width:0;flex:1;display:flex;flex-direction:column;overflow:hidden}
.mobile-header{display:none}
.app-header{
  height:56px;
  background:linear-gradient(90deg,var(--uv-dunkel),var(--uv-blau));
  color:#fff;
  display:flex;
  align-items:center;
  gap:14px;
  padding:0 24px;
  flex-shrink:0;
}
.app-header img{height:28px;width:auto;object-fit:contain;opacity:.95}
.app-header strong{font-size:15px}
.app-version{margin-left:8px;border:1px solid rgba(255,255,255,.35);border-radius:999px;padding:2px 7px;font-size:11px;color:rgba(255,255,255,.86);font-weight:700}
.header-user{margin-left:auto;font-size:14px;color:rgba(255,255,255,.82)}
.yellow-line{height:2px;background:var(--uv-gelb);flex-shrink:0}
.content{flex:1;overflow:auto;padding:24px}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.topbar h1{margin:0;color:var(--uv-schwarz);font-size:22px;font-weight:800}
.topbar p{margin:4px 0 0;color:#6B7280;font-size:14px}

.grid{display:grid;gap:16px}
.two{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}
.leave-page{grid-template-columns:minmax(0,650px) minmax(0,1fr);align-items:start}
.leave-card{max-width:650px}
.leave-table-card{min-height:420px}
.cards{grid-template-columns:repeat(6,minmax(0,1fr))}
.stats{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  background:#fff;
  border:0;
  border-radius:10px;
  padding:20px;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
}
.card h2{margin:0 0 14px;font-size:18px;color:var(--uv-schwarz)}
.card h3{margin:14px 0 0;color:var(--uv-schwarz)}
.tile{
  min-height:128px;
  text-decoration:none;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  gap:12px;
  text-align:left;
  transition:box-shadow .15s,transform .15s;
}
.tile:hover{box-shadow:0 4px 16px rgba(0,0,0,.12);transform:translateY(-1px)}
.tile b{font-size:14px;color:var(--uv-schwarz)}
.tile-icon{
  width:40px;height:40px;border-radius:8px;display:grid;place-items:center;
  color:#fff;font-size:14px;font-weight:800;
}
.tile-icon.blue{background:var(--uv-blau)}
.tile-icon.cyan{background:#0891b2}
.tile-icon.red{background:var(--uv-rot)}
.tile-icon.green{background:#16a34a}
.tile-icon.amber{background:#f59e0b;color:#1D1D1B}
.tile-icon.dark{background:var(--uv-dunkel)}
.tile-icon.slate{background:#475569}
.muted{color:#6B7280}.small{font-size:13px}
.field-hint{margin:5px 0 0;color:#A8B0BD;font-size:12px;line-height:1.35}
.receipt-ocr-box{
  border:1px solid #DBEAFE;
  background:#F8FAFC;
  border-radius:8px;
  padding:12px;
}
.receipt-file-input{max-width:360px}
.receipt-status-ok{color:#15803D}
.receipt-status-error{color:var(--uv-rot)}
.calendar-import-box{
  border:1px solid #D1FAE5;
  background:#F8FAFC;
  border-radius:8px;
  padding:12px;
}
.calendar-suggestion-list{display:grid;gap:8px;margin-top:10px}
.calendar-suggestion{
  width:100%;
  border:1px solid #E5E7EB;
  background:#fff;
  border-radius:8px;
  padding:9px 11px;
  text-align:left;
  display:grid;
  gap:3px;
}
.calendar-suggestion strong{font-size:13px;color:var(--uv-schwarz)}
.calendar-suggestion span{font-size:12px;color:#6B7280}
.calendar-suggestion em{font-style:normal;font-size:11px;color:#047857;font-weight:700}
.calendar-suggestion.is-applied{border-color:#A7F3D0;background:#F0FDF4}
[hidden],.is-hidden,.special-reason-field.is-hidden{display:none!important}

.btn{
  border:1px solid #E5E7EB;
  border-radius:8px;
  background:#fff;
  color:var(--uv-schwarz);
  padding:9px 14px;
  min-height:38px;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  gap:7px;
  font-size:14px;
  font-weight:600;
  transition:background .15s,color .15s,border .15s;
}
.btn:hover{background:#F9FAFB}
.btn.primary{border-color:var(--uv-blau);background:var(--uv-blau);color:#fff}
.btn.primary:hover{background:var(--uv-dunkel)}
.btn.success{border-color:#16A34A;background:#16A34A;color:#fff}
.btn.success:hover{background:#15803D}
.btn.danger{border-color:var(--uv-rot);background:var(--uv-rot);color:#fff}
.btn.danger:hover{background:#b91c1c}
.btn.small{min-height:30px;padding:5px 9px;font-size:12px;border-radius:6px}
.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.no-wrap{flex-wrap:nowrap}
.travel-admin-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.travel-admin-actions form{display:inline-flex}
.travel-admin-table .travel-claim-main td{border-bottom:0;padding-bottom:4px}
.travel-admin-table .travel-claim-actions-row td{padding-top:0;padding-bottom:14px}
.travel-admin-table tr.travel-row-alt td{background:#EAF2FC}
.travel-admin-table tr.travel-row-plain td{background:#fff}
.travel-admin-table .travel-claim-actions-row:hover td,
.travel-admin-table .travel-claim-main:hover td{background:#DBEAFE}
.travel-admin-table .travel-admin-actions{padding-top:2px}
.travel-admin-detail-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.section-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.section-title-row h2{margin-bottom:2px}
.admin-travel-meta{grid-template-columns:repeat(3,minmax(0,1fr))}
.admin-travel-meta span{display:block;color:#6B7280;font-size:12px;margin-top:3px}
.cost-lines{font-size:12px;color:#4B5563;line-height:1.45}
.admin-travel-totals{max-width:760px;margin-left:auto}
.rejection-toggle{justify-self:start;color:#6B7280}
.rejection-box{display:grid;gap:10px;background:#F9FAFB;border:1px solid #E5E7EB;border-radius:8px;padding:12px}
.rejection-box.is-collapsed{display:none}
.rejection-box .textarea{background:#fff;min-height:74px}
.rejection-box .btn{justify-self:start}
.sick-close-form{min-width:180px}
.sick-entry-form .child-field-hidden{display:none}
.sick-action-stack{display:grid;gap:8px;min-width:220px}
.sick-button-row{display:flex;gap:6px;flex-wrap:wrap}
.sick-button-row form{display:inline-flex}
.form-actions{display:flex;gap:10px;align-items:center;justify-content:flex-start}
.form-actions .btn{width:auto}
.profile-actions{justify-content:space-between;border-top:1px solid #F3F4F6;padding-top:12px}

.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}
.leave-form-grid,.date-form-grid,.travel-form-grid{grid-template-columns:1fr;align-items:start;position:relative}
.leave-form-grid .date-side,.date-form-grid .date-side{grid-column:1;align-self:start}
.leave-form-grid .full,.date-form-grid .full{grid-column:1}
.field{display:grid;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:14px;font-weight:600;color:#374151}
.required{color:var(--uv-rot)}
.label-row{display:flex;align-items:center;justify-content:space-between}
.char-count{font-size:12px;color:#9CA3AF}
.char-count.warning{color:#D97706;font-weight:800}
.input,.select,.textarea{
  width:100%;
  border:1px solid #D1D5DB;
  border-radius:8px;
  background:#fff;
  color:var(--uv-schwarz);
  padding:9px 11px;
  min-height:38px;
  font-size:14px;
  outline:none;
}
.input:focus,.select:focus,.textarea:focus{border-color:transparent;box-shadow:0 0 0 2px var(--uv-blau)}
.textarea{min-height:86px;resize:vertical}
.uppercase-input{text-transform:uppercase}
.money-input{position:relative}
.money-input .input{padding-right:34px}
.money-input span{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:#6B7280;font-weight:700}
.input.compact,.select.compact{min-height:30px;padding:5px 7px;font-size:12px;border-radius:6px;margin:2px 0}
.color-input{padding:2px;max-width:48px}
.check-row{display:flex;align-items:center;gap:8px;font-size:13px;color:#4B5563}
.check-row.compact{font-size:12px;margin-top:4px}

.uv-datepicker{position:relative}
.datepicker-display{
  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='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 2v4'/%3E%3Cpath d='M16 2v4'/%3E%3Crect width='18' height='18' x='3' y='4' rx='2'/%3E%3Cpath d='M3 10h18'/%3E%3C/svg%3E") no-repeat right 10px center;
  padding-right:38px;
}
.datepicker-popover{
  display:none;
  position:absolute;
  z-index:50;
  top:calc(100% + 6px);
  left:0;
  width:292px;
  background:#fff;
  border:1px solid #D1D5DB;
  border-radius:10px;
  padding:12px;
  box-shadow:0 16px 36px rgba(0,0,0,.16);
}
.datepicker-popover.open{display:block}
.datepicker-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.datepicker-head strong{font-size:14px;color:var(--uv-schwarz)}
.datepicker-head button{
  width:28px;height:28px;border:0;border-radius:6px;background:#fff;color:#4B5563;font-size:20px;font-weight:800;
}
.datepicker-head button:hover{background:#F3F4F6;color:var(--uv-blau)}
.datepicker-weekdays,.datepicker-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.datepicker-weekdays span{font-size:12px;color:#6B7280;text-align:center;font-weight:700;padding:4px 0}
.datepicker-days button{
  height:30px;border:0;border-radius:6px;background:#fff;color:var(--uv-schwarz);font-size:12px;
}
.datepicker-days button:hover{background:var(--uv-blau-hell);color:var(--uv-blau)}
.datepicker-days button.weekend{color:#C1C7D0}
.datepicker-days button.today{box-shadow:inset 0 0 0 1px var(--uv-blau);font-weight:800}
.datepicker-days button.selected{background:var(--uv-blau);color:#fff;font-weight:800}
.datepicker-legend{display:flex;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid #F3F4F6;color:#6B7280;font-size:11px}
.datepicker-legend b{color:#F97316}
.uv-range-input{position:relative}
.uv-range-input.active .range-display{border-color:transparent;box-shadow:0 0 0 2px var(--uv-blau)}
.range-helper{font-size:13px;color:var(--uv-blau);margin:0 0 10px}
.range-calendar-popup{
  display:none;
  position:static;
  z-index:70;
  width:min(520px,100%);
  margin-top:-2px;
}
.range-calendar-popup.open{display:block}
.range-calendar-box{
  background:#fff;
  border:1px solid #E5E7EB;
  border-radius:10px;
  padding:14px 18px 14px;
  box-shadow:0 18px 42px rgba(0,0,0,.16);
}
.range-calendar-box .datepicker-head{margin-bottom:14px}
.range-calendar-box .datepicker-head strong{font-size:17px}
.range-days{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  row-gap:6px;
}
.range-days button{
  height:34px;
  border:0;
  background:#fff;
  color:var(--uv-schwarz);
  font-size:14px;
  position:relative;
  z-index:1;
}
.range-days button:hover{background:var(--uv-blau-hell);color:var(--uv-blau);border-radius:8px}
.range-days button.weekend{color:#D1D5DB}
.range-days button.today{box-shadow:inset 0 0 0 1px var(--uv-blau);border-radius:8px;font-weight:700}
.range-days button.in-range{background:var(--uv-blau-hell);color:var(--uv-blau)}
.range-days button.range-start,
.range-days button.range-end{
  background:var(--uv-blau);
  color:#fff;
  font-weight:800;
}
.range-days button.range-start{border-radius:999px 0 0 999px}
.range-days button.range-end{border-radius:0 999px 999px 0}
.range-days button.same-day{border-radius:999px}
.monthpicker-popover{width:292px}
.monthpicker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.monthpicker-grid button{
  border:0;
  border-radius:7px;
  background:#fff;
  color:var(--uv-schwarz);
  min-height:34px;
  font-size:12px;
  font-weight:700;
}
.monthpicker-grid button:hover{background:var(--uv-blau-hell);color:var(--uv-blau)}
.monthpicker-grid button.selected{background:var(--uv-blau);color:#fff}

.table-wrap{overflow:hidden}
.employee-table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse;min-width:0;font-size:14px;table-layout:auto}
th,td{padding:10px 14px;border-bottom:1px solid #F3F4F6;text-align:left;vertical-align:top}
th{background:var(--uv-blau);color:#fff;font-weight:700}
.table-wrap .btn{min-height:34px;padding:7px 10px}
.table-wrap td:last-child{width:1%;white-space:normal}
.travel-items-table{table-layout:fixed}
.travel-items-table th:nth-child(1){width:110px}
.travel-items-table th:nth-child(4){width:90px}
.travel-items-table th:nth-child(5){width:90px}
.travel-items-table th:nth-child(6){width:110px}
.travel-item-actions{display:grid;gap:6px;align-items:start;width:98px}
.travel-item-actions form{margin:0}
.action-link{border:0;background:transparent;padding:0;margin:0;font:inherit;font-weight:800;text-align:left;text-decoration:none;cursor:pointer}
.action-link.edit{color:var(--uv-blau)}
.action-link.delete{color:var(--uv-rot)}
.action-link:hover{text-decoration:underline}
tbody tr:nth-child(even){background:var(--uv-blau-hell)}
tbody tr:hover{background:#DBEAFE}
tbody tr.row-alert{background:#FFF1F2}
.mini-form{display:grid;gap:6px;min-width:170px}
.employee-edit-table{min-width:980px}
.badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:4px 9px;
  font-size:12px;
  font-weight:800;
  background:#E5E7EB;
}
.PENDING,.SUBMITTED{background:#FEF3C7;color:#92400E}
.APPROVED,.PAID{background:#DCFCE7;color:#166534}
.REVIEWED{background:#DCFCE7;color:#166534}
.REJECTED{background:#FEE2E2;color:#991B1B}
.NEUTRAL{background:#E5E7EB;color:#374151}
.WITHDRAWN{background:#E5E7EB;color:#374151}
.notice{border-left:4px solid var(--uv-gelb);background:#fff}
.leave-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  background:var(--uv-blau-hell);
  border-radius:10px;
  padding:14px;
}
.leave-stats span{display:block;font-size:12px;color:#6B7280;margin-bottom:4px}
.leave-stats strong{display:block;font-size:26px;color:var(--uv-blau);line-height:1}
.leave-stats strong.negative{color:var(--uv-rot)}
.leave-stats small{display:block;font-size:11px;color:#9CA3AF;margin-top:4px}
.form-error{background:#FEF2F2;border:1px solid #FECACA;color:#B91C1C;border-radius:8px;padding:11px 13px;font-size:14px}
.form-success{background:#ECFDF5;border:1px solid #A7F3D0;color:#047857;border-radius:8px;padding:11px 13px;font-size:14px}
.form-warning{background:#FFFBEB;border:1px solid #FDE68A;color:#92400E;border-radius:8px;padding:11px 13px;font-size:14px}
.admin-list{display:grid;gap:8px}
.admin-row{display:grid;grid-template-columns:32px 1fr auto;gap:10px;align-items:center;background:var(--uv-blau-hell);border-radius:8px;padding:9px 10px}
.admin-row strong{display:block;font-size:14px}
.admin-row span{display:block;font-size:12px;color:#6B7280}
.info-list{display:grid;gap:8px;margin:0}
.info-list div{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid #F3F4F6;padding:7px 0}
.info-list dt{color:#6B7280}
.info-list dd{margin:0;font-weight:700;text-align:right}

.calendar{display:grid;grid-template-columns:repeat(7,minmax(130px,1fr));overflow:auto;background:#fff;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.08);min-width:910px}
.day-head,.day{border-right:1px solid #E5E7EB;border-bottom:1px solid #E5E7EB;padding:9px}
.day-head{background:var(--uv-blau);color:#fff;font-weight:800}
.day{min-height:118px;position:relative;padding-top:34px}
.day>strong{position:absolute;top:9px;left:9px}
.muted-day{background:#F8FAFC;color:#9CA3AF}
.event{margin-top:5px;border-radius:0;padding:5px 7px;color:#fff;font-size:12px;font-weight:700;line-height:1.2;min-height:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.event.segment-start{border-radius:6px 0 0 6px;margin-left:0}
.event.segment-mid{margin-left:-9px;margin-right:-9px}
.event.segment-end{border-radius:0 6px 6px 0;margin-right:0}
.event.segment-start.segment-end{border-radius:6px;margin-left:0;margin-right:0}
.event.pending{background:transparent!important;color:var(--uv-schwarz);border:1px dashed var(--uv-schwarz)}
.event.vacation-event{color:#64748B;font-weight:700}
.event-spacer{height:24px;margin-top:5px}
.holiday{position:absolute;top:7px;left:42px;right:9px;color:#1D1D1B;background:#FFF7A8;border-left:3px solid var(--uv-gelb);border-radius:5px;padding:4px 7px;font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.school-vacation{color:#64748B;background:#F1F5F9;border-left:3px solid #CBD5E1;border-radius:5px;padding:4px 7px;font-size:11px;font-weight:700;margin-top:5px}
.travel-rule-note{background:#F8FAFC;border:1px solid #E5E7EB;border-radius:8px;padding:10px}
.month-filter-card{justify-content:flex-start}
.month-filter-card .field{min-width:220px}
.month-nav{display:flex;align-items:center;gap:12px;width:max-content;max-width:100%}
.month-nav strong{font-size:18px;min-width:150px;text-align:center}
.travel-workspace{grid-template-columns:1fr}
.travel-log-card{margin-top:4px}
.travel-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.travel-card-head h2{margin:0}
.travel-assist-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:start}
.travel-assist-grid>div>label{display:block;color:#374151;font-size:13px;font-weight:700;margin-bottom:7px}
.travel-form-grid{display:flex;flex-wrap:wrap;gap:12px 14px;align-items:flex-start}
.travel-form-grid .full{flex:0 0 100%}
.travel-date-field{flex:0 0 170px}
.travel-time-field{flex:0 0 140px}
.travel-amount-field{flex:0 0 170px}
.travel-date-field .uv-datepicker,.travel-date-field .datepicker-display,.travel-time-field .input,.travel-amount-field .input{width:100%}
.travel-amount-field .field-hint{font-size:11px;white-space:nowrap}
.travel-log-card{padding:0;overflow:hidden}
.travel-log-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;padding:16px 18px;font-size:18px;font-weight:800;list-style:none}
.travel-log-summary::-webkit-details-marker{display:none}
.travel-log-summary::after{content:"›";font-size:22px;color:#6B7280;transition:transform .15s}
.travel-log-card[open] .travel-log-summary::after{transform:rotate(90deg)}
.travel-log-summary small{margin-left:auto;color:#6B7280;font-size:13px;font-weight:700}
.travel-log-content{border-top:1px solid #E5E7EB;overflow:auto}
.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;background:#F8FAFC;border:1px solid #E5E7EB;border-radius:8px;padding:12px}
.detail-grid label{display:block;color:#6B7280;font-size:12px;font-weight:700;margin-bottom:3px}
.claim-summary{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:#F8FAFC;border:1px solid #E5E7EB;border-radius:8px;padding:10px 12px}
.claim-summary strong{font-size:18px;margin-right:auto}
.travel-claim-meta{grid-template-columns:repeat(4,minmax(0,1fr))}
.travel-totals{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;background:#F8FAFC;border:1px solid #E5E7EB;border-radius:8px;padding:10px}
.travel-totals div{display:flex;justify-content:space-between;gap:10px;border-bottom:1px solid #E5E7EB;padding:5px 0;color:#4B5563}
.travel-totals div:nth-last-child(-n+1){border-bottom:0}
.travel-totals span{font-size:12px}
.travel-totals strong{color:var(--uv-schwarz)}
.travel-totals .grand-total{grid-column:1/-1;border-top:2px solid var(--uv-blau);border-bottom:0;margin-top:2px;padding-top:9px;font-size:15px}
.status-row{margin-top:8px}
.quick-time-card{gap:12px}
.quick-time-card h2{margin-bottom:4px}
.quick-time-meta-row{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  flex-wrap:wrap;
}
.quick-time-grid{
  grid-template-columns:130px 110px 110px 100px minmax(180px,1fr);
  gap:10px;
  align-items:end;
}
.quick-time-grid .field.full{grid-column:auto}
.quick-time-grid .field{gap:4px}
.quick-time-grid .field label{font-size:12px}
.quick-time-grid .input{
  min-height:34px;
  padding:7px 9px;
  font-size:13px;
  border-radius:7px;
}
.quick-time-summary{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.quick-time-summary span{
  background:#F8FAFC;
  border:1px solid #E5E7EB;
  border-radius:8px;
  color:#6B7280;
  font-size:12px;
  padding:7px 9px;
}
.quick-time-summary span.time-sum-plus{background:#DCFCE7;border-color:#BBF7D0;color:#166534}
.quick-time-summary span.time-sum-minus{background:#FEE2E2;border-color:#FECACA;color:#991B1B}
.quick-time-summary span.time-sum-plus strong{color:#166534}
.quick-time-summary span.time-sum-minus strong{color:#991B1B}
.quick-time-summary strong{display:block;color:var(--uv-schwarz);font-size:14px;margin-top:2px}
.quick-time-card .form-actions{margin-top:2px;padding-top:8px;border-top:1px solid #F3F4F6}
.time-workspace{grid-template-columns:minmax(0,1.5fr) minmax(280px,.5fr);align-items:start}
.time-sums{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.time-sums span{background:#F8FAFC;border:1px solid #E5E7EB;border-radius:8px;padding:6px 8px;color:#6B7280;font-size:11px}
.time-sums strong{display:block;color:var(--uv-schwarz);font-size:14px}
.time-sums .time-sum-plus{background:#DCFCE7;border-color:#BBF7D0;color:#166534}
.time-sums .time-sum-plus strong{color:#166534}
.time-sums .time-sum-minus{background:#FEE2E2;border-color:#FECACA;color:#991B1B}
.time-sums .time-sum-minus strong{color:#991B1B}
.time-sums .time-sum-neutral{background:#F8FAFC;border-color:#E5E7EB;color:#6B7280}
.time-table-wrap{overflow:auto}
.time-table{min-width:760px;font-size:13px}
.time-table th,.time-table td{padding:6px 8px}
.time-table td,.time-table th{vertical-align:middle}
.time-table input.compact{min-width:62px;min-height:28px;padding:4px 6px}
.time-table td:first-child{white-space:nowrap;width:110px}
.time-table td:nth-child(2),
.time-table td:nth-child(3),
.time-table td:nth-child(4),
.time-table td:nth-child(5){width:78px}
.time-table td:nth-child(6),
.time-table td:nth-child(7){width:70px}
.time-table td:last-child input{min-width:170px}
.time-profile-grid{grid-template-columns:1fr}
.time-profile-grid .field.full{grid-column:1}
.weekday-pills{display:flex;gap:7px;flex-wrap:wrap}
.weekday-pills label{display:inline-flex;align-items:center;cursor:pointer}
.weekday-pills input{position:absolute;opacity:0;pointer-events:none}
.weekday-pills span{display:inline-flex;min-width:38px;justify-content:center;border:1px solid #D1D5DB;border-radius:999px;padding:7px 10px;color:#4B5563;background:#fff;font-weight:800}
.weekday-pills input:checked+span{border-color:var(--uv-blau);background:var(--uv-blau);color:#fff}
.refresh-scope-pills span{min-width:0}
.weekday-hours{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.weekday-hours label{display:grid;gap:4px}
.weekday-hours span{font-size:11px;color:#6B7280;font-weight:800;text-align:center}
.weekday-hours .input{text-align:center;min-width:0}
.time-print-sheet{width:297mm;min-height:210mm;margin:18px auto;background:#fff;color:#111;padding:14mm;box-shadow:0 10px 32px rgba(0,0,0,.14);font-size:10pt;position:relative}
.time-print-sheet h1{text-align:center;margin:4mm 0 8mm;font-size:22pt}
.time-print-meta{display:grid;grid-template-columns:1fr 1fr;border:1px solid #9CA3AF;margin-bottom:10px}
.time-print-meta div{padding:8px 10px;border-right:1px solid #9CA3AF}
.time-print-meta div:last-child{border-right:0}
.time-seen-stamp{position:absolute;right:14mm;top:10mm;min-width:40mm;border:3px solid #16A34A;color:#16A34A;background:#fff;border-radius:4px;padding:8px 10px;text-align:center;font-weight:900;text-transform:uppercase;transform:rotate(-7deg)}
.time-seen-stamp small{display:block;font-size:8pt;margin-top:2px;text-transform:none}
.time-print-table{width:100%;border-collapse:collapse;font-size:8.8pt}
.time-print-table th,.time-print-table td{border:1px solid #9CA3AF;padding:4px 5px}
.time-print-table th{background:#F3F4F6;color:#111}
.time-print-table td:nth-child(3),
.time-print-table td:nth-child(6),
.time-print-table td:nth-child(7),
.time-print-table td:nth-child(8),
.time-print-table td:nth-child(9){text-align:right}
.time-print-sums{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:10px;border:1px solid #9CA3AF}
.time-print-sums div{padding:7px 9px;border-right:1px solid #9CA3AF}
.time-print-sums div:last-child{border-right:0}
.mail-redirect{min-height:100vh;display:grid;place-items:center;background:var(--grau-hell);padding:24px}
.mail-card{max-width:520px}
.travel-print-sheet{width:297mm;min-height:210mm;margin:18px auto;background:#fff;color:#111;padding:9mm 11mm;box-shadow:0 10px 32px rgba(0,0,0,.14);font-size:9.1pt;position:relative}
.desktop-like-print{font-family:Arial,Helvetica,sans-serif}
.print-title{text-align:center;margin:4mm 0 6mm}
.print-title strong{display:block;font-size:11pt;margin-bottom:4px}
.print-title h1{font-size:17pt;line-height:1.1;margin:0}
.travel-stamps{position:absolute;right:13mm;top:12mm;display:grid;gap:6px;justify-items:end}
.travel-stamp{min-width:42mm;border:3px solid #16A34A;color:#16A34A;background:#fff;border-radius:4px;padding:8px 10px;text-align:center;font-weight:900;text-transform:uppercase;transform:rotate(-7deg)}
.travel-stamp.paid{border-color:#1D4ED8;color:#1D4ED8;transform:rotate(5deg)}
.travel-stamp small{display:block;font-size:8pt;margin-top:2px;text-transform:none}
.print-status{align-self:start;border:2px solid var(--uv-blau);color:var(--uv-blau);font-weight:900;padding:8px 12px;text-align:center}
.travel-print-head{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:6px 16px;border:1px solid #9CA3AF;padding:7px 10px;margin-bottom:8px}
.travel-print-head label{display:block;font-weight:800;margin-bottom:2px}
.travel-print-head span{display:block}
.print-table{margin-top:12px;font-size:10pt}
.print-table th,.print-table td{border:1px solid #9CA3AF;padding:4px 5px}
.desktop-print-table{width:100%;border-collapse:collapse;margin-top:0}
.desktop-print-table th{background:#F3F4F6;color:#111;text-align:left;white-space:normal;line-height:1.05}
.desktop-print-table td{text-align:left;vertical-align:top}
.desktop-print-table td:nth-child(3),
.desktop-print-table td:nth-child(4),
.desktop-print-table td:nth-child(5),
.desktop-print-table td:nth-child(7),
.desktop-print-table td:nth-child(8),
.desktop-print-table td:nth-child(9),
.desktop-print-table td:nth-child(10){text-align:right}
.travel-print-lines{font-size:7.9pt;table-layout:fixed}
.travel-print-lines th,.travel-print-lines td{padding:2px 3px}
.travel-print-lines th:nth-child(1){width:28mm}
.travel-print-lines th:nth-child(2){width:19mm}
.travel-print-lines th:nth-child(3){width:15mm}
.travel-print-lines th:nth-child(4),.travel-print-lines th:nth-child(5){width:19mm}
.travel-print-lines th:nth-child(6){width:auto}
.travel-print-lines th:nth-child(7),.travel-print-lines th:nth-child(8){width:14mm}
.travel-print-lines th:nth-child(9){width:19mm}
.travel-print-lines th:nth-child(10){width:18mm}
.travel-print-lines td:nth-child(6){max-width:64mm}
.travel-print-lines small{display:block;color:#4B5563;font-size:6.8pt;margin-top:1px;line-height:1.08}
.travel-print-bottom{display:grid;grid-template-columns:72mm 1fr;gap:12px;margin-top:8px;align-items:start}
.travel-print-bottom table{width:100%;border-collapse:collapse}
.travel-print-bottom td{border:1px solid #9CA3AF;padding:2px 4px;font-size:8.2pt;line-height:1.08}
.travel-print-bottom td:first-child{width:50mm}
.travel-print-bottom td:last-child{text-align:right}
.tax-box{border:1px solid #9CA3AF;padding:6px 9px;margin-bottom:19mm;font-size:9.2pt}
.travel-certification{margin:0 0 -13mm;font-size:9.2pt}
.print-total{text-align:right;font-size:13pt}

.print-body{background:#f3f4f6;min-height:100vh}
.print-toolbar{position:sticky;top:0;background:#fff;border-bottom:1px solid #E5E7EB;padding:12px 18px;display:flex;gap:10px;z-index:5}
.leave-print-sheet{width:190mm;min-height:270mm;margin:18px auto;background:#fff;color:#111;padding:18mm;box-shadow:0 10px 32px rgba(0,0,0,.14);font-size:12pt}
.leave-print-head{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:start;border-bottom:2px solid var(--uv-blau);padding-bottom:12px;margin-bottom:18px}
.leave-print-head img{width:54px;height:auto}
.leave-print-head strong{display:block;color:var(--uv-dunkel);font-size:16pt}
.leave-print-head span{display:block;color:#4B5563;font-size:10pt;margin-top:2px}
.approval-stamp{border:3px solid #16A34A;color:#16A34A;font-weight:900;text-align:center;padding:8px 12px;transform:rotate(-7deg)}
.leave-print-sheet h1{font-size:22pt;margin:10px 0 16px}
.print-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid #9CA3AF;border-left:1px solid #9CA3AF}
.print-grid div{min-height:18mm;padding:7px 9px;border-right:1px solid #9CA3AF;border-bottom:1px solid #9CA3AF}
.print-grid label,.print-notes label,.print-signatures label{display:block;color:#6B7280;font-size:9pt;font-weight:700;margin-bottom:4px}
.print-grid strong{font-size:12pt}
.print-notes{border:1px solid #9CA3AF;border-top:0;padding:9px;min-height:28mm}
.print-notes p{margin:0}
.print-signatures{display:grid;grid-template-columns:1fr 1fr;gap:28mm;margin-top:30mm}
.print-signatures span{display:block;border-bottom:1px solid #111;height:16mm}

.login-shell{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:24px;
  background:linear-gradient(135deg,var(--uv-dunkel),var(--uv-blau));
  position:relative;
}
.login-shell:after{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:var(--uv-gelb)}
.login-panel{
  width:min(430px,100%);
  background:#fff;
  border-radius:10px;
  padding:30px;
  box-shadow:0 18px 44px rgba(0,0,0,.18);
  position:relative;
}
.login-brand{display:flex;gap:14px;align-items:center;margin-bottom:24px}
.login-brand img{height:56px;width:auto;object-fit:contain}
.login-brand h1{margin:0;color:var(--uv-dunkel);font-size:23px}
.login-brand p{margin:4px 0 0;font-size:13px}
.mobile-menu-overlay,.mobile-menu-panel,.mobile-header-actions,.mobile-menu-button{display:none}

@media(max-width:1080px){.cards{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:920px){
  .app-frame,.env-staging .app-frame{display:block;height:auto;min-height:100vh;overflow:visible}
  .sidebar,.app-header,.yellow-line{display:none}
  .mobile-header{
    position:sticky;
    top:36px;
    z-index:20;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    min-height:58px;
    padding:9px 14px;
    background:#fff;
    border-bottom:2px solid var(--uv-gelb);
    box-shadow:0 2px 10px rgba(0,0,0,.08);
  }
  .mobile-brand{
    min-width:0;
    display:flex;
    align-items:center;
    gap:10px;
    color:var(--uv-dunkel);
    text-decoration:none;
  }
  .mobile-brand img{width:auto;height:34px;object-fit:contain;flex:0 0 auto}
  .mobile-brand strong{font-size:14px;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .mobile-header-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
  .mobile-header .app-version{color:#4B5563;border-color:#D1D5DB;flex:0 0 auto;margin-left:0}
  .mobile-menu-button{
    width:42px;
    height:42px;
    border:1px solid #D1D5DB;
    border-radius:9px;
    background:#fff;
    display:grid;
    place-items:center;
    padding:9px;
    box-shadow:0 1px 4px rgba(0,0,0,.06);
  }
  .mobile-menu-button span{
    display:block;
    width:18px;
    height:2px;
    background:var(--uv-dunkel);
    border-radius:999px;
  }
  .mobile-menu-panel{
    position:fixed;
    top:0;
    right:0;
    bottom:0;
    z-index:60;
    width:min(340px,88vw);
    background:#fff;
    display:flex;
    flex-direction:column;
    box-shadow:-12px 0 30px rgba(15,23,42,.20);
    transform:translateX(105%);
    transition:transform .18s ease;
  }
  .mobile-menu-overlay{
    position:fixed;
    inset:0;
    z-index:55;
    background:rgba(15,23,42,.38);
    opacity:0;
    pointer-events:none;
    transition:opacity .18s ease;
  }
  body.mobile-menu-open{overflow:hidden}
  body.mobile-menu-open .mobile-menu-panel{transform:translateX(0)}
  body.mobile-menu-open .mobile-menu-overlay{opacity:1;pointer-events:auto}
  .mobile-menu-head{
    min-height:70px;
    padding:16px 18px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    border-bottom:2px solid var(--uv-gelb);
  }
  .mobile-menu-head strong{display:block;color:var(--uv-dunkel);font-size:17px}
  .mobile-menu-head span{display:block;color:#6B7280;font-size:12px;margin-top:2px}
  .mobile-menu-close{
    width:38px;
    height:38px;
    border:1px solid #E5E7EB;
    border-radius:9px;
    background:#fff;
    color:#4B5563;
    font-size:24px;
    line-height:1;
  }
  .mobile-menu-nav{flex:1;overflow:auto;padding:10px 0}
  .mobile-menu-nav a,
  .mobile-menu-nav .nav-heading{
    display:flex;
    align-items:center;
    padding-left:18px;
    padding-right:18px;
    text-decoration:none;
  }
  .mobile-menu-nav .nav-single{
    width:100%;
    justify-content:flex-start;
    gap:9px;
  }
  .mobile-menu-nav .nav-group{margin:2px 0}
  .mobile-menu-nav .nav-heading{
    min-height:46px;
    border-bottom:1px solid #F3F4F6;
  }
  .mobile-menu-nav .nav-children{
    margin:0;
    padding:4px 0 8px 36px;
    border-left:0;
    background:#F8FAFC;
  }
  .mobile-menu-nav .nav-child{
    display:flex;
    width:100%;
    min-height:38px;
    margin:0;
    padding:9px 18px 9px 14px;
    justify-content:flex-start;
    gap:8px;
    border-right:0!important;
  }
  .mobile-menu-nav .nav-child span{width:18px;flex:0 0 18px}
  .mobile-menu-nav .nav-child.active{
    background:#E8F1FA;
    border-radius:6px 0 0 6px;
  }
  .mobile-menu-logout{
    border-top:1px solid #E5E7EB;
    padding:15px 18px;
    color:#6B7280;
    text-decoration:none;
    font-size:14px;
    font-weight:700;
  }
  .main-area{display:block;overflow:visible}
  .content{padding:18px 14px 28px;overflow:visible}
  .topbar h1{font-size:24px}
  .two,.cards,.stats,.form-grid,.leave-page,.leave-form-grid,.date-form-grid,.travel-form-grid,.travel-assist-grid{grid-template-columns:1fr}
  .travel-workspace,.time-workspace{grid-template-columns:1fr}
  .quick-time-grid{grid-template-columns:1fr 1fr}
  .quick-time-grid .field.full{grid-column:1/-1}
  .travel-claim-meta,.admin-travel-meta,.travel-totals{grid-template-columns:1fr}
  .travel-form-grid .field{flex:0 0 100%}
  .leave-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .leave-card{max-width:none}
  .leave-form-grid .date-side,.leave-form-grid .field:not(.date-side):not(.full),.leave-form-grid .full{grid-column:1;grid-row:auto}
  .date-form-grid .date-side,.date-form-grid .field:not(.date-side):not(.full),.date-form-grid .full,.travel-form-grid .field{grid-column:1;grid-row:auto}
  .range-calendar-popup{position:static;width:100%;margin-top:4px}
  .table-wrap{overflow:auto}
  table{min-width:620px}
  .month-nav{width:100%;justify-content:space-between;padding:14px}
  .month-nav strong{min-width:0;font-size:17px}
  .calendar{
    min-width:0;
    width:100%;
    grid-template-columns:repeat(7,minmax(0,1fr));
    overflow:hidden;
    border-radius:8px;
  }
  .day-head,.day{padding:5px;border-color:#E5E7EB}
  .day-head{font-size:12px}
  .day{
    min-height:84px;
    padding-top:22px;
  }
  .day>strong{top:5px;left:5px;font-size:12px}
  .holiday{
    position:static;
    margin:0 0 3px;
    padding:2px 4px;
    border-left-width:2px;
    font-size:9px;
  }
  .event{
    min-height:17px;
    margin-top:3px;
    padding:3px 4px;
    font-size:9px;
    border-radius:0;
  }
  .event.segment-start{border-radius:4px 0 0 4px}
  .event.segment-mid{margin-left:-5px;margin-right:-5px}
  .event.segment-end{border-radius:0 4px 4px 0}
  .event.segment-start.segment-end{border-radius:4px;margin-left:0;margin-right:0}
  .event-spacer{height:17px;margin-top:3px}
  .tile{min-height:112px}
  .quick-time-card .section-title-row{display:grid;gap:10px}
  .quick-time-card .section-title-row .btn{justify-self:start}
  .quick-time-meta-row{justify-content:flex-start}
  .staging-banner{min-height:36px;padding:7px 10px;gap:7px;font-size:11px;flex-wrap:wrap}
  .staging-banner strong{font-size:11px;padding:2px 6px}
}
@media print{
  @page{size:A4 landscape;margin:10mm}
  body{background:#fff}
  .no-print,.sidebar,.app-header,.yellow-line,.mobile-menu-overlay,.mobile-menu-panel,.topbar,.staging-banner{display:none!important}
  .app-frame,.main-area{display:block;height:auto;overflow:visible}
  .content{padding:0;overflow:visible}
  .card{box-shadow:none;border:0}
  .print-body{background:#fff!important;overflow:visible!important}
  .print-body .print-toolbar{display:none!important}
  .print-body .travel-print-sheet,.print-body .leave-print-sheet,.print-body .time-print-sheet{display:block!important;visibility:visible!important}
  .leave-print-sheet,.travel-print-sheet,.time-print-sheet{box-shadow:none;margin:0;width:auto;min-height:auto;padding:0}
  .travel-print-sheet{width:277mm!important;min-height:190mm!important}
}
