@import url("../../node_modules/swiper/swiper.css");
@import url("../../node_modules/swiper/modules/navigation.css");
@import url("../../node_modules/swiper/modules/pagination.css");

/* Componentes compartidos por el constructor controlado, Live Editor y sitio. */
:root{--block-radius:2px;--block-soft:#f4f0e7;--block-ink:#10233b;--block-line:#d8d0c2}

/* Hero institucional: una portada panorámica completa, nunca una columna. */
.home-hero-stage{position:relative;min-height:100svh;isolation:isolate;overflow:hidden}
.home-hero-stage:after{content:'';position:absolute;z-index:1;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(2,8,17,.94) 0%,rgba(2,8,17,.74) 43%,rgba(2,8,17,.18) 72%,rgba(2,8,17,.08)),linear-gradient(0deg,rgba(2,8,17,.62),transparent 42%)}
.hero-grid{position:relative;z-index:3;display:flex;min-height:100svh;align-items:center;padding-top:130px;padding-bottom:95px}
.hero-content{position:relative;z-index:3;width:min(760px,72%)}
.hero-portrait{position:absolute;z-index:0;inset:0;width:100%;height:100%;min-height:100%;margin:0;overflow:hidden;border:0;background:radial-gradient(circle at 72% 40%,rgba(49,84,124,.62),transparent 42%),linear-gradient(145deg,#061a33,#020811 78%)}
.hero-portrait:before{content:'MAEB';position:absolute;z-index:0;left:-.05em;bottom:-.13em;color:rgba(255,255,255,.055);font:600 clamp(190px,38vw,580px)/.72 var(--serif);letter-spacing:-.09em}
.hero-portrait:after{content:'';position:absolute;z-index:2;inset:auto 0 0;height:22%;background:linear-gradient(transparent,rgba(2,8,17,.7));pointer-events:none}
.hero-portrait img{position:absolute;z-index:1;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;filter:saturate(.94) contrast(1.03)}
.hero-portrait-placeholder{position:absolute;z-index:1;inset:0;display:grid;place-content:center;justify-items:center;gap:12px;color:rgba(255,255,255,.44)}
.hero-portrait-placeholder span{font:500 clamp(84px,9vw,150px)/.8 var(--serif);letter-spacing:-.06em}
.hero-portrait-placeholder small{font:700 8px/1 var(--sans);letter-spacing:.24em;text-transform:uppercase}
.hero-actions [data-hero-primary]:after{content:' →';margin-left:15px}
.hero-actions [data-hero-secondary]:after{content:' ↘';margin-left:10px}

/* Plantillas extendidas. */
.block-template .block-feature-media{width:100%;margin:0;overflow:hidden;background:var(--navy)}
.block-template .block-feature-media img{display:block;width:100%;height:100%;object-fit:cover}
.block-template .block-media-placeholder{display:grid;place-items:center;min-height:260px;color:rgba(255,255,255,.22);background:linear-gradient(135deg,#061a33,#12375f);font:600 100px/.8 var(--serif)}
.block-template-hero{position:relative;min-height:clamp(650px,88svh,920px);display:flex;align-items:center;overflow:hidden;color:#fff;background:#061a33}
.block-template-hero:after{content:'';position:absolute;z-index:1;inset:0;background:linear-gradient(90deg,rgba(2,8,17,.94),rgba(2,8,17,.58) 52%,rgba(2,8,17,.12)),linear-gradient(0deg,rgba(2,8,17,.52),transparent 45%);pointer-events:none}
.block-template-hero .block-shell{position:relative;z-index:2;display:flex!important;flex-direction:column;align-items:flex-start;justify-content:center;min-height:inherit}
.block-template-hero .block-heading{position:relative;z-index:3;display:block!important;width:min(760px,70%);margin:0!important}
.block-template-hero .block-heading-meta{display:block}.block-template-hero .block-order{display:none!important}.block-template-hero .block-eyebrow{max-width:none!important;color:#e0cc95!important}
.block-template-hero .block-title{max-width:780px!important;color:#fff!important;font-size:clamp(62px,8vw,118px)!important;line-height:.82!important}
.block-template-hero .block-intro{color:rgba(255,255,255,.76)!important;font-size:15px!important}
.block-template-hero .block-feature-media{position:absolute;z-index:0;inset:0;width:100%;height:100%;margin:0}
.block-template-hero .block-feature-media img{width:100%;height:100%;object-fit:cover}
.block-template-hero .block-footer{position:relative;z-index:3;width:auto!important;margin:30px 0 0!important}
.block-template-hero .strategy-link{color:#fff;border-color:rgba(255,255,255,.4)}
.block-template-textImage .block-shell{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);gap:clamp(35px,6vw,80px);align-items:center}
.block-template-textImage .block-heading{grid-template-columns:minmax(0,1fr)!important;margin:0!important}
.block-template-textImage .block-heading-meta{display:flex;align-items:center;gap:14px}.block-template-textImage .block-order{margin:0!important}
.block-template-textImage .block-feature-media{min-height:420px;aspect-ratio:4/3}
.block-template-banner{position:relative}
.block-template-banner .block-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,.55fr);gap:45px;align-items:center}
.block-template-banner .block-heading{grid-template-columns:minmax(0,1fr)!important;margin:0!important}
.block-template-banner .block-heading-meta{display:none}
.block-template-banner .block-feature-media{grid-column:2;grid-row:1/3;min-height:300px}
.block-template-banner .block-footer{grid-column:1;margin:0!important}
.block-template-divider{padding-block:42px!important}
.block-template-divider .block-shell:before{content:'✦';display:flex;align-items:center;gap:20px;color:var(--gold);font-size:13px}
.block-template-divider .block-shell:after{content:'';display:block;height:1px;margin-top:-11px;margin-left:40px;background:currentColor;opacity:.2}
.block-template-html .block-custom-html{max-width:900px;margin-left:auto;font-size:15px;line-height:1.75}

.block-item-image{width:calc(100% + 48px);height:210px;margin:-24px -24px 22px;object-fit:cover}
.block-item-link{margin-top:18px;color:inherit;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;text-decoration:none}
.block-items-services .block-item{background:rgba(255,255,255,.48)}
.theme-navy .block-items-services .block-item{background:rgba(255,255,255,.04)}

.block-items-faq{display:grid;gap:10px!important;max-width:900px;margin-left:auto}
.block-items-faq .block-item{height:auto!important;border:1px solid currentColor;padding:0;opacity:.82}
.block-items-faq summary{display:grid;grid-template-columns:54px 1fr;gap:18px;align-items:center;padding:20px 22px;cursor:pointer;list-style:none}
.block-items-faq summary::-webkit-details-marker{display:none}
.block-items-faq summary:after{content:'+';justify-self:end;font-size:20px}
.block-items-faq details[open] summary:after{content:'−'}
.block-items-faq summary strong{font:600 24px/1.1 var(--serif)}
.block-items-faq .block-item-copy{padding:0 22px 22px 94px;max-width:760px}

.block-items-gallery{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px!important}
.block-items-gallery figure{position:relative;min-height:360px;margin:0;overflow:hidden;background:var(--navy)}
.block-items-gallery img,.block-items-gallery .block-media-placeholder{width:100%;height:100%;min-height:360px;object-fit:cover;transition:transform .45s ease}
.block-items-gallery figure:hover img{transform:scale(1.035)}
.block-items-gallery figcaption{position:absolute;inset:auto 0 0;padding:50px 20px 18px;color:#fff;background:linear-gradient(transparent,rgba(2,9,18,.88))}
.block-items-gallery figcaption strong,.block-items-gallery figcaption span{display:block}
.block-items-gallery figcaption strong{font:600 24px/1 var(--serif)}
.block-items-gallery figcaption span{margin-top:7px;font-size:11px;opacity:.74}

.block-items-testimonials{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px!important}
.block-items-testimonials .block-item{display:flex;flex-direction:column;min-height:260px;margin:0;padding:26px;border:1px solid currentColor}
.block-items-testimonials .block-item>span{color:var(--gold);font:600 58px/.6 var(--serif)}
.block-items-testimonials p{margin:auto 0 22px;font:500 25px/1.2 var(--serif)}
.block-items-testimonials cite{font:700 9px/1.4 var(--sans);letter-spacing:.12em;text-transform:uppercase}

.block-items-timeline{display:grid!important;grid-template-columns:minmax(0,1fr);max-width:960px;margin-left:auto;border-top:1px solid currentColor}
.block-items-timeline .block-item{display:grid;grid-template-columns:160px minmax(0,1fr);gap:30px;padding:25px 0;border-bottom:1px solid currentColor}
.block-items-timeline .block-item-value{color:var(--gold);font-size:28px!important}
.block-items-timeline .block-item-title{margin:0 0 7px!important}

.block-carousel{width:100%;padding-bottom:46px!important;--swiper-theme-color:var(--gold)}
.block-carousel:not(.swiper-initialized) .swiper-wrapper{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.block-carousel-slide{box-sizing:border-box;min-height:410px;border:1px solid currentColor;background:rgba(255,255,255,.15)}
.block-carousel-slide>img,.block-carousel-slide>.block-media-placeholder{width:100%;height:220px;min-height:220px;object-fit:cover}
.block-carousel-slide>div:last-child{padding:22px}
.block-carousel .swiper-button-prev,.block-carousel .swiper-button-next{top:auto;bottom:0;width:34px;height:34px;color:currentColor}
.block-carousel .swiper-button-prev{left:auto;right:42px}.block-carousel .swiper-button-next{right:0}
.block-carousel .swiper-button-prev:after,.block-carousel .swiper-button-next:after{font-size:14px}
.block-carousel .swiper-pagination{text-align:left}

/* Builder avanzado publicado permanece aislado mediante Shadow DOM. */
.builder-public-host{display:block;width:100%}

/* Blog / Editor.js público. */
.blog-section{background:var(--ivory)}
.blog-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.blog-card{display:flex;min-width:0;min-height:470px;flex-direction:column;border:1px solid var(--line);background:#fff}
.blog-card-media{height:210px;overflow:hidden;background:linear-gradient(135deg,var(--navy),#12375f)}
.blog-card-media img{width:100%;height:100%;object-fit:cover}
.blog-card-media>span{display:grid;place-items:center;height:100%;color:rgba(255,255,255,.5);font:600 42px/1 var(--serif)}
.blog-card-copy{display:flex;flex:1;flex-direction:column;padding:24px}
.blog-card-copy small{color:var(--gold-text);font-size:9px;font-weight:700;letter-spacing:.13em;text-transform:uppercase}
.blog-card-copy h3{margin:15px 0 12px;color:var(--navy);font:600 30px/1.05 var(--serif)}
.blog-card-copy p{color:var(--slate);font-size:13px}
.blog-card-copy button{align-self:flex-start;margin-top:auto;padding:10px 0;border:0;border-bottom:1px solid var(--line);background:none;color:var(--navy);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}
.blog-empty{grid-column:1/-1;padding:60px;border:1px solid var(--line);text-align:center}
.blog-empty h3{font:600 38px/1 var(--serif);color:var(--navy)}
.post-modal{width:min(940px,calc(100% - 28px));max-height:92dvh;padding:0;border:0;background:#fff;color:var(--ink);box-shadow:var(--shadow)}
.post-modal::backdrop{background:rgba(2,9,18,.82);backdrop-filter:blur(6px)}
.post-modal>article{max-width:790px;margin:auto;padding:70px 45px}
.post-modal h2{margin:14px 0 40px;color:var(--navy);font:600 clamp(44px,6vw,72px)/.95 var(--serif)}
.post-modal-content{font-size:16px;line-height:1.75}
.post-modal-content h2,.post-modal-content h3{margin:1.4em 0 .5em;color:var(--navy);font-family:var(--serif);line-height:1}
.post-modal-content h2{font-size:40px}.post-modal-content h3{font-size:30px}
.post-modal-content img,.post-modal-content iframe{display:block;max-width:100%;margin:28px auto}
.post-modal-content blockquote{margin:35px 0;padding:24px;border-left:3px solid var(--gold);font:500 27px/1.3 var(--serif)}
.post-modal-content table{width:100%;border-collapse:collapse}.post-modal-content td{padding:9px;border:1px solid var(--line)}
.editor-table{overflow:auto}.editor-embed{aspect-ratio:16/9}.editor-embed iframe{width:100%;height:100%;border:0}

@media(max-width:1000px){
  .hero-content{width:min(700px,80%)}
  .block-template-textImage .block-shell{grid-template-columns:minmax(0,1fr) minmax(280px,.8fr);gap:34px}
  .block-items-gallery,.block-items-testimonials,.blog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:700px){
  .home-hero-stage,.hero-grid{min-height:92svh}.hero-grid{padding-top:110px;padding-bottom:72px}.hero-content{width:100%}.hero-portrait img{object-position:center center}.hero-scroll{display:none}
  .block-template-hero{min-height:82svh}.block-template-hero .block-heading{width:100%}.block-template-hero .block-title{font-size:clamp(52px,17vw,76px)!important}.block-template-hero .block-feature-media{min-height:100%}
  .block-template-textImage .block-shell,.block-template-banner .block-shell{display:grid;grid-template-columns:minmax(0,1fr)}
  .block-template-textImage .block-feature-media{min-height:360px}
  .block-template-banner .block-feature-media{grid-column:1;grid-row:auto;min-height:250px}.block-template-banner .block-footer{grid-column:1}
  .block-items-gallery,.block-items-testimonials,.blog-grid{grid-template-columns:minmax(0,1fr)}
  .block-carousel:not(.swiper-initialized) .swiper-wrapper{grid-template-columns:minmax(0,1fr)}
  .block-items-gallery figure,.block-items-gallery img,.block-items-gallery .block-media-placeholder{min-height:310px}
  .block-items-faq summary{grid-template-columns:40px 1fr;padding:18px 14px}.block-items-faq .block-item-copy{padding:0 14px 18px 72px}
  .block-items-timeline .block-item{grid-template-columns:90px minmax(0,1fr);gap:18px}
  .post-modal>article{padding:55px 22px}.blog-empty{padding:38px 20px}
}
