/* Halsen IF · Cup No.1 – foreldreside
   Pluto Proto-rammeverk med Halsens farger (rød + mørk header). Mobil-først. */

:root{
  --red:#d81e2c;          /* Halsen rød */
  --red-deep:#b3151f;
  --ink:#15181c;          /* mørk header/footer */
  --ink-2:#23282e;
  --bg:#f4f5f6;
  --card:#ffffff;
  --text:#1a1d21;
  --muted:#646c75;
  --line:#e6e8eb;
  --radius:16px;
  --pill:999px;
  --shadow:0 1px 2px rgba(0,0,0,.04),0 8px 24px rgba(0,0,0,.06);
  --maxw:680px;
  font-size:16px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  line-height:1.55;-webkit-font-smoothing:antialiased;
}
h1,h2,h3{letter-spacing:-.02em;line-height:1.15;margin:0}
p{margin:.5em 0}
a{color:var(--red-deep)}

/* ---------- PASSORD-SPERRE ---------- */
#gate{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px;
  background:linear-gradient(160deg,var(--ink),#2a3036)}
.gate-card{width:100%;max-width:360px;background:var(--card);border-radius:20px;
  padding:30px 26px;text-align:center;box-shadow:var(--shadow)}
.gate-logo{font-weight:800;letter-spacing:.08em;color:var(--red);font-size:14px;margin-bottom:14px}
.gate-card h1{font-size:20px;font-weight:800;margin-bottom:8px}
.gate-card p{color:var(--muted);font-size:14px;margin:0 0 18px}
.gate-card input{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:12px;
  font:inherit;font-size:16px;text-align:center;margin-bottom:12px}
.gate-card input:focus{outline:none;border-color:var(--red)}
.gate-err{color:var(--red);font-size:13px;font-weight:600;margin:0}

/* ---------- HEADER ---------- */
header.top{position:sticky;top:0;z-index:30;background:var(--ink);color:#fff;
  padding:14px 18px;display:flex;align-items:center;gap:10px}
header.top .logo{font-weight:800;letter-spacing:.06em;font-size:15px;color:#fff}
header.top .logo b{color:var(--red)}
header.top .tag{margin-left:auto;font-size:12px;color:#aeb6bd;font-weight:600}

/* sticky chip-nav */
nav.chips{position:sticky;top:50px;z-index:25;background:rgba(244,245,246,.96);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
  display:flex;gap:8px;overflow-x:auto;padding:10px 14px;-webkit-overflow-scrolling:touch;
  scrollbar-width:none}
nav.chips::-webkit-scrollbar{display:none}
nav.chips a{flex:0 0 auto;text-decoration:none;color:var(--text);font-weight:600;font-size:13px;
  background:#fff;border:1px solid var(--line);border-radius:var(--pill);padding:7px 14px;white-space:nowrap}
nav.chips a:active{background:var(--red);color:#fff;border-color:var(--red)}

/* ---------- HERO ---------- */
.hero{background:linear-gradient(155deg,var(--ink),#2c333a);color:#fff;
  padding:34px 22px 38px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-40px;top:-40px;width:180px;height:180px;
  background:var(--red);opacity:.18;border-radius:30px;transform:rotate(20deg)}
.hero .eyebrow{color:var(--red);font-weight:800;letter-spacing:.08em;font-size:12px;text-transform:uppercase}
.hero h1{font-size:30px;font-weight:800;margin:8px 0 6px}
.hero .dato{display:inline-block;background:var(--red);color:#fff;font-weight:700;
  border-radius:var(--pill);padding:5px 14px;font-size:14px;margin-top:6px}
.hero p{color:#c8ced3;font-size:14.5px;max-width:42ch;margin-top:14px}

/* ---------- LAYOUT ---------- */
main{max-width:var(--maxw);margin:0 auto;padding:18px 14px 40px;
  display:flex;flex-direction:column;gap:16px}
section.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px 18px;box-shadow:var(--shadow);scroll-margin-top:104px}
section.card > h2{font-size:19px;font-weight:800;display:flex;align-items:center;gap:10px;margin-bottom:6px}
section.card > h2::before{content:"";width:5px;height:22px;background:var(--red);border-radius:3px;flex:0 0 auto}

.status{display:inline-block;background:#fff4f5;color:var(--red-deep);border:1px solid #f3c9cd;
  border-radius:var(--pill);padding:4px 11px;font-size:12.5px;font-weight:700;margin:6px 0}

/* program / dager */
.day{padding:12px 0;border-bottom:1px solid var(--line)}
.day:last-child{border-bottom:none;padding-bottom:0}
.day h3{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:5px}
.day ul{margin:0;padding-left:18px;color:var(--text)}
.day li{margin:3px 0;font-size:14.5px}

/* enkel liste m/ ikon */
.rule{display:flex;gap:12px;align-items:flex-start;padding:11px 0;border-bottom:1px solid var(--line)}
.rule:last-child{border-bottom:none}
.rule .ic{font-size:20px;flex:0 0 auto;line-height:1.2}
.rule p{margin:0;font-size:14.5px;font-weight:600}
.info-box{background:#f7f8f9;border:1px dashed var(--line);border-radius:12px;
  padding:12px 14px;font-size:13.5px;color:var(--muted);margin-top:12px}

/* enkel punktliste (pakkeliste) */
ul.facts{margin:.2em 0;padding-left:20px}
ul.facts li{margin:7px 0;font-size:14.5px}

/* tabeller / rader */
.row{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.row:last-child{border-bottom:none}
.row .k{color:var(--text)}
.row .v{font-weight:700;white-space:nowrap;text-align:right;color:var(--ink)}
.row.sum{border-top:2px solid var(--ink);border-bottom:none;margin-top:2px}
.row.sum .k,.row.sum .v{font-weight:800}

/* meal/ferje mini-grid */
.kv{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--line);font-size:14.5px}
.kv:last-child{border-bottom:none}
.kv .k{font-weight:700;color:var(--ink)}
.kv .v{color:var(--muted);text-align:right}

/* transport-alternativer */
.opt{border:1px solid var(--line);border-radius:12px;padding:13px 14px;margin-top:10px}
.opt .h{display:flex;justify-content:space-between;gap:10px;align-items:baseline}
.opt .h b{font-size:15px}
.opt .pris{color:var(--red-deep);font-weight:800;white-space:nowrap;font-size:14px}
.opt .note{color:var(--muted);font-size:13px;margin:5px 0 0}

.husk{background:var(--red);color:#fff;border-radius:12px;padding:11px 14px;font-weight:700;
  font-size:14px;margin-top:12px;display:flex;gap:9px;align-items:center}

/* kontakt */
.contact{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--line)}
.contact:last-child{border-bottom:none}
.contact .av{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;
  display:grid;place-items:center;font-weight:800;flex:0 0 auto}
.contact .n{font-weight:700}
.contact .r{color:var(--muted);font-size:13px}

footer{background:var(--ink);color:#aeb6bd;text-align:center;padding:22px 18px;font-size:12.5px}
footer b{color:#fff}

@media (min-width:560px){
  .hero h1{font-size:36px}
  main{padding:24px 18px 48px}
}
