/* Global “Institutional” styling (deep blue → red) */

:root {
  --tc-bg-0: #040b1a; /* deep navy */
  --tc-bg-1: #061a3a; /* institutional blue */
  --tc-bg-2: #0a2a5a; /* richer blue */
  --tc-accent-red: #6b0f1a; /* deep red */
  --tc-border: rgba(148, 163, 184, 0.22); /* slate-ish */
  --tc-surface: rgba(4, 11, 26, 0.75);
  --tc-surface-2: rgba(4, 11, 26, 0.6);
  --tc-text: #ffffff;
  --tc-text-muted: rgba(226, 232, 240, 0.72);
}

/* Do not set overflow: hidden on html/body – Digistore24 Trusted Badge injects a floating element that must remain visible. */
html,
body {
  height: 100%;
  overflow: visible;
}

body {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif !important;
  letter-spacing: -0.01em !important;
  color: var(--tc-text) !important;
  background-color: var(--tc-bg-0) !important;
  background-image: linear-gradient(
    135deg,
    var(--tc-bg-1) 0%,
    var(--tc-bg-2) 45%,
    var(--tc-accent-red) 100%
  ) !important;
  background-attachment: fixed !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
}

/* Ensure Tailwind background utilities don't override the global gradient */
body[class*="bg-"] {
  background-color: transparent !important;
  background-image: linear-gradient(
    135deg,
    var(--tc-bg-1) 0%,
    var(--tc-bg-2) 45%,
    var(--tc-accent-red) 100%
  ) !important;
}

/* Hero section: full video visible, no cropping */
.tc-hero-video {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center center;
  vertical-align: middle;
}

.tc-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(4, 11, 26, 0.5) 0%,
    rgba(6, 26, 58, 0.65) 50%,
    rgba(4, 11, 26, 0.8) 100%
  );
  z-index: 1;
  pointer-events: none;
}

/* Institutional navigation + footer surfaces */
.tc-nav,
.tc-footer {
  background: var(--tc-surface) !important;
  border-color: var(--tc-border) !important;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.tc-nav-panel {
  background: var(--tc-surface-2) !important;
  border-color: var(--tc-border) !important;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.tc-footer a,
.tc-nav a,
.tc-nav button {
  text-decoration: none;
}

.tc-footer a:hover,
.tc-nav a:hover {
  color: var(--tc-text) !important;
}

/* Inverted navigation bar (light background, dark text) */
.tc-nav-inverted {
  background: #ffffff !important; /* solid white so logo looks clean */
  border-color: rgba(0, 0, 0, 0.08) !important;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06) !important;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
}

.tc-nav-inverted a,
.tc-nav-inverted button {
  color: #0f172a !important; /* slate-900 */
  text-decoration: none;
}

.tc-nav-inverted a:hover,
.tc-nav-inverted button:hover {
  color: #020617 !important; /* darker slate on hover */
}

/* Logo: force transparent background so PNG transparency shows correctly */
.tc-nav-inverted .tc-logo-wrap {
  background: transparent !important;
  background-color: transparent !important;
}

.tc-nav-inverted .logo,
.tc-nav-inverted a.logo {
  color: #0f172a !important; /* slate-900 */
  font-weight: 600;
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.tc-nav-inverted .logo:hover,
.tc-nav-inverted .logo:focus,
.tc-nav-inverted .logo:focus-visible,
.tc-nav-inverted a.logo:hover,
.tc-nav-inverted a.logo:focus,
.tc-nav-inverted a.logo:focus-visible {
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.tc-nav-inverted .logo img {
  background: transparent !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  display: block; /* avoids inline gap that can show background */
}

.tc-nav-inverted svg {
  color: #0f172a !important; /* slate-900 for icons */
}

.tc-nav-inverted .language-switcher {
  color: #0f172a !important;
}

.tc-nav-inverted .language-switcher a {
  color: #475569 !important; /* slate-600 */
  transition: color 0.2s;
}

.tc-nav-inverted .language-switcher a:hover {
  color: #0f172a !important; /* slate-900 on hover */
}

.tc-nav-inverted .language-switcher .active {
  color: #0f172a !important; /* slate-900 for active language */
  font-weight: 600;
}

/* Consistent focus styling */
:focus-visible {
  outline: 2px solid rgba(59, 130, 246, 0.9) !important;
  outline-offset: 2px !important;
}

