:root {
  --purple:#6F2C91;
  --yellow:#EAE84B;
  --dark:#111;
  --light-bg:#fafafa;
  --text-primary:#333;
  --text-secondary:#666;
  --white:#ffffff;
  --shadow:rgba(0,0,0,0.1);
  --transition:all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --transition-smooth:all 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

* {
  margin:0;
  padding:0;
  box-sizing:border-box;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

html {
  scroll-behavior:smooth;
  scroll-padding-top:110px;
}

section {
  scroll-margin-top:110px;
  transition:opacity 0.3s ease;
}

body {
  font-family:'Poppins',sans-serif;
  overflow-x:hidden;
  background:var(--light-bg);
  color:var(--text-primary);
  transition:background-color 0.4s ease, color 0.4s ease;
}

.nav-item,
.submenu,
.footer-social a,
.card,
.grid-card,
.grid-card-inner,
.grid-panel {
  border-radius:20px;
}

.topbar {
  position:fixed;
  top:0;
  width:100%;
  height:110px;
  background:var(--purple);
  z-index:1000;
  box-shadow:0 2px 10px rgba(0,0,0,0.1);
  transition:all 0.3s ease;
  overflow:visible;
}

.nav-inner {
  height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 40px;
  position:relative;
}

.logo {
  display:flex;
  align-items:center;
}

.logo a {
  display:flex;
  align-items:center;
  text-decoration:none;
}

.logo img {
  height:70px;
  transition:transform 0.3s ease;
}

.logo:hover img {
  transform:scale(1.05);
}

.mobile-menu-toggle {
  display:none;
  flex-direction:column;
  justify-content:space-around;
  width:30px;
  height:30px;
  background:transparent;
  border:none;
  cursor:pointer;
  padding:0;
  z-index:1001;
  position:relative;
}

.hamburger-line {
  width:100%;
  height:3px;
  background:white;
  border-radius:3px;
  transition:all 0.3s ease;
  transform-origin:center;
}

.mobile-menu-toggle.active .hamburger-line:nth-child(1) {
  transform:rotate(45deg) translate(8px, 8px);
}

.mobile-menu-toggle.active .hamburger-line:nth-child(2) {
  opacity:0;
}

.mobile-menu-toggle.active .hamburger-line:nth-child(3) {
  transform:rotate(-45deg) translate(7px, -7px);
}

.nav-menu {
  display:block;
}

.menu {
  list-style:none;
  display:flex;
  align-items:center;
  gap:12px;
}

.nav-item {
  padding:14px 20px;
  border-radius:8px;
  background:transparent;
  color:white;
  text-decoration:none;
  font:inherit;
  border:none;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:6px;
  transition:var(--transition);
}

.nav-item:hover {
  background:var(--yellow);
  color:var(--dark);
  transform:translateY(-2px);
}

.dropdown {
  position:relative;
}

.submenu {
  position:absolute;
  top:100%;
  left:0;
  background:var(--purple);
  list-style:none;
  min-width:220px;
  padding:10px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(5px);
  transition:opacity 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94), visibility 0.3s;
  border-radius:0 0 15px 15px;
}

.submenu a {
  display:block;
  padding:12px 20px;
  color:white;
  text-decoration:none;
  transition:var(--transition);
}

.submenu a:hover {
  background:var(--yellow);
  color:var(--dark);
  padding-left:25px;
}

@media (min-width:969px) {
  .dropdown:hover .submenu {
    opacity:1;
    visibility:visible;
    transform:translateY(0);
  }
}

.hero {
  height:100vh;
  position:relative;
}

.hero-img {
  width:100%;
  height:100%;
  object-fit:cover;
}

.overlay {
  position:absolute;
  inset:0;
  background:linear-gradient(135deg, rgba(111, 44, 145, 0.7) 0%, rgba(111, 44, 145, 0.4) 100%);
}

.hero-content {
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  padding:40px;
  color:white;
  text-align:center;
  gap:40px;
}

.typed-text-container {
  min-height:120px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.typed-text {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(3rem, 8vw, 6rem);
  letter-spacing:3px;
  text-shadow:2px 2px 10px rgba(0,0,0,0.5);
  animation:fadeIn 1s ease;
  margin:0;
  line-height:1.2;
}


@keyframes fadeIn {
  from {
    opacity:0;
    transform:translateY(20px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

.hero h1 {
  font-family:'Bebas Neue',sans-serif;
  font-size:120px;
}

.section {
  padding:100px 0;
  transition:opacity 0.3s ease, transform 0.3s ease;
}

#plan {
  background:var(--light-bg);
  transition:background 0.4s ease;
}

#plan h2 {
  font-family:'Bebas Neue',sans-serif;
  font-size:3rem;
  color:var(--purple);
  text-align:center;
  margin-bottom:20px;
  letter-spacing:2px;
}

#plan p {
  text-align:center;
  font-size:1.2rem;
  color:var(--text-secondary);
  max-width:700px;
  margin:0 auto 40px;
}

.cta-container {
  display:flex;
  gap:20px;
  justify-content:center;
  flex-wrap:wrap;
  margin-top:40px;
}

.cta-button {
  display:inline-flex;
  align-items:center;
  gap:12px;
  padding:16px 32px;
  border-radius:50px;
  text-decoration:none;
  font-weight:600;
  font-size:1.1rem;
  transition:var(--transition-smooth);
  border:none;
  cursor:pointer;
  box-shadow:0 4px 15px var(--shadow);
}

.cta-button.primary {
  background:var(--purple);
  color:white;
}

.cta-button.primary:hover {
  background:#5a2475;
  transform:translateY(-2px);
  box-shadow:0 8px 25px rgba(111,44,145,0.3);
}

.cta-button.secondary {
  background:var(--yellow);
  color:var(--dark);
}

.cta-button.secondary:hover {
  background:#d4d23a;
  transform:translateY(-2px);
  box-shadow:0 8px 25px rgba(234,232,75,0.3);
  color:var(--dark);
}

.cta-button.hero-cta {
  margin-top:30px;
  background:rgba(255,255,255,0.2);
  color:white;
  backdrop-filter:blur(10px);
  border:2px solid rgba(255,255,255,0.3);
}

.cta-button.hero-cta:hover {
  background:var(--yellow);
  color:var(--dark);
  border-color:var(--yellow);
  transform:translateY(-3px);
}


.container {
  max-width:1200px;
  margin:auto;
  padding:0 20px;
}

/* ANIMACIONES SCROLL */

.reveal {
  opacity:0;
  transform:translateY(30px);
  transition:opacity 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.reveal.visible {
  opacity:1;
  transform:translateY(0);
}

/* FOOTER */

.footer {
  background:linear-gradient(135deg, var(--purple) 0%, #5a2475 100%);
  color:white;
  padding:80px 0 30px;
  position:relative;
  overflow:hidden;
}

.footer::before {
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:4px;
  background:linear-gradient(90deg, var(--yellow) 0%, var(--purple) 50%, var(--yellow) 100%);
}

.footer-content {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(250px, 1fr));
  gap:50px;
  margin-bottom:50px;
}

.footer-section {
  display:flex;
  flex-direction:column;
}

.footer-logo img {
  height:60px;
  margin-bottom:15px;
}

.footer-tagline {
  color:rgba(255,255,255,0.9);
  font-size:0.95rem;
  line-height:1.6;
  margin:0;
}

.footer-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.5rem;
  letter-spacing:1px;
  margin-bottom:20px;
  color:var(--yellow);
}

.footer-links {
  list-style:none;
  padding:0;
  margin:0;
}

.footer-links li {
  margin-bottom:12px;
}

.footer-links a {
  color:rgba(255,255,255,0.9);
  text-decoration:none;
  font-size:0.95rem;
  transition:var(--transition);
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.footer-links a::before {
  content:'→';
  opacity:0;
  transform:translateX(-8px);
  transition:var(--transition);
}

.footer-links a:hover {
  color:var(--yellow);
  transform:translateX(3px);
}

.footer-links a:hover::before {
  opacity:1;
  transform:translateX(0);
}

.footer-social {
  display:flex;
  flex-direction:column;
  gap:12px;
}

.social-link {
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 16px;
  background:rgba(255,255,255,0.1);
  border-radius:10px;
  color:white;
  text-decoration:none;
  transition:var(--transition);
  font-size:0.95rem;
  backdrop-filter:blur(10px);
}

.social-link i {
  font-size:1.2rem;
  width:24px;
  text-align:center;
}

.social-link:hover {
  background:var(--yellow);
  color:var(--dark);
  transform:translateX(3px);
}

.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.2);
  padding-top:30px;
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}

.footer-copyright {
  color:rgba(255,255,255,0.8);
  font-size:0.9rem;
  margin:0;
  text-align:center;
}

.footer-legal {
  display:flex;
  align-items:center;
  gap:15px;
  font-size:0.9rem;
}

.footer-legal a {
  color:rgba(255,255,255,0.8);
  text-decoration:none;
  transition:var(--transition);
}

.footer-legal a:hover {
  color:var(--yellow);
}

.footer-legal span {
  color:rgba(255,255,255,0.4);
}

.grid-2 {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:30px;
  perspective:1200px;
  max-width:900px;
  margin:60px auto 0;
}

.grid-card {
  height:300px;
  cursor:pointer;
  transition:var(--transition-smooth);
}

.grid-card:hover {
  transform:translateY(-8px);
}

.grid-card:focus {
  outline:3px solid var(--yellow);
  outline-offset:4px;
}

.grid-card-inner {
  position:relative;
  width:100%;
  height:100%;
  transform-style:preserve-3d;
  transition:transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.grid-card:hover .grid-card-inner,
.grid-card.active .grid-card-inner {
  transform:rotateY(180deg);
}

.grid-front,
.grid-back {
  position:absolute;
  inset:0;
  backface-visibility:hidden;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:40px 30px;
  text-align:center;
  border-radius:20px;
  box-shadow:0 10px 30px rgba(0,0,0,0.2);
}

.grid-front {
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  color:white;
}

.grid-front i,
.grid-back i {
  font-size:3.5rem;
  margin-bottom:20px;
  opacity:0.9;
  transition:transform 0.3s ease;
}

.grid-card:hover .grid-front i {
  transform:scale(1.1);
}

.grid-front h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:2.2rem;
  letter-spacing:2px;
  margin:0;
}

.grid-back {
  background:linear-gradient(135deg, var(--yellow) 0%, #F5F56B 100%);
  color:var(--dark);
  transform:rotateY(180deg);
}

.grid-back i {
  color:var(--purple);
}

.grid-back p {
  font-size:1.1rem;
  line-height:1.6;
  margin:0;
  font-weight:500;
}

.section-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:3.5rem;
  color:var(--purple);
  text-align:center;
  margin-bottom:15px;
  letter-spacing:2px;
}

.section-subtitle {
  text-align:center;
  font-size:1.2rem;
  color:var(--text-secondary);
  margin-bottom:40px;
}

.youtube-section {
  padding:100px 0;
  background:linear-gradient(135deg, rgba(111,44,145,0.05) 0%, rgba(234,232,75,0.05) 100%);
}

.youtube-section .section-title {
  margin-bottom:50px;
}

.video-container {
  position:relative;
  width:100%;
  max-width:900px;
  margin:0 auto;
  padding-bottom:56.25%;
  height:0;
  overflow:hidden;
  border-radius:20px;
  box-shadow:0 10px 40px rgba(0,0,0,0.2);
  background:var(--dark);
}

.video-container iframe {
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  border:none;
  border-radius:20px;
}

@media(max-width:968px){
  .mobile-menu-toggle {
    display:flex;
  }

  .nav-menu {
    position:fixed;
    top:110px;
    left:0;
    width:100%;
    background:var(--purple);
    max-height:0;
    overflow:hidden;
    transition:max-height 0.4s ease, box-shadow 0.3s ease;
    box-shadow:0 5px 15px rgba(0,0,0,0.2);
    z-index:999;
  }

  .nav-menu.active {
    max-height:600px;
    overflow-y:auto;
  }

  .menu {
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:20px;
    width:100%;
  }

  .menu li {
    width:100%;
    display:block;
  }

  .nav-item {
    width:100%;
    padding:16px 20px;
    justify-content:space-between;
    border-radius:10px;
    margin-bottom:8px;
    font-size:1rem;
  }

  .dropdown {
    position:static;
  }

  .submenu {
    position:static;
    opacity:1;
    visibility:visible;
    transform:none;
    background:rgba(0,0,0,0.2);
    margin-top:8px;
    margin-left:20px;
    max-height:0;
    overflow:hidden;
    transition:max-height 0.3s ease;
    padding:0;
    min-width:auto;
  }

  .dropdown.active .submenu {
    max-height:300px;
    padding:10px 0;
  }

  .submenu a {
    padding:12px 20px;
    border-radius:8px;
    margin-bottom:4px;
  }

  .nav-inner {
    padding:0 20px;
  }

  .logo img {
    height:55px;
  }

  .nav-menu {
    display:none;
  }

  .nav-menu.active {
    display:block;
  }
}

@media(min-width:969px){
  .nav-menu {
    display:block !important;
    position:static !important;
    max-height:none !important;
    overflow:visible !important;
    background:transparent !important;
    box-shadow:none !important;
  }
  
  .mobile-menu-toggle {
    display:none !important;
  }
}

@media(max-width:768px){
  .grid-2 {
    grid-template-columns:1fr;
    gap:25px;
    max-width:100%;
  }

  .grid-card {
    height:280px;
  }

  .section-title {
    font-size:2.5rem;
  }
}

@media(max-width:600px){
  .hero-content {
    padding-left:20px;
    padding-right:20px;
  }

  .grid-card {
    height:260px;
  }

  .grid-front i,
  .grid-back i {
    font-size:2.5rem;
    margin-bottom:15px;
  }

  .grid-front h3 {
    font-size:1.8rem;
  }

  .grid-back p {
    font-size:1rem;
  }
}

.page-hero {
  position:relative;
  height:400px;
  background:linear-gradient(135deg, var(--purple) 0%, #5a2475 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-top:110px;
  overflow:hidden;
}

.page-hero-overlay {
  position:absolute;
  inset:0;
  background:url('../assets/images/fondo.jpg') center/cover;
  opacity:0.2;
}

.page-hero-content {
  position:relative;
  z-index:2;
  text-align:center;
  color:white;
  padding:40px 20px;
}

.page-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2.5rem, 6vw, 4.5rem);
  letter-spacing:3px;
  margin-bottom:15px;
  text-shadow:2px 2px 10px rgba(0,0,0,0.3);
}

.page-subtitle {
  font-size:clamp(1rem, 2vw, 1.3rem);
  opacity:0.95;
  max-width:700px;
  margin:0 auto;
}

.content-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
  margin-top:40px;
}

.content-text {
  display:flex;
  flex-direction:column;
  gap:20px;
}

.lead-text {
  font-size:1.3rem;
  color:var(--text-secondary);
  line-height:1.7;
  font-weight:400;
}

.content-image {
  position:relative;
}

.image-placeholder {
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  border-radius:20px;
  padding:80px 40px;
  text-align:center;
  color:white;
  min-height:300px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
}

.image-placeholder i {
  font-size:4rem;
  opacity:0.8;
}

.stats-container {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  margin-top:40px;
}

.stat-item {
  text-align:center;
  padding:30px 20px;
  background:var(--light-bg);
  border-radius:15px;
  transition:var(--transition);
}

.stat-item:hover {
  transform:translateY(-5px);
  box-shadow:0 10px 30px var(--shadow);
}

.stat-item i {
  font-size:2.5rem;
  color:var(--purple);
  margin-bottom:15px;
}

.stat-item h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:2.5rem;
  color:var(--purple);
  margin:10px 0;
}

.stat-item p {
  color:var(--text-secondary);
  font-size:0.95rem;
}

.alt-bg {
  background:var(--light-bg);
}

.ideology-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(300px, 1fr));
  gap:30px;
  margin-top:50px;
}

.ideology-card {
  background:white;
  padding:40px 30px;
  border-radius:20px;
  text-align:center;
  transition:var(--transition);
  box-shadow:0 5px 20px var(--shadow);
}

.ideology-card:hover {
  transform:translateY(-10px);
  box-shadow:0 15px 40px rgba(111,44,145,0.2);
}

.ideology-icon {
  width:80px;
  height:80px;
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 25px;
  color:white;
  font-size:2rem;
}

.ideology-card h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem;
  color:var(--purple);
  margin-bottom:15px;
  letter-spacing:1px;
}

.ideology-card p {
  color:var(--text-secondary);
  line-height:1.7;
}

.founders-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:40px;
  margin-top:50px;
}

.founder-card {
  background:white;
  border-radius:20px;
  padding:40px 30px;
  text-align:center;
  transition:var(--transition);
  box-shadow:0 5px 20px var(--shadow);
}

.founder-card:hover {
  transform:translateY(-10px);
  box-shadow:0 15px 40px rgba(111,44,145,0.2);
}

.founder-image {
  width:150px;
  height:150px;
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto 25px;
  color:white;
  font-size:4rem;
}

.founder-card h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem;
  color:var(--purple);
  margin-bottom:10px;
}

.founder-role {
  color:var(--yellow);
  font-weight:600;
  margin-bottom:15px;
  font-size:1.1rem;
}

.founder-bio {
  color:var(--text-secondary);
  line-height:1.7;
}

.bio-container {
  display:grid;
  grid-template-columns:350px 1fr;
  gap:60px;
  margin-top:40px;
}

.bio-image-section {
  position:relative;
}

.president-image {
  width:100%;
  aspect-ratio:1;
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:8rem;
  box-shadow:0 10px 40px rgba(111,44,145,0.3);
}

.president-badge {
  position:absolute;
  bottom:-20px;
  left:50%;
  transform:translateX(-50%);
  background:var(--yellow);
  color:var(--dark);
  padding:12px 25px;
  border-radius:50px;
  font-weight:600;
  display:flex;
  align-items:center;
  gap:8px;
  box-shadow:0 5px 20px rgba(234,232,75,0.4);
}

.bio-timeline {
  margin-top:40px;
}

.timeline-item {
  display:flex;
  gap:25px;
  margin-bottom:35px;
  position:relative;
}

.timeline-item::before {
  content:'';
  position:absolute;
  left:25px;
  top:60px;
  bottom:-35px;
  width:2px;
  background:var(--purple);
  opacity:0.2;
}

.timeline-item:last-child::before {
  display:none;
}

.timeline-icon {
  width:50px;
  height:50px;
  background:var(--purple);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:1.3rem;
  flex-shrink:0;
}

.timeline-content h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.5rem;
  color:var(--purple);
  margin-bottom:10px;
  letter-spacing:1px;
}

.timeline-content p {
  color:var(--text-secondary);
  line-height:1.7;
}

.proposals-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr));
  gap:30px;
  margin-top:50px;
}

.proposal-card {
  background:white;
  padding:35px 30px;
  border-radius:20px;
  transition:var(--transition);
  box-shadow:0 5px 20px var(--shadow);
  border-top:4px solid var(--purple);
}

.proposal-card:hover {
  transform:translateY(-10px);
  box-shadow:0 15px 40px rgba(111,44,145,0.2);
}

.proposal-icon {
  width:70px;
  height:70px;
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  border-radius:15px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:2rem;
  margin-bottom:20px;
}

.proposal-card h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem;
  color:var(--purple);
  margin-bottom:20px;
  letter-spacing:1px;
}

.proposal-card ul {
  list-style:none;
  padding:0;
}

.proposal-card ul li {
  padding:10px 0;
  color:var(--text-secondary);
  padding-left:25px;
  position:relative;
}

.proposal-card ul li::before {
  content:'✓';
  position:absolute;
  left:0;
  color:var(--purple);
  font-weight:bold;
}

.proposal-detail {
  max-width:900px;
  margin:0 auto;
}

.proposal-header {
  display:flex;
  align-items:center;
  gap:25px;
  margin-bottom:30px;
}

.proposal-icon-large {
  width:100px;
  height:100px;
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:3rem;
  flex-shrink:0;
}

.proposal-content {
  margin-top:30px;
}

.proposal-content h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:2rem;
  color:var(--purple);
  margin-bottom:25px;
  letter-spacing:1px;
}

.proposal-list {
  list-style:none;
  padding:0;
}

.proposal-list li {
  padding:20px 0;
  padding-left:40px;
  position:relative;
  border-bottom:1px solid rgba(111,44,145,0.1);
  line-height:1.8;
}

.proposal-list li:last-child {
  border-bottom:none;
}

.proposal-list li i {
  position:absolute;
  left:0;
  top:20px;
  color:var(--purple);
  font-size:1.2rem;
}

.proposal-list li strong {
  color:var(--purple);
}

/* Contact Container */
.contact-container {
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:60px;
  margin-top:40px;
}

.contact-cards {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:25px;
  margin-top:30px;
}

.contact-card {
  background:white;
  padding:30px 25px;
  border-radius:15px;
  text-align:center;
  transition:var(--transition);
  box-shadow:0 5px 20px var(--shadow);
  border-top:4px solid var(--purple);
}

.contact-card:hover {
  transform:translateY(-5px);
  box-shadow:0 10px 30px rgba(111,44,145,0.2);
}

.contact-icon {
  width:60px;
  height:60px;
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:1.5rem;
  margin:0 auto 20px;
}

.contact-card h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.5rem;
  color:var(--purple);
  margin-bottom:15px;
}

.contact-card p {
  color:var(--text-secondary);
  font-size:0.95rem;
  margin:5px 0;
}

.social-contact {
  margin-top:40px;
}

.social-contact h3 {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem;
  color:var(--purple);
  margin-bottom:20px;
}

.social-buttons {
  display:flex;
  flex-wrap:wrap;
  gap:15px;
}

.social-btn {
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 20px;
  background:white;
  border-radius:10px;
  text-decoration:none;
  color:var(--text-primary);
  transition:var(--transition);
  box-shadow:0 3px 10px var(--shadow);
}

.social-btn:hover {
  background:var(--purple);
  color:white;
  transform:translateY(-3px);
}

.contact-form-container {
  background:white;
  padding:40px;
  border-radius:20px;
  box-shadow:0 10px 40px var(--shadow);
}

.contact-form {
  margin-top:30px;
}

.form-group {
  margin-bottom:25px;
}

.form-group label {
  display:block;
  margin-bottom:8px;
  color:var(--text-primary);
  font-weight:500;
  font-size:0.95rem;
}

.required {
  color:var(--purple);
}

.form-group input,
.form-group select,
.form-group textarea {
  width:100%;
  padding:14px 18px;
  border:2px solid #e0e0e0;
  border-radius:10px;
  font-family:'Poppins',sans-serif;
  font-size:1rem;
  transition:var(--transition);
  background:white;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline:none;
  border-color:var(--purple);
  box-shadow:0 0 0 3px rgba(111,44,145,0.1);
}

.checkbox-group {
  display:flex;
  align-items:flex-start;
  gap:10px;
}

.checkbox-label {
  display:flex;
  align-items:flex-start;
  gap:10px;
  cursor:pointer;
  font-size:0.9rem;
  color:var(--text-secondary);
}

.checkbox-label input[type="checkbox"] {
  width:auto;
  margin-top:3px;
  cursor:pointer;
}

.checkbox-label a {
  color:var(--purple);
  text-decoration:none;
}

.checkbox-label a:hover {
  text-decoration:underline;
}

.form-submit {
  width:100%;
  justify-content:center;
  margin-top:10px;
}

.map-container {
  margin-top:40px;
}

.map-placeholder {
  background:linear-gradient(135deg, var(--purple) 0%, #5a2475 100%);
  border-radius:20px;
  padding:100px 40px;
  text-align:center;
  color:white;
  min-height:400px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:20px;
}

.map-placeholder i {
  font-size:5rem;
  opacity:0.9;
}

.map-note {
  font-size:1.1rem;
  opacity:0.9;
}

.news-filters {
  display:flex;
  gap:15px;
  margin-bottom:40px;
  flex-wrap:wrap;
  justify-content:center;
}

.filter-btn {
  padding:12px 25px;
  background:white;
  border:2px solid #e0e0e0;
  border-radius:50px;
  cursor:pointer;
  font-weight:500;
  transition:var(--transition);
  color:var(--text-primary);
}

.filter-btn:hover,
.filter-btn.active {
  background:var(--purple);
  color:white;
  border-color:var(--purple);
}

.news-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(350px, 1fr));
  gap:30px;
  margin-top:40px;
}

.news-card {
  background:white;
  border-radius:20px;
  overflow:hidden;
  transition:var(--transition);
  box-shadow:0 5px 20px var(--shadow);
  display:flex;
  flex-direction:column;
}

.news-card:hover {
  transform:translateY(-10px);
  box-shadow:0 15px 40px rgba(111,44,145,0.2);
}

.news-image {
  width:100%;
  height:200px;
  background:linear-gradient(135deg, var(--purple) 0%, #8B3DA8 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:4rem;
}

.news-content {
  padding:30px;
  flex:1;
  display:flex;
  flex-direction:column;
}

.news-meta {
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:15px;
  font-size:0.85rem;
  flex-wrap:wrap;
  gap:10px;
}

.news-date {
  color:var(--text-secondary);
  display:flex;
  align-items:center;
  gap:5px;
}

.news-category {
  background:var(--yellow);
  color:var(--dark);
  padding:4px 12px;
  border-radius:20px;
  font-weight:600;
  font-size:0.8rem;
}

.news-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.8rem;
  color:var(--purple);
  margin-bottom:15px;
  letter-spacing:1px;
  line-height:1.3;
}

.news-excerpt {
  color:var(--text-secondary);
  line-height:1.7;
  margin-bottom:20px;
  flex:1;
}

.news-link {
  color:var(--purple);
  text-decoration:none;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:var(--transition);
}

.news-link:hover {
  gap:12px;
  color:#5a2475;
}

.pagination {
  display:flex;
  justify-content:center;
  align-items:center;
  gap:20px;
  margin-top:50px;
}

.pagination-btn {
  padding:12px 25px;
  background:white;
  border:2px solid var(--purple);
  border-radius:10px;
  color:var(--purple);
  cursor:pointer;
  font-weight:500;
  transition:var(--transition);
  display:flex;
  align-items:center;
  gap:8px;
}

.pagination-btn:hover:not(:disabled) {
  background:var(--purple);
  color:white;
}

.pagination-btn:disabled {
  opacity:0.5;
  cursor:not-allowed;
}

.pagination-info {
  color:var(--text-secondary);
  font-weight:500;
}

.newsletter-form {
  display:flex;
  gap:15px;
  max-width:500px;
  margin:30px auto 0;
  flex-wrap:wrap;
  justify-content:center;
}

.newsletter-input {
  flex:1;
  min-width:250px;
  padding:16px 20px;
  border:2px solid #e0e0e0;
  border-radius:50px;
  font-family:'Poppins',sans-serif;
  font-size:1rem;
  transition:var(--transition);
}

.newsletter-input:focus {
  outline:none;
  border-color:var(--purple);
  box-shadow:0 0 0 3px rgba(111,44,145,0.1);
}

.cta-section {
  background:linear-gradient(135deg, rgba(111,44,145,0.05) 0%, rgba(234,232,75,0.05) 100%);
  padding:80px 0;
}

@media(max-width:968px){
  .content-grid {
    grid-template-columns:1fr;
    gap:40px;
  }

  .bio-container {
    grid-template-columns:1fr;
  }

  .president-image {
    max-width:300px;
    margin:0 auto;
  }

  .contact-container {
    grid-template-columns:1fr;
  }

  .contact-cards {
    grid-template-columns:1fr;
  }

  .stats-container {
    grid-template-columns:1fr;
  }

  .ideology-grid,
  .founders-grid,
  .proposals-grid {
    grid-template-columns:1fr;
  }

  .news-grid {
    grid-template-columns:1fr;
  }

  .newsletter-form {
    flex-direction:column;
  }

  .newsletter-input {
    width:100%;
  }
}

@media(max-width:600px){
  .page-hero {
    height:300px;
  }

  .page-title {
    font-size:2rem;
  }

  .contact-form-container {
    padding:25px;
  }

  .newsletter-form {
    flex-direction:column;
  }
}

.scroll-to-top {
  position:fixed;
  bottom:30px;
  right:30px;
  width:50px;
  height:50px;
  background:var(--purple);
  color:white;
  border:none;
  border-radius:50%;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.2rem;
  opacity:0;
  visibility:hidden;
  transform:translateY(15px);
  transition:var(--transition-smooth);
  z-index:999;
  box-shadow:0 4px 15px rgba(111,44,145,0.4);
}

.scroll-to-top.visible {
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.scroll-to-top:hover {
  background:#5a2475;
  transform:translateY(-3px);
  box-shadow:0 8px 25px rgba(111,44,145,0.4);
}

.scroll-to-top:focus {
  outline:3px solid var(--yellow);
  outline-offset:3px;
}

.footer {
  background:var(--purple);
  color:white;
}

.footer p {
  color:white;
  font-weight:500;
}

.footer-social a {
  background:rgba(255,255,255,0.2);
  color:white;
}

.footer-social a:hover {
  background:var(--yellow);
  color:var(--dark);
}

@media(max-width:768px){
  .scroll-to-top {
    width:45px;
    height:45px;
    font-size:1rem;
    bottom:20px;
    right:20px;
  }

  .footer-content {
    grid-template-columns:1fr;
    gap:40px;
  }

  .footer-bottom {
    flex-direction:column;
    text-align:center;
  }

  .video-container {
    border-radius:15px;
  }

  .typed-text-container {
    min-height:100px;
  }
}

.bio-content p {
  text-align: justify;
  hyphens: auto;
}

