/*
Theme Name: RedShield Pest Control
Theme URI: https://example.com/redshield
Author: RedShield
Author URI: https://example.com
Description: Bold red, black & white WordPress theme for pest control businesses. Includes Home, About, Services, Process, and Contact templates.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: redshield
Tags: business, custom-menu, custom-logo, featured-images, theme-options, threaded-comments, translation-ready
*/

/* ===== Design Tokens ===== */
:root{
  --rs-red:#dc2626;
  --rs-red-dark:#991b1b;
  --rs-black:#0a0a0a;
  --rs-gray-900:#171717;
  --rs-gray-700:#404040;
  --rs-gray-500:#737373;
  --rs-gray-200:#e5e5e5;
  --rs-gray-100:#f5f5f5;
  --rs-white:#ffffff;
  --rs-shadow-red:0 20px 60px -15px rgba(220,38,38,.5);
  --rs-container:1200px;
  --rs-font: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* ===== Reset ===== */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--rs-font);color:var(--rs-black);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-weight:900;letter-spacing:-0.02em;line-height:1.05;margin:0}
p{margin:0}

.container{max-width:var(--rs-container);margin:0 auto;padding:0 24px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:14px 28px;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.05em;border:0;cursor:pointer;transition:all .2s}
.btn-primary{background:var(--rs-red);color:#fff;box-shadow:var(--rs-shadow-red)}
.btn-primary:hover{background:var(--rs-red-dark)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-dark{background:var(--rs-black);color:#fff}
.btn-dark:hover{background:var(--rs-gray-900)}
.btn-white{background:#fff;color:var(--rs-black)}

.eyebrow{display:inline-block;font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--rs-red);margin-bottom:14px}

/* ===== Header ===== */
.site-header{position:absolute;top:0;left:0;right:0;z-index:50}
.site-header.scrolled{position:fixed;background:var(--rs-black);box-shadow:0 2px 10px rgba(0,0,0,.3)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:20px 0}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:900;letter-spacing:.05em}
.brand-mark{width:36px;height:36px;background:var(--rs-red);transform:rotate(45deg);display:grid;place-items:center;color:#fff}
.brand-mark span{transform:rotate(-45deg);font-weight:900}
.nav-menu{display:flex;align-items:center;gap:32px;list-style:none;margin:0;padding:0}
.nav-menu a{color:rgba(255,255,255,.8);font-weight:500;font-size:14px;transition:color .2s}
.nav-menu a:hover,.nav-menu .current-menu-item a{color:#fff}
.header-cta{display:inline-flex;align-items:center;gap:8px;background:var(--rs-red);color:#fff;padding:10px 18px;font-weight:700;font-size:14px}
.header-cta:hover{background:var(--rs-red-dark)}
.mobile-toggle{display:none;background:none;border:0;color:#fff;cursor:pointer}

/* dark header on inner pages */
.inner-header{background:var(--rs-black);position:relative}

/* ===== Hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;background:linear-gradient(135deg,#0a0a0a 0%,#1a0808 60%,#dc2626 100%);overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:0;opacity:.35}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:right}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,#000 0%,rgba(0,0,0,.8) 50%,transparent 100%)}
.hero-inner{position:relative;padding:160px 0 100px;max-width:680px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(220,38,38,.4);background:rgba(220,38,38,.1);color:var(--rs-red);padding:6px 14px;font-size:11px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;margin-bottom:24px}
.hero-badge::before{content:"";width:6px;height:6px;background:var(--rs-red);border-radius:50%}
.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);line-height:.95}
.hero h1 .accent{color:var(--rs-red)}
.hero-lead{margin-top:24px;color:rgba(255,255,255,.7);font-size:18px;max-width:560px}
.hero-actions{margin-top:40px;display:flex;gap:16px;flex-wrap:wrap}
.hero-stats{margin-top:60px;border-top:1px solid rgba(255,255,255,.1);padding-top:32px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.hero-stats .v{font-size:32px;font-weight:900;color:#fff}
.hero-stats .l{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:4px}

/* ===== Page Header (inner pages) ===== */
.page-hero{background:linear-gradient(135deg,#0a0a0a,#1a0808);color:#fff;padding:160px 0 80px;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-100px;top:50%;transform:translateY(-50%);width:400px;height:400px;background:radial-gradient(circle,rgba(220,38,38,.3),transparent 70%)}
.page-hero h1{font-size:clamp(2.25rem,5vw,3.75rem);position:relative}
.page-hero p{color:rgba(255,255,255,.65);margin-top:16px;max-width:600px;position:relative}

/* ===== Sections ===== */
.section{padding:96px 0}
.section-dark{background:var(--rs-gray-900);color:#fff}
.section-red{background:var(--rs-red);color:#fff;position:relative;overflow:hidden}
.section-red::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,#fff 1px,transparent 0);background-size:24px 24px;opacity:.1}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:56px;flex-wrap:wrap}
.section-head h2{font-size:clamp(2rem,4vw,3rem);max-width:600px}
.section-head p{color:var(--rs-gray-500);max-width:420px}
.section-dark .section-head p{color:rgba(255,255,255,.6)}

/* ===== Services Grid ===== */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rs-gray-200)}
.service-card{background:#fff;padding:32px;cursor:pointer;transition:all .3s}
.service-card:hover{background:var(--rs-black);color:#fff}
.service-icon{width:56px;height:56px;background:var(--rs-red);color:#fff;display:grid;place-items:center;margin-bottom:24px;transition:transform .3s;font-size:28px}
.service-card:hover .service-icon{transform:rotate(12deg)}
.service-card h3{font-size:20px;margin-bottom:12px}
.service-card p{font-size:14px;opacity:.7}
.service-link{margin-top:24px;display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--rs-red)}

/* ===== Why Us ===== */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.why-features{display:flex;flex-direction:column;gap:20px}
.why-feature{display:flex;gap:16px;border-left:2px solid var(--rs-red);padding:8px 0 8px 20px}
.why-feature .check{color:var(--rs-red);font-size:20px;flex-shrink:0}
.why-feature .t{font-weight:700;color:#fff}
.why-feature .d{font-size:14px;color:rgba(255,255,255,.6);margin-top:4px}
.badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.badge-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);padding:8px 16px;font-size:13px;color:#fff}
.badge-pill .dot{color:var(--rs-red)}

/* ===== Process ===== */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.process-step .num{font-size:72px;font-weight:900;color:rgba(220,38,38,.2);line-height:1}
.process-step h3{font-size:20px;margin-top:8px}
.process-step p{font-size:14px;color:var(--rs-gray-500);margin-top:8px}

/* ===== CTA ===== */
.cta-center{text-align:center;position:relative}
.cta-center h2{font-size:clamp(2.25rem,5vw,3.75rem)}
.cta-center p{margin-top:20px;font-size:18px;opacity:.9;max-width:520px;margin-left:auto;margin-right:auto}
.cta-actions{margin-top:40px;display:flex;justify-content:center;gap:16px;flex-wrap:wrap}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact-info{background:var(--rs-black);color:#fff;padding:48px}
.contact-info h3{font-size:24px;margin-bottom:24px}
.contact-info ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:20px}
.contact-info li{display:flex;gap:14px;align-items:flex-start}
.contact-info .ic{width:40px;height:40px;background:var(--rs-red);display:grid;place-items:center;flex-shrink:0;color:#fff}
.contact-info .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.contact-info .val{font-weight:700;margin-top:2px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:14px 16px;border:1px solid var(--rs-gray-200);background:#fff;font-family:inherit;font-size:15px;margin-bottom:14px;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--rs-red)}
.contact-form textarea{min-height:140px;resize:vertical}

/* ===== About ===== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about-img{aspect-ratio:4/5;background-size:cover;background-position:center;position:relative}
.about-img::after{content:"";position:absolute;inset:-16px -16px 16px 16px;border:2px solid var(--rs-red);z-index:-1}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:56px}
.value-card{padding:32px;background:#fff;border-top:3px solid var(--rs-red)}
.value-card h3{font-size:18px;margin-bottom:8px}
.value-card p{font-size:14px;color:var(--rs-gray-500)}

/* ===== Footer ===== */
.site-footer{background:var(--rs-black);color:rgba(255,255,255,.6);padding:64px 0 24px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-col h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.15em;margin-bottom:18px;font-weight:800}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px}
.footer-col a:hover{color:var(--rs-red)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;font-size:13px;flex-wrap:wrap;gap:12px}

/* ===== Posts / Blog ===== */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.post-card{background:#fff;border:1px solid var(--rs-gray-200);transition:transform .2s,box-shadow .2s}
.post-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(0,0,0,.15)}
.post-card .thumb{aspect-ratio:16/10;background:var(--rs-gray-100);background-size:cover;background-position:center}
.post-card .body{padding:24px}
.post-card h3{font-size:20px;margin-bottom:8px}
.post-card .meta{font-size:12px;color:var(--rs-gray-500);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}

.single-post-content{max-width:720px;margin:0 auto;padding:80px 24px;font-size:17px}
.single-post-content h2{margin:32px 0 16px;font-size:28px}
.single-post-content p{margin-bottom:18px}

/* ===== Responsive ===== */
@media (max-width:900px){
  .nav-menu{display:none}
  .mobile-toggle{display:block}
  .nav-menu.open{display:flex;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--rs-black);padding:24px;gap:18px}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid,.about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .process-grid{grid-template-columns:repeat(2,1fr)}
  .values-grid{grid-template-columns:1fr}
  .posts-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .section{padding:64px 0}
  .header-cta span{display:none}
}
