/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--red:#c41e3a;--navy:#1a1a2e;--gold:#d4af37;--white:#ffffff;--gray:#f5f5f5;--dark-gray:#333;--font-heading:'Oswald',sans-serif;--font-body:'Montserrat',sans-serif;--font-accent:'Playfair Display',serif}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--dark-gray);line-height:1.7;background:var(--white)}
img{max-width:100%;height:auto;display:block}
a{color:var(--red);text-decoration:none;transition:color .3s}
a:hover{color:var(--gold)}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--navy);line-height:1.2;margin-bottom:.5em}
h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}
p{margin-bottom:1rem}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.accent-font{font-family:var(--font-accent);font-style:italic}

/* ===== HEADER / NAV ===== */
.site-header{background:var(--navy);position:sticky;top:0;z-index:1000;box-shadow:0 2px 10px rgba(0,0,0,.3)}
.nav-container{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;max-width:1200px;margin:0 auto}
.logo-link{display:flex;align-items:center;gap:10px}
.logo-link img{height:60px;width:auto}
.logo-text{color:var(--white);font-family:var(--font-heading);font-size:1.4rem;text-transform:uppercase;letter-spacing:1px}
.logo-text span{color:var(--red)}
.nav-links{display:flex;list-style:none;gap:25px;align-items:center}
.nav-links a{color:var(--white);font-family:var(--font-heading);font-size:.95rem;text-transform:uppercase;letter-spacing:.5px;padding:5px 0;border-bottom:2px solid transparent;transition:border-color .3s,color .3s}
.nav-links a:hover,.nav-links a.active{color:var(--gold);border-bottom-color:var(--gold)}
.nav-cta{background:var(--red);color:var(--white)!important;padding:10px 20px!important;border-radius:5px;border-bottom:none!important;font-weight:700}
.nav-cta:hover{background:var(--gold);color:var(--navy)!important}
.dropdown{position:relative}
.dropdown-menu{display:none;position:absolute;top:100%;left:0;background:var(--navy);border:1px solid rgba(255,255,255,.1);border-radius:5px;min-width:220px;padding:10px 0;box-shadow:0 10px 30px rgba(0,0,0,.3);z-index:100}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:8px 20px;font-size:.85rem;white-space:nowrap}
.hamburger{display:none;flex-direction:column;cursor:pointer;gap:5px;padding:5px}
.hamburger span{width:25px;height:3px;background:var(--white);border-radius:3px;transition:transform .3s}

/* ===== HERO ===== */
.hero{background:linear-gradient(135deg,var(--navy) 0%,#2a2a4e 100%);color:var(--white);padding:100px 20px 80px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;opacity:.15}
.hero-content{position:relative;z-index:1;max-width:800px;margin:0 auto}
.hero h1{font-size:3rem;color:var(--white);margin-bottom:.3em;text-transform:uppercase}
.hero .tagline{font-family:var(--font-accent);font-size:1.5rem;color:var(--gold);margin-bottom:1.5rem;font-style:italic}
.hero p{font-size:1.15rem;margin-bottom:2rem;opacity:.9}
.hero-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}

/* ===== BUTTONS ===== */
.btn{display:inline-block;padding:14px 30px;border-radius:5px;font-family:var(--font-heading);font-size:1rem;text-transform:uppercase;letter-spacing:1px;cursor:pointer;border:none;transition:all .3s;font-weight:700}
.btn-primary{background:var(--red);color:var(--white)}
.btn-primary:hover{background:#a01830;color:var(--white)}
.btn-secondary{background:transparent;color:var(--gold);border:2px solid var(--gold)}
.btn-secondary:hover{background:var(--gold);color:var(--navy)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:#b8962e;color:var(--navy)}

/* ===== SECTIONS ===== */
.section{padding:80px 20px}
.section-alt{background:var(--gray)}
.section-dark{background:var(--navy);color:var(--white)}
.section-dark h2,.section-dark h3{color:var(--white)}
.section-header{text-align:center;margin-bottom:50px}
.section-header h2{position:relative;display:inline-block;padding-bottom:15px}
.section-header h2::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--gold)}
.section-header p{color:#666;font-size:1.1rem;margin-top:15px;max-width:600px;margin-left:auto;margin-right:auto}

/* ===== SERVICES GRID ===== */
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:30px}
.service-card{background:var(--white);border-radius:10px;padding:35px 25px;text-align:center;box-shadow:0 5px 20px rgba(0,0,0,.08);transition:transform .3s,box-shadow .3s;border-top:4px solid var(--red)}
.service-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px rgba(0,0,0,.12)}
.service-card .icon{font-size:3rem;margin-bottom:15px}
.service-card h3{font-size:1.2rem;margin-bottom:10px}
.service-card p{font-size:.95rem;color:#666;margin-bottom:15px}
.service-card .price{font-family:var(--font-heading);font-size:1.3rem;color:var(--red);font-weight:700}

/* ===== WHY US ===== */
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px}
.why-card{text-align:center;padding:30px 20px}
.why-card .icon{font-size:2.5rem;margin-bottom:15px;color:var(--red)}
.why-card h3{font-size:1.1rem;margin-bottom:10px}
.why-card p{font-size:.9rem;color:#666}

/* ===== HOW IT WORKS ===== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:30px;counter-reset:step}
.step{text-align:center;padding:30px 20px;position:relative}
.step::before{counter-increment:step;content:counter(step);font-family:var(--font-heading);font-size:3rem;color:var(--gold);font-weight:700;display:block;margin-bottom:10px}
.step h3{margin-bottom:10px}
.step p{font-size:.95rem;color:#666}

/* ===== FAQ ===== */
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid #ddd;padding:20px 0}
.faq-question{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-family:var(--font-heading);font-size:1.1rem;color:var(--navy);gap:15px}
.faq-question::after{content:'+';font-size:1.5rem;color:var(--red);transition:transform .3s;flex-shrink:0}
.faq-item.active .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s;padding:0}
.faq-item.active .faq-answer{max-height:500px;padding-top:15px}
.faq-answer p{color:#666;font-size:.95rem}

/* ===== SERVICE AREAS ===== */
.areas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}
.area-card{background:var(--white);padding:20px;border-radius:8px;text-align:center;box-shadow:0 3px 10px rgba(0,0,0,.06);border-left:4px solid var(--red)}
.area-card h3{font-size:1rem;margin-bottom:5px}
.area-card p{font-size:.85rem;color:#666;margin:0}

/* ===== CONTACT FORM ===== */
.contact-form{max-width:700px;margin:0 auto}
.form-group{margin-bottom:20px}
.form-group label{display:block;font-family:var(--font-heading);font-size:.9rem;margin-bottom:5px;color:var(--navy);text-transform:uppercase;letter-spacing:.5px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 15px;border:2px solid #ddd;border-radius:5px;font-family:var(--font-body);font-size:1rem;transition:border-color .3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--red)}
.form-group textarea{min-height:150px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}

/* ===== FOOTER ===== */
.site-footer{background:var(--navy);color:rgba(255,255,255,.7);padding:60px 20px 20px}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:40px;margin-bottom:40px}
.footer-col h3{color:var(--gold);font-size:1rem;margin-bottom:15px;text-transform:uppercase;letter-spacing:1px}
.footer-col p,.footer-col li{font-size:.9rem;line-height:1.8}
.footer-col ul{list-style:none}
.footer-col a{color:rgba(255,255,255,.7);transition:color .3s}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:20px;text-align:center;font-size:.85rem}

/* ===== FLOATING CALL BUTTON ===== */
.floating-call{position:fixed;bottom:25px;right:25px;background:var(--red);color:var(--white);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 5px 20px rgba(196,30,58,.4);z-index:999;animation:pulse 2s infinite;text-decoration:none}
.floating-call:hover{background:var(--gold);color:var(--navy);transform:scale(1.1)}
@keyframes pulse{0%,100%{box-shadow:0 5px 20px rgba(196,30,58,.4)}50%{box-shadow:0 5px 30px rgba(196,30,58,.7)}}

/* ===== BREADCRUMB ===== */
.breadcrumb{padding:15px 20px;background:var(--gray);font-size:.85rem}
.breadcrumb a{color:var(--red)}
.breadcrumb span{color:#999}

/* ===== PAGE HERO ===== */
.page-hero{background:linear-gradient(135deg,var(--navy),#2a2a4e);color:var(--white);padding:60px 20px;text-align:center}
.page-hero h1{color:var(--white);margin-bottom:.3em}
.page-hero p{color:var(--gold);font-family:var(--font-accent);font-size:1.2rem;font-style:italic}

/* ===== CONTENT PAGE ===== */
.content-section{padding:60px 20px}
.content-section h2{margin-top:2rem}
.content-section ul,.content-section ol{margin:1rem 0 1.5rem 2rem}
.content-section li{margin-bottom:.5rem;color:#555}
.content-section .cta-box{background:var(--gray);border-left:4px solid var(--red);padding:25px 30px;margin:2rem 0;border-radius:0 8px 8px 0}
.content-section .cta-box h3{margin-bottom:10px}

/* ===== ABOUT ===== */
.about-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:40px}
.value-card{background:var(--gray);padding:30px;border-radius:8px;text-align:center}
.value-card .icon{font-size:2.5rem;margin-bottom:15px}

/* ===== BLOG ===== */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}
.blog-card{background:var(--white);border-radius:10px;overflow:hidden;box-shadow:0 5px 20px rgba(0,0,0,.08);transition:transform .3s}
.blog-card:hover{transform:translateY(-3px)}
.blog-card .thumb{height:200px;background:var(--gray)}
.blog-card .content{padding:25px}
.blog-card h3{font-size:1.1rem;margin-bottom:10px}
.blog-card .meta{font-size:.8rem;color:#999;margin-bottom:10px}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  h1{font-size:2rem}h2{font-size:1.6rem}
  .hero{padding:70px 20px 60px}
  .hero h1{font-size:2.2rem}
  .hero .tagline{font-size:1.2rem}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:var(--navy);flex-direction:column;padding:20px;gap:15px;border-top:1px solid rgba(255,255,255,.1)}
  .nav-links.active{display:flex}
  .hamburger{display:flex}
  .dropdown-menu{position:static;display:none;box-shadow:none;border:none;padding-left:15px}
  .dropdown.active .dropdown-menu{display:block}
  .form-row{grid-template-columns:1fr}
  .section{padding:50px 20px}
  .footer-grid{grid-template-columns:1fr}
}

/* ===== CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info-block{margin:30px 0}
.contact-info-block p{margin-top:15px}
.contact-label{font-family:var(--font-heading)}
.contact-phone{font-size:1.3rem;font-weight:700}
.check-list{list-style:none;padding:0;margin:15px 0 30px}
.check-list li{padding:8px 0 8px 25px;position:relative}
.check-list li:before{content:'✓';position:absolute;left:0;color:var(--red);font-weight:700}
.area-list{list-style:none;padding:0;margin:15px 0}
.area-list li{padding:5px 0}
.btn-full{width:100%}
.faq-section{margin-top:60px;border-top:1px solid #eee;padding-top:40px}
@media(max-width:768px){.contact-grid{grid-template-columns:1fr}}

/* ===== CONTENT NARROW ===== */
.content-narrow{max-width:800px;margin:0 auto}

/* ===== BLOG PAGE ===== */
.blog-thumb-icon{display:flex;align-items:center;justify-content:center;font-size:3rem}
.blog-cta-section{text-align:center;margin-top:50px}
.blog-cta-section p{font-size:1.1rem;color:#666;margin-bottom:15px}
.section-subtitle{text-align:center;margin:40px 0 30px}
