:root{
  --bg:#f5f7fa;
  --text:#222;
  --dark:#171a20;
  --dark-2:#232831;
  --accent:#ff6a00;
  --accent-2:#ff7f26;
  --danger:#d93b3b;
  --danger-2:#b91c1c;
  --white:#fff;
  --shadow:0 15px 40px rgba(0,0,0,.1);
  --container:1320px;

  --cp-bg:#f5f7fa;
  --cp-card:#ffffff;
  --cp-text:#17202a;
  --cp-muted:#5f6b76;
  --cp-border:rgba(17,24,39,.08);
  --cp-shadow:0 14px 34px rgba(15, 23, 42, .08);
  --cp-radius:22px;
  --cp-primary:#111827;
  --cp-accent:#f4b000;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}

html{
  scroll-behavior:smooth;
}

html.lock-scroll,
body.lock-scroll{
  overflow:hidden;
  height:100%;
}

body{
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}

/* NAV */
nav{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  z-index:1000;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.9)),
    radial-gradient(circle at 15% -80%, rgba(255,106,0,.18), transparent 34%),
    radial-gradient(circle at 85% -120%, rgba(255,127,38,.16), transparent 36%);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(23,26,32,.08);
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  overflow:hidden;
}

nav::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.28), transparent 18%, transparent 82%, rgba(255,255,255,.2)),
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.35), transparent 55%);
  pointer-events:none;
}

nav::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-1px;
  width:100%;
  height:54px;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0) 0%, rgba(255,255,255,0) 42%, rgba(245,247,250,.84) 43%, rgba(245,247,250,1) 100%);
  clip-path:polygon(0 58%, 12% 68%, 24% 60%, 38% 74%, 52% 62%, 66% 76%, 80% 62%, 91% 70%, 100% 60%, 100% 100%, 0 100%);
}

.nav-inner{
  position:relative;
  z-index:2;
  max-width:var(--container);
  margin:0 auto;
  min-height:88px;
  padding:12px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:26px;
}

.nav-left{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
  text-decoration:none;
  flex-shrink:0;
}

.nav-logo-wrap{
  height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  padding-right:6px;
}

.nav-logo{
  height:52px;
  width:auto;
  display:block;
  object-fit:contain;
}

.nav-title{
  display:flex;
  flex-direction:column;
  min-width:0;
}

.nav-title strong{
  font-size:1.02rem;
  line-height:1.1;
  color:#111;
  letter-spacing:.01em;
}

.nav-title span{
  font-size:.84rem;
  color:#626a77;
  margin-top:4px;
  white-space:nowrap;
}

.nav-links{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:8px;
  flex-wrap:wrap;
  max-width:760px;
}

nav a{
  text-decoration:none;
  font-weight:700;
}

.nav-link{
  color:#222b35;
  padding:10px 13px;
  border-radius:12px;
  transition:.25s ease;
  font-size:.95rem;
  line-height:1;
  white-space:nowrap;
}

.nav-link:hover{
  background:rgba(23,26,32,.06);
  color:#111;
}

.cta{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;
  padding:12px 20px;
  border-radius:14px;
  box-shadow:0 10px 24px rgba(255,106,0,.26);
  transition:.25s ease;
  white-space:nowrap;
}

.cta:hover{
  transform:translateY(-2px);
  box-shadow:0 15px 30px rgba(255,106,0,.34);
}

/* HERO */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  color:#fff;
  padding:210px 10% 180px;
  overflow:hidden;
  background:#000;
}

.hero-media{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  z-index:0;
  overflow:hidden;
}

.hero-fallback,
.hero-video{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

.hero-fallback{
  opacity:1;
  transition:opacity .35s ease;
}

.hero-video{
  opacity:0;
  transition:opacity .2s linear;
  pointer-events:none;
}

.hero.video-ready .hero-fallback{
  opacity:0;
}

.hero-video-active{
  opacity:1;
  z-index:1;
}

.hero-video-next,
.hero-video-preload{
  opacity:0;
  z-index:0;
}

.hero::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(rgba(0,0,0,.56),rgba(0,0,0,.48)),
    radial-gradient(circle at 50% 22%,rgba(255,255,255,.10),transparent 34%),
    radial-gradient(circle at 80% 18%,rgba(255,106,0,.16),transparent 28%),
    linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.2));
  pointer-events:none;
}

.hero-overlay{
  display:none;
}

.hero-content{
  position:relative;
  z-index:2;
  max-width:950px;
}

.hero-logo-wrap{
  width:min(300px,70vw);
  margin:0 auto 28px;
  padding:18px 22px;
  border-radius:28px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 22px 55px rgba(0,0,0,.18);
}

.hero-logo{
  width:100%;
  height:auto;
  display:block;
  object-fit:contain;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 16px;
  margin-bottom:24px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  font-size:.95rem;
  font-weight:600;
  letter-spacing:.02em;
}

.hero-badge::before{
  content:"";
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 6px rgba(255,106,0,.16);
}

.hero h1{
  font-size:clamp(2.5rem,5vw,4.5rem);
  line-height:1.05;
  margin-bottom:20px;
  text-shadow:0 10px 30px rgba(0,0,0,.24);
}

.hero p{
  font-size:clamp(1rem,1.8vw,1.3rem);
  opacity:.95;
  margin-bottom:34px;
  text-shadow:0 6px 18px rgba(0,0,0,.25);
}

.hero button{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  border:none;
  padding:17px 34px;
  border-radius:999px;
  font-size:1.05rem;
  font-weight:700;
  color:#fff;
  cursor:pointer;
  transition:.3s ease;
  box-shadow:0 14px 34px rgba(255,106,0,.35);
}

.hero button:hover{
  transform:translateY(-2px) scale(1.02);
}

/* SLICED TRANSITION */
.hero-slice{
  position:absolute;
  left:0;
  bottom:-1px;
  width:100%;
  height:150px;
  z-index:2;
  pointer-events:none;
}

.hero-slice svg{
  display:block;
  width:100%;
  height:100%;
}

/* SECTIONS */
section{
  padding:110px 10%;
}

h2{
  text-align:center;
  margin-bottom:40px;
  font-size:2.4rem;
  line-height:1.1;
}

/* ABOUT */
.about-section{
  position:relative;
  margin-top:-36px;
  padding-top:70px;
}

.about{
  display:flex;
  gap:50px;
  align-items:center;
  background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(255,255,255,.72));
  border-radius:32px;
  padding:34px;
  box-shadow:0 18px 45px rgba(0,0,0,.08);
  backdrop-filter:blur(10px);
}

.about img{
  width:50%;
  border-radius:24px;
  box-shadow:0 20px 40px rgba(0,0,0,.16);
}

.about-text{
  flex:1;
}

.about-text h2{
  text-align:left;
  margin-bottom:18px;
  font-size:2.3rem;
}

.about-text p{
  font-size:1.08rem;
  line-height:1.8;
  color:#4a5059;
  max-width:640px;
}

/* SERVICES */
.services-section{
  padding-top:90px;
}

.cards{
  display:flex;
  gap:25px;
  flex-wrap:wrap;
}

.card{
  flex:1;
  min-width:260px;
  background:rgba(255,255,255,.84);
  backdrop-filter:blur(10px);
  border-radius:24px;
  padding:32px 28px;
  text-align:center;
  box-shadow:var(--shadow);
  transition:.35s ease;
  border:1px solid rgba(255,255,255,.65);
}

.card:hover{
  transform:translateY(-10px);
  box-shadow:0 20px 45px rgba(0,0,0,.12);
}

.card img{
  width:180px;
  height:auto;
  margin-bottom:20px;
}

.card h3{
  font-size:1.45rem;
  margin-bottom:10px;
  color:#1e232c;
}

.card p{
  color:#606775;
  line-height:1.6;
}

/* MATERIALS + FAQ */
.faq-section,
.material-section{
  max-width:1100px;
  margin:56px auto 0;
  padding:0 20px;
}

.faq-section h3,
.material-section h3{
  margin-bottom:18px;
  font-size:1.8rem;
}

.material-topbar{
  position:relative;
  display:flex;
  align-items:flex-start;
  gap:18px;
  padding:22px 24px;
  margin-bottom:24px;
  border-radius:24px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.08), transparent 28%),
    linear-gradient(135deg, #111 0%, #232323 55%, #303030 100%);
  color:#fff;
  box-shadow:0 18px 40px rgba(0,0,0,.18);
  overflow:hidden;
}

.material-topbar::after{
  content:"";
  position:absolute;
  inset:auto -60px -60px auto;
  width:180px;
  height:180px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.08), transparent 65%);
  pointer-events:none;
}

.material-topbar-icon{
  flex:0 0 58px;
  width:58px;
  height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter:blur(8px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}

.material-topbar-icon svg{
  width:30px;
  height:30px;
  stroke:#fff;
  fill:none;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.material-topbar h3{
  margin:0 0 8px;
}

.material-intro{
  color:rgba(255,255,255,.9);
  line-height:1.78;
  margin:0;
  max-width:920px;
}

.material-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:18px;
}

.material-card{
  --accent:#4b5563;
  --accent-soft:rgba(75,85,99,.12);
  position:relative;
  background:linear-gradient(180deg, #ffffff 0%, #fbfcfd 100%);
  border:1px solid rgba(0,0,0,.08);
  border-radius:24px;
  padding:24px 22px 22px;
  box-shadow:0 14px 36px rgba(0,0,0,.06);
  transition:transform .28s ease, box-shadow .28s ease, border-color .28s ease;
  overflow:hidden;
}

.material-card::before{
  content:"";
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:4px;
  background:linear-gradient(90deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 55%, white) 100%);
  opacity:.95;
}

.material-card::after{
  content:"";
  position:absolute;
  top:-36px;
  right:-36px;
  width:120px;
  height:120px;
  border-radius:50%;
  background:radial-gradient(circle, var(--accent-soft) 0%, transparent 68%);
  pointer-events:none;
}

.material-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 44px rgba(0,0,0,.10);
  border-color:rgba(0,0,0,.12);
}

.material-card-beton{
  --accent:#6b7280;
  --accent-soft:rgba(107,114,128,.15);
}

.material-card-ziegel{
  --accent:#b45309;
  --accent-soft:rgba(180,83,9,.14);
}

.material-card-fliesen{
  --accent:#0f766e;
  --accent-soft:rgba(15,118,110,.14);
}

.material-card-erde{
  --accent:#8b5e34;
  --accent-soft:rgba(139,94,52,.14);
}

.material-card-mischabfall{
  --accent:#6d28d9;
  --accent-soft:rgba(109,40,217,.12);
}

.material-card-sperrig{
  --accent:#1d4ed8;
  --accent-soft:rgba(29,78,216,.12);
}

.material-icon{
  width:70px;
  height:70px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:22px;
  margin-bottom:16px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.02)),
    linear-gradient(135deg, var(--accent) 0%, color-mix(in srgb, var(--accent) 70%, black) 100%);
  box-shadow:
    0 14px 28px rgba(0,0,0,.14),
    inset 0 1px 0 rgba(255,255,255,.14);
  transition:transform .28s ease, box-shadow .28s ease;
  border:1px solid rgba(255,255,255,.08);
}

.material-card:hover .material-icon{
  transform:scale(1.06) translateY(-1px);
  box-shadow:
    0 18px 32px rgba(0,0,0,.18),
    inset 0 1px 0 rgba(255,255,255,.16);
}

.material-icon svg{
  width:38px;
  height:38px;
  stroke:#fff;
  fill:none;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.material-icon .fill-soft{
  fill:rgba(255,255,255,.15);
  stroke:rgba(255,255,255,.92);
}

.material-icon .fill-strong{
  fill:rgba(255,255,255,.22);
  stroke:rgba(255,255,255,.98);
}

.material-card h4{
  margin:0 0 10px;
  font-size:1.1rem;
  color:#111;
}

.material-card p{
  margin:0;
  color:#444;
  line-height:1.72;
}

.faq-list{
  display:grid;
  gap:14px;
}

.faq-item{
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.05);
}

.faq-question{
  width:100%;
  border:0;
  background:transparent;
  padding:20px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  text-align:left;
  cursor:pointer;
  font:inherit;
  font-weight:700;
  color:#111;
}

.faq-question span:last-child{
  font-size:1.6rem;
  line-height:1;
  transition:transform .25s ease;
}

.faq-item.active .faq-question span:last-child{
  transform:rotate(45deg);
}

.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .3s ease;
}

.faq-answer p{
  margin:0;
  padding:0 22px 20px;
  color:#444;
  line-height:1.7;
}

/* NEW SECTIONS */
.section-inner{
  width:min(1180px, calc(100% - 32px));
  margin:0 auto;
}

.service-area,
.pricing-info,
.opening-hours{
  padding:72px 0;
}

.service-area h2,
.pricing-info h2,
.opening-hours h2{
  margin:0 0 14px;
  font-size:clamp(1.9rem, 3vw, 2.6rem);
  line-height:1.15;
  color:var(--cp-primary);
}

.service-area > .section-inner > p,
.pricing-info > .section-inner > p,
.opening-hours > .section-inner > p{
  margin:0 0 34px;
  max-width:860px;
  font-size:1.05rem;
  line-height:1.75;
  color:var(--cp-muted);
}

.service-area-grid,
.pricing-grid,
.hours-grid{
  display:grid;
  gap:22px;
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.service-area-card,
.pricing-card,
.hours-card{
  background:var(--cp-card);
  border:1px solid var(--cp-border);
  border-radius:var(--cp-radius);
  box-shadow:var(--cp-shadow);
  padding:28px;
}

.service-area-card h3,
.pricing-card h3,
.hours-card h3{
  margin:0 0 12px;
  font-size:1.18rem;
  color:var(--cp-primary);
}

.service-area-card p,
.pricing-card p,
.hours-card p{
  margin:0;
  color:var(--cp-muted);
  line-height:1.75;
}

.service-area-list{
  margin:0;
  padding-left:20px;
  color:var(--cp-muted);
  line-height:1.9;
}

.area-pills{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.area-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(17,24,39,.06);
  color:var(--cp-primary);
  font-weight:700;
  font-size:.94rem;
}

.service-map{
  margin-top:18px;
  border-radius:18px;
  overflow:hidden;
  min-height:260px;
  background:
    radial-gradient(circle at 20% 30%, rgba(244,176,0,.22), transparent 20%),
    radial-gradient(circle at 78% 60%, rgba(17,24,39,.12), transparent 24%),
    linear-gradient(135deg, #f9fbfd 0%, #eef2f7 100%);
  border:1px solid rgba(17,24,39,.06);
  position:relative;
}

.service-map::before,
.service-map::after{
  content:"";
  position:absolute;
  inset:0;
}

.service-map::before{
  background-image:
    linear-gradient(rgba(17,24,39,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(17,24,39,.05) 1px, transparent 1px);
  background-size:42px 42px;
}

.service-map::after{
  background:
    radial-gradient(circle at 42% 50%, rgba(244,176,0,.95) 0 8px, transparent 9px),
    radial-gradient(circle at 58% 42%, rgba(17,24,39,.88) 0 7px, transparent 8px),
    radial-gradient(circle at 66% 54%, rgba(17,24,39,.88) 0 7px, transparent 8px),
    radial-gradient(circle at 52% 62%, rgba(17,24,39,.88) 0 7px, transparent 8px),
    radial-gradient(circle at 33% 56%, rgba(17,24,39,.88) 0 7px, transparent 8px);
  opacity:.92;
}

.service-map-label{
  position:absolute;
  right:18px;
  bottom:18px;
  z-index:2;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(17,24,39,.06);
  box-shadow:0 10px 25px rgba(15,23,42,.08);
  color:var(--cp-primary);
  border-radius:14px;
  padding:10px 14px;
  font-size:.92rem;
  font-weight:700;
}

.pricing-note{
  margin-top:24px;
  padding:20px 22px;
  border-radius:18px;
  background:rgba(244,176,0,.12);
  border:1px solid rgba(244,176,0,.24);
  color:#4a3a00;
  line-height:1.75;
}

.hours-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.hours-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(17,24,39,.06);
  color:var(--cp-primary);
  font-weight:700;
  font-size:.94rem;
}

/* CONTACT SECTION */
.contact{
  background:linear-gradient(135deg,#1c1f26,#2a2f38);
  color:#fff;
  border-radius:32px;
  box-shadow:0 24px 60px rgba(0,0,0,.18);
}

.contact-grid{
  display:flex;
  gap:30px;
  flex-wrap:wrap;
  justify-content:center;
}

.contact-card{
  flex:1;
  min-width:250px;
  background:rgba(255,255,255,0.05);
  border-radius:20px;
  padding:30px;
  text-align:center;
  transition:.3s ease;
  border:1px solid rgba(255,255,255,.06);
}

.contact-card:hover{
  transform:translateY(-8px);
  background:rgba(255,255,255,0.1);
}

.contact-icon-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  color:inherit;
  transition:transform .2s ease, opacity .2s ease;
}

.contact-icon-link:hover{
  transform:translateY(-2px);
  opacity:.9;
}

.contact-icon{
  width:72px;
  height:72px;
  margin:0 auto 18px;
  display:grid;
  place-items:center;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,106,0,.22),rgba(255,106,0,.08));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.12),
    0 10px 24px rgba(0,0,0,.18);
}

.contact-card svg{
  width:34px;
  height:34px;
  stroke:#ff6a00;
  stroke-width:1.9;
  stroke-linecap:round;
  stroke-linejoin:round;
  fill:none;
}

.contact-card h3{
  margin-bottom:10px;
  font-size:1.2rem;
}

.contact-card p{
  opacity:.92;
}

.contact-card p a{
  color:inherit;
  text-decoration:none;
}

.contact-card p a:hover{
  text-decoration:underline;
}

/* FOOTER */
.footer{
  padding:32px 10% 46px;
}

.footer-inner{
  max-width:var(--container);
  margin:0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
  padding:22px 26px;
  background:#fff;
  border-radius:24px;
  box-shadow:0 14px 35px rgba(0,0,0,.08);
}

.footer-copy{
  color:#4c5360;
  font-size:.96rem;
}

.footer-links{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.footer-links a{
  text-decoration:none;
  color:#1d232c;
  font-weight:700;
  padding:10px 14px;
  border-radius:12px;
  transition:.25s ease;
  background:#f4f6f9;
}

.footer-links a:hover{
  background:#eceff4;
  transform:translateY(-1px);
}

/* MODAL */
.modal{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(10,12,16,.58);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  opacity:0;
  visibility:hidden;
  transition:.28s ease;
  z-index:2000;
}

.modal.active{
  opacity:1;
  visibility:visible;
}

.modal-dialog{
  position:relative;
  width:min(760px,100%);
  max-height:min(88vh,900px);
  overflow:auto;
  background:#fff;
  border-radius:28px;
  box-shadow:0 30px 70px rgba(0,0,0,.24);
  padding:32px 28px 28px;
  transform:translateY(16px) scale(.98);
  transition:.28s ease;
}

.modal.active .modal-dialog{
  transform:translateY(0) scale(1);
}

.modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:46px;
  height:46px;
  border:none;
  border-radius:14px;
  background:#f3f5f8;
  color:#111;
  font-size:1.45rem;
  cursor:pointer;
  display:grid;
  place-items:center;
  transition:.25s ease;
}

.modal-close:hover{
  background:#e9edf3;
  transform:scale(1.04);
}

.modal h3{
  font-size:1.9rem;
  margin-bottom:18px;
  padding-right:56px;
  color:#151920;
}

.modal p{
  font-size:1rem;
  line-height:1.75;
  color:#4a5059;
  margin-bottom:16px;
}

.modal strong{
  color:#171a20;
}

.modal h1,
.modal h4{
  color:#171a20;
  margin:22px 0 12px;
  font-size:1.2rem;
  line-height:1.4;
}

.modal-loading,
.modal-error{
  font-size:1rem;
  line-height:1.75;
  color:#4a5059;
}

.a-info{
  color:var(--accent);
  text-decoration:none;
  font-weight:700;
  word-break:break-word;
}

.a-info:hover{
  text-decoration:underline;
}

/* COOKIE CONSENT */
.cookie-consent{
  position:fixed;
  inset:0;
  z-index:3000;
  display:none;
  align-items:flex-end;
  justify-content:center;
  padding:24px;
  background:rgba(8,10,14,.42);
  backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);
}

.cookie-consent.show{
  display:flex;
}

.cookie-card{
  width:min(980px,100%);
  background:rgba(23,26,32,.98);
  color:#fff;
  border:1px solid rgba(255,255,255,.10);
  border-radius:26px;
  box-shadow:0 30px 70px rgba(0,0,0,.28);
  padding:24px;
  display:flex;
  gap:24px;
  align-items:flex-start;
  justify-content:space-between;
}

.cookie-content{
  flex:1;
}

.cookie-title{
  font-size:1.18rem;
  font-weight:800;
  margin-bottom:10px;
}

.cookie-text{
  color:rgba(255,255,255,.84);
  line-height:1.7;
  font-size:.98rem;
  margin-bottom:16px;
}

.cookie-options{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:10px;
}

.cookie-option{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  min-width:220px;
}

.cookie-option input{
  margin-top:3px;
  accent-color:var(--accent);
  width:16px;
  height:16px;
  flex-shrink:0;
}

.cookie-option strong{
  display:block;
  font-size:.95rem;
  margin-bottom:3px;
}

.cookie-option span{
  display:block;
  font-size:.85rem;
  line-height:1.45;
  color:rgba(255,255,255,.72);
}

.cookie-actions{
  display:flex;
  flex-direction:column;
  gap:10px;
  min-width:220px;
}

.cookie-btn{
  border:none;
  border-radius:14px;
  padding:14px 18px;
  font-weight:800;
  cursor:pointer;
  transition:.25s ease;
  font-size:.96rem;
}

.cookie-btn-accept{
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;
  box-shadow:0 14px 30px rgba(255,106,0,.26);
}

.cookie-btn-accept:hover{
  transform:translateY(-2px);
}

.cookie-btn-save{
  background:#fff;
  color:#171a20;
}

.cookie-btn-decline{
  background:linear-gradient(135deg,var(--danger),var(--danger-2));
  color:#fff;
  box-shadow:0 14px 30px rgba(185,28,28,.22);
}

.cookie-btn-decline:hover{
  transform:translateY(-2px);
}

.cookie-btn:hover{
  opacity:.97;
}

.cookie-note{
  font-size:.8rem;
  color:rgba(255,255,255,.62);
  margin-top:4px;
}

/* MOBILE STICKY CTA */
.mobile-sticky-cta{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  display:none;
  grid-template-columns:1fr 1fr 1fr;
  gap:8px;
  padding:10px;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(10px);
  box-shadow:0 -8px 24px rgba(0,0,0,.12);
  z-index:9999;
}

.mobile-sticky-cta a{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  text-decoration:none;
  padding:13px 10px;
  border-radius:14px;
  font-weight:800;
  font-size:14px;
  transition:transform .18s ease, opacity .18s ease;
}

.mobile-sticky-cta a:hover{
  transform:translateY(-1px);
  opacity:.96;
}

.mobile-cta-call{
  background:#111827;
  color:#fff;
}

.mobile-cta-whatsapp{
  background:#1f9d55;
  color:#fff;
}

.mobile-cta-request{
  background:#f4b000;
  color:#111827;
}

.visually-hidden{
  position:absolute !important;
  height:1px;
  width:1px;
  overflow:hidden;
  clip:rect(1px, 1px, 1px, 1px);
  white-space:nowrap;
}

/* ANIMATION */
.fade{
  opacity:0;
  transform:translateY(40px);
  transition:1s ease;
}

.visible{
  opacity:1;
  transform:translateY(0);
}

/* RESPONSIVE */
@media(max-width:1200px){
  .nav-links{
    max-width:640px;
    gap:6px;
  }

  .nav-link{
    padding:9px 11px;
    font-size:.9rem;
  }

  .cta{
    padding:11px 16px;
  }
}

@media(max-width:1100px){
  .nav-title span{
    display:none;
  }

  .about{
    flex-direction:column;
    padding:24px;
  }

  .about img{
    width:100%;
  }

  .about-text h2{
    text-align:center;
    font-size:2rem;
  }

  .about-text p{
    text-align:center;
  }
}

@media(max-width:980px){
  .material-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media(max-width:900px){
  .nav-inner{
    height:auto;
    padding:14px 18px;
    flex-wrap:wrap;
  }

  .nav-left{
    width:100%;
    justify-content:center;
  }

  .nav-title{
    text-align:center;
  }

  .nav-links{
    width:100%;
    justify-content:center;
    max-width:none;
  }

  .nav-link{
    padding:10px 12px;
    font-size:.95rem;
  }

  .hero{
    padding:180px 7% 150px;
  }

  .hero h1{
    font-size:2.4rem;
  }

  .hero-slice{
    height:110px;
  }

  .card img{
    width:140px;
  }

  .footer{
    padding:26px 6% 40px;
  }

  .cookie-card{
    flex-direction:column;
    padding:20px;
  }

  .cookie-actions{
    width:100%;
    min-width:0;
  }

  .service-area-grid,
  .pricing-grid,
  .hours-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:768px){
  .service-area,
  .pricing-info,
  .opening-hours{
    padding:56px 0;
  }

  .service-area-card,
  .pricing-card,
  .hours-card{
    padding:22px;
  }

  .mobile-sticky-cta{
    display:grid;
  }

  body{
    padding-bottom:84px;
  }
}

@media(max-width:760px){
  .material-topbar{
    flex-direction:column;
    align-items:flex-start;
  }

  .material-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:700px){
  nav{
    background:
      linear-gradient(180deg, rgba(255,255,255,.97), rgba(255,255,255,.92)),
      radial-gradient(circle at 10% -80%, rgba(255,106,0,.18), transparent 34%),
      radial-gradient(circle at 90% -120%, rgba(255,127,38,.16), transparent 36%);
  }

  .nav-inner{
    padding:12px 14px;
    gap:14px;
  }

  .nav-left{
    width:100%;
    justify-content:center;
  }

  .nav-title{
    text-align:center;
  }

  .nav-title span{
    display:none;
  }

  .nav-links{
    width:100%;
    justify-content:center;
    gap:8px;
  }

  .nav-link{
    font-size:.9rem;
  }

  .hero{
    padding-top:240px;
  }

  .hero-logo-wrap{
    width:min(240px,72vw);
    margin-bottom:22px;
  }

  .hero-badge{
    font-size:.85rem;
  }

  section{
    padding:90px 6%;
  }

  .about-section{
    margin-top:-22px;
    padding-top:50px;
  }

  .contact{
    border-radius:24px;
  }

  .footer-inner{
    padding:20px;
    justify-content:center;
    text-align:center;
  }

  .modal{
    padding:12px;
  }

  .modal-dialog{
    padding:26px 18px 22px;
    border-radius:22px;
  }

  .modal h3{
    font-size:1.5rem;
  }

  .modal-close{
    top:10px;
    right:10px;
    width:42px;
    height:42px;
  }

  .cookie-consent{
    padding:12px;
  }

  .cookie-card{
    border-radius:22px;
    padding:18px;
  }

  .cookie-options{
    flex-direction:column;
  }

  .cookie-option{
    min-width:0;
    width:100%;
  }
}