/*
  Atacama IA - Neon Theme (refined typography & contrast)
  1. Variables & Base Styles
  2. Layout & Structure
  3. Components
  4. Animations & Utilities
*/

/* =================================== */
/* 1. Variables & Base Styles          */
/* =================================== */
:root {
  /* Nueva paleta de colores del Desierto de Atacama */
  --color-black-deep: #000000;
  --color-white-bright: #FFFFFF;
  --color-copper-solar: #D57C1E;
  --color-blue-sky: #2B8CBE;
  --color-red-ananuca: #D43D3D;
  --color-green-leaf: #3C8D40;
  --color-sand: #F0D6A6;

  /* Mapeo a variables genéricas */
  --color-text-primary: #fefbf4;
  --color-text-secondary: #e6f0ff;
  --color-text-muted: #c6d8ff;
  --color-background: #0D141C; /* Derivado del negro profundo, con matiz azul */
  --color-surface: #121B28; /* Un tono más claro para superficies */
  --color-primary: var(--color-blue-sky);
  --color-accent: var(--color-copper-solar);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  background-color:var(--color-background);
  background-image:linear-gradient(rgba(43, 140, 190, .08) 1px, transparent 1px),linear-gradient(90deg, rgba(43, 140, 190, .08) 1px, transparent 1px);
  background-size:2rem 2rem;
  color:var(--color-text-secondary);
  font-family:'Inter', 'Roboto', 'Segoe UI', sans-serif;
  font-weight:400;
  letter-spacing:.01em;
  color-scheme: dark;
}
input,textarea,select{color:var(--color-text-primary)!important;background-color:rgba(2,17,44,.82);caret-color:var(--color-text-primary);}
input::placeholder,textarea::placeholder{color:rgba(255,255,255,.55)!important;}
input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill{
  -webkit-text-fill-color:var(--color-text-primary)!important;
  transition:background-color 10000s ease-in-out 0s;
  box-shadow:0 0 0px 1000px rgba(2,17,44,.82) inset;
}
p, li{line-height:1.75;color:var(--color-text-secondary);}
small, .text-muted{color:var(--color-text-muted)!important;}
h1,h2,h3,h4,h5,h6,
.h1,.h2,.h3,.h4,.h5,.h6{
  color:var(--color-text-primary);
  font-family:'Montserrat', 'Poppins', 'Segoe UI', sans-serif;
  font-weight:700;
  letter-spacing:.02em;
}
a{color:var(--color-primary);text-decoration:none;transition:color .2s ease, text-shadow .2s ease}
a:hover{color:var(--color-accent);text-shadow:0 0 10px rgba(213, 124, 30, .3)}

/* =================================== */
/* 2. Layout & Structure               */
/* =================================== */
.full-bleed{width:100%;margin:0}
.container-xxl{max-width:1320px}
.band{padding:clamp(4rem, 8vw, 6.5rem) 0;}
.band-dark{background:var(--color-surface)}
.band-darker{background:var(--color-background)}
.band-gradient{background:linear-gradient(135deg, var(--color-surface), var(--color-background))}
.section-title{font-weight:800;letter-spacing:.5px;color:var(--color-text-primary);text-shadow:0 4px 14px rgba(0,0,0,.25)}
.section-sub{color:var(--color-text-secondary)}

.main-footer{padding-top:64px;padding-bottom:64px;background:#04142b;border-top:1px solid rgba(7,219,242,.18);color:var(--color-text-secondary)}
.main-footer h5{color:var(--color-text-primary)}
.footer-cta{background:rgba(6,32,76,.8);border:1px solid rgba(7,219,242,.25);border-radius:24px;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.footer-cta h3{color:var(--color-text-primary);font-weight:700}
.footer-columns .footer-links li{margin-bottom:.35rem}
.footer-columns .footer-links a{color:var(--color-text-secondary);text-decoration:none;transition:color .2s ease, text-shadow .2s ease}
.footer-columns .footer-links a:hover{color:var(--color-accent);text-shadow:0 0 10px rgba(213, 124, 30, .3)}
.footer-social a{width:42px;height:42px;border-radius:12px;border:1px solid rgba(255,255,255,.25);display:grid;place-items:center;color:var(--color-text-primary);transition:transform .2s ease, box-shadow .2s ease}
.footer-social a:hover{transform:translateY(-4px);box-shadow:0 14px 30px rgba(43, 140, 190, .25);color:var(--color-primary)}
.footer-form .form-control{background:rgba(2,17,44,.85);border:1px solid rgba(255,255,255,.18);color:var(--color-text-primary)}
.footer-form .form-control::placeholder{color:rgba(255,255,255,.45)}
.footer-form .btn{border-color:rgba(255,255,255,.4)}
.footer-form .btn:hover{background:var(--atacama-primary);border-color:var(--atacama-primary);color:#02121e}
.footer-links li{margin-bottom:.6rem}
.footer-links a{color:var(--color-text-muted);transition:color .2s ease}
.footer-links a:hover{color:var(--color-text-primary)}

/* =================================== */
/* 3. Components                       */
/* =================================== */
/* Navbar */
.navbar{background:linear-gradient(180deg, rgba(13, 20, 28, .9), rgba(13, 20, 28, .55));backdrop-filter:blur(16px);border-bottom:1px solid rgba(43, 140, 190, .18)}
.navbar .nav-link{color:var(--color-text-secondary);font-weight:500;text-shadow:0 0 6px transparent;position:relative;padding-top:.7rem;padding-bottom:.7rem}
.navbar .nav-link:hover{color:var(--color-accent);text-shadow:0 0 10px rgba(213, 124, 30, .4)}.navbar .nav-link::after{content:'';position:absolute;left:50%;bottom:0;width:0;height:2px;background:var(--color-primary);transition:all .3s ease;transform:translateX(-50%);box-shadow:0 0 12px rgba(43, 140, 190, .6)}
.navbar .nav-link:hover::after{width:60%}
.offcanvas{background:linear-gradient(180deg, var(--color-surface), var(--color-background));border-left:1px solid rgba(43, 140, 190, .25)}
.navbar-brand {
  font-size: 1.5rem; /* Ajustamos el tamaño para que sea coherente con el logo */
}
.brand-text--gold {
  background: linear-gradient(145deg, var(--color-sand), var(--color-accent), var(--color-sand));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}
.offcanvas .nav-link{font-size:1.15rem;padding-top:1rem;padding-bottom:1rem;color:var(--color-text-primary)}
.offcanvas .nav-link:hover{color:var(--color-primary)}

/* Buttons */
.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-white-bright);font-weight:700;transition:background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease}
.btn-primary:hover{background:#52a9d8;border-color:#52a9d8;color:var(--color-white-bright);transform:translateY(-2px);box-shadow:0 8px 20px rgba(43, 140, 190, .25)}
.btn-outline{background:transparent;border:1px solid rgba(43, 140, 190, .45);color:var(--color-text-primary);transition:background .2s ease}
.btn-outline:hover{background:rgba(43, 140, 190, .16)}
.btn-warning{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-white-bright);font-weight:700;transition:background .2s ease, border-color .2s ease, transform .2s ease, box-shadow .2s ease}
.btn-warning:hover{background:#e68c2f;border-color:#e68c2f;color:var(--color-white-bright);transform:translateY(-2px);box-shadow:0 8px 20px rgba(213, 124, 30, .22)}

/* Cards */
.card{background:rgba(18, 27, 40, 0.6);border:1px solid rgba(43, 140, 190, .2);border-radius:18px;box-shadow:0 20px 50px rgba(0,0,0,.35);backdrop-filter:blur(6px);color:var(--color-text-secondary)}
.card h1,.card h2,.card h3,.card h4,.card h5,.card h6{color:var(--color-text-primary)}
.card p,.card li,.card span{color:var(--color-text-secondary)}
.card.glow{box-shadow:0 28px 80px rgba(213, 124, 30, .18)}
.news-card img{aspect-ratio:16/9;object-fit:cover;border-top-left-radius:18px;border-top-right-radius:18px}
.news-card .meta{font-size:.9rem;color:var(--color-text-muted)}
.metric-card{text-align:center}
.metric-card .icon{margin:0 auto 1rem auto;width:80px;height:80px;border-radius:24px;background:rgba(7,219,242,.1);border:1px solid rgba(7,219,242,.3);color:var(--color-text-primary)}
.metric-card .metric-number{font-size:3rem;font-weight:800;color:var(--color-text-primary);line-height:1}
.section-heading{max-width:760px;margin:0 auto 2.5rem auto}
.section-eyebrow{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .9rem;border-radius:999px;background:rgba(255,255,255,.06);color:var(--color-text-muted);letter-spacing:.12em;font-size:.78rem;text-transform:uppercase;margin-bottom:1rem}
.service-steps{position:relative}
.service-card{background:rgba(18, 27, 40, .72);border:1px solid rgba(43, 140, 190, .22);border-radius:22px;padding:clamp(1.5rem, 5vw, 2.2rem);display:flex;flex-direction:column;gap:1rem;transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease}
.service-card:hover{transform:translateY(-10px);box-shadow:0 32px 90px rgba(0,0,0,.45);border-color:rgba(43, 140, 190, .45)}
.service-card h3{color:var(--color-text-primary);font-weight:700}
.service-card p{color:var(--color-text-secondary);margin-bottom:.5rem}
.service-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem;color:var(--color-text-secondary)}
.service-card ul li{display:flex;gap:.6rem;align-items:flex-start}
.service-card ul li::before{content:'•';color:var(--color-primary);margin-top:.2rem}
.service-icon{width:60px;height:60px;border-radius:18px;background:rgba(43, 140, 190, .12);display:grid;place-items:center;color:var(--color-primary);font-size:1.4rem}
.service-card:hover .service-icon{box-shadow:0 0 25px rgba(43, 140, 190, .35);transform:scale(1.05);transition:all .3s ease}
.step-badge{align-self:flex-start;padding:.3rem .8rem;border-radius:999px;background:rgba(213, 124, 30, .18);border:1px solid rgba(213, 124, 30, .4);font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:#f7ecff;font-weight:600}
.service-link{margin-top:auto;display:inline-flex;align-items:center;gap:.5rem;color:var(--color-primary);font-weight:600;text-decoration:none}
.service-link:hover{color:var(--color-accent);text-shadow:0 0 16px rgba(213, 124, 30, .45)}
.method-grid{position:relative}
.method-card{background:rgba(18, 27, 40, .74);border:1px solid rgba(255,255,255,.14);border-radius:22px;padding:clamp(1.5rem, 5vw, 2rem);display:flex;flex-direction:column;gap:1rem;height:100%;transition:transform .3s ease, box-shadow .3s ease}
.method-card:hover{transform:translateY(-8px);box-shadow:0 28px 80px rgba(0,0,0,.4)}
.method-card h3{font-weight:700;color:var(--color-text-primary)}
.method-card p{color:var(--color-text-secondary);margin-bottom:.5rem}
.method-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem;color:var(--color-text-secondary)}
.method-card ul li{display:flex;gap:.5rem;align-items:flex-start}
.method-card ul li::before{content:'▹';color:var(--color-primary);margin-top:.15rem}
.method-card .phase{display:inline-flex;align-items:center;gap:.5rem;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted);background:rgba(255,255,255,.05);border-radius:999px;padding:.35rem .9rem}
.impact-panel{margin-top:-20px;margin-bottom:60px}
.impact-card{background:rgba(18, 27, 40, .78);border:1px solid rgba(43, 140, 190, .18);border-radius:22px;color:var(--color-text-secondary);gap:1rem}
.impact-card h3{color:var(--color-text-primary);font-weight:700}
.impact-card ul{list-style:none;padding-left:0;margin:0;display:flex;flex-direction:column;gap:.4rem}
.impact-card ul li{display:flex;gap:.6rem;align-items:flex-start}
.impact-card ul li::before{content:'✓';color:var(--color-primary);margin-top:.1rem}
.testimonial-grid{position:relative}
.testimonial-card{background:rgba(4,20,56,.78);border:1px solid rgba(255,255,255,.14);border-radius:22px;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:1.5rem;transition:transform .3s ease, box-shadow .3s ease}
.testimonial-card:hover{transform:translateY(-8px);box-shadow:0 28px 75px rgba(0,0,0,.4)}
.testimonial-card .quote{font-size:1.05rem;font-style:italic;color:var(--color-text-primary);line-height:1.8}
.badge-impact{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .9rem;border-radius:999px;background:rgba(43, 140, 190, .16);border:1px solid rgba(43, 140, 190, .4);color:var(--color-text-primary);font-weight:600}
.action-rail{position:fixed;left:22px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:12px;z-index:1040}
.action-item{width:54px;height:54px;border-radius:18px;background:rgba(18, 27, 40, .88);border:1px solid rgba(43, 140, 190, .28);color:var(--color-text-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;text-decoration:none;font-size:.7rem;font-weight:600;letter-spacing:.04em;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.action-item i{font-size:1.2rem}
.action-item span{font-size:.65rem;text-transform:uppercase}
.action-item:hover{transform:translateX(4px);box-shadow:0 14px 35px rgba(43, 140, 190, .25);border-color:rgba(43, 140, 190, .6);color:var(--color-text-primary)}
.action-item.btn{border-radius:18px}
@media(max-width:991px){.action-rail{display:none!important}}
.publication-card{background:rgba(3,24,64,.8);border:1px solid rgba(255,255,255,.12);border-radius:22px;overflow:hidden;display:flex;flex-direction:column;height:100%;transition:transform .3s ease, box-shadow .3s ease}
.publication-card:hover{transform:translateY(-10px);box-shadow:0 26px 70px rgba(0,0,0,.45)}
.publication-cover{position:relative;overflow:hidden}
.publication-cover img{width:100%;height:200px;object-fit:cover;display:block}
.publication-badge{position:absolute;top:16px;left:16px;background:rgba(43, 140, 190, .22);border:1px solid rgba(43, 140, 190, .4);color:var(--color-text-primary);padding:.3rem .7rem;border-radius:999px;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase}
.publication-body{padding:1.8rem;display:flex;flex-direction:column;gap:1rem}
.publication-body h3{color:var(--color-text-primary);font-size:1.1rem;font-weight:700;margin-bottom:.3rem}
.publication-body p{color:var(--color-text-secondary);margin:0}
.publication-date{color:var(--color-text-muted);letter-spacing:.08em;text-transform:uppercase;font-size:.7rem}
.publication-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:auto}
.publication-actions .btn{border-radius:14px;font-weight:600}
.publication-share{color:var(--color-primary);font-weight:600;text-decoration:none;font-size:.85rem;display:inline-flex;align-items:center;gap:.35rem}
.publication-share:hover{color:var(--color-text-primary)}
.founder-modal .founder-portrait img{box-shadow:0 28px 80px rgba(0,0,0,.4)}
.founder-role{font-size:1rem;color:var(--color-text-secondary);font-weight:600}
.founder-role{
  font-size:1rem;
  color:var(--color-text-secondary);
  font-weight:600;
  word-wrap: break-word; /* Asegura que palabras muy largas se rompan */
  margin-bottom: 1rem; /* Añade un poco de espacio debajo del rol */
}
.founder-focus .badge-impact {
  white-space: normal; /* Permite que el texto del badge se envuelva */
  max-width: 100%; /* Asegura que el badge no exceda el ancho de su contenedor */
  text-align: left; /* Alinea el texto a la izquierda si se envuelve */
}
.founder-bio p{color:var(--color-text-secondary);margin-bottom:1rem}
.founder-bio h6{letter-spacing:.18em}
.founder-bio h6 {
  letter-spacing:.18em;
  margin-top: 1.5rem; /* Más espacio entre secciones de la biografía */
  margin-bottom: 0.5rem;
}
.modal-body { padding: clamp(1.5rem, 4vw, 2.5rem); } /* Aumenta el padding interno del modal para más "aire" */

/* Carousel & imagery */
.team-card img{aspect-ratio:16/9;object-fit:cover;border-top-left-radius:18px;border-top-right-radius:18px}
.team-card h5{color:var(--color-primary)}
.team-card-action{cursor:pointer;transition:transform .25s ease, box-shadow .25s ease}
.team-card-action:hover{transform:translateY(-6px);box-shadow:0 26px 65px rgba(0,0,0,.45)}
.icon-feature{width:64px;height:64px;display:grid;place-items:center;border-radius:18px;background:rgba(43, 140, 190, .1);border:1px solid rgba(43, 140, 190, .35);color:var(--color-primary)}
.icon-feature i{font-size:2rem}

/* --- NUEVO SLIDER PROFESIONAL: PANTALLA DIVIDIDA --- */
.hero{
  position:relative;
  /* Este padding-top es CRÍTICO para que el slider no choque con el menú fijo */
  padding-top: 120px; 
  background:linear-gradient(135deg, var(--color-surface), var(--color-background));
  overflow:hidden;
  color:var(--color-text-primary);
}
.hero-slider{position:relative;height:calc(100vh - 80px);display:flex;align-items:stretch;overflow:hidden;}
.hero-slider__track{position:relative;width:100%;height:100%;isolation:isolate;}
.hero-slide{position:absolute;inset:0;display:grid;grid-template-columns:repeat(12, 1fr);opacity:0;transition:opacity 1s ease;pointer-events:none;z-index:1;}
.hero-slide.is-active{opacity:1;pointer-events:auto;z-index:2;}

/* Paneles del slider */
.hero-slide__image-pane{grid-column:1 / span 6;position:relative;overflow:hidden;}
.hero-slide__content-pane{grid-column:7 / span 6;display:flex;align-items:center;justify-content:center;padding:clamp(2rem, 8vw, 5rem);background:var(--color-background);}
.hero-slide__image-wrapper{position:absolute;inset:0;transform:scale(1.1);transition:transform 8s ease-out;}
.hero-slide.is-active .hero-slide__image-wrapper{transform:scale(1);}
.hero-slide__image-wrapper img{width:100%;height:100%;object-fit:cover;}

/* Contenido del slider */
.hero-slide__content{max-width:550px;}
.hero-slide__label, .hero-slide h1, .hero-slide p, .hero-slide__actions {
  opacity: 0;
  transform:translateY(30px);
  transition:opacity .7s ease, transform .7s ease;
}
.hero-slide.is-active .hero-slide__label{transition-delay:.5s;}
.hero-slide.is-active h1{transition-delay:.6s;}
.hero-slide.is-active p{transition-delay:.7s;}
.hero-slide.is-active .hero-slide__actions{transition-delay:.8s;}
.hero-slide.is-active .hero-slide__label,
.hero-slide.is-active h1,
.hero-slide.is-active p,
.hero-slide.is-active .hero-slide__actions {
  opacity:1;
  transform:translateY(0);
}

.hero-slide__label{display:inline-flex;align-items:center;gap:.6rem;padding:.4rem 1rem;border-radius:999px;background:rgba(255,255,255,.1);letter-spacing:.18em;font-size:.75rem;text-transform:uppercase;margin-bottom:1.2rem;color:var(--color-text-primary);font-weight:600;}
.hero-slide h1{font-family:var(--font-display);font-weight:800;font-size:clamp(2.2rem, 5vw, 3.5rem);line-height:1.15;margin-bottom:1.2rem;text-shadow:0 10px 30px rgba(0,0,0,.2);}
.hero-slide p{color:var(--color-text-secondary);font-size:clamp(1rem, 1.5vw, 1.1rem);margin-bottom:2rem;max-width:550px;}
.hero-slide__actions{display:flex;flex-wrap:wrap;gap:1.2rem;}
.hero-slide__actions .btn{border-radius:16px;padding:.95rem 1.9rem;font-weight:600;box-shadow:0 16px 35px rgba(43, 140, 190, .3);}
.hero-slide__actions .btn-outline-light{border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.08);color:var(--color-text-primary);}
.hero-slide__actions .btn-outline-light:hover{background:rgba(255,255,255,.2);color:#021a35;}

/* Navegación del Slider (Barras de Progreso) */
.hero-slider__nav-wrapper{position:absolute;bottom:0;left:50%;width:50%;height:100px;z-index:5;display:flex;align-items:flex-end;padding:0 0 2rem clamp(2rem, 8vw, 5rem);}
.hero-slider__nav{width:100%;max-width:550px;display:flex;gap:10px;}
.hero-slider__nav-item{flex:1;display:flex;flex-direction:column;gap:6px;cursor:pointer;opacity:.6;transition:opacity .3s ease;}
.hero-slider__nav-item:hover{opacity:.8;}
.hero-slider__nav-item.is-active{opacity:1;}
.hero-slider__nav-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);padding-left:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.hero-slider__nav-progress{width:100%;height:4px;background:rgba(255,255,255,.2);border-radius:4px;overflow:hidden;}
.hero-slider__nav-progress-bar{width:0;height:100%;background:var(--color-primary);border-radius:4px;}
.hero-slider__nav-item.is-active .hero-slider__nav-progress-bar{
  transition:width 8s linear; /* Debe coincidir con data-autoplay en el HTML */
}

.hero-metrics-bar{padding:40px 0;}
.metric-chip{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:1.2rem;backdrop-filter:blur(10px);height:100%;display:flex;flex-direction:column;gap:.35rem;}
.metric-chip__label{text-transform:uppercase;letter-spacing:.14em;font-size:.7rem;color:var(--color-text-muted);}
.metric-chip__value{font-size:1.8rem;font-weight:800;color:var(--color-text-primary);}
.metric-chip small{color:var(--color-text-secondary);font-size:.8rem;}
@media(max-width:991px){
  .hero{padding-top:110px;}
  .hero-slider{height:auto;}
  .hero-slide{grid-template-columns:1fr;height:auto;}
  .hero-slide__image-pane{grid-row:1;min-height:300px;height:50vh;}
  .hero-slide__content-pane{grid-row:2;padding:3rem 1.5rem;}
  .hero-slider__nav-wrapper{position:relative;width:100%;height:auto;left:auto;bottom:auto;padding:1.5rem 1.5rem 0;}
  .hero-slider__nav{max-width:none;}
  .hero-metrics-bar{padding:30px 0;}
}
@media(max-width:575px){
  .hero-slide h1{font-size:2rem;}
  .hero-slide__actions .btn{width:100%;justify-content:center;}
  .hero-metrics-bar .metric-chip__value{font-size:1.55rem;}
}

/* Map */
.map-container{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,.35)}
.map-container iframe{width:100%;height:450px;filter:grayscale(1) invert(.9) contrast(.9);border:1px solid rgba(43, 140, 190, .2)}
.map-overlay{position:absolute;bottom:1rem;left:1rem;right:1rem;background:rgba(4,17,43,.8);color:var(--color-text-secondary);border-radius:16px;padding:18px}
@media(min-width:992px){.map-overlay{max-width:400px}}

/* Forms & misc */
.form-control,.form-select{background:rgba(18, 27, 40, .78);color:var(--color-text-primary);border:1px solid rgba(43, 140, 190, .25)}
.form-control:focus,.form-select:focus{background:rgba(18, 27, 40, .92);border-color:var(--color-primary);box-shadow:0 0 0 .25rem rgba(43, 140, 190, .2)}
.badge-soft{background:rgba(43, 140, 190, .14);color:#e9fbff;border:1px solid rgba(43, 140, 190, .35);border-radius:12px}
.icon{width:56px;height:56px;display:grid;place-items:center;border-radius:14px;background:rgba(43, 140, 190, .1);border:1px solid rgba(43, 140, 190, .35);color:var(--color-primary)}
.avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid rgba(7,219,242,.4)}
#contact-feedback .alert{display:none}
#contact-feedback .alert.show{display:block}

/* Admin */
.admin-body{background:var(--color-background);color:var(--color-text-secondary)}
.admin-shell{display:flex;min-height:100vh;overflow:hidden}
.admin-sidebar{width:260px;display:flex;flex-direction:column;background:linear-gradient(180deg, var(--color-surface), var(--color-background));color:var(--color-text-secondary);border-right:1px solid rgba(43, 140, 190, .18);position:sticky;top:0;height:100vh}
.admin-sidebar .sidebar-header{color:var(--color-text-primary);letter-spacing:.08em;text-transform:uppercase}
.admin-sidebar .sidebar-user .avatar{width:44px;height:44px;border-radius:14px;object-fit:cover;border:1px solid rgba(255,255,255,.3)}
.admin-menu .nav-link{color:var(--color-text-secondary);font-weight:500;border-radius:12px;padding:.6rem .85rem;margin-bottom:.35rem;transition:background .2s ease,color .2s ease, transform .2s ease}
.admin-menu .nav-link:hover,.admin-menu .nav-link.active{background:rgba(255,255,255,.12);color:var(--color-text-primary);transform:translateX(4px)}
.admin-sidebar .sidebar-footer .btn{border-radius:12px}
.admin-main{flex:1;display:flex;flex-direction:column;min-height:100vh;background:linear-gradient(210deg, var(--color-background), var(--color-surface))}
.admin-topbar{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid rgba(43, 140, 190, .12);background:rgba(18, 27, 40, .75);backdrop-filter:blur(18px);position:sticky;top:0;z-index:1020}
.admin-topbar .btn-link{color:var(--color-text-primary)}
.topbar-search .input-group-text{background:rgba(255,255,255,.06);border:none;color:var(--color-text-muted)}
.topbar-search .form-control{border:none;background:rgba(255,255,255,.06);color:var(--color-text-primary)}
.topbar-search .form-control::placeholder{color:rgba(255,255,255,.45)}
.topbar-actions .btn{white-space:nowrap}
.admin-content{flex:1;width:100%;color:var(--color-text-secondary)}
#admin-alerts .alert{border-radius:14px}
.admin-quick-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}
.admin-quick-actions .btn{border-radius:14px;font-weight:600}
@media(max-width:991px){
  .admin-shell{flex-direction:column}
  .admin-sidebar{position:fixed;inset:0 auto 0 -280px;width:240px;transition:transform .3s ease;box-shadow:0 0 40px rgba(0,0,0,.45);z-index:1050}
  .admin-sidebar.open{transform:translateX(280px)}
  .admin-main{padding-top:72px}
  .admin-topbar{position:fixed;top:0;left:0;right:0}
}
.stats-grid .stat-card{display:flex;align-items:center;gap:1rem;padding:1.4rem;border-radius:20px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);transition:transform .2s ease, box-shadow .2s ease}
.stats-grid .stat-card:hover{transform:translateY(-4px);box-shadow:0 18px 48px rgba(0,0,0,.35)}
.stat-card .stat-icon{width:52px;height:52px;border-radius:18px;display:grid;place-items:center;font-size:1.35rem}
.stat-card .stat-body .label{text-transform:uppercase;letter-spacing:.16em;font-size:.65rem;color:var(--color-text-muted)}
.stat-card .stat-body strong{display:block;font-size:1.9rem;font-weight:800;color:var(--color-text-primary);line-height:1}
.stat-card .stat-body small{color:var(--color-text-secondary);font-size:.8rem}
.board-card{background:rgba(18, 27, 40, .78);border:1px solid rgba(43, 140, 190, .12);border-radius:22px;color:var(--color-text-secondary)}
.board-card .card-header{background:transparent;padding:1.2rem 1.4rem;border-bottom:1px solid rgba(255,255,255,.06)}
.board-card .card-body{padding:1.4rem}
.board-list{display:flex;flex-direction:column}
.board-item{display:flex;align-items:flex-start;gap:1rem;padding:1.1rem 1.4rem;border-bottom:1px solid rgba(255,255,255,.05);transition:background .2s ease}
.board-item:last-child{border-bottom:none}
.board-item:hover{background:rgba(255,255,255,.04)}
.board-item-icon{width:42px;height:42px;border-radius:14px;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:1.1rem}
.board-item-body h6{color:var(--color-text-primary);font-weight:600}
.board-item-body .item-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:var(--color-text-muted);margin-bottom:.35rem}
.board-item-body .item-meta a{color:var(--color-primary)}
.board-item-actions{display:flex;gap:.5rem}
.board-item-actions .btn{border-radius:12px}
.board-search .form-control{background:rgba(255,255,255,.06);border:none;color:var(--color-text-primary)}
.board-search .input-group-text{background:rgba(255,255,255,.06);border:none;color:var(--color-text-muted)}
.board-search .form-control::placeholder{color:rgba(255,255,255,.4)}
.empty-state{border-radius:18px;background:rgba(255,255,255,.03);border:1px dashed rgba(255,255,255,.12)}
.board-empty-results{border-radius:18px;background:rgba(255,255,255,.03);border:1px dashed rgba(255,255,255,.12)}
.timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.4rem}
.timeline-item{display:flex;gap:1rem;position:relative}
.timeline-item::before{content:'';position:absolute;left:20px;top:32px;bottom:-1.4rem;width:2px;background:rgba(255,255,255,.08)}
.timeline-item:last-child::before{display:none}
.timeline-icon{width:40px;height:40px;border-radius:14px;background:rgba(255,255,255,.08);display:grid;place-items:center;font-size:1rem}
.timeline-content{flex:1;min-width:0}
.timeline-content strong{color:var(--color-text-primary)}
.timeline-date{font-size:.78rem;color:var(--color-text-muted)}
.timeline-link{font-size:.78rem;color:var(--color-primary);text-decoration:none}
.timeline-news .timeline-icon{color:#f8d57a}
.timeline-publication .timeline-icon{color:#6ef0c4}
.timeline-appointment .timeline-icon{color:#7bd3ff}
.timeline-contact .timeline-icon{color:#f48ad1}
.engagement-list{display:flex;flex-direction:column;gap:1rem}
.engagement-list li{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:1rem}
.engagement-list .title{font-weight:600;color:var(--color-text-primary)}
.engagement-list .meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.78rem}
.engagement-list p{margin-bottom:0}
.metric-card-admin .icon { background: rgba(43, 140, 190, .1); border: 1px solid rgba(43, 140, 190, .35); color: var(--color-text-primary); width: 56px; height: 56px; display: grid; place-items: center; border-radius: 14px; }
.metric-card-admin h4 { color: var(--color-text-primary); }
.table {
  --bs-table-bg: transparent;
  --bs-table-striped-bg: rgba(255,255,255,.04);
  --bs-table-hover-bg: rgba(255,255,255,.06);
  color: var(--color-text-secondary);
}
.table thead th { color: var(--color-text-primary); border-color: rgba(255,255,255,.1); font-weight:600; }
.table tbody td { color: var(--color-text-secondary); border-color: rgba(255,255,255,.05); }

/* WYSIWYG */
.wys-editor { background: rgba(18, 27, 40, .4); border: 1px solid rgba(43, 140, 190, .25); border-radius: 18px; overflow: hidden; }
.wys-toolbar .btn { color: #f6fbff; border-color: rgba(255,255,255,.18); background: rgba(255,255,255,.06); }
.wys-toolbar .btn:hover, .wys-toolbar .btn:focus { color: #fff; background: rgba(255,255,255,.2); }
.wys-toolbar .btn:active { background: rgba(43, 140, 190, .35); color: #011232; }
.wys-surface { min-height: 320px; background: rgba(13, 20, 28, .8); color: var(--color-text-primary); font-size: .96rem; line-height: 1.68; outline: none; border: none; padding-bottom:6px; }
.wys-surface:focus { box-shadow: inset 0 0 0 2px rgba(43, 140, 190, .25); }
.wys-surface *, .wys-output * { color: var(--color-text-primary) !important; background-color: transparent !important; }
.wys-surface a, .wys-output a { color: #87d4ff !important; text-decoration: underline; }
.wys-surface ul, .wys-surface ol, .wys-output ul, .wys-output ol { padding-left: 1.6rem; }
.wys-surface blockquote, .wys-output blockquote { border-left: 4px solid rgba(43, 140, 190, .5); padding-left: 1rem; color: #f4f7ff !important; font-style: italic; }
.wys-output { color: var(--color-text-primary); line-height: 1.74; font-size: 1rem; }

.whatsapp-float {
  position: fixed;
  bottom: 25px;
  left: 25px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background-color: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  box-shadow: 0 8px 20px rgba(37, 211, 102, .4);
  z-index: 1040;
  transition: transform .2s ease, box-shadow .2s ease;
}
.whatsapp-float:hover { background-color: #128C7E; color: #fff; transform: translateY(-3px); box-shadow: 0 12px 25px rgba(18, 140, 126, .4); }

/* Botón de WhatsApp personalizado (alternativa) */
.whatsapp-float.custom {
  background: var(--color-primary);
  box-shadow: 0 8px 20px rgba(43, 140, 190, .3);
}
.whatsapp-float.custom:hover {
  background: #52a9d8;
  box-shadow: 0 12px 25px rgba(43, 140, 190, .4);
}

/* =================================== */
/* 4. Animations & Utilities           */
/* =================================== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease, transform .7s ease}
.reveal.in-view{opacity:1;transform:none}
@keyframes fade-in{from{opacity:0}}
@keyframes fade-in-up{from{opacity:0;transform:translateY(20px)}}
