:root{--bg:#f5f7fb;--panel:#fff;--text:#172033;--muted:#667085;--line:#e5e7eb;--blue:#2563eb;--blue2:#1d4ed8;--danger:#dc2626;--green:#16a34a;--shadow:0 14px 30px rgba(15,23,42,.08);--namew:260px;--dayw:34px}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}a{color:var(--blue);text-decoration:none}a:hover{text-decoration:underline}.topbar{height:64px;background:#0f172a;color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 26px;position:sticky;top:0;z-index:20}.brand a{color:#fff;font-weight:800;font-size:18px}.navlinks{display:flex;gap:18px;align-items:center}.navlinks a,.navlinks span{color:#fff}.container{max-width:1280px;margin:28px auto;padding:0 18px}.hero{display:flex;justify-content:space-between;gap:20px;align-items:flex-start;margin-bottom:18px}.hero h1{margin:0 0 6px;font-size:30px}.small{color:var(--muted);font-size:14px}.card{background:var(--panel);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:22px;margin-bottom:18px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}.form-row{margin-bottom:14px}label{display:block;font-weight:750;margin-bottom:6px}input,textarea,select{width:100%;padding:11px 12px;border:1px solid #d0d5dd;border-radius:10px;font-size:15px;background:#fff}textarea{min-height:90px;resize:vertical}input[type=color]{width:44px;height:44px;padding:0;border:1px solid #cbd5e1;border-radius:10px;cursor:pointer;background:none}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:0;border-radius:9px}input[type=color]::-moz-color-swatch{border:0;border-radius:9px}.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.btn,button{border:0;border-radius:10px;background:var(--blue);color:#fff;padding:11px 14px;font-weight:750;font-size:15px;cursor:pointer;display:inline-block}.btn:hover,button:hover{background:var(--blue2);text-decoration:none}.btn.secondary,button.secondary{background:#e5e7eb;color:#111827}.btn.danger,button.danger{background:var(--danger)}.btn.green,button.green{background:var(--green)}.error{background:#fee2e2;color:#991b1b;padding:12px;border-radius:12px;margin-bottom:14px}.success{background:#dcfce7;color:#166534;padding:12px;border-radius:12px;margin-bottom:14px}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;border-bottom:1px solid var(--line);padding:12px;vertical-align:middle}.table th{font-size:13px;color:#475467;background:#f8fafc}.pill{display:inline-block;border-radius:999px;padding:5px 10px;background:#eef2ff;font-size:13px;font-weight:700}.status-ikke_startet{background:#f1f5f9}.status-i_gang{background:#dbeafe}.status-faerdig{background:#dcfce7}.progress{height:8px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress div{height:100%;background:#22c55e}.swatch{width:26px;height:26px;border-radius:8px;border:1px solid #d1d5db}.gantt-toolbar{display:flex;justify-content:space-between;gap:12px;align-items:center;position:sticky;top:64px;z-index:10;background:var(--bg);padding:10px 0}.gantt-shell{overflow:auto;border:1px solid var(--line);border-radius:16px;background:#fff;max-height:calc(100vh - 210px)}.gantt{min-width:900px}.gantt-head,.gantt-row{display:grid;grid-template-columns:var(--namew) 1fr}.gantt-head{position:sticky;top:0;z-index:5;background:#f8fafc;font-size:12px;font-weight:800;color:#475467}.gantt-name{position:sticky;left:0;z-index:3;background:#fff;border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:12px}.gantt-head .gantt-name{background:#f8fafc;z-index:7}.gantt-timeline{position:relative;display:grid;border-bottom:1px solid var(--line);min-height:54px}.gantt-head .gantt-timeline{min-height:40px;background:#f8fafc}.gantt-cell{border-right:1px solid #edf0f4;padding:10px 3px;text-align:center;white-space:nowrap}.weekend{background:#fafafa}.bar{position:absolute;top:12px;height:30px;border-radius:9px;color:#fff;font-weight:800;font-size:13px;display:flex;align-items:center;padding:0 10px;box-shadow:0 7px 16px rgba(15,23,42,.17);cursor:grab;overflow:hidden;white-space:nowrap}.bar:active{cursor:grabbing}.bar .bar-progress{position:absolute;left:0;top:0;bottom:0;background:rgba(255,255,255,.28);pointer-events:none}.bar span{position:relative;z-index:2}.milestone{position:absolute;top:13px;width:28px;height:28px;transform:rotate(45deg);border-radius:5px;box-shadow:0 7px 16px rgba(15,23,42,.17);cursor:grab}.milestone-label{position:absolute;top:17px;font-size:12px;font-weight:800;background:#fff;padding:2px 6px;border-radius:6px;white-space:nowrap}.dependency{font-size:13px;color:#475467}.print-only{display:none}@media print{.topbar,.gantt-toolbar,.no-print,.btn,button{display:none!important}.container{max-width:none;margin:0}.card{box-shadow:none;border:0}.gantt-shell{overflow:visible;max-height:none}.print-only{display:block}}

/* Sikrer at farver i Gantt-kortet kommer med ved PDF/print */
.bar,.milestone,.swatch,input[type=color]{
  -webkit-print-color-adjust: exact !important;
  print-color-adjust: exact !important;
  color-adjust: exact !important;
}
.bar .bar-progress{
  -webkit-print-color-adjust: exact !important;
  print-color-adjust: exact !important;
}
@media print{
  *{
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    color-adjust: exact !important;
  }
  body{background:#fff!important}
  .bar,.milestone{box-shadow:none!important}
  .milestone-label{border:1px solid #e5e7eb}
}
