:root{--bg:#f6f3ee;--card:#fff;--text:#172033;--muted:#697386;--border:#e5e0d8;--accent:#2f855a;--accent2:#276749;--soft:#e6f4ec;--pending:#fff7db;--pending-border:#f0b429;--approved:#e6f4ec;--approved-border:#2f855a;--danger:#b91c1c;--blue:#2563eb;--shadow:0 10px 30px rgba(31,41,51,.08)}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at top left,#fff7e8 0,var(--bg) 38%,#edf7f1 100%);color:var(--text);min-height:100vh}.app{width:calc(100% - 24px);max-width:none;margin:auto;padding:18px 0 96px}header{display:grid;grid-template-columns:320px minmax(0,1fr);gap:12px;align-items:start;margin-bottom:14px}.title,.card,.modal{background:rgba(255,255,255,.94);border:1px solid rgba(255,255,255,.9);box-shadow:var(--shadow)}.title{border-radius:26px;padding:18px}h1{margin:0;font-size:clamp(1.9rem,5vw,3rem);letter-spacing:-.055em;line-height:.95}.subtitle,.hint{color:var(--muted);line-height:1.4}.subtitle{margin-top:8px}.toolbar,.nav,.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}button,input,select,textarea{font:inherit}button{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:999px;padding:11px 14px;min-height:44px;font-weight:800;box-shadow:0 4px 14px rgba(31,41,51,.05);cursor:pointer}button:disabled{opacity:.45;cursor:not-allowed}.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.danger{color:var(--danger)}input,select,textarea{width:100%;border:1px solid var(--border);border-radius:14px;padding:12px;background:#fff;min-height:44px}textarea{min-height:78px;resize:vertical}label{display:grid;gap:6px;font-weight:750;font-size:.88rem}.views{display:inline-flex;background:#fff;border:1px solid var(--border);border-radius:999px;padding:4px}.views button{box-shadow:none;border:0;background:transparent;min-height:36px;padding:8px 13px}.views .active{background:var(--accent);color:#fff}.panel{display:grid;grid-template-columns:320px minmax(0,1fr);gap:14px}.card{border-radius:26px;padding:16px;height:max-content;min-width:0}.side{position:sticky;top:14px}.form{display:grid;gap:10px}.stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:14px}.stat{background:var(--soft);border-radius:16px;padding:12px}.stat strong{display:block;font-size:1.35rem}.period{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-bottom:14px}.period-title{font-size:1.35rem;font-weight:900;letter-spacing:-.04em}.week{display:grid;grid-template-columns:repeat(7,minmax(125px,1fr));gap:10px}.single-day{display:grid;grid-template-columns:minmax(0,1fr);gap:10px}.single-day .day{min-height:320px}.day{background:#fff;border:1px solid var(--border);border-radius:18px;padding:11px;min-height:235px}.day.today,.mday.today{outline:3px solid rgba(37,99,235,.22);border-color:rgba(37,99,235,.72);background:#eff6ff}.day-head{display:flex;justify-content:space-between;gap:8px;border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:8px}.day-name{font-weight:900}.date{color:var(--muted);font-size:.84rem;white-space:nowrap}.meal{border-radius:14px;padding:10px;margin-top:8px;border:1px solid #e8edf0;background:#f9fafb}.meal.approved{background:var(--approved);border-color:var(--approved-border)}.meal.pending{background:var(--pending);border-color:var(--pending-border)}.meal strong,.meal small{display:block}.meal small{color:var(--muted);white-space:pre-wrap;margin-top:3px}.badge{display:inline-flex;border-radius:999px;padding:4px 8px;font-size:.73rem;font-weight:900;margin-bottom:5px}.badge.ok{background:var(--approved);color:var(--accent2)}.badge.pending{background:var(--pending);color:#8a5a00}.empty{color:var(--muted);margin-top:18px}.meal-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.meal-actions button{min-height:36px;padding:7px 10px;font-size:.82rem}.month{display:grid;grid-template-columns:repeat(7,minmax(90px,1fr));gap:8px}.wlabel{text-align:center;color:var(--muted);font-weight:900;font-size:.8rem}.mday{background:#fff;border:1px solid var(--border);border-radius:16px;min-height:112px;padding:9px;cursor:pointer}.mday.other{opacity:.42}.mday.hasApproved{border-left:5px solid var(--approved-border)}.mday.hasPending{border-right:5px solid var(--pending-border)}.mdate{font-weight:900;margin-bottom:6px}.mmeal{font-size:.76rem;border-radius:10px;padding:5px 6px;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mmeal.ok{background:var(--approved)}.mmeal.pending{background:var(--pending)}.status{font-size:.9rem;margin:0 0 14px}.global-status{margin:0 0 14px;border:1px solid #cbd5e1;background:rgba(248,250,252,.96);color:#334155;border-radius:18px;padding:11px 14px;font-weight:750;box-shadow:0 6px 18px rgba(31,41,51,.06)}.global-status.infoText,.global-status.okText{border-color:#bfdbfe;background:#eff6ff;color:#1e3a8a}.global-status.badText{border-color:#fecaca;background:#fef2f2;color:var(--danger)}.global-status.warnText{border-color:#fde68a;background:#fffbeb;color:#92400e}.okText{color:#1e3a8a}.badText{color:var(--danger)}.modal-bg{position:fixed;inset:0;background:rgba(17,24,39,.48);display:none;align-items:center;justify-content:center;padding:14px;z-index:30}.modal-bg.open{display:flex}.modal{width:min(780px,100%);max-height:88vh;overflow:auto;border-radius:26px;padding:16px}.modal-head{display:flex;justify-content:space-between;gap:10px;align-items:center}.tabs{display:flex;gap:6px;margin:12px 0;overflow:auto}.tab.active{background:var(--accent);color:#fff}.settings-panel{display:none}.settings-panel.active{display:block}.user-tools{display:grid;grid-template-columns:1.2fr .8fr 1fr;gap:8px;margin:10px 0}.user-selected-note{background:var(--soft);border:1px solid var(--border);border-radius:16px;padding:10px;margin:8px 0}.user-row,.backup-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;border:1px solid var(--border);border-radius:16px;padding:10px;margin-top:8px;background:#fff}.roles{display:flex;gap:10px;flex-wrap:wrap}.roles label{display:flex;align-items:center;gap:5px}.roles input{width:auto;min-height:0}.meta{font-size:.8rem;color:var(--muted)}.login-wrap{width:min(460px,calc(100% - 28px));margin:8vh auto}.login-card{background:#fff;border-radius:28px;padding:20px;box-shadow:var(--shadow);border:1px solid var(--border)}.login-card h1{font-size:2.4rem}.hidden{display:none!important}.bottom{display:none}.small{font-size:.85rem;color:var(--muted)}.log-filter{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:10px 0}.log-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin:8px 0 12px}.log-row,.version-row{border:1px solid var(--border);border-radius:16px;background:#fff;padding:10px;margin-top:8px}.log-head{display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap}.log-cat{background:#eef2ff;color:#1e3a8a;border-radius:999px;padding:3px 8px;font-size:.75rem;font-weight:900}.details{white-space:pre-wrap;font-size:.82rem;color:var(--muted);margin-top:6px}.version-row ul{margin:6px 0 0 18px;padding:0}.version-row li{margin:3px 0}@media(max-width:1050px){header,.panel{grid-template-columns:1fr}.toolbar{justify-content:flex-start}.side{position:static}.week{grid-template-columns:repeat(2,minmax(160px,1fr))}}@media(max-width:680px){.top-title{align-items:flex-start}.version-pill{font-size:.76rem;padding:6px 10px}.user-tools{grid-template-columns:1fr}.app{width:min(100% - 16px,1280px);padding-top:10px}.toolbar{display:none}.title,.card{border-radius:20px}.period{align-items:flex-start;flex-direction:column}.week,.month,.single-day{grid-template-columns:1fr}.wlabel{display:none}.day{min-height:170px}.mday{min-height:86px}.user-row,.backup-row{grid-template-columns:1fr}.bottom{display:flex;position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.96);border-top:1px solid var(--border);padding:8px;padding-bottom:calc(8px + env(safe-area-inset-bottom));z-index:20;justify-content:space-around}.bottom button{box-shadow:none;min-width:56px;padding:9px 9px;font-size:.82rem}.bottom button.active{background:var(--accent);color:#fff}.views{width:100%;justify-content:center}.views button{flex:1}.modal{max-height:92vh}}
.user-mode-switch{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 14px;padding:6px;background:#f8fafc;border:1px solid var(--border);border-radius:999px;width:max-content;max-width:100%}.user-mode-switch button{box-shadow:none}.admin-section{border:1px solid var(--border);background:#fff;border-radius:20px;padding:14px;margin-top:10px}.admin-section h3{margin-top:0}.admin-section .form{max-width:520px}.admin-section .user-row{margin-top:12px}@media(max-width:680px){.user-mode-switch{width:100%;border-radius:18px}.user-mode-switch button{flex:1}.admin-section{padding:12px}}

header .toolbar{width:100%;justify-content:flex-start;align-content:flex-start;row-gap:10px}
header .toolbar > *{flex:0 0 auto}
header .toolbar button{font-size:.94rem;padding:10px 13px}
header .toolbar .views button{padding:8px 12px}
main.card{min-width:0;overflow:hidden}
#calendarRoot{min-width:0;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}
.week,.month,.single-day{min-width:0}
.top-title{min-height:100%;align-content:start}
.title{height:100%}

/* Version 1.35: header version badge */
.top-title{display:flex;align-items:center;justify-content:space-between;gap:14px;min-width:0}
.top-title h1{min-width:0}
.version-pill{display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;border-radius:999px;padding:7px 12px;font-size:.78rem;font-weight:900;letter-spacing:.01em;box-shadow:0 4px 12px rgba(37,99,235,.08)}
@media(max-width:680px){.top-title{flex-direction:row;align-items:center}.version-pill{font-size:.72rem;padding:6px 9px}}

/* Version 1.37: responsive header/layout polish */
body{
  background:#f7f2ea;
  background-image:linear-gradient(120deg,#fbf6ee 0%,#f7f2ea 58%,#eef7f1 100%);
  background-attachment:fixed;
}
.title{overflow:hidden}
.side,.form,label,input,select,textarea{min-width:0}
.side{overflow:hidden}
#mealDate{max-width:100%;width:100%}
input[type="date"]{max-width:100%;min-width:0}

@media(max-width:1050px){
  .app{width:min(100% - 20px,1280px)}
  header{grid-template-columns:1fr}
}

@media(orientation:landscape) and (max-height:740px){
  .app{width:calc(100% - 18px);padding-top:14px}
  header{grid-template-columns:320px minmax(0,1fr);gap:14px;margin-bottom:14px}
  .title{padding:16px 18px;border-radius:24px}
  .top-title{grid-template-columns:minmax(0,1fr) auto;align-items:start}
  .top-title h1{font-size:clamp(2.15rem,4vw,3rem);line-height:.95}
  .version-pill{font-size:.75rem;padding:6px 11px;margin-top:2px}
  .toolbar{display:flex;align-items:flex-start;justify-content:flex-start;gap:8px 10px;flex-wrap:wrap}
  .toolbar button{min-height:40px;padding:8px 12px;font-size:.9rem}
  .views button{min-height:34px;padding:7px 13px}
  .panel{grid-template-columns:320px minmax(0,1fr);gap:14px}
  .side{position:static}
  .card{padding:16px}
  .week{grid-template-columns:repeat(7,minmax(110px,1fr));gap:10px}
  .day{min-height:220px}
  .month{grid-template-columns:repeat(7,minmax(86px,1fr))}
}

@media(orientation:landscape) and (max-height:740px) and (max-width:980px){
  .app{width:calc(100% - 16px)}
  header{grid-template-columns:300px minmax(0,1fr)}
  .panel{grid-template-columns:300px minmax(0,1fr)}
  .top-title h1{font-size:clamp(2rem,4vw,2.6rem)}
  .version-pill{font-size:.68rem;padding:5px 9px}
  .toolbar{gap:7px 8px}
  .toolbar button{font-size:.88rem;padding:8px 10px}
  .week{grid-template-columns:repeat(7,minmax(110px,1fr));}
}

@media(max-width:680px) and (orientation:portrait){
  .top-title{grid-template-columns:1fr auto;align-items:start}
  .top-title h1{font-size:clamp(1.9rem,11vw,3rem)}
}


/* Version 1.38: iPhone modal scrolling polish */
.modal-bg{
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left));
}
.modal{
  width:min(780px, 100%);
  max-height:calc(100dvh - 24px);
  overflow-y:auto;
  overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  touch-action:pan-y;
  padding:0;
}
.modal > *{
  margin-left:16px;
  margin-right:16px;
}
.modal-head{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(10px);
  margin:0;
  padding:14px 16px 12px;
  border-bottom:1px solid var(--border);
  border-radius:26px 26px 0 0;
}
.modal-head + .tabs{
  margin-top:12px;
}
.modal .settings-panel:last-child,
.modal #activityPanel,
.modal #usersPanel,
.modal #profilePanel,
.modal #backupPanel,
.modal #smtpPanel,
.modal #versionsPanel,
.modal #passwordPanel{
  padding-bottom:18px;
}
.tabs{
  padding-bottom:4px;
  -webkit-overflow-scrolling:touch;
}

@media(max-width:680px), (orientation:landscape) and (max-height:740px){
  .modal-bg{
    align-items:stretch;
    padding:max(8px, env(safe-area-inset-top)) max(8px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left));
  }
  .modal{
    width:100%;
    max-height:calc(100dvh - 16px);
    border-radius:22px;
  }
  .modal-head{
    border-radius:22px 22px 0 0;
    padding:12px 14px 10px;
  }
  .modal > *{
    margin-left:14px;
    margin-right:14px;
  }
  .tabs{
    display:flex;
    gap:6px;
    overflow-x:auto;
    overflow-y:hidden;
    scrollbar-width:none;
    margin-top:10px;
  }
  .tabs::-webkit-scrollbar{display:none}
  .tabs button{flex:0 0 auto;white-space:nowrap}
  .settings-panel.active{display:block}
}


/* Version 1.39: prevent day header date overflow in landscape */
.day-head{
  min-width:0;
}
.day-head .day-name{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}
.day-head .date{
  flex:0 1 auto;
  min-width:0;
  max-width:48%;
  overflow:hidden;
  text-overflow:ellipsis;
  text-align:right;
}

@media(orientation:landscape) and (max-height:740px){
  .day-head{
    align-items:flex-start;
    gap:6px;
  }
  .day-head .date{
    font-size:.76rem;
    line-height:1.15;
    white-space:normal;
    overflow-wrap:anywhere;
    max-width:42%;
  }
  .day-head .day-name{
    font-size:.96rem;
    line-height:1.15;
  }
}


/* Version 1.41: meal history modal */
.meal-history-list{display:grid;gap:8px;padding-bottom:18px}
.history-row{display:grid;grid-template-columns:135px minmax(0,1fr);gap:12px;align-items:start;border:1px solid var(--border);border-radius:16px;background:#fff;padding:11px}
.history-date{font-weight:700;color:#0f172a;white-space:nowrap}
.history-meal strong,.history-meal small{display:block}
.history-meal small{color:var(--muted);margin-top:3px;white-space:pre-wrap}
.history-empty{border:1px solid var(--border);border-radius:16px;background:#fff;padding:14px}
@media(max-width:680px){.history-row{grid-template-columns:110px minmax(0,1fr)}.bottom{gap:6px}.bottom button{min-width:0;flex:1}}

/* Version 1.43: ren månedsvisning uden dage fra andre måneder */
.mday .mdate{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.mday .mdate small{font-size:.72rem;color:var(--muted);font-weight:800;white-space:nowrap}

/* Version 1.46: afkort lange måltidsnavne i ugevisning */
.week .day,
.week .meal{
  min-width:0;
  overflow:hidden;
}
.week .meal strong{
  display:block;
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}


/* Version 1.49: stop iOS auto-zoom ved input uden at ændre feltstørrelser */
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}
input,select,textarea{
  touch-action:manipulation;
}


/* Version 1.51: deaktiver double-tap zoom på touch-skærme */
html,body{
  touch-action:manipulation;
}
button,a,input,select,textarea,.day,.meal,.bottom-nav button,.toolbar button{
  touch-action:manipulation;
}


/* Version 1.51: global notits som fast toast øverst i synligt vindue */
.global-status{
  position:fixed;
  top:calc(12px + env(safe-area-inset-top));
  left:50%;
  transform:translateX(-50%);
  width:min(720px,calc(100% - 24px));
  margin:0;
  z-index:80;
  pointer-events:none;
}
/* Version 1.52: pending user approval indicator */
#userAdminBtn.has-pending{border-color:#f59e0b;background:#fffbeb;color:#92400e}
.pending-users-box{border:1px solid #fde68a;background:#fffbeb;border-radius:18px;padding:12px;margin:10px 0}
.pending-user-row{border-color:#fde68a}

/* Version 1.54: cleaner user edit layout on desktop without changing mobile layout */
.selected-user-row{
  grid-template-columns:1fr;
  align-items:start;
}
.selected-user-row .user-fields{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  margin-top:10px;
}
.selected-user-row .roles{
  align-items:center;
}
.selected-user-row .last-admin-note{
  flex-basis:100%;
}
@media(max-width:680px){
  .selected-user-row .user-fields{grid-template-columns:1fr}
}


/* Version 1.55: opret bruger som tekstlink under loginboksen og tvungen SMTP-opsætning */
.login-extra{margin:12px auto 0;text-align:center;color:var(--muted);font-weight:650}
.text-link{border:0;background:transparent;box-shadow:none;padding:0;min-height:0;color:var(--accent2);text-decoration:underline;border-radius:0}
.modal-bg.smtp-required .modal{border:2px solid #fde68a}
.warnText{color:#92400e}
.status.warnText{border-color:#fde68a;background:#fffbeb;color:#92400e;border-radius:14px;padding:10px}


/* Version 1.63: tydelig migrationslog ved opstart */
.trash-list{display:grid;gap:10px;margin:10px 0 12px}
.trash-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;border:1px solid var(--border);background:#fff;border-radius:16px;padding:12px}
.trash-row b{display:block;overflow-wrap:anywhere}
.trash-row .nav{justify-content:flex-end}
#mealDate{box-sizing:border-box;display:block;max-width:100%;min-width:0}
@media(max-width:680px){
  #mealForm label{max-width:100%;overflow:hidden}
  #mealDate{width:100%;max-width:100%;min-width:0;box-sizing:border-box;-webkit-appearance:none;appearance:none}
  .trash-row{grid-template-columns:1fr}
  .trash-row .nav{justify-content:flex-start}
}


/* Version 1.66: note/indkøb under måltid og mere diskret metadata */
.meal-note{
  display:block;
  margin-top:5px;
  color:#334155;
  font-size:.88rem;
  line-height:1.35;
  white-space:pre-wrap;
  overflow-wrap:anywhere;
}
.meal-meta{
  display:flex;
  flex-direction:column;
  gap:1px;
  margin-top:8px;
  padding-top:6px;
  border-top:1px solid rgba(105,115,134,.18);
  opacity:.72;
}
.meal-meta small{
  font-size:.73rem;
  line-height:1.25;
  margin-top:0;
  color:var(--muted);
}
.week .meal-note{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Version 1.67: admin-kodeord under Brugere & rettigheder */
.user-password-admin{margin-top:12px;padding-top:10px;border-top:1px solid #e5e7eb}
.user-password-admin h4{margin:0 0 4px;font-size:14px}
.password-inline{display:grid;grid-template-columns:minmax(180px,1fr) auto;gap:8px;align-items:end;margin-top:8px}
.password-inline input{width:100%;box-sizing:border-box}
@media (max-width:720px){.password-inline{grid-template-columns:1fr}.password-inline button{width:100%}}


/* Version 1.72: flyt måltider mellem datoer */
.draggable-meal{cursor:grab}
.draggable-meal:active{cursor:grabbing}
.dragging{opacity:.55}
.day.drag-over,.mday.drag-over{outline:3px dashed var(--accent);outline-offset:3px;background:#eff6ff}
/* Version 1.72.5: editable meal history */
.history-section{display:grid;gap:8px;margin-top:10px}
.history-section h3{margin:8px 0 2px;font-size:1rem;letter-spacing:-.02em}
.history-row.history-approved{background:var(--approved);border-color:var(--approved-border)}
.history-row.history-pending{background:var(--pending);border-color:var(--pending-border)}
.history-row.editable{cursor:pointer}
.history-row.editable:hover{filter:brightness(.985);box-shadow:0 6px 18px rgba(31,41,51,.08)}
.meal-history-list .meal-actions{margin-top:8px}

.history-toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:10px 0 8px;flex-wrap:wrap}
.history-toolbar .views,.history-toolbar .nav{display:flex;gap:8px;flex-wrap:wrap}
.history-period-title{margin:6px 0 12px;font-size:1rem}
@media(max-width:760px){.history-toolbar{align-items:stretch}.history-toolbar .views,.history-toolbar .nav{width:100%}.history-toolbar button{flex:1}}
