:root{
  --paper:#f4efe4;
  --paper2:#ece4d3;
  --ink:#1d2320;
  --ink2:#56605a;
  --teal:#0f5e5a;
  --teal-d:#0a4441;
  --terra:#c25a3a;
  --line:#d6cdb8;
  --ok:#2f7d4f;
  --warn:#b8862f;
  --card:#fbf8f0;
  --shadow:0 1px 0 rgba(0,0,0,.04), 0 12px 28px -16px rgba(29,35,32,.35);
  --r:14px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:
    radial-gradient(120% 90% at 85% -10%, #f9f5ea 0%, transparent 55%),
    var(--paper);
  color:var(--ink);
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:1080px;margin:0 auto;padding:26px 18px 80px}
header.top{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:22px}
.brand{display:flex;align-items:baseline;gap:12px}
.brand h1{font-family:"Fraunces",serif;font-weight:900;font-size:42px;letter-spacing:-.02em;margin:0;line-height:.9}
.brand .dot{color:var(--terra)}
.brand small{color:var(--ink2);font-weight:500;font-size:13px}
.tabs{display:flex;gap:6px;background:var(--paper2);padding:5px;border-radius:12px;border:1px solid var(--line)}
.tab{appearance:none;border:0;background:transparent;font:inherit;font-weight:600;color:var(--ink2);padding:8px 14px;border-radius:8px;cursor:pointer;font-size:14px}
.tab.active{background:var(--card);color:var(--ink);box-shadow:0 1px 6px -2px rgba(0,0,0,.2)}
.panel{display:none;animation:fade .25s ease}
.panel.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.sectionhead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:6px 0 14px;flex-wrap:wrap}
.sectionhead h2{font-family:"Fraunces",serif;font-weight:600;font-size:22px;margin:0}
.muted{color:var(--ink2);font-size:13.5px}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:18px}
.grid{display:grid;gap:14px}
.beds-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}

.bed{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card)}
.bed .photo{aspect-ratio:4/3;background:var(--paper2);position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer}
.bed .photo img{width:100%;height:100%;object-fit:cover;display:block}
.bed .photo .ph{color:var(--ink2);font-size:13px;text-align:center;padding:14px}
.bed .photo .ph b{display:block;font-size:26px;margin-bottom:4px;color:var(--line)}
.bed .meta{padding:12px}
.bed .meta .nm{font-weight:700;font-size:15px}
.bed .meta .sub{color:var(--ink2);font-size:12.5px;margin-top:2px}
.bed .flags{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}
.chip{font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;background:var(--paper2);color:var(--ink2);border:1px solid var(--line)}
.chip.teal{background:#dcebe9;color:var(--teal-d);border-color:#bcd9d5}
.chip.terra{background:#f3ddd3;color:#8a3a20;border-color:#e6c3b3}
.chip.soon{background:#f5eccf;color:#7a5e16;border-color:#e6d39b}
.bed .editrow{display:flex;gap:6px;padding:0 12px 12px}

label.fld{display:block;font-size:12.5px;font-weight:600;color:var(--ink2);margin:0 0 4px}
input,select,textarea{font:inherit;width:100%;background:var(--card);border:1px solid var(--line);border-radius:9px;padding:9px 10px;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:2px solid #bcd9d5;border-color:var(--teal)}
textarea{resize:vertical;min-height:64px}
.row{display:grid;gap:12px}
.row.c2{grid-template-columns:1fr 1fr}
.row.c3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:620px){.row.c2,.row.c3{grid-template-columns:1fr}}

button.btn{appearance:none;border:0;font:inherit;font-weight:700;cursor:pointer;border-radius:10px;padding:10px 16px;font-size:14px}
.btn.primary{background:var(--teal);color:#fff}
.btn.primary:hover{background:var(--teal-d)}
.btn.terra{background:var(--terra);color:#fff}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--ink)}
.btn.ghost:hover{background:var(--paper2)}
.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:8px}
.btn.icon{padding:6px 9px}
.btn[disabled]{opacity:.55;cursor:wait}

.bookings{display:flex;flex-direction:column;gap:12px}
.booking{border:1px solid var(--line);border-radius:12px;background:var(--card);overflow:hidden}
.booking.bortfalt{opacity:.6}
.bk-head{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer}
.bk-head .when{font-weight:700}
.bk-head .sub{color:var(--ink2);font-size:13px}
.bk-head .right{margin-left:auto;display:flex;align-items:center;gap:10px}
.status{font-size:11.5px;font-weight:700;padding:3px 9px;border-radius:999px;border:1px solid}
.status.planlagt{background:var(--paper2);color:var(--ink2);border-color:var(--line)}
.status.sendt{background:#dcebe9;color:var(--teal-d);border-color:#bcd9d5}
.status.bekreftet{background:#dcf0e2;color:#1f6b3e;border-color:#b6ddc3}
.status.utfort{background:#e6e0f0;color:#5b3f8a;border-color:#cdc1e6}
.status.bortfalt{background:#f3ddd3;color:#8a3a20;border-color:#e6c3b3}
.send-toggle{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--ink2)}
.send-toggle input{width:18px;height:18px;accent-color:var(--terra)}
.bk-body{padding:0 14px 16px;border-top:1px dashed var(--line);display:none}
.booking.open .bk-body{display:block}

.bedpick{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:6px}
.pick{border:1px solid var(--line);border-radius:10px;padding:10px;cursor:pointer;display:flex;flex-direction:column;gap:6px;background:var(--card);transition:.15s}
.pick.on{border-color:var(--teal);background:#eef6f4;box-shadow:0 0 0 2px #bcd9d5 inset}
.pick.disabled{opacity:.5;cursor:not-allowed}
.pick .pk-nm{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:6px}
.pick .pk-nm .mk{width:16px;height:16px;border-radius:5px;border:1.5px solid var(--ink2);display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:#fff}
.pick.on .pk-nm .mk{background:var(--teal);border-color:var(--teal)}
.pick .splitsel{font-size:12px}
.pick img{width:100%;height:64px;object-fit:cover;border-radius:6px;background:var(--paper2)}
.persrow{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:var(--ink2);font-weight:600}
.stepper{display:flex;align-items:center;gap:8px}
.stepper button{width:24px;height:24px;border-radius:6px;border:1px solid var(--line);background:var(--card);font-size:16px;line-height:1;cursor:pointer;color:var(--ink);padding:0}
.stepper button:hover{background:var(--paper2)}
.stepper b{min-width:14px;text-align:center;font-size:14px}

.tally{display:flex;gap:18px;flex-wrap:wrap;margin-top:14px;padding:12px 14px;background:var(--paper2);border-radius:10px}
.tally .t{display:flex;flex-direction:column}
.tally .t b{font-family:"Fraunces",serif;font-size:24px;font-weight:900;line-height:1}
.tally .t span{font-size:11.5px;color:var(--ink2);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:3px}

.empty{text-align:center;color:var(--ink2);padding:40px 16px}
.empty b{display:block;font-family:"Fraunces",serif;font-size:18px;color:var(--ink);margin-bottom:6px}

/* oppdrag */
.order{border:1px solid var(--line);border-radius:12px;background:var(--card);padding:16px;margin-bottom:14px}
.order h3{font-family:"Fraunces",serif;margin:0 0 2px;font-size:19px}
.order .om{color:var(--ink2);font-size:13px;margin-bottom:10px}
.order .beds{display:flex;flex-direction:column;gap:8px;margin:10px 0}
.order .b{display:flex;gap:10px;align-items:center;padding:8px;border:1px solid var(--line);border-radius:9px}
.order .b img{width:54px;height:42px;object-fit:cover;border-radius:6px;background:var(--paper2);flex:none}
.order .b .bn{font-weight:700;font-size:13.5px}
.order .b .bh{font-size:12px;color:var(--ink2)}
.order .note{background:#f5eccf;border:1px solid #e6d39b;border-radius:9px;padding:9px 11px;font-size:13px;margin-top:8px}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.orderhead{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--terra);margin:18px 0 10px}
.orderhead.rest{color:var(--ink2)}

dialog{border:0;border-radius:16px;padding:0;box-shadow:0 30px 60px -20px rgba(0,0,0,.5);max-width:520px;width:92%;background:var(--card)}
dialog::backdrop{background:rgba(29,35,32,.45)}
.dlg-h{padding:16px 18px;border-bottom:1px solid var(--line);font-family:"Fraunces",serif;font-weight:600;font-size:18px}
.dlg-b{padding:18px;display:flex;flex-direction:column;gap:12px}
.dlg-f{padding:14px 18px;border-top:1px solid var(--line);display:flex;gap:8px;justify-content:flex-end}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:11px 18px;border-radius:10px;font-weight:600;font-size:14px;opacity:0;pointer-events:none;transition:.3s;z-index:50}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.savebar{font-size:12px;color:var(--ink2);display:flex;align-items:center;gap:6px}
.savebar .pip{width:8px;height:8px;border-radius:50%;background:var(--ok)}

/* premium PDF-knapp */
.btn.pdf{
  background:linear-gradient(140deg,#23292589 0%,#1d2320 45%,#3a443e 100%) #1d2320;
  color:#ecd9a8;
  border:1px solid #b8862f;
  box-shadow:0 1px 0 rgba(255,255,255,.08) inset, 0 8px 18px -10px rgba(29,35,32,.6);
  letter-spacing:.03em;
  position:relative;
}
.btn.pdf:hover{
  background:linear-gradient(140deg,#2c332e 0%,#242b27 45%,#46524b 100%) #242b27;
  box-shadow:0 1px 0 rgba(255,255,255,.12) inset, 0 10px 22px -10px rgba(29,35,32,.7);
}
.btn.pdf::before{content:"⬇";margin-right:6px;color:#b8862f}

/* mottakervalg paa oppdragsfanen */
.recipients{margin-bottom:14px;padding:14px 16px}
.rec-title{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink2);margin-bottom:8px}
.rec-list{display:flex;gap:8px;flex-wrap:wrap}
.rec{display:flex;align-items:center;gap:7px;border:1px solid var(--line);border-radius:999px;padding:6px 13px;cursor:pointer;font-size:13px;font-weight:600;background:var(--card);transition:.15s;user-select:none}
.rec input{display:none}
.rec.on{border-color:var(--teal);background:#eef6f4;box-shadow:0 0 0 1.5px #bcd9d5 inset;color:var(--teal-d)}
.rec .pip{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--ink2);display:inline-flex;align-items:center;justify-content:center;font-size:9px;color:#fff;flex:none}
.rec.on .pip{background:var(--teal);border-color:var(--teal)}
.rec small{color:var(--ink2);font-weight:500}

/* mottakerliste under innstillinger */
.mrow{display:grid;grid-template-columns:1fr 1.4fr auto auto auto;gap:10px;align-items:center;padding:9px 0;border-bottom:1px dashed var(--line)}
.mrow:last-child{border-bottom:0}
.mrow .akt{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--ink2);white-space:nowrap}
.mrow .akt input{width:17px;height:17px;accent-color:var(--teal)}
@media(max-width:620px){.mrow{grid-template-columns:1fr 1fr;grid-auto-flow:row}}

/* sendelogg */
.lrow{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:var(--card);margin-bottom:8px;font-size:13px}
.lrow .tid{font-weight:700;white-space:nowrap}
.lrow .hvem{color:var(--ink2)}
.lrow .res{margin-left:auto;white-space:nowrap}
.lrow .res.ok{color:var(--ok);font-weight:700}
.lrow .res.feil{color:#8a3a20;font-weight:700}

/* inline soveplasser paa bookingkort */
.cardbeds-label{margin-top:14px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink2)}
.order .toolbar{justify-content:flex-end}

/* innlogging */
.loginbox{max-width:380px;margin:12vh auto 0;padding:0 18px}
.loginbox .card{padding:26px}
.loginbox h1{font-family:"Fraunces",serif;font-weight:900;font-size:38px;letter-spacing:-.02em;margin:0 0 4px;line-height:.9}
.loginbox .dot{color:var(--terra)}
.loginbox p{color:var(--ink2);font-size:13.5px;margin:0 0 18px}
.loginbox input{font-size:20px;letter-spacing:.3em;text-align:center}
.loginbox .btn{width:100%;margin-top:12px}
.loginfeil{background:#f3ddd3;color:#8a3a20;border:1px solid #e6c3b3;border-radius:9px;padding:9px 12px;font-size:13px;margin-bottom:12px}
