/* =========================
   Grupo Kaisō - Layout inspirado en referencia
   ========================= */
:root{
  --gold:#D4AF37;
  --black:#0A0A0A;
  --black2:#141414;
  --white:#FFFFFF;
  --muted:#BDBDBD;
  --line:rgba(255,255,255,0.08);
  --shadow:0 18px 40px rgba(0,0,0,0.45);
  --t:all .35s ease;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--black);
  color:var(--white);
  font-family:'Montserrat',sans-serif;
  line-height:1.6;
}
a{color:inherit}
.container{width:90%;max-width:1200px;margin:0 auto}
.gold-text{color:var(--gold)}
.muted{color:var(--muted)}
.small{font-size:.9rem}

/* HEADER */
.main-header{
  background:rgba(0,0,0,0.92);
  border-bottom:2px solid var(--gold);
  padding:18px 0;
  position:fixed;top:0;left:0;right:0;
  z-index:999;
  backdrop-filter: blur(10px);
}
.header-flex{display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo{
  font-family:'Cinzel',serif;
  font-size:1.75rem;
  letter-spacing:2px;
  text-decoration:none;
  white-space:nowrap;
}
.main-nav ul{list-style:none;display:flex;gap:22px;align-items:center}
.main-nav a{
  text-decoration:none;
  font-weight:700;
  text-transform:uppercase;
  font-size:.82rem;
  letter-spacing:.5px;
  opacity:.92;
  transition:var(--t);
}
.main-nav a:hover{color:var(--gold);opacity:1}

.btn-delivery{
  background:var(--gold);
  color:#000 !important;
  padding:10px 18px;
  border-radius:6px;
  display:inline-block;
  text-decoration:none;
  font-weight:900;
  box-shadow: var(--shadow);
  transition:var(--t);
}
.btn-delivery:hover{transform:translateY(-2px);filter:brightness(1.05)}

.menu-toggle{
  display:none;
  width:44px;height:44px;
  border:1px solid rgba(255,255,255,0.12);
  background:transparent;
  position:relative;
}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{
  content:"";
  position:absolute;
  left:50%;
  width:22px;height:2px;
  background:#fff;
  transform:translateX(-50%);
  transition:var(--t);
}
.menu-toggle span{top:50%;transform:translate(-50%,-50%)}
.menu-toggle span::before{top:-7px}
.menu-toggle span::after{top:7px}
.menu-toggle.is-open span{background:transparent}
.menu-toggle.is-open span::before{top:0;transform:translateX(-50%) rotate(45deg)}
.menu-toggle.is-open span::after{top:0;transform:translateX(-50%) rotate(-45deg)}

/* HERO */
.hero-premium{
  min-height:92vh;
  position:relative;
  padding-top:96px;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background:url('bg-kaiso.jpg') center/cover no-repeat;
  filter: blur(10px) saturate(.75) contrast(1.05) brightness(.52);
  transform: scale(1.08);
}
.hero-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(60% 60% at 35% 30%, rgba(212,175,55,0.18), transparent 60%),
    linear-gradient(rgba(0,0,0,0.35), rgba(0,0,0,0.86));
}
.hero-grid{
  position:relative; z-index:2;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:26px;
  align-items:center;
}
.kicker{
  display:inline-block;
  color:var(--gold);
  letter-spacing:2px;
  text-transform:uppercase;
  font-size:.78rem;
  font-weight:800;
  margin-bottom:10px;
}
.hero-left h1{
  font-family:'Cinzel',serif;
  font-size:3.3rem;
  letter-spacing:1px;
  margin-bottom:10px;
}
.hero-left p{
  color:rgba(255,255,255,0.86);
  max-width:720px;
  margin-bottom:18px;
}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.btn-outline{
  border:1px solid var(--gold);
  color:var(--white);
  padding:12px 16px;
  text-decoration:none;
  font-weight:900;
  letter-spacing:.5px;
  text-transform:uppercase;
  border-radius:6px;
  transition:var(--t);
}
.btn-outline:hover{background:rgba(212,175,55,0.12);transform:translateY(-2px)}
.btn-ghost{
  border:1px solid rgba(255,255,255,0.18);
  background:rgba(0,0,0,0.25);
  color:rgba(255,255,255,0.92);
  padding:12px 16px;
  text-decoration:none;
  font-weight:800;
  border-radius:6px;
  transition:var(--t);
}
.btn-ghost:hover{border-color:rgba(212,175,55,0.55);transform:translateY(-2px)}

.hero-badges{display:flex;gap:10px;flex-wrap:wrap}
.badge{
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.32);
  padding:8px 12px;
  border-radius:999px;
  font-size:.82rem;
  color:rgba(255,255,255,0.88);
  backdrop-filter: blur(8px);
}

.hero-card{
  border:1px solid rgba(212,175,55,0.30);
  background:rgba(20,20,20,0.58);
  box-shadow:var(--shadow);
  padding:22px;
  border-radius:14px;
}
.hero-card h3{
  font-family:'Cinzel',serif;
  font-size:1.25rem;
  margin-bottom:8px;
}
.hero-card-ctas{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.btn-block{width:100%;text-align:center}

/* SECTIONS */
.section{padding:110px 0}
.section-dark{background:var(--black2)}
.section-black{background:#050505}
.top-label{
  color:var(--gold);
  letter-spacing:4px;
  text-transform:uppercase;
  font-size:.78rem;
  font-weight:900;
}
.section h2{
  font-family:'Cinzel',serif;
  font-size:2.6rem;
  margin:10px 0 10px;
}
.section-headline p{max-width:880px}
.section-split{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:26px;
  align-items:start;
}

.media-card{
  border:1px solid var(--line);
  background:rgba(255,255,255,0.02);
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.media-card img{width:100%;display:block}
.caption{padding:12px 14px;color:rgba(255,255,255,0.70);font-size:.88rem}

.feature-list{margin-top:18px;display:grid;gap:12px}
.feature{
  border:1px solid var(--line);
  background:rgba(0,0,0,0.25);
  padding:14px;
  border-radius:12px;
}
.feature-title{font-weight:900;margin-bottom:4px}

/* DELIVERY */
.delivery-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:26px;
  align-items:center;
}
.delivery-card{
  border:1px solid rgba(212,175,55,0.22);
  background:rgba(20,20,20,0.50);
  padding:22px;
  border-radius:14px;
  box-shadow:var(--shadow);
}
.delivery-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.delivery-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.kpi{
  border:1px solid var(--line);
  background:rgba(255,255,255,0.02);
  padding:18px;
  border-radius:14px;
  text-align:center;
}
.kpi-value{font-weight:900;font-size:1.4rem}
.kpi-label{margin-top:6px}

/* CATEGORIES */
.categories-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:14px;
  margin-top:18px;
}
.cat-card{
  border:1px solid var(--line);
  background:rgba(255,255,255,0.02);
  padding:18px;
  border-radius:14px;
  text-decoration:none;
  box-shadow:var(--shadow);
  transition:var(--t);
}
.cat-card:hover{transform:translateY(-4px);border-color:rgba(212,175,55,0.45)}
.cat-title{font-weight:900;font-size:1.05rem;margin-bottom:6px}
.center-cta{margin-top:18px;text-align:center}

/* REVIEWS */
.reviews-summary{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  margin-top:18px;
}
.summary-card{
  background:rgba(255,255,255,0.03);
  border:1px solid var(--line);
  padding:20px;
  border-radius:14px;
  box-shadow: var(--shadow);
}
.summary-score{display:flex;align-items:baseline;gap:10px}
.score{font-size:2.6rem;font-weight:900;line-height:1}
.summary-stars{color:var(--gold);letter-spacing:2px;margin:8px 0}
.summary-ctas{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.btn-small{padding:10px 12px;font-size:.85rem}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.tag{
  border:1px solid rgba(255,255,255,0.14);
  background:rgba(0,0,0,0.25);
  padding:6px 10px;
  border-radius:999px;
  font-size:.82rem;
  color:rgba(255,255,255,0.86);
}

.reviews-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:14px;
}
.review-card{
  background:rgba(255,255,255,0.02);
  border:1px solid var(--line);
  padding:18px;
  border-radius:14px;
  min-height:170px;
}
.review-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.review-name{font-weight:900}
.review-stars{color:var(--gold);letter-spacing:1px}
.review-text{line-height:1.7}
.skeleton{opacity:0.6; animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%{opacity:0.45}50%{opacity:0.75}100%{opacity:0.45}}
.reviews-cta{margin-top:18px;display:flex;gap:12px;flex-wrap:wrap}

/* CONSULTORÍA */
.consultoria-box{
  max-width:900px;
  border:1px solid rgba(212,175,55,0.30);
  background:rgba(0,0,0,0.35);
  padding:26px;
  border-radius:14px;
  box-shadow: var(--shadow);
}
.consultoria-list{list-style:none;margin:16px 0}
.consultoria-list li{margin-bottom:10px;color:#d0d0d0}
.consultoria-list li::before{content:"✓";color:var(--gold);font-weight:900;margin-right:10px}
.consultoria-ctas{display:flex;gap:12px;flex-wrap:wrap}

/* VISÍTANOS */
.visit-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:26px;
  align-items:start;
}
.visit-card{
  border:1px solid var(--line);
  background:rgba(255,255,255,0.02);
  padding:22px;
  border-radius:14px;
  box-shadow:var(--shadow);
}
.visit-item{margin-top:12px}
.visit-label{display:block;font-weight:900;margin-bottom:3px}
.visit-ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}

/* FOOTER */
.main-footer{
  padding:40px 0;
  background:#000;
  border-top:1px solid rgba(212,175,55,0.35);
}
.footer-inner{display:flex;justify-content:center;text-align:center;color:rgba(255,255,255,0.75);font-size:.9rem}

/* RESPONSIVE */
@media (max-width: 1050px){
  .hero-grid,.section-split,.delivery-grid,.visit-grid{grid-template-columns:1fr}
  .categories-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 980px){
  .hero-left h1{font-size:2.5rem}
  .reviews-summary{grid-template-columns:1fr}
  .reviews-grid{grid-template-columns:1fr}
  .main-nav ul{
    display:none;
    position:absolute;
    top:74px;left:5%;right:5%;
    background:rgba(0,0,0,0.96);
    border:1px solid var(--line);
    padding:18px;
    flex-direction:column;
    gap:14px;
    border-radius:12px;
  }
  .main-nav ul.is-open{display:flex}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center}
  .categories-grid{grid-template-columns:1fr}
}
