:root{
  --ink:#172334;
  --muted:#687386;
  --line:#e7ebf0;
  --soft:#f6f8fb;
  --white:#ffffff;
  --navy:#0f2d46;
  --blue:#2e6f9e;
  --accent:#b98b42;
  --radius:18px;
  --shadow:0 18px 45px rgba(23,35,52,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;color:var(--ink);background:var(--white);line-height:1.65}
img{max-width:100%;display:block}
a{color:inherit}
.container{width:min(1120px,92%);margin-inline:auto}
.site-header{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{font-weight:800;text-decoration:none;color:var(--navy);letter-spacing:-.02em;font-size:1.12rem}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{text-decoration:none;color:var(--muted);font-size:.94rem;font-weight:650}
.nav-links a:hover{color:var(--navy)}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 22px;border-radius:999px;background:var(--navy);color:white;text-decoration:none;font-weight:750;border:1px solid var(--navy);transition:.2s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(15,45,70,.18)}
.btn.small{min-height:40px;padding:0 17px;font-size:.9rem}
.btn.secondary{background:white;color:var(--navy);border-color:var(--line)}
.hero{background:linear-gradient(180deg,#f7f9fc 0%,#ffffff 100%);border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center;min-height:650px;padding:64px 0}
.eyebrow,.section-label{text-transform:uppercase;letter-spacing:.16em;color:var(--blue);font-size:.76rem;font-weight:800;margin:0 0 14px}
h1,h2,h3,p{margin-top:0}
h1{font-size:clamp(2.5rem,5.4vw,5rem);line-height:.98;letter-spacing:-.06em;color:var(--navy);margin-bottom:24px;max-width:820px}
h2{font-size:clamp(2rem,3.6vw,3.1rem);line-height:1.08;letter-spacing:-.045em;color:var(--navy);margin-bottom:18px}
h3{color:var(--navy);letter-spacing:-.02em}
.lead{font-size:1.14rem;color:var(--muted);max-width:680px;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-image{margin:0;border-radius:26px;overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:white;padding:10px}
.hero-image img{width:100%;height:520px;object-fit:cover;border-radius:18px}
.section{padding:90px 0}
.about-grid{display:grid;grid-template-columns:.88fr 1.12fr;gap:64px;align-items:start}
.about-grid p{font-size:1.04rem;color:var(--muted)}
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px;margin-bottom:30px}
.features article,.tour-card,.service-card,.payment-box,.contact-card{background:white;border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 10px 30px rgba(23,35,52,.05)}
.features article{padding:24px;min-height:178px}
.features h3,.service-card h3{margin-bottom:8px;font-size:1.05rem}
.features p,.service-card p,.section-title p{color:var(--muted);margin-bottom:0}
.tours,.gastronomia{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-title{text-align:center;max-width:760px;margin:0 auto 42px}
.cards{display:grid;gap:24px}.cards.two{grid-template-columns:repeat(2,1fr)}.cards.three{grid-template-columns:repeat(3,1fr)}
.tour-card{overflow:hidden}.tour-card img{width:100%;height:260px;object-fit:cover}.tour-content{padding:28px}.tour-card h3{font-size:1.35rem;margin-bottom:10px}.tour-card p,.tour-card li{color:var(--muted)}
.meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.meta span{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;font-weight:800;color:var(--navy);background:#eef3f7;border:1px solid #dce5ed;border-radius:999px;padding:7px 11px}
ul{padding-left:20px;margin-top:12px;margin-bottom:22px}.link{font-weight:800;color:var(--blue);text-decoration:none}.link:hover{text-decoration:underline}.payment-box{margin-top:24px;padding:22px 24px;color:var(--muted);border-left:5px solid var(--accent)}.payment-box strong{color:var(--ink)}
.gastronomia-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}.gastronomia p,.gastronomia li{color:var(--muted)}.note{font-size:.93rem;border-top:1px solid var(--line);padding-top:18px;margin-top:18px}.gallery-clean{display:grid;grid-template-columns:1fr 1fr;gap:14px}.gallery-clean img{height:220px;width:100%;object-fit:cover;border-radius:16px;box-shadow:var(--shadow)}.gallery-clean img:first-child{grid-row:span 2;height:454px}
.service-card{padding:28px;min-height:210px}.contact-section{margin:90px auto;display:grid;grid-template-columns:1fr .9fr;gap:42px;align-items:start;background:var(--navy);color:white;border-radius:28px;padding:44px}.contact-section h2{color:white}.contact-section p{color:#d8e3ec}.contact-section .section-label{color:#9fd0f4}.contact-card{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.14);box-shadow:none;padding:12px;display:grid;gap:10px}.contact-card a{display:flex;justify-content:space-between;gap:16px;text-decoration:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);padding:16px;border-radius:14px}.contact-card span{color:#d8e3ec;text-align:right}
footer{border-top:1px solid var(--line);padding:28px 0;background:#fff}.footer-grid{display:flex;justify-content:space-between;gap:20px;color:var(--muted);font-size:.92rem}.footer-grid p{margin:0}
@media(max-width:900px){.nav-links{display:none}.hero-grid,.about-grid,.gastronomia-grid,.contact-section{grid-template-columns:1fr}.hero-grid{min-height:auto;padding:48px 0}.hero-image img{height:380px}.features{grid-template-columns:repeat(2,1fr)}.cards.two,.cards.three{grid-template-columns:1fr}.contact-section{padding:30px;margin:60px auto}.footer-grid{display:block}.footer-grid p+p{margin-top:8px}}
@media(max-width:560px){.nav{height:68px}.btn.small{display:none}h1{font-size:2.55rem}.section{padding:64px 0}.features{grid-template-columns:1fr}.gallery-clean{grid-template-columns:1fr}.gallery-clean img,.gallery-clean img:first-child{height:240px}.contact-card a{display:block}.contact-card span{display:block;text-align:left;margin-top:4px}.hero-image img{height:320px}}
.cards.tour-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.montjuic{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.montjuic-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:start}
.montjuic-copy p,.route-list span{color:var(--muted)}
.route-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:24px 0}
.route-list div{border:1px solid var(--line);border-radius:16px;padding:16px;background:var(--soft)}
.route-list strong{display:block;color:var(--navy);margin-bottom:4px}
.route-list span{display:block;font-size:.93rem;line-height:1.45}
.warning{background:#fff8ec;border:1px solid #f0dfbf;border-left:5px solid var(--accent);border-radius:14px;padding:16px 18px;color:var(--ink)!important}
.montjuic-gallery{display:grid;grid-template-columns:1fr 1fr;gap:14px;position:sticky;top:100px}
.montjuic-gallery img{height:210px;width:100%;object-fit:cover;border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--line)}
.montjuic-gallery img:first-child{grid-column:1/-1;height:300px}
@media(max-width:900px){.montjuic-grid{grid-template-columns:1fr}.montjuic-gallery{position:static}.route-list{grid-template-columns:1fr}}
@media(max-width:560px){.montjuic-gallery{grid-template-columns:1fr}.montjuic-gallery img,.montjuic-gallery img:first-child{height:230px}}

/* Menu mobile */
.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid var(--line);
  border-radius:12px;
  background:#fff;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
}
.nav-toggle span{
  display:block;
  width:20px;
  height:2px;
  background:var(--navy);
  border-radius:999px;
  transition:.2s ease;
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .nav{position:relative;gap:12px}
  .brand{font-size:1rem;max-width:210px;line-height:1.15}
  .nav-toggle{display:flex;margin-left:auto}
  .nav-links{
    display:none;
    position:absolute;
    left:0;
    right:0;
    top:78px;
    background:#fff;
    border:1px solid var(--line);
    border-radius:0 0 18px 18px;
    box-shadow:0 18px 38px rgba(23,35,52,.12);
    padding:12px;
    z-index:30;
  }
  .nav-links.is-open{display:grid;gap:4px}
  .nav-links a{
    display:block;
    padding:13px 14px;
    border-radius:12px;
    color:var(--navy);
    background:#fff;
  }
  .nav-links a:hover{background:var(--soft)}
  .nav .btn.small{display:inline-flex;min-height:38px;padding:0 14px;font-size:.82rem}
}
@media(max-width:560px){
  .nav-links{top:68px}
  .nav .btn.small{display:none}
}
