/* ==========================================================================
   Novo Wine — NV Wine & More
   Sitio estático independiente (sin WordPress)
   ========================================================================== */

:root{
  --wine:#6b1f2a;
  --wine-dark:#4a141c;
  --wine-deep:#2a0d12;
  --gold:#c9a24b;
  --gold-soft:#e0c98a;
  --cream:#f7f1e8;
  --cream-2:#efe6d6;
  --ink:#1c1416;
  --muted:#6f6157;
  --white:#ffffff;
  --shadow:0 18px 50px rgba(42,13,18,.16);
  --radius:14px;
  --maxw:1180px;
  --ff-head:"Playfair Display", Georgia, "Times New Roman", serif;
  --ff-body:"Inter", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:124px}
body{
  margin:0;
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{font-family:var(--ff-head); font-weight:700; line-height:1.15; margin:0 0 .4em}
p{margin:0 0 1em}

.container{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px}
.eyebrow{
  font-family:var(--ff-body);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.74rem;
  font-weight:700;
  color:var(--gold);
  margin:0 0 .9rem;
  display:inline-block;
}
.section{padding:96px 0}
.section--tight{padding:72px 0}
.section-head{max-width:760px; margin:0 auto 56px; text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.4vw,2.8rem); color:var(--wine)}
.section-head p{color:var(--muted); font-size:1.05rem}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:.55rem;
  font-weight:600; font-size:.95rem; letter-spacing:.02em;
  padding:14px 28px; border-radius:999px; cursor:pointer;
  border:1.5px solid transparent; transition:.25s ease;
}
.btn--gold{background:var(--gold); color:var(--wine-deep)}
.btn--gold:hover{background:var(--gold-soft); transform:translateY(-2px)}
.btn--outline{border-color:rgba(255,255,255,.7); color:#fff}
.btn--outline:hover{background:#fff; color:var(--wine)}
.btn--wine{background:var(--wine); color:#fff}
.btn--wine:hover{background:var(--wine-dark); transform:translateY(-2px)}

/* ===================== Top bar ===================== */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:70;
  background:var(--wine-deep); color:rgba(255,255,255,.78);
  height:38px; display:flex; align-items:center;
  border-bottom:2px solid var(--gold);
}
.topbar .container{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; width:100%;
}
.topbar .tb-left{display:flex; align-items:center; gap:22px; font-size:.82rem}
.topbar .tb-left a{display:inline-flex; align-items:center; gap:7px; transition:.2s}
.topbar .tb-left a:hover{color:var(--gold-soft)}
.topbar .tb-left svg{width:14px; height:14px}
.topbar .tb-right{display:flex; align-items:center; gap:14px}
.topbar .tb-right a{opacity:.8; transition:.2s}
.topbar .tb-right a:hover{opacity:1; color:var(--gold-soft)}
.topbar .tb-right svg{width:15px; height:15px}
@media (max-width:620px){
  .topbar .tb-left a span{display:none}
  .topbar{height:36px}
}

/* ===================== Header / Nav ===================== */
.site-header{
  position:fixed; top:38px; left:0; right:0; z-index:60;
  background:rgba(247,241,232,.96);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(107,31,42,.10);
  transition:.3s ease;
}
.site-header .bar{
  display:flex; align-items:center; justify-content:space-between;
  height:78px; gap:24px;
}
.brand{display:flex; align-items:center; gap:12px}
.brand img{height:50px; width:auto}
.brand .brand-text{font-family:var(--ff-head); font-weight:700; color:var(--wine); font-size:1.15rem; line-height:1}
.brand .brand-text small{display:block; font-family:var(--ff-body); font-weight:500; letter-spacing:.14em; text-transform:uppercase; font-size:.6rem; color:var(--gold); margin-top:3px}

.nav{display:flex; align-items:center; gap:30px}
.nav a{font-size:.92rem; font-weight:500; color:var(--ink); position:relative; padding:6px 0}
.nav a::after{content:""; position:absolute; left:0; bottom:0; height:2px; width:0; background:var(--gold); transition:.25s}
.nav a:hover{color:var(--wine)}
.nav a:hover::after{width:100%}
.nav .btn{padding:10px 22px}
.nav .btn--wine{background:var(--gold); color:var(--wine-deep)}
.nav .btn--wine:hover{background:var(--gold-soft)}

.nav-toggle{display:none; background:none; border:0; cursor:pointer; padding:8px; flex-direction:column; gap:5px}
.nav-toggle span{width:26px; height:2px; background:var(--wine); display:block; transition:.3s}

/* ===================== Hero ===================== */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center;
  color:#fff; text-align:left; overflow:hidden;
  background:
    linear-gradient(120deg, rgba(42,13,18,.45) 0%, rgba(74,20,28,.39) 45%, rgba(107,31,42,.28) 100%),
    url("../img/wine-background-white-and-red-wine-1536x1024.webp");
  background-size:cover; background-position:center;
}
.hero::after{
  content:""; position:absolute; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M0 39.5H40M39.5 0V40' stroke='%23ffffff' stroke-opacity='0.03'/%3E%3C/svg%3E");
  pointer-events:none;
}
.hero .container{position:relative; z-index:2; padding-top:100px; padding-bottom:60px}
.hero-inner{max-width:780px}
.hero-logo{
  height:1.05em; width:auto; vertical-align:-.12em; margin-right:.35em;
  background:transparent;
}
.hero h1{
  font-size:clamp(2.6rem,6vw,4.6rem); margin-bottom:.3em;
  letter-spacing:-.01em;
}
.hero-title{
  text-shadow:0 2px 10px rgba(42,13,18,.45);
}
.hero h1 .accent{color:var(--gold-soft); font-style:italic}
.hero .lead{font-size:clamp(1.05rem,1.6vw,1.3rem); color:rgba(255,255,255,.85); max-width:560px; margin-bottom:2rem}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap}
.hero-tags{display:flex; gap:10px; flex-wrap:wrap; margin-top:2.6rem}
.hero-tags span{
  font-size:.78rem; letter-spacing:.08em; text-transform:uppercase;
  background:var(--gold); border:1px solid var(--gold); color:var(--wine-deep);
  font-weight:600; padding:7px 14px; border-radius:999px;
}

/* ===================== Stats ===================== */
.stats{background:var(--wine-deep); color:#fff; padding:0}
.stats .grid{display:grid; grid-template-columns:repeat(3,1fr)}
.stat{padding:42px 24px; text-align:center; border-left:1px solid rgba(255,255,255,.08)}
.stat:first-child{border-left:0}
.stat .num{font-family:var(--ff-head); font-size:2.6rem; color:var(--gold); line-height:1}
.stat .lbl{font-size:.92rem; color:rgba(255,255,255,.8); margin-top:.4rem}

/* ===================== Nosotros ===================== */
.about{background:var(--cream)}
.about .grid{display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:center}
.about-cards{display:grid; gap:18px}
.about-card{
  background:#fff; border-radius:var(--radius); padding:26px 28px;
  box-shadow:var(--shadow); border-left:4px solid var(--gold);
}
.about-card h3{color:var(--wine); font-size:1.25rem; margin-bottom:.35em}
.about-card p{margin:0; color:var(--muted)}
.about-visual{
  border-radius:var(--radius); min-height:440px; box-shadow:var(--shadow);
  background:
    linear-gradient(160deg, rgba(42,13,18,.20), rgba(42,13,18,.10)),
    url("../img/wine-decanter-and-glass-of-red-wine-768x512.webp");
  background-size:cover; background-position:center;
  position:relative; overflow:hidden; display:flex; align-items:flex-end;
}
.about-visual .badge{
  margin:26px; background:rgba(247,241,232,.95); color:var(--wine);
  border-radius:12px; padding:18px 22px; max-width:240px;
}
.about-visual .badge strong{font-family:var(--ff-head); font-size:1.5rem; display:block; color:var(--wine)}

/* ===================== Servicios ===================== */
.services{background:#fff}
.services-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:26px}
.service{
  background:var(--cream); border-radius:var(--radius); overflow:hidden;
  transition:.25s ease; border:1px solid rgba(107,31,42,.06);
}
.service:hover{transform:translateY(-6px); box-shadow:var(--shadow)}
.service-media{position:relative; height:180px; overflow:hidden}
.service-media img{width:100%; height:100%; object-fit:cover; transition:.5s ease}
.service:hover .service-media img{transform:scale(1.06)}
.service-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(42,13,18,.05), rgba(42,13,18,.35));
}
.service-body{padding:28px 30px}
.service .ico{
  width:52px; height:52px; border-radius:14px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--wine),var(--wine-dark)); color:var(--gold-soft);
  margin:-52px 0 16px; position:relative; z-index:2; box-shadow:0 8px 20px rgba(42,13,18,.25);
}
.service .ico svg{width:26px; height:26px}
.service h3{color:var(--wine); font-size:1.2rem}
.service p{margin:0; color:var(--muted)}

/* ===================== Misión ===================== */
.mission{
  color:#fff; position:relative;
  background:
    linear-gradient(120deg, rgba(42,13,18,.47), rgba(74,20,28,.43) 60%, rgba(107,31,42,.40)),
    url("../img/traditional-winemaking-and-wine-tasting-1536x877.webp");
  background-size:cover; background-position:center; background-attachment:fixed;
}
.mission .grid{display:grid; grid-template-columns:1.2fr 1fr; gap:56px; align-items:center}
.mission h2{color:#fff; font-size:clamp(1.9rem,3.4vw,2.9rem)}
.mission .eyebrow{color:var(--gold-soft)}
.mission p{color:rgba(255,255,255,.85)}
.mission .pillars{display:grid; gap:16px}
.mission .pillar{
  background:rgba(255,255,255,.06); border:1px solid rgba(224,201,138,.22);
  border-radius:12px; padding:22px 24px;
}
.mission .pillar h3{color:var(--gold-soft); font-size:1.1rem; margin-bottom:.3em}
.mission .pillar p{margin:0; font-size:.96rem}

/* ===================== Alcance ===================== */
.reach{background:var(--cream-2)}
.reach .grid{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center}
.reach h2{color:var(--wine)}
.reach .map{
  border-radius:var(--radius); min-height:380px; box-shadow:var(--shadow);
  background:
    linear-gradient(160deg, rgba(42,13,18,.31), rgba(107,31,42,.22)),
    url("../img/wine-champagne768x512.webp");
  background-size:cover; background-position:center;
  display:flex; align-items:center; justify-content:center; color:#fff;
  text-align:center; padding:30px;
}
.reach .zones{display:flex; flex-wrap:wrap; gap:10px; margin-top:1.4rem}
.reach .zones span{
  background:#fff; color:var(--wine); border:1px solid rgba(107,31,42,.12);
  border-radius:999px; padding:8px 16px; font-size:.86rem; font-weight:600;
}

/* ===================== Socios ===================== */
.partners{background:#fff; text-align:center}
.partners-logos{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center;
  gap:48px; margin-top:18px;
}
.partners-logos img{
  height:64px; width:auto; object-fit:contain;
  filter:grayscale(100%); opacity:.62; transition:.3s ease;
}
.partners-logos img:hover{filter:grayscale(0); opacity:1; transform:scale(1.06)}

/* ===================== CTA band ===================== */
.cta-band{
  background:
    linear-gradient(120deg, rgba(42,13,18,.44), rgba(74,20,28,.39)),
    url("../img/excellent-red-wine-tasting-at-night-1536x1025.webp");
  background-size:cover; background-position:center;
  color:#fff; text-align:center;
}
.cta-band h2{color:#fff; font-size:clamp(1.8rem,3.2vw,2.6rem)}
.cta-band p{color:rgba(255,255,255,.85); max-width:560px; margin:0 auto 1.8rem}

/* ===================== Contacto ===================== */
.page-hero{
  background:
    linear-gradient(120deg, rgba(42,13,18,.45) 0%, rgba(107,31,42,.36) 100%),
    url("../img/excellent-red-wine-tasting-at-night-1536x1025.webp");
  background-size:cover; background-position:center;
  color:#fff; padding:160px 0 80px; text-align:center;
}
.page-hero h1{font-size:clamp(2.2rem,4.5vw,3.4rem)}
.page-hero p{color:rgba(255,255,255,.85); max-width:560px; margin:0 auto}

.contact-wrap{display:grid; grid-template-columns:1fr 1.2fr; gap:50px; align-items:start}
.contact-info .info-item{
  display:flex; gap:16px; align-items:flex-start; margin-bottom:26px;
}
.contact-info .info-item .ico{
  flex:0 0 auto; width:48px; height:48px; border-radius:12px; display:grid; place-items:center;
  background:linear-gradient(135deg,var(--wine),var(--wine-dark)); color:var(--gold-soft);
}
.contact-info h3{color:var(--wine); margin:0 0 .2em; font-size:1.1rem}
.contact-info p{margin:0; color:var(--muted)}
.contact-info a{color:var(--wine); font-weight:600}

.contact-form{
  background:#fff; border-radius:var(--radius); padding:38px; box-shadow:var(--shadow);
  border-top:4px solid var(--gold);
}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.field{margin-bottom:18px}
.field label{display:block; font-size:.85rem; font-weight:600; color:var(--ink); margin-bottom:7px}
.field input,.field textarea,.field select{
  width:100%; padding:13px 15px; border:1.5px solid #e3d9c8; border-radius:10px;
  font-family:inherit; font-size:.95rem; background:var(--cream); color:var(--ink); transition:.2s;
}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none; border-color:var(--gold); background:#fff;
}
.field textarea{min-height:130px; resize:vertical}
.form-note{font-size:.82rem; color:var(--muted); margin-top:6px}
.form-success{
  display:none; background:#eef7ee; color:#1f6b2e; border:1px solid #bfe0c4;
  border-radius:10px; padding:14px 16px; margin-bottom:18px; font-size:.92rem;
}

/* ===================== Footer ===================== */
.site-footer{background:var(--wine-deep); color:rgba(255,255,255,.78); padding:64px 0 28px}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; margin-bottom:40px}
.site-footer .brand img{height:54px; filter:brightness(0) invert(1); opacity:.9}
.site-footer h4{color:#fff; font-family:var(--ff-body); font-size:.8rem; letter-spacing:.16em; text-transform:uppercase; margin-bottom:18px}
.footer-links{list-style:none; padding:0; margin:0; display:grid; gap:10px}
.footer-links a{font-size:.92rem; transition:.2s}
.footer-links a:hover{color:var(--gold-soft); padding-left:4px}
.socials{display:flex; gap:12px; margin-top:14px}
.socials a{
  width:40px; height:40px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.08); transition:.25s;
}
.socials a:hover{background:var(--gold); color:var(--wine-deep)}
.socials svg{width:18px; height:18px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1); padding-top:22px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:.84rem; color:rgba(255,255,255,.6);
}

/* ===================== Reveal animation ===================== */
.reveal{opacity:0; transform:translateY(26px); transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}

/* ===================== Responsive ===================== */
@media (max-width:980px){
  .about .grid,.mission .grid,.reach .grid,.contact-wrap{grid-template-columns:1fr; gap:40px}
  .services-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .about-visual{min-height:300px}
}
@media (max-width:760px){
  .nav{
    position:fixed; top:116px; right:0; left:0;
    background:var(--cream); flex-direction:column; align-items:flex-start;
    gap:0; padding:10px 24px 24px; box-shadow:var(--shadow);
    transform:translateY(-140%); transition:.35s ease; height:auto;
  }
  .nav.open{transform:translateY(0)}
  .nav a{width:100%; padding:14px 0; border-bottom:1px solid rgba(107,31,42,.08)}
  .nav .btn{margin-top:14px; width:100%; justify-content:center}
  .nav-toggle{display:flex}
  .stats .grid{grid-template-columns:1fr}
  .stat{border-left:0; border-top:1px solid rgba(255,255,255,.08)}
  .stat:first-child{border-top:0}
  .services-grid,.footer-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .section{padding:70px 0}
  .footer-bottom{flex-direction:column; text-align:center}
}
