/* ANPG-system — brand tokens hentet direkte fra carlsbergcamping.dk's tema. */
:root {
  /* Brand-farver (matcher --wp--preset--color--* fra carlsbergcamping.dk) */
  --cc-base:        #f7f7f7;   /* sidebaggrund */
  --cc-contrast:    #181818;   /* tekst + footer */
  --cc-knap:        #009942;   /* primær CTA-grøn */
  --cc-knap-hover:  #07bf54;   /* hover */
  --cc-surface:     #ffffff;   /* kort */
  --cc-line:        #e3e3e3;
  --cc-muted:       #6b6b6b;
  --cc-error:       #c0392b;
  --cc-success:     var(--cc-knap);

  --radius:         12px;
  --shadow-sm:      0 1px 2px rgba(24,24,24,.06), 0 4px 12px rgba(24,24,24,.04);

  /* Typografi (matcher --wp--preset--font-* fra carlsbergcamping.dk) */
  --cc-font:        "Manrope", "Segoe UI", system-ui, -apple-system, sans-serif;
  --cc-fs-medium:   clamp(1rem, 1rem + ((1vw - 0.2rem) * 0.196), 1.125rem);
  --cc-fs-large:    clamp(1.125rem, 1.125rem + ((1vw - 0.2rem) * 0.392), 1.375rem);
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font: var(--cc-fs-medium) / 1.55 var(--cc-font);
  background: var(--cc-base);
  color: var(--cc-contrast);
  -webkit-font-smoothing: antialiased;
}

/* ─── Header ─── */
.site-header {
  background: var(--cc-surface);
  border-bottom: 1px solid var(--cc-line);
  padding: .9rem 1.5rem;
  display: flex; align-items: center; gap: 1rem;
}
.site-header .brand-logo {
  display: inline-flex; align-items: center; text-decoration: none;
}
.site-header .brand-logo img {
  height: 44px; width: auto; display: block;
}
.site-header .brand-text {
  font-weight: 700; color: var(--cc-contrast); text-decoration: none;
  letter-spacing: .02em;
}
.site-header .spacer { flex: 1; }
.site-header nav a {
  color: var(--cc-contrast); text-decoration: none; margin-left: 1.25rem;
  font-weight: 600;
}
.site-header nav a:hover { color: var(--cc-knap-hover); }

/* ─── Layout ─── */
.container { max-width: 920px; margin: 0 auto; padding: 1.5rem 1.25rem 4rem; }
.card {
  background: var(--cc-surface);
  border: 1px solid var(--cc-line);
  border-radius: var(--radius);
  padding: 1.75rem;
  box-shadow: var(--shadow-sm);
  margin-bottom: 1.25rem;
}
h1 {
  font: 700 clamp(1.6rem, 1.4rem + 1.2vw, 2.25rem)/1.2 var(--cc-font);
  color: var(--cc-contrast); margin: 0 0 .5rem; letter-spacing: -.01em;
}
h2 {
  font: 700 1.35rem/1.3 var(--cc-font);
  color: var(--cc-contrast); margin: 0 0 .75rem;
  padding-bottom: .4rem; border-bottom: 1px solid var(--cc-line);
}
p  { margin: .5rem 0; }
a  { color: var(--cc-knap); text-decoration: none; }
a:hover { color: var(--cc-knap-hover); text-decoration: underline; }

/* ─── Forms ─── */
form label { display: block; margin: .85rem 0; font-weight: 600; }
input, button, select, textarea {
  font: inherit;
  padding: .65rem .9rem;
  border: 1px solid var(--cc-line);
  border-radius: 8px;
  background: var(--cc-surface);
  color: var(--cc-contrast);
}
input[type="text"], input[type="password"], input[type="date"], input[type="email"] {
  width: 100%; max-width: 380px;
}
input[readonly] { background: var(--cc-base); color: var(--cc-muted); }
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--cc-knap);
  box-shadow: 0 0 0 3px rgba(0,153,66,.18);
}
button {
  background: var(--cc-knap);
  color: #fff;
  border-color: var(--cc-knap);
  cursor: pointer;
  font-weight: 700;
  padding: .7rem 1.4rem;
  border-radius: 999px;     /* CC bruger pille-knapper */
  transition: background .15s ease;
}
button:hover { background: var(--cc-knap-hover); border-color: var(--cc-knap-hover); }
button.secondary {
  background: transparent; color: var(--cc-knap); border-color: var(--cc-knap);
}
button.secondary:hover { background: rgba(0,153,66,.08); color: var(--cc-knap-hover); }
button.danger { background: var(--cc-error); border-color: var(--cc-error); }
button.danger:hover { background: #d44637; border-color: #d44637; }

a.button {
  display: inline-block; background: var(--cc-knap); color: #fff;
  border: 1px solid var(--cc-knap); padding: .7rem 1.4rem;
  border-radius: 999px; text-decoration: none; font-weight: 700;
  transition: background .15s ease;
}
a.button:hover { background: var(--cc-knap-hover); border-color: var(--cc-knap-hover); color: #fff; text-decoration: none; }

.link-button {
  background: transparent; border: 0; color: var(--cc-knap);
  padding: 0 .25rem; cursor: pointer; font: inherit; border-radius: 0;
}
.link-button:hover { background: transparent; text-decoration: underline; color: var(--cc-knap-hover); }
.link-button.danger { color: var(--cc-error); font-weight: 700; }

/* Plate-chips */
.plate-chip {
  display: inline-flex; align-items: center; gap: .35rem;
  background: rgba(0,153,66,.10); color: var(--cc-contrast);
  padding: .2rem .55rem .2rem .7rem;
  border-radius: 999px; margin: .15rem .25rem .15rem 0;
  font-weight: 700; font-size: .95em; letter-spacing: .03em;
}

/* ─── Flash ─── */
.flash { padding: 0 1rem; max-width: 920px; margin: 1rem auto 0; }
.flash--error,
.flash--success {
  padding: .65rem 1rem; margin: .35rem 0; border-radius: 8px; color: #fff; font-weight: 600;
}
.flash--error   { background: var(--cc-error); }
.flash--success { background: var(--cc-success); }

/* ─── Admin header ─── */
.admin-header { display: flex; gap: .75rem; align-items: center; flex-wrap: wrap; margin-bottom: 1rem; }
.admin-header h1 { margin: 0; flex: 1; }

/* ─── Inline rows (forms i tabel) ─── */
.row {
  display: flex; gap: .5rem; flex-wrap: wrap; align-items: end;
  margin: 1rem 0; padding: 1rem;
  background: var(--cc-base); border: 1px solid var(--cc-line); border-radius: 10px;
}
.row input { width: auto; flex: 1 1 140px; max-width: none; }

/* ─── Tables ─── */
table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
th, td { padding: .65rem .75rem; text-align: left; vertical-align: top; border-bottom: 1px solid var(--cc-line); }
th { background: var(--cc-base); font-weight: 700; color: var(--cc-contrast); text-transform: uppercase; font-size: .8em; letter-spacing: .05em; }
tr:hover td { background: rgba(0,153,66,.04); }
code { background: var(--cc-base); padding: .1rem .35rem; border-radius: 4px; font-size: .85em; word-break: break-all; }

/* ─── Lists ─── */
ul { padding-left: 1.25rem; }
ul li { margin: .35rem 0; }

/* ─── Public hero ─── */
.hero { text-align: center; padding: 2.5rem 1rem 1.5rem; }
.hero h1 { font-size: clamp(2rem, 1.5rem + 2vw, 2.75rem); margin-bottom: .75rem; }
.hero .lead { font-size: var(--cc-fs-large); color: var(--cc-muted); margin: 0 auto 1.5rem; max-width: 560px; }

/* ─── Footer ─── */
.site-footer {
  background: var(--cc-contrast);
  color: var(--cc-base);
  padding: 1.5rem 1.25rem;
  text-align: center;
  font-size: .9rem;
  margin-top: 4rem;
}
.site-footer a { color: var(--cc-knap-hover); }

/* ─── Mobile ─── */
@media (max-width: 640px) {
  .container { padding: 1rem; }
  .card { padding: 1.25rem; }
  .row { flex-direction: column; align-items: stretch; }
  .site-header { padding: .75rem 1rem; }
  .site-header .brand-logo img { height: 36px; }
  table, thead, tbody, tr, th, td { display: block; }
  thead { display: none; }
  td { border: none; padding: .15rem 0; }
  tr { border-bottom: 1px solid var(--cc-line); padding: .65rem 0; }
}
