/* =========================
   0) Variables y base
   ========================= */
:root{
  /* Tipografías */
  --body-font: "Work Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --heading-font: "Montserrat", var(--body-font);

  /* Paleta */
  --bs-blue:   #4BA1A7;
  --bs-red:    #F0756C;
  --bs-orange: #F5E9E9;
  --bs-yellow: #EFEAEA;
  --bs-green:  #F5F8F1;
  --bs-teal:   #EFE8EF;
  --bs-cyan:   #F3F3F3;
  --bs-black:  #111111;
  --bs-white:  #FFFFFF;
  --bs-gray:   #777777;
  --bs-info:   #C3C3C3;
  --bs-primary:#F0756C;

  /* Links */
  --bs-link-color:#111111;
  --bs-link-hover-color:#F0756C;

  /* UI */
  --header-h: 72px;        /* alto visual del header en desktop */
  --header-h-sm: 64px;     /* alto visual en móvil */
  --hotpink:#fb2d7a;       /* acento sitio */
  --glass-bg:rgba(0,0,0,.28);
  --glass-brd:rgba(255,255,255,.18);

  /* Swiper */
  --swiper-pagination-color:#F0756C;
}

html, body{
  height:100%;
  scroll-behavior:smooth;
}

body{
  font-family: var(--body-font);
  color: var(--bs-black);
  margin:0;
}

/* Empuje solo al primer section tras header (no a todo el body) */
header + section,
header + .hero-banner,
header + .page-hero-wrap{
  margin-top: var(--header-h);
}
@media (max-width: 576px){
  header + section,
  header + .hero-banner,
  header + .page-hero-wrap{ margin-top: var(--header-h-sm); }
}

/* =========================
   1) Utilidades y helpers
   ========================= */
.bg-gray  { background-color: var(--bs-gray)  !important; }
.bg-yellow{ background-color: var(--bs-yellow)!important; }
.bg-green { background-color: var(--bs-green) !important; }
.bg-teal  { background-color: var(--bs-teal)  !important; }

.lh-small{ line-height: .8; }
.ls-4    { letter-spacing: .2rem; }

.postf{ color: var(--bs-gray); }
.postg{ color: var(--bs-info); }

/* Contenedor ancho mayor (desktop) */
@media (min-width:1200px){
  .container, .container-lg, .container-md, .container-sm, .container-xl{
    max-width:1460px;
  }
}

/* =========================
   2) Tipografía display
   ========================= */
h2,h3,h4,h5,h6{ font-weight:700; font-family: var(--heading-font); }

.display-1{
  font-family: var(--heading-font);
  font-weight:900;
  font-size: clamp(3rem, 6vw, 6.5rem);
  line-height:.8;
}
.display-2,.display-3,.display-4,.display-5{ font-weight:700; }

/* =========================
   3) Navbar / Menú
   ========================= */
/* Header base: ya usas .navbar.fixed-top en el HTML */
.navbar{
  background:#fff;
  box-shadow: 0 2px 12px rgba(0,0,0,.04);
  margin-bottom:0;               /* sin hueco extra */
}

.navbar svg{ color: var(--bs-black); }

.navbar .navbar-nav .nav-link{
  font-family: "Montserrat", sans-serif;
  font-weight:600;
  font-size:14px;
  letter-spacing:1px;
  text-transform:uppercase;
  color:#000;
  padding:.5rem .75rem;
}
.navbar .navbar-nav .nav-link:hover,
.navbar .navbar-nav .nav-link:focus{
  color: var(--bs-primary)!important;
}

/* Dropdown (nivel 1) */
.dropdown-menu{
  border-radius: .75rem;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
}
.dropdown-item{
  font-family: var(--body-font);
  font-weight:600;
}
.dropdown-item:hover{
  background: var(--bs-orange);
  color: var(--bs-black);
}

/* Toggler / offcanvas por encima del hero */
.navbar-toggler{ border:0; position:relative; z-index:2100; }
.navbar-toggler .navbar-toggler-icon{ background-image: var(--bs-navbar-toggler-icon-bg); }
.offcanvas{ z-index:2000; }
.offcanvas .nav-link{ font-weight:600; }

/* Desktop layout */
@media (min-width:992px){
  .navbar .navbar-nav.d-lg-flex{ display:flex!important; flex-direction:row!important; }
}

/* =========================
   4) Botón CTA
   ========================= */
.cta-btn{
  font-family:"Montserrat",sans-serif;
  font-weight:700;
  font-size:14px;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:12px 28px;
  border:0;
  border-radius:6px;
  background: linear-gradient(90deg,#ff3cac,#ff4ecb,#ff6ec7);
  color:#fff !important;
  text-decoration:none;
  display:inline-block;
  transition: transform .2s ease, box-shadow .2s ease, background .3s;
  box-shadow: 0 8px 20px rgba(255,78,203,.25);
}
.cta-btn:hover{
  transform: translateY(-2px);
  background: linear-gradient(90deg,#ff6ec7,#ff4ecb,#ff3cac);
  box-shadow: 0 10px 26px rgba(255,78,203,.35);
}

/* =========================
   5) Banner / Hero
   ========================= */
.banner{
  background-size:cover;
  background-position:center;
  border-radius:18px;
  min-height: clamp(420px, 58vh, 640px);
  max-height: 700px;                  /* evita expansión rara */
  display:flex;
  flex-direction:column;
  justify-content:center;             /* centra bloque de texto */
  padding: clamp(2rem, 4vw, 4rem);
  margin-top:0;                       /* sin hueco extra */
}
.text-content{
  color:#fff;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
  margin: 0 auto 1.5rem auto;         /* centrado + respiro antes de stats */
  padding: 0;                         /* elimina py-5/my-5 inflado */
}

/* Copy principal SPOILED / IKBF */
.hero-copy{ line-height:1.05; text-shadow:0 2px 24px rgba(0,0,0,.25); }
.hero-line1,.hero-line2{
  display:block; color: var(--hotpink); font-weight:800; letter-spacing:.5px;
}
.hero-line1{ font-size: clamp(24px, 3.1vw, 42px); }
.hero-line2{ font-size: clamp(28px, 4.2vw, 56px); }

/* typewriter ancho reservado (evita saltos) */
.typewrap{
  display:inline-block;
  min-width:24ch; white-space:nowrap;
}
.typewrap::after{
  content:""; display:inline-block; width:.08em; height:1em; margin-left:.08em;
  background:currentColor; animation: blink 1s steps(1) infinite; vertical-align:-.12em;
}
@keyframes blink{ 50%{ opacity:0; } }

.hero-sub{
  margin-top:.6rem; color:#fff; font-size: clamp(16px, 1.6vw, 18px); font-weight:700;
}

/* Stats “glass” limpio (si usas tu fila negra, se ve bien igual) */
.glass-bar{
  background: rgba(0,0,0,.55);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  border-radius: 18px;
}

/* =========================
   6) Componentes varios
   ========================= */
.btn-primary{
  --bs-btn-color: var(--bs-black);
  --bs-btn-bg: var(--bs-orange);
  --bs-btn-border-color: var(--bs-orange);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--bs-black);
  --bs-btn-hover-border-color: var(--bs-black);
  --bs-btn-focus-shadow-rgb: 49,132,253;
  --bs-btn-active-bg: var(--bs-black);
}

/* Paginación */
.pagination{
  --bs-pagination-color: var(--bs-link-color);
  --bs-pagination-hover-color: var(--bs-link-hover-color);
  --bs-pagination-hover-bg: var(--bs-black);
  --bs-pagination-active-color: var(--bs-black);
  --bs-pagination-active-bg: #F5E9E9;
  --bs-pagination-active-border-color:#F5E9E9;
  display:flex; padding-left:0; list-style:none;
}
.page-link{ color: var(--bs-black); }
.page-link:hover{
  z-index:2; color: var(--bs-link-hover-color);
  background-color: var(--bs-black);
  border-color: var(--bs-black);
}
.active>.page-link, .page-link.active{
  z-index:3; color:var(--bs-black);
  background-color:#F5E9E9; border-color:#F5E9E9;
}

/* Testimonial */
.testimonial-card{ background:var(--bs-black); color:var(--bs-white); }
.testimonial-card .postd{ color:var(--bs-red); }

/* FAQs */
.accordion-item{ background: var(--bs-yellow); border-radius:12px; }
h5 button.accordion-button{
  font-family: var(--body-font);
  background: var(--bs-yellow);
  border-radius:12px;
}
.accordion-button:focus{ border:none; outline:0; box-shadow:none; }
.accordion-button:not(.collapsed){ background:none; box-shadow:none; }
.accordion-button::after{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1em' height='1em' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m12 13.171l4.95-4.95l1.414 1.415L12 16L5.636 9.636L7.05 8.222z'/%3E%3C/svg%3E");
}
.accordion-button:not(.collapsed)::after{ transform: rotate(180deg); }

/* =========================
   7) Responsivo fino
   ========================= */
@media (max-width: 992px){
  header + section,
  header + .hero-banner,
  header + .page-hero-wrap{ margin-top: var(--header-h-sm); }

  .banner{ min-height:56vh; }
}
@media (max-width: 576px){
  .banner{ min-height:58vh; padding: 1.75rem; }
  .cta-btn{ padding:10px 22px; font-size:13px; }
}
/* === BOTÓN HOT PINK DE SPOILED === */
.btn-spoiled {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  padding: 12px 28px;
  border: none;
  border-radius: 6px; /* esquinas suaves, no píldora */
  background: linear-gradient(90deg, #fe2977, #ff4ecb, #ff6ec7);
  color: #fff !important;
  text-decoration: none;
  display: inline-block;
  transition: all 0.3s ease;
  box-shadow: 0 6px 18px rgba(254, 41, 119, .35);
}

.btn-spoiled:hover {
  background: linear-gradient(90deg, #ff6ec7, #ff4ecb, #fe2977);
  transform: translateY(-2px);
  box-shadow: 0 10px 26px rgba(254, 41, 119, .45);
}
/* ========= LINK-IN-BIO • @holapixelatte ========= */

:root{
  --hotpink:#ff2f94;        /* tu hotpink */
  --ink:#111;               /* black base */
  --paper:#fff;             /* white base */
  --muted:#7a7a7a;          /* gris texto secundario */
  --radius:18px;            /* bordes redondeados */
  --shadow:0 10px 30px rgba(0,0,0,.15);
}

/* Wrapper */
.b-linktree{
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--paper);
  background: linear-gradient(120deg, #0e0e0f, #19191c, #0e0e0f);
  background-size: 200% 200%;
  animation: bgShift 10s ease-in-out infinite;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}

@keyframes bgShift{
  0%   { background-position: 0% 50% }
  50%  { background-position:100% 50% }
  100% { background-position: 0% 50% }
}

/* ===== HERO centrado con fondo ===== */
.b-hero{
  position: relative;
  padding: 40px 24px 96px;
  text-align: center;
  overflow: hidden;
  min-height: 220px;

  /* Fondo directo en el elemento (lee --hero-bg) */
  background-image: var(--hero-bg, none);
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
/* Capa oscura encima del fondo */
.b-hero::before{
  content:"";
  position:absolute; inset:0;
  background: rgba(0,0,0,.28);   /* puedes subir a .35 si quieres más contraste */
  z-index: 0;
}

/* Hotpink mist (decorativo) */
.b-hero::after{
  content:"";
  position:absolute; inset:-20%;
  background:
    radial-gradient(60% 50% at 15% 10%, rgba(255,47,148,.22), transparent 60%),
    radial-gradient(70% 60% at 90% 20%, rgba(255,47,148,.14), transparent 60%);
  z-index: 1;
}

/* Asegura contenido sobre los overlays */
.b-hero > *{ position:relative; z-index: 2; }


/* Títulos/paragraphs centrados */
.b-hero h3{ margin:0 0 6px; font-weight:800; letter-spacing:.4px; }
.b-hero a.handle{ color:#fff; text-decoration:none; }
.b-hero p{ margin:6px auto 0; color:#f1f1f1; line-height:1.45; max-width:680px; }
.b-hero .tags{ color:#e2e2e2; font-size:.96rem }
.b-hero .fam{ color:#ddd;   font-size:.95rem }

/* Avatar centrado */
.b-hero .avatar{
  position:absolute; left:50%; bottom:-46px;
  transform: translateX(-50%);
  width:92px; height:92px; border-radius:50%;
  background-image: var(--avatar-img, none);
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
  background-color:#ccc;   /* fallback */
  border:4px solid #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}

/* Body */
.b-body{ padding: 70px 18px 18px; background: #0b0b0c; }

/* Social round icons */
.b-social{ display:flex; gap:12px; flex-wrap:wrap; margin-bottom:14px; }
.b-social a{
  width:44px; aspect-ratio:1/1; border-radius:50%;
  display:grid; place-items:center; background:#1c1c1f; color:#fff;
  border:1px solid rgba(255,255,255,.08); text-decoration:none;
  transition: transform .15s ease, background .15s ease;
}
.b-social a:hover{ transform:translateY(-2px); background:#242428 }
.b-social svg{ width:20px; height:20px; fill:#fff }

/* Card generic */
.b-card{
  background:#111114; border:1px solid rgba(255,255,255,.07);
  border-radius:14px; padding:16px; margin:12px 0; color:#f5f5f5;
}
.b-card h4{ margin:0 0 8px; font-weight:800; letter-spacing:.3px; }
.muted{ color:var(--muted); font-size:.95rem }

/* CTA button */
.b-btn{
  display:inline-block; text-decoration:none; color:#111;
  background: var(--paper); border-radius:999px; padding:10px 16px; font-weight:800;
}
.b-btn--pink{
  background: var(--hotpink); color:#fff;
  box-shadow: 0 8px 24px rgba(255,47,148,.35);
}
.b-btn + .b-btn{ margin-left:8px }

/* COUNTDOWN */
.b-count{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px }
.b-k{
  background:#18181c; border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:10px 12px; min-width:84px; text-align:center
}
.b-k strong{ display:block; font-size:1.25rem }
.b-k span{ font-size:.72rem; color:#bdbdbd; text-transform:uppercase; letter-spacing:.6px }

/* Accordion projects */
.b-acc{ margin: 10px 0 }
.b-acc .item{
  border:1px solid rgba(255,255,255,.07); border-radius:14px; overflow:hidden;
  margin-bottom:10px; background:#111114
}
.b-acc .head{
  display:flex; align-items:center; gap:12px; width:100%;
  background:#141418; color:#fff; padding:14px 16px; cursor:pointer;
  border:none; text-align:left; font-weight:800;
}
.b-acc .head .dot{ width:10px; height:10px; border-radius:50%; background:var(--hotpink) }
.b-acc .head .chev{ margin-left:auto; transition: transform .18s ease }
.b-acc .panel{ display:none; padding:0 }
.b-acc .panel.open{ display:block; }
.b-acc .panel .inner{ padding:14px 16px 16px }
/* cover sin shorthand (para compat) */
.b-acc .cover{
  width:100%; aspect-ratio:16/9;
  background-color:#222;
  background-image:url('images/cover-placeholder.jpg'); /* cámbiala */
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
}
.b-acc .desc{ margin:10px 0 12px; color:#dcdcdc }
.b-acc .links a{
  display:inline-block; margin:6px 8px 0 0; padding:8px 12px; border-radius:999px;
  background:#1b1b1e; color:#fff; text-decoration:none; border:1px solid rgba(255,255,255,.08); font-weight:700
}
.b-acc .links a:hover{ background:#232327 }

/* Store list */
.b-store .links a{ background:#141418; }
.b-store .links a:hover{ background:#1d1d22 }

/* Contact form */
.b-form{ display:grid; gap:10px; margin-top:8px }
.b-form input, .b-form textarea{
  width:100%; background:#141418; color:#fff; border:1px solid rgba(255,255,255,.07);
  border-radius:12px; padding:12px 14px; outline:none;
}
.b-form textarea{ min-height:110px; resize:vertical }
.b-form button{
  background:var(--hotpink); color:#fff; border:none; border-radius:999px; padding:12px 18px; font-weight:800; cursor:pointer;
  box-shadow: 0 8px 24px rgba(255,47,148,.35);
}
.b-form button:hover{ filter:brightness(1.05) }

/* Small */
.b-footnote{ color:#a7a7a7; font-size:.82rem; margin-top:10px }

/* Motion safety */
@media (prefers-reduced-motion: reduce){
  .b-linktree{ animation: none; }
}
/* HERO: deja que el avatar “salga” y ponlo por encima del body */
.b-hero{
  overflow: visible;   /* antes: hidden */
  z-index: 1;          /* para que quede sobre el siguiente bloque */
}

/* Asegura que el avatar tenga prioridad máxima */
.b-hero .avatar{
  z-index: 5;          /* antes no tenía z-index */
}

/* El body queda debajo del hero en la pila de pintado */
.b-body{
  position: relative;
  z-index: 0;
}
/* Instagram grid */
.ig-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.ig-card{ position:relative; overflow:hidden; border-radius:16px; background:#111; aspect-ratio:1/1; }
.ig-card img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .25s ease; }
.ig-card:hover img{ transform:scale(1.04); }
@media (max-width:768px){ .ig-grid{ grid-template-columns:repeat(2,1fr); gap:10px; } }
/* COUNTER full-width */
.b-card{ width:100%; }                /* asegura ancho completo del card */
.b-count{
  display:grid;
  grid-template-columns: repeat(4, minmax(110px, 1fr)); /* 4 columnas iguales */
  gap:12px;
  margin-top:12px;
}
.b-k{
  min-width:0;                        /* quita el tope que lo hacía encoger */
  padding:14px 12px;
  background:#18181c;
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  text-align:center;
}
.b-k strong{ display:block; font-size:1.6rem; line-height:1; }
.b-k span{ font-size:.72rem; color:#bdbdbd; text-transform:uppercase; letter-spacing:.6px }

/* Responsive: en móvil 2 columnas */
@media (max-width: 640px){
  .b-count{ grid-template-columns: repeat(2, 1fr); }
}

/* Botones responsivos (opcional) */
@media (max-width: 480px){
  .b-btn{ width:100%; text-align:center; }
  .b-btn + .b-btn{ margin-left:0; margin-top:8px; }
}
/* Social icons centrados + más grandes */
.b-social{
  justify-content: center;            /* centra el grupo */
  gap: 14px;
  margin: 18px auto 16px;
}

.b-social a{
  width: 56px;                        /* antes 44px */
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: #16161a;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 8px 18px rgba(0,0,0,.25);
  transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}

.b-social svg{
  width: 24px;                        /* antes 20px */
  height: 24px;
  fill: #fff;
}

.b-social a:hover{
  transform: translateY(-2px);
  background: #1d1d22;
  box-shadow: 0 10px 24px rgba(255,47,148,.35); /* hotpink glow */
  border-color: rgba(255,255,255,.18);
}

/* Opcional: en pantallas muy pequeñas, separa un poco más */
@media (max-width: 420px){
  .b-social{ gap: 16px; }
}
/* Social interno del panel (dos iconos centrados) */
.p-social{
  display:flex; justify-content:center; gap:16px; margin:8px 0 10px;
}
.p-social a{
  width:52px; aspect-ratio:1/1; border-radius:50%;
  display:grid; place-items:center;
  background:#16161a; border:1px solid rgba(255,255,255,.12);
  box-shadow:0 8px 18px rgba(0,0,0,.25);
  transition: transform .15s ease, background .15s ease, box-shadow .15s ease;
}
.p-social svg{ width:24px; height:24px; fill:#fff }
.p-social a:hover{
  transform: translateY(-2px);
  background:#1d1d22;
  box-shadow:0 10px 24px rgba(255,47,148,.35);
  border-color:rgba(255,255,255,.18);
}
.carousel-wrapper {
  overflow-x: auto;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
}
.carousel {
  display: flex;
  gap: 20px;
}
.carousel-item {
  display: inline-block;
  width: 250px;
  text-align: center;
}
.carousel-item img {
  width: 100%;
  border-radius: 12px;
  margin-bottom: 10px;
}
.btn {
  margin-top: 10px;
}
.projects-wrap{position:relative}
.projects-track{
  display:flex; gap:24px; overflow-x:auto; scroll-behavior:smooth;
  padding:4px 8px; -webkit-overflow-scrolling:touch;
}
.project-card{
  flex:0 0 260px; text-align:center; background:#fff; border-radius:16px;
  padding:14px; box-shadow:0 6px 24px rgba(0,0,0,.08);
}
.project-card img{width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:12px; margin-bottom:10px}
.project-card h3{font-size:1.05rem; margin:.25rem 0 .5rem}
.project-card p{font-size:.95rem; color:#555; min-height:44px}
.btn.btn-spoiled{ /* reutiliza tu estilo de “LEE SPOILED”; o deja este como fallback */
  display:inline-block; padding:10px 16px; border-radius:999px; background:#ff4fa0; color:#fff; text-decoration:none; font-weight:700; box-shadow:0 6px 16px rgba(255,79,160,.35)
}
.proj-arrow{
  position:absolute; top:50%; transform:translateY(-50%); border:0; background:#fff; width:40px; height:40px;
  border-radius:999px; box-shadow:0 6px 18px rgba(0,0,0,.12); cursor:pointer; font-size:26px; line-height:40px
}
.proj-arrow.left{left:-6px} .proj-arrow.right{right:-6px}
@media (max-width:768px){ .project-card{flex-basis:72vw} .proj-arrow{display:none} }

.projects-track{
  display:flex; gap:24px;
  overflow-x:auto;              /* ← vuelve a permitir scroll */
  scroll-behavior:smooth;
  padding:4px 8px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;         /* Firefox: oculta la barra */
  -ms-overflow-style:none;      /* IE/Edge legacy */
}
.projects-track::-webkit-scrollbar{ display:none; } /* Chrome/Safari/Edge */
.blog-preview .container{max-width:1100px;margin:auto;padding:0 20px}
.blog-preview .section-title{margin:0 0 24px}

.post-card{
  display:flex; gap:24px; align-items:stretch;
  width:100%; background:#fff; padding:24px; border-radius:16px;
  box-shadow:0 4px 24px rgba(0,0,0,.06); margin:0 0 24px
}
.post-thumb{flex:0 0 320px; display:block; border-radius:12px; overflow:hidden; aspect-ratio:16/9}
.post-thumb img{width:100%; height:100%; object-fit:cover; display:block}

.post-content{flex:1; display:flex; flex-direction:column}
.post-content .meta{font-size:.85rem; letter-spacing:.06em; color:#8c8c8c; text-transform:uppercase; margin-bottom:8px}
.post-content .title{margin:0 0 10px; line-height:1.2}
.post-content .excerpt{margin:0 0 16px; color:#333}

.blog-actions{display:flex; justify-content:center; margin-top:8px}

/* usa tu clase real del botón rosa; si no, estas son seguras */
.btn-pink{
  display:inline-block; padding:12px 20px; border-radius:999px;
  background:linear-gradient(180deg,#ff58b1,#ff2f86);
  color:#fff; font-weight:700; box-shadow:0 10px 18px rgba(255,47,134,.25)
}
.btn-pink:hover{transform:translateY(-1px)}
.btn-outline{
  display:inline-block; padding:12px 20px; border-radius:999px; border:2px solid #ff2f86;
  color:#ff2f86; font-weight:700; background:#fff
}

@media (max-width: 900px){
  .post-card{flex-direction:column}
  .post-thumb{flex:0 0 auto; width:100%}
}
.post-grid{
  display:grid; gap:28px;
  grid-template-columns: 320px minmax(0,1fr);
}
@media (max-width: 992px){
  .post-grid{ grid-template-columns: 1fr; }
  .sidebar{ order:2; }
}
.sidebar{ position:sticky; top:96px; height:max-content; }
.widget{
  background:#fff; border-radius:16px; padding:16px; margin-bottom:16px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.widget-title{ text-transform:uppercase; font-weight:800; font-size:.85rem; letter-spacing:.06em; margin-bottom:8px }
.widget.banner img{ width:100%; border-radius:12px; display:block }

/* Hero: mostrar la imagen COMPLETA, sin recortes y con altura correcta */
.post-hero{
  margin: 0 0 16px;
  border-radius: 16px;
  overflow: hidden;         /* bordes redondeados */
}

.post-hero img{
  display: block;
  width: 100%;
  height: auto;             /* clave: respeta 1920x600 = 16:5 */
  /* sin object-fit aquí; no lo necesitamos si height es auto */
}

.post-title{ line-height:1.15; margin:4px 0 6px }
.post-meta{ color:#8c8c8c; font-size:.9rem; text-transform:uppercase; letter-spacing:.06em; margin-bottom:14px }
.post-content p{ margin:0 0 1rem; line-height:1.75 }
.post-cta{ margin-top:20px; padding:18px; border:2px dashed #ffe0ef; border-radius:14px; background:#fff5fa }
.post-nav{ margin-top:16px }
.btn-outline{
  display:inline-block; padding:10px 16px; border-radius:999px; border:2px solid #ff2f86;
  color:#ff2f86; font-weight:700; background:#fff; text-decoration:none;
}
<!-- ====== ESTILOS LOCALES DEL POST ====== -->

  /* Grid 2 columnas y alineación superior */
  .post-grid{
    display:grid;
    gap:28px;
    grid-template-columns: 320px minmax(0,1fr);
    align-items:start;                 /* <— clave: alinea sidebar y contenido */
  }
  @media (max-width: 992px){
    .post-grid{ grid-template-columns: 1fr; }
  }

  /* Sidebar sticky sin tapar el header fijo */
  .sidebar{
    position: sticky;
    top:110px;                         /* igual que el padding-top del <main> */
    height:max-content;
    align-self:start;
  }
  @media (max-width: 992px){
    .sidebar{ position: static; }
  }

  .widget{
    background:#fff;
    border-radius:16px;
    padding:16px;
    margin-bottom:16px;
    box-shadow:0 8px 24px rgba(0,0,0,.06);
  }
  .widget-title{
    text-transform:uppercase;
    font-weight:800;
    font-size:.85rem;
    letter-spacing:.06em;
    margin-bottom:8px;
  }
  .widget.banner img{ width:100%; border-radius:12px; display:block }

  /* Hero: mostrar imagen COMPLETA (1920x600) sin recortes */
  .post-hero{
    margin:0 0 16px;
    border-radius:16px;
    overflow:hidden;
  }
  .post-hero img{
    display:block;
    width:100%;
    height:auto;                        /* respeta 1920x600 */
    object-fit:contain;                 /* evita recortes si alguna regla pone altura */
    object-position:center center;
  }

  .post-title{ line-height:1.15; margin:4px 0 6px }
  .post-meta{
    color:#8c8c8c; font-size:.9rem; text-transform:uppercase;
    letter-spacing:.06em; margin-bottom:14px
  }
  .post-content p{ margin:0 0 1rem; line-height:1.75 }
  .post-cta{
    margin-top:20px; padding:18px; border:2px dashed #ffe0ef;
    border-radius:14px; background:#fff5fa
  }
  .post-nav{ margin-top:16px }
  .btn-outline{
    display:inline-block; padding:10px 16px; border-radius:999px; border:2px solid #ff2f86;
    color:#ff2f86; font-weight:700; background:#fff; text-decoration:none;
  }

.linktree-mini{ padding:16px; }
.linktree-mini .lt-hero{
  text-align:center;
  margin-bottom:10px;
}
.linktree-mini .lt-avatar{
  width:72px; height:72px; border-radius:50%;
  margin:0 auto 8px;
  background-image:var(--avatar);
  background-size:cover; background-position:center;
  box-shadow:0 0 0 3px #fff, 0 4px 18px rgba(0,0,0,.12);
}
.linktree-mini .lt-tagline{ color:#818181; font-size:.9rem; }

.linktree-mini .lt-links{ display:flex; flex-direction:column; gap:8px; margin:10px 0 12px; }
.linktree-mini .lt-btn{
  display:block; width:100%; text-align:center;
  padding:10px 14px; border-radius:999px; font-weight:700;
  text-decoration:none; background:#f5f5f7; color:#111;
  border:2px solid transparent;
}
.linktree-mini .lt-btn:hover{ background:#fff; border-color:#ffd1e6; }

.linktree-mini .lt-btn--pink{ background:#ff2f86; color:#fff; }
.linktree-mini .lt-btn--pink:hover{ filter:brightness(1.05); }

.linktree-mini .lt-social{
  display:flex; justify-content:center; gap:10px;
}
.linktree-mini .lt-social a{
  width:34px; height:34px; display:grid; place-items:center;
  border-radius:50%; background:#111; color:#fff; text-decoration:none;
}
.linktree-mini .lt-social svg{ width:18px; height:18px; fill:#fff; }