:root{
  --ashein-blue:#0b2f5b;
  --ashein-blue-2:#114a8d;
  --ashein-cyan:#16b6d8;
  --ashein-green:#82bd43;
  --ashein-dark:#071b32;
  --ashein-muted:#64748b;
  --ashein-light:#f4f8fb;
  --ashein-white:#ffffff;
  --ashein-radius:24px;
  --ashein-shadow:0 22px 60px rgba(7,27,50,.14);
}

*{scroll-behavior:smooth}
body{font-family:'Poppins','Open Sans',Arial,sans-serif;color:#26384d;background:#fff;}
a{text-decoration:none!important}

#header.ashein-header{background:rgba(255,255,255,.94);box-shadow:0 10px 35px rgba(7,27,50,.08);backdrop-filter:blur(12px);padding:12px 0;}
#header .logo img{max-height:58px!important;width:auto!important;}
#navbar ul li a{font-weight:600;color:#19324f;font-size:15px;padding:10px 13px;}
#navbar ul li a:hover,#navbar ul li a.active{color:var(--ashein-green);}
.ashein-header-cta{background:linear-gradient(135deg,var(--ashein-green),#5da929);color:#fff!important;padding:11px 18px!important;border-radius:999px;box-shadow:0 10px 25px rgba(130,189,67,.32);}
.ashein-header-cta:hover{color:#fff!important;transform:translateY(-1px);}

.ashein-hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;background:linear-gradient(120deg,rgba(7,27,50,.92),rgba(11,47,91,.82)),url('../img/hero-bg.jpg') center/cover no-repeat;padding:140px 0 80px;}
.ashein-hero:before{content:'';position:absolute;inset:-20% -10% auto auto;width:620px;height:620px;background:radial-gradient(circle,rgba(22,182,216,.32),transparent 67%);border-radius:50%;}
.ashein-hero:after{content:'';position:absolute;left:-160px;bottom:-180px;width:520px;height:520px;background:radial-gradient(circle,rgba(130,189,67,.28),transparent 68%);border-radius:50%;}
.ashein-hero .container{position:relative;z-index:2;}
.ashein-kicker{display:inline-flex;gap:8px;align-items:center;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.22);color:#d9f8ff;border-radius:999px;padding:9px 15px;font-weight:600;margin-bottom:24px;}
.ashein-hero h1{font-size:clamp(40px,6vw,76px);line-height:1.02;font-weight:800;color:#fff;margin:0 0 22px;letter-spacing:-2px;}
.ashein-hero h1 span{color:#a6e96a;}
.ashein-hero p{font-size:19px;line-height:1.75;color:#dce8f6;max-width:650px;margin-bottom:30px;}
.ashein-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:36px;}
.ashein-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:14px 24px;font-weight:700;transition:.25s ease;}
.ashein-btn-primary{background:linear-gradient(135deg,var(--ashein-green),#62a93b);color:#fff;box-shadow:0 16px 34px rgba(130,189,67,.34);}
.ashein-btn-secondary{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);}
.ashein-btn-light{background:#fff;color:var(--ashein-blue);box-shadow:0 12px 30px rgba(7,27,50,.12);}
.ashein-btn:hover{transform:translateY(-3px);color:#fff;}
.ashein-btn-light:hover{color:var(--ashein-blue);}
.ashein-hero-panel{background:rgba(255,255,255,.95);border-radius:32px;padding:28px;box-shadow:var(--ashein-shadow);position:relative;overflow:hidden;}
.ashein-hero-panel:before{content:'';position:absolute;top:0;left:0;right:0;height:7px;background:linear-gradient(90deg,var(--ashein-green),var(--ashein-cyan));}
.ashein-panel-title{font-weight:800;color:var(--ashein-blue);font-size:24px;margin-bottom:18px;}
.ashein-panel-item{display:flex;gap:13px;align-items:flex-start;padding:14px 0;border-bottom:1px solid #e8eef5;}
.ashein-panel-item:last-child{border-bottom:0;}
.ashein-panel-item i{width:42px;height:42px;border-radius:14px;background:#eaf7df;color:var(--ashein-green);display:grid;place-items:center;font-size:22px;flex:none;}
.ashein-panel-item strong{display:block;color:#16314f;margin-bottom:2px;}
.ashein-panel-item small{color:var(--ashein-muted);font-size:13px;line-height:1.5;display:block;}
.ashein-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;max-width:650px;}
.ashein-stat{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);border-radius:18px;padding:16px;color:#fff;}
.ashein-stat strong{display:block;font-size:28px;line-height:1;font-weight:800;color:#a6e96a;}
.ashein-stat span{font-size:13px;color:#dce8f6;}

.ashein-section{padding:90px 0;}
.ashein-section-soft{background:var(--ashein-light);}
.ashein-title{max-width:760px;margin:0 auto 48px;text-align:center;}
.ashein-title span{display:inline-block;color:var(--ashein-green);font-weight:800;text-transform:uppercase;letter-spacing:1.8px;font-size:13px;margin-bottom:10px;}
.ashein-title h2{font-size:clamp(30px,4vw,46px);font-weight:800;color:var(--ashein-blue);margin:0 0 14px;letter-spacing:-1px;}
.ashein-title p{color:var(--ashein-muted);font-size:17px;line-height:1.7;margin:0;}

.ashein-areas-section{position:relative;overflow:hidden;}
.ashein-areas-section:before{content:'';position:absolute;left:-140px;top:80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(130,189,67,.22),transparent 70%);}
.ashein-areas-section:after{content:'';position:absolute;right:-170px;bottom:20px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(0,154,218,.18),transparent 70%);}
.ashein-areas-grid{position:relative;z-index:2;}
.ashein-area-card{display:flex;flex-direction:column;align-items:center;text-align:center;height:100%;min-height:310px;background:#fff;border:1px solid #e3edf6;border-radius:28px;padding:26px 20px 24px;text-decoration:none;box-shadow:0 12px 32px rgba(7,27,50,.07);transition:.25s ease;position:relative;overflow:hidden;color:inherit;}
.ashein-area-card:before{content:'';position:absolute;inset:0 0 auto 0;height:6px;background:linear-gradient(90deg,var(--ashein-green),var(--ashein-cyan));}
.ashein-area-card:hover{transform:translateY(-10px);box-shadow:var(--ashein-shadow);}
.ashein-area-card:hover h3{color:var(--ashein-green);}
.ashein-area-number{position:absolute;top:18px;right:20px;font-size:13px;font-weight:900;color:#b7c6d6;letter-spacing:1px;}
.ashein-area-card img{width:82px;height:82px;object-fit:contain;margin:18px 0 22px;filter:drop-shadow(0 10px 18px rgba(7,27,50,.12));}
.ashein-area-card h3{font-size:20px;line-height:1.2;font-weight:900;color:var(--ashein-blue);margin:0 0 12px;transition:.25s;}
.ashein-area-card p{font-size:14px;color:var(--ashein-muted);line-height:1.6;margin:0;}

.ashein-service-card{height:100%;background:#fff;border:1px solid #e7eef6;border-radius:var(--ashein-radius);padding:30px;box-shadow:0 10px 35px rgba(7,27,50,.06);transition:.25s ease;position:relative;overflow:hidden;}
.ashein-service-card:before{content:'';position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--ashein-green),var(--ashein-cyan));opacity:0;transition:.25s;}
.ashein-service-card:hover{transform:translateY(-8px);box-shadow:var(--ashein-shadow);}
.ashein-service-card:hover:before{opacity:1;}
.ashein-service-card .icon{width:66px;height:66px;border-radius:20px;background:linear-gradient(135deg,#edf9e4,#e3f8ff);display:grid;place-items:center;font-size:32px;color:var(--ashein-blue);margin-bottom:22px;}
.ashein-service-card h3{font-size:21px;font-weight:800;color:var(--ashein-blue);margin-bottom:12px;}
.ashein-service-card p{color:var(--ashein-muted);line-height:1.7;margin:0 0 18px;}
.ashein-service-card ul{margin:0;padding:0;list-style:none;}
.ashein-service-card li{display:flex;gap:8px;color:#36516d;margin-top:8px;font-size:14px;}
.ashein-service-card li i{color:var(--ashein-green);margin-top:3px;}

.ashein-band{background:linear-gradient(135deg,var(--ashein-blue),var(--ashein-dark));border-radius:34px;padding:48px;color:#fff;box-shadow:var(--ashein-shadow);position:relative;overflow:hidden;}
.ashein-band:after{content:'';position:absolute;right:-110px;top:-120px;width:310px;height:310px;background:radial-gradient(circle,rgba(130,189,67,.35),transparent 70%);border-radius:50%;}
.ashein-band h2{font-size:38px;font-weight:800;margin-bottom:14px;}
.ashein-band p{color:#d6e5f7;font-size:17px;line-height:1.7;margin:0;}
.ashein-band .ashein-btn{position:relative;z-index:2;}

.ashein-course-card{height:100%;border-radius:24px;overflow:hidden;background:#fff;border:1px solid #e7eef6;box-shadow:0 12px 32px rgba(7,27,50,.08);transition:.25s;}
.ashein-course-card:hover{transform:translateY(-7px);box-shadow:var(--ashein-shadow);}
.ashein-course-card img{width:100%;height:190px;object-fit:cover;}
.ashein-course-body{padding:24px;}
.ashein-tag{display:inline-block;background:#eaf7df;color:#4b931f;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:800;margin-bottom:12px;}
.ashein-course-body h3{font-size:20px;font-weight:800;color:var(--ashein-blue);margin-bottom:10px;}
.ashein-course-body p{color:var(--ashein-muted);line-height:1.65;margin-bottom:0;}

.ashein-standards-section{position:relative;overflow:hidden;}
.ashein-standards-section:before{content:'';position:absolute;left:-140px;bottom:-160px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(130,189,67,.18),transparent 70%);}
.ashein-standards-grid{position:relative;z-index:2;}
.ashein-standard-card{display:block;height:100%;background:#fff;border:1px solid #e3edf6;border-radius:26px;padding:16px 16px 18px;box-shadow:0 12px 32px rgba(7,27,50,.08);transition:.25s ease;text-align:center;overflow:hidden;}
.ashein-standard-card:hover{transform:translateY(-8px);box-shadow:var(--ashein-shadow);}
.ashein-standard-card img{width:100%;height:330px;object-fit:cover;object-position:top center;border-radius:20px;background:#f7fbff;box-shadow:inset 0 0 0 1px #e8eef5;}
.ashein-standard-card span{display:inline-flex;align-items:center;justify-content:center;margin-top:14px;background:#eaf7df;color:#4b931f;border-radius:999px;padding:8px 15px;font-size:13px;font-weight:900;letter-spacing:.5px;}

.ashein-process{counter-reset:step;}
.ashein-step{display:flex;gap:18px;background:#fff;border:1px solid #e8eef5;border-radius:22px;padding:24px;height:100%;box-shadow:0 10px 28px rgba(7,27,50,.06);}
.ashein-step:before{counter-increment:step;content:'0' counter(step);width:54px;height:54px;border-radius:18px;background:var(--ashein-blue);color:#fff;display:grid;place-items:center;font-weight:800;flex:none;}
.ashein-step h3{font-size:19px;color:var(--ashein-blue);font-weight:800;margin-bottom:7px;}
.ashein-step p{color:var(--ashein-muted);line-height:1.6;margin:0;}

.ashein-whatsapp{position:fixed;right:22px;bottom:22px;z-index:9999;width:62px;height:62px;border-radius:50%;display:grid;place-items:center;background:#25d366;color:#fff;font-size:34px;box-shadow:0 16px 35px rgba(37,211,102,.42);}
.ashein-whatsapp:hover{color:#fff;transform:scale(1.05);}
.back-to-top{background:var(--ashein-blue)!important;}

#footer{background:#071b32;color:#d9e8f9;}
#footer .footer-top{background:#08213d;padding:60px 0 30px;border-top:1px solid rgba(255,255,255,.08);}
#footer h4{color:#fff;font-weight:800;}
#footer .footer-links ul a,#footer .footer-contact p{color:#c9d9ea;}
#footer .footer-links ul a:hover{color:#a6e96a;}
#footer .credits a{color:#a6e96a;font-weight:700;}
#footer .social-links a{background:rgba(255,255,255,.08);color:#fff;}
#footer .social-links a:hover{background:var(--ashein-green);}


.ashein-environment-section{background:#fff;position:relative;overflow:hidden;}
.ashein-environment-section:before{content:'';position:absolute;left:-180px;top:10%;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(130,189,67,.14),transparent 70%);}
.ashein-environment-visual{display:grid;gap:18px;}
.ashein-environment-banner{position:relative;border-radius:34px;overflow:hidden;box-shadow:var(--ashein-shadow);background:linear-gradient(135deg,#0f5132,#84cc16);min-height:430px;}
.ashein-environment-banner img{width:100%;height:430px;object-fit:cover;object-position:center;display:block;filter:saturate(1.05);}
.ashein-environment-banner:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,29,18,.08),rgba(6,18,12,.60));}
.ashein-environment-overlay-card{position:absolute;left:26px;right:26px;bottom:26px;z-index:2;background:rgba(255,255,255,.92);border:1px solid rgba(255,255,255,.6);backdrop-filter:blur(10px);border-radius:24px;padding:22px;box-shadow:0 18px 40px rgba(0,0,0,.18);}
.ashein-mini-badge{display:inline-flex;align-items:center;gap:8px;background:#e9f8ea;color:#2f6f2f;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:800;letter-spacing:.3px;margin-bottom:12px;}
.ashein-environment-overlay-card h3{font-size:28px;line-height:1.2;margin:0 0 10px;color:#0f172a;}
.ashein-environment-overlay-card p{margin:0;color:#425466;line-height:1.6;font-size:15px;}
.ashein-environment-agencies{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.ashein-agency-item{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;border:1px solid #e5edf4;border-radius:18px;padding:12px 14px;box-shadow:0 14px 28px rgba(15,23,42,.06);}
.ashein-agency-item img{width:42px;height:42px;object-fit:contain;border-radius:10px;flex:none;background:#fff;}
.ashein-agency-item span{font-weight:700;color:#17324d;font-size:13px;}
.ashein-environment-list{display:grid;gap:10px;margin:22px 0 6px;}
.ashein-environment-list p{display:flex;gap:10px;align-items:flex-start;margin:0;color:#334e68;line-height:1.55;font-size:15px;background:#f4f8fb;border:1px solid #e3edf6;border-radius:16px;padding:12px 14px;}
.ashein-environment-list i{color:var(--ashein-green);font-size:19px;margin-top:2px;flex:none;}
@media (max-width: 991.98px){
  .ashein-environment-banner,.ashein-environment-banner img{height:380px;min-height:380px;}
  .ashein-environment-agencies{grid-template-columns:repeat(2,1fr);}
}
@media (max-width: 575.98px){
  .ashein-environment-banner,.ashein-environment-banner img{height:320px;min-height:320px;}
  .ashein-environment-overlay-card{left:16px;right:16px;bottom:16px;padding:16px;border-radius:18px;}
  .ashein-environment-overlay-card h3{font-size:22px;}
  .ashein-agency-item{padding:10px 12px;}
  .ashein-agency-item img{width:36px;height:36px;}
  .ashein-agency-item span{font-size:12px;}
}


@media(max-width:991px){
  .ashein-hero{padding-top:125px;text-align:left;min-height:auto;}
  .ashein-hero-panel{margin-top:30px;}
  .ashein-stats{grid-template-columns:1fr;}
  .ashein-band{padding:32px;}
  .ashein-band h2{font-size:30px;}
  #navbar ul li a{font-size:16px;}
}
@media(max-width:575px){
  .ashein-standard-card img{height:260px;}
  .ashein-actions{display:grid;grid-template-columns:1fr;}
  .ashein-btn{width:100%;}
  .ashein-section{padding:64px 0;}
  .ashein-hero h1{letter-spacing:-1px;}
  .ashein-whatsapp{width:56px;height:56px;font-size:31px;}
}


/* ===== Nosotros ===== */
.ashein-page-hero{position:relative;min-height:560px;display:flex;align-items:center;padding:145px 0 85px;background:linear-gradient(135deg,rgba(7,27,50,.96),rgba(9,56,97,.9)),url('../img/banner/banner2.jpg') center/cover;color:#fff;overflow:hidden;}
.ashein-page-hero:before{content:'';position:absolute;right:-160px;top:-160px;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(130,189,67,.35),transparent 70%);}
.ashein-page-hero:after{content:'';position:absolute;left:-170px;bottom:-210px;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(0,154,218,.24),transparent 70%);}
.ashein-page-hero .container{position:relative;z-index:2;}
.ashein-page-hero h1{font-size:clamp(38px,5vw,66px);font-weight:900;line-height:1.05;letter-spacing:-1.7px;margin:0 0 20px;color:#fff;}
.ashein-page-hero p{font-size:18px;line-height:1.75;color:#dce8f6;max-width:720px;margin-bottom:28px;}
.ashein-about-logo-card{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:34px;padding:42px 34px;box-shadow:var(--ashein-shadow);backdrop-filter:blur(10px);text-align:center;}
.ashein-about-logo-card img{max-width:270px;width:100%;margin-bottom:24px;filter:drop-shadow(0 16px 25px rgba(0,0,0,.18));}
.ashein-about-logo-card span{display:block;color:#e8f5ff;font-weight:700;line-height:1.6;font-size:17px;}
.ashein-title-left{text-align:left;margin:0 0 20px;}
.ashein-title-left p{margin:0;}
.ashein-text{color:var(--ashein-muted);line-height:1.85;font-size:16px;}
.ashein-about-media{position:relative;border-radius:34px;overflow:hidden;box-shadow:var(--ashein-shadow);min-height:460px;background:#dfe9f4;}
.ashein-about-media img{width:100%;height:460px;object-fit:cover;display:block;}
.ashein-experience-badge{position:absolute;left:26px;bottom:26px;background:#fff;border-radius:24px;padding:20px 24px;box-shadow:0 16px 35px rgba(7,27,50,.18);}
.ashein-experience-badge strong{display:block;font-size:44px;line-height:1;font-weight:900;color:var(--ashein-green);}
.ashein-experience-badge span{display:block;color:var(--ashein-blue);font-weight:800;margin-top:6px;}
.ashein-value-mini{height:100%;display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e7eef6;border-radius:18px;padding:16px 18px;color:var(--ashein-blue);font-weight:800;box-shadow:0 10px 28px rgba(7,27,50,.06);}
.ashein-value-mini i{color:var(--ashein-green);font-size:20px;}
.ashein-identity-card{height:100%;background:#fff;border:1px solid #e3edf6;border-radius:28px;padding:34px 28px;text-align:center;box-shadow:0 12px 32px rgba(7,27,50,.07);transition:.25s ease;}
.ashein-identity-card:hover{transform:translateY(-8px);box-shadow:var(--ashein-shadow);}
.ashein-identity-card img{width:82px;height:82px;object-fit:contain;margin-bottom:22px;}
.ashein-identity-card h3{font-size:22px;font-weight:900;color:var(--ashein-blue);margin-bottom:12px;}
.ashein-identity-card p{color:var(--ashein-muted);line-height:1.75;margin:0;}
.ashein-check-list p{display:flex;gap:10px;align-items:flex-start;color:#36516d;line-height:1.6;margin:0 0 14px;font-weight:600;}
.ashein-check-list i{color:var(--ashein-green);font-size:22px;margin-top:1px;}
.ashein-video-card{position:relative;overflow:hidden;border-radius:30px;box-shadow:var(--ashein-shadow);background:#000;}
.ashein-video-card:before{content:'';display:block;padding-top:56.25%;}
.ashein-video-card iframe{position:absolute;inset:0;width:100%;height:100%;}
.ashein-client-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px;}
.ashein-client-logo{height:150px;background:#fff;border:1px solid #e3edf6;border-radius:24px;display:grid;place-items:center;padding:28px;box-shadow:0 12px 32px rgba(7,27,50,.07);transition:.25s ease;}
.ashein-client-logo:hover{transform:translateY(-7px);box-shadow:var(--ashein-shadow);}
.ashein-client-logo img{max-width:100%;max-height:86px;object-fit:contain;filter:grayscale(1);opacity:.88;transition:.25s ease;}
.ashein-client-logo:hover img{filter:grayscale(0);opacity:1;}
.ashein-gallery-card{height:300px;border-radius:28px;overflow:hidden;box-shadow:0 14px 34px rgba(7,27,50,.1);background:#e8eef5;}
.ashein-gallery-card img{width:100%;height:100%;object-fit:cover;transition:.35s ease;}
.ashein-gallery-card:hover img{transform:scale(1.06);}

@media(max-width:991px){
  .ashein-client-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .ashein-page-hero{min-height:auto;padding:125px 0 70px;}
  .ashein-about-media,.ashein-about-media img{min-height:360px;height:360px;}
}
@media(max-width:575px){
  .ashein-client-grid{grid-template-columns:1fr;}
  .ashein-client-logo{height:130px;}
  .ashein-about-logo-card{padding:30px 22px;}
  .ashein-gallery-card{height:240px;}
  .ashein-experience-badge{left:18px;bottom:18px;padding:16px 18px;}
  .ashein-experience-badge strong{font-size:34px;}
}


/* Ajuste v5: Gestión Ambiental sin encimarse */
.ashein-environment-section-v5 {
  padding-top: 90px;
  padding-bottom: 90px;
}

.ashein-environment-layout-v5 {
  margin-top: 34px;
}

.ashein-environment-banner-v5 {
  width: 100%;
  height: 210px;
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 22px 45px rgba(15, 23, 42, .12);
  margin-bottom: 28px;
  background: #eef7ee;
}

.ashein-environment-banner-v5 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.ashein-environment-summary-v5 {
  height: 100%;
  background: #ffffff;
  border: 1px solid #e4edf4;
  border-radius: 28px;
  padding: 30px;
  box-shadow: 0 18px 38px rgba(15, 23, 42, .07);
}

.ashein-environment-summary-v5 h3 {
  color: #0b2f57;
  font-size: 30px;
  line-height: 1.18;
  margin: 10px 0 14px;
}

.ashein-environment-summary-v5 p {
  color: #52667a;
  line-height: 1.7;
  margin-bottom: 18px;
}

.ashein-environment-list-v5 {
  height: 100%;
  margin: 0;
}

.ashein-environment-list-v5 p {
  min-height: 58px;
}

.ashein-environment-agencies-v5 {
  margin-top: 24px;
}

@media (max-width: 991.98px) {
  .ashein-environment-section-v5 {
    padding-top: 70px;
    padding-bottom: 70px;
  }

  .ashein-environment-banner-v5 {
    height: 170px;
  }

  .ashein-environment-summary-v5 {
    padding: 24px;
  }

  .ashein-environment-summary-v5 h3 {
    font-size: 25px;
  }
}

@media (max-width: 575.98px) {
  .ashein-environment-banner-v5 {
    height: 140px;
    border-radius: 22px;
  }

  .ashein-environment-summary-v5 {
    border-radius: 22px;
    padding: 20px;
  }

  .ashein-environment-list-v5 p {
    min-height: auto;
  }
}


/* ===== Servicios ===== */
.ashein-services-hero{background:linear-gradient(135deg,rgba(7,27,50,.96),rgba(9,56,97,.90)),url('../img/banner/banner1.jpg') center/cover no-repeat;min-height:620px;}
.ashein-services-panel{background:rgba(255,255,255,.96);border-radius:32px;padding:30px;box-shadow:var(--ashein-shadow);position:relative;overflow:hidden;}
.ashein-services-panel:before{content:'';position:absolute;inset:0 0 auto 0;height:7px;background:linear-gradient(90deg,var(--ashein-green),var(--ashein-cyan));}
.ashein-services-panel h3{font-size:27px;font-weight:900;color:var(--ashein-blue);margin:6px 0 18px;}
.ashein-service-detail-section{background:#fff;}
.ashein-service-detail-card{background:#fff;border:1px solid #e5edf5;border-radius:32px;padding:34px;box-shadow:0 16px 40px rgba(7,27,50,.07);}
.ashein-service-detail-alt{background:#f9fcff;}
.ashein-service-detail-media{border-radius:28px;overflow:hidden;box-shadow:0 16px 34px rgba(7,27,50,.10);background:#eaf1f7;height:100%;}
.ashein-service-detail-media img{width:100%;height:100%;min-height:340px;object-fit:cover;display:block;}
.ashein-service-detail-banner{border-radius:28px;overflow:hidden;box-shadow:0 16px 34px rgba(7,27,50,.10);background:#eaf1f7;}
.ashein-service-detail-banner img{width:100%;height:220px;object-fit:cover;display:block;}
.ashein-mini-service-box{height:100%;background:#f4f8fb;border:1px solid #e2ecf4;border-radius:20px;padding:20px;}
.ashein-mini-service-box h3{font-size:18px;font-weight:800;color:var(--ashein-blue);margin:0 0 8px;}
.ashein-mini-service-box p{margin:0;color:var(--ashein-muted);line-height:1.65;font-size:14px;}
.ashein-service-detail-environment .ashein-environment-list{margin-top:18px;}
@media(max-width:991px){
  .ashein-services-hero{min-height:auto;padding:125px 0 70px;}
  .ashein-service-detail-card{padding:24px;}
  .ashein-service-detail-media img{min-height:280px;}
}
@media(max-width:575px){
  .ashein-services-panel{padding:22px;border-radius:24px;}
  .ashein-services-panel h3{font-size:23px;}
  .ashein-service-detail-card{padding:18px;border-radius:24px;}
  .ashein-service-detail-media img{min-height:220px;}
  .ashein-service-detail-banner img{height:170px;}
}


/* ===== Cursos ===== */
.ashein-courses-hero {
  background: linear-gradient(135deg, rgba(7,27,50,.96), rgba(9,56,97,.88)), url('../img/banner/banner2.jpg') center/cover no-repeat;
  min-height: 620px;
}

.ashein-course-hero-card {
  background: rgba(255,255,255,.96);
  border-radius: 32px;
  padding: 34px;
  box-shadow: var(--ashein-shadow);
  border: 1px solid rgba(255,255,255,.5);
  position: relative;
  overflow: hidden;
}

.ashein-course-hero-card:before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 7px;
  background: linear-gradient(90deg, var(--ashein-green), var(--ashein-cyan));
}

.ashein-course-hero-card img {
  width: 92px;
  height: 92px;
  object-fit: contain;
  margin-bottom: 20px;
}

.ashein-course-hero-card h3 {
  color: var(--ashein-blue);
  font-size: 28px;
  font-weight: 900;
  margin-bottom: 12px;
}

.ashein-course-hero-card p {
  color: var(--ashein-muted);
  line-height: 1.7;
  margin-bottom: 20px;
}

.ashein-course-hero-list {
  display: grid;
  gap: 10px;
}

.ashein-course-hero-list span {
  display: flex;
  gap: 9px;
  align-items: center;
  color: #284663;
  font-weight: 700;
}

.ashein-course-hero-list i {
  color: var(--ashein-green);
}

.ashein-category-card {
  display: block;
  height: 100%;
  background: #fff;
  border: 1px solid #e5edf4;
  border-radius: 28px;
  padding: 30px;
  text-align: center;
  box-shadow: 0 14px 34px rgba(7,27,50,.07);
  transition: .25s ease;
  color: inherit;
}

.ashein-category-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--ashein-shadow);
}

.ashein-category-card img {
  width: 86px;
  height: 86px;
  object-fit: contain;
  margin-bottom: 20px;
}

.ashein-category-card h3 {
  color: var(--ashein-blue);
  font-weight: 900;
  font-size: 21px;
  margin-bottom: 10px;
}

.ashein-category-card p {
  color: var(--ashein-muted);
  line-height: 1.65;
  margin: 0;
}

.ashein-course-card-v2 {
  display: flex;
  flex-direction: column;
}

.ashein-course-card-v2 .ashein-course-body {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.ashein-course-features {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 18px 0 20px;
}

.ashein-course-features span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: #f2f8ee;
  color: #376f24;
  border-radius: 999px;
  padding: 7px 11px;
  font-size: 12px;
  font-weight: 800;
}

.ashein-course-btn {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  border-radius: 999px;
  padding: 12px 18px;
  background: var(--ashein-blue);
  color: #fff;
  font-weight: 800;
  transition: .25s ease;
}

.ashein-course-btn:hover {
  background: var(--ashein-green);
  color: #fff;
  transform: translateY(-2px);
}

@media(max-width:991px) {
  .ashein-courses-hero {
    min-height: auto;
    padding: 125px 0 70px;
  }
}

@media(max-width:575px) {
  .ashein-course-hero-card {
    padding: 24px;
    border-radius: 24px;
  }

  .ashein-course-hero-card h3 {
    font-size: 24px;
  }
}


/* Ajustes Cursos v2: modal y Anexo SSPA */
.ashein-course-card-v2 img[src*="logo_sspa"] {
  object-fit: contain;
  padding: 32px;
  background: linear-gradient(135deg, #f4f8fb, #ffffff);
}

.ashein-modal .modal-content {
  border: 0;
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 28px 70px rgba(7,27,50,.25);
}

.ashein-modal .modal-header {
  background: linear-gradient(135deg, var(--ashein-blue), var(--ashein-dark));
  color: #fff;
  border: 0;
  padding: 26px 30px;
}

.ashein-modal .modal-title {
  font-size: 25px;
  font-weight: 900;
  margin: 4px 0 0;
}

.ashein-modal-kicker {
  display: inline-flex;
  color: #a6e96a;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  font-size: 12px;
}

.ashein-modal .btn-close {
  filter: invert(1);
  opacity: .9;
}

.ashein-modal .modal-body {
  padding: 30px;
}

.ashein-modal .modal-footer {
  border: 0;
  padding: 0 30px 30px;
}

.ashein-modal .form-label {
  color: var(--ashein-blue);
  font-weight: 800;
  font-size: 14px;
}

.ashein-modal .form-control,
.ashein-modal .form-select {
  border: 1px solid #dbe7f1;
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: none;
}

.ashein-modal .form-control:focus,
.ashein-modal .form-select:focus {
  border-color: var(--ashein-green);
  box-shadow: 0 0 0 .18rem rgba(130,189,67,.18);
}

.ashein-course-btn.border-0 {
  cursor: pointer;
}


/* Cursos v3: Anexo SSPA como listado informativo */
.ashein-sspa-section {
  position: relative;
  overflow: hidden;
}

.ashein-sspa-card {
  background: #fff;
  border: 1px solid #e2edf5;
  border-radius: 34px;
  padding: 36px;
  box-shadow: 0 20px 48px rgba(7,27,50,.08);
}

.ashein-sspa-side {
  height: 100%;
  background: linear-gradient(135deg, var(--ashein-blue), var(--ashein-dark));
  border-radius: 28px;
  padding: 30px;
  color: #fff;
  box-shadow: var(--ashein-shadow);
}

.ashein-sspa-side img {
  width: 120px;
  height: 120px;
  object-fit: contain;
  background: #fff;
  border-radius: 24px;
  padding: 18px;
  margin-bottom: 22px;
}

.ashein-sspa-side span {
  display: inline-flex;
  color: #a6e96a;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1.3px;
  font-weight: 900;
  margin-bottom: 8px;
}

.ashein-sspa-side h2 {
  font-size: 34px;
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 14px;
}

.ashein-sspa-side p {
  color: #dce8f6;
  line-height: 1.75;
  margin: 0;
}

.ashein-sspa-list {
  display: grid;
  gap: 10px;
}

.ashein-sspa-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: #f4f8fb;
  border: 1px solid #e2ecf4;
  border-radius: 16px;
  padding: 13px 15px;
  color: #334e68;
  line-height: 1.55;
}

.ashein-sspa-item strong {
  width: 30px;
  height: 30px;
  flex: none;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: #eaf7df;
  color: #4b931f;
  font-weight: 900;
}

.ashein-sspa-note {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  margin-top: 18px;
  background: #eef7ff;
  border: 1px solid #dcecff;
  border-radius: 18px;
  padding: 16px;
}

.ashein-sspa-note i {
  color: var(--ashein-blue);
  font-size: 22px;
  margin-top: 1px;
}

.ashein-sspa-note p {
  margin: 0;
  color: #415a77;
  line-height: 1.6;
}

@media(max-width: 991px) {
  .ashein-sspa-card {
    padding: 24px;
  }

  .ashein-sspa-side h2 {
    font-size: 28px;
  }
}

@media(max-width: 575px) {
  .ashein-sspa-card {
    padding: 18px;
    border-radius: 24px;
  }

  .ashein-sspa-side {
    padding: 22px;
    border-radius: 22px;
  }

  .ashein-sspa-item {
    padding: 12px;
  }
}


/* ===== Unidad de Inspección ===== */
.ashein-ui-hero {
  background: linear-gradient(135deg, rgba(7,27,50,.96), rgba(9,56,97,.88)), url('../img/banner/banner1.jpg') center/cover no-repeat;
  min-height: 620px;
}

.ashein-ui-panel {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 34px;
  padding: 34px;
  color: #fff;
  box-shadow: var(--ashein-shadow);
  backdrop-filter: blur(10px);
}

.ashein-ui-panel img {
  max-width: 220px;
  margin-bottom: 22px;
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.18));
}

.ashein-ui-panel h3 {
  font-size: 28px;
  font-weight: 900;
  margin-bottom: 12px;
  color: #fff;
}

.ashein-ui-panel p {
  color: #dce8f6;
  line-height: 1.7;
  margin-bottom: 20px;
}

.ashein-ui-panel-list {
  display: grid;
  gap: 10px;
}

.ashein-ui-panel-list span {
  display: flex;
  gap: 9px;
  align-items: center;
  color: #eef8ff;
  font-weight: 700;
}

.ashein-ui-panel-list i {
  color: #a6e96a;
}

.ashein-ui-media {
  position: relative;
  border-radius: 34px;
  overflow: hidden;
  box-shadow: var(--ashein-shadow);
  background: #eaf1f7;
  min-height: 450px;
}

.ashein-ui-media img {
  width: 100%;
  height: 450px;
  object-fit: cover;
  display: block;
}

.ashein-ui-badge {
  position: absolute;
  left: 26px;
  bottom: 26px;
  background: #fff;
  border-radius: 24px;
  padding: 20px 24px;
  box-shadow: 0 16px 35px rgba(7,27,50,.18);
}

.ashein-ui-badge strong {
  display: block;
  font-size: 44px;
  line-height: 1;
  font-weight: 900;
  color: var(--ashein-green);
}

.ashein-ui-badge span {
  display: block;
  color: var(--ashein-blue);
  font-weight: 800;
  margin-top: 6px;
}

.ashein-ui-service-card {
  height: 100%;
  background: #fff;
  border: 1px solid #e3edf6;
  border-radius: 28px;
  padding: 30px;
  box-shadow: 0 12px 32px rgba(7,27,50,.07);
  transition: .25s ease;
  position: relative;
  overflow: hidden;
}

.ashein-ui-service-card:before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 6px;
  background: linear-gradient(90deg, var(--ashein-green), var(--ashein-cyan));
}

.ashein-ui-service-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--ashein-shadow);
}

.ashein-ui-service-card .icon {
  width: 68px;
  height: 68px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #edf9e4, #e3f8ff);
  color: var(--ashein-blue);
  font-size: 34px;
  margin: 18px 0 22px;
}

.ashein-ui-service-card h3 {
  color: var(--ashein-blue);
  font-size: 22px;
  font-weight: 900;
  margin-bottom: 12px;
}

.ashein-ui-service-card p {
  color: var(--ashein-muted);
  line-height: 1.7;
  margin-bottom: 18px;
}

.ashein-ui-service-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ashein-ui-service-card li {
  display: flex;
  gap: 8px;
  color: #36516d;
  margin-top: 9px;
  font-size: 14px;
}

.ashein-ui-service-card li i {
  color: var(--ashein-green);
  margin-top: 3px;
}

.ashein-ui-highlight {
  background: linear-gradient(135deg, var(--ashein-blue), var(--ashein-dark));
  border-radius: 32px;
  padding: 34px;
  color: #fff;
  box-shadow: var(--ashein-shadow);
}

.ashein-ui-highlight > i {
  width: 76px;
  height: 76px;
  border-radius: 24px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.12);
  color: #a6e96a;
  font-size: 38px;
  margin-bottom: 24px;
}

.ashein-ui-highlight h3 {
  color: #fff;
  font-size: 30px;
  font-weight: 900;
  margin-bottom: 12px;
}

.ashein-ui-highlight p {
  color: #dce8f6;
  line-height: 1.7;
  margin-bottom: 22px;
}

@media(max-width:991px) {
  .ashein-ui-hero {
    min-height: auto;
    padding: 125px 0 70px;
  }

  .ashein-ui-media,
  .ashein-ui-media img {
    min-height: 360px;
    height: 360px;
  }
}

@media(max-width:575px) {
  .ashein-ui-panel,
  .ashein-ui-highlight {
    padding: 24px;
    border-radius: 24px;
  }

  .ashein-ui-panel h3,
  .ashein-ui-highlight h3 {
    font-size: 24px;
  }

  .ashein-ui-media,
  .ashein-ui-media img {
    min-height: 280px;
    height: 280px;
    border-radius: 24px;
  }

  .ashein-ui-badge {
    left: 16px;
    bottom: 16px;
    padding: 16px 18px;
    border-radius: 18px;
  }

  .ashein-ui-badge strong {
    font-size: 34px;
  }
}


/* ===== Contacto ===== */
.ashein-contact-hero {
  background: linear-gradient(135deg, rgba(7,27,50,.96), rgba(9,56,97,.88)), url('../img/banner/banner2.jpg') center/cover no-repeat;
  min-height: 620px;
}

.ashein-contact-panel {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 34px;
  padding: 34px;
  color: #fff;
  box-shadow: var(--ashein-shadow);
  backdrop-filter: blur(10px);
}

.ashein-contact-panel img {
  max-width: 230px;
  margin-bottom: 24px;
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.18));
}

.ashein-contact-panel h3 {
  font-size: 28px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 12px;
}

.ashein-contact-panel p {
  color: #dce8f6;
  line-height: 1.7;
  margin-bottom: 20px;
}

.ashein-contact-panel-list {
  display: grid;
  gap: 10px;
}

.ashein-contact-panel-list span {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #eef8ff;
  font-weight: 700;
}

.ashein-contact-panel-list i {
  color: #a6e96a;
}

.ashein-contact-card {
  display: block;
  height: 100%;
  background: #fff;
  border: 1px solid #e3edf6;
  border-radius: 28px;
  padding: 30px;
  color: inherit;
  box-shadow: 0 12px 32px rgba(7,27,50,.07);
  transition: .25s ease;
  position: relative;
  overflow: hidden;
}

.ashein-contact-card:before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 6px;
  background: linear-gradient(90deg, var(--ashein-green), var(--ashein-cyan));
}

.ashein-contact-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--ashein-shadow);
}

.ashein-contact-card .icon {
  width: 68px;
  height: 68px;
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #edf9e4, #e3f8ff);
  color: var(--ashein-blue);
  font-size: 34px;
  margin: 18px 0 22px;
}

.ashein-contact-card h3 {
  color: var(--ashein-blue);
  font-size: 22px;
  font-weight: 900;
  margin-bottom: 10px;
}

.ashein-contact-card p {
  color: var(--ashein-muted);
  line-height: 1.7;
  margin-bottom: 14px;
}

.ashein-contact-card span {
  display: inline-flex;
  color: var(--ashein-green);
  font-weight: 900;
}

.ashein-contact-info-box {
  height: 100%;
  background: linear-gradient(135deg, var(--ashein-blue), var(--ashein-dark));
  border-radius: 34px;
  padding: 34px;
  color: #fff;
  box-shadow: var(--ashein-shadow);
}

.ashein-contact-info-box h2 {
  color: #fff;
  font-size: 36px;
  font-weight: 900;
  line-height: 1.14;
  margin-bottom: 16px;
}

.ashein-contact-info-box p {
  color: #dce8f6;
  line-height: 1.75;
  margin-bottom: 24px;
}

.ashein-contact-info-list {
  display: grid;
  gap: 14px;
}

.ashein-contact-info-list div {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 18px;
  padding: 14px;
}

.ashein-contact-info-list i {
  color: #a6e96a;
  font-size: 22px;
  margin-top: 2px;
}

.ashein-contact-info-list span {
  color: #eef8ff;
  line-height: 1.55;
  font-weight: 600;
}

.ashein-contact-form-card {
  height: 100%;
  background: #fff;
  border: 1px solid #e3edf6;
  border-radius: 34px;
  padding: 34px;
  box-shadow: 0 18px 42px rgba(7,27,50,.08);
}

.ashein-contact-form .form-label {
  color: var(--ashein-blue);
  font-weight: 800;
  font-size: 14px;
}

.ashein-contact-form .form-control,
.ashein-contact-form .form-select {
  border: 1px solid #dbe7f1;
  border-radius: 14px;
  padding: 13px 14px;
  box-shadow: none;
}

.ashein-contact-form .form-control:focus,
.ashein-contact-form .form-select:focus {
  border-color: var(--ashein-green);
  box-shadow: 0 0 0 .18rem rgba(130,189,67,.18);
}

.ashein-social-box {
  height: 100%;
  background: #fff;
  border: 1px solid #e3edf6;
  border-radius: 30px;
  padding: 32px;
  box-shadow: 0 14px 36px rgba(7,27,50,.07);
}

.ashein-social-box h3 {
  color: var(--ashein-blue);
  font-size: 26px;
  font-weight: 900;
  margin-bottom: 10px;
}

.ashein-social-box p {
  color: var(--ashein-muted);
  line-height: 1.7;
  margin-bottom: 20px;
}

.ashein-social-large {
  display: grid;
  gap: 12px;
}

.ashein-social-large a {
  display: flex;
  align-items: center;
  gap: 12px;
  background: #f4f8fb;
  border: 1px solid #e2ecf4;
  border-radius: 16px;
  padding: 14px 16px;
  color: var(--ashein-blue);
  font-weight: 800;
  transition: .25s ease;
}

.ashein-social-large a:hover {
  background: var(--ashein-blue);
  color: #fff;
}

.ashein-social-large i {
  font-size: 26px;
}

.ashein-platform-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.ashein-platform-actions .ashein-btn-light {
  border: 1px solid #e3edf6;
}

@media(max-width:991px) {
  .ashein-contact-hero {
    min-height: auto;
    padding: 125px 0 70px;
  }
}

@media(max-width:575px) {
  .ashein-contact-panel,
  .ashein-contact-info-box,
  .ashein-contact-form-card,
  .ashein-social-box {
    padding: 24px;
    border-radius: 24px;
  }

  .ashein-contact-info-box h2 {
    font-size: 28px;
  }

  .ashein-platform-actions {
    display: grid;
  }
}


/* ===== Fix menú móvil ASHEIN ===== */
@media (max-width: 991px) {
  #header.ashein-header {
    padding: 10px 0;
  }

  #header.ashein-header .logo img {
    max-height: 50px !important;
  }

  .mobile-nav-toggle {
    display: block !important;
    color: var(--ashein-blue) !important;
    font-size: 34px !important;
    cursor: pointer;
    line-height: 1;
    z-index: 10001;
  }

  .navbar ul {
    display: none;
  }

  .navbar-mobile {
    position: fixed !important;
    overflow: hidden;
    inset: 0;
    background: rgba(7, 27, 50, .72);
    transition: .3s;
    z-index: 9999;
  }

  .navbar-mobile .mobile-nav-toggle {
    position: absolute;
    top: 22px;
    right: 22px;
    color: #ffffff !important;
    font-size: 36px !important;
  }

  .navbar-mobile ul {
    display: block !important;
    position: absolute;
    top: 76px;
    right: 18px;
    bottom: 18px;
    left: 18px;
    padding: 18px 0;
    border-radius: 24px;
    background: #ffffff;
    box-shadow: 0 22px 60px rgba(7, 27, 50, .28);
    overflow-y: auto;
  }

  .navbar-mobile li {
    display: block;
    width: 100%;
  }

  .navbar-mobile a,
  .navbar-mobile a:focus {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: 15px 22px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    color: var(--ashein-blue) !important;
    white-space: normal;
    border-bottom: 1px solid #edf2f7;
  }

  .navbar-mobile li:last-child a {
    border-bottom: 0;
  }

  .navbar-mobile a:hover,
  .navbar-mobile .active,
  .navbar-mobile li:hover > a {
    color: var(--ashein-green) !important;
    background: #f4f8fb;
  }

  .navbar-mobile .ashein-header-cta {
    margin: 14px 18px 4px;
    justify-content: center;
    background: linear-gradient(135deg, var(--ashein-green), #5da929) !important;
    color: #ffffff !important;
    border-radius: 999px !important;
    border-bottom: 0 !important;
    box-shadow: 0 10px 25px rgba(130, 189, 67, .30);
  }

  .navbar-mobile .ashein-header-cta:hover {
    color: #ffffff !important;
    background: linear-gradient(135deg, #6eb235, var(--ashein-green)) !important;
  }
}

@media (min-width: 992px) {
  .mobile-nav-toggle {
    display: none !important;
  }

  .navbar ul {
    display: flex;
  }
}


/* ===== Fix menú móvil ASHEIN v2 - fuerza enlaces visibles ===== */
@media (max-width: 991px) {
  body.mobile-nav-active {
    overflow: hidden;
  }

  #navbar {
    position: static;
  }

  #navbar .mobile-nav-toggle,
  #navbar i.mobile-nav-toggle {
    display: block !important;
    color: var(--ashein-blue) !important;
    font-size: 34px !important;
    cursor: pointer;
    z-index: 10003 !important;
  }

  #navbar > ul {
    display: none !important;
  }

  #navbar.navbar-mobile {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    background: rgba(7, 27, 50, .78) !important;
    z-index: 10000 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  #navbar.navbar-mobile .mobile-nav-toggle,
  #navbar.navbar-mobile i.mobile-nav-toggle {
    position: fixed !important;
    top: 22px !important;
    right: 24px !important;
    color: #ffffff !important;
    font-size: 36px !important;
    z-index: 10004 !important;
  }

  #navbar.navbar-mobile > ul {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: fixed !important;
    top: 78px !important;
    left: 18px !important;
    right: 18px !important;
    bottom: 18px !important;
    width: auto !important;
    height: auto !important;
    max-height: calc(100vh - 96px) !important;
    overflow-y: auto !important;
    padding: 12px 0 !important;
    margin: 0 !important;
    border-radius: 24px !important;
    background: #ffffff !important;
    box-shadow: 0 28px 80px rgba(0, 0, 0, .35) !important;
    z-index: 10002 !important;
  }

  #navbar.navbar-mobile > ul > li {
    display: block !important;
    position: relative !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  #navbar.navbar-mobile > ul > li > a,
  #navbar.navbar-mobile > ul > li > a:focus {
    display: block !important;
    width: 100% !important;
    padding: 15px 22px !important;
    margin: 0 !important;
    color: #0b2f5b !important;
    background: transparent !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
    text-align: left !important;
    border-bottom: 1px solid #edf2f7 !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  #navbar.navbar-mobile > ul > li > a:hover,
  #navbar.navbar-mobile > ul > li > a.active {
    color: #82bd43 !important;
    background: #f4f8fb !important;
  }

  #navbar.navbar-mobile > ul > li > a.ashein-header-cta {
    display: block !important;
    width: calc(100% - 36px) !important;
    margin: 14px 18px 6px !important;
    padding: 14px 18px !important;
    text-align: center !important;
    color: #ffffff !important;
    background: linear-gradient(135deg, #82bd43, #5da929) !important;
    border-radius: 999px !important;
    border-bottom: 0 !important;
    box-shadow: 0 10px 25px rgba(130, 189, 67, .30) !important;
  }
}

/* Por si algún estilo del template deja el menú como flex vacío */
@media (max-width: 991px) {
  .navbar-mobile ul,
  .navbar-mobile > ul,
  nav.navbar-mobile ul,
  nav.navbar-mobile > ul {
    display: block !important;
  }
}


/* ===== Fix menú móvil ASHEIN v3 - menú propio independiente ===== */
@media (max-width: 991px) {
  body.ashein-mobile-menu-open {
    overflow: hidden !important;
  }

  .ashein-mobile-menu-panel {
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    background: rgba(7, 27, 50, .78) !important;
    padding: 76px 18px 18px !important;
    display: none;
  }

  body.ashein-mobile-menu-open .ashein-mobile-menu-panel {
    display: block !important;
  }

  .ashein-mobile-menu-box {
    width: 100% !important;
    max-height: calc(100vh - 94px) !important;
    overflow-y: auto !important;
    background: #ffffff !important;
    border-radius: 24px !important;
    box-shadow: 0 28px 80px rgba(0, 0, 0, .35) !important;
    padding: 12px 0 !important;
  }

  .ashein-mobile-menu-box a {
    display: block !important;
    width: 100% !important;
    padding: 16px 24px !important;
    color: #0b2f5b !important;
    background: #ffffff !important;
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
    text-align: left !important;
    opacity: 1 !important;
    visibility: visible !important;
    border-bottom: 1px solid #edf2f7 !important;
    text-decoration: none !important;
  }

  .ashein-mobile-menu-box a:hover,
  .ashein-mobile-menu-box a.active {
    color: #82bd43 !important;
    background: #f4f8fb !important;
  }

  .ashein-mobile-menu-box a.ashein-header-cta {
    width: calc(100% - 36px) !important;
    margin: 14px 18px 8px !important;
    padding: 15px 18px !important;
    text-align: center !important;
    color: #ffffff !important;
    background: linear-gradient(135deg, #82bd43, #5da929) !important;
    border-radius: 999px !important;
    border-bottom: 0 !important;
    box-shadow: 0 10px 25px rgba(130, 189, 67, .30) !important;
  }

  .ashein-mobile-menu-close {
    position: fixed !important;
    top: 22px !important;
    right: 24px !important;
    z-index: 1000000 !important;
    width: 44px !important;
    height: 44px !important;
    border: 0 !important;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, .12) !important;
    color: #ffffff !important;
    font-size: 32px !important;
    line-height: 1 !important;
    display: none;
    align-items: center !important;
    justify-content: center !important;
  }

  body.ashein-mobile-menu-open .ashein-mobile-menu-close {
    display: flex !important;
  }

  body.ashein-mobile-menu-open #navbar.navbar-mobile {
    display: none !important;
  }

  body.ashein-mobile-menu-open #navbar.navbar-mobile > ul {
    display: none !important;
  }
}


/* ===== Fix menú móvil ASHEIN v4 - ocultar menú móvil fuera de móvil ===== */

/* Oculto SIEMPRE por defecto para que no se pinte en escritorio ni al cargar página */
.ashein-mobile-menu-panel,
.ashein-mobile-menu-close {
  display: none !important;
}

/* Sólo en móvil, y sólo cuando el JS agregue la clase al body */
@media (max-width: 991px) {
  body.ashein-mobile-menu-open .ashein-mobile-menu-panel {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 999999 !important;
    background: rgba(7, 27, 50, .78) !important;
    padding: 76px 18px 18px !important;
  }

  body.ashein-mobile-menu-open .ashein-mobile-menu-close {
    display: flex !important;
    position: fixed !important;
    top: 22px !important;
    right: 24px !important;
    z-index: 1000000 !important;
    width: 44px !important;
    height: 44px !important;
    border: 0 !important;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, .12) !important;
    color: #ffffff !important;
    font-size: 32px !important;
    line-height: 1 !important;
    align-items: center !important;
    justify-content: center !important;
  }

  body.ashein-mobile-menu-open .ashein-mobile-menu-box {
    display: block !important;
    width: 100% !important;
    max-height: calc(100vh - 94px) !important;
    overflow-y: auto !important;
    background: #ffffff !important;
    border-radius: 24px !important;
    box-shadow: 0 28px 80px rgba(0, 0, 0, .35) !important;
    padding: 12px 0 !important;
  }

  body.ashein-mobile-menu-open .ashein-mobile-menu-box a {
    display: block !important;
    width: 100% !important;
    padding: 16px 24px !important;
    color: #0b2f5b !important;
    background: #ffffff !important;
    font-family: 'Poppins', 'Open Sans', Arial, sans-serif !important;
    font-size: 17px !important;
    font-weight: 800 !important;
    line-height: 1.35 !important;
    text-align: left !important;
    opacity: 1 !important;
    visibility: visible !important;
    border-bottom: 1px solid #edf2f7 !important;
    text-decoration: none !important;
  }

  body.ashein-mobile-menu-open .ashein-mobile-menu-box a:hover,
  body.ashein-mobile-menu-open .ashein-mobile-menu-box a.active {
    color: #82bd43 !important;
    background: #f4f8fb !important;
  }

  body.ashein-mobile-menu-open .ashein-mobile-menu-box a.ashein-header-cta {
    width: calc(100% - 36px) !important;
    margin: 14px 18px 8px !important;
    padding: 15px 18px !important;
    text-align: center !important;
    color: #ffffff !important;
    background: linear-gradient(135deg, #82bd43, #5da929) !important;
    border-radius: 999px !important;
    border-bottom: 0 !important;
    box-shadow: 0 10px 25px rgba(130, 189, 67, .30) !important;
  }
}

/* En escritorio queda completamente apagado aunque el JS lo haya creado */
@media (min-width: 992px) {
  body.ashein-mobile-menu-open {
    overflow: auto !important;
  }

  .ashein-mobile-menu-panel,
  .ashein-mobile-menu-close {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }
}


/* ===== Aviso de Privacidad ===== */
.ashein-privacy-hero {
  background: linear-gradient(135deg, rgba(7,27,50,.96), rgba(9,56,97,.88)), url('../img/banner/banner2.jpg') center/cover no-repeat;
  min-height: 560px;
}

.ashein-privacy-panel {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.20);
  border-radius: 34px;
  padding: 34px;
  color: #fff;
  box-shadow: var(--ashein-shadow);
  backdrop-filter: blur(10px);
}

.ashein-privacy-panel > i {
  width: 82px;
  height: 82px;
  display: grid;
  place-items: center;
  border-radius: 26px;
  background: rgba(255,255,255,.12);
  color: #a6e96a;
  font-size: 42px;
  margin-bottom: 24px;
}

.ashein-privacy-panel h3 {
  font-size: 30px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 12px;
}

.ashein-privacy-panel p {
  color: #dce8f6;
  line-height: 1.75;
  margin: 0;
}

.ashein-privacy-index {
  position: sticky;
  top: 110px;
  background: #fff;
  border: 1px solid #e3edf6;
  border-radius: 28px;
  padding: 28px;
  box-shadow: 0 16px 38px rgba(7,27,50,.08);
}

.ashein-privacy-index h3 {
  color: var(--ashein-blue);
  font-size: 24px;
  font-weight: 900;
  margin: 10px 0 18px;
}

.ashein-privacy-index a {
  display: block;
  padding: 12px 0;
  color: #334e68;
  font-weight: 800;
  border-bottom: 1px solid #edf2f7;
}

.ashein-privacy-index a:hover {
  color: var(--ashein-green);
}

.ashein-privacy-index a:last-child {
  border-bottom: 0;
}

.ashein-privacy-content {
  background: #fff;
  border: 1px solid #e3edf6;
  border-radius: 34px;
  padding: 40px;
  box-shadow: 0 18px 42px rgba(7,27,50,.08);
}

.ashein-privacy-content section {
  scroll-margin-top: 120px;
  padding-bottom: 28px;
  margin-bottom: 28px;
  border-bottom: 1px solid #edf2f7;
}

.ashein-privacy-content section:last-child {
  border-bottom: 0;
  margin-bottom: 0;
  padding-bottom: 0;
}

.ashein-privacy-content h2 {
  color: var(--ashein-blue);
  font-size: 30px;
  font-weight: 900;
  margin-bottom: 14px;
}

.ashein-privacy-content p {
  color: #52667a;
  line-height: 1.85;
  font-size: 16px;
  margin-bottom: 14px;
}

.ashein-privacy-list {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.ashein-privacy-list p {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin: 0;
  color: #334e68;
  line-height: 1.55;
  font-size: 15px;
  background: #f4f8fb;
  border: 1px solid #e3edf6;
  border-radius: 16px;
  padding: 12px 14px;
}

.ashein-privacy-list i {
  color: var(--ashein-green);
  font-size: 19px;
  margin-top: 2px;
  flex: none;
}

.ashein-privacy-callout {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-top: 18px;
  background: #eef7ff;
  border: 1px solid #dcecff;
  border-radius: 20px;
  padding: 18px;
}

.ashein-privacy-callout i {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  flex: none;
  border-radius: 16px;
  background: #fff;
  color: var(--ashein-blue);
  font-size: 24px;
}

.ashein-privacy-callout strong {
  display: block;
  color: var(--ashein-blue);
  font-weight: 900;
  margin-bottom: 4px;
}

.ashein-privacy-callout span {
  display: block;
  color: #52667a;
  line-height: 1.6;
}

@media(max-width:991px) {
  .ashein-privacy-hero {
    min-height: auto;
    padding: 125px 0 70px;
  }

  .ashein-privacy-index {
    position: relative;
    top: auto;
  }
}

@media(max-width:575px) {
  .ashein-privacy-panel,
  .ashein-privacy-index,
  .ashein-privacy-content {
    padding: 24px;
    border-radius: 24px;
  }

  .ashein-privacy-panel h3,
  .ashein-privacy-content h2 {
    font-size: 24px;
  }
}
