/* SportSort — shared styles */

/* ── Reset & base ─────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:      #1a7a4a;
  --green-l:    #52b788;
  --green-d:    #0d5c38;
  --green-p:    #d8f3dc;
  --accent:     #00c853;
  --text:       #1a1a1a;
  --text-mid:   #555;
  --text-light: #888;
  --bg:         #f0f4f1;
  --bg-dark:    #0a130d;
  --card:       #fff;
  --border:     #e0e0e0;
  --radius:     14px;
  --shadow:     0 2px 12px rgba(0,0,0,.08);
}

html { scroll-behavior: smooth; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ── Nav ──────────────────────────────────────── */
.ss-nav {
  background: var(--bg-dark);
  padding: .9rem 1.4rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.ss-nav-logo {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-size: 1.8rem;
  font-weight: 900;
  color: #fff;
  letter-spacing: -.03em;
  text-decoration: none;
}
.ss-nav-logo .sort { color: var(--accent); }
.ss-logo-icon { width: 1.8rem; height: 1.8rem; flex-shrink: 0; color: var(--accent); }
.ss-nav-links {
  display: flex;
  align-items: center;
  gap: 1.4rem;
  list-style: none;
}
.ss-nav-links a {
  color: rgba(255,255,255,.75);
  font-size: .875rem;
  font-weight: 500;
  transition: color .15s;
  text-decoration: none;
}
.ss-nav-links a:hover { color: #fff; }
.ss-nav-links .badge {
  font-size: .65rem;
  font-weight: 700;
  background: var(--green);
  color: #fff;
  padding: 2px 6px;
  border-radius: 20px;
  margin-left: .3rem;
  vertical-align: middle;
}
.ss-nav-links .badge-beta {
  font-size: .65rem;
  font-weight: 700;
  background: #f5c842;
  color: #5a3a00;
  padding: 2px 6px;
  border-radius: 20px;
  margin-left: .3rem;
  vertical-align: middle;
}
.ss-nav-cta {
  background: var(--green) !important;
  color: #fff !important;
  padding: .45rem 1rem;
  border-radius: 8px;
  font-weight: 600 !important;
  font-size: .85rem !important;
  transition: background .15s !important;
}
.ss-nav-cta:hover { background: var(--green-d) !important; }

/* Launch App dropdown */
.ss-nav-launch-wrap { position: relative; }
.ss-nav-launch-btn { border: none; cursor: pointer; font-family: inherit; font-size: .85rem !important; line-height: 1; display: inline-flex; align-items: center; gap: .35rem; }
.ss-launch-chevron { font-size: .6rem; transition: transform .15s; }
.ss-nav-launch-btn[aria-expanded="true"] .ss-launch-chevron { transform: rotate(180deg); }
.ss-launch-menu {
  display: none;
  position: absolute;
  top: calc(100% + .5rem);
  right: 0;
  min-width: 260px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0,0,0,.14);
  list-style: none;
  padding: .4rem;
  z-index: 200;
}
.ss-launch-menu.is-open { display: block; }
.ss-launch-item {
  display: flex;
  align-items: center;
  gap: .8rem;
  padding: .75rem .85rem;
  border-radius: 9px;
  color: var(--text);
  transition: background .12s;
  text-decoration: none;
}
.ss-launch-item:hover { background: var(--bg); }
.ss-launch-icon { font-size: 1.5rem; flex-shrink: 0; line-height: 1; }
.ss-launch-item strong { display: block; font-size: .9rem; font-weight: 800; }
.ss-launch-desc { display: block; font-size: .75rem; color: var(--text-mid); margin-top: .1rem; }
.ss-launch-badge { font-size: .62rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; padding: 2px 7px; border-radius: 20px; flex-shrink: 0; margin-left: auto; }
.ss-badge-live { background: var(--accent); color: #fff; }
.ss-badge-beta { background: #f5c842; color: #5a3a00; }

.ss-nav-toggle {
  display: none;
  width: 2.4rem;
  height: 2.4rem;
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 8px;
  background: rgba(255,255,255,.05);
  color: #fff;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-direction: column;
  padding: 0;
}
.ss-nav-toggle span,
.ss-nav-toggle::before,
.ss-nav-toggle::after {
  content: "";
  display: block;
  width: 1.1rem;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transition: transform .18s, opacity .18s;
}
.ss-nav-toggle span { margin: 4px 0; }
.ss-nav-toggle[aria-expanded="true"]::before { transform: translateY(6px) rotate(45deg); }
.ss-nav-toggle[aria-expanded="true"] span { opacity: 0; }
.ss-nav-toggle[aria-expanded="true"]::after { transform: translateY(-6px) rotate(-45deg); }

/* ── Sitewide ad slot ─────────────────────────── */
.ad-sitewide {
  background: #fff;
  border-top: 1px solid var(--border);
  padding: .75rem 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.ad-sitewide-label {
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-light);
  margin-bottom: .35rem;
}
@media (max-width: 600px) { .ad-sitewide { display: none; } }

/* ── Footer ───────────────────────────────────── */
.ss-footer {
  background: var(--bg-dark);
  color: rgba(255,255,255,.5);
  padding: 2.5rem 1.4rem;
}
.ss-footer-inner {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.4rem;
}
.ss-footer-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 2rem;
  flex-wrap: wrap;
}
.ss-footer-brand {
  font-size: 1.5rem;
  font-weight: 900;
  color: #fff;
  letter-spacing: -.03em;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ss-footer-brand-name { display: flex; align-items: center; gap: .4rem; }
.ss-footer-brand-name .sort { color: var(--accent); }
.ss-footer-brand p { font-size: .8rem; font-weight: 400; color: rgba(255,255,255,.4); margin-top: .3rem; }
.ss-footer-links { display: flex; gap: 1.5rem; flex-wrap: wrap; list-style: none; }
.ss-footer-links a { font-size: .83rem; color: rgba(255,255,255,.5); transition: color .15s; }
.ss-footer-links a:hover { color: #fff; }
.ss-footer-privacy {
  font-size: .78rem;
  line-height: 1.6;
  color: rgba(255,255,255,.35);
  border-top: 1px solid rgba(255,255,255,.07);
  padding-top: 1.2rem;
}
.ss-footer-privacy strong { color: rgba(255,255,255,.55); }
.ss-footer-privacy a { color: rgba(255,255,255,.45); text-decoration: underline; }
.ss-footer-bottom {
  font-size: .75rem;
  color: rgba(255,255,255,.25);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .5rem;
}

/* ── Cookie banner ────────────────────────────── */
.cookie-consent {
  position: fixed;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 10000;
  background: #fff;
  color: #1a1a1a;
  border: 1px solid rgba(0,0,0,.12);
  box-shadow: 0 12px 40px rgba(0,0,0,.22);
  border-radius: 12px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: .85rem;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}
.cookie-consent p { margin: 0; font-size: .9rem; line-height: 1.45; color: #333; }
.cookie-consent a { color: #1a7a4a; text-decoration: underline; }
.cookie-consent-actions { display: flex; gap: .6rem; flex-wrap: wrap; }
.cookie-consent button {
  border: 0;
  border-radius: 8px;
  padding: .65rem .95rem;
  font-weight: 800;
  cursor: pointer;
  font-size: .86rem;
}
.cookie-consent-accept { background: #1a7a4a; color: #fff; }
.cookie-consent-reject { background: #edf3ef; color: #153d28; }

/* ── Print: hide nav/footer/cookie ───────────── */
@media print {
  .ss-nav, .ss-footer, .cookie-consent { display: none !important; }
}

/* ── Mobile nav ───────────────────────────────── */
@media (max-width: 700px) {
  .ss-nav-links {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg-dark);
    flex-direction: column;
    align-items: flex-start;
    padding: 1rem 1.4rem 1.4rem;
    gap: 1rem;
    border-top: 1px solid rgba(255,255,255,.08);
  }
  .ss-nav-links.is-open { display: flex; }
  .ss-nav-toggle { display: inline-flex; flex-direction: column; }
  .ss-nav { position: relative; }

  /* Launch dropdown: flat list inside mobile nav, no floating panel */
  .ss-nav-launch-wrap { width: 100%; }
  .ss-nav-launch-btn { width: 100%; justify-content: center; padding: .65rem 1rem !important; }
  .ss-launch-menu {
    position: static;
    box-shadow: none;
    border: 1px solid rgba(255,255,255,.1);
    background: rgba(255,255,255,.05);
    border-radius: 10px;
    margin-top: .4rem;
    padding: .25rem;
  }
  .ss-launch-item { color: #fff; }
  .ss-launch-item:hover { background: rgba(255,255,255,.08); }
  .ss-launch-desc { color: rgba(255,255,255,.5); }
}

@media (min-width: 720px) {
  .cookie-consent { left: auto; max-width: 520px; }
}
