/* ═══════════════════════════════════════════
   DASHBOARD — utökar style.css med dashboard-specifika komponenter
   ═══════════════════════════════════════════ */

/* ─── LOGIN ─── */
/* .login-wrapper ger bara padding — layout (flex-centrering, min-height)
   kommer från .hero--full, bakgrund + mönster från .hero själv. */
.login-wrapper {
  padding: 20px;
}
.login-box {
  background: var(--offwhite);
  border-radius: 20px; padding: 3rem 2.5rem; width: 100%; max-width: var(--w-box);
  text-align: center; position: relative; z-index: 1;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3), 0 0 0 1px rgba(218,165,32,0.15);
}
.login-box h1 {
  font-family: 'Jost', sans-serif;
  font-size: 1.6rem; font-weight: 800; color: var(--burgundy);
  letter-spacing: -0.02em; margin-bottom: 4px;
}
.login-box .sub {
  font-family: 'Jost', sans-serif;
  font-size: 0.8rem; color: var(--pink-hot); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 28px;
}
.login-box input {
  font-family: 'Jost', sans-serif;
  width: 100%; padding: 13px 16px; border: 1px solid var(--border, #EDE6DC);
  border-radius: 10px; font-size: 14px; margin-bottom: 12px; outline: none;
  background: white; transition: border-color 0.2s;
}
.login-box input:focus { border-color: var(--pink-hot); }
.login-box button {
  font-family: 'Jost', sans-serif;
  width: 100%; padding: 13px; border: none; border-radius: 50px;
  background: var(--burgundy); color: white; font-weight: 700;
  font-size: 0.9rem; letter-spacing: 0.04em; text-transform: uppercase;
  cursor: pointer; transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
  margin-top: 6px;
}
.login-box button:hover {
  background: var(--burgundy-deep); transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(94,26,43,0.25);
}
.login-err {
  font-family: 'Source Serif 4', serif;
  color: #c44; font-size: 13px; margin-top: 10px; display: none;
}
.login-box .links {
  font-family: 'Source Serif 4', serif;
  margin-top: 18px; font-size: 13px; color: #999;
}
.login-box .links a {
  font-family: 'Jost', sans-serif;
  color: var(--pink-hot); text-decoration: none; font-weight: 600;
}
.login-box .links a:hover { color: var(--burgundy); }

/* ─── PORTAL CONTAINER ─── */
.dashboard { display: none; }

/* ─── PORTAL WELCOME (ersatte den gamla burgundy-hero) ─── */
.dashboard-welcome {
  /* Bakgrund, position:relative, overflow:hidden, symbolfärg, textfärg
     — allt kommer från .hero-klassen som sitter på samma element. Här
     sätter vi bara sektionspadding och sektions-specifika saker. */
  padding: 5rem 2rem 2.5rem;
}
.dashboard-welcome .container {
  /* Positioning-kontext för att lägga innehållet ovanpå .hero-notes.
     .hero-notes har pointer-events:none så knappar funkar ändå. */
  position: relative;
  z-index: 1;
  max-width: var(--w-content);
  margin: 0 auto;
}
.welcome-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.5rem 2rem; flex-wrap: wrap;
}
.welcome-text {
  /* Tar allt utrymme som knapparna inte behöver.
     min-width säkerställer att rubriken inte krymps så mycket att den
     bryts mellan tecken. När rubrikens naturliga bredd + knapparnas
     bredd + gap överstiger raden, faller welcome-actions ner på egen
     rad som ett helt block.  */
  flex: 1 1 auto; min-width: 240px;
}
.welcome-text .section-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.2em;
  /* pink-hot på burgundy-bg syns snyggt (ljusare nyans av samma hue) */
  color: var(--pink-hot);
  margin-bottom: 0.5rem;
}
.welcome-text h1 {
  font-family: 'Jost', sans-serif;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 800; letter-spacing: -0.02em;
  line-height: 1.15;
  /* Mjukare rosa (inte pink-hot som är för skrikig för rubriker) —
     ger varm välkomstkänsla mot burgundy-bakgrunden. */
  color: var(--pink-light);
  margin: 0;
}
.welcome-actions {
  display: flex; gap: 0.75rem; align-items: center;
  /* Knappgruppen hålls ihop och stannar vänsterjusterad när den
     faller ner på egen rad. flex-shrink: 0 så knapparna aldrig krymps.
     flex-wrap tillåter internt radbrott på allra smalaste skärmar. */
  flex-shrink: 0; flex-wrap: wrap;
}
/* Knapparna sitter i .hero:s mörka bakgrund — btn-outline behöver
   ljusa färger för att synas mot burgundy-gradienten. */
.welcome-actions .btn {
  padding: 0.7rem 1.4rem; font-size: 0.85rem; white-space: nowrap;
}
.welcome-actions .btn-outline {
  color: var(--cream);
  border: 2px solid rgba(255, 249, 242, 0.5);
  background: transparent;
  margin-left: 0;
}
.welcome-actions .btn-outline:hover {
  background: var(--cream); color: var(--burgundy); border-color: var(--cream);
}

/* Ikontext-hantering: på smal skärm kollapsar "Logga ut" till bara ikon.
   Strukturen i HTML: <svg>icon</svg><span class="btn-label">Logga ut</span>
   btn-icon-only-sm gör att texten döms ut när skärmen är ≤420px. */
.btn-icon-only-sm {
  /* Tooltipen kommer från title="" på knappen. */
}

/* ≤420px: "Logga ut" blir kompakt. Admin behåller text. */
@media (max-width: 420px) {
  .btn-icon-only-sm .btn-label {
    /* Göm text men behåll tillgänglighet */
    position: absolute; width: 1px; height: 1px;
    padding: 0; margin: -1px; overflow: hidden;
    clip: rect(0,0,0,0); white-space: nowrap; border: 0;
  }
  .btn-icon-only-sm svg { margin-right: 0 !important; }
  .btn-icon-only-sm {
    flex: 0 0 auto !important;
    padding: 0.7rem 0.9rem !important;
    aspect-ratio: 1; min-width: 44px;
  }
}

/* ≤360px: gammal iPhone SE etc. — stackar knapparna vertikalt
   så admin-knappens text inte klipps. Då finns plats för "Logga ut"-text
   igen på logout-knappen. */
@media (max-width: 360px) {
  .welcome-actions { flex-direction: column; align-items: stretch; width: 100%; }
  .welcome-actions .btn { width: 100%; justify-content: center; }
  .welcome-actions .btn-icon-only-sm {
    aspect-ratio: auto; padding: 0.7rem 1.4rem !important;
  }
  .welcome-actions .btn-icon-only-sm .btn-label {
    /* Visa texten igen — knappen har full bredd så plats finns */
    position: static; width: auto; height: auto;
    padding: inherit; margin: 0; overflow: visible;
    clip: auto; white-space: normal;
  }
  .welcome-actions .btn-icon-only-sm svg { margin-right: 6px !important; }
}

/* ─── PORTAL SECTIONS ─── */
/* Enhetlig cream-bakgrund för alla dashboard-sektioner. Kortens egen vita
   bakgrund + 1px pink-border ger tillräcklig visuell separation utan att
   behöva zebra-variera sektionerna. Cream följer automatiskt med dark-theme
   via CSS-variabeln. */
.dashboard-section { padding: 4rem 2rem; background: var(--cream); }
.dashboard-section .container { max-width: var(--w-content); margin: 0 auto; }

/* ─── PORTAL GRID ─── */
.dashboard-grid-2 {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem;
  align-items: start;
}

/* ─── PORTAL CARDS ─── */
.dashboard-card {
  background: white; border-radius: 16px; padding: 2rem;
  border: 1px solid rgba(214,75,138,0.08);
  box-shadow: 0 2px 15px rgba(94,26,43,0.04);
  transition: box-shadow 0.3s;
}
.dashboard-card:hover { box-shadow: 0 4px 25px rgba(94,26,43,0.08); }
.dashboard-card .card-title {
  font-family: 'Jost', sans-serif;
  font-size: 1.4rem; font-weight: 800; color: var(--burgundy);
  letter-spacing: -0.02em; margin-bottom: 1.5rem; line-height: 1.2;
}

/* Sektion-label (matchar hemsidan) */
.section-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.75rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.2em; color: var(--pink-hot); margin-bottom: 0.5rem;
}
.section-title {
  font-family: 'Jost', sans-serif;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem); font-weight: 800;
  color: var(--burgundy); letter-spacing: -0.02em; margin-bottom: 1rem;
}
.section-desc {
  font-family: 'Source Serif 4', serif;
  font-size: 1.1rem; color: #555; max-width: var(--w-prose);
  margin-bottom: 2.5rem; line-height: 1.8;
}

/* ─── MEDLEMSKORT ─── */
/* Baserat på original /kort/-sidans design, anpassat för inbäddad visning
   i dashboard-card istället för full-screen. Max-width håller kortet i
   mobil-format även på desktop så proportionerna stämmer med en riktig
   hembärbart korttelefon-vy.

   Färgstrategi: brand-färger (burgundy, pink, gold) använder sajtens
   semantiska variabler så de håller en konsekvent palett. Själva kortytans
   ljusa gradient (cream → rosa) hardkodas per theme eftersom --cream och
   --pink-pale byter värden olika i dark mode vilket skulle ge en
   oönskad gradient. */
.member-card {
  width: 100%; max-width: 380px;
  margin: 0 auto 1.25rem;
  border-radius: 24px;
  overflow: hidden;
  background: linear-gradient(170deg, #FFFDF9 0%, #FFF9F2 40%, #FBEAF0 100%);
  box-shadow: 0 10px 32px rgba(94, 26, 43, 0.18), 0 0 0 1px rgba(218, 165, 32, 0.2);
  position: relative;
  font-family: 'Jost', 'Century Gothic', sans-serif;
}

/* Guld-accentlinje i topp och botten */
.member-card-gold-line {
  height: 3px;
  background: linear-gradient(90deg, var(--gold), var(--gold-light), var(--gold));
}

/* Topp-band i burgundy — brand-konsekvent i båda teman */
.member-card-top {
  background: linear-gradient(135deg, var(--burgundy-deep), var(--burgundy));
  padding: 16px 24px 40px;
  position: relative;
  overflow: hidden;
}
.member-card-top::after {
  /* Rundad övergång till ljus/mörk del — samma ton som kortytans topp */
  content: '';
  position: absolute; bottom: -20px; left: -10%; right: -10%;
  height: 40px; background: #FFFDF9;
  border-radius: 50% 50% 0 0;
}
.member-card-org {
  display: flex; align-items: center; gap: 10px; margin-bottom: 4px;
}
.member-card-org-badge {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--pink-hot);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; color: white; font-size: 9px;
}
.member-card-org-name {
  color: white; font-weight: 700; font-size: 13px; letter-spacing: 0.02em;
}
.member-card-type {
  color: var(--pink-light); font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.15em; margin-left: 38px;
}

/* Status-pill i övre högra hörnet */
.member-card-status {
  position: absolute; top: 14px; right: 20px;
  padding: 3px 10px; border-radius: 20px;
  font-size: 9px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.08em;
}
.member-card-status.active { background: rgba(26, 122, 26, 0.18); color: #1A7A1A; }
.member-card-status.inactive { background: rgba(196, 68, 68, 0.18); color: #c44; }

/* Foto — cirkel som överlappar topp/botten. Border matchar kortytan. */
.member-card-photo-area {
  display: flex; justify-content: center;
  margin-top: -28px;
  position: relative; z-index: 2;
}
.member-card-photo {
  width: 100px; height: 100px; border-radius: 50%;
  border: 4px solid #FFFDF9;
  box-shadow: 0 4px 20px rgba(94, 26, 43, 0.2);
  background: var(--pink-pale);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.member-card-photo img { width: 100%; height: 100%; object-fit: cover; }
.member-card-photo-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--pink-hot), #E85B9A);
  color: white; font-weight: 800; font-size: 28px;
}

/* Kroppsinfo: namn, instrument, detaljer */
.member-card-body { padding: 10px 24px 12px; text-align: center; }
.member-card-name {
  font-size: 22px; font-weight: 800; color: var(--burgundy-deep);
  letter-spacing: -0.02em; line-height: 1.2;
}
.member-card-instrument {
  font-size: 13px; color: var(--pink-hot); font-weight: 500;
  margin-top: 2px;
}
.member-card-instrument:empty { display: none; }

.member-card-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(214, 75, 138, 0.2), transparent);
  margin: 10px 0;
}

.member-card-details {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  text-align: center;
}
.member-card-detail-label {
  font-size: 9px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--pink-hot);
}
.member-card-detail-value {
  font-size: 14px; font-weight: 700; color: var(--burgundy-deep); margin-top: 1px;
}

/* QR-område — bakgrunden förblir vit oavsett theme för max kontrast
   vid scanning. Kanten följer pink-accent med låg opacitet. */
.member-card-qr-area {
  display: flex; flex-direction: column; align-items: center;
  padding: 10px 24px 16px;
}
.member-card-qr {
  padding: 8px; background: #ffffff; border-radius: 10px;
  box-shadow: 0 2px 10px rgba(94, 26, 43, 0.08);
  border: 1px solid rgba(214, 75, 138, 0.15);
  width: 120px; height: 120px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  /* Återställ button-defaults så den ser ut som den ursprungliga div:en */
  font: inherit; color: inherit;
}
.member-card-qr:hover {
  transform: scale(1.03);
  box-shadow: 0 4px 16px rgba(94, 26, 43, 0.14);
}
.member-card-qr:active { transform: scale(0.98); }
.member-card-qr:focus-visible {
  outline: 2px solid var(--pink-hot);
  outline-offset: 3px;
}
.member-card-qr svg { width: 100%; height: 100%; display: block; }
.member-card-qr-hint {
  font-size: 10px; color: var(--charcoal); opacity: 0.5;
  margin-top: 6px;
  font-weight: 500; letter-spacing: 0.04em;
}

/* ─── Dark-theme för medlemskortet ───
   Byter ut kortytans ljusa gradient mot en mörk burgundy-toning så
   den harmoniserar med resten av dark-sajten. Topp-bandet lämnas
   oförändrat eftersom det redan är brand-mörkt i båda teman.

   Namn + detail-value byter från burgundy-deep till pink-light — samma
   princip som övriga dark-mode-rubriker på sajten. Foto-ring och
   pseudo-after uppdateras så de matchar kortytans nya topp-ton.

   Två likvärdiga selektorer: (1) automatisk via OS/webbläsar-preferens,
   (2) explicit via data-theme som prefs.js sätter. */
@media (prefers-color-scheme: dark) {
  .member-card {
    background: linear-gradient(170deg, #1E181C 0%, #241A20 40%, #2A1A24 100%);
    box-shadow: 0 10px 32px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(218, 165, 32, 0.25);
  }
  .member-card-top::after { background: #1E181C; }
  .member-card-photo { border-color: #1E181C; background: #2A1A24; }
  .member-card-name,
  .member-card-detail-value { color: var(--pink-light); }
  .member-card-divider {
    background: linear-gradient(90deg, transparent, rgba(242, 175, 196, 0.2), transparent);
  }
}

html[data-theme="dark"] .member-card {
  background: linear-gradient(170deg, #1E181C 0%, #241A20 40%, #2A1A24 100%);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(218, 165, 32, 0.25);
}
html[data-theme="dark"] .member-card-top::after { background: #1E181C; }
html[data-theme="dark"] .member-card-photo { border-color: #1E181C; background: #2A1A24; }
html[data-theme="dark"] .member-card-name,
html[data-theme="dark"] .member-card-detail-value { color: var(--pink-light); }
html[data-theme="dark"] .member-card-divider {
  background: linear-gradient(90deg, transparent, rgba(242, 175, 196, 0.2), transparent);
}

/* ─── FOTO-UPPLOAD-LÄNK (under kortet) ─── */
.card-photo-actions {
  display: flex; justify-content: center; align-items: center;
  gap: 0.75rem; flex-wrap: wrap;
  margin-bottom: 1rem;
}
.photo-upload-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.75rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--pink-hot); cursor: pointer;
}
.photo-upload-label:hover { color: var(--burgundy); }
.photo-status {
  font-family: 'Source Serif 4', serif;
  font-size: 0.8rem; color: #888;
}

/* ─── WALLET-KNAPPAR ───
   Använder Apples och Googles officiella badge-SVG:er (svenskspråkiga).
   Knapparna är bara visuella wrappers som gör SVG-en klickbar — ingen
   egen styling på "Lägg till"-text eftersom det finns i SVG:en.
   Enhetlig höjd så de justerar snyggt när båda visas samtidigt. */
.wallet-buttons {
  display: flex; flex-direction: column; align-items: center;
  gap: 0.6rem;
  max-width: 380px; margin: 0 auto;
}
.wallet-btn {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  display: inline-flex;
  transition: opacity 0.15s ease, transform 0.1s ease;
  /* Apples guidelines: badge ska ha minst 7px touch-marginal runtom.
     Vi ger 4px inset så tapp-ytan är tillräckligt stor utan att ändra
     badgens synliga storlek. */
  padding: 4px;
}
.wallet-btn:hover { opacity: 0.85; }
.wallet-btn:active { transform: scale(0.97); }
.wallet-btn:focus-visible {
  outline: 2px solid var(--pink-hot);
  outline-offset: 2px;
  border-radius: 6px;
}
.wallet-svg {
  display: block;
  height: 44px;   /* enhetlig höjd för båda, Apple + Google-guidelines ≥30-40px */
  width: auto;
  pointer-events: none; /* klick går alltid till knappen, aldrig SVG */
}

/* Enhetsbaserad visibilitet: JS sätter `data-platform` på <html> vid init.
   Default (ingen attribut eller "other") visar båda. */
html[data-platform="ios"] .wallet-btn-google { display: none; }
html[data-platform="android"] .wallet-btn-apple { display: none; }

/* ─── INFO GRID ─── */
.info-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.info-item .lbl {
  font-family: 'Jost', sans-serif;
  font-size: 0.7rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.12em; color: var(--pink-hot);
}
.info-item .val {
  font-family: 'Source Serif 4', serif;
  font-size: 1.05rem; color: var(--burgundy); font-weight: 500; margin-top: 3px;
}

/* ─── STATUS BADGES ─── */
.status-badge {
  font-family: 'Jost', sans-serif;
  display: inline-block; padding: 4px 12px; border-radius: 50px;
  font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
}
.status-active { background: #E6F9E6; color: #1A7A1A; }
.status-pending { background: #FFF3CD; color: #856404; }
.status-inactive { background: #F8D7DA; color: #721C24; }
.payment-paid { background: #E6F9E6; color: #1A7A1A; }
.payment-unpaid { background: #FFF3CD; color: #856404; }
.payment-exempt { background: #E2E3E5; color: #383D41; }

/* ─── EVENTS LIST ─── */
.event-mini {
  display: grid; grid-template-columns: auto 1fr; gap: 1.2rem;
  align-items: center; padding: 1rem 0;
  border-bottom: 1px solid rgba(214,75,138,0.08);
}
.event-mini:last-child { border-bottom: none; padding-bottom: 0; }
.event-mini:first-child { padding-top: 0; }
.event-mini .date-box {
  text-align: center; padding: 0.7rem 1rem; background: var(--pink-pale);
  border-radius: 10px; min-width: 64px;
}
.event-mini .date-box .d {
  font-family: 'Jost', sans-serif;
  font-size: 1.4rem; font-weight: 800; color: var(--burgundy); line-height: 1;
}
.event-mini .date-box .m {
  font-family: 'Jost', sans-serif;
  font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--pink-hot); font-weight: 600; margin-top: 2px;
}
.event-mini .title {
  font-family: 'Jost', sans-serif;
  font-weight: 700; color: var(--burgundy); font-size: 1rem;
}
.event-mini .desc {
  font-family: 'Source Serif 4', serif;
  font-size: 0.9rem; color: #666; margin-top: 2px;
}
.loading-txt {
  font-family: 'Source Serif 4', serif;
  color: #aaa; font-size: 13px; font-style: italic;
}

/* ─── PASSWORD SECTION ─── */
.pw-section input {
  font-family: 'Jost', sans-serif;
  width: 100%; padding: 12px 14px; border: 1px solid rgba(214,75,138,0.15);
  border-radius: 10px; font-size: 14px; margin-bottom: 10px; outline: none;
  background: white; transition: border-color 0.2s;
}
.pw-section input:focus { border-color: var(--pink-hot); }
.pw-msg {
  font-family: 'Source Serif 4', serif;
  font-size: 0.85rem; margin-top: 10px;
}
.pw-msg.ok { color: #1A7A1A; }
.pw-msg.err { color: #c44; }

/* ─── OFFERS (dashboard) ─── */
.offers-filter { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 1.5rem; }
.offer-filter-btn {
  font-family: 'Jost', sans-serif;
  border: 1px solid rgba(214,75,138,0.15); background: white;
  padding: 6px 16px; border-radius: 50px;
  font-size: 0.7rem; font-weight: 600; cursor: pointer; color: #888;
  text-transform: uppercase; letter-spacing: 0.06em;
  transition: all 0.2s;
}
.offer-filter-btn:hover { border-color: var(--pink-hot); color: var(--pink-hot); }
.offer-filter-btn.active { border-color: var(--pink-hot); color: var(--pink-hot); background: var(--pink-pale); }

.offers-list {
  background: white; border-radius: 16px;
  border: 1px solid rgba(214,75,138,0.08);
  box-shadow: 0 2px 15px rgba(94,26,43,0.04);
  padding: 0 2rem;
}
.offer-item {
  padding: 1.25rem 0; border-bottom: 1px solid rgba(214,75,138,0.08); cursor: pointer;
  transition: background 0.15s;
}
.offer-item:last-child { border-bottom: none; }
.offer-item:hover { background: rgba(214,75,138,0.02); }
.offer-row { display: flex; align-items: center; gap: 14px; }
.offer-logo {
  width: 48px; height: 48px; object-fit: contain; border-radius: 10px;
  border: 1px solid rgba(214,75,138,0.1); flex-shrink: 0; background: white;
}
.offer-logo-placeholder {
  width: 48px; height: 48px; border-radius: 10px; background: var(--pink-pale);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Jost', sans-serif;
  font-weight: 800; color: var(--burgundy); font-size: 18px; flex-shrink: 0;
}
.offer-info { flex: 1; min-width: 0; }
.offer-company {
  font-family: 'Jost', sans-serif;
  font-size: 1rem; font-weight: 700; color: var(--burgundy);
}
.offer-short {
  font-family: 'Source Serif 4', serif;
  font-size: 0.9rem; color: #666; margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.offer-cat {
  font-family: 'Jost', sans-serif;
  font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em;
  padding: 4px 10px; border-radius: 50px; white-space: nowrap; flex-shrink: 0;
}
.offer-detail {
  margin-top: 14px; padding: 1.25rem 1.4rem; background: var(--cream);
  border-radius: 12px; cursor: default;
}
.offer-desc {
  font-family: 'Source Serif 4', serif;
  font-size: 0.95rem; color: #555; line-height: 1.7; margin-bottom: 1rem;
}
.offer-code {
  display: inline-flex; align-items: center; gap: 10px;
  background: white; border: 1px dashed var(--gold); border-radius: 10px;
  padding: 10px 16px; margin-bottom: 1rem;
}
.offer-code-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.65rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--gold);
}
.offer-code-value {
  font-family: 'Jost', monospace;
  font-size: 1.1rem; font-weight: 800; color: var(--burgundy); letter-spacing: 0.05em;
}
.offer-link {
  font-family: 'Jost', sans-serif;
  display: inline-block; font-size: 0.85rem; font-weight: 600;
  color: var(--pink-hot); text-decoration: none; margin-top: 4px;
}
.offer-link:hover { text-decoration: underline; }

/* ─── SETUP TOPBAR + WIZARD ─── */
.setup-topbar {
  background: linear-gradient(135deg, var(--burgundy-deep), var(--burgundy));
  padding: 16px 24px; display: flex; align-items: center; gap: 12px;
}
.setup-topbar .badge {
  width: 36px; height: 36px; border-radius: 50%; background: var(--pink-hot);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Jost', sans-serif;
  font-weight: 800; color: white; font-size: 12px;
}
.setup-topbar-name {
  font-family: 'Jost', sans-serif;
  color: white; font-weight: 700; font-size: 15px;
}
.setup-topbar-label {
  font-family: 'Jost', sans-serif;
  color: var(--pink-light); font-size: 11px; letter-spacing: 0.04em;
}

#force-pw-screen { background: var(--offwhite); min-height: 100vh; }
#force-pw-screen .card {
  background: white; border-radius: 16px; padding: 2rem;
  border: 1px solid rgba(214,75,138,0.08);
  box-shadow: 0 2px 15px rgba(94,26,43,0.04);
}
.setup-option {
  display: flex; align-items: center; gap: 14px; width: 100%;
  padding: 18px 20px; border: 1px solid rgba(214,75,138,0.15); border-radius: 14px;
  background: white; cursor: pointer; text-align: left;
  margin-bottom: 10px; transition: all 0.2s;
}
.setup-option:hover {
  border-color: var(--pink-hot); background: var(--pink-pale);
  transform: translateY(-1px); box-shadow: 0 4px 15px rgba(94,26,43,0.06);
}
.setup-option svg { flex-shrink: 0; color: var(--burgundy); }
.setup-option strong {
  font-family: 'Jost', sans-serif;
  display: block; font-size: 14px; color: var(--burgundy); margin-bottom: 3px; font-weight: 700;
}
.setup-option span {
  font-family: 'Source Serif 4', serif;
  font-size: 13px; color: #666;
}
.setup-back {
  font-family: 'Jost', sans-serif;
  background: none; border: none; cursor: pointer;
  font-size: 13px; color: var(--pink-hot); font-weight: 600; display: flex;
  align-items: center; gap: 5px; padding: 0; margin-bottom: 6px;
}
.setup-lbl {
  font-family: 'Jost', sans-serif;
  font-size: 0.7rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--burgundy); margin-bottom: 4px; display: block; text-align: left;
}
.setup-inp {
  font-family: 'Jost', sans-serif;
  width: 100%; padding: 11px 14px; border: 1px solid rgba(214,75,138,0.15); border-radius: 10px;
  font-size: 14px; outline: none; margin-bottom: 14px;
  transition: border-color 0.2s; background: white;
}
.setup-inp:focus { border-color: var(--pink-hot); }
.setup-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.setup-submit {
  font-family: 'Jost', sans-serif;
  width: 100%; padding: 14px; border: none; border-radius: 50px;
  background: var(--burgundy); color: white; font-weight: 700;
  font-size: 0.9rem; letter-spacing: 0.04em; text-transform: uppercase;
  cursor: pointer; margin-top: 8px; transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.setup-submit:hover {
  background: var(--burgundy-deep); transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(94,26,43,0.2);
}
.setup-err {
  font-family: 'Source Serif 4', serif;
  color: #c44; font-size: 13px; margin: 8px 0; display: none; text-align: left;
}
.setup-err.show { display: block; }

/* ─── ADMIN LIST ─── */
.admin-members-list { padding: 0 2rem; }
.admin-member-row {
  display: flex; align-items: center; gap: 12px; padding: 1.2rem 0;
  border-bottom: 1px solid rgba(214,75,138,0.08); flex-wrap: wrap;
}
.admin-member-row:last-child { border-bottom: none; }
.admin-member-info { flex: 1; min-width: 200px; }
.admin-member-email {
  font-family: 'Jost', sans-serif;
  font-weight: 700; color: var(--burgundy); font-size: 1rem;
}
.admin-member-meta {
  font-family: 'Source Serif 4', serif;
  font-size: 0.9rem; color: #888; margin-top: 2px;
}
.admin-member-actions { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.btn-mini {
  font-family: 'Jost', sans-serif;
  border: 1px solid rgba(214,75,138,0.15); background: white;
  padding: 6px 14px; border-radius: 50px;
  font-size: 0.7rem; font-weight: 600; cursor: pointer;
  color: var(--burgundy);
  text-transform: uppercase; letter-spacing: 0.06em;
  transition: all 0.2s;
}
.btn-mini:hover { border-color: var(--pink-hot); color: var(--pink-hot); }
.btn-mini.danger { color: #c44; }
.btn-mini.danger:hover { border-color: #c44; background: #fef0f0; }
.btn-mini:disabled { opacity: 0.4; cursor: not-allowed; }

/* ─── CREDENTIALS BOX ─── */
.credentials-box {
  background: linear-gradient(135deg, var(--gold-light), #FFE9A8);
  border-radius: 12px; padding: 1.25rem 1.5rem; margin-top: 1rem;
  border: 1px solid rgba(218,165,32,0.3);
}
.credentials-box strong {
  font-family: 'Jost', sans-serif;
  color: var(--burgundy-deep); display: block; margin-bottom: 8px;
  font-weight: 700; font-size: 0.85rem;
}
.credentials-box .cred-row {
  display: flex; align-items: center; gap: 10px; margin: 6px 0;
  font-family: 'Jost', monospace; font-size: 0.9rem;
}
.credentials-box .cred-label {
  font-family: 'Jost', sans-serif;
  font-size: 0.7rem; font-weight: 600; color: var(--burgundy-deep);
  text-transform: uppercase; letter-spacing: 0.08em; min-width: 80px;
}
.credentials-box code {
  background: rgba(255,255,255,0.7); padding: 5px 10px; border-radius: 6px;
  color: var(--burgundy-deep); font-weight: 700; font-family: inherit;
  flex: 1; word-break: break-all;
}
.credentials-box .cred-warning {
  font-family: 'Source Serif 4', serif;
  font-size: 0.85rem; color: var(--burgundy-deep); font-style: italic;
  margin-top: 10px; opacity: 0.9;
}

/* ═══════════════════════════════════════════
   MODAL-SYSTEM
   Delas av TOTP-modaler (login.js, dashboard.js, totp.js) och smsAlert/Confirm/Prompt
   (dialogs.js). Klassnamnen .modal-backdrop, .modal-content, .modal-header,
   .modal-body, .modal-actions, .modal-close, .modal-err, .inp, .lbl refereras
   redan i JS-koden — nu har de en hemvist.
   ═══════════════════════════════════════════ */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(20, 10, 14, 0.55);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
  animation: sms-modal-fade 0.18s ease-out;
}
@keyframes sms-modal-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}
.modal-content {
  background: var(--offwhite);
  border-radius: 16px;
  width: 100%;
  max-width: var(--w-modal);
  max-height: 90vh;
  overflow-y: auto;
  box-shadow:
    0 30px 80px rgba(0,0,0,0.35),
    0 0 0 1px rgba(214,75,138,0.08);
  animation: sms-modal-pop 0.22s cubic-bezier(0.22, 1, 0.36, 1);
  display: flex; flex-direction: column;
}
@keyframes sms-modal-pop {
  from { opacity: 0; transform: translateY(12px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
@media (prefers-reduced-motion: reduce) {
  .modal-backdrop, .modal-content { animation: none; }
}

.modal-header {
  padding: 22px 24px 0;
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px;
}
.modal-header h3 {
  font-family: 'Jost', sans-serif;
  font-size: 1.1rem; font-weight: 800;
  color: var(--burgundy);
  letter-spacing: -0.01em;
  line-height: 1.3;
  margin: 0;
}
.modal-close {
  background: none; border: none; font-size: 24px; line-height: 1;
  color: #999; cursor: pointer; padding: 0 4px; margin: -4px -4px 0 0;
  font-family: 'Jost', sans-serif;
  transition: color 0.15s;
}
.modal-close:hover { color: var(--burgundy); }

.modal-body {
  padding: 14px 24px 18px;
  font-family: 'Source Serif 4', Georgia, serif;
  color: #444; font-size: 0.95rem; line-height: 1.6;
  flex: 1;
}
.modal-body > p:not(.modal-err):not(.lbl) {
  margin-bottom: 12px;
}
.modal-body > p:last-child { margin-bottom: 0; }

.modal-body .lbl {
  font-family: 'Jost', sans-serif;
  font-size: 0.72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--burgundy); margin: 6px 0 6px; display: block;
}
.modal-body .inp {
  width: 100%; padding: 12px 14px;
  border: 1px solid var(--border, #EDE6DC);
  border-radius: 10px;
  font-family: 'Jost', sans-serif; font-size: 0.95rem;
  background: white; color: var(--charcoal);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  margin-bottom: 6px;
}
.modal-body .inp:focus {
  border-color: var(--pink-hot);
  box-shadow: 0 0 0 3px rgba(214,75,138,0.12);
}
.modal-err {
  font-family: 'Source Serif 4', serif;
  color: #c44; font-size: 0.85rem;
  margin-top: 8px; min-height: 1em;
}

.modal-actions {
  padding: 6px 24px 22px;
  display: flex; justify-content: flex-end; gap: 10px;
  flex-wrap: wrap;
}

/* ─── QR-förstoringsmodal ─── */
/* Överridar .modal-content:s standardbredd — QR behöver inte lika bred ruta
   men vill ha ordentligt utrymme vertikalt för själva koden. */
.qr-modal-content { max-width: 400px; }
.qr-modal-body {
  padding: 20px 24px 24px;
  display: flex; flex-direction: column; align-items: center;
  gap: 14px;
}
.qr-modal-code {
  width: 280px; height: 280px;
  padding: 12px; background: #ffffff;
  border-radius: 12px;
  border: 1px solid rgba(214, 75, 138, 0.15);
  box-shadow: 0 4px 16px rgba(94, 26, 43, 0.08);
  /* På smala mobiler: låt den krympa innan modalen blir scrollande */
  max-width: 100%;
  aspect-ratio: 1 / 1;
  height: auto;
}
.qr-modal-code svg { width: 100%; height: 100%; display: block; }
.qr-modal-hint {
  font-family: 'Source Serif 4', serif;
  font-size: 13px;
  color: var(--charcoal); opacity: 0.7;
  text-align: center;
  margin: 0;
}

/* Modal-anpassade knappar. Kompaktare än .btn-primary/.btn-outline
   på hero, men använder samma färgspråk. */
.btn-dialog {
  font-family: 'Jost', sans-serif;
  padding: 10px 22px;
  border-radius: 50px;
  border: 1px solid transparent;
  font-weight: 600; font-size: 0.9rem;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s, transform 0.1s;
  min-width: 90px;
}
.btn-dialog:active { transform: translateY(1px); }

.btn-dialog-cancel {
  background: var(--cream);
  color: var(--burgundy);
  border-color: var(--border, #EDE6DC);
}
.btn-dialog-cancel:hover {
  background: white;
  border-color: var(--pink-hot);
  color: var(--pink-hot);
}

.btn-dialog-ok {
  background: var(--burgundy);
  color: white;
}
.btn-dialog-ok:hover { background: var(--burgundy-deep); }

.btn-dialog-ok.btn-dialog-danger {
  background: #c44;
}
.btn-dialog-ok.btn-dialog-danger:hover { background: #a73333; }

/* Gamla `.btn`-knappar som också används inuti .modal-actions (TOTP).
   Trimma ner padding så de passar i en dialog och inte är jättestora. */
.modal-actions .btn {
  padding: 10px 22px;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  text-transform: none;
}

/* Specifikt för sms-dialogerna (alert/confirm/prompt) */
.sms-dialog-message {
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 0.98rem; color: #333; line-height: 1.6;
  margin: 0 0 10px;
  white-space: pre-wrap; /* bevara radbrytningar i meddelanden */
}

@media (max-width: 480px) {
  .modal-backdrop { padding: 12px; align-items: flex-end; }
  .modal-content { border-radius: 16px 16px 0 0; max-height: 85vh; }
  .modal-actions { flex-direction: column-reverse; }
  .modal-actions .btn,
  .modal-actions .btn-dialog { width: 100%; }
}

/* ─── TOAST ─── */
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(10px);
  background: var(--burgundy); color: white;
  padding: 12px 26px; border-radius: 50px;
  font-family: 'Jost', sans-serif; font-size: 14px; font-weight: 600;
  box-shadow: 0 6px 24px rgba(0,0,0,0.2); z-index: 999;
  opacity: 0; transition: all 0.3s; pointer-events: none;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ─── RESPONSIVE ─── */
@media (max-width: 768px) {
  .dashboard-welcome { padding: 4rem 1.5rem 2rem; }
  .dashboard-section { padding: 3rem 1.5rem; }
  .dashboard-card { padding: 1.5rem; }
  .dashboard-grid-2 { grid-template-columns: 1fr; gap: 1.5rem; }
  .info-grid { grid-template-columns: 1fr; gap: 1rem; }
  .offers-list, .admin-members-list { padding: 0 1.5rem; }
  .setup-row { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════
   DARK MODE
   ═══════════════════════════════════════════ */
@media (prefers-color-scheme: dark) {
  .login-box { background: #1E181C; box-shadow: 0 20px 60px rgba(0,0,0,0.5); }
  .login-box h1 { color: #F2AFC4; }
  .login-box input { background: #141014; border-color: #2E262A; color: #E8D0DC; }
  .login-box button { background: #D64B8A; }
  .login-box button:hover { background: #C03F78; }
  .login-box .links { color: #998A92; }

  .welcome-actions .btn-outline { color: #F2AFC4; border-color: #F2AFC4; }
  .welcome-actions .btn-outline:hover { background: #F2AFC4; color: #141014; }

  .dashboard-card { background: #1E181C; border-color: rgba(214,75,138,0.1); box-shadow: 0 2px 15px rgba(0,0,0,0.2); }
  .dashboard-card:hover { box-shadow: 0 4px 25px rgba(0,0,0,0.3); }
  .dashboard-card .card-title { color: #F2AFC4; }

  .info-item .val { color: #E8D0DC; }
  .event-mini { border-bottom-color: #2E262A; }
  .event-mini .date-box { background: rgba(214,75,138,0.12); }
  .event-mini .date-box .d { color: #F2AFC4; }
  .event-mini .title { color: #F2AFC4; }
  .event-mini .desc { color: #998A92; }

  .pw-section input { background: #141014; border-color: #2E262A; color: #E8D0DC; }
  .pw-section input:focus { border-color: var(--pink-hot); }

  .offer-filter-btn { background: #1E181C; border-color: #2E262A; color: #998A92; }
  .offer-filter-btn:hover { border-color: var(--pink-hot); color: var(--pink-hot); }
  .offer-filter-btn.active { background: rgba(214,75,138,0.12); border-color: var(--pink-hot); color: var(--pink-hot); }
  .offers-list, .admin-members-list { background: #1E181C; border-color: rgba(214,75,138,0.1); }
  .offer-item { border-bottom-color: #2E262A; }
  .offer-item:hover { background: rgba(214,75,138,0.04); }
  .offer-logo { background: #1E181C; border-color: #2E262A; }
  .offer-logo-placeholder { background: rgba(214,75,138,0.1); color: #F2AFC4; }
  .offer-company { color: #F2AFC4; }
  .offer-short { color: #998A92; }
  .offer-detail { background: #141014; }
  .offer-desc { color: #B8A8B0; }
  .offer-code { background: #1E181C; border-color: rgba(218,165,32,0.4); }
  .offer-code-value { color: #F2AFC4; }

  .setup-topbar { background: linear-gradient(135deg, #1A0A10, #2A1520); }
  #force-pw-screen { background: var(--offwhite); }
  #force-pw-screen .card { background: #1E181C; border-color: rgba(214,75,138,0.1); }
  .setup-option { background: #1E181C; border-color: #2E262A; }
  .setup-option:hover { border-color: var(--pink-hot); background: rgba(214,75,138,0.08); }
  .setup-option strong { color: #F2AFC4; }
  .setup-option span { color: #998A92; }
  .setup-option svg { color: #F2AFC4; }
  .setup-lbl { color: #F2AFC4; }
  .setup-inp { background: #141014; border-color: #2E262A; color: #E8D0DC; }
  .setup-submit { background: #D64B8A; }
  .setup-submit:hover { background: #C03F78; }
  .setup-back { color: var(--pink-hot); }

  .admin-member-row { border-bottom-color: #2E262A; }
  .admin-member-email { color: #F2AFC4; }
  .admin-member-meta { color: #998A92; }
  .btn-mini { background: #1E181C; border-color: #2E262A; color: #E8D0DC; }
  .btn-mini:hover { border-color: var(--pink-hot); color: var(--pink-hot); }
  .btn-mini.danger { color: #E88080; }
  .btn-mini.danger:hover { background: rgba(196,68,68,0.15); }

  .credentials-box { background: linear-gradient(135deg, rgba(218,165,32,0.2), rgba(245,215,122,0.15)); border-color: rgba(218,165,32,0.3); }
  .credentials-box strong, .credentials-box .cred-label, .credentials-box code, .credentials-box .cred-warning { color: #F5D77A; }
  .credentials-box code { background: rgba(0,0,0,0.4); }

  .toast { background: var(--pink-hot); }

  /* Modal dark-mode */
  .modal-backdrop { background: rgba(0, 0, 0, 0.65); }
  .modal-content {
    background: #1E181C;
    box-shadow:
      0 30px 80px rgba(0,0,0,0.6),
      0 0 0 1px rgba(214,75,138,0.12);
  }
  .modal-header h3 { color: #F2AFC4; }
  .modal-close { color: #998A92; }
  .modal-close:hover { color: #F2AFC4; }
  .modal-body { color: #B8A8B0; }
  .modal-body .lbl { color: #F2AFC4; }
  .modal-body .inp {
    background: #141014; border-color: #2E262A; color: #E8D0DC;
  }
  .modal-body .inp:focus {
    border-color: var(--pink-hot);
    box-shadow: 0 0 0 3px rgba(214,75,138,0.2);
  }
  .sms-dialog-message { color: #D0C4CA; }
  .btn-dialog-cancel {
    background: #141014;
    color: #E8D0DC;
    border-color: #2E262A;
  }
  .btn-dialog-cancel:hover {
    background: #221C20;
    border-color: var(--pink-hot);
    color: #F2AFC4;
  }
  .btn-dialog-ok { background: var(--pink-hot); }
  .btn-dialog-ok:hover { background: #C03F78; }
  .btn-dialog-ok.btn-dialog-danger { background: #c44; }
  .btn-dialog-ok.btn-dialog-danger:hover { background: #a73333; }
}

/* 2FA-styling */
.security-row-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px; flex-wrap: wrap;
}
.security-row-head > div:first-child { flex: 1; min-width: 200px; }

/* ═══════════════════════════════════════════
   PREFERENSER-KNAPPAR
   ═══════════════════════════════════════════ */
.pref-row {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.pref-label {
  min-width: 80px; font-size: 14px; color: #555; font-weight: 500;
}
.pref-buttons {
  display: inline-flex; gap: 2px; background: var(--cream);
  padding: 3px; border-radius: 10px; border: 1px solid var(--border);
}
.pref-buttons button {
  background: none; border: none; padding: 8px 14px; font-family: inherit;
  font-size: 13px; color: #666; border-radius: 7px; cursor: pointer;
  transition: all 0.15s;
}
.pref-buttons button:hover { color: var(--burgundy); }
.pref-buttons button.active {
  background: white; color: var(--burgundy); font-weight: 600;
  box-shadow: 0 1px 3px rgba(94,26,43,0.08);
}

/* Remember me — login */
.remember-me {
  display: flex; align-items: center; gap: 8px; margin: 8px 0 4px;
  font-size: 13px; color: #555; cursor: pointer; user-select: none;
}
.remember-me input { margin: 0; cursor: pointer; }

/* ═══════════════════════════════════════════
   MÖRKT TEMA (explicit, via Prefs)
   ═══════════════════════════════════════════ */
html[data-theme="dark"] body {
  background: #141014; color: #E8D0DC;
}
html[data-theme="dark"] .dashboard-section { background: #1E181C; }
html[data-theme="dark"] .welcome-actions .btn-outline {
  color: #F2AFC4; border-color: #F2AFC4;
}
html[data-theme="dark"] .welcome-actions .btn-outline:hover {
  background: #F2AFC4; color: #141014;
}
html[data-theme="dark"] .dashboard-card {
  background: #1E181C; border-color: #2E262A; color: #E8D0DC;
}
html[data-theme="dark"] .dashboard-card h2,
html[data-theme="dark"] .dashboard-card h3 { color: #F2AFC4; }
html[data-theme="dark"] .section-label { color: #B8A8B0; }
html[data-theme="dark"] input[type="text"],
html[data-theme="dark"] input[type="email"],
html[data-theme="dark"] input[type="password"],
html[data-theme="dark"] input[type="tel"],
html[data-theme="dark"] textarea,
html[data-theme="dark"] select {
  background: #141014; border-color: #2E262A; color: #E8D0DC;
}
html[data-theme="dark"] .pref-buttons { background: #141014; border-color: #2E262A; }
html[data-theme="dark"] .pref-buttons button { color: #B8A8B0; }
html[data-theme="dark"] .pref-buttons button.active { background: #2E262A; color: #F2AFC4; }

/* Modal — explicit dark-theme (via Prefs, inte bara OS) */
html[data-theme="dark"] .modal-backdrop { background: rgba(0, 0, 0, 0.65); }
html[data-theme="dark"] .modal-content {
  background: #1E181C;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(214,75,138,0.12);
}
html[data-theme="dark"] .modal-header h3 { color: #F2AFC4; }
html[data-theme="dark"] .modal-close { color: #998A92; }
html[data-theme="dark"] .modal-close:hover { color: #F2AFC4; }
html[data-theme="dark"] .modal-body { color: #B8A8B0; }
html[data-theme="dark"] .modal-body .lbl { color: #F2AFC4; }
html[data-theme="dark"] .modal-body .inp {
  background: #141014; border-color: #2E262A; color: #E8D0DC;
}
html[data-theme="dark"] .modal-body .inp:focus {
  border-color: var(--pink-hot);
  box-shadow: 0 0 0 3px rgba(214,75,138,0.2);
}
html[data-theme="dark"] .sms-dialog-message { color: #D0C4CA; }
html[data-theme="dark"] .btn-dialog-cancel {
  background: #141014; color: #E8D0DC; border-color: #2E262A;
}
html[data-theme="dark"] .btn-dialog-cancel:hover {
  background: #221C20; border-color: var(--pink-hot); color: #F2AFC4;
}
html[data-theme="dark"] .btn-dialog-ok { background: var(--pink-hot); }
html[data-theme="dark"] .btn-dialog-ok:hover { background: #C03F78; }

/* ═══════════════════════════════════════════
   KOMPAKT TÄTHET
   ═══════════════════════════════════════════ */
html[data-density="compact"] .dashboard-section { padding: 32px 2rem; }
html[data-density="compact"] .dashboard-card { padding: 18px; }
html[data-density="compact"] .info-item { padding: 8px 12px; }
html[data-density="compact"] .event-mini { padding: 8px 10px; }
html[data-density="compact"] .offer-item { padding: 10px 12px; }

/* Mobil: kompakt density får fortfarande ordentlig sido-marginal så
   innehållet inte ligger kant-i-kant mot skärmkanterna. */
@media (max-width: 768px) {
  html[data-density="compact"] .dashboard-section { padding: 24px 1.5rem; }
  html[data-density="compact"] .dashboard-welcome { padding: 3rem 1.5rem 1.5rem; }
}
