:root {
  --primary: #F97316;
  --secondary: #14B8A6;
  --dark: #475569;
  --light: #FFFFFF;
  --muted: #EAB308;
  --text: #111827;
  --line: rgba(17, 24, 39, .16);
  --shadow: 0 22px 60px rgba(15, 23, 42, .16);
  --head: "DM Serif Display", serif;
  --body: "Lato", sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--body); color: var(--text); background: var(--light); line-height: 1.6; }
a { color: inherit; }
img { max-width: 100%; display: block; object-fit: cover; }
h1, h2, h3 { font-family: var(--head); line-height: 1.05; margin: 0 0 16px; }
h1 { font-size: clamp(2.9rem, 7vw, 6.4rem); }
h2 { font-size: clamp(2rem, 4vw, 3.5rem); }
h3 { font-size: clamp(1.3rem, 2.2vw, 1.9rem); }
p { margin: 0 0 18px; }
.site-header { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; gap: 22px; justify-content: space-between; padding: 16px clamp(18px, 4vw, 56px); background: color-mix(in srgb, var(--light) 88%, transparent); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line); }
.logo { font-family: var(--head); font-size: 1.7rem; text-decoration: none; color: var(--dark); }
nav { display: flex; gap: 16px; flex-wrap: wrap; }
nav a, .footer-links a { text-decoration: none; font-weight: 700; }
.btn, button { display: inline-flex; align-items: center; justify-content: center; min-height: 44px; border: 2px solid transparent; padding: 11px 20px; font-weight: 800; text-decoration: none; cursor: pointer; transition: transform .25s ease, background-color .25s ease, color .25s ease, border-color .25s ease; border-radius: 28px; }
.btn:hover, button:hover { transform: translateY(-2px); }
.btn-primary { background-color: var(--primary); color: #0b0b0b; border-color: var(--primary); }
.btn-primary:hover { background-color: var(--secondary); color: #ffffff; border-color: var(--secondary); }
.btn-secondary { background-color: transparent; color: var(--dark); border-color: var(--primary); }
.btn-secondary:hover { background-color: var(--primary); color: #0b0b0b; }
.btn-cookie { background-color: var(--dark); color: #ffffff; border-color: var(--dark); }
.btn-cookie:hover { background-color: var(--primary); color: #0b0b0b; }
.hero, .page-hero { min-height: 72vh; display: grid; grid-template-columns: 1.08fr .92fr; gap: clamp(24px, 5vw, 70px); align-items: center; padding: clamp(56px, 8vw, 110px) clamp(18px, 5vw, 72px); background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 18%, var(--light)), var(--light) 58%, color-mix(in srgb, var(--secondary) 14%, var(--light))); }
.hero-image img, .page-hero img, .split img, .full-bleed img, .contact-card img { width: 100%; height: min(58vh, 560px); border: 1px solid var(--line); box-shadow: var(--shadow); border-radius: 28px; }
.eyebrow { color: var(--primary); font-weight: 900; letter-spacing: .14em; text-transform: uppercase; font-size: .82rem; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--dark); color: #ffffff; }
.stats div { padding: 30px; background: color-mix(in srgb, var(--dark) 88%, var(--primary)); }
.stats strong { display: block; font-family: var(--head); font-size: 2.7rem; color: var(--primary); }
.section, .catalog-grid, .service-rows, .legal-content, .testimonials, .process, .filters, .contact-layout { padding: clamp(42px, 7vw, 96px) clamp(18px, 5vw, 72px); }
.section-heading { max-width: 760px; margin-bottom: 28px; }
.cards, .feature-grid, .services-list, .process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.card, .service-pill, .feature-grid article, .process-grid article, .legal-block, .service-row, .catalog-card, .contact-card, .contact-form, .success-message { background: #ffffff; border: 1px solid var(--line); padding: 24px; box-shadow: var(--shadow); border-radius: 28px; }
.card span, .ref { color: var(--primary); font-weight: 900; }
.card strong, .catalog-card strong { display: block; margin: 16px 0; font-size: 1.1rem; }
.split, .contact-layout { display: grid; grid-template-columns: .95fr 1.05fr; gap: clamp(24px, 5vw, 70px); align-items: center; }
.accent-block { padding: clamp(42px, 7vw, 96px) clamp(18px, 5vw, 72px); background: color-mix(in srgb, var(--primary) 9%, var(--light)); }
.order-list li { margin: 10px 0; font-weight: 800; }
.alt { background: color-mix(in srgb, var(--dark) 6%, var(--light)); }
.full-bleed { position: relative; min-height: 430px; display: grid; place-items: center; overflow: hidden; color: #ffffff; text-align: center; }
.full-bleed img { position: absolute; inset: 0; height: 100%; filter: brightness(.42); border: 0; border-radius: 0; }
.full-bleed div { position: relative; max-width: 760px; padding: 40px; }
.testimonials { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; background: var(--dark); color: #ffffff; }
blockquote { margin: 0; padding: 28px; border-left: 5px solid var(--primary); background: rgba(255,255,255,.08); }
cite { display: block; margin-top: 18px; color: color-mix(in srgb, var(--primary) 70%, white); }
.cta-panel { margin: clamp(42px, 7vw, 96px) clamp(18px, 5vw, 72px); padding: clamp(32px, 6vw, 72px); background: var(--dark); color: #ffffff; text-align: center; border-radius: 28px; }
.filters { display: flex; flex-wrap: wrap; gap: 12px; padding-bottom: 16px; }
.filter-btn { background-color: #ffffff; color: var(--dark); border-color: var(--line); }
.filter-btn:hover, .filter-btn.active { background-color: var(--primary); color: #0b0b0b; border-color: var(--primary); }
.catalog-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; padding-top: 18px; }
.catalog-card { display: grid; grid-template-columns: .9fr 1.1fr; gap: 20px; }
.catalog-card img { height: 100%; min-height: 270px; }
.service-row { display: grid; grid-template-columns: .7fr 1.3fr auto; gap: 20px; align-items: center; margin-bottom: 18px; }
.service-row span { color: var(--primary); font-weight: 900; }
.check-list li, .catalog-card li { margin: 8px 0; }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-form label { display: grid; gap: 7px; font-weight: 800; }
.contact-form textarea, .contact-form label:has(textarea), .contact-form label.date-field, .contact-form button { grid-column: 1 / -1; }
.date-picker { display: grid; grid-template-columns: 1fr 1.6fr 1fr; gap: 12px; }
.date-picker select { width: 100%; }
input, select, textarea { width: 100%; padding: 12px 14px; border: 2px solid var(--line); font: inherit; background: #ffffff; color: var(--text); }
input:focus, select:focus, textarea:focus { outline: 3px solid color-mix(in srgb, var(--primary) 35%, transparent); border-color: var(--primary); }
.field-error { color: #b91c1c; font-size: .86rem; font-weight: 800; margin-top: -2px; }
.success-message { display: none; background: color-mix(in srgb, var(--secondary) 14%, #ffffff); }
.success-message.visible { display: block; animation: fadeIn .45s ease both; }
.cookie-banner { position: fixed; left: 18px; right: 18px; bottom: 18px; z-index: 30; display: none; align-items: center; gap: 18px; justify-content: space-between; padding: 18px; background: #ffffff; color: var(--text); border: 1px solid var(--line); box-shadow: var(--shadow); border-radius: 28px; }
.cookie-banner.visible { display: flex; }
.cookie-banner p { margin: 0; }
.site-footer { display: grid; grid-template-columns: 1fr 1.2fr .7fr; gap: 24px; padding: 40px clamp(18px, 5vw, 72px); background: var(--dark); color: #ffffff; }
.site-footer a { color: #ffffff; }
.footer-links { display: grid; gap: 10px; }
.slide-up, .fade-in { opacity: 1; transform: none; transition: opacity .4s ease, transform .4s ease; }
html.js .slide-up, html.js .fade-in { opacity: 0; transform: translateY(28px); }
html.js .slide-up.visible, html.js .fade-in.visible { opacity: 1; transform: translateY(0); }
@keyframes fadeIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@media (max-width: 960px) {
  .hero, .page-hero, .split, .contact-layout, .catalog-card, .service-row { grid-template-columns: 1fr; }
  .cards, .feature-grid, .services-list, .process-grid, .stats, .catalog-grid, .testimonials, .site-footer { grid-template-columns: 1fr; }
  .site-header { align-items: flex-start; flex-direction: column; }
  .contact-form { grid-template-columns: 1fr; }
}
