:root{
  --gw-primary:#0B3C5D;
  --gw-primary-dark:#07273c;
  --gw-primary-mid:#09334f;
  --gw-bg:#F8FAFC;
  --gw-surface:#ffffff;
  --gw-accent:#C9A227;
  --gw-accent-dark:#C9A227;
  --gw-accent-text:#ffffff;
  --gw-secondary:#18A0AE;
  --gw-secondary-dark:#148894;
  --gw-support:#F1F5F9;
  --gw-support-dark:#E2E8F0;
  --gw-text:#1E293B;
  --gw-text-soft:#64748B;
  --gw-border:#E2E8F0;
  --radius-sm:2px;
  --radius-md:4px;
  --radius-lg:8px;
  --maxw:1200px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Inter',sans-serif;
  background:var(--gw-bg);
  color:var(--gw-text);
  line-height:1.7;
  font-size:17px;
}
h1,h2,h3,h4{
  font-family:'Playfair Display',serif;
  font-weight:700;
  line-height:1.2;
  margin:0 0 .6em;
  color:var(--gw-primary);
  letter-spacing:-0.01em;
}
h1{font-size:clamp(36px,5.6vw,64px);font-weight:700;}
h2{font-size:clamp(26px,3.6vw,40px);}
h3{font-size:22px;}
p{margin:0 0 1em;color:var(--gw-text-soft);}
a{color:var(--gw-primary);text-decoration:none;}
a:hover{text-decoration:underline;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.small{font-size:14px;color:var(--gw-text-soft);}

/* Header */
header.site{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:transparent;
  border-bottom:1px solid transparent;
  transition:background-color .3s ease,border-color .3s ease,backdrop-filter .3s ease;
}
header.site.scrolled{
  background:rgba(248,250,252,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--gw-border);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;max-width:var(--maxw);margin:0 auto;
  transition:padding .3s ease;
}
header.site.scrolled .nav{padding:14px 24px;}
.logo{
  display:flex;align-items:center;gap:10px;
  font-family:'Playfair Display',serif;font-weight:700;font-size:22px;
  letter-spacing:-0.02em;
  color:#fff;
  text-decoration:none;
  transition:color .3s ease;
}
.logo:hover{text-decoration:none;}
header.site.scrolled .logo{color:var(--gw-primary);}
.logo svg{flex-shrink:0;}
.nav-links{display:flex;gap:32px;align-items:center;}
.nav-links a{
  color:rgba(255,255,255,.85);font-weight:500;font-size:14px;
  letter-spacing:.02em;
  transition:color .3s ease;
}
header.site.scrolled .nav-links a{color:var(--gw-text-soft);}
.nav-links a:hover{color:var(--gw-secondary);text-decoration:none;}
header.site.scrolled .nav-links a:hover{color:var(--gw-secondary);}
.nav-search{display:inline-flex;align-items:center;color:rgba(255,255,255,.85);transition:color .3s ease;}
header.site.scrolled .nav-search{color:var(--gw-text-soft);}
.nav-search:hover{color:var(--gw-secondary);}
header.site.scrolled .nav-search:hover{color:var(--gw-secondary);}
.btn{
  display:inline-block;padding:14px 32px;border-radius:var(--radius-sm);
  font-family:'Inter',sans-serif;font-weight:700;font-size:13px;
  letter-spacing:.12em;text-transform:uppercase;
  border:2px solid transparent;cursor:pointer;
  transition:all .25s ease;
}
.btn-primary{background:var(--gw-accent);color:var(--gw-accent-text);border-color:var(--gw-accent);}
.btn-primary:hover{background:var(--gw-accent-dark);border-color:var(--gw-accent-dark);color:var(--gw-accent-text);text-decoration:none;}
.btn-outline{background:transparent;border-color:var(--gw-primary);color:var(--gw-primary);}
.btn-outline:hover{background:var(--gw-primary);color:#fff;text-decoration:none;}
.nav-links .btn-primary{padding:11px 24px;font-size:12px;}
.nav-cta{display:none;}
@media(min-width:860px){.nav-cta{display:inline-block;}}
.menu-toggle{display:block;background:none;border:none;font-size:26px;color:#fff;cursor:pointer;transition:color .3s ease;}
header.site.scrolled .menu-toggle{color:var(--gw-primary);}
@media(min-width:860px){.menu-toggle{display:none;}}
.nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--gw-primary);padding:24px;border-bottom:1px solid var(--gw-primary-dark);align-items:flex-start;}
.nav-links.open{display:flex;}
@media(min-width:860px){.nav-links{display:flex;flex-direction:row;position:static;background:none;padding:0;border:none;align-items:center;}}

/* Hero */
.hero{
  padding:180px 0 88px;
  background:linear-gradient(160deg,var(--gw-primary) 0%,var(--gw-primary-mid) 55%,var(--gw-primary-dark) 100%);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:"";position:absolute;left:0;right:0;bottom:-1px;height:120px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 40' preserveAspectRatio='none'%3E%3Cpath d='M0 20 C 100 0, 200 40, 300 20 S 500 0, 600 20 S 800 40, 900 20 S 1100 0, 1200 20' stroke='%2318a0ae' stroke-width='1' fill='none' opacity='0.3'/%3E%3C/svg%3E") repeat-x bottom;
  background-size:1200px 40px;
  pointer-events:none;
}
.hero .wrap{position:relative;z-index:1;}
.hero-video{background:var(--gw-primary-dark);}
.hero-bg-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(160deg,rgba(11,60,93,.82) 0%,rgba(9,51,79,.72) 55%,rgba(7,39,60,.9) 100%);
}
.hero-photo{background:var(--gw-primary-dark);padding-bottom:260px;}
.hero-photo::after{display:none;}
.hero-bg-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.hero-fade{
  position:absolute;left:0;right:0;bottom:0;height:240px;
  background:linear-gradient(to bottom, rgba(248,250,252,0) 0%, var(--gw-bg) 82%);
}
.hero-inner{display:grid;gap:48px;align-items:center;}
@media(min-width:900px){.hero-inner{grid-template-columns:1.1fr .9fr;}}
.hero h1{color:#fff;}
.hero .breadcrumb,.hero .breadcrumb a{color:rgba(255,255,255,.6);}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--gw-secondary);
  font-family:'Inter',sans-serif;font-weight:700;font-size:13px;
  text-transform:uppercase;letter-spacing:.28em;
  margin-bottom:20px;
}
.hero p.lead{font-size:19px;max-width:52ch;color:rgba(255,255,255,.78);}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px;}
.hero .btn-outline{border-color:#fff;color:#fff;}
.hero .btn-outline:hover{background:#fff;color:var(--gw-primary);}
.pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:32px;}
.hero .chip{border-color:rgba(255,255,255,.3);color:rgba(255,255,255,.85);}
.hero .chip:hover{border-color:var(--gw-secondary);color:var(--gw-secondary);}
.hero-visual{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius-lg);
  padding:36px;color:#fff;min-height:280px;
  display:flex;flex-direction:column;justify-content:space-between;
  backdrop-filter:blur(6px);
}
.hero-visual > div + div{margin-top:24px;}
.hero-visual .stat{font-family:'Playfair Display',serif;font-size:44px;font-weight:700;color:var(--gw-secondary);}
.hero-visual .stat-label{font-size:13px;opacity:.75;text-transform:uppercase;letter-spacing:.08em;margin-top:4px;}
.post-meta{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em;}
@media(max-width:700px){
  .hero-photo{padding-bottom:180px;}
  .hero-fade{height:160px;}
}

/* Wave divider (legacy element kept as spacer, visual accent now lives in .hero::after) */
.wave{width:100%;height:0;display:block;margin:0;visibility:hidden;}

/* Sections */
section{padding:88px 0;}
.section-alt{background:var(--gw-surface);}
.section-head{max-width:640px;margin-bottom:48px;}

/* Cards grid */
.grid{display:grid;gap:2px;background:var(--gw-border);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
@media(max-width:700px){.grid-3,.grid-2{grid-template-columns:1fr;}}
@media(min-width:701px) and (max-width:960px){.grid-3{grid-template-columns:repeat(2,1fr);}}
.card{
  background:var(--gw-surface);
  padding:40px 32px;
  transition:background-color .25s ease,transform .25s ease;
}
.card:hover{background:var(--gw-bg);}
.card h3{margin-bottom:.5em;font-size:21px;}
.card .icon{
  width:44px;height:44px;border-radius:var(--radius-sm);background:var(--gw-support);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
  color:var(--gw-primary);font-family:'Playfair Display',serif;font-weight:700;
}

/* Photo filler cards (complete grid rows with real imagery instead of empty cells) */
.card-photo{position:relative;min-height:240px;overflow:hidden;padding:0;}
.card-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .5s ease;}
.card-photo:hover img{transform:scale(1.06);}
.card-photo-wide{grid-column:span 2;}
@media(max-width:960px){.card-photo-wide{grid-column:span 1;}}

/* Full-bleed photo band */
.photo-band{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--gw-border);margin-top:56px;}
.photo-band .photo-item{position:relative;aspect-ratio:4/5;overflow:hidden;}
.photo-band .photo-item img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:transform .5s ease;}
.photo-band .photo-item:hover img{transform:scale(1.06);}
@media(max-width:700px){.photo-band{grid-template-columns:1fr;}}

/* Single full-width photo banner (zona/sector pages) */
.single-photo{position:relative;aspect-ratio:21/9;overflow:hidden;border-radius:var(--radius-lg);}
.single-photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;}
@media(max-width:700px){.single-photo{aspect-ratio:4/3;}}
.card-link{
  font-size:13px;font-weight:700;display:inline-block;margin-top:12px;
  text-transform:uppercase;letter-spacing:.1em;color:var(--gw-primary);
  border-bottom:1px solid var(--gw-secondary);padding-bottom:2px;
}
.card-link:hover{color:var(--gw-secondary);text-decoration:none;border-color:var(--gw-secondary);}

/* Zone / sector chip list */
.chip-list{display:flex;flex-wrap:wrap;gap:10px;}
.chip{
  background:transparent;border:1px solid var(--gw-border);
  padding:10px 18px;border-radius:var(--radius-sm);font-size:13px;color:var(--gw-text);
  font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  transition:all .2s ease;
}
.chip:hover{border-color:var(--gw-primary);background:var(--gw-primary);color:#fff;text-decoration:none;}

/* CTA band */
.cta-band{
  background:var(--gw-primary);
  padding:64px 48px;text-align:center;color:#fff;
}
.cta-band h2{color:#fff;}
.cta-band p{color:rgba(255,255,255,.75);max-width:56ch;margin:0 auto 28px;}

/* FAQ */
.faq-item{border-bottom:1px solid var(--gw-border);padding:22px 0;}
.faq-item summary{cursor:pointer;font-family:'Playfair Display',serif;font-weight:700;color:var(--gw-primary);font-size:18px;}
.faq-item summary:hover{color:var(--gw-secondary);}
.faq-item p{margin-top:14px;}

/* Breadcrumb */
.breadcrumb{font-size:13px;color:var(--gw-text-soft);margin-bottom:18px;text-transform:uppercase;letter-spacing:.06em;}
.breadcrumb a{color:var(--gw-text-soft);}

/* Table-ish list */
.check-list{list-style:none;padding:0;margin:0;}
.check-list li{padding-left:28px;position:relative;margin-bottom:10px;}
.check-list li::before{
  content:"";position:absolute;left:0;top:7px;width:14px;height:14px;
  border-radius:50%;background:var(--gw-secondary);
}

/* Footer */
footer.site{background:var(--gw-primary-dark);color:rgba(255,255,255,.65);padding:72px 0 32px;margin-top:0;}
footer.site a{color:rgba(255,255,255,.65);}
footer.site a:hover{color:var(--gw-secondary);}
.footer-grid{display:grid;gap:40px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:48px;}
.footer-grid h4{color:var(--gw-secondary);font-family:'Inter',sans-serif;font-size:12px;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px;}
.footer-grid ul{list-style:none;padding:0;margin:0;}
.footer-grid li{margin-bottom:10px;font-size:14px;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;font-size:13px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;color:rgba(255,255,255,.4);}

/* Blog */
article.post-body h2{margin-top:1.6em;}
article.post-body{max-width:70ch;}

/* Reveal on scroll */
.reveal-on-scroll{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease;}
.reveal-on-scroll.visible{opacity:1;transform:translateY(0);}

/* Cookie consent banner */
.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;z-index:200;
  background:var(--gw-primary-dark);
  box-shadow:0 -8px 32px rgba(0,0,0,.28);
  padding:22px 24px;
  transform:translateY(110%);
  transition:transform .4s ease;
}
.cookie-banner.visible{transform:translateY(0);}
.cookie-banner-inner{
  max-width:var(--maxw);margin:0 auto;
  display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between;
}
.cookie-banner p{margin:0;font-size:14px;line-height:1.6;color:rgba(255,255,255,.8);max-width:640px;}
.cookie-banner a{color:var(--gw-secondary);}
.cookie-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0;}
.cookie-actions button{
  padding:12px 26px;border-radius:var(--radius-sm);
  font-family:'Inter',sans-serif;font-weight:700;font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;cursor:pointer;
  transition:all .2s ease;
}
.cookie-reject{background:transparent;border:2px solid rgba(255,255,255,.3);color:#fff;}
.cookie-reject:hover{border-color:#fff;}
.cookie-accept{background:var(--gw-accent);border:2px solid var(--gw-accent);color:var(--gw-accent-text);}
.cookie-accept:hover{background:var(--gw-accent-dark);border-color:var(--gw-accent-dark);}

/* Search */
.search-box{display:flex;gap:12px;flex-wrap:wrap;}
.search-box input{
  flex:1;min-width:220px;padding:14px 18px;border-radius:var(--radius-sm);
  border:2px solid rgba(255,255,255,.3);font-family:'Inter',sans-serif;font-size:16px;
  background:rgba(255,255,255,.08);color:#fff;
}
.search-box input::placeholder{color:rgba(255,255,255,.55);}
.search-box input:focus{outline:none;border-color:var(--gw-secondary);}
#search-results{min-height:40px;}
#search-results .grid{margin-top:32px;}
