@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
/* Boscà Imprès - estilo replicando el mockup */
 .bi-root { font-family: 'Inter', system-ui, -apple-system, sans-serif; color:#222; background:#fff; }
.bi-root * { box-sizing: border-box; }
/* === Header === */
.header { background: var(--brand-blue); color: #fff; }
.nav-main {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.5rem;
}
.logo {
  font-weight: 800; letter-spacing: -0.02em; color: #fff;
  font-size: 1.75rem;
}
.logo .italic { font-style: italic; }
.logo sup { color: var(--brand-pink); font-size: 1.5rem; }
.logo.small { font-size: 1.25rem; }

.nav-links { display: none; gap: 2rem; font-weight: 500; }
.nav-links a { transition: opacity .15s; }
.nav-links a:hover { opacity: .8; }
.nav-links a.active { text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px; }

.nav-cta { display: flex; align-items: center; gap: .75rem; }
.wa {
  width: 36px; height: 36px; border-radius: 9999px;
  background: var(--brand-whatsapp);
  display: inline-flex; align-items: center; justify-content: center; color: #fff;
}
.btn-pink {
  background: var(--brand-pink); color: #fff;
  padding: .5rem 1rem; border-radius: .375rem;
  font-size: .875rem; font-weight: 600;
  transition: opacity .15s;
}
.btn-pink:hover { opacity: .9; }
.btn-pink.small { padding: .375rem 1rem; display: inline-block; }

.subnav { background: var(--brand-blue-light); }
.subnav-inner {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 2rem; padding: .75rem 1.5rem;
  color: #fff; font-weight: 500;
}
.subnav-inner a.active { text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px; }
.subnav-inner .plus { font-size: 1.25rem; line-height: 1; }

@media (min-width: 768px) {
  .nav-links { display: flex; }
}

/* NAV */
.bi-nav { background:#0f1f5c; color:#fff; }
.bi-nav-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; padding:14px 24px; }
.bi-logo { display:flex; align-items:center; gap:2px; font-weight:700; }
.bi-logo-dot { width:10px; height:10px; border-radius:50%; display:inline-block; }
.bi-d1{background:#ff3ea5;} .bi-d2{background:#ffd400;} .bi-d3{background:#00c2ff;} .bi-d4{background:#1a1a1a;}
.bi-logo-text { margin-left:8px; font-size:22px; font-style:italic; letter-spacing:.5px;  height: 30px; }
.bi-mainnav { display:flex; gap:28px; }
.bi-link { color:#fff; text-decoration:none; font-size:15px; }
.bi-link-active { color:#ffb84d; }
.bi-cta-wsp { background:#ff3ea5; color:#fff; padding:8px 16px; border-radius:20px; text-decoration:none; font-weight:600; font-size:14px; display:inline-flex; align-items:center; gap:8px; }
.bi-wsp-icon { background:#25d366; color:#fff; width:18px; height:18px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:10px; }

.bi-subnav { background:#22c0e8; }
.bi-subnav-inner { max-width:1200px; margin:0 auto; display:flex; gap:28px; justify-content:center; padding:8px 24px; }
.bi-sublink { color:#fff; text-decoration:none; font-size:14px; }
.bi-sublink-active { color:#F53D8A; font-weight:700;}
.bi-plus { font-weight:700; }                /* FOOTER */
.bi-footer { background:#0f1f5c; color:#fff; }
.bi-footer-grid { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1.2fr 1fr 1fr 1fr 1fr; gap:24px; padding:0 0 0 0; }
.bi-footer-img img { width:100%; height:100%; object-fit:cover; display:block; min-height:280px; }
.bi-footer-col { padding:30px 10px; }
.bi-footer-col h4 { color:#fff; font-size:14px; letter-spacing:1px; margin:0 0 14px; font-weight:700; }
.bi-footer-col ul { list-style:none; padding:0; margin:0; }
.bi-footer-col li { font-size:13.5px; color:#cfd5e8; padding:3px 0; }
.bi-footer a{ color:#fff; text-decoration:none;}
.bi-footer a:hover{ color:#ccc; }
.bi-div-footer-bottom{background:#22c0e8; padding:14px 24px; max-width:100%;}
.bi-footer-bottom { max-width:1200px;  display:flex; align-items:center; justify-content:space-between; margin:auto; }
.bi-footer-bottom p { margin:0; font-size:12px; color:#0f1f5c; }
.bi-logo-foot .bi-logo-text { color:#fff; }

@media (max-width: 900px) {
  .bi-services-grid { grid-template-columns:1fr 1fr; }
  .bi-testi-wrap, .bi-contact-grid { grid-template-columns:1fr; }
  .bi-footer-grid { grid-template-columns:1fr 1fr; }
  .bi-mainnav { display:none; }
  .bi-hero-title { font-size:30px; }
}
@media (max-width: 560px) {
  .bi-services-grid { grid-template-columns:1fr; }
  .bi-footer-grid { grid-template-columns:1fr; }


}


/* === Header === */
.header { background: var(--brand-blue); color: #fff; }
.nav-main {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.5rem;
}
.logo {
  font-weight: 800; letter-spacing: -0.02em; color: #fff;
  font-size: 1.75rem;
}
.logo .italic { font-style: italic; }
.logo sup { color: var(--brand-pink); font-size: 1.5rem; }
.logo.small { font-size: 1.25rem; }

.nav-links { display: none; gap: 2rem; font-weight: 500; }
.nav-links a { transition: opacity .15s; }
.nav-links a:hover { opacity: .8; }
.nav-links a.active { text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px; }

.nav-cta { display: flex; align-items: center; gap: .75rem; }
.wa {
  width: 36px; height: 36px; border-radius: 9999px;
  background: var(--brand-whatsapp);
  display: inline-flex; align-items: center; justify-content: center; color: #fff;
}
.btn-pink {
  background: var(--brand-pink); color: #fff;
  padding: .5rem 1rem; border-radius: .375rem;
  font-size: .875rem; font-weight: 600;
  transition: opacity .15s;
}
.btn-pink:hover { opacity: .9; }
.btn-pink.small { padding: .375rem 1rem; display: inline-block; }

.subnav { background: var(--brand-blue-light); }
.subnav-inner {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 2rem; padding: .75rem 1.5rem;
  color: #fff; font-weight: 500;
}
.subnav-inner a.active { text-decoration: underline; text-underline-offset: 4px; text-decoration-thickness: 2px; }
.subnav-inner .plus { font-size: 1.25rem; line-height: 1; }

@media (min-width: 768px) {
  .nav-links { display: flex; }
}


/* === Footer === */
.footer { background: var(--brand-blue); color: #fff; }
.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  padding-top: 3.5rem; padding-bottom: 3.5rem;
}
.footer-img img {
  width: 100%; height: 100%; object-fit: cover; border-radius: .375rem;
  min-height: 180px;
}
.footer h4 { font-weight: 700; letter-spacing: .04em; margin-bottom: 1rem; }
.footer ul li { font-size: .875rem; margin-bottom: .5rem; }
.footer ul li.pt { padding-top: .5rem; }
.underline { text-decoration: underline; }

.footer-bottom { background: var(--brand-blue-light); }
.footer-bottom-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.5rem;
  color: #fff; font-size: .875rem;
}
.footer-bottom-inner .spacer { width: 96px; }

@media (min-width: 768px) {
  .footer-grid { grid-template-columns: repeat(5, 1fr); }
}

/* HAMBURGER */
.bi-burger { display:none; background:transparent; border:0; cursor:pointer; padding:8px; flex-direction:column; gap:5px; }
.bi-burger span { display:block; width:26px; height:3px; background:#fff; border-radius:2px; transition:.25s; }
.bi-burger.open span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
.bi-burger.open span:nth-child(2){ opacity:0; }
.bi-burger.open span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }

@media (max-width: 900px) {
  .bi-nav-inner { flex-wrap:wrap; }
  .bi-burger { display:flex; order:3; margin-left:auto; }
  .bi-cta-wsp { order:2; }
  .bi-mainnav { display:none; flex-direction:column; width:100%; order:4; padding:10px 0; gap:0; }
  .bi-mainnav.open { display:flex; }
  .bi-mainnav .bi-link { padding:10px 4px; border-bottom:1px solid rgba(255,255,255,.1); }

  .bi-subnav { display:none; }
  .bi-subnav.open { display:block; }
  .bi-subnav-inner { flex-direction:column; gap:0; padding:6px 24px; }
  .bi-subnav-inner .bi-sublink { padding:10px 0; border-bottom:1px solid rgba(255,255,255,.2); width:100%; }
}
