/* =====================
   Roots of Wonder — One Page (Bilingual)
   business.rootsofwonder.tours
   ===================== */

:root{
  --green:#666;
  --sand:#00cfff;
  --ink:#1e1e1e;
  --cream:#faf9f5;
  --cloud:#f6f3ef;
  --muted:#6b6b6b;
  --radius:10px;
  --container:1200px;
}

*{ box-sizing: border-box; }
html, body{ margin:0; padding:0; color:var(--ink); font-family:-apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; line-height:1.5; }
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--green); text-decoration:none; }
a:hover{ text-decoration:underline; }
.container{ max-width:var(--container); padding:0 20px; margin:0 auto; }

/* Accessibility */
.skip-link{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip-link:focus{ position:fixed; left:20px; top:20px; width:auto; height:auto; background:#fff; color:#000; padding:10px 14px; border-radius:6px; z-index:9999; }

/* Header */
.site-header{ position:sticky; top:0; z-index:1000; background:#fff; border-bottom:1px solid #eee; }
.header-inner{ display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:14px; }
.logo{ display:flex; flex-direction:column; gap:2px; font-weight:700; color:var(--ink); }
.logo-title{ font-size:18px; letter-spacing:.2px; }
.logo-tagline{ font-size:12px; color:var(--muted); }

.nav-row{ display:flex; align-items:center; gap:16px; }
.nav-toggle{ display:none; background:transparent; border:0; font-size:24px; line-height:1; cursor:pointer; }

.site-nav ul{ list-style:none; margin:0; padding:0; display:flex; gap:18px; }
.site-nav a{ display:inline-block; padding:8px 10px; border-radius:6px; }
.site-nav a[aria-current="true"], .site-nav a:hover{ background:var(--cream); text-decoration:none; }

/* Language switch */
.lang-switch{ display:flex; align-items:center; gap:8px; font-size:14px; }
.lang-switch a{ display:inline-flex; align-items:center; justify-content:center; width:36px; height:28px; border:1px solid #e0e0e0; border-radius:6px; color:var(--ink); background:#fff; }
.lang-switch a[aria-current="true"]{ background:var(--cream); border-color:#cfcfcf; font-weight:700; }
.lang-sep{ color:#bdbdbd; }

/* Hero */
.hero{ position:relative; min-height:62vh; display:grid; place-items:center; text-align:center; }
.hero-bg{ position:absolute; inset:0; z-index:-1; }
.hero-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.30), rgba(0,0,0,.35)); }
.hero-bg img{ width:100%; height:100%; object-fit:cover; }

.hero-inner {
    color: #fff;
    text-shadow: 0 1px 2px rgba(0, 0, 0, .25);
    padding: 50px 0 70px;
}

.hero h1 {
    font-size: clamp(28px, 4vw, 70px);
    margin: 0 0 10px;
    font-family: 'Allura', cursive;
}

.hero h2 {
    font-family: serif;
}

.tagline{ color:#fff; }
.lead{ font-size:clamp(16px, 2.2vw, 20px); max-width:800px; margin:0 auto 20px; }
.cta-row{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* Sections */
.section{ padding:64px 0; }
.section--alt{ background:var(--cloud); }

/* Typography */

h2{ font-size:clamp(22px, 3vw, 32px); margin:0 0 12px; }
h3{ font-size:clamp(18px, 2.2vw, 22px); margin:10px 0; }
p{ margin:12px 0; color:var(--ink); }
.bullets{ list-style:none; padding:0; margin:18px 0; display:grid; gap:8px; }
.bullets.two-col{ grid-template-columns:repeat(auto-fit, minmax(260px, 1fr)); gap:10px 18px; }

/* Grid & Cards */
.grid{ display:grid; gap:20px; }
.grid.two{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
.grid.three{ grid-template-columns:repeat(3, minmax(0, 1fr)); }
.cards .card{ background:#fff; border:1px solid #eee; border-radius:var(--radius); padding:18px; box-shadow:0 1px 2px rgba(0,0,0,.03);}
.card-emoji{ font-size:28px; }
.cards .card img{ border-radius:var(--radius);height: 200px;
    width: 100%;  }

@media (max-width: 900px){
  .grid.two{ grid-template-columns:1fr; }
  .grid.three{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .grid.three{ grid-template-columns:1fr; }
}

/* Buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; background:var(--green); color:#fff; border-radius:8px; border:1px solid transparent; font-weight:600; }
.btn:hover{ text-decoration:none; filter:brightness(1.05); }
.btn--alt{ background:var(--sand); }
.btn--ghost{ background:transparent; border-color:var(--green); color:var(--green); }
.btn--ghost:hover{ background:var(--cream); }

/* Forms */
.form fieldset{ border:1px solid #eee; border-radius:var(--radius); padding:16px; margin:18px 0; }
.form legend{ padding:0 6px; font-weight:700; color:var(--ink); }
.form label{ display:block; font-size:14px; color:var(--ink); margin:8px 0 6px; }

button[type="SUBMIT"]{ cursor:pointer }

.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form input[type="url"],
.form textarea,
.form select{ width:100%; padding:10px 12px; border:1px solid #ddd; border-radius:8px; background:#fff; }
.form input[type="checkbox"]{ margin-right:8px; transform:translateY(1px); }
.form .checkbox{ display:flex; align-items:center; gap:8px; margin-top:8px; }
.form .sliders label{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.form .sliders input[type="range"]{ width:100%; }
.form .gdpr{ font-size:12px; color:var(--muted); }
.form .form-msg{ margin-top:10px; font-weight:600; }

.partner-box{ margin-top:36px; padding:20px; background:#fff; border:1px solid #eee; border-radius:var(--radius); }

/* Alice mockup */
.mockup{ display:grid; place-items:center; }
.mockup img{ border-radius:20px; box-shadow:0 8px 24px rgba(0,0,0,.12); }

/* Catalogo CTA centered */
.cta-centered{ text-align:center; margin-top:22px; }

/* Footer */
.site-footer{ background:var(--green); color:#fff; text-align:center; padding:40px 0; }
.site-footer a{ color:#fff; text-decoration:underline; }
.footer-tagline{ font-size:18px; margin:0; }
.footer-nav{ margin:8px 0; }
.footer-nav a{ margin:0 6px; }

/* Responsive nav */
@media (max-width: 1000px){
  .nav-toggle{ display:block; }
  .nav-row{ gap:8px; }
  .site-nav{ position:fixed; top:56px; right:0; width:min(280px, 80vw); max-height:0; overflow:hidden; background:#fff; border-left:1px solid #eee; border-bottom:1px solid #eee; box-shadow:0 6px 18px rgba(0,0,0,.06); transition:max-height .3s ease; }
  .site-nav.open{ max-height:70vh; }
  .site-nav ul{ flex-direction:column; padding:12px; gap:4px; }
  .site-nav a{ padding:12px; }
}

/* Focus styles */
:focus-visible{ outline:3px solid #94c6b4; outline-offset:2px; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
}
.lead {
  color: #fff;
}