/* ======================================================================
   CoreBistro ?Zorastra: Spanish Market
   2026-05-16: Zorastra brand, 3-col Product Cards
   2026-05-19: Product showcase carousel replaces old hero-module SVG
   ====================================================================== */

:root {
  --blue: #0066CC;
  --blue-dark: #0052a3;
  --blue-xlight: #eff6ff;
  --orange: #C8963E;
  --orange-light: #f5e6ce;
  --red: #c0392b;
  --green: #27ae60;
  --text-body: #1e293b;
  --text-mid: #475569;
  --text-light: #64748b;
  --border: #e0e4e8;
  --white: #fff;
  --bg: #f8fafc;
  --bg-card: #fff;
  --shadow: 0 1px 3px rgba(0,0,0,0.06);
  --radius: 12px;
  --market: #C8A200; /* Spanish gold */
  --market-light: #fff6d6;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;color:var(--text-body);background:var(--bg);line-height:1.6}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:0 24px}

/* ======================================================================
   NAV
   ====================================================================== */
nav{position:sticky;top:0;z-index:100;background:var(--white);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;max-width:1200px;margin:0 auto;padding:0 24px}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.2rem}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:0.9rem;font-weight:500;color:var(--text-mid);transition:color .15s;padding:4px 0}
.nav-links a:hover{color:var(--blue)}
.nav-cta{margin-left:8px;padding:10px 22px;background:var(--market)!important;color:#ffffff!important;font-weight:700;font-size:0.92rem;border-radius:8px;transition:background .2s,transform .15s,box-shadow .15s;box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.nav-cta:hover{opacity:.92;transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,0.22)}
.nav-toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:8px;outline:none}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text-body);border-radius:1px}
.nav-cta-mobile{display:block;margin-top:8px;padding:13px 24px;background:var(--market)!important;color:#ffffff!important;font-weight:700;font-size:0.95rem;border-radius:8px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.nav-mobile{display:none;flex-direction:column;gap:6px;padding:0 24px 16px;background:var(--white);border-top:1px solid var(--border)}

@media (max-width:768px){.nav-links,.nav-cta{display:none}.nav-toggle{display:flex}.nav-mobile.open{display:flex}}

/* ======================================================================
   NAV LANG DROPDOWN
   ====================================================================== */
.nav-lang{position:relative}
.nav-lang-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:7px 14px;font-size:0.85rem;cursor:pointer;display:flex;align-items:center;gap:4px;color:var(--text-mid)}





@media (max-width:768px){.nav-lang{margin-left:auto}}

/* ======================================================================
   HERO - left text + right product showcase (opacity fade carousel)
   ====================================================================== */
.hero{padding:64px 0;background:var(--white);border-bottom:1px solid var(--border);text-align:center}
.hero-inner{max-width:800px;margin:0 auto;text-align:center}
.hero-inner>div{text-align:center}
.hero-badge{display:inline-block;padding:5px 14px;background:var(--market-light);border-radius:20px;font-size:0.78rem;color:#6b5700;font-weight:500;margin:12px 0}
.hero-badge-dot{display:inline-block;width:6px;height:6px;background:var(--market);border-radius:50%;margin-right:4px}
.es-badge{display:inline-block;padding:4px 12px;background:var(--market-light);border:1px solid #e6d08e;border-radius:6px;font-size:0.82rem;color:#6b5700;font-weight:600;margin-bottom:8px}
.hero h1{font-size:2.2rem;font-weight:800;line-height:1.25;margin:8px 0 16px;color:var(--text-body)}
.es-highlight{color:var(--market)}
.hero-sub{font-size:1rem;color:var(--text-mid);line-height:1.6;max-width:540px;margin-bottom:24px}
.hero-btns{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;background:var(--blue);color:var(--white);border-radius:8px;font-weight:600;font-size:0.95rem;transition:opacity .15s}
.btn-primary:hover{opacity:.9}
.btn-secondary{display:inline-flex;align-items:center;padding:12px 28px;background:var(--white);color:var(--blue);border:1px solid var(--blue);border-radius:8px;font-weight:600;font-size:0.95rem;transition:background .15s}
.btn-secondary:hover{background:var(--blue-xlight)}

/* === product showcase: fade carousel (opacity cross-fade, 4 slides) === */







@keyframes fs1{0%,21%{opacity:1}25%,100%{opacity:0}}
@keyframes fs2{0%,21%{opacity:0}25%,46%{opacity:1}50%,100%{opacity:0}}
@keyframes fs3{0%,46%{opacity:0}50%,71%{opacity:1}75%,100%{opacity:0}}
@keyframes fs4{0%,71%{opacity:0}75%,96%{opacity:1}100%{opacity:0}}

/* dots */






@keyframes sd1{0%,21%{background:rgba(0,0,0,0.35)}25%,100%{background:rgba(0,0,0,0.12)}}
@keyframes sd2{0%,21%{background:rgba(0,0,0,0.12)}25%,46%{background:rgba(0,0,0,0.35)}50%,100%{background:rgba(0,0,0,0.12)}}
@keyframes sd3{0%,46%{background:rgba(0,0,0,0.12)}50%,71%{background:rgba(0,0,0,0.35)}75%,100%{background:rgba(0,0,0,0.12)}}
@keyframes sd4{0%,71%{background:rgba(0,0,0,0.12)}75%,96%{background:rgba(0,0,0,0.35)}100%{background:rgba(0,0,0,0.12)}}

@media(max-width:900px){.hero-inner{grid-template-columns:1fr}}

/* ======================================================================
   FTA BANNER
   ====================================================================== */
.fta-banner{padding:28px 0;background:linear-gradient(135deg,var(--market-light),#fff8e1);border-bottom:1px solid var(--border)}
.fta-banner h3{font-size:1.15rem;font-weight:700}
.fta-banner p{font-size:0.92rem;color:var(--text-mid);margin-top:4px}

/* ======================================================================
   SECTION COMMON
   ====================================================================== */
.section{padding:72px 0}
.section-label{font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--blue);margin-bottom:12px}
.section-title{font-size:1.8rem;font-weight:800;margin-bottom:16px;color:var(--text-body)}
.section-desc{font-size:1rem;color:var(--text-mid);max-width:680px;margin-bottom:40px}

/* ======================================================================
   PRODUCT CARDS (3-column grid)
   ====================================================================== */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:56px}
.product-category{margin-bottom:56px}
.product-category h3{font-size:1.3rem;margin-bottom:16px;color:var(--text-body);padding-bottom:8px;border-bottom:2px solid var(--blue-xlight)}
.product-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column;gap:14px}
.product-card:hover{box-shadow:0 8px 24px rgba(0,0,0,0.08);transform:translateY(-2px)}
.card-tag{display:inline-block;font-size:0.72rem;font-weight:700;text-transform:uppercase;padding:3px 10px;border-radius:4px;width:fit-content}
.tag-home{background:#dbeafe;color:#0066CC}
.tag-offgrid{background:#fff6d6;color:#6b5700}
.tag-pump{background:#e0f2fe;color:#065f8a}
.product-card h4{font-size:1.05rem;font-weight:700;color:var(--text-body)}
.card-sku{font-size:0.78rem;color:var(--text-light);font-family:monospace}
.card-specs{list-style:none;font-size:0.85rem;color:var(--text-mid);display:flex;flex-direction:column;gap:4px}
.card-specs li::before{content:'?';color:var(--green);font-weight:700}
.card-price{font-size:0.88rem;font-weight:600;color:var(--blue);margin-top:auto}

@media(max-width:768px){.product-grid{grid-template-columns:1fr}}

/* ======================================================================
   SPEC TABLE
   ====================================================================== */
.spec-table{width:100%;border-collapse:collapse;font-size:0.9rem}
.spec-table thead{background:var(--blue);color:var(--white)}
.spec-table th{padding:12px 16px;text-align:left;font-weight:600;font-size:0.85rem}
.spec-table td{padding:11px 16px;border-bottom:1px solid var(--border)}
.spec-table tbody tr:hover{background:#f8fafc}

/* ======================================================================
   WHY US CARDS
   ====================================================================== */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.why-icon{font-size:1.6rem;margin-bottom:12px}
.why-card h4{font-size:1rem;font-weight:700;margin-bottom:8px}
.why-card p{font-size:0.88rem;color:var(--text-mid)}
@media(max-width:768px){.why-grid{grid-template-columns:1fr}}

/* ======================================================================
   APP CARDS
   ====================================================================== */
.app-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.app-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.app-icon{font-size:1.8rem;margin-bottom:12px}
.app-card h4{font-size:1rem;font-weight:700;margin-bottom:8px}
.app-card p{font-size:0.88rem;color:var(--text-mid)}
@media(max-width:768px){.app-grid{grid-template-columns:1fr}}

/* ======================================================================
   FAQ
   ====================================================================== */
.faq-list{max-width:720px}
.faq-item{border-bottom:1px solid var(--border);padding:20px 0}
.faq-q{font-size:1.05rem;font-weight:700;margin-bottom:8px;color:var(--text-body)}
.faq-a{font-size:0.92rem;color:var(--text-mid)}


.cert-bar{display:flex;flex-wrap:wrap;gap:12px;margin:8px 0}
.cert-bar span{font-size:0.78rem;background:var(--blue-xlight);color:var(--blue);padding:4px 12px;border-radius:20px;font-weight:500}

/* ======================================================================
   CTA
   ====================================================================== */
.cta{padding:64px 0;background:var(--blue);color:var(--white);text-align:center}
.cta h2{font-size:1.8rem;font-weight:800;margin-bottom:16px}
.cta p{font-size:1rem;opacity:.85;max-width:600px;margin:0 auto 24px}
.cta .btn-primary{background:var(--white);color:var(--blue)}
.cta .btn-primary:hover{background:#e8f2ee}
.cta .btn-secondary{color:var(--white);border-color:rgba(255,255,255,.4)}
.cta .btn-secondary:hover{background:rgba(255,255,255,.08)}

/* ======================================================================
   FOOTER
   ====================================================================== */
footer{padding:48px 0;background:#0f172a;color:rgba(255,255,255,.7);font-size:0.85rem}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.footer-col h4{color:var(--white);font-weight:700;margin-bottom:12px;font-size:0.92rem}
.footer-col a{display:block;color:rgba(255,255,255,.55);padding:3px 0;transition:color .15s}
.footer-col a:hover{color:var(--white)}
.footer-bottom{margin-top:40px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr}}

/* ======================================================================
   RESPONSIVE
   ====================================================================== */
@media(max-width:640px){
  nav{position:static}
  .hero{padding:40px 0}
  .hero h1{font-size:1.6rem}
  .section{padding:48px 0}
  .section-title{font-size:1.4rem}
}

.stats-strip{display:flex;gap:32px;justify-content:center;padding:40px 0;flex-wrap:wrap;border-top:1px solid var(--border)}
.stat-item{text-align:center}
.stat-num{font-size:1.6rem;font-weight:800;color:var(--market)}
.stat-label{font-size:0.82rem;color:var(--text-light);margin-top:4px}
/* Cert Grid Cards */
.cert-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:24px}
.cert-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:18px 20px}
.cert-card .cert-badge{display:inline-block;background:var(--market);color:#fff;font-size:0.75rem;font-weight:700;padding:3px 10px;border-radius:20px;margin-bottom:8px;letter-spacing:0.04em}
.cert-card .cert-name{font-weight:600;font-size:0.9rem;margin-bottom:4px;color:var(--text-body)}
.cert-card .cert-desc{font-size:0.83rem;color:var(--text-mid);line-height:1.5}

/* FAQ clean accordion */
.faq-list .faq-item{border-bottom:1px solid var(--border)}
.faq-list .faq-q{width:100%;text-align:left;background:none;border:none;padding:18px 0;font-size:1rem;font-weight:600;color:var(--text-body);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-list .faq-q:hover{color:var(--market)}
.faq-list .faq-icon{font-size:1.2rem;color:var(--market);transition:transform .2s;flex-shrink:0}
.faq-list .faq-a{display:none;padding:0 0 16px;font-size:0.93rem;color:var(--text-mid);line-height:1.6}
.faq-list .faq-a.open{display:block}

/* ============================================================
   Injected from main styles.css by fix-layouts.js
   ============================================================ */

/* SKU GRID */
.sku-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  max-width: 1050px; margin: 0 auto;
}
.sku-card {
  background: var(--white, #fff); border: 1px solid var(--border, #e0e4e8);
  border-radius: 20px; padding: 36px 24px 28px;
  text-align: center; position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
  display: flex; flex-direction: column; align-items: center;
}
.sku-card:hover {
  transform: translateY(-4px); box-shadow: 0 8px 30px rgba(0,0,0,0.10);
  border-color: #dbeafe;
}
.sku-badge {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  padding: 4px 16px; border-radius: 50px;
  font-size: 0.7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; white-space: nowrap;
}
.sku-badge-hot { background: #E63946; color: white; }
.sku-badge-new { background: #0066CC; color: white; }
.sku-icon {
  width: 56px; height: 56px; margin: 0 auto 16px;
  background: #eff6ff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.sku-icon svg { width: 28px; height: 28px; stroke: #0066CC; }
.sku-name { font-size: 1.15rem; font-weight: 800; color: #0D1117; margin-bottom: 4px; }
.sku-sub { font-size: 0.85rem; color: #6B7280; margin-bottom: 16px; }
.sku-specs-mini {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
  margin-bottom: 20px;
}
.sku-specs-mini span {
  padding: 3px 10px; background: #eff6ff;
  border-radius: 6px; font-size: 0.72rem; font-weight: 600;
  color: #0052a3; white-space: nowrap;
}
.sku-quote-btn {
  display: inline-block; padding: 10px 24px;
  background: #0066CC; color: #ffffff !important;
  font-size: 0.85rem; font-weight: 600; border-radius: 6px;
  transition: background 0.3s ease, transform 0.2s;
  margin-top: auto; text-decoration: none;
}
.sku-quote-btn:hover { background: #0052a3; transform: translateY(-1px); }
.sku-category-label {
  font-size: 1rem; font-weight: 700; color: #0066CC;
  margin: 36px 0 16px; padding-bottom: 8px;
  border-bottom: 2px solid #dbeafe; max-width: 1050px; margin-left: auto; margin-right: auto;
}

/* WHY FEATURES (ensure flex works) */
.why-features { display: flex; flex-direction: column; gap: 10px; }
.why-feature {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 0.9rem; color: #2C3E50; padding: 8px 0;
}
.why-feature-check { flex-shrink: 0; margin-top: 2px; }

/* SUPPLY CHAIN */
.why-supply-chain {
  background: #ffffff; border-radius: 20px;
  padding: 28px; box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  display: flex; flex-direction: column; gap: 8px;
}
.supply-node {
  padding: 12px 16px; border-radius: 6px;
  background: #eff6ff; border: 1px solid #dbeafe;
  text-align: center;
}
.supply-node strong { display: block; font-size: 0.95rem; color: #0D1117; }
.supply-node span { display: block; font-size: 0.78rem; color: #6B7280; margin-top: 2px; }
.supply-node.accent { background: #0066CC; border-color: #0066CC; }
.supply-node.accent strong, .supply-node.accent span { color: #ffffff; }
.supply-arrow { text-align: center; font-size: 1.4rem; font-weight: 700; color: #0066CC; padding: 2px 0; }

@media (max-width: 768px) {
  .sku-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1024px) {
  .sku-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .sku-grid { grid-template-columns: 1fr !important; }
  .specs-table-wrap { max-width: 100%; overflow-x: auto; }
  .specs-table { width: 100%; table-layout: fixed; }
  .specs-table td,
  .specs-table th { overflow-wrap: anywhere; }
}

.cta-banner{padding:64px 0;text-align:center;background:var(--market);color:#fff}
.nav-lang{position:relative}
.nav-lang-drop{display:none;position:absolute;top:calc(100% + 2px);right:0;padding-top:4px;background:var(--white);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.10);width:220px;z-index:1000;overflow:hidden}
.nav-lang-drop.open{display:block!important}
.nav-lang-drop a{display:block;padding:9px 16px;font-size:0.84rem;color:var(--text-body);text-decoration:none;white-space:nowrap;transition:background .15s;border-radius:0}
.nav-lang-drop a:hover{background:var(--blue-xlight,#eff6ff);color:var(--blue,#0066CC)}
.nav-lang-drop a.active{background:var(--blue-xlight,#eff6ff);color:var(--blue,#0066CC);font-weight:600}/* QUOTE FORM */
.quote-form{max-width:820px;margin:34px auto 0;padding:24px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);border-radius:var(--radius,12px);text-align:left;backdrop-filter:blur(10px)}
.quote-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.quote-field{display:flex;flex-direction:column;gap:6px}
.quote-field.full{grid-column:1/-1}
.quote-field label{font-size:.78rem;font-weight:700;color:rgba(255,255,255,.88)}
.quote-field input,.quote-field select,.quote-field textarea{width:100%;padding:12px 13px;color:var(--text-body,#0D1117);background:#fff;border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-sm,8px);font:inherit;font-size:.9rem}
.quote-field textarea{min-height:110px;resize:vertical}
.quote-form-actions{display:flex;align-items:center;gap:14px;margin-top:18px;flex-wrap:wrap}
.quote-note{margin:0;font-size:.8rem;color:rgba(255,255,255,.78)}
.quote-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;background:#fff;color:var(--market,var(--blue,#0066CC));font-weight:700;font-size:.95rem;border:0;border-radius:var(--radius-sm,8px);cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s}
.quote-submit:hover{background:#eff6ff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.15)}
.quote-status{margin:0;font-size:.82rem;font-weight:600;color:rgba(255,255,255,.86)}
.quote-status-success{color:#d1fae5}
.quote-status-error{color:#fee2e2}
.quote-status-pending{color:rgba(255,255,255,.86)}
.quote-submit:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:none}@media(max-width:768px){.quote-form{padding:18px}.quote-form-grid{grid-template-columns:1fr}}
