:root{
  --bg:#0b0f14;
  --card:#ffffff;
  --text:#0f172a;
  --muted:#64748b;
  --border:#e5e7eb;
  --accent:#fbbf24;
}

@font-face{font-family:'CompassAvenir';src:url('../compass/fonts/Avenir-Roman.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'CompassAvenir';src:url('../compass/fonts/Avenir-Oblique.woff2') format('woff2');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'CompassAvenir';src:url('../compass/fonts/Avenir-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'CompassAvenir';src:url('../compass/fonts/Avenir-Black.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:'CompassLato';src:url('../compass/fonts/Lato-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'CompassLato';src:url('../compass/fonts/Lato-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'CompassLato';src:url('../compass/fonts/Lato-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:CompassLato,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:#fff}
a{color:inherit}

.container{max-width:1200px;margin:0 auto;padding:0 20px}
.heading{font-family:CompassAvenir,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
.kicker{letter-spacing:.35em;text-transform:uppercase;font-size:12px;color:rgba(255,255,255,.8)}

.topbar{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(0,0,0,.25);backdrop-filter:blur(8px);border-bottom:1px solid rgba(255,255,255,.12)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none}
.brand-dot{width:10px;height:10px;border-radius:50%;background:var(--accent)}
.nav{display:flex;gap:18px;align-items:center}
.nav a{color:#fff;text-decoration:none;font-size:14px;opacity:.9}
.nav a:hover{opacity:1}
.header-phone{display:flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-size:14px;opacity:.9;padding:6px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.2);transition:all .2s}
.header-phone:hover{opacity:1;background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3)}
.header-phone-icon{font-size:16px;line-height:1}
.header-phone-text{font-weight:500;white-space:nowrap}
@media(max-width:1024px){.header-phone-text{display:none}}
@media(max-width:768px){.header-phone{display:none}}
.lang{display:flex;gap:8px}
.lang a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:30px;border:1px solid rgba(255,255,255,.25);border-radius:8px;color:#fff;text-decoration:none;font-size:13px}
.lang a.active{border-color:rgba(255,255,255,.9)}

.menu-btn{display:none;align-items:center;justify-content:center;width:42px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;cursor:pointer}
.menu-btn:hover{background:rgba(255,255,255,.10)}
.menu-icon{width:18px;height:14px;position:relative}
.menu-icon span{position:absolute;left:0;right:0;height:2px;background:#fff;border-radius:2px}
.menu-icon span:nth-child(1){top:0}
.menu-icon span:nth-child(2){top:6px;opacity:.9}
.menu-icon span:nth-child(3){top:12px;opacity:.85}

.mobile-menu{position:fixed;inset:0;z-index:120;display:none}
.mobile-menu.open{display:block}
.mobile-menu .backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.mobile-menu .panel{position:absolute;top:0;right:0;height:100%;width:min(420px, 88vw);background:#0b0f14;color:#fff;border-left:1px solid rgba(255,255,255,.12);padding:18px 18px 26px}
.mobile-menu .panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.mobile-menu .panel-title{display:flex;align-items:center;gap:10px}
.mobile-menu .panel-title .name{font-weight:900}
.mobile-menu .panel-nav{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.mobile-menu .panel-nav a{display:flex;align-items:center;justify-content:space-between;padding:12px 12px;border-radius:12px;background:rgba(255,255,255,.06);text-decoration:none}
.mobile-menu .panel-nav a:hover{background:rgba(255,255,255,.10)}
.mobile-menu .panel-nav small{opacity:.7}
.mobile-menu .panel-contact{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12)}
.mobile-menu .panel-phone{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;background:rgba(14,165,233,.15);color:#fff;text-decoration:none;font-size:15px;border:1px solid rgba(14,165,233,.25)}
.mobile-menu .panel-phone:hover{background:rgba(14,165,233,.22);border-color:rgba(14,165,233,.35)}
.mobile-menu .panel-phone span:first-child{font-size:20px}
.mobile-menu .panel-phone strong{font-weight:700}
.mobile-menu .panel-lang{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap}
.mobile-menu .panel-lang a{display:inline-flex;align-items:center;justify-content:center;height:34px;min-width:44px;padding:0 12px;border-radius:10px;border:1px solid rgba(255,255,255,.22);text-decoration:none}
.mobile-menu .panel-lang a.active{border-color:rgba(255,255,255,.9)}

@media (max-width: 860px){
  .nav{display:none}
  .lang{display:none}
  .menu-btn{display:inline-flex}
}

.hero{position:relative;height:92vh;min-height:640px;background:var(--bg);color:#fff;overflow:hidden}
.hero video,.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.64), rgba(0,0,0,.28), rgba(0,0,0,.64))}
.hero-content{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;height:100%;padding-top:64px}
.hero-card{max-width:920px;text-align:center}
.hero h1{margin:18px 0 0;font-size:44px;line-height:1.05;font-weight:900;white-space:pre-line}
.hero-actions{margin-top:26px;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:999px;text-decoration:none;font-weight:700}
.btn-primary{background:var(--accent);color:#111827}
.btn-primary:hover{filter:brightness(.97)}
.btn-ghost{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.scroll-down{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);z-index:2;color:#fff;text-decoration:none;font-size:12px;letter-spacing:.28em;text-transform:uppercase;opacity:.85}
.scroll-down:hover{opacity:1}

.section{padding:64px 0}
.section.gray{background:#f8fafc;border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9}
.section-title{margin:0;font-size:34px;font-weight:900;white-space:pre-line}
.section-sub{margin:14px auto 0;max-width:900px;color:var(--muted)}

.cards{margin-top:28px;display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:16px}
@media (min-width: 720px){.cards{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (min-width: 1040px){.cards{grid-template-columns:repeat(3,minmax(0,1fr))}}
.card{border:1px solid var(--border);border-radius:18px;background:var(--card);padding:22px}
.card .icon{width:52px;height:52px}
.card h3{margin:14px 0 0;font-size:18px}
.card p{margin:10px 0 0;color:#475569}

.finishes-grid{margin-top:28px;display:grid;grid-template-columns:1fr;gap:18px;align-items:center}
@media (min-width: 980px){.finishes-grid{grid-template-columns:1.2fr .8fr}}
.finishes-image{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#f1f5f9}
.finishes-image img{width:100%;height:520px;object-fit:cover;display:block}
@media (max-width: 600px){.finishes-image img{height:360px}}
.chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
@media (min-width: 980px){.chips{justify-content:flex-start}}
.chip{width:48px;height:48px;border-radius:999px;border:1px solid var(--border);padding:0;background:#fff;cursor:pointer}
.chip img{width:100%;height:100%;border-radius:999px;object-fit:cover;display:block}
.chip.active{border-color:#111827;box-shadow:0 0 0 3px rgba(17,24,39,.12)}
.chip-label{margin:0 0 12px;font-size:18px;font-weight:700}

.parallax{height:380px;border-top:1px solid #0b1220;border-bottom:1px solid #0b1220;background:#0b1220;position:relative;overflow:hidden}
.parallax img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.05)}
.parallax::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.55), rgba(0,0,0,.25), rgba(0,0,0,.55))}

.cta-band{padding:56px 0;background:linear-gradient(135deg,#0b1220,#0b0f14);color:#fff}
.cta-band .cta-wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.cta-band h2{margin:0;font-size:34px;font-weight:900}
.cta-band p{margin:10px 0 0;color:rgba(255,255,255,.78)}

.text-image{padding:64px 0;background:#fff}
.text-image .wrap{display:grid;grid-template-columns:1fr;gap:18px;align-items:center}
@media (min-width: 980px){.text-image .wrap{grid-template-columns:1fr 1fr;gap:26px}}
.text-image .media{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#f8fafc}
.text-image .media img{width:100%;height:520px;object-fit:cover;display:block}
@media (max-width: 600px){.text-image .media img{height:320px}}
.quote{font-size:16px;line-height:1.65;color:#0f172a}
.quote p{margin:0}
.quote .title{margin:0 0 10px;font-size:28px;font-weight:900}
.quote .muted{margin-top:14px;color:var(--muted)}

.video-section{padding:64px 0;background:#0b0f14;color:#fff}
.video-section .wrap{display:grid;grid-template-columns:1fr;gap:18px;align-items:center}
@media (min-width: 980px){.video-section .wrap{grid-template-columns:1fr 1fr;gap:26px}}
.video-section video{width:100%;border-radius:18px;border:1px solid rgba(255,255,255,.16);background:#000}
.video-section h2{margin:0;font-size:30px;font-weight:900}
.video-section p{margin:12px 0 0;color:rgba(255,255,255,.78)}

.showcase{padding:64px 0;background:#fff}
.showcase-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.showcase-grid{margin-top:22px;display:grid;grid-template-columns:1fr;gap:14px}
@media (min-width: 720px){.showcase-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.shot{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#f8fafc}
.shot img{width:100%;height:220px;object-fit:cover;display:block}
@media (max-width: 600px){.shot img{height:200px}}

.tabs{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 22px}
.tab{
  position:relative;
  z-index:0;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.18);
  background:#0b1220;
  color:#fff;
  border-radius:999px;
  padding:10px 14px;
  font-size:13px;
  cursor:pointer;
}
.tab::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:url('../compass/finishes/previews/nova-blue.png') center/cover no-repeat;
  opacity:.95;
}
.tab:hover{filter:brightness(1.05)}
.tab.active{
  border-color:rgba(255,255,255,.55);
  box-shadow:0 0 0 3px rgba(2,132,199,.18);
}
.grid{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width: 720px){.grid{grid-template-columns:repeat(2, minmax(0, 1fr))}}
@media (min-width: 1040px){.grid{grid-template-columns:repeat(3, minmax(0, 1fr))}}
.pool{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#fff}
.pool-img{background:#f8fafc}
.pool-img img{width:100%;height:220px;object-fit:cover;display:block}
.pool-body{padding:16px}
.pool-title{margin:0;font-size:16px;font-weight:800}
.kv{margin-top:10px;font-size:13px;color:#334155}
.kv-row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px dashed #e2e8f0}
.kv-row:last-child{border-bottom:none}
.btn-row{margin-top:14px}
.btn-block{width:100%;border:none;cursor:pointer}
.btn-green{
  position:relative;
  z-index:0;
  overflow:hidden;
  background:#0b1220;
  color:#fff;
  border-radius:12px;
  padding:12px 14px;
  font-weight:900;
  letter-spacing:.02em;
  text-shadow:0 1px 0 rgba(0,0,0,.25);
}
.btn-green::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:url('../compass/finishes/previews/nova-blue.png') center/cover no-repeat;
  opacity:.95;
}
.btn-green:hover{filter:brightness(1.06)}

.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:80;padding:18px}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.modal-card{position:relative;z-index:2;width:min(920px, 100%);background:#fff;border-radius:18px;overflow:hidden}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border)}
.modal-close{border:none;background:#fff;width:40px;height:40px;border-radius:999px;cursor:pointer}
.modal-close:hover{background:#f1f5f9}
.modal-body{display:grid;grid-template-columns:1fr;gap:0}
@media (min-width: 900px){.modal-body{grid-template-columns:1fr 1fr}}
.modal-media{background:#f8fafc;padding:16px}
.modal-media img{width:100%;height:340px;object-fit:cover;border-radius:14px}
.modal-info{padding:16px}

/* Comparison table: concrete vs our pools */
.comparison-section{background:#f8fafc;border-top:1px solid #e2e8f0}
.comparison-table-wrap{margin-top:32px;overflow-x:auto;border-radius:16px;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.comparison-table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;table-layout:fixed;display:table}
.comparison-table thead{background:#0f172a;color:#fff;display:table-header-group}
.comparison-table tbody{display:table-row-group}
.comparison-table tr{display:table-row}
.comparison-table th,.comparison-table td{display:table-cell;padding:16px 20px;font-size:15px;line-height:1.45;vertical-align:middle;width:50%}
.comparison-table th{padding:18px 20px;font-size:16px;font-weight:800;text-align:left}
.comparison-table tbody tr{border-bottom:1px solid #e2e8f0}
.comparison-table tbody tr:last-child{border-bottom:none}
.comparison-cell-inner{display:flex;align-items:center;gap:12px}
.comparison-col-left{background:linear-gradient(90deg, rgba(254,226,226,.25) 0%, rgba(254,226,226,.08) 100%);border-right:2px solid #fecaca}
.comparison-col-right{background:linear-gradient(90deg, rgba(220,252,231,.2) 0%, rgba(220,252,231,.4) 100%);border-left:2px solid #86efac}
.comparison-minus{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;font-size:26px;font-weight:900;color:#dc2626;background:#fecaca;border-radius:10px;line-height:1}
.comparison-plus{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;font-size:30px;font-weight:900;color:#15803d;background:#86efac;border-radius:12px;line-height:1;box-shadow:0 2px 10px rgba(34,197,94,.3)}
.comparison-col-left .comparison-text{font-weight:700;color:#991b1b}
.comparison-col-right .comparison-text{font-weight:700;color:#166534}
@media (max-width: 640px){
  .comparison-table th,.comparison-table td{padding:12px 14px;font-size:14px}
  .comparison-minus{min-width:28px;height:28px;font-size:20px;margin-right:10px}
  .comparison-plus{min-width:30px;height:30px;font-size:24px;margin-right:10px}
}

.cta{background:#f0fdf4;border-top:1px solid #dcfce7}
.form{max-width:720px;margin:18px auto 0;display:grid;gap:12px}
.row{display:grid;gap:12px}
@media (min-width: 720px){.row{grid-template-columns:1fr 1fr}}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;color:#334155}
.field input{padding:12px 12px;border-radius:12px;border:1px solid var(--border);font-size:14px}
.field input:focus{outline:none;border-color:#94a3b8;box-shadow:0 0 0 3px rgba(148,163,184,.18)}
.submit{margin-top:4px}
.submit button{width:100%;border:none;border-radius:12px;padding:14px 16px;font-weight:900;background:#111827;color:#fff;cursor:pointer}
.submit button:hover{filter:brightness(1.05)}
.form-note{font-size:12px;color:#64748b;text-align:center}
.toast{display:none;margin-top:10px;padding:12px 14px;border-radius:12px;background:#ecfeff;border:1px solid #a5f3fc;color:#0f172a}
.toast.show{display:block}

.footer{padding:30px 0;color:#64748b;font-size:12px;text-align:center;border-top:1px solid #f1f5f9}

/* Cookie banner (EU compliant, Spanish) */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#0f172a;color:#f8fafc;box-shadow:0 -4px 20px rgba(0,0,0,.2);padding:20px 0}
.cookie-banner[hidden]{display:none}
.cookie-banner-inner{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px}
.cookie-banner-text{flex:1;min-width:280px}
.cookie-banner-title{margin:0 0 8px;font-size:16px;font-weight:700;font-family:CompassAvenir,system-ui,sans-serif}
.cookie-banner-desc{margin:0;font-size:14px;line-height:1.5;opacity:.92}
.cookie-banner-desc a{color:var(--accent,#fbbf24);text-decoration:underline}
.cookie-banner-desc a:hover{opacity:.9}
.cookie-banner-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.cookie-btn{padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:opacity .2s}
.cookie-btn:hover{opacity:.9}
.cookie-btn-reject{background:rgba(255,255,255,.12);color:#f8fafc;border:1px solid rgba(255,255,255,.25)}
.cookie-btn-accept{background:var(--accent,#fbbf24);color:#0f172a}
@media(max-width:600px){.cookie-banner-inner{flex-direction:column;align-items:stretch}.cookie-banner-actions{justify-content:stretch}.cookie-btn{flex:1}}

