/* swpkontakt.org — Aurora dark theme */
:root{
  --bg:#07151f;
  --bg-section:#0a1c28;
  --bg-elevated:#0e2433;
  --bg-card:#102a3a;
  --ink:#e2edf3;
  --ink-strong:#fff;
  --muted:#8aa0ad;
  --accent:#22c574;
  --accent-2:#34d39a;
  --accent-glow:rgba(34,197,116,.35);
  --rule:#1b3140;
  --rule-soft:#13283a;
  --warn:#15292a;
  --warn-ink:#fbbf24;
  --cta:#fbbf24;
  --cta-hover:#fcd34d;
  --cta-text:#0a1820;
  --container:1140px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font:16px/1.6 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
.container{max-width:var(--container);margin:0 auto;padding:0 16px}
img{max-width:100%;height:auto}
a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(34,197,116,.4)}
a:hover{color:var(--accent-2);text-decoration-color:var(--accent-2)}
h1,h2,h3{line-height:1.25;font-weight:700;margin:0 0 .6em;color:var(--ink-strong)}
h1{font-size:2.2rem;letter-spacing:-.01em}
h2{font-size:1.6rem;margin-top:2em}
h3{font-size:1.18rem;margin-top:1.4em}
p,ul,ol,table{margin:0 0 1em}
ul,ol{padding-left:1.4em}
strong{color:var(--ink-strong)}

/* compliance banner — single line on desktop, compact on mobile */
.compliance-banner{background:#0c1a14;color:#cbd5cf;font-size:.88rem;padding:9px 0;border-bottom:1px solid #173e2c;text-align:center;line-height:1.4}
.compliance-banner .container{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.compliance-banner strong{color:#fbbf24;font-weight:700}
.compliance-banner a{color:#7dd9a4;text-decoration:underline;text-decoration-color:rgba(125,217,164,.4)}
.compliance-banner a:hover{color:#a5e8c1}
@media(max-width:720px){
  .compliance-banner{font-size:.78rem;padding:8px 0}
  .compliance-banner .container{white-space:normal;text-overflow:clip;padding:0 12px}
}

/* breadcrumb */
.breadcrumb{background:var(--bg-section);border-bottom:1px solid var(--rule-soft);font-size:.88rem;padding:8px 0;color:var(--muted)}
.breadcrumb a{color:var(--muted)}

/* header */
header.site{background:var(--bg);border-bottom:1px solid var(--rule)}
header.site .container{display:flex;align-items:center;gap:24px;padding-top:14px;padding-bottom:14px;flex-wrap:wrap}
.brand{font-weight:800;text-decoration:none;color:var(--ink-strong);font-size:1.25rem;letter-spacing:-.01em}
.brand:hover{color:var(--accent-2)}
nav.main ul{list-style:none;margin:0;padding:0;display:flex;gap:18px;flex-wrap:wrap}
nav.main a{color:var(--ink);text-decoration:none;font-weight:500;font-size:.95rem}
nav.main a:hover{color:var(--accent-2)}

/* HERO — aurora gradient */
.hero{
  position:relative;
  padding:48px 0 56px;
  background:
    radial-gradient(ellipse 90% 70% at 50% 120%, rgba(34,197,116,.55) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 80% 90%, rgba(52,211,154,.30) 0%, transparent 60%),
    radial-gradient(ellipse 50% 35% at 15% 85%, rgba(34,197,116,.25) 0%, transparent 60%),
    linear-gradient(180deg, #050f17 0%, #08182a 40%, #0a2335 80%, #0c3a35 100%);
  border-bottom:1px solid var(--rule);
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.5px 1.5px at 40% 20%, rgba(255,255,255,.5), transparent),
    radial-gradient(2px 2px at 70% 25%, rgba(255,255,255,.6), transparent),
    radial-gradient(1.5px 1.5px at 85% 40%, rgba(255,255,255,.45), transparent),
    radial-gradient(1.5px 1.5px at 30% 50%, rgba(255,255,255,.4), transparent);
  pointer-events:none;opacity:.7;
}
.hero .container{position:relative;z-index:1}
.hero h1{color:#fff;text-shadow:0 1px 20px rgba(34,197,116,.25)}
.hero .lead{font-size:1.1rem;color:#cfe1d8;max-width:820px;line-height:1.6}
.hero .meta-info{color:#8fb5a3;font-size:.88rem;margin-top:14px}
.hero .meta-info a{color:#7dd9a4}
.hero .meta-info strong{color:#a5e8c1}

.meta-info{color:var(--muted);font-size:.88rem;display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.byline-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1px solid var(--rule);flex-shrink:0}
.hero .byline-avatar{border:1.5px solid rgba(125,217,164,.45);box-shadow:0 0 0 2px rgba(34,197,116,.15)}

/* /autoren/ team page */
.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin:24px 0}
.team-card{background:var(--bg-elevated);border:1px solid var(--rule);border-radius:12px;padding:20px;text-align:center}
.team-card .photo{width:140px;height:140px;border-radius:50%;object-fit:cover;margin:0 auto 14px;border:3px solid var(--accent);box-shadow:0 0 0 4px rgba(34,197,116,.12)}
.team-card h3{margin:0 0 4px;color:var(--ink-strong)}
.team-card .role{color:var(--accent-2);font-weight:600;font-size:.92rem;margin-bottom:12px}
.team-card .bio{color:var(--ink);font-size:.92rem;line-height:1.55;text-align:left}
.team-card .expertise{margin-top:12px;display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.team-card .expertise span{padding:3px 10px;background:rgba(34,197,116,.12);color:var(--accent-2);border-radius:999px;font-size:.74rem;font-weight:600}

/* sections — alternating subtle backgrounds */
section{padding:32px 0;border-bottom:1px solid var(--rule-soft);background:var(--bg)}
section:nth-of-type(even){background:var(--bg-section)}
section:last-of-type{border-bottom:0}

/* table */
.table-scroll{overflow-x:auto;margin:0 -16px 16px;padding:0 16px}
table{width:100%;border-collapse:collapse;font-size:.95rem;min-width:760px;color:var(--ink)}
th,td{padding:12px 14px;border-bottom:1px solid var(--rule-soft);text-align:left;vertical-align:top}
thead th{background:var(--bg-elevated);font-weight:700;font-size:.88rem;color:var(--ink-strong);border-bottom:1px solid var(--rule)}
tbody th{font-weight:700;color:var(--ink-strong)}
.muted{color:var(--muted);font-size:.85rem;display:block}

/* === Dark card-list affiliate layout === */
.anbieter-list-section{
  background:
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(34,197,116,.18) 0%, transparent 60%),
    linear-gradient(180deg,#06121b 0%,#0a1f2e 60%,#0c2c2e 100%);
  padding:40px 0;
  color:#cbd5e1;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.anbieter-list-section h2{color:#fff;margin-bottom:.6em}
.anbieter-list-section p{color:#cbd5e1}
.anbieter-list-section .affiliate-disclosure{background:rgba(15,40,52,.7);border:1px solid #1c3a48;color:#94a3b8}
.anbieter-list-section .footnote{color:#7d96a4}
.anbieter-list-section a{color:#fbbf24;text-decoration-color:rgba(251,191,36,.4)}
.anbieter-list-section a:hover{color:#fcd34d}
.anbieter-list{display:flex;flex-direction:column;gap:14px;margin:24px 0}
.anbieter-card{
  background:linear-gradient(180deg,#0f263a 0%,#10283c 100%);
  border:1px solid #1d3a4f;
  border-radius:14px;
  padding:18px 22px;
  display:grid;
  grid-template-columns:44px 140px minmax(140px,1.3fr) minmax(150px,1.1fr) auto minmax(150px,1.2fr) auto;
  gap:18px;
  align-items:center;
  transition:border-color .15s, transform .15s;
}
.anbieter-card:hover{border-color:#2c5a4a;transform:translateY(-1px)}
.card-position{width:38px;height:38px;background:#fbbf24;color:#0b1424;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;box-shadow:0 2px 8px rgba(251,191,36,.25)}
.card-logo{width:130px;height:80px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:10px;display:flex;align-items:center;justify-content:center}
.card-logo img{max-width:100%;max-height:100%;object-fit:contain;display:block}
/* Black outline around letters for logos whose text is light/thin */
img[src*="betrepublic"],
img[src*="boomerang"],
img[src*="freshbet"]{
  filter:
    drop-shadow(1px 0 0 #000)
    drop-shadow(-1px 0 0 #000)
    drop-shadow(0 1px 0 #000)
    drop-shadow(0 -1px 0 #000);
}
.card-brand-name{color:#fff;font-size:1.18rem;font-weight:700;line-height:1.2}
.card-brand-license{color:#94a3b8;font-size:.88rem;margin-top:6px}
.card-bonus-main{color:#34d39a;font-size:1.22rem;font-weight:800;line-height:1.2;text-shadow:0 0 12px rgba(34,197,116,.2)}
.card-bonus-sub{color:#94a3b8;font-size:.84rem;margin-top:6px}
.card-rating{text-align:center}
.card-rating-stars{color:#fbbf24;font-size:1.05rem;letter-spacing:2px}
.card-rating-stars .star-empty{color:#3f4b6b}
.card-rating-score{color:#fff;font-weight:700;font-size:.98rem;margin-top:4px}
.card-tags{display:flex;flex-wrap:wrap;gap:6px;align-content:center}
.tag{padding:5px 11px;border-radius:999px;font-size:.72rem;font-weight:700;white-space:nowrap;color:#fff;letter-spacing:.2px}
.tag-purple{background:#8b5cf6}
.tag-green{background:#22c55e}
.tag-blue{background:#3b82f6}
.tag-orange{background:#f97316}
.card-cta{display:flex;flex-direction:column;align-items:stretch;gap:8px;min-width:140px}
.cta-primary{background:#fbbf24;color:#0b1424 !important;padding:12px 22px;border-radius:999px;font-weight:800;text-decoration:none;display:inline-block;text-align:center;white-space:nowrap;transition:background .15s,box-shadow .15s;font-size:.95rem;box-shadow:0 4px 14px rgba(251,191,36,.25)}
.cta-primary:hover{background:#fcd34d;color:#0b1424 !important;box-shadow:0 6px 20px rgba(251,191,36,.4)}
.cta-secondary{color:#fbbf24 !important;font-size:.82rem;text-decoration:none;white-space:nowrap;text-align:center}
.cta-secondary:hover{text-decoration:underline}
@media(max-width:980px){
  .anbieter-card{grid-template-columns:44px 100px 1fr;gap:12px}
  .card-logo{width:100px;height:60px;padding:8px}
  .card-brand{grid-column:3}
  .card-bonus,.card-rating,.card-tags,.card-cta{grid-column:1 / -1}
  .card-cta{flex-direction:row;justify-content:space-between;padding-top:10px;border-top:1px solid #1f2d4a;align-items:center}
}
@media(max-width:520px){
  .anbieter-card{padding:14px}
  .card-bonus-main{font-size:1.05rem}
  .card-cta{flex-direction:column;gap:6px}
  .cta-primary{width:100%}
}

/* legacy brand-logo inline (kept for any remaining table cells) */
.brand-logo{display:inline-block;width:96px;height:54px;vertical-align:middle;object-fit:contain;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:8px;flex-shrink:0}
.brand-cell{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.brand-cell .brand-name{font-weight:600;font-size:.98rem;color:var(--ink-strong)}
@media(max-width:640px){
  .brand-logo{width:72px;height:42px;padding:6px;border-radius:6px}
  .brand-cell{gap:8px}
  .brand-cell .brand-name{font-size:.9rem}
}

/* tax pills */
.tax{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.78rem;font-weight:700}
.tax-full{background:rgba(34,197,116,.18);color:#34d39a;border:1px solid rgba(34,197,116,.35)}
.tax-partial{background:rgba(251,191,36,.15);color:#fbbf24;border:1px solid rgba(251,191,36,.3)}
.tax-pass{background:rgba(148,163,184,.15);color:#a8b8c4;border:1px solid rgba(148,163,184,.25)}

/* generic CTA (legacy) */
.cta{display:inline-block;background:var(--cta);color:var(--cta-text) !important;padding:9px 16px;border-radius:8px;text-decoration:none;font-weight:700;font-size:.92rem;white-space:nowrap;transition:background .15s}
.cta:hover{background:var(--cta-hover);color:var(--cta-text) !important}

/* affiliate-disclosure */
.affiliate-disclosure{background:rgba(15,40,52,.5);border:1px solid var(--rule);border-radius:8px;padding:12px 14px;font-size:.9rem;color:var(--muted);margin:0 0 14px}
.affiliate-disclosure strong{color:var(--ink-strong)}
.footnote{font-size:.85rem;color:var(--muted)}

/* card grids (highlights / why-international etc) */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.cards article{background:var(--bg-elevated);border:1px solid var(--rule);border-radius:10px;padding:18px}
.cards article h3{margin-top:0;color:var(--ink-strong)}
.cards article p{color:var(--ink)}

.method-list li{margin-bottom:.6em}

/* sportarten grid */
.sportarten-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.sportarten-grid a{display:block;padding:16px;background:var(--bg-elevated);border:1px solid var(--rule);border-radius:10px;text-decoration:none;color:var(--ink);font-size:.93rem;line-height:1.5;transition:border-color .15s,transform .15s}
.sportarten-grid a:hover{border-color:var(--accent);transform:translateY(-1px)}
.sportarten-grid strong{color:var(--accent-2);display:block;margin-bottom:6px;font-size:1.02rem}

/* example tables (Wett-Steuer rechnung) */
.example-table{font-size:.92rem;background:var(--bg-elevated);border-radius:8px;overflow:hidden}
.example-table thead th{background:var(--bg-card)}

/* FAQ details */
details{border:1px solid var(--rule);border-radius:8px;padding:12px 16px;margin-bottom:8px;background:var(--bg-elevated)}
details[open]{background:var(--bg-card);border-color:var(--accent)}
summary{cursor:pointer;font-weight:600;padding:4px 0;color:var(--ink-strong)}
summary:hover{color:var(--accent-2)}
details p{margin-top:10px;color:var(--ink)}

/* footer */
.site-footer{background:#040c12;color:#9bb0bc;padding:36px 0 16px;margin-top:24px;border-top:1px solid var(--rule)}
.site-footer a{color:#cbdde5;text-decoration:none}
.site-footer a:hover{color:var(--accent-2)}
.site-footer h3{color:#fff;font-size:1rem;margin:0 0 10px}
.footer-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px}
.footer-cols ul{list-style:none;padding:0;margin:0;font-size:.9rem}
.footer-cols li{margin-bottom:6px}
.footer-bottom{border-top:1px solid #1b3140;margin-top:28px;padding-top:16px;color:#7d96a4;font-size:.85rem}
.footer-bottom strong{color:#fbbf24}

/* yellow callout (used on Wett-Steuer ratgeber pages) */
section[style*="#fff7e6"]{background:rgba(251,191,36,.06) !important;border-top:2px solid rgba(251,191,36,.3) !important;border-bottom:2px solid rgba(251,191,36,.3) !important}

/* blockquote */
blockquote{border-left:4px solid var(--accent) !important;padding:10px 18px !important;background:rgba(34,197,116,.07) !important;font-style:italic;color:var(--ink)}

/* minimalist body class — used on informational, E-E-A-T and legal pages */
body.minimal main .container{max-width:720px}
body.minimal main section{padding:24px 0}
body.minimal main section.hero{padding:36px 0 32px}
body.minimal main h2{font-size:1.4rem;margin-top:1.6em}
body.minimal main h3{font-size:1.08rem}
body.minimal main p{font-size:1rem;line-height:1.7;max-width:680px}
body.minimal main ul,body.minimal main ol{max-width:680px}
body.minimal main .cards{display:block}
body.minimal main .cards article{background:transparent;border:none;padding:0 0 18px 0}
body.minimal main .cards article h3{margin-top:0}
body.minimal main .team-grid{display:block}
body.minimal main .team-card{background:transparent;border:none;border-radius:0;padding:0;margin:0 0 36px 0;text-align:left;display:flex;gap:18px;align-items:flex-start}
body.minimal main .team-card .photo{width:88px;height:88px;border-width:2px;box-shadow:none;margin:0;flex-shrink:0}
body.minimal main .team-card>div:not(.expertise){flex:1;text-align:left}
body.minimal main .team-card .expertise{justify-content:flex-start;margin-top:8px}
body.minimal main table{font-size:.92rem}
body.minimal main .footnote{margin-top:8px}
/* keep emergency BZgA-box prominent even in minimal mode */
body.minimal main section[style*="rgba(251,191,36"] .container{max-width:720px}

/* responsive base */
@media(max-width:640px){
  h1{font-size:1.7rem}
  h2{font-size:1.32rem}
  nav.main ul{gap:12px}
  .hero{padding:36px 0 44px}
  body.minimal main .team-card{flex-direction:column;align-items:center;text-align:center}
  body.minimal main .team-card>div:not(.expertise){text-align:center}
}
