/* GoGolop shared page layout — pair with themes.css + partials/top_nav.html */

html {
  margin: 0;
  padding: 0;
  scroll-padding-top: 70px;
}

/* Sticky .gg-nav sits in document flow — no body padding-top (avoids gap under browser chrome) */
body.gg-page,
body:has(> .gg-nav),
body:has(> nav.gg-nav) {
  margin: 0;
  padding-top: 0 !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  line-height: 1.6;
  color: var(--text-primary, #2c3e50);
  background: var(--bg-primary, #f8f9fa);
  min-height: 100vh;
  transition: background 0.2s ease, color 0.2s ease;
}

/* Day mode: brand teal hero — !important beats per-page <style> blocks */
html[data-theme="light"] body.gg-page--gradient,
html:not([data-theme="dark"]) body.gg-page--gradient,
body.gg-page--gradient {
  background: linear-gradient(
    165deg,
    var(--hero-bg, #096896) 0%,
    var(--hero-bg-end, #0a7ab0) 55%,
    #087aa5 100%
  ) !important;
  color: var(--hero-text, #fff);
}

html[data-theme="light"] body.gg-page--auth,
html:not([data-theme="dark"]) body.gg-page--auth {
  background: linear-gradient(165deg, #096896 0%, #0a7ab0 55%, #087aa5 100%) !important;
}

html[data-theme="dark"] body.gg-page--gradient {
  background: linear-gradient(135deg, #121212 0%, #2c3e50 100%);
  color: var(--text-primary);
}

/* Legacy per-page navbar hidden when shared nav is present */
body:has(.gg-nav) > .navbar,
body:has(.gg-nav) nav.navbar:first-of-type {
  display: none !important;
}

/* —— Dark mode: pages with hardcoded light colors —— */
html[data-theme="dark"] body {
  color: var(--text-primary) !important;
}

html[data-theme="dark"] .main-content,
html[data-theme="dark"] .content-card,
html[data-theme="dark"] .feature-card,
html[data-theme="dark"] .pricing-card,
html[data-theme="dark"] .tournament-card,
html[data-theme="dark"] .group-card,
html[data-theme="dark"] .challenge-card,
html[data-theme="dark"] .league-card,
html[data-theme="dark"] .scorecard-card,
html[data-theme="dark"] .auth-card,
html[data-theme="dark"] .profile-section,
html[data-theme="dark"] .info-card,
html[data-theme="dark"] .stat-box,
html[data-theme="dark"] .panel,
html[data-theme="dark"] .card,
html[data-theme="dark"] .bracket-panel,
html[data-theme="dark"] .tab-content,
html[data-theme="dark"] .modal-content,
html[data-theme="dark"] .dropdown-menu,
html[data-theme="dark"] .list-group-item,
html[data-theme="dark"] .table-container {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

html[data-theme="dark"] p,
html[data-theme="dark"] li,
html[data-theme="dark"] label,
html[data-theme="dark"] .form-group label,
html[data-theme="dark"] .detail-row,
html[data-theme="dark"] .meta-item,
html[data-theme="dark"] .description,
html[data-theme="dark"] .subtitle,
html[data-theme="dark"] .text-secondary {
  color: var(--text-secondary) !important;
}

html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3,
html[data-theme="dark"] h4,
html[data-theme="dark"] h5,
html[data-theme="dark"] .page-title,
html[data-theme="dark"] .section-title,
html[data-theme="dark"] .tournament-title,
html[data-theme="dark"] .group-name,
html[data-theme="dark"] .feature-card h3,
html[data-theme="dark"] .features h2 {
  color: var(--text-primary) !important;
}

/* Day mode: hero bands with white text on brand background */
html[data-theme="light"] body.gg-page--gradient .page-header,
html[data-theme="light"] body.gg-page--gradient .header.hero,
html:not([data-theme="dark"]) body.gg-page--gradient .page-header {
  background: var(--hero-bg, #096896);
  color: var(--hero-text, #fff);
  border-radius: 12px;
  padding: 32px 20px;
  margin-bottom: 24px;
}

html[data-theme="dark"] body.gg-page--gradient .page-header,
html[data-theme="dark"] body.gg-page--gradient .header.hero,
html[data-theme="dark"] .header.hero {
  color: var(--hero-text, #fff) !important;
  background: transparent;
}

html[data-theme="dark"] input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select,
html[data-theme="dark"] .form-control,
html[data-theme="dark"] .form-select {
  background: var(--bg-tertiary) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

html[data-theme="dark"] .table {
  --bs-table-bg: var(--bg-secondary);
  --bs-table-color: var(--text-primary);
  --bs-table-border-color: var(--border-color);
  color: var(--text-primary);
}

html[data-theme="dark"] .table td,
html[data-theme="dark"] .table th {
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

html[data-theme="dark"] .nav-tabs .nav-link {
  color: var(--text-secondary);
}

html[data-theme="dark"] .nav-tabs .nav-link.active {
  color: var(--text-primary);
  background: var(--bg-secondary);
}

html[data-theme="dark"] .btn-outline,
html[data-theme="dark"] .btn-secondary:not(.btn-quick-waitlist) {
  color: var(--text-primary);
  border-color: var(--border-color);
}

html[data-theme="dark"] .workflow-alert {
  background: rgba(241, 196, 15, 0.15) !important;
  color: var(--warning-color) !important;
  border-color: var(--warning-color) !important;
}

html[data-theme="dark"] #betaAccessMessage {
  color: var(--text-primary) !important;
}

/* Inline light backgrounds from templates */
html[data-theme="dark"] [style*="background: white"],
html[data-theme="dark"] [style*="background:white"],
html[data-theme="dark"] [style*="background: #fff"],
html[data-theme="dark"] [style*="background:#fff"] {
  background: var(--bg-secondary) !important;
}

html[data-theme="dark"] [style*="color: #333"],
html[data-theme="dark"] [style*="color:#333"],
html[data-theme="dark"] [style*="color: #2c3e50"] {
  color: var(--text-primary) !important;
}

/* Login / register — form below sticky top_nav */
body.gg-page--auth {
  display: block;
  min-height: 100vh;
}

.auth-page {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  min-height: calc(100vh - 70px);
  padding: 24px 16px 48px;
  box-sizing: border-box;
}

.auth-container {
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
}

.auth-card {
  background: var(--bg-secondary, #fff);
  border-radius: 15px;
  box-shadow: 0 20px 40px var(--shadow-dark, rgba(0, 0, 0, 0.15));
  overflow: hidden;
  border: 1px solid var(--border-color, #e9ecef);
}

.auth-header {
  text-align: center;
  padding: 32px 24px 24px;
  background: linear-gradient(135deg, var(--hero-bg, #096896) 0%, var(--hero-bg-end, #0a7ab0) 100%);
  color: var(--hero-text, #fff);
}

.auth-header h1 {
  font-size: 1.75rem;
  margin-bottom: 8px;
  font-weight: 700;
}

.auth-header p {
  opacity: 0.92;
  font-size: 1rem;
}

.auth-form {
  padding: 24px 28px 28px;
}

.social-login {
  padding: 20px 28px 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  align-items: stretch;
}

.social-login .divider {
  margin: 18px 0 4px;
  position: relative;
  color: var(--text-secondary, #666);
  font-size: 0.9rem;
  text-align: center;
}

.social-login .divider::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--border-color, #e1e8ed);
}

.social-login .divider span {
  background: var(--bg-secondary, #fff);
  padding: 0 12px;
  position: relative;
}

.btn-social {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 12px 20px;
  border: 2px solid var(--border-color, #e1e8ed);
  border-radius: 8px;
  background: var(--bg-secondary, #fff);
  color: var(--text-primary, #333);
  text-decoration: none;
  font-weight: 600;
  margin: 0;
  transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
  box-sizing: border-box;
}

.btn-social:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px var(--shadow-color, rgba(0, 0, 0, 0.1));
}

.btn-social.google {
  border-color: #db4437;
  color: #db4437;
}

.btn-social.google:hover {
  background: #db4437;
  color: #fff;
}

.btn-social-icon {
  width: 20px;
  height: 20px;
  margin-right: 10px;
  flex-shrink: 0;
}

.auth-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 0;
}

.auth-form .form-group {
  margin-bottom: 18px;
}

.auth-form .form-group label {
  display: block;
  margin-bottom: 8px;
  color: var(--text-primary, #333);
  font-weight: 500;
}

.auth-form .form-group input,
.auth-form .form-group select {
  width: 100%;
  padding: 12px 14px;
  border: 2px solid var(--border-color, #e1e8ed);
  border-radius: 8px;
  font-size: 16px;
  background: var(--bg-secondary, #fff);
  color: var(--text-primary, #333);
  box-sizing: border-box;
}

.auth-form .form-group input:focus,
.auth-form .form-group select:focus {
  outline: none;
  border-color: var(--accent-color, #3498db);
  box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.15);
}

.auth-form .phone-row {
  display: flex;
  gap: 10px;
}

.auth-form .phone-row select {
  min-width: 120px;
  flex: 0 0 auto;
  width: auto;
}

.auth-form .phone-row input {
  flex: 1;
  min-width: 0;
}

.form-options {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 22px;
  flex-wrap: wrap;
  gap: 8px;
}

.checkbox-label {
  display: flex;
  align-items: center;
  font-weight: normal;
  cursor: pointer;
  color: var(--text-primary, #333);
}

.checkbox-label input {
  width: auto;
  margin-right: 8px;
}

.forgot-link {
  color: var(--accent-color, #3498db);
  text-decoration: none;
  font-size: 0.9rem;
}

.forgot-link:hover {
  text-decoration: underline;
}

.auth-form .btn-primary {
  background: var(--accent-color, #3498db);
  color: #fff;
  width: 100%;
  padding: 14px 16px;
  border: none;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
}

.auth-form .btn-primary:hover {
  background: var(--accent-hover, #2980b9);
}

.auth-links {
  text-align: center;
  padding: 18px 28px;
  background: var(--bg-tertiary, #f8f9fa);
  border-top: 1px solid var(--border-color, #e9ecef);
  color: var(--text-secondary, #666);
}

.auth-links a {
  color: var(--accent-color, #3498db);
  text-decoration: none;
  font-weight: 600;
}

.demo-account {
  padding: 18px 28px;
  background: var(--bg-tertiary, #f8f9fa);
  border-top: 1px solid var(--border-color, #e9ecef);
  text-align: center;
}

.demo-account h3 {
  color: var(--text-primary, #2c3e50);
  margin-bottom: 8px;
  font-size: 1.05rem;
}

.demo-account p {
  margin: 4px 0;
  color: var(--text-secondary, #666);
  font-size: 0.9rem;
}

.demo-account .btn-secondary {
  margin-top: 12px;
  padding: 10px 18px;
  border: 2px solid var(--border-color, #2c3e50);
  border-radius: 8px;
  background: transparent;
  color: var(--text-primary, #2c3e50);
  font-weight: 600;
  cursor: pointer;
}

.message {
  margin: 16px 28px 0;
  padding: 12px 14px;
  border-radius: 8px;
  font-weight: 500;
}

.message.success {
  background: rgba(39, 174, 96, 0.15);
  color: var(--success-color, #155724);
  border: 1px solid var(--success-color, #c3e6cb);
}

.message.error {
  background: rgba(231, 76, 60, 0.12);
  color: var(--danger-color, #721c24);
  border: 1px solid var(--danger-color, #f5c6cb);
}

@media (max-width: 520px) {
  .auth-form .form-row {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .auth-header h1 {
    font-size: 1.5rem;
  }
}

/* —— Global contrast & friendly defaults (light + dark) —— */
body.gg-page {
  color: var(--text-primary, #2c3e50);
}

body.gg-page a:not(.btn):not(.btn-primary):not(.btn-social):not(.gg-btn) {
  color: var(--accent-color, #3498db);
}

body.gg-page p,
body.gg-page li,
body.gg-page label,
body.gg-page .form-group label {
  color: var(--text-primary, #2c3e50);
}

body.gg-page .text-muted,
body.gg-page small,
body.gg-page .subtitle,
body.gg-page .meta-label {
  color: var(--text-secondary, #666) !important;
}

/* White text only on gradient/hero headers — not plain content pages (e.g. scoring) */
body.gg-page--gradient .page-header,
body.gg-page--gradient .page-header h1,
body.gg-page--gradient .page-header p,
body.gg-page--gradient .page-title,
body.gg-page--gradient .page-subtitle,
.header.hero,
.header.hero h1,
.header.hero p {
  color: #fff;
}

body.gg-page:not(.gg-page--gradient) .page-header h1,
body.gg-page:not(.gg-page--gradient) .page-header p {
  color: var(--text-primary, #2c3e50);
}

html[data-theme="dark"] .message.success {
  background: rgba(39, 174, 96, 0.2) !important;
  color: #b8f0d0 !important;
  border-color: #58d68d !important;
}

html[data-theme="dark"] .message.error {
  background: rgba(231, 76, 60, 0.2) !important;
  color: #f5b7b1 !important;
  border-color: #ec7063 !important;
}

html[data-theme="dark"] .auth-header,
html[data-theme="dark"] .auth-header h1,
html[data-theme="dark"] .auth-header p {
  color: #fff !important;
}

html[data-theme="dark"] .social-login .divider span {
  background: var(--bg-secondary, #2d2d2d) !important;
}

html[data-theme="dark"] .btn-social.google {
  color: #ff8a80 !important;
  border-color: #db4437 !important;
}

html[data-theme="dark"] .btn-social.google:hover {
  color: #fff !important;
}

html[data-theme="dark"] .demo-account .btn-secondary {
  border-color: var(--border-color) !important;
  color: var(--text-primary) !important;
}

html[data-theme="dark"] .gg-nav__logo,
html[data-theme="dark"] .gg-link,
html[data-theme="dark"] .gg-dd__item,
html[data-theme="dark"] .gg-navitem {
  color: var(--text-primary) !important;
}

html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder {
  color: var(--text-muted, #888) !important;
  opacity: 1;
}

html[data-theme="light"] .auth-card,
html[data-theme="light"] .main-content {
  color: var(--text-primary, #2c3e50);
}

/* Badges / alerts that often use fixed light-theme colors */
html[data-theme="dark"] [class*="badge"],
html[data-theme="dark"] .alert,
html[data-theme="dark"] .workflow-alert {
  color: var(--text-primary) !important;
}

html[data-theme="dark"] .status-pending,
html[data-theme="dark"] [style*="background:#fff3cd"],
html[data-theme="dark"] [style*="background: #fff3cd"] {
  background: rgba(241, 196, 15, 0.22) !important;
  color: #f7dc6f !important;
}

/* Scoring / dashboard-style cards (inline light colors in page CSS) */
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .action-btn,
html[data-theme="dark"] .scorecard-item,
html[data-theme="dark"] .empty-state,
html[data-theme="dark"] .user-dropdown,
html[data-theme="dark"] .user-info,
html[data-theme="dark"] .tournament-card,
html[data-theme="dark"] .filter-card,
html[data-theme="dark"] .hub-card {
  background: var(--bg-secondary) !important;
  color: var(--text-primary) !important;
  border-color: var(--border-color) !important;
}

html[data-theme="dark"] .stat-content h3,
html[data-theme="dark"] .stat-content p,
html[data-theme="dark"] .action-content h4,
html[data-theme="dark"] .action-content p,
html[data-theme="dark"] .scorecard-content h4,
html[data-theme="dark"] .scorecard-content p,
html[data-theme="dark"] .empty-state h4,
html[data-theme="dark"] .empty-state p,
html[data-theme="dark"] .user-name,
html[data-theme="dark"] .dropdown-item {
  color: var(--text-primary) !important;
}

html[data-theme="dark"] .stat-content p,
html[data-theme="dark"] .action-content p,
html[data-theme="dark"] .scorecard-content p,
html[data-theme="dark"] .empty-state p,
html[data-theme="dark"] .page-header p:not(.page-subtitle) {
  color: var(--text-secondary) !important;
}

html[data-theme="dark"] .stat-icon,
html[data-theme="dark"] .action-icon,
html[data-theme="dark"] .scorecard-icon,
html[data-theme="dark"] .nav-link.active {
  background: var(--bg-tertiary) !important;
}

html[data-theme="dark"] .status.complete {
  background: rgba(39, 174, 96, 0.25) !important;
  color: #a9dfbf !important;
}

html[data-theme="dark"] .status.incomplete {
  background: rgba(241, 196, 15, 0.22) !important;
  color: #f7dc6f !important;
}

html[data-theme="dark"] [style*="color: #666"],
html[data-theme="dark"] [style*="color:#666"],
html[data-theme="dark"] [style*="color: #999"] {
  color: var(--text-secondary) !important;
}
