:root{
  --orange:#F08A1F;
  --orange-dark:#d97509;
  --black:#0c0c0c;
  --dark:#1a1a1a;
  --gray:#2a2a2a;
  --light:#f6f6f6;
  --muted:#a8a8a8;
  --white:#ffffff;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Segoe UI',Tahoma,Arial,sans-serif;color:#222;background:var(--white);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--orange);text-decoration:none;transition:color .2s}
a:hover{color:var(--orange-dark)}
.container{max-width:1140px;margin:0 auto;padding:0 24px}

/* Header */
.header{background:var(--black);position:sticky;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.25)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 24px}
.brand{display:flex;align-items:center;gap:12px;color:var(--white)}
.brand:hover{color:var(--white)}
.logo{height:54px;width:54px;object-fit:contain;border-radius:8px;background:var(--white);padding:4px}
.brand-text{font-weight:800;letter-spacing:2px;color:var(--white);font-size:1.15rem}
.menu{list-style:none;display:flex;gap:24px}
.menu a{color:var(--white);font-weight:500;font-size:.95rem;letter-spacing:.5px}
.menu a:hover{color:var(--orange)}
.btn{display:inline-block;padding:11px 22px;border-radius:50px;font-weight:700;letter-spacing:.5px;transition:transform .15s,box-shadow .2s,background .2s;border:none;cursor:pointer;font-size:.95rem}
.btn-call{background:var(--orange);color:var(--black);padding:9px 18px;font-size:.9rem}
.btn-call:hover{background:var(--white);color:var(--black);transform:translateY(-1px)}
.btn-primary{background:var(--orange);color:var(--black)}
.btn-primary:hover{background:var(--orange-dark);color:var(--white);box-shadow:0 6px 20px rgba(240,138,31,.4);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--white);border:2px solid var(--white)}
.btn-ghost:hover{background:var(--white);color:var(--black)}

/* Hero */
.hero{position:relative;background:linear-gradient(135deg,#0c0c0c 0%,#1f1f1f 100%);color:var(--white);padding:90px 0 110px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 30%,rgba(240,138,31,.18),transparent 55%);pointer-events:none}
.hero-inner{position:relative;text-align:center;max-width:780px}
.hero h1{font-size:clamp(2rem,5vw,3.4rem);font-weight:800;line-height:1.15;margin-bottom:14px}
.accent{color:var(--orange)}
.tagline{font-size:1.15rem;color:var(--orange);font-weight:600;letter-spacing:3px;text-transform:uppercase;margin-bottom:20px}
.hero-sub{font-size:1.08rem;color:#d4d4d4;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.hero-rating{font-size:1rem;color:#ffd27a;letter-spacing:1px}
.hero-rating strong{color:var(--white);margin:0 4px}

/* Sections */
.section{padding:80px 0}
.section-dark{background:var(--dark);color:var(--white)}
.section h2{font-size:clamp(1.7rem,3.5vw,2.4rem);font-weight:800;margin-bottom:14px;text-align:center;color:inherit}
.section-dark h2{color:var(--white)}
.section h2::after{content:"";display:block;width:60px;height:4px;background:var(--orange);margin:14px auto 0;border-radius:2px}
.section-lead{text-align:center;color:#666;max-width:680px;margin:0 auto 48px;font-size:1.05rem}
.section-dark .section-lead{color:#bdbdbd}
.section-lead.center{margin-top:32px;margin-bottom:0}

/* Grid */
.grid{display:grid;gap:24px}
.services{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}

/* Cards */
.card{background:var(--white);border:1px solid #ececec;border-radius:14px;padding:28px 24px;transition:transform .25s,box-shadow .25s,border-color .25s}
.card:hover{transform:translateY(-6px);box-shadow:0 14px 30px rgba(0,0,0,.1);border-color:var(--orange)}
.card h3{color:var(--black);font-size:1.2rem;margin-bottom:10px;position:relative;padding-bottom:8px}
.card h3::after{content:"";position:absolute;bottom:0;left:0;width:32px;height:3px;background:var(--orange);border-radius:2px}
.card p{color:#555;font-size:.97rem}

/* Hours */
.hours{max-width:560px;margin:0 auto;background:var(--gray);border-radius:14px;padding:14px 28px;border:1px solid #333}
.hours-row{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid #2f2f2f;font-size:1rem}
.hours-row:last-child{border-bottom:none}
.hours-row span:first-child{font-weight:600;color:var(--orange);text-transform:uppercase;letter-spacing:1px;font-size:.92rem}
.hours-row span:last-child{color:#e8e8e8}
.hours-row.closed span:last-child{color:#888;font-style:italic}
.note{text-align:center;margin-top:24px;color:#bdbdbd;font-size:.95rem}

/* Reviews */
.reviews{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.review{background:#fafafa;border-left:4px solid var(--orange);padding:22px 24px;border-radius:0 12px 12px 0;font-style:normal}
.review p{color:#333;margin-bottom:12px;font-size:1rem;line-height:1.55}
.review cite{color:#777;font-size:.88rem;font-style:normal;font-weight:600}

/* Contact */
.contact-grid{grid-template-columns:1fr 1fr;align-items:start}
.contact-line{margin-bottom:18px;color:#d6d6d6;font-size:1rem;line-height:1.5}
.contact-line strong{color:var(--orange);display:inline-block;margin-bottom:4px;letter-spacing:.5px;font-size:.88rem;text-transform:uppercase}
.contact-line a{color:var(--white);font-weight:600}
.contact-line a:hover{color:var(--orange)}
#contact h2{text-align:left}
#contact h2::after{margin-left:0;margin-right:auto}
#contact .btn-primary{margin-top:14px}
.map-wrap{box-shadow:0 10px 30px rgba(0,0,0,.4);border-radius:12px;overflow:hidden}

/* Footer */
.footer{background:#000;color:#ccc;padding:32px 0;text-align:center}
.footer p{margin-bottom:6px;font-size:.94rem}
.footer .small{color:var(--orange);font-size:.85rem;letter-spacing:1.5px;text-transform:uppercase}

/* Responsive */
@media (max-width:780px){
  .menu{display:flex;flex-wrap:wrap;justify-content:center;gap:.25rem .75rem}
  .nav{padding:10px 16px}
  .brand-text{font-size:1rem;letter-spacing:1px}
  .logo{height:46px;width:46px}
  .btn-call{padding:8px 14px;font-size:.85rem}
  .section{padding:60px 0}
  .hero{padding:60px 0 70px}
  .contact-grid{grid-template-columns:1fr}
  #contact h2{text-align:center}
  #contact h2::after{margin-left:auto;margin-right:auto}
}


/* Cards services cliquables */
.card-link{display:block;text-decoration:none;color:inherit;height:100%;}
.card-link .card{height:100%;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;cursor:pointer;}
.card-link:hover .card{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,0.12);}
.card-link:focus{outline:none;}
.card-link:focus-visible .card{outline:2px solid var(--accent,#e30613);outline-offset:3px;}
.card-cta{display:inline-block;margin-top:12px;font-weight:600;color:var(--accent,#e30613);}
.card-link:hover .card-cta{text-decoration:underline;}

/* Pages services - SEO */
.service-page{padding:80px 0 60px;}
.service-page h1{font-size:2.2rem;margin-bottom:.6rem;}
.service-page .lead{font-size:1.15rem;color:#444;margin-bottom:2rem;}
.service-page h2{margin-top:2rem;font-size:1.5rem;}
.service-page ul{padding-left:1.2rem;line-height:1.8;}
.service-page .price-box{background:#f7f7f7;border-left:4px solid var(--accent,#e30613);padding:18px 22px;margin:1.6rem 0;border-radius:6px;}
.service-page .price-box strong{font-size:1.2rem;}
.service-page .back-link{display:inline-block;margin-top:2rem;color:var(--accent,#e30613);font-weight:600;text-decoration:none;}
.service-page .back-link:hover{text-decoration:underline;}
.faq-item{margin:1rem 0;padding:1rem 0;border-bottom:1px solid #eee;}
.faq-item h3{font-size:1.1rem;margin:0 0 .4rem;}

/* === Dropdown navigation === */
.menu .has-dropdown { position: relative; }
.menu .dropdown-toggle { cursor: pointer; }
.menu .dropdown { position: absolute; top: 100%; left: 0; min-width: 220px; background: #1a1a1a; border: 1px solid #2a2a2a; border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,0.4); padding: 8px 0; margin: 0; list-style: none; opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity .18s ease, transform .18s ease, visibility .18s; z-index: 1000; }
.menu .dropdown li { display: block; }
.menu .dropdown li a { display: block; padding: 10px 16px; color: #f5f5f5; text-decoration: none; font-size: .95rem; white-space: nowrap; }
.menu .dropdown li a:hover { background: #ff7a18; color: #fff; }
.menu .has-dropdown:hover > .dropdown,
.menu .has-dropdown:focus-within > .dropdown,
.menu .has-dropdown.open > .dropdown { opacity: 1; visibility: visible; transform: translateY(0); }

/* === Mobile === */
@media (max-width: 768px) {
  .nav { flex-wrap: wrap; gap: .5rem; }
  .menu { flex-wrap: wrap; gap: .25rem .75rem; justify-content: center; }
  .menu li a { padding: .35rem .5rem; font-size: .92rem; }
  .menu .has-dropdown { position: static; }
  .menu .dropdown { position: static; opacity: 1; visibility: visible; transform: none; display: none; box-shadow: none; border: none; background: transparent; padding: 4px 0 8px; min-width: 0; width: 100%; }
  .menu .has-dropdown.open > .dropdown { display: block; }
  .menu .dropdown li a { padding: 8px 12px; text-align: center; color: #ffb27a; }
  .service-page { padding: 1rem; }
  .service-page h1 { font-size: 1.55rem; line-height: 1.25; }
  .service-page h2 { font-size: 1.2rem; }
  .service-page h3 { font-size: 1.05rem; }
  .price-box { padding: .9rem 1rem; font-size: 1rem; }
  .price-box .price { font-size: 1.4rem; }
  .faq-item { padding: .8rem; }
  .services-grid { grid-template-columns: 1fr; gap: 1rem; }
  .card { padding: 1rem; }
  .header .brand img { max-height: 42px; }
  .btn-call { padding: .5rem .8rem; font-size: .9rem; }
}
@media (max-width: 480px) {
  .menu li a { font-size: .85rem; padding: .3rem .35rem; }
  .service-page h1 { font-size: 1.35rem; }
  .price-box .price { font-size: 1.2rem; }
  body { font-size: 15px; }
}
