/* ==========================================================================
   Taxi Calonge Palamós, main stylesheet
   ========================================================================== */

:root{
  --blue:#3454D1;
  --blue-dark:#2742A8;
  --blue-soft:#eef1fb;
  --orange:#F9AD36;
  --orange-dark:#E69A24;
  --ink:#080808;
  --ink-soft:#3a3a3a;
  --ink-mute:#6a6a6a;
  --line:#e8e8e2;
  --cream:#FAFAF7;
  --bg:#ffffff;
  --radius:10px;
  --shadow-sm:0 1px 2px rgba(8,8,8,.04), 0 2px 6px rgba(8,8,8,.04);
  --shadow-md:0 6px 24px rgba(8,8,8,.08);
  --container:1200px;
  --font-serif:'Fraunces',Georgia,'Times New Roman',serif;
  --font-sans:'Inter','Helvetica Neue',Arial,sans-serif;
}

*,*:before,*:after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-sans);
  color:var(--ink);
  background:var(--bg);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

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

/* Typography */
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:500;letter-spacing:-0.02em;line-height:1.15;margin:0 0 .4em}
h1{font-size:clamp(2.1rem,4.3vw,3.3rem)}
h2{font-size:clamp(1.7rem,3vw,2.4rem)}
h3{font-size:1.15rem;font-weight:500;letter-spacing:-0.01em}
h4{font-size:1rem;font-weight:600;letter-spacing:0}
p{margin:0 0 1em}
.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);font-weight:600;margin-bottom:14px}
.lead{font-size:1.05rem;color:var(--ink-soft);max-width:640px}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 22px;border-radius:6px;
  font-weight:500;font-size:.95rem;letter-spacing:.01em;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  border:1px solid transparent;cursor:pointer;text-align:center;white-space:nowrap;
}
.btn svg{width:18px;height:18px;flex-shrink:0}
.btn-gold{background:var(--orange);color:var(--ink);box-shadow:0 1px 0 rgba(8,8,8,.04)}
.btn-gold:hover{background:var(--orange-dark);transform:translateY(-1px);box-shadow:0 4px 14px rgba(249,173,54,.35)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-outline:hover{border-color:var(--ink);background:#fff}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink)}
.btn-block{width:100%}

/* ---------- Topbar + Header (both fixed) ---------- */
.topbar{
  background:var(--blue);
  color:#fff;font-size:.78rem;letter-spacing:.02em;
  border-bottom:1px solid rgba(255,255,255,.08);
  position:fixed;top:0;left:0;right:0;z-index:51;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:9px 20px;max-width:1200px;margin:0 auto;gap:12px;flex-wrap:wrap}
.topbar-tagline{font-style:italic;font-family:var(--font-serif);color:rgba(255,255,255,.9)}
.topbar-tagline .hl{color:var(--orange)}

/* Language switcher (native, no plugin) */
.lang-switcher{position:relative;display:inline-block}
.lang-current{
  display:inline-flex;align-items:center;gap:6px;
  background:rgba(255,255,255,.08);color:#fff;
  border:1px solid rgba(255,255,255,.2);border-radius:3px;
  padding:4px 10px;font-size:.78rem;font-family:inherit;
  cursor:pointer;letter-spacing:.04em;
}
.lang-current:hover{background:rgba(255,255,255,.15)}
.lang-current .caret{width:8px;height:5px}
.lang-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  background:#fff;color:var(--ink);
  border:1px solid var(--line);border-radius:6px;
  box-shadow:var(--shadow-md);
  min-width:140px;padding:6px 0;
  opacity:0;visibility:hidden;transform:translateY(-4px);
  transition:opacity .15s ease, transform .15s ease, visibility .15s;
  z-index:60;
}
.lang-switcher.open .lang-menu,
.lang-switcher:hover .lang-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-menu a{
  display:block;padding:8px 14px;font-size:.85rem;
  color:var(--ink-soft);transition:background .1s ease;
}
.lang-menu a:hover{background:var(--cream);color:var(--ink)}
.lang-menu a.active{color:var(--blue);font-weight:500}

header.site{
  position:fixed;top:34px;left:0;right:0;z-index:50;
  background:rgba(255,255,255,.96);
  border-bottom:1px solid var(--line);
  backdrop-filter:saturate(180%) blur(14px);
  padding-top: 8px;
}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 0;gap:16px}
.logo{display:flex;align-items:center;gap:12px}
.logo-img{height:44px;width:auto;max-width:220px;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{color:var(--ink-soft);font-weight:400;font-size:.93rem;transition:color .15s ease}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:flex;gap:10px;align-items:center}
.nav-phone{display:inline-flex;align-items:center;gap:6px;color:var(--ink);font-weight:500;font-size:.9rem;padding:8px 10px;border-radius:4px;transition:background .15s ease}
.nav-phone:hover{background:var(--cream)}
.nav-phone svg{width:15px;height:15px}
.menu-toggle{display:none;background:transparent;border:none;color:var(--ink);font-size:1.4rem;padding:6px 10px}

/* Spacer reserves space for the two fixed bars (topbar 34 + header 72 = ~106) */
.site-spacer{height:106px;display:block}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  color:#fff;padding:90px 0 110px;
  background:linear-gradient(180deg, rgba(8,18,54,.55) 0%, rgba(8,18,54,.72) 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;
  background:var(--blue-dark);
}
.hero-bg{
  position:absolute;inset:0;z-index:-1;
  background-size:cover;background-position:center;
  opacity:.45;
}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid rgba(255,255,255,.25);border-radius:24px;
  padding:6px 14px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,255,255,.9);margin-bottom:22px;font-weight:500;
}
.hero-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 3px rgba(249,173,54,.2)}
.hero h1{color:#fff;font-size:clamp(2.4rem,5vw,3.8rem);font-weight:400}
.hero h1 .accent{display:block;font-style:italic;color:var(--orange);font-weight:400;margin-top:4px}
.hero h1 .dash{color:var(--orange);font-style:normal;margin:0 .3em}
.hero-lead{color:rgba(255,255,255,.88);font-size:1.05rem;max-width:540px;margin:16px 0 30px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}
.hero-ctas .btn{padding:14px 22px}
.hero-trust{margin-top:30px;display:flex;gap:26px;flex-wrap:wrap;color:rgba(255,255,255,.75);font-size:.84rem}
.hero-trust span{display:inline-flex;align-items:center;gap:6px}
.hero-trust svg{width:14px;height:14px;color:var(--orange)}

/* Quick-book card */
.quick-book{
  background:#fff;color:var(--ink);border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-md);
}
.qb-title{margin:0 0 4px;font-family:var(--font-serif);font-size:1.35rem;font-weight:500}
.qb-sub{margin:0 0 22px;font-size:.9rem;color:var(--ink-mute)}
.qb-group{display:block;margin-bottom:14px}
.qb-group label{display:block;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:6px;font-weight:500}
.qb-group select,
.qb-group input{
  width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:6px;
  font-size:.93rem;font-family:inherit;color:var(--ink);background:#fff;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1l5 5 5-5' stroke='%23080808' stroke-width='1.5' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 12px center;
  padding-right:36px;
}
.qb-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.qb-submit{width:100%;margin-top:10px;padding:14px 22px}
.qb-divider{display:flex;align-items:center;margin:18px 0;color:var(--ink-mute);font-size:.78rem;gap:10px}
.qb-divider::before,.qb-divider::after{content:"";flex:1;height:1px;background:var(--line)}
.qb-call{width:100%;padding:13px 22px;font-size:.95rem}

/* ---------- Generic section ---------- */
section{padding:90px 0;border-top:1px solid var(--line)}
section.alt{background:var(--cream)}
section:first-of-type{border-top:none}
.section-head{text-align:center;max-width:720px;margin:0 auto 50px}
.section-head .lead{margin:14px auto 0}

/* ---------- Why us ---------- */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:50px}
.why-card{text-align:left}
.why-icon{
  width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--blue);border-radius:8px;color:var(--blue);margin-bottom:16px;
}
.why-icon svg{width:22px;height:22px}
.why-card h3{margin-bottom:8px}
.why-card p{color:var(--ink-soft);font-size:.93rem;margin:0}

/* ---------- Services ---------- */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);transition:border-color .2s ease, box-shadow .2s ease;
  display:flex;flex-direction:column;
}
.service:hover{border-color:var(--blue);box-shadow:var(--shadow-md)}
.service-img{aspect-ratio:4/3;background:var(--cream);position:relative;overflow:hidden}
.service-img svg{position:absolute;inset:0;margin:auto;width:64px;height:64px;color:var(--blue)}
.service-body{padding:22px;flex:1;display:flex;flex-direction:column}
.service-body h3{margin-bottom:6px}
.service-body p{color:var(--ink-soft);font-size:.9rem;margin:0 0 14px;flex:1}
.service-link{color:var(--blue);font-size:.85rem;font-weight:500;display:inline-flex;align-items:center;gap:4px;margin-top:auto}

/* ---------- Fleet ---------- */
.fleet-card{
  background:#fff;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;
}
.fleet-image{aspect-ratio:4/3;background:var(--cream);overflow:hidden;height:100%}
.fleet-image img{width:100%;height:100%;object-fit:cover}
.fleet-body{padding:40px}
.fleet-body h3{font-size:1.55rem;margin-bottom:10px}
.fleet-body > p{color:var(--ink-soft);margin-bottom:24px}
.fleet-features{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.fleet-feature{display:flex;gap:10px}
.fleet-feature svg{flex-shrink:0;width:20px;height:20px;color:var(--blue);margin-top:2px}
.fleet-feature h4{margin:0 0 2px;font-size:.92rem}
.fleet-feature p{margin:0;font-size:.84rem;color:var(--ink-mute)}
.fleet-ctas{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- Routes/Prices table ---------- */
.routes{background:#fff;border-radius:var(--radius);border:1px solid var(--line);overflow:hidden}
.routes table{width:100%;border-collapse:collapse}
.routes th, .routes td{padding:16px 20px;text-align:left;font-size:.92rem}
.routes th{background:var(--cream);border-bottom:1px solid var(--line);font-weight:500;letter-spacing:.04em;font-size:.78rem;text-transform:uppercase;color:var(--ink-mute)}
.routes tr:not(:last-child) td{border-bottom:1px solid var(--line)}
.routes td.price{font-weight:500;font-family:var(--font-serif);font-size:1rem}
.routes-foot{font-size:.82rem;color:var(--ink-mute);margin-top:16px;text-align:center}

/* ---------- Coverage ---------- */
.coverage-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:50px;align-items:center}
.coverage-areas{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}
.coverage-areas span{background:#fff;border:1px solid var(--line);border-radius:30px;padding:7px 16px;font-size:.83rem;color:var(--ink-soft)}

/* ---------- Reviews ---------- */
.reviews-header{text-align:center;margin-bottom:40px}
.reviews-stars{color:var(--orange);font-size:1.2rem;letter-spacing:2px;margin-bottom:6px}
.reviews-rating{font-family:var(--font-serif);font-size:1.8rem;font-weight:500}
.reviews-sub{color:var(--ink-mute);font-size:.88rem;margin-top:4px}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.review-stars{color:var(--orange);margin-bottom:10px;font-size:.9rem;letter-spacing:2px}
.review-text{font-size:.94rem;color:var(--ink-soft);margin:0 0 14px;font-style:italic}
.review-author{font-size:.85rem;color:var(--ink-mute)}

/* ---------- SEO text section ---------- */
.seo-text{max-width:860px;margin:0 auto;color:var(--ink-soft)}
.seo-text h3{margin-top:36px;color:var(--ink);font-size:1.3rem}
.seo-text h3:first-child{margin-top:0}
.seo-text p{margin:0 0 14px}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:800px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:10px;padding:0;overflow:hidden;transition:border-color .2s ease}
.faq details[open]{border-color:var(--blue)}
.faq summary{cursor:pointer;padding:18px 24px;font-weight:500;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:.97rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--blue);transition:transform .2s ease;flex-shrink:0}
.faq details[open] summary::after{content:"−"}
.faq .faq-body{padding:0 24px 22px;color:var(--ink-soft);font-size:.93rem}

/* ---------- Contact / final CTA ---------- */
.final-cta{
  background:var(--blue);color:#fff;border-radius:var(--radius);
  padding:70px 40px;text-align:center;
}
.final-cta h2{color:#fff}
.final-cta p{color:rgba(255,255,255,.88);max-width:540px;margin:12px auto 28px}
.final-cta .btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.final-cta .btn-outline:hover{background:rgba(255,255,255,.1);border-color:#fff}
.final-ctas{display:inline-flex;gap:12px;flex-wrap:wrap;justify-content:center}

/* ---------- Footer ---------- */
footer{background:#0a0a0a;color:rgba(255,255,255,.7);padding:70px 0 30px;font-size:.88rem}
footer h4{color:#fff;font-family:var(--font-sans);font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;font-weight:600;margin-bottom:18px}
footer a{color:rgba(255,255,255,.7);transition:color .15s}
footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.footer-logo{margin-bottom:16px}
.footer-logo img{height:38px;filter:brightness(0) invert(1);opacity:.9}
.footer-about{font-size:.88rem;line-height:1.7;max-width:300px}
.footer-list{list-style:none;padding:0;margin:0}
.footer-list li{margin-bottom:8px}
.footer-contact{font-size:.88rem;line-height:1.8}
.footer-contact strong{color:#fff;font-weight:500}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:.82rem;color:rgba(255,255,255,.5);
}

/* ---------- Floating WhatsApp CTA ---------- */
.wa-float{
  position:fixed;bottom:20px;right:20px;z-index:40;
  width:56px;height:56px;background:#25d366;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(37,211,102,.4);color:#fff;
  transition:transform .15s ease;
}
.wa-float:hover{transform:scale(1.06)}
.wa-float svg{width:28px;height:28px}

/* ---------- Responsive ---------- */
@media (max-width:960px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .fleet-card{grid-template-columns:1fr}
  .fleet-image{aspect-ratio:16/9}
  .coverage-grid{grid-template-columns:1fr;gap:30px}
  .reviews-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:760px){
	.routes th:nth-child(3),
	.routes td:nth-child(3),
	.routes th:nth-child(4),
	.routes td:nth-child(4){
  display:none;
}
.routes th, .routes td{padding:14px 14px;font-size:.88rem}
  .nav-links{
    display:none;position:absolute;top:100%;right:0;
    background:#fff;border:1px solid var(--line);border-radius:6px;
    flex-direction:column;align-items:flex-start;padding:12px 0;
    min-width:200px;box-shadow:var(--shadow-md);
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:8px 20px;width:100%}
  .menu-toggle{display:inline-block}
  .nav-phone span{display:none}
  .hero{padding:60px 0 70px}
  .why-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .fleet-features{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .qb-row{grid-template-columns:1fr}
  .fleet-body{padding:28px}
  .final-cta{padding:50px 24px}
  section{padding:60px 0}
  .topbar-tagline{font-size:.72rem}
}
