@font-face {
    font-family: "BentonSansBBVA";
    src: url("BentonSansBBVA-Light.otf") format("opentype");
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "BentonSansBBVA";
    src: url("BentonSansBBVA-Book.otf") format("opentype");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "BentonSansBBVA";
    src: url("BentonSansBBVA-BookItalic.otf") format("opentype");
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "BentonSansBBVA";
    src: url("BentonSansBBVA-Medium.otf") format("opentype");
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "BentonSansBBVA";
    src: url("BentonSansBBVA-MediumItalic.otf") format("opentype");
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: "BentonSansBBVA";
    src: url("BentonSansBBVA-Bold.otf") format("opentype");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
:root{--bg:#f4f4f4;--text:#151515;--muted:#6b6b6b;--accent:#b3a08d;--radius:28px;--container:1800px;}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:"BentonSansBBVA",Arial,sans-serif;background:var(--bg);color:var(--text);}
.navbar{position:sticky;top:0;background:var(--bg);z-index:50;padding:26px 0;}
.nav-inner{max-width:var(--container);margin:0 auto;padding:0 48px;position:relative;display:flex;align-items:center;justify-content:center;}
.logo{position:absolute;top:0;left:48px;display:flex;align-items:center;gap:10px;}
.logo img{height:34px;display:block;}
.nav-links{list-style:none;display:flex;gap:26px;align-items:center;}
.nav-links a{text-decoration:none;color:var(--text);font-size:12px;font-weight:700;letter-spacing:.3px;}
.nav-links li{position:relative;}
.nav-links li.active::before{content:"";position:absolute;top:-14px;left:50%;transform:translateX(-50%);width:6px;height:6px;border-radius:999px;background:var(--accent);}
.menu-toggle{display:none;position:absolute;right:48px;top:50%;transform:translateY(-50%);flex-direction:column;gap:6px;cursor:pointer;z-index:60;}
.menu-toggle span{width:30px;height:2px;background:var(--text);transition:.25s ease;}
.container{max-width:var(--container);margin:0 auto;padding:0 48px 90px;}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:start;padding-top:22px;padding-bottom:90px;}
.hero h1{font-size:58px;line-height:1.02;font-weight:800;letter-spacing:-1px;margin-top:10px;}
.hero .sub{margin-top:18px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1.6px;max-width:460px;}
.hero .para{margin-top:18px;font-size:12px;line-height:1.7;color:var(--muted);max-width:480px;}
.hero-media{position:relative;width:100%;height:460px;border-radius:var(--radius);overflow:hidden;background:#d7d7d7;}
.hero-media img{width:100%;height:100%;object-fit:cover;display:block;}
.hero-media::after{content:"Q";position:absolute;left:18px;bottom:-120px;font-size:240px;font-weight:800;color:rgba(179,160,141,.55);line-height:1;pointer-events:none;filter:saturate(0.95);}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:40px;gap:24px;padding-top:14px;}
.card{position:relative;border-radius:var(--radius);overflow:hidden;background:#ddd;}
.card img{width:100%;height:100%;object-fit:cover;display:block;}
.card:nth-child(1){grid-column:1/2;grid-row:span 9;}
.card:nth-child(2){grid-column:2/3;grid-row:span 13;}
.card:nth-child(3){grid-column:1/2;grid-row:span 13;}
.card:nth-child(4){grid-column:2/3;grid-row:span 9;}
.card-wide{grid-column:1/-1;grid-row:span 7;}
.card-content{position:absolute;left:26px;bottom:22px;color:#fff;text-shadow:0 8px 24px rgba(0,0,0,.35);z-index:10;}
.card-content .kicker{font-size:11px;text-transform:uppercase;letter-spacing:2px;opacity:.95;display:block;margin-bottom:6px;font-weight:700;}
.card-content a{color:#fff;font-size:12px;font-weight:700;text-decoration:underline;transition:opacity 0.3s ease;}
.card-content a:hover{opacity:0.8;}
footer{text-align:center;padding-top:70px;}
.footer-logo{font-size:26px;letter-spacing:10px;opacity:.85;margin-bottom:18px;}
.footer-small{font-size:11px;color:#8a8a8a;margin-bottom:16px;}
.social{display:flex;justify-content:center;gap:14px;margin-top:6px;}
.social a{width:26px;height:26px;display:grid;place-items:center;border-radius:8px;text-decoration:none;color:var(--text);background:rgba(0,0,0,.05);font-size:12px;}
.qs-hero{margin:0 -48px;margin-bottom:72px;}
.qs-hero-inner{position:relative;width:100%;height:480px;border-radius:var(--radius);overflow:hidden;background:#1a1a1a;}
.qs-hero-img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block;}
.qs-hero-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:52px 60px;align-items:center;}
.qs-hero-overlay h1{font-size:46px;font-weight:800;line-height:1.05;letter-spacing:-0.5px;color:#fff;text-transform:uppercase;margin-bottom:18px;text-align:center;}
.qs-hero-sub{font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,0.80);line-height:1.7;text-align:center;}
.qs-intro{max-width:720px;margin:0 auto 72px;text-align:center;}
.qs-intro p{font-size:13px;line-height:1.8;color:var(--text);}
.qs-split{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:0;}
.qs-split-img{border-radius:var(--radius);overflow:hidden;height:400px;background:#ccc;}
.qs-split-img img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(100%);}
.qs-split-card{background:#1e1e1e;border-radius:var(--radius);padding:52px 48px;display:flex;flex-direction:column;justify-content:center;gap:20px;height:400px;}
.qs-split-card p{font-size:13px;line-height:1.8;color:rgba(255,255,255,0.70);}
.qs-split-highlight{font-size:14px !important;font-weight:700 !important;color:#fff !important;}
.qs-values{background:#111 center/320px repeat;margin-top:80px;padding:140px 0 90px;}
.qs-values-inner{max-width:var(--container);margin:0 auto;padding:0 48px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:28px;align-items:start;}
.qs-val-col{display:flex;flex-direction:column;gap:28px;}
.qs-val-col--center{gap:24px;margin-top:-70px;}
.qs-val-item--img-only{border-radius:var(--radius);overflow:hidden;height:260px;background:#222;}
.qs-val-item--img-only img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(100%) brightness(0.75);}
.qs-val-item--text{padding:12px 4px 0;}
.qs-val-item--text h3{font-size:12px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#fff;margin-bottom:8px; text-align: center;}
.qs-val-item--text p{font-size:12px;line-height:1.65;color:rgba(255,255,255,0.55); text-align: center;}
.qs-val-item--card{border-radius:var(--radius);overflow:hidden;background:#1e1e1e;}
.qs-val-item--card img{width:100%;height:220px;object-fit:cover;display:block;filter:grayscale(100%) brightness(0.75);border-radius:var(--radius);}
.qs-val-item--card h3{font-size:12px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:#fff;padding:20px 22px 6px; text-align: center;}
.qs-val-item--card p{font-size:12px;line-height:1.65;color:rgba(255,255,255,0.55);padding:0 22px 22px; text-align: center;}
.qs-footer{background:var(--bg);padding:70px 48px 48px;text-align:center;}
.qs-footer-logo{font-family:Georgia,"Times New Roman",serif;font-style:italic;font-size:42px;font-weight:400;letter-spacing:1px;color:var(--text);margin-bottom:16px;}
.qs-footer-address{font-size:11px;color:var(--muted);margin-bottom:12px;}
.qs-footer-contact{display:flex;justify-content:center;gap:24px;font-size:11px;color:var(--muted);margin-bottom:16px;}
.qs-footer-links{display:flex;justify-content:center;gap:18px;margin-bottom:18px;}
.qs-footer-links a{font-size:10px;color:var(--muted);text-decoration:none;transition:color 0.2s;}
.qs-footer-links a:hover{color:var(--text);}
.qs-footer-social{display:flex;justify-content:center;gap:12px;}
.qs-footer-social a{width:32px;height:32px;display:grid;place-items:center;border-radius:8px;background:rgba(0,0,0,0.06);color:var(--text);text-decoration:none;transition:background 0.2s;}
.qs-footer-social a:hover{background:rgba(0,0,0,0.12);}
.qs-hero{margin:0 -48px 72px;}
.qs-hero-inner{position:relative;width:100%;height:480px;border-radius:var(--radius);overflow:hidden;background:#1a1a1a;}
.qs-hero-img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block;}
.qs-hero-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:52px 60px;text-align:center;}
.qs-hero-overlay h1{font-size:46px;font-weight:800;line-height:1.05;letter-spacing:-0.5px;color:#fff;text-transform:uppercase;margin-bottom:18px;}
.qs-hero-sub{font-size:11px;font-weight:700;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,0.80);line-height:1.7;}
.qs-intro{max-width:760px;margin:0 auto 64px;text-align:center;}
.qs-intro p{font-size:13px;line-height:1.9;color:var(--text);}
.qs-intro p + p{margin-top:12px;}
.qs-intro-kicker{margin-top:18px;font-size:10px;letter-spacing:1.6px;text-transform:uppercase;color:rgba(21,21,21,0.55);font-weight:700;}
.qs-two{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;margin:0 auto 70px;max-width:1180px;}
.qs-two-item{display:flex;flex-direction:column;gap:18px;}
.qs-two-img{border-radius:var(--radius);overflow:hidden;background:#ddd;}
.qs-two-img img{width:100%;height:100%;object-fit:cover;display:block;}
.qs-two-text{padding:0 6px;}
.qs-two-text h3{font-size:12px;font-weight:800;color:var(--text);margin-bottom:10px;}
.qs-two-text p{font-size:12px;line-height:1.75;}
.qs-wide{margin:0 -48px;}
.qs-wide-inner{position:relative;width:100%;height:auto;border-radius:var(--radius);overflow:hidden;background:#111;}
.qs-wide-img{width:100%;height:100%;object-fit:cover;display:block;}
.qs-wide-mark{position:absolute;right:44px;bottom:-54px;font-size:260px;font-weight:800;line-height:1;color:rgba(179,160,141,0.55);pointer-events:none;user-select:none;}

.qs-steps{max-width:1200px;margin:0 auto;padding-bottom:40px;}
.qs-step{position:relative;display:grid;grid-template-columns:1fr 520px;align-items:center;gap:56px;padding:54px 0;}
.qs-step+.qs-step{border-top:1px solid rgba(21,21,21,.08);}
.qs-step-text{position:relative;z-index:2;padding:0 6px;max-width:520px;}
.qs-step-text h3{font-size:16px;font-weight:800;letter-spacing:-.2px;margin-bottom:10px;}
.qs-step-text p{font-size:12px;line-height:1.8;color:var(--muted);max-width:480px;}
.qs-step-media{position:relative;z-index:2;width:100%;max-width:520px;height:auto;border-radius:0;overflow:visible;background:transparent;box-shadow:none;}
.qs-step-media--composite img{width:100%;height:auto;display:block;}
.qs-step--left{grid-template-columns:520px 1fr;}
.qs-step--left .qs-step-media{justify-self:start;}
.qs-step--right .qs-step-media{justify-self:end;}
.qs-steps-cta{display:flex;justify-content:center;padding-top:34px;}
.qs-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;background:rgba(179,160,141,.3);color:var(--text);text-decoration:none;font-size:11px;font-weight:800;letter-spacing:.6px;transition:background .2s ease,transform .2s ease;}
.qs-btn:hover{background:rgba(179,160,141,.45);transform:translateY(-1px);}
@media (max-width:1024px){.qs-step{grid-template-columns:1fr;gap:18px;padding:42px 0;}.qs-step--left{grid-template-columns:1fr;}.qs-step-text{max-width:640px;}.qs-step-media{max-width:640px;justify-self:start;}.qs-step--right .qs-step-media{justify-self:start;}}
@media (max-width:520px){.qs-step-text h3{font-size:14px;}}

.collections{max-width:1180px;margin:0 auto;}
.col-block{margin:0 auto 56px;}
.col-banner{position:relative;border-radius:var(--radius);overflow:hidden;height:340px;background:#111;margin-bottom:18px;}
.col-banner-img{width:100%;height:100%;object-fit:cover;display:block;}
.col-banner-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:28px;}
.col-banner-overlay h2{color:#fff;font-size:74px;line-height:.95;letter-spacing:1px;font-weight:900;text-align:center;text-transform:uppercase;text-shadow:0 18px 40px rgba(0,0,0,.35);}
.col-card{background:#fff;border-radius:22px;box-shadow:0 1px 0 rgba(0,0,0,.03);}
.col-palette{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:16px 18px;margin:0 auto 16px;}
.col-swatch{display:flex;flex-direction:column;align-items:center;gap:10px;padding:10px 6px;}
.col-swatch .dot{width:44px;height:44px;border-radius:999px;background:var(--c);box-shadow:inset 0 0 0 1px rgba(0,0,0,.06);}
.col-swatch .label{font-size:9px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:rgba(21,21,21,.72);text-align:center;line-height:1.15;}
.col-grid{padding:18px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.col-item{border-radius:18px;overflow:hidden;background:rgba(0,0,0,.03);text-decoration:none;color:inherit;display:flex;flex-direction:column;min-height:230px;}
.col-item-imgwrap{flex:1;display:grid;place-items:center;padding:18px;}
.col-item img{width:100%;height:100%;object-fit:contain;display:block;}
.col-item--photo .col-item-imgwrap{padding:0;} 
.col-item--photo img{object-fit:cover;}
.col-item-meta{padding:12px 14px 14px;text-align:center;}
.col-item-meta .sku{display:block;font-size:10px;font-weight:800;letter-spacing:.5px;color:rgba(21,21,21,.65);margin-bottom:2px;}
.col-item-meta .name{display:block;font-size:10px;font-weight:900;letter-spacing:1px;text-transform:uppercase;color:rgba(21,21,21,.78);}
.col-banner::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(0,0,0,.10),rgba(0,0,0,.35));pointer-events:none;}
@media (max-width:1024px){.collections{max-width:760px;}.col-banner{height:300px;border-radius:20px;}.col-banner-overlay h2{font-size:54px;}.col-palette{grid-template-columns:repeat(2,1fr);}.col-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.col-banner{height:260px;}.col-banner-overlay h2{font-size:40px;}.col-grid{grid-template-columns:1fr;}}

/* ─── Historial de colecciones ─────────────────────────────────────── */
.col-history{max-width:1180px;margin:24px auto 40px;padding:36px 28px;background:#fff;border-radius:var(--radius);box-shadow:0 1px 0 rgba(0,0,0,.03);}
.col-history-title{font-size:13px;font-weight:800;letter-spacing:2.4px;text-transform:uppercase;color:var(--text);text-align:center;margin-bottom:30px;}
.col-history-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px 22px;}
.col-history-item{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;padding:18px 10px;border-radius:18px;background:rgba(0,0,0,.02);text-decoration:none;color:var(--text);transition:background .2s ease,transform .2s ease,box-shadow .2s ease;}
.col-history-item:hover{background:rgba(179,160,141,.12);transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.06);}
.col-history-item:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}
.col-history-icon{width:54px;height:54px;object-fit:contain;display:block;}
.col-history-label{font-size:10px;font-weight:800;letter-spacing:1.1px;text-transform:uppercase;color:rgba(21,21,21,.72);text-align:center;line-height:1.3;}
@media (max-width:1024px){.col-history{max-width:760px;padding:28px 20px;}.col-history-grid{grid-template-columns:repeat(3,1fr);}}
@media (max-width:520px){.col-history{padding:22px 14px;border-radius:20px;}.col-history-grid{grid-template-columns:repeat(2,1fr);gap:12px;}.col-history-icon{width:46px;height:46px;}.col-history-title{font-size:12px;margin-bottom:22px;}}



@media (max-width:1024px){
  .nav-inner{padding:0 22px;}
  .logo{left:22px;max-width:calc(100% - 88px);}
  .logo img{height:28px;max-width:100%;object-fit:contain;object-position:left center;}
  .menu-toggle{display:flex;right:22px;}
  .nav-links{position:fixed;inset:0;background:#fff;flex-direction:column;justify-content:center;gap:18px;transform:translateX(100%);transition:transform .35s ease;}
  .nav-links.active{transform:translateX(0);}
  .nav-links a{font-size:20px;text-transform:uppercase;}
  .nav-links li.active::before{display:none;}
  .container{padding:0 22px 80px;}
  .hero{grid-template-columns:1fr;gap:22px;}
  .hero-media{height:380px;}
  .hero-media::after{font-size:200px;bottom:-110px;}
  .gallery{grid-template-columns:1fr;gap:20px;}
  .card-short,.card-tall{height:400px;}
  .card-wide{grid-column:auto;height:280px;}
  .qs-hero{margin:0 -22px 48px;}
  .qs-hero-inner{height:380px;border-radius:20px;}
  .qs-hero-overlay{padding:36px 28px;}
  .qs-hero-overlay h1{font-size:30px;}
  .qs-intro{margin-bottom:48px;}
  .qs-split{grid-template-columns:1fr;}
  .qs-split-img{height:320px;}
  .qs-split-card{height:auto;padding:40px 30px;}
  .qs-values{padding:60px 0 70px;}
  .qs-values-inner{padding:0 22px;grid-template-columns:1fr;gap:20px;}
  .qs-val-col{gap:20px;}
  .qs-val-col--center{margin-top:0;}
  .qs-val-item--img-only{height:220px;}
  .qs-footer{padding:60px 22px 40px;}
  .qs-footer-contact{flex-direction:column;gap:6px;}
  .qs-hero{margin:0 -22px 48px;}
  .qs-hero-inner{height:380px;border-radius:20px;}
  .qs-hero-overlay{padding:36px 28px;}
  .qs-hero-overlay h1{font-size:30px;}
  .qs-two{grid-template-columns:1fr;gap:28px;max-width:760px;margin-bottom:54px;}
  .qs-two-img{height:320px;}
  .qs-wide{margin:0 -22px;}
  .qs-wide-inner{height:420px;border-radius:20px;}
  .qs-wide-mark{right:20px;bottom:-46px;font-size:220px;}
}

@media (max-width:520px){
  .logo img{height:24px;}
  .logo {top:-12px;}
}





/* ── Sección contenedor ── */
.qs-contact {
  padding: 64px 40px 80px;
  background-color: var(--color-bg, #f2f1ef);
}
 
.qs-contact-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 52px;
  align-items: start;
}
 
/* ── Columna formulario ── */
.qs-contact-form-col {
  display: flex;
  flex-direction: column;
}
 
/* ── Campos individuales ── */
.qs-field {
  margin-bottom: 14px;
}
 
.qs-field-row {
  display: flex;
  gap: 14px;
  margin-bottom: 14px;
}
 
.qs-field-row .qs-field {
  flex: 1;
  margin-bottom: 0;
}
 
/* ── Inputs y textarea ── */
.qs-contact input[type="text"],
.qs-contact input[type="email"],
.qs-contact input[type="tel"],
.qs-contact textarea {
  width: 100%;
  display: block;
  background: #ffffff;
  border: 1px solid #d6d2cc;
  border-radius: 6px;
  padding: 13px 18px;
  font-family: inherit;
  font-size: 13px;
  font-weight: 300;
  color: #2a2a2a;
  letter-spacing: 0.02em;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  outline: none;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
}
 
.qs-contact input::placeholder,
.qs-contact textarea::placeholder {
  color: #999;
  font-weight: 300;
}
 
.qs-contact input:focus,
.qs-contact textarea:focus {
  border-color: #9b8d7a;
  box-shadow: 0 0 0 3px rgba(155, 141, 122, 0.12);
}
 
.qs-contact textarea {
  resize: vertical;
  min-height: 110px;
  line-height: 1.6;
}
 
/* Estado inválido */
.qs-contact input.qs-invalid,
.qs-contact textarea.qs-invalid {
  border-color: #c87070;
  box-shadow: 0 0 0 3px rgba(200, 112, 112, 0.10);
}
 
/* ── Botón enviar ── */
.qs-btn-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 4px;
  padding: 13px 28px;
  background-color: #9b8d7a;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
  cursor: pointer;
  transition: background-color 0.25s ease, transform 0.15s ease;
  min-width: 190px;
}
 
.qs-btn-submit:hover {
  background-color: #7d7060;
  transform: translateY(-1px);
}
 
.qs-btn-submit:active {
  transform: translateY(0);
}
 
.qs-btn-submit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}
 
/* ── Mensajes de feedback ── */
.qs-feedback {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 0.02em;
  margin-bottom: 18px;
}
 
.qs-feedback--ok {
  background: #edf5f0;
  border: 1px solid #b5d4bf;
  color: #3d6b4f;
}
 
.qs-feedback--err {
  background: #f9eded;
  border: 1px solid #d4b5b5;
  color: #8c3333;
}
 
/* ── Columna mapa ── */
.qs-contact-map-col {
  position: sticky;
  top: 40px;
}
 
.qs-map-wrapper { width: 100%; height: 450px; border-radius: 6px; overflow: hidden;  border: 1px solid #d6d2cc;
  filter: grayscale(100%);
  transition: filter 0.3s ease;
}
 
.qs-map-wrapper:hover { filter: grayscale(0%); }
 
/* ── Responsive ── */
@media (max-width: 960px) {
  .qs-contact { padding: 48px 24px 64px; }
  .qs-contact-inner { grid-template-columns: 1fr; gap: 36px; }
  .qs-contact-map-col { position: static; order: -1; }
  .qs-map-wrapper { height: 260px; }
}
 
@media (max-width: 540px) {
  .qs-contact { padding: 36px 16px 56px; }
  .qs-field-row { flex-direction: column; gap: 0; }
  .qs-field-row .qs-field { margin-bottom: 14px; }
}


.reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}
 
/* Variante: aparece desde la izquierda */
.reveal-left {
  opacity: 0;
  transform: translateX(-36px);
  transition: opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}
 
/* Variante: aparece desde la derecha */
.reveal-right {
  opacity: 0;
  transform: translateX(36px);
  transition: opacity 0.65s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.65s cubic-bezier(0.22, 1, 0.36, 1);
}
 
/* Variante: sólo fade, sin movimiento (para imágenes grandes) */
.reveal-fade {
  opacity: 0;
  transition: opacity 0.8s ease;
}
 
/* --- Estado activo: cuando el elemento es visible --- */
.reveal.is-visible,
.reveal-left.is-visible,
.reveal-right.is-visible,
.reveal-fade.is-visible {
  opacity: 1;
  transform: none;
}
 
/* --- Delays escalonados para grupos de elementos --- */
.reveal-group .reveal:nth-child(1) { transition-delay: 0s;    }
.reveal-group .reveal:nth-child(2) { transition-delay: 0.12s; }
.reveal-group .reveal:nth-child(3) { transition-delay: 0.24s; }
.reveal-group .reveal:nth-child(4) { transition-delay: 0.36s; }
.reveal-group .reveal:nth-child(5) { transition-delay: 0.48s; }
.reveal-group .reveal:nth-child(6) { transition-delay: 0.60s; }
 
/* --- Respeta preferencia de movimiento reducido --- */
@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-left,
  .reveal-right,
  .reveal-fade {
    opacity: 1;
    transform: none;
    transition: none;
  }
}





















/* Contenedor relativo para las flechas */
.qs-slider-wrap {
  position: relative;
  padding: 18px;           /* igual que .col-card original */
  overflow: visible;
}

/* Zona de scroll */
.qs-slider {
  overflow: hidden;
  border-radius: 18px;
  cursor: grab;
  user-select: none;
  -webkit-user-select: none;
}
.qs-slider.is-dragging {
  cursor: grabbing;
}

/* Track: fila horizontal de slides */
.qs-slider-track {
  display: flex;
  gap: 18px;
  will-change: transform;
  transition: transform 0.38s cubic-bezier(0.25, 1, 0.5, 1);
}
.qs-slider-track.no-transition {
  transition: none;
}

/* Cada slide */
.qs-slide {
  flex: 0 0 calc(25% - 14px);   /* 4 visibles en escritorio */
  min-width: 0;
  min-height: 230px;
}

/* Flechas */
.qs-slider-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.90);
  box-shadow: 0 2px 12px rgba(0,0,0,0.12);
  cursor: pointer;
  z-index: 10;
  color: #151515;
  transition: background 0.2s, transform 0.2s;
}
.qs-slider-arrow:hover {
  background: #fff;
  transform: translateY(-50%) scale(1.07);
}
.qs-slider-arrow--prev { left: 4px; }
.qs-slider-arrow--next { right: 4px; }
.qs-slider-arrow:disabled {
  opacity: 0.3;
  pointer-events: none;
}

/* Puntos / dots */
.qs-slider-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  padding-top: 16px;
}
.qs-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(21,21,21,0.20);
  border: none;
  cursor: pointer;
  transition: background 0.25s, transform 0.25s;
  padding: 0;
}
.qs-dot.active {
  background: var(--accent, #b3a08d);
  transform: scale(1.4);
}

/* Responsive */
@media (max-width: 1024px) {
  .qs-slide { flex: 0 0 calc(50% - 10px); }   /* 2 visibles */
  .qs-slider-arrow { display: none; }           /* solo swipe en tablet */
}
@media (max-width: 520px) {
  .qs-slide { flex: 0 0 calc(75% - 10px); }    /* 1.25 visibles en móvil */
}








/* =========================================================
   FIX RESPONSIVE — GALERÍA QUEIJA
   Sustituye/añade estas reglas en tu media query (max-width:1024px)
   ========================================================= */

@media (max-width: 1024px) {

  /* Galería: una sola columna, filas automáticas */
  .gallery {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;     /* anula los 40px del desktop */
    gap: 20px;
  }

  /* RESET de las posiciones nth-child del desktop.
     Sin esto, las cards siguen ocupando "span 9", "span 13"...
     y eso es lo que crea los huecos blancos en móvil. */
  .gallery .card,
  .gallery .card:nth-child(1),
  .gallery .card:nth-child(2),
  .gallery .card:nth-child(3),
  .gallery .card:nth-child(4) {
    grid-column: 1 / -1;      /* ocupan toda la fila */
    grid-row: auto;           /* sin spans forzados */
    height: 360px;            /* altura uniforme y razonable en móvil */
  }

  /* Las "wide" también una columna */
  .gallery .card-wide {
    grid-column: 1 / -1;
    grid-row: auto;
    height: 280px;
  }

  /* La imagen siempre cubre la card */
  .gallery .card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
}

/* Móvil más pequeño: cards algo más bajas */
@media (max-width: 520px) {
  .gallery .card,
  .gallery .card:nth-child(1),
  .gallery .card:nth-child(2),
  .gallery .card:nth-child(3),
  .gallery .card:nth-child(4) {
    height: 300px;
  }
  .gallery .card-wide {
    height: 240px;
  }
}




/* =========================================================
   Q construida con DOS máscaras (anillo + cola)
   Cada parte se pinta del color que queramos vía CSS
   ========================================================= */
 
.hero-media{
  position: relative;
  width: 100%;
  height: 460px;
  border-radius: var(--radius);
  overflow: visible;
  background: #d7d7d7;
}
 
.hero-media > img,
.hero-media > video{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: var(--radius);
}
 
/* === ANILLO (parte blanca de la Q) === */
.hero-media::after {
    content: "";
    position: absolute;
    left: calc(50% - 160px);
    bottom: -132px;
    width: 270px;
    height: 260px;
    background-image: url(/images/q-queija.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    pointer-events: none;
    z-index: 5;
}
 
/* ----- Responsive ----- */
@media (max-width: 1024px){
  .hero-media{ height: 380px; }
  .hero-media::after,
  .hero-media::before{
    width: 220px;
    height: 220px;
    left: 50%;
    transform: translateX(-50%);
    bottom: -80px;
  }
}
 
@media (max-width: 520px){
  .hero-media::after,
  .hero-media::before{
    width: 170px;
    height: 170px;
    bottom: -60px;
  }
}








.qslider, .qslider *, .qslider *::before, .qslider *::after {
  box-sizing: border-box;
}
.qslider ul,
.qslider ol,
.qslider li {
  list-style: none !important;     /* quita los puntos de los <li> */
  margin: 0;
  padding: 0;
}

.qslider {
  --qs-bg: #f4f4f4;
  --qs-card-bg: #ffffff;
  --qs-text: #151515;
  --qs-radius: 18px;
  --qs-radius-lg: 22px;
  --qs-arrow-size: 44px;
  --qs-gap: 28px;
  --qs-transition: 520ms cubic-bezier(.22, .61, .36, 1);

  position: relative;
  width: 100%;
  background: var(--qs-bg);
  padding: 60px 0;
  overflow: hidden;          /* las cards laterales asoman pero no desbordan */
  font-family: inherit;       /* hereda la tipografía del sitio */
}

/* Pista (track) que se desliza horizontalmente */
.qslider__viewport {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.qslider__track {
  display: flex;
  align-items: center;        /* alineación vertical centrada */
  gap: var(--qs-gap);
  transition: transform var(--qs-transition);
  will-change: transform;
  padding: 0 var(--qs-gap);   /* respiración para que la primera/última card no toque el borde */
}

/* Cada slide */
.qslider__slide {
  flex: 0 0 auto;
  width: 33%;                 /* 3 cards visibles en desktop */
  max-width: 460px;
  transition: transform var(--qs-transition), opacity var(--qs-transition);
  transform: scale(.86);      /* laterales más pequeñas */
  opacity: .85;
}

/* Card central destacada — más grande */
.qslider__slide.is-active {
  transform: scale(1);
  opacity: 1;
  z-index: 2;
}

/* Cuerpo de la card */
.qslider__card {
  background: var(--qs-card-bg);
  border-radius: var(--qs-radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 6px 22px rgba(40, 30, 20, .06);
}

.qslider__media {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;        /* cuadrada como en la referencia */
  overflow: hidden;
  border-radius: var(--qs-radius);
  margin: 0;
  background: #e9e2d500;
  cursor: grab;               /* feedback de "arrastrable" en desktop */
  touch-action: pan-y;        /* permite scroll vertical, captamos el horizontal */
  user-select: none;
  -webkit-user-select: none;
}
.qslider__media:active { cursor: grabbing; }
.qslider__media img { -webkit-user-drag: none; user-drag: none; pointer-events: none; }
/* Las imágenes no capturan eventos para que el pointer drag funcione limpio.
   Los dots SÍ los capturan porque son hijos posteriores con z-index. */
.qslider__media-dots { pointer-events: auto; }

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

/* ----------- Capas de imágenes (cross-fade dentro de la card) ----------- */
.qslider__media-stack {
  position: absolute;
  inset: 0;
}
.qslider__media-stack img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  opacity: 0;
  transition: opacity 380ms ease;
}
.qslider__media-stack img.is-active {
  opacity: 1;
}

/* ----------- Dots internos (sobre la imagen, abajo) ----------- */
.qslider__media-dots {
  position: absolute;
  left: 50%;
  bottom: 14px;
  transform: translateX(-50%);
  display: flex;
  gap: 7px;
  z-index: 3;
  padding: 6px 10px;
  background: rgba(255, 255, 255, .55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-radius: 999px;
}
.qslider__media-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(21, 21, 21, .35);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background .2s ease, transform .2s ease;
}
.qslider__media-dot:hover { transform: scale(1.15); }
.qslider__media-dot.is-active {
  background: var(--qs-text);
}
.qslider__media-dot:focus-visible {
  outline: 2px solid var(--qs-text);
  outline-offset: 2px;
}

.qslider__label {
  text-align: center;
  padding: 28px 16px 32px;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: .2px;
  color: var(--qs-text);
}

/* La card activa tiene un label un poco mayor */
.qslider__slide.is-active .qslider__label {
  font-size: 26px;
}

/* ----------- Flechas de navegación ----------- */
.qslider__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: var(--qs-arrow-size);
  height: var(--qs-arrow-size);
  border-radius: 50%;
  background: #ffffff;
  border: none;
  cursor: pointer;
  display: grid;
  place-items: center;
  box-shadow: 0 2px 10px rgba(0, 0, 0, .08);
  z-index: 5;
  transition: background .2s ease, transform .2s ease;
  color: var(--qs-text);
}

.qslider__arrow:hover {
  background: #fafafa;
  transform: translateY(-50%) scale(1.05);
}

.qslider__arrow:focus-visible {
  outline: 2px solid var(--qs-text);
  outline-offset: 3px;
}

.qslider__arrow--prev { left: 18px; }
.qslider__arrow--next { right: 18px; }

.qslider__arrow svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 2;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* ----------- Indicadores (dots) ----------- */
.qslider__dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 32px;
}

.qslider__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(21, 21, 21, .2);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background .2s ease, width .2s ease;
}

.qslider__dot.is-active {
  background: var(--qs-text);
  width: 22px;
  border-radius: 999px;
}

/* ============ RESPONSIVE ============ */

/* Tablet: 3 cards pero algo más juntas */
@media (max-width: 1024px) {
  .qslider {
    --qs-gap: 20px;
    padding: 50px 0;
  }
  .qslider__slide { width: 38%; }
  .qslider__slide.is-active { transform: scale(1.05); }
  .qslider__label { font-size: 18px; }
  .qslider__slide.is-active .qslider__label { font-size: 22px; }
}

/* Móvil: 1 card central destacada + asomos laterales */
@media (max-width: 720px) {
  .qslider {
    --qs-gap: 14px;
    --qs-arrow-size: 38px;
    padding: 36px 0;
  }
  .qslider__slide {
    width: 72%;               /* la activa ocupa casi toda la pantalla */
    transform: scale(.82);
  }
  .qslider__slide.is-active {
    transform: scale(1);
  }
  .qslider__arrow--prev { left: 8px; }
  .qslider__arrow--next { right: 8px; }
  .qslider__label { font-size: 16px; padding: 20px 12px 24px; }
  .qslider__slide.is-active .qslider__label { font-size: 19px; }
}

/* Móvil pequeño */
@media (max-width: 420px) {
  .qslider__slide { width: 78%; }
}

/* Respeta el "reduce motion" del sistema */
@media (prefers-reduced-motion: reduce) {
  .qslider__track,
  .qslider__slide {
    transition: none;
  }
}

















/*
    
    :root{
      --bg: #f4f4f4;
      --text: #151515;
      --muted: #6b6b6b;
      --accent: #b3a08d;
      --radius: 28px;
      --container: 1800px;
    }

    *{ margin:0; padding:0; box-sizing:border-box; }
    body{
      font-family: "Helvetica Neue", Arial, sans-serif;
      background: var(--bg);
      color: var(--text);
    }


    .navbar {  position: sticky;
      top: 0;
      background: var(--bg);
      z-index: 50;
      padding: 26px 0;
    }

    .nav-inner{
      max-width: var(--container);
      margin: 0 auto;
      padding: 0 48px;
      position: relative;
      display:flex;
      align-items:center;
      justify-content:center;
    }

    .logo{
      position:absolute;
      left: 48px;
      display:flex;
      align-items:center;
      gap:10px;
    }
    .logo img{ height: 34px; display:block; }

    .nav-links{
      list-style:none;
      display:flex;
      gap: 26px;
      align-items:center;
    }
    .nav-links a{
      text-decoration:none;
      color: var(--text);
      font-size: 12px;
      font-weight: 700;
      letter-spacing: .3px;
    }
    .nav-links li{ position:relative; }
    .nav-links li.active::before{
      content:"";
      position:absolute;
      top:-14px;
      left:50%;
      transform:translateX(-50%);
      width:6px;height:6px;border-radius:999px;
      background: var(--accent);
    }

    .menu-toggle{
      display:none;
      position:absolute;
      right:48px;
      top:50%;
      transform:translateY(-50%);
      flex-direction:column;
      gap:6px;
      cursor:pointer;
      z-index:60;
    }
    .menu-toggle span{
      width:30px;
      height:2px;
      background: var(--text);
      transition:.25s ease;
    }


    .container{
      max-width: var(--container);
      margin: 0 auto;
      padding: 0 48px 90px;
    }

    .hero{
      display:grid;
      grid-template-columns: 1.05fr .95fr;
      gap: 46px;
      align-items:start;
      padding-top: 22px;
      padding-bottom: 46px;
    }

    .hero h1{
      font-size: 58px;
      line-height: 1.02;
      font-weight: 800;
      letter-spacing: -1px;
      margin-top: 10px;
    }

    .hero .sub{
      margin-top: 18px;
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 1.6px;
      max-width: 460px;
    }

    .hero .para{
      margin-top: 18px;
      font-size: 12px;
      line-height: 1.7;
      color: var(--muted);
      max-width: 480px;
    }

    .hero-media{
      position:relative;
      width: 100%;
      height: 460px;
      border-radius: var(--radius);
      overflow:hidden;
      background:#d7d7d7;
    }
    .hero-media img{
      width:100%;
      height:100%;
      object-fit:cover;
      display:block;
    }

    .hero-media::after{
      content:"Q";
      position:absolute;
      left: 18px;
      bottom: -120px;
      font-size: 240px;
      font-weight: 800;
      color: rgba(179,160,141,.55);
      line-height: 1;
      pointer-events:none;
      filter: saturate(0.95);
    }

    .gallery{
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      grid-auto-rows: 40px;
      gap: 24px;
      padding-top: 14px;
    }

    .card{
      position: relative;
      border-radius: var(--radius);
      overflow: hidden;
      background: #ddd;
    }
    
    .card img{
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .card:nth-child(1){ grid-column: 1 / 2; grid-row: span 9; }
    .card:nth-child(2){ grid-column: 2 / 3; grid-row: span 13; }
    .card:nth-child(3){ grid-column: 1 / 2; grid-row: span 13; }
    .card:nth-child(4){ grid-column: 2 / 3; grid-row: span 9; }

    .card-wide{
      grid-column: 1 / -1;
      grid-row: span 7;
    }

    .card-content{
      position: absolute;
      left: 26px;
      bottom: 22px;
      color: #fff;
      text-shadow: 0 8px 24px rgba(0,0,0,.35);
      z-index: 10;
    }
    
    .card-content .kicker{
      font-size: 11px;
      text-transform: uppercase;
      letter-spacing: 2px;
      opacity: .95;
      display: block;
      margin-bottom: 6px;
      font-weight: 700;
    }
    
    .card-content a{
      color: #fff;
      font-size: 12px;
      font-weight: 700;
      text-decoration: underline;
      transition: opacity 0.3s ease;
    }
    
    .card-content a:hover{ opacity: 0.8; }

    footer{
      text-align:center;
      padding-top: 70px;
    }
    .footer-logo{
      font-size: 26px;
      letter-spacing: 10px;
      opacity: .85;
      margin-bottom: 18px;
    }
    .footer-small{
      font-size: 11px;
      color: #8a8a8a;
      margin-bottom: 16px;
    }
    .social{
      display:flex;
      justify-content:center;
      gap: 14px;
      margin-top: 6px;
    }
    .social a{
      width: 26px; height: 26px;
      display:grid; place-items:center;
      border-radius: 8px;
      text-decoration:none;
      color: var(--text);
      background: rgba(0,0,0,.05);
      font-size: 12px;
    }

    .qs-hero {
      margin: 0 -48px;          
      margin-bottom: 72px;
    }

    .qs-hero-inner {
      position: relative;
      width: 100%;
      height: 480px;
      border-radius: var(--radius);
      overflow: hidden;
      background: #1a1a1a;
    }

    .qs-hero-img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 20%;
      display: block;
      filter: grayscale(100%) brightness(0.55);
    }

    .qs-hero-overlay {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      justify-content: center;
      padding: 52px 60px;
      align-items: center;
    }

    .qs-hero-overlay h1 {
      font-size: 46px;
      font-weight: 800;
      line-height: 1.05;
      letter-spacing: -0.5px;
      color: #fff;
      text-transform: uppercase;
      margin-bottom: 18px;
      text-align: center;
    }

    .qs-hero-sub {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 1.8px;
      text-transform: uppercase;
      color: rgba(255,255,255,0.80);
      line-height: 1.7;
      text-align: center;
    }

    .qs-intro {
      max-width: 720px;
      margin: 0 auto 72px;
      text-align: center;
    }

    .qs-intro p {
      font-size: 13px;
      line-height: 1.8;
      color: var(--text);
    }

    .qs-split {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      margin-bottom: 0;
    }

    .qs-split-img {
      border-radius: var(--radius);
      overflow: hidden;
      height: 400px;
      background: #ccc;
    }

    .qs-split-img img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      filter: grayscale(100%);
    }

    .qs-split-card {
      background: #1e1e1e;
      border-radius: var(--radius);
      padding: 52px 48px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 20px;
      height: 400px;
    }

    .qs-split-card p {
      font-size: 13px;
      line-height: 1.8;
      color: rgba(255,255,255,0.70);
    }

    .qs-split-highlight {
      font-size: 14px !important;
      font-weight: 700 !important;
      color: #fff !important;
    }

    .qs-values {
      background: #1a1a1a;
      margin-top: 80px;
      padding: 80px 0 90px;
    }

    .qs-values-inner {
      max-width: var(--container);
      margin: 0 auto;
      padding: 0 48px;
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 28px;
      align-items: start;
    }

    .qs-val-col {
      display: flex;
      flex-direction: column;
      gap: 28px;
    }

    .qs-val-col--center {
      gap: 24px;
    }

    .qs-val-item--img-only {
      border-radius: var(--radius);
      overflow: hidden;
      height: 260px;
      background: #333;
    }

    .qs-val-item--img-only img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      filter: grayscale(100%) brightness(0.85);
    }

    .qs-val-item--text {
      padding: 0 4px;
    }

    .qs-val-item--text h3 {
      font-size: 12px;
      font-weight: 800;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: #fff;
      margin-bottom: 8px;
    }

    .qs-val-item--text p {
      font-size: 12px;
      line-height: 1.65;
      color: rgba(255,255,255,0.55);
    }

    .qs-val-item--card {
      border-radius: var(--radius);
      overflow: hidden;
      background: #2a2a2a;
    }

    .qs-val-item--card img {
      width: 100%;
      height: 200px;
      object-fit: cover;
      display: block;
      filter: grayscale(100%) brightness(0.85);
    }

    .qs-val-item--card h3 {
      font-size: 12px;
      font-weight: 800;
      letter-spacing: 2px;
      text-transform: uppercase;
      color: #fff;
      padding: 20px 22px 6px;
    }

    .qs-val-item--card p {
      font-size: 12px;
      line-height: 1.65;
      color: rgba(255,255,255,0.55);
      padding: 0 22px 22px;
    }

    .qs-footer {
      background: var(--bg);
      padding: 70px 48px 48px;
      text-align: center;
    }

    .qs-footer-logo {
      font-family: Georgia, "Times New Roman", serif;
      font-style: italic;
      font-size: 42px;
      font-weight: 400;
      letter-spacing: 1px;
      color: var(--text);
      margin-bottom: 16px;
    }

    .qs-footer-address {
      font-size: 11px;
      color: var(--muted);
      margin-bottom: 12px;
    }

    .qs-footer-contact {
      display: flex;
      justify-content: center;
      gap: 24px;
      font-size: 11px;
      color: var(--muted);
      margin-bottom: 16px;
    }

    .qs-footer-links {
      display: flex;
      justify-content: center;
      gap: 18px;
      margin-bottom: 18px;
    }

    .qs-footer-links a {
      font-size: 10px;
      color: var(--muted);
      text-decoration: none;
      transition: color 0.2s;
    }

    .qs-footer-links a:hover { color: var(--text); }

    .qs-footer-social {
      display: flex;
      justify-content: center;
      gap: 12px;
    }

    .qs-footer-social a {
      width: 32px;
      height: 32px;
      display: grid;
      place-items: center;
      border-radius: 8px;
      background: rgba(0,0,0,0.06);
      color: var(--text);
      text-decoration: none;
      transition: background 0.2s;
    }

    .qs-footer-social a:hover { background: rgba(0,0,0,0.12); }

    @media (max-width: 1024px){
      .nav-inner{ padding: 0 22px; }
      .logo{ left: 22px; max-width: calc(100% - 88px); }
      .logo img{ height: 28px; max-width:100%; object-fit:contain; object-position:left center; }
      .menu-toggle{ display:flex; right:22px; }

      .nav-links{
        position:fixed;
        inset:0;
        background:#fff;
        flex-direction:column;
        justify-content:center;
        gap: 18px;
        transform: translateX(100%);
        transition: transform .35s ease;
      }
      .nav-links.active{ transform: translateX(0); }
      .nav-links a{ font-size: 20px; text-transform: uppercase; }
      .nav-links li.active::before{ display:none; }

      .container{ padding: 0 22px 80px; }

      .hero{ grid-template-columns: 1fr; gap: 22px; }
      .hero-media{ height: 380px; }
      .hero-media::after{ font-size: 200px; bottom: -110px; }

      .gallery{ grid-template-columns: 1fr; gap: 20px; }
      .card-short, .card-tall{ height: 400px; }
      .card-wide{ grid-column: auto; height: 280px; }

      .qs-hero { margin: 0 -22px 48px; }
      .qs-hero-inner { height: 380px; border-radius: 20px; }
      .qs-hero-overlay { padding: 36px 28px; }
      .qs-hero-overlay h1 { font-size: 30px; }

      .qs-intro { margin-bottom: 48px; }

      .qs-split { grid-template-columns: 1fr; }
      .qs-split-img { height: 320px; }
      .qs-split-card { height: auto; padding: 40px 30px; }
      .qs-values { padding: 60px 0 70px; }
      .qs-values-inner {
        padding: 0 22px;
        grid-template-columns: 1fr;
        gap: 20px;
      }
      .qs-val-col { gap: 20px; }
      .qs-val-item--img-only { height: 220px; }

      .qs-footer { padding: 60px 22px 40px; }
      .qs-footer-contact { flex-direction: column; gap: 6px; }
    }

.qs-hero{
  margin: 0 -48px 72px;
}
.qs-hero-inner{
  position: relative;
  width: 100%;
  height: 480px;
  border-radius: var(--radius);
  overflow: hidden;
  background: #1a1a1a;
}
.qs-hero-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  display: block;
  filter: grayscale(100%) brightness(0.55);
}
.qs-hero-overlay{
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 52px 60px;
  text-align: center;
}
.qs-hero-overlay h1{
  font-size: 46px;
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.5px;
  color: #fff;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.qs-hero-sub{
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.80);
  line-height: 1.7;
}

.qs-intro{
  max-width: 760px;
  margin: 0 auto 64px;
  text-align: center;
}
.qs-intro p{
  font-size: 13px;
  line-height: 1.9;
  color: var(--text);
}
.qs-intro p + p{ margin-top: 12px; }

.qs-intro-kicker{
  margin-top: 18px;
  font-size: 10px;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: rgba(21,21,21,0.55);
  font-weight: 700;
}

.qs-two{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 44px;
  align-items: start;
  margin: 0 auto 70px;
  max-width: 1180px;
}
.qs-two-item{
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.qs-two-img{
  border-radius: var(--radius);
  overflow: hidden;
  background: #ddd;
}
.qs-two-img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.qs-two-text{
  padding: 0 6px;
}
.qs-two-text h3{
  font-size: 12px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 10px;
}
.qs-two-text p{
  font-size: 12px;
  line-height: 1.75;
}

.qs-wide{
  margin: 0 -48px;
}
.qs-wide-inner{
  position: relative;
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  overflow: hidden;
  background: #111;
}
.qs-wide-img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.qs-wide-mark{
  position: absolute;
  right: 44px;
  bottom: -54px;
  font-size: 260px;
  font-weight: 800;
  line-height: 1;
  color: rgba(179,160,141,0.55);
  pointer-events: none;
  user-select: none;
}


@media (max-width: 1024px){
  .qs-hero{ margin: 0 -22px 48px; }
  .qs-hero-inner{ height: 380px; border-radius: 20px; }
  .qs-hero-overlay{ padding: 36px 28px; }
  .qs-hero-overlay h1{ font-size: 30px; }

  .qs-two{
    grid-template-columns: 1fr;
    gap: 28px;
    max-width: 760px;
    margin-bottom: 54px;
  }
  .qs-two-img{ height: 320px; }

  .qs-wide{ margin: 0 -22px; }
  .qs-wide-inner{ height: 420px; border-radius: 20px; }
  .qs-wide-mark{
    right: 20px;
    bottom: -46px;
    font-size: 220px;
  }
}
*/
/* ──────────────────────────────────────────────────────────
   Selector de idioma (desplegable)
   ────────────────────────────────────────────────────────── */
.lang-switch{position:relative;}
.lang-dd{position:relative;}
.lang-dd[open] .lang-dd-caret{transform:rotate(180deg);}

/* Versión DESKTOP: pegado a la derecha del navbar */
.lang-switch--desktop{
  position:absolute;
  right:48px;
  top:50%;
  transform:translateY(-50%);
  z-index:55;
}

/* Versión MÓVIL: oculta en desktop (vive dentro del menú hamburguesa) */
.lang-switch-mobile-wrap{display:none;}

/* Resetear el marcador nativo de <summary> */
.lang-dd-current{
  list-style:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.3px;
  color:var(--text);
  user-select:none;
  padding:4px 2px;
  outline:none;
}
.lang-dd-current::-webkit-details-marker{display:none;}
.lang-dd-current::marker{content:"";}
.lang-dd-current:focus-visible{outline:1px dotted var(--text);outline-offset:4px;}

.lang-dd-caret{transition:transform .18s ease;flex-shrink:0;}

/* Menú desplegado */
.lang-dd-menu{
  position:absolute;
  top:calc(100% + 10px);
  right:0;            /* alineado al borde derecho del selector */
  min-width:60px;
  list-style:none;
  margin:0;
  padding:6px 0;
  background:var(--bg);
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 6px 18px rgba(0,0,0,.06);
  z-index:60;
  animation:langDdIn .18s ease both;
}
.lang-dd-menu li{margin:0;}
.lang-dd-menu a{
  display:block;
  padding:8px 16px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.3px;
  color:var(--text);
  text-decoration:none;
  text-align:center;
  transition:background .15s ease;
}
.lang-dd-menu a:hover,
.lang-dd-menu a:focus-visible{background:rgba(0,0,0,.05);outline:none;}

@keyframes langDdIn{
  from{opacity:0;transform:translateY(-4px);}
  to  {opacity:1;transform:translateY(0);}
}

/* ── MÓVIL ────────────────────────────────────────────────── */
@media (max-width:980px){
  /* En móvil ocultamos la versión desktop y mostramos la del hamburguesa */
  .lang-switch--desktop{display:none;}
  .lang-switch-mobile-wrap{display:block;}

  /* Dentro del menú hamburguesa: sin desplegable, idiomas en línea */
  .lang-switch--mobile .lang-dd-menu{
    position:static;
    border:none;
    box-shadow:none;
    background:transparent;
    padding:0;
    display:flex;
    gap:18px;
    justify-content:center;
    margin-top:10px;
    animation:none;
  }
  .lang-switch--mobile .lang-dd-menu a{padding:4px 8px;font-size:18px;}
  .lang-switch--mobile .lang-dd-current{font-size:18px;justify-content:center;}
}
