/* Custom global styles and design tokens for FinanciaIA
   - Define color palette, typography, spacing utilities
   - Place all project-specific overrides here
*/

:root {
  /* Color palette */
  --color-brand: #ff851b;
  /* AI Strategy brand orange */
  --color-brand-60: #ff851b60;
  /* AI Strategy brand orange */
  --color-violet: #9932cc;
  /* Bootstrap violet */
  --color-violet-60: #9932cc60;
  --color-primary: #001f3f;
  /* Bootstrap primary */
  --color-green: #3d9970;
  --color-gray-100: #e1e1e140;
  --color-gray-0: #e1e1e100;
  --color-gray-text: #ffffff;
  --color-gray-text-dark: #515151;

  ;
  --color-primary-700: #050505;
  --color-secondary: #6c757d;
  --color-success: #198754;
  --color-warning: #ffc107;
  --color-danger: #dc3545;
  --color-info: #0dcaf0;
  --color-light: #f8f9fa;
  --color-dark: #212529;

  /* Neutrals */
  --bg-page: #0b0c20 !important;
  --surface: #ffffff;
  --muted: #6c757d;

  /* Typography */
  --font-family-base: "Inter", "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --font-size-base: 16px;

  /* Spacing scale */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 1rem;
  --space-4: 1.5rem;
  --space-5: 3rem;

  --text-h1: #f6f6f6;
}

/* Hero logo styling */
.hero-logo {
  max-width: 450px;
  width: 100%;
  height: auto;
  filter: drop-shadow(0 6px 25px rgba(255, 255, 255, 0.4));
  animation: float 3s ease-in-out infinite;
}

@keyframes float {

  0%,
  100% {
    transform: translateY(0px);
  }

  50% {
    transform: translateY(-12px);
  }
}

@media (max-width: 768px) {
  .hero-logo {
    max-width: 300px;
  }
}

/* Navbar logo styling */
.navbar-logo {
  height: 20px;
  width: auto;
  filter: brightness(0) invert(1);
}

/* Full-width orange background section */
.section-orange-full {
  background-color: #9932cc;
  margin-left: -50vw;
  margin-right: -50vw;
  padding: 3rem 0;
  position: relative;
  left: 50%;
  right: 50%;
  width: 100vw;
}

/* Feature icons */
.feature-icon {
  width: 3rem;
  height: 3rem;
}

/* Bento Grid & Glass Layout for Quienes Somos */
.values-bento-container {
  max-width: 1200px;
  margin: 3rem auto;
  padding: 0 20px;
}

.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(2, minmax(200px, auto));
  gap: 20px;
}

.glass-card {
  position: relative;
  background: rgba(255, 255, 255, 0.12) !important;
  /* Force high visibility */
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255, 255, 255, 0.6) !important;
  border-radius: 24px;
  padding: 2.5rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.glass-card:hover {
  transform: translateY(-8px);
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.9) !important;
  box-shadow: 0 20px 45px rgba(0, 0, 0, 0.6), 0 0 25px rgba(255, 255, 255, 0.2);
}

.bento-large {
  grid-column: span 2;
  grid-row: span 1;
}

.bento-medium {
  grid-column: span 2;
  grid-row: span 1;
}

.bento-vertical {
  grid-column: span 1;
  grid-row: span 1;
}

.bento-small {
  grid-column: span 1;
  grid-row: span 1;
}

/* Icons & Typography */
.bento-icon-box {
  width: 50px;
  height: 50px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
  color: var(--color-brand);
  transition: transform 0.3s ease;
}

.bento-mission .bento-title {
  color: var(--color-brand);
}

.bento-vision .bento-title {
  color: var(--color-violet);
}

.glass-card:hover .bento-icon-box {
  transform: scale(1.1) rotate(5deg);
}

.bento-title {
  font-size: 1.75rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

.bento-text {
  color: #ffffff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.8) !important;
  /* Stronger for testing */
  line-height: 1.6;
  margin: 0;
  opacity: 1 !important;
}

/* Animations */
.animate-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  animation: fadeInUp 0.8s forwards;
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Responsive Bento */
@media (max-width: 992px) {
  .bento-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .bento-large,
  .bento-medium {
    grid-column: span 2;
  }
}

@media (max-width: 600px) {
  .bento-grid {
    grid-template-columns: 1fr;
  }

  .bento-large,
  .bento-medium,
  .bento-vertical,
  .bento-small {
    grid-column: span 1;
  }

  .glass-card {
    padding: 1.5rem;
  }
}

/* Small responsive tweaks */
@media (prefers-color-scheme: dark) {
  :root {
    --bg-page: #0b1220;
    --surface: #ffffff;
    --color-dark: var(--text-h1);
    --muted: #9aa7b8;
  }

  /* Removed body background override to allow starry effect */
}

/* Base page styles */
html,
body {
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  background: radial-gradient(circle at 10% 20%, rgba(153, 50, 204, 0.08) 0%, transparent 40%), radial-gradient(circle at 90% 80%, rgba(255, 133, 27, 0.05) 0%, transparent 40%), linear-gradient(180deg, #001f3f 0%, #03010a 100%) !important;
  background-attachment: fixed !important;
  color: var(--text-h1);
  position: relative;
  min-height: 100vh;
}

/* Ensure main content is above shooting stars */
main.container {
  position: relative;
  z-index: 50;
}

.container {
  position: relative;
  z-index: 50;
}

/* Starry background for entire page */
body::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image:
    radial-gradient(4px 4px at 20px 30px, #ffffff, transparent),
    radial-gradient(3px 3px at 40px 70px, #ffffff, transparent),
    radial-gradient(2px 2px at 90px 40px, #ffffff, transparent),
    radial-gradient(3px 3px at 130px 80px, #ffffff, transparent),
    radial-gradient(4px 4px at 160px 30px, #ffffff, transparent),
    radial-gradient(2px 2px at 200px 60px, #ffffff, transparent),
    radial-gradient(3px 3px at 240px 20px, #ffffff, transparent),
    radial-gradient(2px 2px at 280px 90px, #ffffff, transparent),
    radial-gradient(3px 3px at 320px 10px, #ffffff, transparent),
    radial-gradient(2px 2px at 350px 100px, #ffffff, transparent),
    radial-gradient(4px 4px at 50px 150px, #ffffff, transparent),
    radial-gradient(2px 2px at 180px 120px, #ffffff, transparent),
    radial-gradient(3px 3px at 270px 50px, #ffffff, transparent),
    radial-gradient(2px 2px at 380px 140px, #ffffff, transparent);
  background-repeat: repeat;
  background-size: 500px 300px;
  animation: twinkle 3s infinite ease-in-out;
  opacity: 1;
  z-index: -2;
  pointer-events: none;
}

/* Realistic shooting stars rain effect - 15 stars */
.shooting-star {
  position: fixed;
  z-index: 1;
  pointer-events: none;
}

.shooting-star::before {
  content: '';
  position: absolute;
  width: 4px;
  height: 4px;
  background: radial-gradient(circle, #ffffff 0%, rgba(255, 255, 255, 0.8) 50%, rgba(255, 255, 255, 0.3) 100%);
  border-radius: 50%;
  box-shadow:
    0 0 8px #ffffff,
    0 0 16px #ffffff,
    0 0 24px rgba(255, 255, 255, 0.8),
    0 0 32px rgba(255, 255, 255, 0.4);
  z-index: 2;
}

.shooting-star::after {
  content: '';
  position: absolute;
  width: 100px;
  height: 3px;
  background: linear-gradient(90deg,
      transparent 0%,
      rgba(255, 255, 255, 0.1) 20%,
      rgba(255, 255, 255, 0.4) 60%,
      rgba(255, 255, 255, 0.8) 90%,
      #ffffff 100%);
  left: -98px;
  top: 0.5px;
  border-radius: 2px;
  box-shadow:
    0 0 6px rgba(255, 255, 255, 0.4),
    0 0 12px rgba(255, 255, 255, 0.2);
  z-index: 1;
}

/* 8 shooting stars with natural random distribution - very slow speeds */
.shooting-star:nth-child(1) {
  left: 15%;
  animation: fall-angle1 8.5s infinite linear 0s;
}

.shooting-star:nth-child(2) {
  left: 35%;
  animation: fall-angle2 9.2s infinite linear 2.5s;
}

.shooting-star:nth-child(3) {
  left: 55%;
  animation: fall-angle3 10.1s infinite linear 5.0s;
}

.shooting-star:nth-child(4) {
  left: 75%;
  animation: fall-angle1 9.8s infinite linear 7.5s;
}

.shooting-star:nth-child(5) {
  left: 25%;
  animation: fall-angle2 8.7s infinite linear 10.0s;
}

.shooting-star:nth-child(6) {
  left: 65%;
  animation: fall-angle3 9.6s infinite linear 12.5s;
}

.shooting-star:nth-child(7) {
  left: 45%;
  animation: fall-angle1 10.3s infinite linear 15.0s;
}

.shooting-star:nth-child(8) {
  left: 85%;
  animation: fall-angle2 9.0s infinite linear 17.5s;
}

@keyframes fall-angle1 {
  0% {
    top: -30px;
    opacity: 0;
    transform: rotate(15deg) translateX(-10px) scale(0);
  }

  5% {
    opacity: 1;
    transform: rotate(15deg) translateX(5px) scale(1);
  }

  95% {
    opacity: 0.7;
    transform: rotate(15deg) translateX(80px) scale(0.9);
  }

  100% {
    top: 110vh;
    opacity: 0;
    transform: rotate(15deg) translateX(100px) scale(0.3);
  }
}

@keyframes fall-angle2 {
  0% {
    top: -15px;
    opacity: 0;
    transform: rotate(25deg) translateX(5px) scale(0);
  }

  6% {
    opacity: 1;
    transform: rotate(25deg) translateX(15px) scale(1);
  }

  94% {
    opacity: 0.8;
    transform: rotate(25deg) translateX(120px) scale(1);
  }

  100% {
    top: 110vh;
    opacity: 0;
    transform: rotate(25deg) translateX(140px) scale(0.4);
  }
}

@keyframes fall-angle3 {
  0% {
    top: -25px;
    opacity: 0;
    transform: rotate(10deg) translateX(-5px) scale(0);
  }

  4% {
    opacity: 1;
    transform: rotate(10deg) translateX(8px) scale(1);
  }

  96% {
    opacity: 0.6;
    transform: rotate(10deg) translateX(70px) scale(0.8);
  }

  100% {
    top: 110vh;
    opacity: 0;
    transform: rotate(10deg) translateX(85px) scale(0.2);
  }
}

@keyframes fall-angle4 {
  0% {
    top: -40px;
    opacity: 0;
    transform: rotate(55deg) translateX(20px) scale(0);
  }

  7% {
    opacity: 1;
    transform: rotate(55deg) translateX(40px) scale(1);
  }

  93% {
    opacity: 0.9;
    transform: rotate(55deg) translateX(280px) scale(1.1);
  }

  100% {
    top: 110vh;
    opacity: 0;
    transform: rotate(55deg) translateX(320px) scale(0.5);
  }
}

/* Form alignment helpers for password fields */
.form-row-equal {
  display: flex;
  gap: 1rem;
  align-items: stretch;
  flex-wrap: nowrap;
}

.form-row-equal>.form-col {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
}

/* Ensure labels and inputs inside each column stack neatly */
.form-col .form-label {
  margin-bottom: .5rem;
}

.form-col input[type="password"],
.form-col input[type="text"],
.form-col input[type="email"],
.form-col .form-control {
  width: 100%;
  box-sizing: border-box;
}

/* Mobile: stack columns */
@media (max-width: 576px) {
  .form-row-equal {
    flex-direction: column;
    gap: .75rem;
  }
}

/* Small visual tweak: keep consistent vertical spacing for card forms */
.card .mb-3 {
  display: flex;
  flex-direction: column;
}

/* Ensure the input element sits at the bottom of its field container
   Use a more specific selector so other .mb-3 usages are unaffected */
.form-col .mb-3 {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  /* label top, input bottom */
  min-height: 5.25rem;
  /* gives space so inputs can anchor to bottom */
}

/* Filters helper: keep filter controls in a row but avoid them becoming too narrow
   `.filters-row` is a flex container that wraps; `.filter-item` has a sensible min-width
   and will stack on narrow screens. */
.filters-row {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  align-items: end;
  /* align label/input bottoms */
}

.filters-row .filter-item {
  flex: 1 1 160px;
  /* grow, shrink, base 160px */
  min-width: 140px;
}

@media (max-width: 768px) {
  .filters-row {
    align-items: stretch;
  }

  .filters-row .filter-item {
    flex: 1 1 100%;
    min-width: 100%;
  }
}

/* Large screens (>=769px): force three filter items in a single row with equal widths */
@media (min-width: 769px) {
  .filters-row {
    flex-wrap: nowrap;
  }

  .filters-row .filter-item {
    flex: 0 0 calc(33.333% - 0.75rem);
    min-width: 0;
  }
}

/* Keep input-group full-width and prevent the icon from separating from the input */
.filter-item .input-group {
  width: 100%;
}

.filter-item .input-group .input-group-text {
  white-space: nowrap;
}

.filter-item select,
.filter-item input {
  width: 100%;
}

/* Convocatoria detail cards styling */
.detail-card .card-body {
  color: var(--color-gray-text) !important;
}

.detail-card {
  border: none;
  border-radius: .75rem;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(2, 6, 23, 0.18);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(250, 250, 250, 0.95));
}

.detail-card .card-header {
  border-bottom: 1px solid rgba(0, 0, 0, 0.04);
  padding: .8rem 1.25rem;
  display: flex;
  align-items: center;
  gap: .75rem;
}

.detail-card .card-header .icon-circle {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
}

.detail-card .card-header .icon-circle img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}

.detail-card .card-body {
  padding: 1.25rem;
  color: var(--color-primary-700);
}

.detail-card .meta-row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  align-items: center;
}

.detail-card .meta-item {
  flex: 1 1 200px;
  min-width: 160px;
}

.detail-card .badge-list {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.detail-actions {
  display: flex;
  gap: .5rem;
  margin-top: 1rem;
}

@media (min-width: 768px) {
  .detail-layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 1.25rem;
    align-items: start;
  }
}

/* Spacing below cards in detail layout to avoid cramped bottom */
.detail-layout>.card {
  margin-bottom: 1.5rem;
}

/* Ensure main container has padding at bottom so footer doesn't overlap */
main.container {
  padding-bottom: 3rem;
}

/* Objective block: white text on primary gradient -> transparent */
.objective-block {
  color: #ffffff;
  background: linear-gradient(180deg, var(--color-violet) 0%, rgba(0, 31, 63, 0.0) 100%);
}

.objective-block h5,
.objective-block p {
  color: #ffffff;
}



@keyframes fall-angle5 {
  0% {
    top: -10px;
    opacity: 0;
    transform: rotate(75deg) translateX(-30px) scale(0);
  }

  5% {
    opacity: 1;
    transform: rotate(75deg) translateX(-5px) scale(1);
  }

  95% {
    opacity: 0.7;
    transform: rotate(75deg) translateX(190px) scale(0.9);
  }

  100% {
    top: 110vh;
    opacity: 0;
    transform: rotate(75deg) translateX(220px) scale(0.3);
  }
}

@keyframes fall-angle6 {
  0% {
    top: -35px;
    opacity: 0;
    transform: rotate(40deg) translateX(0px) scale(0);
  }

  8% {
    opacity: 1;
    transform: rotate(40deg) translateX(25px) scale(1);
  }

  92% {
    opacity: 0.8;
    transform: rotate(40deg) translateX(300px) scale(1);
  }

  100% {
    top: 110vh;
    opacity: 0;
    transform: rotate(40deg) translateX(350px) scale(0.6);
  }
}

a {
  color: var(--color-primary);
}

/* Utility helpers */
.text-muted {
  color: var(--muted) !important;
}

.bg-soft {
  background-color: #f5f7fb;
}

.text-primary {
  --bs-text-opacity: 1;
  color: var(--color-brand) !important;
}

.card {
  background: var(--color-gray-100) !important;
  border-radius: .5rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(10px);
  position: relative;
  z-index: 10;
}

.card-white {
  position: relative;
  display: block;
  padding: var(--bs-list-group-item-padding-y) var(--bs-list-group-item-padding-x);
  color: var(--bs-list-group-color);
  text-decoration: none;
  background-color: var(--bs-list-group-bg);
  border: var(--bs-list-group-border-width) solid var(--bs-list-group-border-color);
}

.text-muted {
  color: var(--color-gray-text) !important;
}

.text-gray {
  color: var(--color-gray-text-dark) !important;
}

.text-primary {
  --bs-text-opacity: 1;
  color: var(--color-brand) !important;
}

/* Buttons override subtle */
.btn-primary {
  background-color: var(--color-brand) !important;
  border-color: var(--color-brand) !important;
  color: #ffffff;
}

.btn-primary:hover {
  background-color: #e67300;
  border-color: #e67300;
  color: #ffffff;
}

.btn-primary:active,
.btn-primary:focus {
  background-color: #cc6600;
  border-color: #cc6600;
  box-shadow: 0 0 0 0.25rem rgba(255, 133, 27, 0.5);
}

.btn-outline-primary {
  color: var(--color-gray-text) !important;
  border-color: var(--color-violet-60) !important;
  background-color: var(--color-violet-60) !important;
}

.btn-outline-primary:hover {
  color: var(--color-gray-text) !important;
  background-color: var(--color-violet) !important;
  border-color: var(--color-violet) !important;
}

.btn-info {
  background-color: var(--color-violet);
  border-color: var(--color-violet);
  color: #ffffff;
}

.btn-info:hover {
  background-color: var(--color-violet);
  border-color: var(--color-violet);
  color: #ffffff;
}

.bg-primary {
  --bs-bg-opacity: 1;
  background-color: var(--color-brand) !important;
}

/* Card subtle shadow and surface */
.card {
  background: rgba(255, 255, 255, 0.95);
  border-radius: .5rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(10px);
  position: relative;
  z-index: 10;
  color: var(--color-gray-text);
}

.card h3,
.card .form-label,
.card label {
  color: var(--color-gray-text);
}


/* Specific components used by the app */
.header-brand {
  font-weight: 700;
  letter-spacing: -0.02em;
}

.summary-badge {
  padding: .25rem .6rem;
  border-radius: .5rem;
}

/* Simple status badges */
.badge-success {
  background: var(--color-success);
  color: rgb(151, 29, 29);
}

.badge-warning {
  background: var(--color-warning);
  color: #054a8f;
}

.badge-danger {
  background: var(--color-danger);
  color: rgb(176, 83, 24);
}

/* Forms */
.form-label {
  font-weight: 600;
}

/* Small helpers for the execution trend dots */
.trend-dot {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-block;
}

.trend-dot--success {
  background: var(--color-success);
}

.trend-dot--partial {
  background: var(--color-warning);
}

.trend-dot--error {
  background: var(--color-danger);
}

/* Make tables more compact */
.table-sm th,
.table-sm td {
  padding: .45rem;
}

/* Navbar overrides: set project brand color and ensure readable link colors */
.navbar {
  background-color: #0b1220 !important;
  position: relative;
  z-index: 100;
}

/* Navbar with brand orange color - full width */
.navbar-brand-orange {
  background-color: var(--color-brand) !important;
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  padding-left: 0;
  padding-right: 0;
}

.navbar-brand-orange .container-fluid {
  padding-left: 2rem;
  padding-right: 2rem;
}

.navbar .navbar-brand,
.navbar .nav-link,
.navbar .dropdown-item {
  color: var(--text-h1) !important;
  /* soft off-white for contrast */
}

.navbar .nav-link:hover,
.navbar .dropdown-item:hover {
  color: #ffffff !important;
}


.navbar-brand {
  font-weight: bold;
  font-size: 1.5rem;
}

.footer {
  background-color: #0b1220 !important;
  color: #ffffff;
  padding: 3rem 0;
  margin-top: 5rem;
}

.card-shadow {
  box-shadow: 0 0.125rem 0.25rem rgba(180, 30, 30, 0.075);
}

.profile-img {
  width: 120px;
  height: 120px;
  object-fit: cover;
}

/* Full-bleed helper: make an element span the entire viewport width
   Useful for hero banners placed inside constrained containers. */
.full-bleed {
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  width: 100vw;
  box-sizing: border-box;
}

/* Starry sky background effect with shooting stars */
.starry-hero {
  background: linear-gradient(135deg, #0c0c0c 0%, #1e3c72 50%, #2a5298 100%);
  position: relative;
  overflow: hidden;
}

.starry-hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image:
    radial-gradient(2px 2px at 20px 30px, #fff, transparent),
    radial-gradient(2px 2px at 40px 70px, #fff, transparent),
    radial-gradient(1px 1px at 90px 40px, #fff, transparent),
    radial-gradient(1px 1px at 130px 80px, #fff, transparent),
    radial-gradient(2px 2px at 160px 30px, #fff, transparent),
    radial-gradient(1px 1px at 200px 60px, #fff, transparent),
    radial-gradient(2px 2px at 240px 20px, #fff, transparent),
    radial-gradient(1px 1px at 280px 90px, #fff, transparent);
  background-repeat: repeat;
  background-size: 300px 300px;
  animation: twinkle 8s infinite;
  opacity: 0.8;
  z-index: 1;
}

.starry-hero::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background:
    linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.8), transparent);
  width: 150px;
  height: 2px;
  transform: rotate(-45deg);
  animation: shooting-star 4s infinite linear;
  z-index: 2;
}

.starry-hero>* {
  position: relative;
  z-index: 3;
}

.dropdown-menu {
  background-color: var(--bg-page);
}

.dropdown-item:hover {
  background-color: var(--color-violet);
  color: var(--color-gray-text);
}

@keyframes twinkle {

  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }

  25% {
    opacity: 0.3;
    transform: scale(0.8);
  }

  50% {
    opacity: 0.1;
    transform: scale(0.6);
  }

  75% {
    opacity: 0.6;
    transform: scale(0.9);
  }
}

@keyframes shooting-star {
  0% {
    top: -20%;
    left: -20%;
    opacity: 0;
    transform: rotate(-45deg) scale(0);
  }

  5% {
    opacity: 1;
    transform: rotate(-45deg) scale(1);
  }

  95% {
    opacity: 1;
    transform: rotate(-45deg) scale(1);
  }

  100% {
    top: 120%;
    left: 120%;
    opacity: 0;
    transform: rotate(-45deg) scale(0);
  }
}

/* Data Acceptance Page Styles */
.rounded-4 {
  border-radius: 1rem !important;
}

.data-acceptance-card {
  transition: transform 0.3s ease;
}

.policy-container {
  max-height: 400px;
  overflow-y: auto;
  font-size: 0.95rem;
}

.data-acceptance-card,
.data-acceptance-card h1,
.data-acceptance-card h2,
.data-acceptance-card h3,
.data-acceptance-card h4,
.data-acceptance-card h5,
.data-acceptance-card p,
.data-acceptance-card li,
.policy-container,
.policy-container * {
  color: #000000 !important;
}

.btn-gradient-primary {
  background: linear-gradient(135deg, var(--color-brand) 0%, #e67300 100%) !important;
  border: none;
  color: #ffffff !important;
}

.btn-gradient-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(255, 133, 27, 0.3) !important;
}

body {
  padding-top: 76px;
  /* Matches navbar height */
}

/* Force sticky behavior in case of Bootstrap conflict */
.fixed-top {
  position: fixed !important;
  top: 0;
  right: 0;
  left: 0;
  z-index: 9999 !important;
  width: 100%;
}

.navbar {
  display: flex !important;
  z-index: 9999 !important;
}

.bg-violet {
  background-color: var(--color-violet) !important;
  color: #ffffff !important;
}

/* --- Donation Page Styles --- */
.full-bg-donate {
  background: transparent;
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.glass-container-donate {
  background: rgba(255, 255, 255, 0.03);
  backdrop-filter: blur(25px);
  -webkit-backdrop-filter: blur(25px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

.glow-orange-donate {
  box-shadow: 0 0 20px rgba(255, 133, 27, 0.4);
}

.amount-btn-donate {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition: all 0.3s ease;
  color: white;
}

.amount-btn-donate:hover {
  background: rgba(255, 133, 27, 0.2);
  border-color: var(--color-brand);
  transform: scale(1.05);
}

.animate-float-donate {
  animation: float-donate 6s ease-in-out infinite;
}

@keyframes float-donate {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-20px);
  }
}

/* Neutralizing Bootstrap container for full-width layouts */
.container-content-override {
  max-width: none !important;
  padding: 0 !important;
}

.donate-input {
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  color: white !important;
  font-weight: 500 !important;
}

.donate-input::placeholder {
  color: rgba(255, 255, 255, 0.4) !important;
}

.donate-input:focus {
  border-color: var(--color-brand) !important;
  box-shadow: 0 0 10px rgba(255, 133, 27, 0.3) !important;
  outline: none !important;
  color: white !important;
}

/* Custom Number Input Controls */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=number] {
  -moz-appearance: textfield;
  appearance: textfield;
}

.btn-plus-donate {
  background: rgba(255, 133, 27, 0.2);
  border: 1px solid var(--color-brand);
  color: var(--color-brand);
  border-radius: 12px;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
}

.btn-plus-donate:hover {
  background: var(--color-brand);
  color: white;
  transform: scale(1.1);
}

/* --- Strategic Bento V2 (Value Proposition) --- */
.bento-grid-v2 {
  display: grid !important;
  grid-template-columns: repeat(12, 1fr) !important;
  gap: 1.5rem !important;
  max-width: 1280px;
  margin: 0 auto;
}

.bento-card-v2 {
  background: rgba(255, 255, 255, 0.02) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255, 255, 255, 0.05) !important;
  border-radius: 2.5rem !important;
  transition: all 0.5s cubic-bezier(0.2, 0.8, 0.2, 1) !important;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  z-index: 10;
}

.bento-card-v2:hover {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  transform: translateY(-8px) !important;
  box-shadow: 0 40px 80px -20px rgba(0, 0, 0, 0.6) !important;
}

.bento-card-v2::after {
  content: " \;
 position: absolute;
 inset: 0;
 border-radius: 2.5rem;
 padding: 1px;
 background: linear-gradient(135deg, rgba(255,255,255,0.1), transparent 50%, rgba(255,255,255,0.05));
 -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
 mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
 -webkit-mask-composite: xor;
 mask-composite: exclude;
 pointer-events: none;
}

.text-glow-orange { text-shadow: 0 0 20px rgba(255, 133, 27, 0.3); }
.text-glow-purple { text-shadow: 0 0 20px rgba(153, 50, 204, 0.3); }

.bento-12 { grid-column: span 12 !important; }
.bento-8 { grid-column: span 8 !important; }
.bento-4 { grid-column: span 4 !important; }

@media (max-width: 1024px) {
 .bento-grid-v2 { 
 display: flex !important;
 flex-direction: column !important;
 }
 .bento-8, .bento-4 { width: 100% !important; }
}

.text-gradient-strategic {
 background: linear-gradient(to right, #ff851b, #9932cc) !important;
 -webkit-background-clip: text !important;
 -webkit-text-fill-color: transparent !important;
 background-clip: text !important;
}

.tracking-tighter-impact { letter-spacing: -0.05em !important; }
.tracking-widest-impact { letter-spacing: 0.3em !important; }
.lh-09 { line-height: 0.9 !important; }

.font-black-title {
 font-weight: 900 !important;
}

