/* ============================================
   TU CHEF EN CASA — Oscar Bejarano
   Diseño: elegante, oscuro, gastronómico
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Outfit:wght@300;400;500;600&display=swap');

:root {
  --c-dark:      #0b1220;
  --c-dark2:     #111827;
  --c-dark3:     #1c2535;
  --c-orange:    #e8601c;
  --c-orange-lt: #f07840;
  --c-gold:      #c9963a;
  --c-gold-lt:   #e2b96a;
  --c-white:     #ffffff;
  --c-off:       #f4f1ec;
  --c-text:      #e8e2d9;
  --c-muted:     #8a9ab0;
  --c-border:    rgba(255,255,255,.08);
  --font-serif:  'Cormorant Garamond', Georgia, serif;
  --font-sans:   'Outfit', system-ui, sans-serif;
  --max-w:       1160px;
  --radius:      8px;
  --shadow:      0 8px 40px rgba(0,0,0,.35);
  --tr:          .3s ease;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  background: var(--c-dark);
  color: var(--c-text);
  line-height: 1.7;
  font-size: 16px;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* ---- TYPO ---- */
h1,h2,h3,h4 { font-family: var(--font-serif); line-height: 1.2; }
h1 { font-size: clamp(2.6rem,6vw,4.4rem); font-weight: 300; }
h2 { font-size: clamp(1.9rem,4vw,3rem);   font-weight: 300; }
h3 { font-size: clamp(1.3rem,2.5vw,1.8rem); font-weight: 400; }
h4 { font-family: var(--font-sans); font-size:.72rem; font-weight:600;
     letter-spacing:.18em; text-transform:uppercase; color:var(--c-orange); }
p  { margin-bottom: 1rem; }

/* ---- LAYOUT ---- */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.section    { padding: 6rem 0; }

/* ============ HEADER ============ */
.site-header {
  position: fixed; top:0; left:0; right:0; z-index:100;
  padding: 1.1rem 0;
  transition: background var(--tr), box-shadow var(--tr);
}
.site-header.scrolled {
  background: rgba(11,18,32,.95);
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 24px rgba(0,0,0,.4);
}
.nav-inner {
  display: flex; align-items: center;
  justify-content: space-between; gap: 2rem;
}
.nav-logo {
  display: flex; align-items: center; gap:.75rem;
  font-family: var(--font-serif); font-size:1.25rem; font-weight:300;
  color: var(--c-white); letter-spacing:.04em;
}
.nav-logo img { width:38px; height:38px; object-fit:contain; }
.nav-links {
  display: flex; align-items: center; gap:2rem;
}
.nav-links a {
  font-size:.82rem; font-weight:500; letter-spacing:.1em;
  text-transform:uppercase; color:rgba(255,255,255,.7);
  transition: color var(--tr);
}
.nav-links a:hover { color:var(--c-orange-lt); }
.nav-contact {
  display: flex; align-items: center; gap:.75rem;
}
.nav-contact a {
  font-size:.82rem; font-weight:500; color:rgba(255,255,255,.6);
  display:flex; align-items:center; gap:.4rem;
  transition: color var(--tr);
}
.nav-contact a:hover { color:var(--c-orange-lt); }
.nav-toggle { display:none; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span { display:block; width:22px; height:2px; background:var(--c-white); margin:5px 0; transition:var(--tr); }

/* ============ HERO ============ */
.hero {
  position: relative; width:100%; height:100vh; min-height:600px;
  display:flex; align-items:center; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background: url('/fotos/cocina.jpg') center 30%/cover no-repeat;
  transform: scale(1.05);
  transition: transform 10s ease;
}
.hero.loaded .hero-bg { transform: scale(1); }
.hero-overlay {
  position:absolute; inset:0;
  background: linear-gradient(
    110deg,
    rgba(8,14,26,.90) 0%,
    rgba(8,14,26,.65) 55%,
    rgba(8,14,26,.20) 100%
  );
}
.hero-content {
  position:relative; z-index:2;
  padding: 0 0 0 4rem; max-width:660px;
}
.hero-label {
  display:inline-flex; align-items:center; gap:.6rem;
  background: rgba(232,96,28,.15); border:1px solid rgba(232,96,28,.4);
  color:var(--c-orange-lt); font-size:.72rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase;
  padding:.38rem 1.1rem; border-radius:2rem; margin-bottom:1.6rem;
}
.hero-content h1 {
  color:var(--c-white);
  text-shadow:0 2px 24px rgba(0,0,0,.5);
  margin-bottom:1.2rem;
}
.hero-content h1 em { font-style:italic; color:var(--c-gold-lt); }
.hero-content p {
  font-size:1.1rem; color:rgba(255,255,255,.78);
  max-width:500px; margin-bottom:2.2rem;
  text-shadow:0 1px 8px rgba(0,0,0,.4);
}
.hero-cta { display:flex; flex-wrap:wrap; gap:1rem; }
.hero-chips {
  position:absolute; bottom:2.5rem; left:4rem; z-index:2;
  display:flex; flex-wrap:wrap; gap:.6rem;
}
.chip {
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(6px);
  color:rgba(255,255,255,.85); font-size:.75rem; font-weight:500;
  padding:.35rem .9rem; border-radius:2rem; letter-spacing:.04em;
}
.scroll-hint {
  position:absolute; bottom:2.5rem; right:4rem; z-index:2;
  display:flex; flex-direction:column; align-items:center; gap:.4rem;
  color:rgba(255,255,255,.35); font-size:.68rem; letter-spacing:.12em; text-transform:uppercase;
  animation: floatY 2.2s ease-in-out infinite;
}
.scroll-hint svg { width:18px; height:18px; }
@keyframes floatY { 0%,100%{transform:translateY(0)} 50%{transform:translateY(7px)} }

/* ============ BUTTONS ============ */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.78rem 1.9rem; border-radius:var(--radius);
  font-family:var(--font-sans); font-size:.84rem; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase; cursor:pointer;
  transition:var(--tr); border:2px solid transparent;
}
.btn-primary { background:var(--c-orange); color:var(--c-white); border-color:var(--c-orange); }
.btn-primary:hover { background:var(--c-orange-lt); border-color:var(--c-orange-lt); transform:translateY(-2px); box-shadow:0 8px 28px rgba(232,96,28,.4); }
.btn-outline { background:transparent; color:var(--c-white); border-color:rgba(255,255,255,.5); }
.btn-outline:hover { border-color:var(--c-white); background:rgba(255,255,255,.08); }
.btn-ghost { background:transparent; color:var(--c-orange-lt); border-color:var(--c-orange); }
.btn-ghost:hover { background:var(--c-orange); color:var(--c-white); transform:translateY(-2px); }
.btn-wa { background:#25D366; color:var(--c-white); border-color:#25D366; }
.btn-wa:hover { background:#1ebe5d; border-color:#1ebe5d; transform:translateY(-2px); box-shadow:0 8px 24px rgba(37,211,102,.4); }

/* ============ SECTION HEADER ============ */
.sec-header { text-align:center; margin-bottom:3.5rem; }
.sec-header h4 { margin-bottom:.5rem; }
.sec-header h2 { color:var(--c-white); }
.sec-header p { color:var(--c-muted); max-width:520px; margin:.8rem auto 0; }
.divider {
  width:48px; height:2px;
  background:linear-gradient(90deg,var(--c-orange),var(--c-gold));
  margin:.8rem auto 0; border-radius:2px;
}

/* ============ SERVICIOS ============ */
.servicios { background:var(--c-dark2); }
.servicios-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem;
}
.servicio-card {
  background:var(--c-dark3); border:1px solid var(--c-border);
  border-radius:var(--radius); padding:2.5rem 2rem;
  transition:var(--tr); position:relative; overflow:hidden;
}
.servicio-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--c-orange),var(--c-gold));
  transform:scaleX(0); transform-origin:left; transition:transform var(--tr);
}
.servicio-card:hover { transform:translateY(-6px); border-color:rgba(232,96,28,.3); box-shadow:var(--shadow); }
.servicio-card:hover::before { transform:scaleX(1); }
.servicio-icon { font-size:2.2rem; margin-bottom:1.2rem; }
.servicio-card h3 { color:var(--c-white); margin-bottom:.7rem; font-size:1.4rem; }
.servicio-card p { color:var(--c-muted); font-size:.93rem; margin:0; }
.servicio-price {
  margin-top:1.5rem; padding-top:1.2rem; border-top:1px solid var(--c-border);
  font-size:.8rem; color:var(--c-orange-lt); font-weight:600; letter-spacing:.06em;
}

/* ============ PROCESO ============ */
.proceso-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem;
  position:relative;
}
.proceso-grid::before {
  content:''; position:absolute; top:2.5rem; left:10%; right:10%; height:1px;
  background:linear-gradient(90deg,transparent,var(--c-orange),var(--c-gold),transparent);
  z-index:0;
}
.paso {
  text-align:center; padding:2rem 1.2rem; position:relative; z-index:1;
  background:var(--c-dark2); border:1px solid var(--c-border);
  border-radius:var(--radius); transition:var(--tr);
}
.paso:hover { border-color:rgba(232,96,28,.4); transform:translateY(-4px); }
.paso-num {
  width:52px; height:52px; border-radius:50%;
  background:linear-gradient(135deg,var(--c-orange),var(--c-gold));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-serif); font-size:1.5rem; font-weight:600;
  color:var(--c-white); margin:0 auto 1.2rem;
  box-shadow:0 4px 16px rgba(232,96,28,.4);
}
.paso h3 { color:var(--c-white); font-size:1.1rem; margin-bottom:.5rem; }
.paso p { color:var(--c-muted); font-size:.88rem; margin:0; }

/* ============ GALERIA ============ */
.galeria { background:var(--c-dark2); }
.galeria-grid {
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  grid-template-rows: 280px 280px;
  gap:1rem;
}
.gal-item {
  overflow:hidden; border-radius:var(--radius); position:relative;
  cursor:pointer;
}
.gal-item img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s ease;
}
.gal-item:hover img { transform:scale(1.06); }
.gal-item--tall { grid-row:1 / span 2; }
.gal-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(8,14,26,.7) 0%,transparent 50%);
  opacity:0; transition:opacity var(--tr);
  display:flex; align-items:flex-end; padding:1.2rem;
}
.gal-item:hover .gal-overlay { opacity:1; }
.gal-overlay span { color:var(--c-white); font-size:.82rem; font-weight:500; letter-spacing:.06em; }

/* ============ MEDIA (TV/Radio) ============ */
.media-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:2rem;
}
.media-card {
  border-radius:var(--radius); overflow:hidden; position:relative;
  aspect-ratio:16/9; cursor:pointer;
}
.media-card img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.media-card:hover img { transform:scale(1.05); }
.media-card-info {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(8,14,26,.85),rgba(8,14,26,.2));
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:1.5rem;
}
.media-tag {
  display:inline-block; background:var(--c-orange); color:var(--c-white);
  font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:.2rem .7rem; border-radius:2rem; margin-bottom:.6rem; width:fit-content;
}
.media-card-info h3 { color:var(--c-white); font-size:1.2rem; }
.media-card-info p { color:rgba(255,255,255,.7); font-size:.85rem; margin:0; }

/* ============ VIDEO ============ */
.video-wrap {
  background:var(--c-dark2);
  padding:5rem 0;
}
.video-inner {
  display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center;
}
.video-frame {
  border-radius:var(--radius); overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.5);
  aspect-ratio:16/9;
}
.video-frame iframe { width:100%; height:100%; border:0; }
.video-text h4 { margin-bottom:.5rem; }
.video-text h2 { color:var(--c-white); margin-bottom:1rem; }
.video-text p { color:var(--c-muted); }

/* ============ CONTACTO ============ */
.contacto { background:var(--c-dark2); }
.contacto-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start;
}
.contacto-info h4 { margin-bottom:.5rem; }
.contacto-info h2 { color:var(--c-white); margin-bottom:1.2rem; }
.contacto-info p { color:var(--c-muted); margin-bottom:2rem; }
.contacto-detail {
  display:flex; align-items:center; gap:1rem; margin-bottom:1.2rem;
}
.contacto-icon {
  width:44px; height:44px; border-radius:50%;
  background:rgba(232,96,28,.15); border:1px solid rgba(232,96,28,.3);
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
  flex-shrink:0;
}
.contacto-detail p { margin:0; font-size:.95rem; }
.contacto-detail a { color:var(--c-text); transition:color var(--tr); }
.contacto-detail a:hover { color:var(--c-orange-lt); }
.form-card {
  background:var(--c-dark3); border:1px solid var(--c-border);
  border-radius:var(--radius); padding:2.5rem;
}
.form-card h3 { color:var(--c-white); margin-bottom:1.8rem; font-size:1.5rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label {
  display:block; font-size:.78rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--c-muted); margin-bottom:.45rem;
}
.form-group input,
.form-group textarea,
.form-group select {
  width:100%; padding:.78rem 1rem;
  background:rgba(255,255,255,.05); border:1.5px solid var(--c-border);
  border-radius:var(--radius); font-family:var(--font-sans);
  font-size:.95rem; color:var(--c-text);
  transition:border-color var(--tr);
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  outline:none; border-color:var(--c-orange);
  background:rgba(232,96,28,.05);
}
.form-group textarea { resize:vertical; min-height:110px; }
.form-group select option { background:var(--c-dark2); }
.form-check {
  display:flex; align-items:flex-start; gap:.75rem; margin-bottom:1.4rem;
}
.form-check input { width:auto; margin-top:3px; accent-color:var(--c-orange); }
.form-check label { font-size:.83rem; color:var(--c-muted); }
.form-check a { color:var(--c-orange-lt); text-decoration:underline; }

/* ============ FOOTER ============ */
.site-footer {
  background:var(--c-dark); border-top:1px solid var(--c-border);
  padding:4rem 0 2rem;
}
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr; gap:3rem; margin-bottom:3rem;
}
.footer-brand .brand-name {
  display:flex; align-items:center; gap:.75rem; margin-bottom:1rem;
}
.footer-brand .brand-name img { width:40px; height:40px; object-fit:contain; }
.footer-brand .brand-name span {
  font-family:var(--font-serif); font-size:1.2rem; color:var(--c-white);
}
.footer-brand p { font-size:.9rem; color:var(--c-muted); max-width:280px; }
.footer-social { display:flex; gap:.75rem; margin-top:1.2rem; }
.footer-social a {
  width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.06); border:1px solid var(--c-border);
  display:flex; align-items:center; justify-content:center;
  color:var(--c-muted); transition:var(--tr);
}
.footer-social a:hover { background:var(--c-orange); border-color:var(--c-orange); color:var(--c-white); }
.footer-col h4 { color:var(--c-orange-lt); font-size:.72rem; letter-spacing:.12em; margin-bottom:1.2rem; }
.footer-col ul li { margin-bottom:.6rem; }
.footer-col ul a { font-size:.9rem; color:var(--c-muted); transition:color var(--tr); }
.footer-col ul a:hover { color:var(--c-orange-lt); }
.footer-col address { font-style:normal; font-size:.9rem; color:var(--c-muted); line-height:1.9; }
.footer-col address a { color:var(--c-muted); transition:color var(--tr); }
.footer-col address a:hover { color:var(--c-orange-lt); }
.footer-bottom {
  border-top:1px solid var(--c-border); padding-top:1.5rem;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
  font-size:.8rem; color:var(--c-muted);
}
.footer-bottom a { color:var(--c-muted); transition:color var(--tr); }
.footer-bottom a:hover { color:var(--c-orange-lt); }

/* ============ COOKIE BANNER ============ */
#cookie-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:9999;
  background:rgba(17,24,39,.97); border-top:2px solid var(--c-orange);
  padding:1.2rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between;
  gap:1.5rem; flex-wrap:wrap;
  backdrop-filter:blur(10px);
}
#cookie-banner p { margin:0; font-size:.88rem; color:rgba(255,255,255,.8); flex:1; min-width:220px; }
#cookie-banner a { color:var(--c-orange-lt); text-decoration:underline; }
.cookie-actions { display:flex; gap:.75rem; }
.btn-ca { background:var(--c-orange); color:#fff; border:none; padding:.6rem 1.4rem; border-radius:var(--radius); font-weight:600; font-size:.85rem; cursor:pointer; transition:var(--tr); }
.btn-ca:hover { background:var(--c-orange-lt); }
.btn-cr { background:transparent; color:rgba(255,255,255,.6); border:1px solid rgba(255,255,255,.25); padding:.6rem 1.1rem; border-radius:var(--radius); font-size:.85rem; cursor:pointer; transition:var(--tr); }
.btn-cr:hover { border-color:#fff; color:#fff; }

/* ============ LEGAL ============ */
.legal-content { max-width:820px; margin:0 auto; padding:4rem 1.5rem; }
.legal-content h1 { color:var(--c-white); margin-bottom:2rem; font-size:2.2rem; }
.legal-content h2 { color:var(--c-white); font-size:1.3rem; margin:2rem 0 .7rem; }
.legal-content h3 { color:var(--c-gold-lt); font-size:1.1rem; margin:1.5rem 0 .5rem; }
.legal-content p  { color:var(--c-muted); }
.legal-content ul { padding-left:1.5rem; list-style:disc; margin-bottom:1rem; }
.legal-content ul li { margin-bottom:.4rem; color:var(--c-muted); }
.legal-content a { color:var(--c-orange-lt); text-decoration:underline; }
.page-hero-legal {
  background:var(--c-dark2); border-bottom:1px solid var(--c-border);
  padding:8rem 0 3rem; text-align:center;
}
.page-hero-legal h1 { color:var(--c-white); }
.breadcrumb { font-size:.8rem; color:var(--c-muted); margin-bottom:.8rem; }
.breadcrumb a { color:var(--c-muted); }
.breadcrumb a:hover { color:var(--c-orange-lt); }

/* ============ 404 ============ */
.error-page {
  min-height:80vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center; text-align:center; padding:4rem 2rem;
}
.error-num {
  font-family:var(--font-serif); font-size:clamp(6rem,15vw,11rem);
  font-weight:300; color:var(--c-dark3); line-height:1;
}
.error-page h2 { color:var(--c-white); margin-bottom:.8rem; }
.error-page p { color:var(--c-muted); margin-bottom:2rem; }

/* ============ ANIMATIONS ============ */
.fade-up { opacity:0; transform:translateY(28px); transition:opacity .65s ease,transform .65s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }

/* ============ RESPONSIVE ============ */
@media (max-width:960px) {
  .servicios-grid { grid-template-columns:1fr 1fr; }
  .proceso-grid   { grid-template-columns:1fr 1fr; }
  .proceso-grid::before { display:none; }
  .galeria-grid   { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .gal-item--tall { grid-row:auto; }
  .media-grid     { grid-template-columns:1fr; }
  .video-inner    { grid-template-columns:1fr; }
  .contacto-grid  { grid-template-columns:1fr; }
  .footer-grid    { grid-template-columns:1fr 1fr; }
}
@media (max-width:640px) {
  .servicios-grid,
  .proceso-grid,
  .galeria-grid,
  .footer-grid { grid-template-columns:1fr; }
  .hero-content { padding:0 1.5rem; }
  .hero-chips   { left:1.5rem; bottom:5rem; }
  .nav-links    { display:none; flex-direction:column; position:fixed;
                  top:0; left:0; right:0; bottom:0;
                  background:rgba(8,14,26,.98); justify-content:center;
                  align-items:center; gap:2.5rem; z-index:999; }
  .nav-links.open { display:flex; }
  .nav-contact  { display:none; }
  .nav-toggle   { display:block; z-index:1000; }
  .footer-grid  { grid-template-columns:1fr; }
}
