:root{
  --celeste:#99cfe0;
  --celeste-dark:#8fc4d6;
  --azul:#202f80;
  --azul-claro:#4559b8;
  --texto:#071241;
  --gris:#f6f6f6;
  --max:1180px;
}

.page-title {
  margin: 0 0 28px;
  color: #4055bd;
  font-family: "Georgia", "Times New Roman", serif;
  font-size: clamp(42px, 5.2vw, 72px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 8px;
  transform: scaleX(1.08);

  -webkit-text-stroke: 1px #4055bd;

  text-shadow:
    1px 0 0 #4055bd,
    -1px 0 0 #4055bd,
    0 1px 0 #4055bd,
    0 -1px 0 #4055bd,
    1px 1px 0 #ffffff,
    2px 2px 0 rgba(30, 45, 140, .45);
}


*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Trebuchet MS", Arial, sans-serif;
  color:var(--texto);
  background:#fff;
  line-height:1.45;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(var(--max),92%);margin-inline:auto}

/* HEADER COMPARTIDO */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  background:var(--celeste);
  box-shadow:0 1px 0 rgba(0,0,0,.05);
}
.navbar{
  min-height:96px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:44px;
}
.logo-link{flex:0 0 auto}
.logo{width:142px;height:auto}
.menu{display:flex;align-items:center;gap:0;list-style:none;margin:0;padding:0}
.menu a{
  display:block;
  padding:18px 16px;
  text-transform:uppercase;
  font-size:14px;
  color:#0d1a58;
  white-space:nowrap;
}
.menu a:hover,.menu a.active{background:var(--azul-claro);color:#fff}
.menu-toggle{display:none;margin-left:auto;border:0;background:var(--azul-claro);color:#fff;padding:10px 13px;font-size:24px;cursor:pointer}

/* HERO HOME */
.hero-slider{
  position:relative;
  min-height:calc(100vh - 96px);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  background:#f8f8f8;
}
.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  transition:opacity .7s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:40px 20px;
  background:
    radial-gradient(circle at center, rgba(0,0,0,.72) 0 2px, transparent 3px) 0 0/18px 18px,
    radial-gradient(circle at center, rgba(0,0,0,.28) 0 1px, transparent 4px) 9px 9px/18px 18px,
    #fbfbfb;
}
.hero-slide::after{content:"";position:absolute;inset:0;background:rgba(255,255,255,.25)}
.hero-slide.active{opacity:1}
.hero-content{position:relative;z-index:1;width:min(950px,100%);min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:space-between}
.hero-logo{width:min(345px,70vw);margin-top:4vh;filter:drop-shadow(0 2px 1px rgba(0,0,0,.15))}
.hero-caption{display:inline-block;padding:7px 18px 8px;font-size:25px;color:#fff;background:rgba(32,47,128,.62);text-shadow:0 1px 2px rgba(0,0,0,.35)}
.hero-btn{display:block;width:max-content;margin:6px auto 0;padding:5px 15px;background:var(--azul-claro);color:#fff;font-size:11px;text-transform:uppercase;border-radius:1px}
.slider-arrow{position:absolute;z-index:4;top:50%;transform:translateY(-50%);width:30px;height:30px;border-radius:50%;border:0;background:rgba(0,0,0,.45);color:white;font-size:26px;line-height:26px;cursor:pointer}
.slider-arrow.prev{left:16px}.slider-arrow.next{right:16px}

/* HOME */
.features{width:min(1200px,92%);margin:16px auto 72px;display:grid;grid-template-columns:repeat(3,1fr);gap:58px;text-align:center}
.feature-icon{color:var(--azul-claro);font-size:36px;line-height:1;min-height:46px;font-weight:bold}
.feature h3{font-size:17px;margin:6px 0 8px;font-weight:400;color:#222}.feature p{font-size:13px;color:#222;margin:0}
.content-narrow{width:min(1200px,92%);margin:0 auto}.section-title{font-weight:400;color:var(--azul-claro);text-align:center;font-size:28px;margin:0 0 12px}.intro p{font-size:13.5px;margin:0 0 14px}.intro a{color:var(--azul-claro)}.shop-img{margin:14px auto 20px;width:100%;max-width:740px}.two-col{display:grid;grid-template-columns:315px 1fr;gap:22px;align-items:start;margin:18px 0 82px}.two-col .section-title{text-align:left;margin-top:10px}.two-col p{font-size:13px;margin:0}.gallery-block{text-align:center;margin-bottom:76px}.gallery-block .lead{font-size:21px;line-height:1.2;margin:8px 0 22px;color:#111}.cake-slider{position:relative;width:min(570px,100%);margin:0 auto}.cake-frame{border:6px solid #eee;overflow:hidden;background:#eee}.cake-track{display:flex;transition:transform .45s ease}.cake-track img{min-width:100%;height:auto}.cake-dots{display:flex;justify-content:center;gap:8px;margin-top:14px}.cake-dots button{width:6px;height:6px;border-radius:50%;border:0;background:#111;opacity:.35;padding:0;cursor:pointer}.cake-dots button.active{opacity:1}

/* PÁGINAS INTERNAS */
.page-main{padding:54px 0 90px}.page-title{font-size:44px;line-height:1.05;color:var(--azul-claro);font-weight:400;letter-spacing:2px;margin:0 0 24px}.page-lead{font-size:36px;line-height:1.1;margin:0 0 18px;color:#000;font-weight:400}.page-copy{max-width:1120px;font-size:18px;color:#000}.page-copy p{margin:0 0 16px}.page-copy a{color:var(--azul-claro)}.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:70px;margin-top:70px}.product-card{min-height:220px}.product-meta{color:var(--azul-claro);font-size:20px;margin-bottom:-5px}.product-name{color:var(--azul-claro);font-size:24px;line-height:1.05;min-height:56px;margin-left:165px}.product-placeholder{height:105px}.product-btn{display:flex;align-items:center;justify-content:center;width:100%;height:42px;background:var(--azul-claro);color:#fff;font-size:18px}.product-btn::before{content:"▾";font-size:18px;margin-right:8px}

/* FOOTER COMPARTIDO */
.site-footer{margin-top:30px}.footer-top{background:var(--celeste);padding:22px 0 8px;color:#06124a}.footer-top-inner{width:min(var(--max),92%);margin:auto;display:grid;grid-template-columns:1.55fr .75fr .75fr;gap:35px;align-items:start;text-align:center}.thanks h2,.likes h2,.follow h2{font-size:28px;color:#06124a;margin:0 0 8px;font-weight:400}.quote{font-size:15px;margin:0 auto;max-width:580px}.quote em{display:block;margin-top:1px;font-style:italic}.quote-row{display:flex;align-items:center;justify-content:center;gap:25px}.quote-arrow{font-size:25px;opacity:.4}.socials{display:flex;justify-content:center;gap:28px;color:var(--azul-claro);font-size:31px;line-height:1;margin-top:4px}.qr{display:inline-flex;border:1px solid rgba(0,0,0,.35);width:52px;height:78px;align-items:center;justify-content:center;font-weight:bold;font-size:28px;letter-spacing:1px;line-height:.86}.footer-main{background:var(--azul);color:#fff;padding:44px 0 55px}.footer-grid{width:min(1110px,92%);margin:auto;display:grid;grid-template-columns:repeat(4,1fr);gap:60px}.footer-col h3{font-size:25px;color:var(--celeste);font-weight:400;margin:0 0 26px}.footer-col a,.footer-col p{display:block;color:var(--celeste);font-size:15px;margin:0 0 30px}.footer-col p.white{color:#fff;line-height:1.45;margin-bottom:16px}.footer-col .line{border-top:1px solid #fff;margin:12px 0 16px}.contact-line{display:flex;gap:10px;color:#fff;margin-bottom:24px;align-items:flex-start}.contact-line span:first-child{color:var(--celeste)}

@media (max-width:1000px){
  .navbar{justify-content:flex-start;gap:20px}.menu-toggle{display:block}.menu{display:none;position:absolute;top:96px;left:0;right:0;background:var(--celeste);flex-direction:column;align-items:stretch;border-top:1px solid rgba(0,0,0,.08)}.menu.open{display:flex}.menu a{text-align:center;padding:14px}.features{grid-template-columns:1fr;gap:28px;margin-bottom:52px}.two-col{grid-template-columns:1fr}.two-col .section-title{text-align:center}.footer-top-inner{grid-template-columns:1fr;gap:20px}.footer-grid{grid-template-columns:1fr 1fr;gap:35px}.products-grid{grid-template-columns:1fr 1fr;gap:40px}.page-lead{font-size:30px}.page-title{font-size:38px}
}
@media (max-width:620px){
  .navbar{min-height:78px}.logo{width:112px}.menu{top:78px}.hero-slider{min-height:calc(100vh - 78px)}.hero-content{min-height:62vh}.hero-caption{font-size:19px}.slider-arrow{display:none}.section-title{font-size:24px}.gallery-block .lead{font-size:18px}.footer-grid{grid-template-columns:1fr}.page-main{padding-top:38px}.page-title{font-size:32px}.page-lead{font-size:25px}.page-copy{font-size:16px}.products-grid{grid-template-columns:1fr;gap:28px}.product-name{margin-left:120px}.footer-main{padding:34px 0}
}




/* =========================
   PÁGINA TARTAS
========================= */

.cakes-page {
  padding-top: 54px;
  padding-bottom: 90px;
}

.cakes-page .page-title {
  margin-bottom: 28px;
}

.cakes-page .page-lead {
  margin-bottom: 18px;
  max-width: 1160px;
}

.cakes-page .page-copy {
  max-width: 1220px;
}



.cake-categories {
  margin: 105px auto 0;
  max-width: 1160px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px 32px;
  align-items: start;
}

.cake-category {
  min-width: 0;
}

.cake-img-box {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid #d4d4d4;
  border-radius: 4px;
  background: #fff;
  overflow: hidden;
  text-decoration: none;
}

.cake-img-box > img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform .35s ease;
}

.cake-hover-logo {
  position: absolute;
  inset: auto 0 0 0;
  height: 58px;
  background: rgba(0, 0, 0, .72);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(100%);
  transition: opacity .28s ease, transform .28s ease;
}

.cake-hover-logo img {
  width: 92px;
  height: auto;
  display: block;
}

.cake-img-box:hover > img {
  transform: scale(1.04);
}

.cake-img-box:hover .cake-hover-logo {
  opacity: 1;
  transform: translateY(0);
}

.cake-category h3 {
  margin: 16px 0 0;
  font-size: 26px;
  font-weight: 400;
  line-height: 1.2;
}

.cake-category h3 a {
  color: #4055bd;
  text-decoration: none;
}

.cake-category h3 a:hover {
  text-decoration: underline;
}

.cake-category-centered {
  grid-column: 2 / span 2;
  max-width: 280px;
  justify-self: center;
}


@media (max-width: 1100px) {
  .cake-categories {
    grid-template-columns: repeat(3, 1fr);
  }

  .cake-category-centered {
    grid-column: auto;
    max-width: none;
    justify-self: stretch;
  }
}

@media (max-width: 780px) {
  .cake-categories {
    margin-top: 60px;
    grid-template-columns: repeat(2, 1fr);
    gap: 26px 22px;
  }

  .cake-category h3 {
    font-size: 22px;
  }
}

@media (max-width: 520px) {
  .cake-categories {
    grid-template-columns: 1fr;
  }

  .cake-category h3 {
    font-size: 24px;
  }
}







.products-grid .cake-img-box {
  margin: 28px 0 0;
  width: 100%;
  aspect-ratio: 1.55 / 1;
  border: 0;
  border-radius: 0;
}

.products-grid .cake-img-box > img {
  object-fit: cover;
}

.products-grid .cake-hover-logo {
  height: 48px;
}

.products-grid .cake-hover-logo img {
  width: 78px;
}




/* =========================
   DETALLE PRODUCTO
========================= */

.product-detail-page {
  padding-top: 72px;
  padding-bottom: 90px;
}

.product-detail {
  max-width: 1210px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 470px 1fr;
  column-gap: 48px;
  align-items: start;
}

.product-gallery {
  width: 100%;
}

.product-main-photo {
  width: 100%;
  height: 360px;
  border: 1px solid #d8d8d8;
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
}

.product-main-photo img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.product-thumbs {
  margin-top: 58px;
  display: flex;
  justify-content: center;
  gap: 42px;
}

.product-thumb {
  width: 44px;
  height: 60px;
  padding: 0;
  border: 2px solid #4055bd;
  background: #fff;
  cursor: pointer;
  overflow: hidden;
}

.product-thumb:nth-child(2) {
  border-color: #0082bd;
}

.product-thumb:nth-child(3) {
  margin-left: -38px;
  border-color: #5f6b7a;
}

.product-thumb.active {
  outline: 2px solid #4055bd;
  outline-offset: 3px;
}

.product-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.product-info {
  text-align: center;
}

.product-detail .page-title {
  margin-top: -12px;
  margin-bottom: 28px;
  white-space: nowrap;
}

.product-comments-status {
  margin: 0;
  color: #000;
  font-size: 21px;
  line-height: 1.3;
}

.product-comments {
  max-width: 1210px;
  margin: 250px auto 0;
  border-bottom: 1px solid #d2d2d2;
}

.product-comments h2 {
  width: 300px;
  margin: 0;
  padding: 0 0 24px 35px;
  border-bottom: 2px solid #4055bd;
  color: #4055bd;
  font-size: 20px;
  font-weight: 400;
}

/* Responsive */

@media (max-width: 1000px) {
  .product-detail {
    grid-template-columns: 1fr;
    row-gap: 48px;
  }

  .product-detail .page-title {
    white-space: normal;
  }

  .product-comments {
    margin-top: 90px;
  }
}

@media (max-width: 600px) {
  .product-detail-page {
    padding-top: 42px;
  }

  .product-main-photo {
    height: 260px;
  }

  .product-thumbs {
    margin-top: 28px;
    gap: 14px;
  }

  .product-thumb:nth-child(3) {
    margin-left: 0;
  }

  .product-comments h2 {
    width: 100%;
    padding-left: 0;
  }
}



.pastry-categories {
  grid-template-columns: repeat(3, 1fr);
  max-width: 980px;
  gap: 70px 44px;
}

.pastry-categories .cake-category-centered {
  grid-column: auto;
  max-width: none;
  justify-self: stretch;
}

@media (max-width: 900px) {
  .pastry-categories {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 520px) {
  .pastry-categories {
    grid-template-columns: 1fr;
  }
}
