/* Base */
:root{
  --bg:#0f1115; --panel:#171a21; --muted:#9aa4b2; --border:#232732;
  --brand:#6ee7ff; --ok:#4ade80; --warn:#fbbf24; --err:#f87171; --text:#ffffff;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu}
body, body * {
  color: var(--text) !important;
}
#edtBreak{
  max-width: 65px;
}
.form-row{margin: 5px;}
.site-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#151822,#0f1115);position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:center;gap:10px}.logo-dot{width:10px;height:10px;border-radius:50%;background:var(--brand);display:inline-block}
.tabs{display:flex;gap:8px;padding:8px;border-bottom:1px solid var(--border);position:sticky;top:58px;background:#0f1115;z-index:9}
.tab-button{border:1px solid var(--border);background:#12151d;color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer}
.tab-button.active{border-color:var(--brand);box-shadow:0 0 0 2px rgba(110,231,255,.15)}
main{padding:12px;max-width:1100px;margin:0 auto}
.view{display:none}.view.active{display:block}
.card{background:var(--panel);border:1px solid var(--border);padding:14px;border-radius:14px;margin:12px 0;box-shadow:0 6px 30px rgba(0,0,0,.25)}
.grid-2{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media(max-width:800px){.grid-2,.grid-3{grid-template-columns:1fr}}
label{display:flex;flex-direction:column;gap:6px;font-size:14px; color: #FFF}
input,select,textarea{background:#0f131a;border:1px solid var(--border);color:var(--text);padding:10px 12px;border-radius:10px;outline:none}
input::placeholder,textarea::placeholder{color:#6b7280}
.btn{border:1px solid var(--border);background:#10141b;color:var(--text);padding:10px 14px;border-radius:10px;cursor:pointer}
.btn.primary{border-color:#1b3a42;background:#0d1f26;color:#c3f3ff}.btn.danger{border-color:#3e1b1b;background:#1a0e0e;color:#ffd1d1}.btn:disabled{opacity:.5;cursor:not-allowed}.btn+.btn{margin-left:8px}
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.right{display:flex;align-items:center;gap:8px}
.muted{color:var(--muted)}.small{font-size:12px}
.clock-now{font-size:48px;font-weight:700;letter-spacing:2px;margin-bottom:8px}
.punch-controls{display:flex;gap:10px;margin-top:10px}
.shift-box{background:#10141b;border:1px dashed var(--border);padding:10px;border-radius:10px}
.list>.row{display:grid;grid-template-columns:1fr auto;gap:8px;padding:10px;border-bottom:1px solid var(--border)}
.row .meta{font-size:12px;color:var(--muted)}
.calendar{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;user-select:none}
.calendar.hidden{display:none}
.hidden {
  display: none !important;
}
.cal-cell{border:1px solid var(--border);border-radius:10px;min-height:88px;padding:6px;position:relative}
.cal-cell .day{position:absolute;top:6px;right:8px;font-size:11px;color:#94a3b8}
.badge{display:inline-block;padding:2px 6px;border-radius:6px;font-size:11px;border:1px solid var(--border);margin-top:18px;cursor:pointer}
.badge.work{background:#0d1f26;color:#c3f3ff}.badge.vacation{background:#12210d;color:#c6ffc3}.badge.sick{background:#21120d;color:#ffd0c3}.badge.other{background:#1f1f1f;color:#e5e7eb}
.badge .dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}
/* Approved checkmark */
.badge.approved{position:relative;padding-left:22px}
.badge.approved::before{content:"✓";position:absolute;left:6px;top:2px;font-weight:700;opacity:.9}
.toast{display:none;position:fixed;bottom:16px;left:50%;transform:translateX(-50%);background:#0b1220;border:1px solid var(--border);padding:10px 14px;border-radius:10px;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.toast.success{border-color:#12331b;color:#b7f7c8}.toast.error{border-color:#3a1b1b;color:#ffd1d1}.toast.info{color:#cbd5e1}
.modal{border:none;padding:0;background:transparent}.modal::backdrop{background:rgba(0,0,0,.6)}.modal-inner{background:#0f131a;border:1px solid var(--border);padding:14px;border-radius:14px;min-width:420px;max-width:960px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}
.switch{position:relative;display:inline-block;width:50px;height:28px}.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#19202b;border:1px solid var(--border);transition:.2s;border-radius:999px}
.slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;top:3px;border-radius:50%;background:white;transition:.2s}
input:checked+.slider{background:#0d1f26;border-color:#1b3a42}input:checked+.slider:before{transform:translateX(22px)}
.blocks-wrap{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.block{border:1px solid var(--border);border-radius:10px;padding:8px 10px;cursor:pointer;background:#10141b}
.block.active{border-color:var(--brand);box-shadow:0 0 0 2px rgba(110,231,255,.15)}
.block .title{font-weight:600;font-size:14px}.block .sub{font-size:12px;color:var(--muted)}
.block.disabled{opacity:.5;pointer-events:none;position:relative}
.block.disabled::after{content:"Allerede stemplet";position:absolute;bottom:4px;right:8px;font-size:10px;color:#94a3b8}
.week-split{margin:10px 0;padding:6px 10px;border-left:3px solid var(--brand);background:#0e131a;color:#c3f3ff;border-radius:8px;font-size:13px}
/* Subtabs */
.subtabs{display:flex;gap:8px;margin:6px 0 10px 0}
.subtab-button{border:1px solid var(--border);background:#10141b;color:var(--text);padding:8px 12px;border-radius:10px;cursor:pointer}
.subtab-button.active{border-color:var(--brand);box-shadow:0 0 0 2px rgba(110,231,255,.15)}
.subview{display:none}.subview.active{display:block}
/* Timeline */
.timeline{display:block}.timeline.hidden{display:none}
.timeline-hours{display:flex;gap:0;margin-bottom:6px}
.timeline-hours .tick{flex:1;font-size:11px;color:#94a3b8;text-align:right;padding-right:4px}
.timeline-row{display:flex;align-items:center;gap:10px;padding:8px 6px;border-bottom:1px solid var(--border)}
.timeline-name{width:180px;flex:0 0 180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.timeline-barwrap{position:relative;height:22px;flex:1;border:1px solid var(--border);border-radius:8px;background:#0f131a}
.timeline-bar{position:absolute;height:100%;border-radius:7px;opacity:.9}
.timeline-bar.nonwork{filter:grayscale(.7);opacity:.6;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.25) 0,rgba(255,255,255,.25) 6px,rgba(255,255,255,0) 6px,rgba(255,255,255,0) 12px);border:1px dashed #334155}
.weekday-grid{display:grid;grid-template-columns:repeat(7, minmax(0,1fr));gap:6px}
/* Approvals – rent, lyst layout */
.approval-row{
  display:flex; align-items:stretch; gap:16px;
  background:#171A21; border:1px solid #494d55; border-radius:12px;
  padding:12px; margin-bottom:10px;
}
.approval-left{ flex:1; min-width:0; }
.approval-right{ display:flex; flex-direction:column; gap:8px; }
.approval-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.approval-head .who{ font-weight:700; font-size:15px; }
.approval-head .date{ color:#374151; font-size:13px; }
.approval-meta{ color:#374151; margin-bottom:8px; }
.badge{ background:#171A21; border:1px solid #343a47; border-radius:6px; padding:2px 6px; font-size:12px; color:#111; }

.approvals-grid{
  display:grid; grid-template-columns: 1fr 1fr 1fr; gap:10px; margin-bottom:8px;
}
.approvals-grid label{ display:flex; flex-direction:column; font-size:12px; color:#374151; }
.approvals-grid input[type="time"], .approvals-grid input[type="number"]{
  margin-top:4px; border:1px solid #363b47; border-radius:8px; padding:6px 8px; background:#171A21; color:#ffffff;
}

.approvals-toggles{ display:flex; gap:8px; margin-bottom:8px; }

.splitPanel{ border-top:1px dashed #e5e7eb; padding-top:10px; display:grid; grid-template-columns: 1fr 1fr; gap:16px; }
.splitPanel.hidden{ display:none; }
.splitCol{ background:#171A21; border:1px solid #494d55; border-radius:10px; padding:10px; }
.splitTitle{ font-weight:600; margin-bottom:8px; }
.splitRow{ display:grid; grid-template-columns: 1fr 1fr; gap:10px; margin-bottom:8px; }
.splitRow label{ display:flex; flex-direction:column; font-size:12px; color:#374151; }
.splitRow input[type="time"]{ margin-top:4px; border:1px solid #494d55; border-radius:8px; padding:6px 8px; background:#171A21; color:#111; }

.approval-gps{ display:none; } /* felt findes men er skjult */
/* Roster (Planday-agtigt) */
.roster{width:100%; overflow:auto; border:1px solid var(--border); border-radius:10px; background:#10141b}
.roster-table{min-width:900px; border-collapse:separate; border-spacing:0; width:100%}
.roster thead th{position:sticky; top:0; background:#0f131a; color:#cbd5e1; font-weight:600; padding:8px; border-bottom:1px solid var(--border); z-index:1}
.roster .name-col{position:sticky; left:0; background:#0f131a; border-right:1px solid var(--border); min-width:160px; width:160px; z-index:2}
.roster tbody td{vertical-align:top; border-bottom:1px solid var(--border); padding:6px}
.roster .slot{min-height:56px}

/* Shift “pill” */
.shift-pill{position:relative; display:block; margin:4px 0; padding:6px 8px 6px 10px; border:1px solid #273244; border-radius:8px; background:#121923; color:#e5e7eb; font-size:12px; line-height:1.25}
.shift-pill.approved{background:#0f2414; border-color:#1f4d2a} /* godkendte bliver grønne */
.shift-pill .time{display:block; font-weight:600}
.shift-pill .type{display:block; font-size:11px; opacity:.9}

/* type-stribe */
.shift-pill::before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px; border-top-left-radius:8px; border-bottom-left-radius:8px; background:#334155}
.shift-pill.type-vacation::before{background:#2d742d}
.shift-pill.type-sick::before{background:#944231}
.shift-pill.type-overtime::before{background:#8b5cf6}
.shift-pill.type-comp::before{background:#2563eb}
.shift-pill.type-closed::before{background:#250303}
.shift-pill.type-work::before{background: #2c3b50}

/* Day (timeline) */
.roster-hours{display:grid; grid-template-columns:160px 1fr; gap:0; border-bottom:1px solid var(--border); background:#0f131a}
.roster-hours .ticks{position:relative; height:28px; border-left:1px solid var(--border)}
.roster-hours .ticks div{position:absolute; top:4px; font-size:10px; color:#94a3b8; transform:translateX(-50%)}
.roster-row{display:grid; grid-template-columns:160px 1fr; gap:0; border-bottom:1px solid var(--border)}
.roster-row .name{padding:8px; border-right:1px solid var(--border); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.roster-row .barwrap{position:relative; height:34px}
.roster-row .bar{position:absolute; top:6px; height:22px; border-radius:7px; background:#1f2937; border:1px solid #273244; overflow:hidden}
.roster-row .bar.approved{background:#0f2414; border-color:#1f4d2a}
.roster-row .bar .label{position:absolute; left:6px; top:3px; font-size:11px}

/* dag/uge/måned aktiv knap */
.btn-group .calmode.active{border-color:var(--brand); box-shadow:0 0 0 2px rgba(110,231,255,.15)}
