
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@400;700&family=Montserrat:wght@600;700;800&display=swap');

:root{
  --font-main: "Lato", "Helvetica Neue", Arial, sans-serif;
  --font-heading: "Montserrat", "Lato", "Helvetica Neue", Arial, sans-serif;
  --bg:#f5f7f8;
  --bg-2:#eef2f3;
  --surface:#ffffff;
  --surface-2:#f1f4f5;
  --text:#14222d;
  --muted:#5f6f78;
  --line:#d8e0e4;
  --brand:#18384f;
  --brand-2:#31536b;
  --shadow:0 10px 24px rgba(20,34,45,.05);
  --max:1280px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: var(--font-main);
  color:var(--text);
  background:linear-gradient(180deg,#f7f8f9 0%,#f2f5f6 100%);
  line-height:1.65;
}
button,input,select,textarea,a{
  font-family: var(--font-main);
}
h1,h2,h3{
  font-family: var(--font-heading);
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.sr-only{
  position:absolute!important;
  width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.container{width:min(calc(100% - 32px),var(--max));margin-inline:auto}
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(247,248,249,.96);
  border-bottom:1px solid var(--line);
}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:12px 0}
.brand{display:flex;align-items:center;gap:14px;min-width:0;position:relative;z-index:2}
.brand-mark{
  width:40px;height:40px;
  background:linear-gradient(180deg,var(--brand),var(--brand-2));
}
.brand h1{font-size:1rem;line-height:1.15;margin:0;font-weight:700;letter-spacing:.01em}
.brand p{margin:0;color:var(--muted);font-size:.84rem}
.nav-toggle{
  display:none;
  width:44px;height:44px;padding:0;border:1px solid var(--line);
  background:#fff;cursor:pointer;
}
.nav-toggle span{display:block;width:20px;height:2px;background:var(--text);margin:5px auto}
.nav-wrap{display:flex;align-items:center;gap:12px}
.main-nav{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}
.main-nav a,.lang-switch a,.cta-button,.ghost-button,.lang-card{
  padding:10px 14px;border:1px solid transparent;transition:.2s ease;
}
.main-nav a:hover,.lang-switch a:hover,.ghost-button:hover,.lang-card:hover{
  background:#fff;border-color:var(--line)
}
.main-nav a.active,.lang-switch a.active{
  background:#fff;border-color:var(--line)
}
.lang-switch{display:flex;gap:6px}
.hero{padding:28px 0 12px}
.hero-grid{display:grid;grid-template-columns:.88fr 1.12fr;gap:20px;align-items:stretch}
.hero-copy,.hero-media{
  background:var(--surface);
  border:1px solid var(--line);
  overflow:hidden;
}
.hero-copy{
  padding:40px;
  display:flex;flex-direction:column;justify-content:center;
}
.eyebrow{
  display:inline-flex;gap:8px;align-items:center;
  padding:6px 10px;background:var(--surface-2);
  color:var(--brand);font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  align-self:flex-start;
}
.hero h2{font-size:clamp(2.2rem,4.3vw,4.7rem);line-height:1.02;margin:16px 0 14px;font-weight:700;letter-spacing:-.03em}
.hero p{font-size:1.02rem;color:var(--muted);max-width:58ch}
.hero-actions,.landing-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}
.cta-button{
  background:var(--brand);
  color:#fff;
  border-color:var(--brand)
}
.ghost-button{border-color:var(--line);background:#fff}
.hero-media{position:relative;min-height:600px;background:#dfe6ea}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,14,18,.02),rgba(8,14,18,.18))
}
.hero-floating{
  position:absolute;left:18px;right:18px;bottom:18px;
  display:grid;grid-template-columns:repeat(3,1fr);gap:10px;z-index:2
}
.mini-card{
  padding:16px;background:rgba(255,255,255,.92);
  border:1px solid rgba(20,34,45,.10)
}
.mini-card strong{display:block;font-size:.98rem}
.mini-card span{display:block;font-size:.9rem;color:var(--muted);line-height:1.35}
.section{padding:20px 0 54px}
.section-head{display:flex;justify-content:space-between;gap:20px;align-items:end;margin-bottom:16px}
.section-head h3{font-size:clamp(1.55rem,2.5vw,2.35rem);margin:0;letter-spacing:-.02em}
.section-head p{margin:0;max-width:64ch;color:var(--muted)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.card{
  background:var(--surface);
  border:1px solid var(--line);
  box-shadow:var(--shadow)
}
.card.pad{padding:28px}
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.feature-item,.list-item,.contact-line,.bullets li{
  background:#fff;
  border:1px solid var(--line)
}
.feature-item{padding:18px}
.feature-item h4,.list-item h4{margin:0 0 8px;font-size:1rem}
.feature-item p,.list-item p{margin:0;color:var(--muted)}
.photo-stack{display:grid;grid-template-columns:1.16fr .84fr;gap:12px}
.photo-stack .big img,.photo-stack .small img{height:100%;object-fit:cover}
.photo-stack .small{display:grid;gap:12px}
.photo-stack .big img{min-height:560px}
.photo-stack .small img{min-height:272px}
.quote{
  padding:18px 20px;border-left:3px solid var(--brand);
  background:#f7f9fa;color:var(--muted);font-style:italic
}
.simple-list{display:grid;gap:10px}
.list-item{padding:16px 18px}
.bullets{display:grid;gap:10px;padding:0;list-style:none;margin:0}
.bullets li{padding:14px 16px}
.optional-box{
  margin-top:16px;padding:20px;
  background:var(--brand);color:#fff
}
.optional-box h4{margin:0 0 10px}
.masonry{columns:3 260px;column-gap:14px}
.masonry figure{
  break-inside:avoid;margin:0 0 14px;overflow:hidden;
  border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)
}
.masonry img{width:100%;height:auto}
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:20px}
.contact-card{padding:28px}
.contact-block{display:grid;gap:12px}
.contact-line{padding:16px 18px}
.contact-line small{display:block;color:var(--muted);margin-bottom:3px}
form{display:grid;gap:14px}
label{display:grid;gap:6px;font-weight:600}
input,textarea{
  width:100%;padding:14px 15px;border:1px solid var(--line);
  font:inherit;background:#fff;color:var(--text)
}
input:focus,textarea:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(24,56,79,.07)
}
textarea{min-height:180px;resize:vertical}
.form-actions{display:flex;gap:10px;flex-wrap:wrap}
.form-note{margin-top:.25rem;color:#4a6070;font-size:.95rem;line-height:1.6}
.map-embed{overflow:hidden;border:1px solid var(--line);min-height:340px;background:#fff}
.map-embed iframe{border:0;width:100%;height:100%}
.map-consent-placeholder{
  min-height:340px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  gap:12px;
  padding:28px;
  background:linear-gradient(180deg,#f8fbfd 0%,#eef3f7 100%);
  color:var(--text);
}
.map-consent-placeholder strong{font-size:1.05rem}
.map-consent-placeholder p{margin:0;max-width:58ch;color:var(--muted)}
.map-consent-actions{display:flex;gap:10px;flex-wrap:wrap}
.site-footer{padding:24px 0 44px;color:var(--muted)}
.footer-inner{display:flex;justify-content:space-between;gap:20px;align-items:center;flex-wrap:wrap}
.footer-credit{
  color:var(--muted);
}
.footer-credit-separator{color:var(--muted)}
.footer-cookie-settings{
  border:0;
  background:transparent;
  color:var(--brand);
  font:inherit;
  font-weight:700;
  cursor:pointer;
  padding:0;
}
.footer-cookie-settings:hover{color:#12344a}
.footer-credit a{
  color:var(--brand);
  font-weight:700;
}
.footer-credit a:hover{
  color:#12344a;
}
.footer-chevrons{
  font-weight:700;
  color:var(--brand);
}
.footer-icon{
  display:inline-block;
  margin:0 2px;
}
.footer-icon-coffee{
  width:26px;
  height:26px;
  vertical-align:-4px;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23616f78' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 10h10v5a4 4 0 0 1-4 4H9a4 4 0 0 1-4-4v-5Z'/%3E%3Cpath d='M15 11h2a2 2 0 0 1 0 4h-2'/%3E%3C/svg%3E");
}
.footer-icon-heart{
  color:#d43c52;
}
.footer-inner a[href="#top"]{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:46px;
  height:46px;
  border-radius:999px;
  border:1px solid var(--brand);
  background:var(--brand);
  color:transparent;
  font-size:0;
  line-height:1;
  transition:background .2s ease,border-color .2s ease,transform .2s ease;
}
.footer-inner a[href="#top"]::before{
  content:"";
  display:block;
  width:12px;
  height:12px;
  border-top:3px solid #ffffff;
  border-left:3px solid #ffffff;
  transform:rotate(45deg) translate(1px, 1px);
}
.footer-inner a[href="#top"]:hover{
  background:#12344a;
  border-color:#12344a;
  transform:translateY(-1px);
}

.floating-whatsapp{
  position:fixed;
  right:20px;
  bottom:20px;
  width:58px;
  height:58px;
  border-radius:999px;
  background:#25d366;
  box-shadow:0 14px 30px rgba(24, 34, 45, .18);
  z-index:140;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.floating-whatsapp::before{
  content:"";
  width:28px;
  height:28px;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='none'%3E%3Cpath fill='%23fff' d='M27.2 15.3c0 6.1-5 11.1-11.2 11.1-2 0-3.8-.5-5.5-1.4l-6 1.9 2-5.8A11 11 0 0 1 4.8 15.3C4.8 9.2 9.8 4.2 16 4.2s11.2 5 11.2 11.1Z'/%3E%3Cpath fill='%2325d366' d='M16 6.1c-5.1 0-9.2 4.1-9.2 9.2 0 1.7.5 3.4 1.4 4.8l.2.3-1.2 3.5 3.6-1.1.3.2c1.4.9 3.1 1.3 4.9 1.3 5.1 0 9.2-4.1 9.2-9.2S21.1 6.1 16 6.1Zm5.4 12.6c-.2.5-1.3 1-1.8 1.1-.5.1-1 .1-1.6-.1-.4-.1-1-.3-1.7-.6-3-1.3-4.9-4.4-5-4.6-.2-.2-1.2-1.6-1.2-3 0-1.4.7-2.1 1-2.4.2-.2.5-.3.7-.3h.5c.2 0 .4 0 .6.5.2.5.7 1.7.8 1.9.1.2.1.4 0 .6-.1.2-.2.4-.4.6-.2.2-.3.4-.5.6-.2.2-.3.4-.1.7.2.4.9 1.5 2 2.4 1.4 1.2 2.5 1.6 2.9 1.8.4.2.6.1.8-.1.2-.2.8-.9 1-1.2.2-.3.4-.3.7-.2.3.1 2 .9 2.3 1.1.3.1.5.2.5.4.1.2.1 1-.2 1.5Z'/%3E%3C/svg%3E");
}

.floating-whatsapp:hover{
  background:#1fbe5a;
  transform:translateY(-2px);
  box-shadow:0 18px 34px rgba(24, 34, 45, .22);
}

.cookie-consent{
  position:fixed;
  left:20px;
  right:20px;
  bottom:20px;
  z-index:150;
  display:none;
}

.cookie-consent.is-visible{
  display:block;
}

.cookie-banner{
  max-width:980px;
  margin-left:auto;
  display:grid;
  gap:16px;
  padding:18px 20px;
  background:rgba(17, 37, 54, .96);
  color:#eef4f8;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 20px 44px rgba(20,34,45,.28);
  backdrop-filter:blur(12px);
}

.cookie-banner-copy{
  display:grid;
  gap:8px;
}

.cookie-banner-copy strong{
  font-size:1rem;
}

.cookie-banner-copy p{
  margin:0;
  color:rgba(238,244,248,.84);
  max-width:74ch;
}

.cookie-banner-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.cookie-banner .ghost-button{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.2);
  color:#eef4f8;
}

.cookie-banner .ghost-button:hover{
  background:rgba(255,255,255,.16);
  border-color:rgba(255,255,255,.3);
}

.cookie-panel{
  display:none;
  gap:12px;
  padding-top:8px;
  border-top:1px solid rgba(255,255,255,.14);
}

.cookie-consent.is-configuring .cookie-panel{
  display:grid;
}

.cookie-option{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  padding:12px 0;
}

.cookie-option span{
  display:grid;
  gap:4px;
}

.cookie-option small{
  color:rgba(238,244,248,.72);
  line-height:1.45;
}

.cookie-option input{
  width:18px;
  height:18px;
  margin-top:2px;
}

.cookie-option-disabled{
  opacity:.85;
}

.cookie-panel-actions{
  display:flex;
  justify-content:flex-end;
}

@media (max-width: 980px){
  .footer-inner a[href="#top"]{
    display:none;
  }

  .cookie-consent{
    left:12px;
    right:12px;
    bottom:12px;
  }

  .cookie-banner{
    padding:16px;
  }

  .cookie-banner-actions,
  .cookie-panel-actions,
  .map-consent-actions{
    flex-direction:column;
    align-items:stretch;
  }

  .floating-whatsapp{
    right:16px;
    bottom:16px;
    width:54px;
    height:54px;
  }
}
.breadcrumbs{display:flex;gap:8px;flex-wrap:wrap;color:var(--muted);font-size:.92rem;margin:0 0 12px}
.badge-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.badge{
  padding:7px 10px;background:var(--surface-2);
  font-weight:700;color:var(--brand);border:1px solid var(--line)
}
.notice{font-size:.92rem;color:var(--muted)}
.lang-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:26px}
.lang-card{
  display:flex;flex-direction:column;gap:4px;background:#fff;
  border:1px solid var(--line);padding:18px 20px;box-shadow:var(--shadow)
}
.lang-card strong{font-size:1rem}
.lang-card span{font-size:.92rem;color:var(--muted)}
.hero-landing .hero-copy{justify-content:center}
.hero-grid-landing .hero-media{min-height:520px}
.page-galeria .hero-media,
.page-entorno .hero-media,
.page-index .hero-media{min-height:620px}

@media (max-width: 1080px){
  .hero-grid,.grid-2,.contact-grid{grid-template-columns:1fr}
  .hero-copy{padding:30px}
  .hero-media,.hero-grid-landing .hero-media{min-height:440px}
  .hero-floating{grid-template-columns:1fr}
  .photo-stack{grid-template-columns:1fr}
  .photo-stack .big img{min-height:360px}
  .photo-stack .small img{min-height:200px}
  .feature-list,.lang-cards{grid-template-columns:1fr}
}
@media (max-width: 840px){
  .header-row{align-items:center}
  .nav-toggle{display:inline-block;position:relative;z-index:3;flex:0 0 auto}
  .nav-wrap{
    position:absolute;top:calc(100% + 8px);left:16px;right:16px;
    display:none;flex-direction:column;align-items:stretch;gap:10px;
    padding:14px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow)
  }
  .nav-wrap.open{display:flex}
  .main-nav{justify-content:flex-start;flex-direction:column}
  .main-nav a,.lang-switch a{width:100%}
  .lang-switch{display:grid;grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 760px){
  .header-row{gap:12px}
  .hero{padding-top:18px}
  .hero h2{font-size:clamp(2rem,9vw,3.2rem)}
  .section{padding:10px 0 38px}
  .hero-media,.page-galeria .hero-media,.page-entorno .hero-media,.page-index .hero-media{min-height:340px}
  .mini-card{padding:14px}
  .card.pad,.contact-card{padding:22px}
}


/* sober refinement */
body{
  font-family: var(--font-main);
  letter-spacing: .001em;
}
.site-header{
  backdrop-filter: blur(10px);
}
.header-row{
  gap: 24px;
  padding: 10px 0;
}
.brand h1{
  font-size: .98rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.brand p{
  font-size: .76rem;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.nav-wrap{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
  margin-left:auto;
}
.header-utilities{
  display:flex;
  align-items:center;
  gap:10px;
}
.main-nav{
  display:flex;
  align-items:center;
  gap:2px;
  flex-wrap:nowrap;
  justify-content:flex-end;
}
.main-nav > a,
.nav-dropdown-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 12px;
  white-space:nowrap;
  font-size:.84rem;
  text-transform:uppercase;
  letter-spacing:.04em;
  color:var(--text);
  border:1px solid transparent;
  background:transparent;
  cursor:pointer;
}
.nav-dropdown-toggle{
  width:auto;
}
.nav-group{
  position:relative;
}
.nav-caret{
  width:8px;
  height:8px;
  margin-left:8px;
  border-right:1px solid currentColor;
  border-bottom:1px solid currentColor;
  transform:rotate(45deg) translateY(-1px);
  transform-origin:center;
}
.nav-group:hover .nav-dropdown,
.nav-group:focus-within .nav-dropdown,
.nav-group.open .nav-dropdown{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.nav-group:hover .nav-dropdown-toggle,
.nav-group:focus-within .nav-dropdown-toggle,
.nav-group.open .nav-dropdown-toggle,
.nav-group.is-active .nav-dropdown-toggle,
.main-nav > a:hover,
.main-nav > a.active{
  background:#fff;
  border-color:var(--line);
}
.nav-dropdown{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  min-width:240px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 18px 44px rgba(20,34,45,.08);
  display:grid;
  gap:0;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
  z-index:80;
}
.nav-dropdown a{
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  background:#fff;
  font-size:.92rem;
}
.nav-dropdown a:last-child{
  border-bottom:0;
}
.nav-dropdown a:hover,
.nav-dropdown a.active{
  background:var(--surface-2);
}
.nav-contact-link{
  margin-left:2px;
}
.header-call{
  min-height:42px;
  padding:10px 14px;
  white-space:nowrap;
  font-size:.82rem;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.lang-switch{
  display:flex;
  gap:4px;
}
.lang-switch a{
  min-width:42px;
  text-align:center;
  padding:10px 10px;
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.06em;
}
.hero-copy h2,
.section-heading h2,
.intro-panel h2,
.content-block h2{
  letter-spacing:.01em;
  line-height:1.12;
}
.hero-copy p,
.section-heading p,
.intro-panel p,
.content-block p,
.content-block li{
  color:#334550;
}
.hero-copy,
.hero-media,
.intro-panel,
.card,
.content-block,
.gallery-card,
.contact-card,
.feature-list li,
.lang-card{
  border-radius:0 !important;
}
.cta-button,
.ghost-button,
.main-nav a,
.lang-switch a,
.nav-dropdown-toggle,
.lang-card{
  border-radius:0 !important;
}
@media (max-width: 1180px){
  .header-row{
    align-items:flex-start;
  }
  .nav-wrap{
    flex-direction:column;
    align-items:flex-end;
  }
  .main-nav > a,
  .nav-dropdown-toggle{
    font-size:.78rem;
    padding:9px 10px;
  }
}
@media (max-width: 980px){
  .nav-toggle{
    display:inline-block;
    margin-left:auto;
  }
  .nav-wrap{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    display:none;
    background:rgba(247,248,249,.99);
    border-bottom:1px solid var(--line);
    padding:12px 16px 16px;
    align-items:stretch;
    gap:12px;
  }
  .site-header.nav-open .nav-wrap{
    display:flex;
  }
  .main-nav{
    width:100%;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }
  .main-nav > a,
  .nav-dropdown-toggle{
    justify-content:space-between;
    width:100%;
    background:#fff;
    border:1px solid var(--line);
    padding:12px 14px;
    font-size:.9rem;
  }
  .nav-group{
    width:100%;
  }
  .nav-dropdown{
    position:static;
    opacity:1;
    visibility:visible;
    transform:none;
    pointer-events:auto;
    display:none;
    min-width:0;
    box-shadow:none;
    border-top:0;
    margin-top:-1px;
  }
  .nav-group.open .nav-dropdown,
  .nav-group.is-active .nav-dropdown{
    display:grid;
  }
  .header-utilities{
    width:100%;
    justify-content:space-between;
  }
  .header-call{
    flex:1 1 auto;
    text-align:center;
  }
}



/* logo */
.brand-logo{
  display:flex;
  align-items:center;
  min-width:0;
  padding:0;
  border:0;
  background:none;
}
.brand-logo img{
  display:block;
  width:240px;
  max-width:min(240px, 30vw);
  height:auto;
}
.brand-mark{display:none}

/* root redirect page does not need landing visuals */
body.landing-page .site-header,
body.landing-page main{display:none}

/* header refinement closer to original hierarchy */
.site-header{
  position:sticky;
  top:0;
  z-index:60;
  background:rgba(247,248,249,.98);
}
.header-row{
  gap:20px;
  align-items:center;
}
.main-nav{
  gap:6px;
}
.main-nav > a,
.nav-dropdown-toggle{
  font-size:.8rem;
  letter-spacing:.06em;
  padding:11px 12px;
}
.nav-dropdown{
  top:calc(100% + 2px);
  min-width:250px;
  border-top:2px solid var(--brand);
}
.nav-dropdown a{
  font-size:.86rem;
  padding:11px 13px;
}
.header-utilities{
  gap:8px;
}
.header-call,
.lang-switch a{
  min-height:40px;
  font-size:.76rem;
  letter-spacing:.06em;
}
.header-call,
.ghost-button[href^="tel:"]{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.header-call::before,
.ghost-button[href^="tel:"]::before{
  content:"";
  width:14px;
  height:14px;
  flex:0 0 auto;
  background-color: currentColor;
  -webkit-mask-repeat:no-repeat;
  -webkit-mask-position:center;
  -webkit-mask-size:contain;
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.86 19.86 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.86 19.86 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.12.9.33 1.79.63 2.64a2 2 0 0 1-.45 2.11L8 9.91a16 16 0 0 0 6.09 6.09l1.44-1.29a2 2 0 0 1 2.11-.45c.85.3 1.74.51 2.64.63A2 2 0 0 1 22 16.92Z'/%3E%3C/svg%3E");
  mask-repeat:no-repeat;
  mask-position:center;
  mask-size:contain;
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2.1' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.86 19.86 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.86 19.86 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.12.9.33 1.79.63 2.64a2 2 0 0 1-.45 2.11L8 9.91a16 16 0 0 0 6.09 6.09l1.44-1.29a2 2 0 0 1 2.11-.45c.85.3 1.74.51 2.64.63A2 2 0 0 1 22 16.92Z'/%3E%3C/svg%3E");
}
@media (max-width: 1180px){
  .brand-logo img{
    width:210px;
    max-width:34vw;
  }
}
@media (max-width: 980px){
  .brand-logo img{
    width:180px;
    max-width:58vw;
  }
  .header-row{
    padding:10px 0;
  }
  .nav-wrap{
    top:100%;
  }
}



/* moderate rounded refresh */
:root{
  --radius-s: 10px;
  --radius-m: 16px;
  --radius-l: 22px;
  --shadow-soft: 0 18px 48px rgba(20,34,45,.08);
}
.hero-copy,
.hero-media,
.intro-panel,
.card,
.content-block,
.gallery-card,
.contact-card,
.feature-list li,
.lang-card,
.cta-button,
.ghost-button,
.main-nav a,
.lang-switch a,
.nav-dropdown-toggle{
  border-radius: var(--radius-s) !important;
}
.nav-dropdown{
  border-radius: 14px;
}
.hero-home{
  padding: 26px 0 8px;
}
.hero-home-grid{
  display:grid;
  grid-template-columns: minmax(320px, .9fr) minmax(420px, 1.1fr);
  gap: 24px;
  align-items: stretch;
}
.hero-home-copy{
  background: linear-gradient(180deg, rgba(255,255,255,.95) 0%, rgba(248,250,251,.98) 100%);
  border:1px solid var(--line);
  border-radius: var(--radius-l);
  padding: 42px;
  box-shadow: var(--shadow-soft);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.hero-home-copy h2{
  font-size: clamp(2.2rem, 4vw, 4.6rem);
  line-height: .98;
  margin: 16px 0 14px;
  letter-spacing: -.035em;
}
.hero-home-copy p{
  font-size: 1.05rem;
  color: var(--muted);
  max-width: 56ch;
}
.hero-home-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top: 24px;
}
.hero-home-actions .cta-button,
.hero-home-actions .ghost-button{
  min-height: 50px;
  padding: 13px 18px;
  font-weight: 600;
}
.cta-phone{
  background:#fff;
}
.hero-home-stats{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 28px;
}
.hero-stat{
  background: rgba(24,56,79,.04);
  border:1px solid rgba(24,56,79,.08);
  border-radius: 16px;
  padding: 16px 14px;
}
.hero-stat strong{
  display:block;
  font-size:.96rem;
  line-height:1.2;
}
.hero-stat span{
  display:block;
  margin-top:5px;
  font-size:.85rem;
  color:var(--muted);
}
.hero-slider{
  position:relative;
  min-height: 640px;
  border-radius: 24px;
  overflow:hidden;
  box-shadow: var(--shadow-soft);
  background: #cfd9de;
}
.hero-slides{
  position:relative;
  height:100%;
}
.hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  visibility:hidden;
  transition: opacity .5s ease, visibility .5s ease, transform .5s ease;
  transform: scale(1.02);
}
.hero-slide.is-active{
  opacity:1;
  visibility:visible;
  transform: scale(1);
}
.hero-slide::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(12,18,22,.08) 0%, rgba(12,18,22,.34) 100%);
}
.hero-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.hero-slide-caption{
  position:absolute;
  left:24px;
  right:24px;
  bottom:26px;
  z-index:2;
  color:#fff;
  display:grid;
  gap:6px;
}
.hero-slide-caption span{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  opacity:.88;
}
.hero-slide-caption strong{
  font-size:clamp(1.25rem,2vw,1.9rem);
  line-height:1.15;
  max-width:22ch;
}
.hero-slider-ui{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  z-index:3;
  display:flex;
  align-items:center;
  justify-content:space-between;
  pointer-events:none;
}
.hero-arrow,
.hero-dot{
  pointer-events:auto;
}
.hero-arrow{
  width:46px;
  height:46px;
  border:1px solid rgba(255,255,255,.38);
  border-radius:999px;
  background:rgba(255,255,255,.18);
  color:#fff;
  font-size:1.7rem;
  line-height:1;
  cursor:pointer;
  backdrop-filter: blur(8px);
}
.hero-dots{
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  backdrop-filter: blur(8px);
}
.hero-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:0;
  background:rgba(255,255,255,.48);
  cursor:pointer;
}
.hero-dot.is-active{
  background:#fff;
}
@media (max-width: 980px){
  .hero-home{
    padding-top: 18px;
  }
  .hero-home-grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .hero-home-copy{
    padding: 26px 22px;
    order: 2;
  }
  .hero-home-copy h2{
    font-size: clamp(2rem, 8vw, 3.25rem);
  }
  .hero-home-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .hero-home-actions .cta-button,
  .hero-home-actions .ghost-button{
    width:100%;
    justify-content:center;
    text-align:center;
  }
  .hero-home-stats{
    grid-template-columns:1fr;
  }
  .hero-slider{
    min-height: 420px;
    order: 1;
    border-radius: 18px;
  }
  .hero-slide-caption{
    left:18px;
    right:18px;
    bottom:70px;
  }
}

/* smaller H2 scale */
h2{
  font-size: clamp(1.55rem, 2.5vw, 2.35rem);
}

.hero h2,
.hero-home-copy h2{
  font-size: clamp(1.85rem, 3.2vw, 3rem) !important;
}

/* larger logo + full-width hero slider */
.brand-logo img{
  width: 180px !important;
  max-width: min(180px, 21vw) !important;
  height: auto;
}

.hero-home{
  padding: 0 0 16px !important;
}

.hero-home-grid{
  display:block !important;
}

.hero-slider{
  position: relative;
  min-height: clamp(540px, 80vh, 860px) !important;
  height: min(80vh, 860px);
  width: 100%;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: hidden;
}

.hero-slides,
.hero-slide,
.hero-slide img{
  height: 100%;
}

.hero-slide img{
  width: 100%;
  object-fit: cover;
}

.hero-slide::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(7,13,17,.70) 0%, rgba(7,13,17,.52) 34%, rgba(7,13,17,.18) 64%, rgba(7,13,17,.20) 100%) !important;
}

.hero-home-copy{
  position:absolute !important;
  left: clamp(20px, 4vw, 56px);
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  width: min(680px, calc(100% - 40px));
  background: rgba(255,255,255,.12) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  border-radius: 22px !important;
  padding: clamp(24px, 3vw, 42px) !important;
  box-shadow: 0 18px 48px rgba(0,0,0,.14) !important;
  backdrop-filter: blur(10px);
}

.hero-home-copy .eyebrow{
  background: rgba(255,255,255,.14) !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,.18);
}

.hero-home-copy h2,
.hero-home-copy p,
.hero-home-copy .hero-stat strong,
.hero-home-copy .hero-stat span{
  color: #ffffff !important;
}

.hero-home-copy p{
  max-width: 54ch;
}

.hero-home-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top: 24px;
}

.hero-home-actions .ghost-button,
.hero-home-actions .cta-button{
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.24);
  color: #ffffff;
  min-height: 50px;
  padding: 13px 18px;
  font-weight: 600;
}

.hero-home-actions .cta-button{
  background: #18384f;
  border-color: #18384f;
}

.hero-home-stats{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px;
  margin-top: 26px;
}

.hero-stat{
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 16px !important;
  padding: 15px 14px;
}

.hero-slide-caption{
  display:none !important;
}

.hero-slider-ui{
  left: auto !important;
  right: clamp(18px, 3vw, 36px) !important;
  bottom: clamp(18px, 3vw, 34px) !important;
  width: auto;
  gap: 12px;
  justify-content: flex-end !important;
}

.hero-arrow{
  width: 52px;
  height: 52px;
  background: rgba(255,255,255,.16) !important;
  border-color: rgba(255,255,255,.26) !important;
}

.hero-dots{
  background: rgba(255,255,255,.12) !important;
  border: 1px solid rgba(255,255,255,.16);
}

@media (max-width: 1180px){
  .brand-logo img{
    width: 160px !important;
    max-width: 24vw !important;
  }
}

@media (max-width: 980px){
  .brand-logo img{
    width: 255px !important;
    max-width: 64vw !important;
  }

  .hero-slider{
    min-height: 78vh !important;
    height: 78vh;
  }

  .hero-home-copy{
    left: 16px !important;
    right: 16px !important;
    top: auto !important;
    bottom: 88px !important;
    transform: none !important;
    width: auto !important;
    padding: 20px 18px !important;
    border-radius: 18px !important;
  }

  .hero-home-copy h2{
    font-size: clamp(2rem, 8vw, 3.2rem) !important;
  }

  .hero-home-actions{
    flex-direction: column;
    align-items: stretch;
  }

  .hero-home-actions .cta-button,
  .hero-home-actions .ghost-button{
    width: 100%;
    text-align: center;
    justify-content: center;
  }

  .hero-home-stats{
    grid-template-columns: 1fr !important;
  }

  .hero-slider-ui{
    left: 16px !important;
    right: 16px !important;
    bottom: 18px !important;
    justify-content: space-between !important;
  }
}

/* header width and dark-blue tone override */
.site-header{
  background: rgba(24, 61, 89, .97) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .2) !important;
}

.site-header .container{
  width: calc(100% - 32px);
}

@media (min-width: 981px){
  .site-header .header-row{
    justify-content: flex-start;
    gap: 24px;
  }

  .site-header .brand-logo{
    flex: 0 0 auto;
    margin-right: 10px;
  }

  .site-header .nav-wrap{
    margin-left: auto;
    flex: 0 1 auto;
    min-width: 0;
    justify-content: flex-end;
    gap: 8px;
  }

  .site-header .main-nav{
    justify-content: flex-end;
  }
}

.site-header .brand h1,
.site-header .brand p,
.site-header .main-nav > a,
.site-header .nav-dropdown-toggle,
.site-header .lang-switch a,
.site-header .header-call{
  color: #eef4f8;
}

.site-header .main-nav > a:hover,
.site-header .main-nav > a.active,
.site-header .nav-group:hover .nav-dropdown-toggle,
.site-header .nav-group:focus-within .nav-dropdown-toggle,
.site-header .nav-group.open .nav-dropdown-toggle,
.site-header .nav-group.is-active .nav-dropdown-toggle,
.site-header .lang-switch a:hover,
.site-header .lang-switch a.active{
  background: rgba(255, 255, 255, .14);
  border-color: rgba(255, 255, 255, .3);
}

.site-header .nav-dropdown a{
  color: var(--text);
}

@media (max-width: 980px){
  .site-header .container{
    width: calc(100% - 24px);
  }

  .site-header .header-row{
    justify-content: space-between;
    align-items: center;
    gap: 10px;
  }

  .site-header .brand-logo{
    flex: 0 1 auto;
    min-width: 0;
  }

  .site-header .brand-logo img{
    width: 170px !important;
    max-width: 58vw !important;
  }

  .site-header .nav-toggle{
    margin-left: auto;
    flex: 0 0 auto;
  }

  .site-header .nav-wrap{
    background: rgba(24, 61, 89, .99);
    border-bottom: 1px solid rgba(255, 255, 255, .2);
  }
}

/* final header menu colors + language dropdown */
.site-header .main-nav > a,
.site-header .nav-dropdown-toggle,
.site-header .header-call{
  color: #eef4f8;
}

.site-header .header-call{
  background: rgba(255, 255, 255, .12) !important;
  border-color: rgba(255, 255, 255, .34) !important;
}

.site-header .main-nav > a:hover,
.site-header .main-nav > a.active,
.site-header .nav-dropdown-toggle:hover,
.site-header .nav-group:hover .nav-dropdown-toggle,
.site-header .nav-group:focus-within .nav-dropdown-toggle,
.site-header .nav-group.open .nav-dropdown-toggle,
.site-header .nav-group.is-active .nav-dropdown-toggle,
.site-header .header-call:hover{
  background: rgba(255, 255, 255, .16) !important;
  border-color: rgba(255, 255, 255, .34) !important;
  color: #ffffff;
}

.site-header .nav-dropdown{
  background: #f8fbfd;
  border-color: #c8d7e3;
  box-shadow: 0 18px 42px rgba(10, 30, 47, .2);
}

.site-header .nav-dropdown a{
  color: #14324a;
}

.site-header .nav-dropdown a:hover,
.site-header .nav-dropdown a.active{
  background: #e7eff5;
  color: #0f283b;
}

.site-header .lang-switch.lang-dropdown{
  position: relative;
}

.site-header .lang-dropdown-trigger{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 40px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 255, 255, .28);
  background: rgba(255, 255, 255, .08);
  color: #eef4f8;
  text-transform: uppercase;
  letter-spacing: .06em;
  font-size: .76rem;
  cursor: pointer;
}

.site-header .lang-dropdown-trigger:hover,
.site-header .lang-switch.open .lang-dropdown-trigger{
  background: rgba(255, 255, 255, .16);
  border-color: rgba(255, 255, 255, .38);
  color: #ffffff;
}

.site-header .lang-caret{
  width: 8px;
  height: 8px;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transform-origin: center;
}

.site-header .lang-dropdown-menu{
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  display: grid;
  min-width: 130px;
  padding: 4px;
  border: 1px solid #c8d7e3;
  background: #f8fbfd;
  box-shadow: 0 12px 28px rgba(10, 30, 47, .18);
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  pointer-events: none;
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
  z-index: 120;
}

.site-header .lang-switch.open .lang-dropdown-menu{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

.site-header .lang-dropdown-menu .lang-option{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 10px;
  border: 1px solid transparent;
  color: #14324a;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.site-header .lang-dropdown-menu .lang-option:hover,
.site-header .lang-dropdown-menu .lang-option.active{
  background: #e7eff5;
  border-color: #d2e0ea;
  color: #0f283b;
}

.site-header .lang-flag{
  width: 16px;
  height: 12px;
  border-radius: 2px;
  border: 1px solid rgba(12, 28, 40, .18);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .2);
  flex: 0 0 auto;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

.site-header .lang-flag-es{
  background-image: url('/assets/img/flags/es.png');
}

.site-header .lang-flag-sv{
  background-image: url('/assets/img/flags/se.png');
}

.site-header .lang-flag-en{
  background-image: url('/assets/img/flags/en.png');
}

.site-header .lang-flag-generic{
  background: #5f7689;
}

@media (max-width: 980px){
  .site-header .main-nav > a,
  .site-header .nav-dropdown-toggle{
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, .14) !important;
    border-radius: 0 !important;
    color: #eef4f8 !important;
    padding: 14px 2px !important;
    min-height: 0;
  }

  .site-header .main-nav > a:hover,
  .site-header .nav-dropdown-toggle:hover,
  .site-header .nav-group.open .nav-dropdown-toggle,
  .site-header .nav-group.is-active .nav-dropdown-toggle{
    background: transparent !important;
    border-bottom-color: rgba(255, 255, 255, .35) !important;
    color: #ffffff !important;
  }

  .site-header .main-nav > a.active{
    background: transparent !important;
    border-bottom-color: rgba(255, 255, 255, .14) !important;
    color: #eef4f8 !important;
  }

  .site-header .main-nav{
    gap: 0;
  }

  .site-header .nav-group{
    border-bottom: 1px solid rgba(255, 255, 255, .14);
  }

  .site-header .nav-group .nav-dropdown-toggle{
    border-bottom: 0 !important;
  }

  .site-header .nav-dropdown{
    background: transparent;
    border: 0;
    box-shadow: none;
    margin-top: 0;
    padding: 0 0 8px 12px;
  }

  .site-header .nav-group.is-active .nav-dropdown{
    display: none;
  }

  .site-header .nav-group.open .nav-dropdown{
    display: grid;
  }

  .site-header .nav-dropdown a{
    background: transparent;
    border: 0;
    border-left: 1px solid rgba(255, 255, 255, .14);
    color: rgba(238, 244, 248, .82);
    padding: 10px 12px;
    font-size: .84rem;
  }

  .site-header .nav-dropdown a:hover,
  .site-header .nav-dropdown a.active{
    background: transparent;
    border-left-color: rgba(255, 255, 255, .14);
    color: rgba(238, 244, 248, .82);
  }

  .site-header .nav-dropdown a:hover{
    background: transparent;
    border-left-color: rgba(255, 255, 255, .34);
    color: #ffffff;
  }

  .site-header .header-call{
    background: #ffffff !important;
    border-color: #c8d7e3 !important;
    color: #14324a !important;
  }

  .site-header .header-call:hover{
    background: #e7eff5 !important;
    border-color: #c8d7e3 !important;
    color: #0f283b !important;
  }

  .site-header .lang-switch.lang-dropdown{
    width: auto;
  }

  .site-header .lang-dropdown-menu{
    right: 0;
    min-width: 118px;
  }
}

