/* ============================================================
   NIRUWP Aktivitetssidor – Frontend CSS
   Använder CSS-variabler från NIRUWP-temat
   ============================================================ */

.nakt-wrap {
  --nakt-accent:      var(--accent, #14432a);
  --nakt-accent-hover:var(--accent-hover, #1a5632);
  --nakt-surface:     var(--bg-surface, #f5f0e6);
  --nakt-card:        var(--card-bg, #fff);
  --nakt-text:        var(--text-primary, #1a1a1a);
  --nakt-text-2:      var(--text-secondary, #555);
  --nakt-text-3:      var(--text-muted, #888);
  --nakt-border:      var(--border, #d4cdbf);
  --nakt-radius:      var(--radius-md, 8px);
  --nakt-radius-sm:   var(--radius-sm, 4px);
  --nakt-font-h:      var(--font-display, Georgia, serif);
  --nakt-font-b:      var(--font-body, system-ui, sans-serif);
  --nakt-shadow:      var(--card-shadow, 0 2px 8px rgba(0,0,0,.06));

  max-width: var(--max-width, 1180px);
  margin: 0 auto;
  padding: 2rem 0 4rem;
  color: var(--nakt-text);
  font-family: var(--nakt-font-b);
  font-size: var(--font-size-base, 1rem);
  line-height: 1.7;
}

.nakt-wrap * { box-sizing: border-box; }

.nakt-wrap a {
  color: var(--nakt-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color .15s;
}
.nakt-wrap a:hover { color: var(--nakt-accent-hover); }

/* ── Ingress ── */
.nakt-ingress {
  background: var(--nakt-surface);
  border: 1px solid var(--nakt-border);
  border-radius: var(--nakt-radius);
  padding: clamp(1.2rem, 3vw, 2rem);
  margin-bottom: 1.5rem;
  font-size: 1.08rem;
  color: var(--nakt-text-2);
}

.nakt-note {
  background: var(--nakt-card);
  border-left: 4px solid var(--nakt-accent);
  border-radius: var(--nakt-radius-sm);
  padding: .85rem 1.1rem;
  margin-top: 1rem;
  color: var(--nakt-text);
  font-size: .95rem;
}
.nakt-note p:last-child { margin: 0; }

/* ── Anchor nav ── */
.nakt-anchornav {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 2rem;
}
.nakt-anchornav a {
  display: inline-block;
  background: var(--nakt-card);
  border: 1px solid var(--nakt-border);
  border-radius: var(--nakt-radius-sm);
  padding: .4rem .85rem;
  text-decoration: none;
  color: var(--nakt-accent);
  font-size: .88rem;
  font-weight: 500;
  transition: background .15s, border-color .15s;
}
.nakt-anchornav a:hover { background: var(--nakt-surface); border-color: var(--nakt-accent); }

/* ── Faktarutor ── */
.nakt-facts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}

.nakt-fact {
  background: var(--nakt-surface);
  border: 1px solid var(--nakt-border);
  border-top: 3px solid var(--nakt-accent);
  border-radius: var(--nakt-radius);
  padding: 1.1rem 1.2rem;
  display: flex;
  flex-direction: column;
  gap: .2rem;
}
.nakt-fact__label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--nakt-accent);
}
.nakt-fact__value {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--nakt-text);
  font-family: var(--nakt-font-h);
}
.nakt-fact__note {
  font-size: .85rem;
  color: var(--nakt-text-3);
}

/* ── Händelselista ── */
.nakt-dates { }
.nakt-event-list { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1rem; }

.nakt-event-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: var(--nakt-card);
  border: 1px solid var(--nakt-border);
  border-radius: var(--nakt-radius);
  padding: 1rem 1.2rem;
  text-decoration: none;
  color: var(--nakt-text);
  transition: border-color .15s, box-shadow .15s, transform .15s;
  box-shadow: var(--nakt-shadow);
}
.nakt-event-row:hover {
  border-color: var(--nakt-accent);
  box-shadow: 0 4px 16px rgba(0,0,0,.1);
  transform: translateY(-1px);
  color: var(--nakt-text);
}

.nakt-event-date-badge {
  background: var(--nakt-text);
  color: #fff;
  border-radius: var(--nakt-radius-sm);
  padding: .4rem .75rem;
  text-align: center;
  min-width: 52px;
  flex-shrink: 0;
}
.nakt-event-date-badge__day   { display: block; font-size: 1.4rem; font-weight: 700; line-height: 1; font-family: var(--nakt-font-h); }
.nakt-event-date-badge__month { display: block; font-size: .65rem; font-weight: 700; letter-spacing: .08em; opacity: .7; text-transform: uppercase; }

.nakt-event-row__info { flex: 1; }
.nakt-event-row__info strong { display: block; font-weight: 600; font-size: 1rem; }
.nakt-event-row__meta { display: flex; flex-wrap: wrap; gap: .35rem .85rem; font-size: .83rem; color: var(--nakt-text-3); margin-top: .2rem; }

.nakt-event-row__arrow { width: 20px; height: 20px; color: var(--nakt-text-3); flex-shrink: 0; }

.nakt-booking-info { color: var(--nakt-text-2); font-size: .9rem; margin-top: .75rem; }

/* ── Sektioner ── */
.nakt-section {
  margin: 2.5rem 0;
  padding: clamp(1.2rem, 3vw, 2rem);
  background: var(--nakt-surface);
  border: 1px solid var(--nakt-border);
  border-radius: var(--nakt-radius);
}

.nakt-section__title {
  font-family: var(--nakt-font-h);
  font-size: clamp(1.3rem, 3vw, 1.8rem);
  font-weight: 700;
  color: var(--nakt-text);
  margin: 0 0 1rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--nakt-border);
  line-height: 1.2;
}

.nakt-section__text { color: var(--nakt-text-2); margin-bottom: 1.2rem; }
.nakt-section__text p:last-child { margin: 0; }

/* ── Kort i sektioner ── */
.nakt-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .85rem;
}
/* Sista kortet tar full bredd om det är ensamt på sin rad (udda antal) */
.nakt-card:last-child:nth-child(odd) {
  grid-column: 1 / -1;
}

.nakt-card {
  background: var(--nakt-card);
  border-left: 3px solid var(--nakt-accent);
  border-radius: var(--nakt-radius-sm);
  padding: .9rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: .3rem;
  box-shadow: var(--nakt-shadow);
}
.nakt-card__title {
  color: var(--nakt-accent);
  font-weight: 700;
  font-size: .9rem;
  display: block;
}

/* Swish-inlinemärke */
.nakt-swish {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--nakt-surface);
  border: 1px solid var(--nakt-border);
  border-radius: var(--nakt-radius-sm);
  padding: .3rem .65rem;
  margin-top: .35rem;
}
.nakt-swish code { color: var(--nakt-accent); font-weight: 700; font-size: 1.05rem; }
.nakt-copy-btn {
  border: 1px solid var(--nakt-border);
  background: var(--nakt-card);
  color: var(--nakt-accent);
  cursor: pointer;
  padding: .25rem .55rem;
  border-radius: var(--nakt-radius-sm);
  font-size: .82rem;
  transition: background .15s;
}
.nakt-copy-btn:hover { background: var(--nakt-surface); }

/* ── Karta ── */
.nakt-map__embed iframe {
  width: 100%;
  height: 420px;
  border: 0;
  display: block;
  border-radius: var(--nakt-radius) var(--nakt-radius) 0 0;
}
.nakt-map__meta {
  background: var(--nakt-card);
  border: 1px solid var(--nakt-border);
  border-top: 0;
  border-radius: 0 0 var(--nakt-radius) var(--nakt-radius);
  padding: .85rem 1rem;
  font-size: .9rem;
}
.nakt-map.nakt-section { padding: 0; overflow: hidden; }
.nakt-map .nakt-section__title { padding: 1rem 1.2rem .6rem; margin: 0; border-radius: 0; }

/* ── FAQ ── */
.nakt-faq__item {
  background: var(--nakt-card);
  border: 1px solid var(--nakt-border);
  border-radius: var(--nakt-radius);
  margin-bottom: .5rem;
  overflow: hidden;
  box-shadow: var(--nakt-shadow);
}
.nakt-faq__item[open] { border-color: var(--nakt-accent); }

.nakt-faq__q {
  cursor: pointer;
  padding: .9rem 1.2rem;
  color: var(--nakt-text);
  font-weight: 600;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  transition: background .15s;
  font-size: .95rem;
}
.nakt-faq__q::-webkit-details-marker { display: none; }
.nakt-faq__q::after { content: '+'; color: var(--nakt-accent); font-size: 1.3rem; font-weight: 400; line-height: 1; transition: transform .2s; }
.nakt-faq__item[open] .nakt-faq__q::after { content: '−'; }
.nakt-faq__q:hover { background: var(--nakt-surface); }

.nakt-faq__a {
  border-top: 1px solid var(--nakt-border);
  padding: .9rem 1.2rem;
  color: var(--nakt-text-2);
  font-size: .95rem;
}
.nakt-faq__a p:last-child { margin: 0; }

/* ── Kontakt ── */
.nakt-contact {
  background: var(--bg-dark, var(--nakt-accent));
  border-color: transparent;
  color: rgba(255,255,255,.85);
}
.nakt-contact .nakt-section__title { color: #fff; border-bottom-color: rgba(255,255,255,.15); }
.nakt-contact a { color: rgba(255,255,255,.8); }
.nakt-contact a:hover { color: #fff; }

.nakt-contact__grid { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 1rem; }
.nakt-contact__row { display: flex; gap: .75rem; align-items: baseline; flex-wrap: wrap; }
.nakt-contact__label { font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: rgba(255,255,255,.45); min-width: 70px; }
.nakt-contact__text { color: rgba(255,255,255,.6); font-size: .9rem; margin-top: .75rem; }

/* ── Responsivt ── */
@media (max-width: 640px) {
  .nakt-facts { grid-template-columns: 1fr 1fr; }
  .nakt-cards { grid-template-columns: 1fr; }
  .nakt-map__embed iframe { height: 280px; }
  .nakt-event-row { gap: .75rem; padding: .85rem 1rem; }
}
@media (max-width: 400px) {
  .nakt-facts { grid-template-columns: 1fr; }
}
