:root{
  --bg:#f4f6f8; --card:#fff; --ink:#1f2a33; --muted:#6b7a86;
  --line:#e3e8ec; --brand:#1e6fd9; --brand-d:#1857a8;
  --ok:#2e9e5b; --ok-bg:#e9f7ee; --err:#c0392b; --warn:#b07b00;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--ink); line-height:1.5; font-size:17px;
}
.wrap{max-width:680px;margin:0 auto;padding:16px 14px 60px}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;margin:14px 0;box-shadow:0 1px 2px rgba(0,0,0,.03)}
.center{text-align:center}
.muted{color:var(--muted);font-size:15px}
h1{font-size:24px;margin:0 0 10px}
h2.room{font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:26px 6px 8px}

/* topbar / progress */
.topbar{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--line)}
.topbar-inner{max-width:680px;margin:0 auto;padding:10px 14px}
.addr{font-weight:700;font-size:16px}
.prog-text{font-size:13px;color:var(--muted);margin:2px 0 6px}
.progbar{height:8px;background:var(--line);border-radius:6px;overflow:hidden}
.progfill{height:100%;background:var(--ok);width:0;transition:width .3s ease}

.intro p{margin:8px 0}

/* item card */
.item{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--line);
  border-radius:12px;padding:14px;margin:10px 0}
.item.done{border-left-color:var(--ok);background:var(--ok-bg)}
.item-head{display:flex;align-items:flex-start;gap:10px}
.tick{display:inline-flex;align-items:center;justify-content:center;flex:0 0 24px;width:24px;height:24px;
  border-radius:50%;border:2px solid var(--line);color:transparent;font-weight:700;font-size:15px;margin-top:1px}
.item.done .tick{background:var(--ok);border-color:var(--ok);color:#fff}
.punkt{font-weight:600}
.thumb-wrap{margin:12px 0 4px}
.thumb{width:100%;max-height:240px;object-fit:cover;border-radius:10px;border:1px solid var(--line);display:block}
.item-desc{margin:6px 0 2px;font-size:14.5px;color:#8a5a00;background:#fff7e6;border:1px solid #ffe2a8;border-radius:8px;padding:8px 10px}
.item.na{border-left-color:#9aa7b1;background:#eef1f4}
.item.na .tick{background:#9aa7b1;border-color:#9aa7b1;color:#fff}
.na-note{margin:10px 0 2px;font-size:15px;color:#5a6772;font-style:italic}
.na-line{text-align:center;margin-top:8px}
.na-toggle{background:none;border:none;color:#6b7a86;text-decoration:underline;font-size:14px;font-weight:500;padding:8px 6px;cursor:pointer}
.na-toggle:active{color:#1857a8}
.na-form{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.na-form .na-input{width:100%;padding:11px;border:1px solid var(--line);border-radius:10px;font-size:16px;font-family:inherit}
.na-form .na-save{background:#6b7a86}
.na-form .na-save:active{background:#566069}
.done-toggle{width:100%;margin-top:10px;background:#566069}
.done-toggle.is-done{background:var(--ok)}
.done-toggle.is-done:active{background:#247a47}
.item-status{font-size:13px;margin-top:6px;min-height:16px}
.item-status.ok{color:var(--ok)}
.item-status.err{color:var(--err)}
.item-status.working{color:var(--warn)}

/* buttons */
.btn{display:inline-block;background:var(--brand);color:#fff;border:none;border-radius:10px;
  padding:13px 18px;font-size:16px;font-weight:600;text-decoration:none;cursor:pointer;text-align:center}
.btn:active{background:var(--brand-d)}
.btn[disabled]{background:#b9c4cd;cursor:not-allowed}
.btn.ghost{background:#eef3f8;color:var(--brand-d);border:1px solid #d4e2f1;margin-top:10px}
.filebtn{display:block;position:relative}
.filebtn input{position:absolute;inset:0;opacity:0}
#submitBtn{width:100%;margin-top:8px;padding:16px}

/* form fields */
.fld{display:block;margin:0 0 14px}
.fld>span{display:block;font-weight:600;font-size:15px;margin-bottom:6px}
.fld input,.fld textarea{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;font-size:16px;font-family:inherit}
.confirm{display:flex;gap:10px;align-items:flex-start;margin:6px 0 16px;font-size:15px}
.confirm input{margin-top:4px;width:20px;height:20px;flex:0 0 20px}

.big-check{font-size:54px;color:var(--ok);line-height:1}

/* admin */
.admin-head{background:var(--brand-d);color:#fff;padding:14px}
.admin-head a{color:#fff}
.admin-wrap{max-width:900px;margin:0 auto;padding:18px 14px}
table{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);font-size:15px;vertical-align:top}
th{background:#f0f4f8;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:700}
.b-sendt{background:#eef;color:#34c}
.b-pabegynt{background:#fff3d6;color:var(--warn)}
.b-levert{background:#e3f1ff;color:#1857a8}
.b-godkjent{background:var(--ok-bg);color:var(--ok)}
.linkbox{background:#f0f4f8;border:1px dashed #c3d2e0;border-radius:8px;padding:8px;font-size:13px;word-break:break-all}
.grid2{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.photo-card{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.photo-card img{width:100%;display:block}
.photo-card .cap{padding:8px 10px;font-size:13px}
.flash{background:var(--ok-bg);color:var(--ok);padding:10px 12px;border-radius:8px;margin:10px 0}
