/* ============================================================
   HTK Utleie — delt designsystem
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  /* ink + neutrals (warm) */
  --ink:#16140f;
  --ink-2:#4c473e;
  --ink-3:#857f73;
  --bg:#f3f2ed;
  --surface:#ffffff;
  --surface-2:#fbfaf6;
  --line:#e6e2d9;
  --line-2:#d6d1c5;

  /* brand */
  --brand:#0f6e29;
  --brand-d:#0a5420;
  --brand-l:#e6f1e7;
  --brand-ll:#f1f7f1;
  --signal:#ffce00;        /* enerpac-gul, sparsomt */

  /* status */
  --free:#2f9e44;  --free-bg:#e9f6ec;
  --low:#bb7d10;   --low-bg:#fbf1da;
  --out:#c0392b;   --out-bg:#fae9e6;

  --radius:9px;
  --radius-s:6px;
  --radius-l:14px;
  --shadow-s:0 1px 2px rgba(22,20,15,.06), 0 1px 1px rgba(22,20,15,.04);
  --shadow-m:0 4px 14px rgba(22,20,15,.08);
  --shadow-l:0 18px 50px rgba(22,20,15,.20);

  --display:'Space Grotesk',sans-serif;
  --sans:'IBM Plex Sans',system-ui,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,monospace;

  --maxw:1320px;
  --hdr:62px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);
  font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{margin:0;font-family:var(--display);font-weight:600;line-height:1.08;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
.mono{font-family:var(--mono);font-feature-settings:"tnum" 1}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}

/* ---------- utility bar ---------- */
.util{background:var(--ink);color:#d8d3c8;font-size:12.5px;border-bottom:2px solid var(--signal)}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:34px}
.util a{color:#d8d3c8}
.util a:hover{color:#fff;text-decoration:underline;text-underline-offset:2px}
.util .u-r{display:flex;align-items:center;gap:20px}
.util .u-r span{display:inline-flex;align-items:center;gap:7px}
.util .dotsep{color:#5f594d}
.util svg{width:14px;height:14px;opacity:.8}

/* ---------- header ---------- */
.hdr{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.6) blur(10px);border-bottom:1px solid var(--line)}
.hdr .wrap{display:flex;align-items:center;gap:26px;height:var(--hdr)}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand .brandlogo{height:29px;width:auto;display:block}
.brand .brandtag{font-family:var(--display);font-weight:600;font-size:13px;color:var(--ink-3);border-left:1.5px solid var(--line-2);padding-left:12px;letter-spacing:.01em}
.brand .mk{width:38px;height:38px;border-radius:9px;background:var(--brand);display:grid;place-items:center;box-shadow:inset 0 -2px 0 rgba(0,0,0,.18)}
.brand .mk svg{width:23px;height:23px}
.brand .wm{display:flex;flex-direction:column;line-height:1}
.brand .wm b{font-family:var(--display);font-weight:700;font-size:16px;letter-spacing:-.02em}
.brand .wm small{font-size:10.5px;letter-spacing:.16em;color:var(--ink-3);text-transform:uppercase;margin-top:3px}
.nav{display:flex;align-items:center;gap:5px;margin-left:6px}
.nav a{padding:8px 13px;border-radius:var(--radius-s);font-size:14.5px;font-weight:500;color:var(--ink-2);white-space:nowrap}
.nav a:hover{background:var(--surface-2);color:var(--ink)}
.nav a.on{color:var(--brand-d);background:var(--brand-l)}
.hdr .sp{flex:1}
.hdr-r{display:flex;align-items:center;gap:12px;flex-shrink:0}
.tlink{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:500;color:var(--ink-2);padding:8px 10px;border-radius:var(--radius-s);white-space:nowrap;flex-shrink:0}
.tlink:hover{background:var(--surface-2)}
.tlink svg{width:16px;height:16px}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:14px;
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);
  padding:9px 15px;border-radius:var(--radius-s);cursor:pointer;transition:.13s;white-space:nowrap}
.btn:hover{border-color:var(--ink-3);background:var(--surface-2)}
.btn svg{width:16px;height:16px}
.btn.brand{background:var(--brand);border-color:var(--brand-d);color:#fff;box-shadow:var(--shadow-s)}
.btn.brand:hover{background:var(--brand-d)}
.btn.ghost{border-color:transparent;background:transparent}
.btn.ghost:hover{background:var(--surface-2);border-color:var(--line)}
.btn.sm{padding:6px 11px;font-size:13px;gap:6px}
.btn.sm svg{width:14px;height:14px}
.btn.block{width:100%;justify-content:center}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* cart button w/ count */
.cartbtn{position:relative}
.cartbtn .cnt{position:absolute;top:-7px;right:-7px;min-width:19px;height:19px;padding:0 5px;border-radius:11px;
  background:var(--signal);color:var(--ink);font-family:var(--mono);font-weight:600;font-size:11px;
  display:grid;place-items:center;border:1.5px solid #fff;box-shadow:var(--shadow-s)}
.cartbtn .cnt:empty,.cartbtn .cnt[data-n="0"]{display:none}

/* ---------- chips ---------- */
.chip{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--ink-2);
  border:1px solid var(--line-2);background:var(--surface);padding:5px 11px;border-radius:20px;cursor:pointer;transition:.12s;white-space:nowrap}
.chip:hover{border-color:var(--ink-3)}
.chip.on{background:var(--ink);border-color:var(--ink);color:#fff}
.chip.spec{cursor:default;background:var(--surface-2);border-color:var(--line);color:var(--ink-2);font-family:var(--mono);font-size:12px;padding:3px 9px;border-radius:5px}
.chip.spec:hover{border-color:var(--line)}

/* ---------- badges / status ---------- */
.stat{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;
  border-radius:6px;padding:3px 8px;font-family:var(--mono)}
.stat .led{width:7px;height:7px;border-radius:50%;flex:none}
.stat.free{background:var(--free-bg);color:#1d6b2c}.stat.free .led{background:var(--free)}
.stat.low{background:var(--low-bg);color:#8a5c08}.stat.low .led{background:var(--low)}
.stat.out{background:var(--out-bg);color:#9c2d22}.stat.out .led{background:var(--out)}

.availbar{height:5px;border-radius:4px;background:var(--line);overflow:hidden;margin-top:6px;width:84px}
.availbar i{display:block;height:100%;border-radius:4px;background:var(--free)}
.availbar.low i{background:var(--low)}.availbar.out i{background:var(--out)}

/* ---------- thumbnails / image placeholder ---------- */
.thumb{position:relative;background:
    radial-gradient(120% 120% at 30% 20%, #fdfdfb 0%, #f1efe9 70%, #e9e6dd 100%);
  border:1px solid var(--line);border-radius:var(--radius-s);overflow:hidden;display:grid;place-items:center;flex:none}
.thumb svg{width:46%;height:46%;color:var(--ink-3);opacity:.55}
.thumb .thumbimg{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#fff;z-index:1}
.thumb .sx{position:absolute;left:6px;bottom:5px;z-index:2;font-family:var(--mono);font-size:9px;font-weight:600;color:var(--ink-3);
  background:rgba(255,255,255,.7);padding:0 4px;border-radius:3px;letter-spacing:.02em}
.thumb.big svg{width:38%;height:38%}

/* price */
.price{font-family:var(--mono);font-weight:600;font-size:15px;letter-spacing:-.02em}
.price .k{font-size:11px;color:var(--ink-3);font-weight:400}
.price-2{font-family:var(--mono);font-size:12.5px;color:var(--ink-3)}

/* ---------- cards ---------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-s)}

/* ---------- drawer ---------- */
.scrim{position:fixed;inset:0;background:rgba(22,20,15,.42);opacity:0;visibility:hidden;transition:.22s;z-index:90;backdrop-filter:blur(1px)}
.scrim.on{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:var(--surface);
  box-shadow:var(--shadow-l);transform:translateX(100%);transition:transform .26s cubic-bezier(.4,.05,.2,1);z-index:100;display:flex;flex-direction:column}
.drawer.on{transform:none}
.drawer h3{font-size:19px}
.drawer .d-hd{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}
.drawer .d-bd{flex:1;overflow:auto;padding:6px 20px}
.drawer .d-ft{border-top:1px solid var(--line);padding:16px 20px;background:var(--surface-2)}
.iconbtn{width:34px;height:34px;display:grid;place-items:center;border-radius:8px;border:1px solid transparent;background:transparent;cursor:pointer;color:var(--ink-2)}
.iconbtn:hover{background:var(--surface-2);border-color:var(--line)}
.iconbtn svg{width:19px;height:19px}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:110;opacity:0;visibility:hidden;transition:.2s;padding:20px}
.modal.on{opacity:1;visibility:visible}
.modal .sheet{width:520px;max-width:100%;max-height:92vh;overflow:auto;background:var(--surface);border-radius:var(--radius-l);box-shadow:var(--shadow-l);transform:translateY(14px) scale(.98);transition:.22s}
.modal.on .sheet{transform:none}

/* form */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--ink-2);margin-bottom:5px}
.field label .req{color:var(--out)}
.input,.select,.textarea{width:100%;font-family:var(--sans);font-size:14.5px;color:var(--ink);background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--radius-s);padding:10px 12px;transition:.12s}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-l)}
.textarea{resize:vertical;min-height:74px}

/* misc */
.kicker{font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--brand-d)}
.divlabel{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.muted{color:var(--ink-3)}
.hr{height:1px;background:var(--line);border:0;margin:0}

/* ---------- footer ---------- */
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding:46px 26px 30px}
.foot-grid a{word-break:break-word}
.foot-bot{padding:16px 26px;border-top:1px solid #2c2920;display:flex;justify-content:space-between;gap:12px;font-size:12px;color:#7d776b}
@media(max-width:760px){
  .foot-grid{grid-template-columns:1fr 1fr;gap:24px;padding:34px 20px 26px}
}
@media(max-width:460px){
  .foot-grid{grid-template-columns:1fr;gap:20px}
  .foot-bot{flex-direction:column;gap:6px;align-items:flex-start;padding:14px 20px}
}

::selection{background:var(--brand);color:#fff}

/* ---------- vedvarende mini-kurv ---------- */
.minicart{position:fixed;right:20px;bottom:20px;z-index:80;transform:translateY(150%);opacity:0;transition:transform .3s cubic-bezier(.4,.05,.2,1),opacity .2s;pointer-events:none}
.minicart.on{transform:none;opacity:1;pointer-events:auto}
.minicart .mc-open{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line-2);border-radius:14px;box-shadow:var(--shadow-l);padding:10px 14px 10px 12px;cursor:pointer;font-family:var(--sans);min-width:290px;transition:.13s}
.minicart .mc-open:hover{border-color:var(--ink-3)}
.minicart .mc-ic{position:relative;display:grid;place-items:center;width:40px;height:40px;border-radius:10px;background:var(--brand);color:#fff;flex:none}
.minicart .mc-ic svg{width:20px;height:20px}
.minicart .mc-cnt{position:absolute;top:-6px;right:-6px;min-width:19px;height:19px;padding:0 5px;border-radius:11px;background:var(--signal);color:var(--ink);font-family:var(--mono);font-weight:600;font-size:11px;display:grid;place-items:center;border:1.5px solid var(--surface)}
.minicart .mc-txt{display:flex;flex-direction:column;line-height:1.2;text-align:left;flex:1}
.minicart .mc-txt b{font-size:14.5px}
.minicart .mc-txt small{font-size:11.5px;color:var(--ink-3);font-family:var(--mono);margin-top:2px}
.minicart .mc-go{display:inline-flex;align-items:center;gap:5px;font-size:13.5px;font-weight:600;color:var(--brand-d);white-space:nowrap}
.minicart .mc-go svg{width:15px;height:15px}
@media(max-width:560px){
  .minicart{left:12px;right:12px;bottom:12px}
  .minicart .mc-open{width:100%;min-width:0}
}

@media(max-width:1024px){
  .hdr .wrap{gap:16px}
  .tlink span.hide-sm{display:none}
}
@media(max-width:820px){
  .nav{display:none}
}
@media(max-width:760px){
  .brand .brandtag{display:none}
  .brand .brandlogo{height:26px}
}
@media(max-width:680px){
  .util .wrap{justify-content:center}
  .util .u-l{display:none}
}
@media(max-width:560px){
  .hdr-r .tlink{display:none}
}
@media(max-width:430px){
  .util .u-mail{display:none}
}

/* ---------- leiebetingelser (full avtale) ---------- */
.terms-doc{display:flex;flex-direction:column;gap:17px}
.terms-doc .td-sec h4{display:flex;align-items:flex-start;gap:9px;font-family:var(--display);font-weight:600;font-size:13.5px;letter-spacing:.01em;text-transform:uppercase;color:var(--ink);margin:0 0 7px}
.terms-doc .td-n{font-family:var(--mono);font-size:11.5px;font-weight:600;color:#fff;background:var(--brand);min-width:22px;height:22px;border-radius:6px;display:inline-grid;place-items:center;flex:none}
.terms-doc .td-cl{display:flex;gap:9px;font-size:13.5px;line-height:1.55;color:var(--ink-2);margin:0 0 6px}
.terms-doc .td-c{font-family:var(--mono);font-size:11.5px;font-weight:600;color:var(--brand-d);flex:none;min-width:26px}
