:root {
  --bg: #f5f1e8;
  --bg-soft: #fffaf2;
  --ink: #182028;
  --ink-soft: #50606f;
  --deep: #12202d;
  --deep-2: #0d1721;
  --brand: #c96c1d;
  --brand-dark: #a7530c;
  --sea: #1f5d70;
  --sand: #ead9b7;
  --line: rgba(18, 32, 45, 0.12);
  --shadow: 0 24px 55px rgba(18, 32, 45, 0.12);
  --radius-xl: 34px;
  --radius-lg: 26px;
  --radius-md: 18px;
  --radius-sm: 14px;
  --container: 1180px;
  --btn-height: 54px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Outfit", sans-serif;
  color: var(--ink);
  background:
    radial-gradient(circle at top left, rgba(201, 108, 29, 0.14), transparent 28%),
    radial-gradient(circle at top right, rgba(31, 93, 112, 0.12), transparent 30%),
    linear-gradient(180deg, #fffdf9 0%, #f7f1e7 45%, #fffaf4 100%);
}
img { display: block; max-width: 100%; }
a { color: var(--sea); text-decoration: none; }
a:hover { color: var(--brand-dark); }
p { margin: 0 0 1rem; color: var(--ink-soft); line-height: 1.76; }
h1, h2, h3 {
  margin: 0 0 1rem;
  color: var(--deep-2);
  font-family: "Urbanist", sans-serif;
  line-height: 1.08;
}
ul { margin: 0; padding: 0; list-style: none; }
strong { color: inherit; font-weight: 800; }
.container { width: min(calc(100% - 2rem), var(--container)); margin: 0 auto; }
.topbar {
  background: linear-gradient(90deg, var(--deep-2), var(--deep));
  color: #f5f4ee;
  font-size: 0.95rem;
}
.topbar-inner, .topbar-copy, .topbar-actions, .nav-shell, .hero-grid, .cta-row, .pill-row, .feature-grid, .card-grid, .split-band, .two-column-story, .footer-grid, .footer-bottom, .map-grid, .contact-layout, .zones-grid, .service-layout, .stats-row, .table-actions { display: flex; gap: 1rem; }
.topbar-inner { justify-content: space-between; align-items: center; flex-wrap: wrap; padding: 0.75rem 0; }
.topbar-copy, .topbar-actions { flex-wrap: wrap; }
.topbar-copy span, .mini-link { padding: 0.35rem 0.8rem; border-radius: 999px; border: 1px solid rgba(255, 255, 255, 0.12); background: rgba(255, 255, 255, 0.06); color: #fff8f1; }
.site-header { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(18px); background: rgba(255, 250, 244, 0.92); border-bottom: 1px solid rgba(18, 32, 45, 0.08); }
.nav-shell { justify-content: space-between; align-items: center; padding: 1rem 0; }
.brand { display: inline-flex; align-items: center; gap: 0.9rem; color: var(--deep); }
.brand img { width: 58px; height: 58px; padding: 0.35rem; border-radius: 18px; background: linear-gradient(145deg, #ffffff, #efe7d9); border: 1px solid var(--line); }
.brand span { display: grid; gap: 0.1rem; }
.brand strong { font-size: 1rem; }
.brand small { color: var(--ink-soft); }
.site-nav { display: flex; align-items: center; gap: 0.4rem; }
.site-nav a { padding: 0.7rem 0.8rem; border-radius: 999px; color: var(--deep); font-weight: 700; }
.site-nav a.is-active, .site-nav a:hover { background: rgba(18, 32, 45, 0.07); }
.nav-toggle { display: none; background: transparent; border: 0; padding: 0; }
.nav-toggle span { display: block; width: 28px; height: 3px; margin: 5px 0; border-radius: 999px; background: var(--deep); }
.btn { display: inline-flex; justify-content: center; align-items: center; min-height: var(--btn-height); padding: 0.9rem 1.35rem; border-radius: 999px; border: 1px solid transparent; font-weight: 800; transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: linear-gradient(135deg, var(--brand), var(--brand-dark)); color: #fff; box-shadow: 0 16px 32px rgba(201, 108, 29, 0.28); }
.btn-primary:hover { color: #fff; }
.btn-secondary { background: rgba(255, 255, 255, 0.88); border-color: rgba(18, 32, 45, 0.12); color: var(--deep); }
.btn-light { background: rgba(255, 255, 255, 0.12); color: #fff; border-color: rgba(255, 255, 255, 0.24); }
.btn-light:hover { color: #fff; background: rgba(255, 255, 255, 0.18); }
.hero { padding: 3.5rem 0 2.8rem; }
.hero-home { position: relative; overflow: hidden; background: linear-gradient(120deg, rgba(9, 18, 28, 0.92) 0%, rgba(18, 32, 45, 0.84) 52%, rgba(31, 93, 112, 0.84) 100%), url("assets/Maresme Cerrajeros - Llovizna [Pineda de mar].png") center/cover no-repeat; }
.hero-grid { align-items: stretch; }
.hero-grid > * { flex: 1 1 0; }
.hero-copy, .hero-media { display: grid; gap: 1.2rem; }
.hero-copy { color: #fff; padding: 1rem 0; }
.hero-copy p, .hero-copy li, .hero-copy h1, .hero-copy a { color: #fff; }
.eyebrow { display: inline-flex; width: fit-content; padding: 0.45rem 0.85rem; border-radius: 999px; background: rgba(234, 217, 183, 0.55); color: var(--brand-dark); font-weight: 800; letter-spacing: 0.03em; }
.hero-copy .eyebrow,
.page-hero-card .eyebrow,
.section-contrast .eyebrow,
.final-cta-box .eyebrow,
.cta-panel .eyebrow {
  background: rgba(234, 217, 183, 0.18);
  color: #ffe0b4;
}
h1 { font-size: clamp(2.2rem, 5vw, 4.65rem); }
h2 { font-size: clamp(1.7rem, 3vw, 2.9rem); }
h3 { font-size: 1.22rem; }
.hero-photo, .hero-note, .feature-card, .story-card, .service-card, .ladder-card, .content-card, .service-highlight, .contact-card, .info-card, .zone-card, .table-card, .visual-card, .map-card, .final-cta-box, .cta-panel { border: 1px solid var(--line); border-radius: var(--radius-xl); box-shadow: var(--shadow); }
.hero-photo { overflow: hidden; min-height: 460px; }
.hero-photo img { width: 100%; height: 100%; object-fit: cover; }
.hero-note, .feature-card, .story-card, .content-card, .service-highlight, .contact-card, .info-card, .zone-card, .table-card, .visual-card, .cta-panel { padding: 1.55rem; background: rgba(255, 252, 246, 0.95); }
.hero-note { background: rgba(255, 250, 242, 0.92); }
.pill-row, .hero-points, .bullet-list, .contact-list, .check-list, .stats-list, .footer-grid ul, .zone-links, .table-list, .validation-summary { display: grid; gap: 0.8rem; }
.pill-row span, .hero-points li, .bullet-list li, .check-list li, .stats-list li, .zone-links a { position: relative; padding-left: 1.3rem; }
.pill-row span::before, .hero-points li::before, .bullet-list li::before, .check-list li::before, .stats-list li::before, .zone-links a::before { content: ""; position: absolute; left: 0; top: 0.68rem; width: 0.55rem; height: 0.55rem; border-radius: 50%; background: var(--brand); }
.hero-points li::before { background: var(--sand); }
.section { padding: 5rem 0; }
.section-soft { background: linear-gradient(180deg, rgba(255, 248, 238, 0.9), rgba(241, 235, 223, 0.72)); }
.section-contrast { background: linear-gradient(135deg, rgba(18, 32, 45, 0.96), rgba(31, 93, 112, 0.86)), linear-gradient(180deg, #1b2d3f, #143040); }
.section-contrast h2, .section-contrast p, .section-contrast a, .section-contrast strong { color: #fff; }
.section-heading { display: grid; gap: 0.7rem; max-width: 820px; margin-bottom: 2rem; }
.feature-grid, .card-grid, .footer-grid, .contact-layout, .service-layout, .zones-grid { flex-wrap: wrap; }
.feature-grid > *, .card-grid > *, .contact-layout > *, .service-layout > *, .zones-grid > * { flex: 1 1 280px; }
.feature-card h3 a, .service-card h3 a, .ladder-card h3, .zone-card h3 { color: var(--deep); }
.split-band, .two-column-story, .map-grid, .contact-layout { flex-wrap: wrap; align-items: stretch; }
.split-band > *, .two-column-story > *, .map-grid > *, .contact-layout > * { flex: 1 1 340px; }
.cta-panel { background: linear-gradient(155deg, #10202c, #15374a); color: #fff; }
.cta-panel h3, .cta-panel p, .cta-panel a, .cta-panel strong { color: #fff; }
.cta-stack { display: grid; gap: 0.9rem; }
.story-card { background: linear-gradient(180deg, rgba(255, 253, 248, 0.95), rgba(248, 240, 225, 0.95)); }
.service-ladder { display: grid; gap: 1rem; }
.ladder-card { display: block; padding: 1.45rem; background: rgba(255, 255, 255, 0.92); color: inherit; }
.ladder-card:hover { transform: translateY(-1px); }
.card-grid-services .service-card { overflow: hidden; background: rgba(255, 253, 247, 0.96); }
.service-card img { width: 100%; height: 230px; object-fit: cover; }
.service-card div { padding: 1.5rem; }
.page-hero { padding: 3rem 0 2rem; }
.page-hero-card { padding: 2rem; color: #fff; border-radius: 34px; background: linear-gradient(135deg, rgba(12, 24, 35, 0.94), rgba(18, 32, 45, 0.86)), url("assets/Maresme Cerrajeros - Carro [Pineda de mar].png") center/cover no-repeat; }
.page-hero-card p, .page-hero-card a, .page-hero-card h1, .page-hero-card .eyebrow, .page-hero-card strong { color: #fff; }
.breadcrumbs { display: flex; gap: 0.45rem; flex-wrap: wrap; margin-bottom: 1rem; font-size: 0.92rem; }
.breadcrumbs a, .breadcrumbs span { color: rgba(255, 255, 255, 0.9); }
.map-card { overflow: hidden; background: rgba(255, 255, 255, 0.9); }
.map-card iframe { width: 100%; min-height: 440px; border: 0; }
.map-section { padding-top: 4.5rem; }
.map-copy { display: grid; gap: 1rem; }
.contact-card, .info-card, .service-highlight { min-height: 100%; }
.zone-card { background: linear-gradient(180deg, rgba(255, 252, 246, 0.98), rgba(245, 238, 225, 0.95)); }
.zone-links a { display: block; color: var(--sea); }
.stats-row { flex-wrap: wrap; }
.stats-chip { padding: 0.7rem 0.9rem; border-radius: 999px; background: rgba(18, 32, 45, 0.06); color: var(--deep); font-weight: 700; }
.table-card { overflow: auto; }
table { width: 100%; border-collapse: collapse; min-width: 820px; }
th, td { padding: 0.9rem 0.85rem; border-bottom: 1px solid rgba(18, 32, 45, 0.1); text-align: left; vertical-align: top; color: var(--ink-soft); }
th { color: var(--deep); font-family: "Urbanist", sans-serif; background: rgba(18, 32, 45, 0.04); }
.site-footer { margin-top: 3rem; padding: 3rem 0 1.8rem; background: linear-gradient(180deg, #111f2c, #0c1822); color: #f7f3ea; }
.site-footer p, .site-footer a, .site-footer li, .site-footer strong { color: #f7f3ea; }
.site-footer h3 { color: #fff; font-size: 1rem; }
.footer-grid { align-items: start; justify-content: space-between; }
.footer-grid > * { flex: 1 1 220px; }
.footer-brand { margin-bottom: 1rem; }
.footer-bottom { margin-top: 1.4rem; padding-top: 1.4rem; border-top: 1px solid rgba(255, 255, 255, 0.1); }
.final-cta-box { display: flex; gap: 1.3rem; justify-content: space-between; align-items: center; flex-wrap: wrap; padding: 2rem; background: linear-gradient(145deg, #11202d, #1b4f60); }
.final-cta-box h2, .final-cta-box p, .final-cta-box a, .final-cta-box strong { color: #fff; }
.floating-cta { position: fixed; right: 1rem; bottom: 1rem; z-index: 60; min-height: var(--btn-height); padding: 0.9rem 1.2rem; border-radius: 999px; background: linear-gradient(135deg, var(--brand), var(--brand-dark)); color: #fff; font-weight: 800; box-shadow: 0 16px 28px rgba(201, 108, 29, 0.28); }
.floating-cta:hover { color: #fff; }
@media (max-width: 920px) {
  .nav-toggle { display: inline-block; }
  .site-nav { display: none; position: absolute; top: calc(100% + 0.7rem); left: 1rem; right: 1rem; padding: 1rem; flex-direction: column; align-items: stretch; border-radius: 24px; background: rgba(255, 250, 244, 0.98); border: 1px solid var(--line); box-shadow: var(--shadow); }
  .site-nav.is-open { display: flex; }
  .hero, .section { padding: 3.8rem 0; }
}
@media (max-width: 720px) {
  .container { width: min(calc(100% - 1.2rem), var(--container)); }
  .hero, .page-hero { padding-top: 2.4rem; }
  .hero-photo { min-height: 320px; }
  .floating-cta { left: 1rem; right: 1rem; text-align: center; }
  table { min-width: 680px; }
}
