/*
Theme Name: Summerlin Roofing Co.
Theme URI: https://lasvegasnewroof.com
Author: Summerlin Roofing Co.
Description: SEO-optimized roofing contractor theme for Summerlin & Las Vegas, NV — luxury desert editorial aesthetic.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: summerlin-roofing
Tags: business, contractor, roofing, seo, local, nevada
*/

/* ── TOKENS ─────────────────────────────────────── */
:root{
  --sand:      #F2EAD8;
  --sand-dark: #E4D8C0;
  --terra:     #B85C2C;
  --terra-dk:  #8F4420;
  --sage:      #7A9175;
  --sage-lt:   #A8BFA4;
  --charcoal:  #1E1E1E;
  --warm-gray: #6B6358;
  --off-white: #FAF7F2;
  --white:     #FFFFFF;
  --max:       1200px;
  --r:         2px;
  --transition: 0.25s ease;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

body{
  font-family:'DM Sans',sans-serif;
  font-weight:300;
  color:var(--charcoal);
  background:var(--off-white);
  line-height:1.75;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition)}

.container{max-width:var(--max);margin:0 auto;padding:0 2rem}

/* TYPOGRAPHY */
.display,.serif{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.08;letter-spacing:-0.02em}
.display{font-weight:900}
.eyebrow{font-size:0.72rem;font-weight:500;letter-spacing:0.2em;text-transform:uppercase;color:var(--terra)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:0.5rem;padding:0.9rem 2rem;font-family:'DM Sans',sans-serif;font-size:0.85rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;border:1.5px solid transparent;border-radius:var(--r);cursor:pointer;transition:all var(--transition)}
.btn-terra{background:var(--terra);color:#fff;border-color:var(--terra)}
.btn-terra:hover{background:var(--terra-dk);border-color:var(--terra-dk)}
.btn-outline{background:transparent;color:var(--charcoal);border-color:var(--charcoal)}
.btn-outline:hover{background:var(--charcoal);color:#fff}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,0.6)}
.btn-outline-light:hover{background:#fff;color:var(--charcoal)}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:200;padding:1.5rem 0;transition:background var(--transition),padding var(--transition),box-shadow var(--transition)}
.site-header.scrolled{background:rgba(250,247,242,0.96);backdrop-filter:blur(12px);padding:1rem 0;box-shadow:0 1px 0 rgba(0,0,0,0.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Playfair Display',serif;font-weight:700;font-size:1.25rem;color:#fff;letter-spacing:-0.01em;transition:color var(--transition)}
.logo em{font-style:italic;color:rgba(255,255,255,0.7)}
.site-header.scrolled .logo{color:var(--charcoal)}
.site-header.scrolled .logo em{color:var(--terra)}
nav ul{list-style:none;display:flex;align-items:center;gap:2rem}
nav a{font-size:0.82rem;font-weight:500;letter-spacing:0.06em;text-transform:uppercase;color:rgba(255,255,255,0.8);transition:color var(--transition)}
nav a:hover{color:#fff}
.site-header.scrolled nav a{color:var(--warm-gray)}
.site-header.scrolled nav a:hover{color:var(--charcoal)}
.nav-cta{background:var(--terra)!important;color:#fff!important;padding:0.55rem 1.25rem;border-radius:var(--r)}
.nav-cta:hover{background:var(--terra-dk)!important}
.menu-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.menu-toggle span{width:22px;height:1.5px;background:#fff;display:block;transition:var(--transition)}
.site-header.scrolled .menu-toggle span{background:var(--charcoal)}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:flex-end;position:relative;overflow:hidden;padding-bottom:5rem}
.hero-bg{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(20,15,10,0.1) 0%,rgba(20,15,10,0.55) 100%),linear-gradient(160deg,#C4803A 0%,#D4956A 20%,#B86040 40%,#7A4A30 60%,#3A2820 80%,#1A1208 100%);z-index:0}
.hero-bg::after{content:'';position:absolute;top:-15%;right:-8%;width:650px;height:650px;border-radius:50%;background:radial-gradient(circle,rgba(255,200,80,0.25) 0%,rgba(220,120,40,0.12) 45%,transparent 70%);z-index:1}
.hero .container{position:relative;z-index:2;width:100%}
.hero-tag{display:inline-block;border:1px solid rgba(255,255,255,0.4);color:rgba(255,255,255,0.85);font-size:0.72rem;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;padding:0.45rem 1rem;border-radius:100px;margin-bottom:2rem}
.hero h1{font-family:'Playfair Display',serif;font-weight:900;font-size:clamp(3rem,7vw,5.5rem);line-height:1.05;letter-spacing:-0.02em;color:#fff;max-width:820px;margin-bottom:1.75rem}
.hero h1 em{font-style:italic;color:rgba(255,200,120,0.95)}
.hero-sub{font-size:1.1rem;font-weight:300;color:rgba(255,255,255,0.75);max-width:540px;margin-bottom:1.5rem;line-height:1.7}
.hero-body{max-width:580px;margin-bottom:2.5rem}
.hero-body p{font-size:0.95rem;color:rgba(255,255,255,0.65);margin-bottom:0.75rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}

/* SECTIONS */
section{padding:7rem 0}
.section--sand{background:var(--sand)}
.section--dark{background:var(--charcoal)}
.section--off{background:var(--off-white)}
.sec-label{margin-bottom:0.6rem}
.sec-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:900;line-height:1.1;letter-spacing:-0.02em;color:var(--charcoal);margin-bottom:1.25rem}
.sec-title em{font-style:italic;color:var(--terra)}
.sec-intro{font-size:1rem;font-weight:300;color:var(--warm-gray);max-width:580px;line-height:1.8}

/* SERVICES */
.services-layout{display:grid;grid-template-columns:1fr 2fr;gap:5rem;align-items:start}
.services-sticky{position:sticky;top:120px}
.services-sticky .sec-title{margin-bottom:1.5rem}
.services-sticky p{font-size:0.95rem;color:var(--warm-gray);line-height:1.8;margin-bottom:2rem}
.services-list{display:flex;flex-direction:column;gap:0}
.service-item{border-top:1px solid var(--sand-dark);padding:2rem 0;display:grid;grid-template-columns:auto 1fr;gap:1.5rem;align-items:start;transition:var(--transition);cursor:default}
.service-item:last-child{border-bottom:1px solid var(--sand-dark)}
.service-item:hover .service-num{color:var(--terra)}
.service-num{font-family:'Playfair Display',serif;font-size:0.85rem;font-weight:700;color:var(--sand-dark);padding-top:0.3rem;transition:color var(--transition);min-width:2rem}
.service-content h3{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--charcoal);margin-bottom:0.6rem}
.service-content p{font-size:0.9rem;color:var(--warm-gray);line-height:1.75}
.service-tag{display:inline-block;margin-top:0.75rem;font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:var(--terra)}

/* WHY */
.why-section{background:var(--charcoal);position:relative;overflow:hidden}
.why-section::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(184,92,44,0.12) 0%,transparent 70%);pointer-events:none}
.why-header{text-align:center;max-width:640px;margin:0 auto 5rem}
.why-header .sec-title{color:#fff}
.why-header .eyebrow{color:var(--sage-lt)}
.why-header p{color:rgba(255,255,255,0.55);font-size:1rem;line-height:1.8}
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.06)}
.why-item{background:var(--charcoal);padding:3rem 2.5rem;transition:background var(--transition)}
.why-item:hover{background:#252525}
.why-icon{font-size:1.75rem;margin-bottom:1.25rem;display:block}
.why-item h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:#fff;margin-bottom:0.75rem;line-height:1.3}
.why-item p{font-size:0.88rem;color:rgba(255,255,255,0.5);line-height:1.8}

/* CLIMATE */
.climate-grid{display:grid;grid-template-columns:3fr 2fr;gap:5rem;align-items:center}
.climate-text .sec-title{margin-bottom:1.5rem}
.climate-text p{font-size:0.95rem;color:var(--warm-gray);line-height:1.85;margin-bottom:1rem}
.climate-panel{background:var(--sand);padding:3rem 2.5rem;border-radius:var(--r);position:relative}
.climate-panel::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(to bottom,var(--terra),var(--sage));border-radius:var(--r) 0 0 var(--r)}
.climate-panel h3{font-size:0.8rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--terra);margin-bottom:1.5rem}
.stat-row{display:flex;justify-content:space-between;align-items:baseline;padding:1rem 0;border-bottom:1px solid var(--sand-dark)}
.stat-row:last-child{border-bottom:none}
.stat-val{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:900;color:var(--charcoal)}
.stat-desc{font-size:0.8rem;color:var(--warm-gray);text-align:right;max-width:140px;line-height:1.4}

/* AREAS */
.areas-section{background:linear-gradient(135deg,var(--terra) 0%,#9A4A22 100%);padding:5rem 0;text-align:center}
.areas-section .eyebrow{color:rgba(255,255,255,0.6)}
.areas-section .sec-title{color:#fff}
.areas-wrap{display:flex;flex-wrap:wrap;gap:0.6rem;justify-content:center;max-width:860px;margin:2rem auto 0}
.area-pill{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.25);color:#fff;padding:0.45rem 1.1rem;border-radius:100px;font-size:0.82rem;font-weight:400}
.area-pill.featured{background:rgba(255,255,255,0.22);font-weight:500;border-color:rgba(255,255,255,0.45)}

/* CTA */
.cta-section{background:var(--sand);padding:8rem 0}
.cta-inner{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.cta-text .sec-title{font-size:clamp(2rem,4vw,3.2rem)}
.cta-text p{font-size:0.95rem;color:var(--warm-gray);line-height:1.85;margin-bottom:1rem}
.cta-card{background:var(--charcoal);padding:3rem;border-radius:var(--r)}
.cta-card h3{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:0.5rem}
.cta-card > p{font-size:0.85rem;color:rgba(255,255,255,0.5);margin-bottom:2rem}
.form-group{margin-bottom:1rem}
.form-group label{display:block;font-size:0.72rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-bottom:0.4rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:0.75rem 1rem;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);border-radius:var(--r);color:#fff;font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:300;transition:border-color var(--transition);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--terra)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group textarea{resize:vertical;min-height:90px}
.submit-btn{width:100%;padding:1rem;background:var(--terra);color:#fff;border:none;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:0.85rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;cursor:pointer;transition:background var(--transition);margin-top:0.5rem}
.submit-btn:hover{background:var(--terra-dk)}
.form-note{font-size:0.75rem;color:rgba(255,255,255,0.3);text-align:center;margin-top:0.75rem}

/* FOOTER */
.site-footer{background:#141414;padding:5rem 0 2rem}
.footer-top{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr;gap:3rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,0.07);margin-bottom:2rem}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:#fff;display:block;margin-bottom:1rem}
.footer-logo em{font-style:italic;color:var(--terra)}
.footer-brand p{font-size:0.82rem;color:rgba(255,255,255,0.38);line-height:1.75;max-width:280px;margin-bottom:1.5rem}
.footer-address{font-size:0.82rem;color:rgba(255,255,255,0.45);line-height:1.8;font-style:normal}
.footer-address a{color:rgba(255,255,255,0.55);transition:color var(--transition)}
.footer-address a:hover{color:#fff}
.footer-col h4{font-size:0.72rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.3);margin-bottom:1.25rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:0.6rem}
.footer-col a{font-size:0.85rem;color:rgba(255,255,255,0.5);transition:color var(--transition)}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;font-size:0.78rem;color:rgba(255,255,255,0.25)}
.footer-bottom a{color:rgba(255,255,255,0.35);margin-left:1.5rem}
.footer-bottom a:hover{color:rgba(255,255,255,0.65)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
.hero-tag{animation:fadeUp 0.7s ease both}
.hero h1{animation:fadeUp 0.7s 0.15s ease both}
.hero-sub{animation:fadeUp 0.7s 0.25s ease both}
.hero-body{animation:fadeUp 0.7s 0.35s ease both}
.hero-actions{animation:fadeUp 0.7s 0.45s ease both}

/* RESPONSIVE */
@media(max-width:1024px){
  .services-layout{grid-template-columns:1fr}
  .services-sticky{position:static}
  .climate-grid{grid-template-columns:1fr}
  .cta-inner{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  section{padding:5rem 0}
  .why-grid{grid-template-columns:1fr}
  nav ul{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--off-white);padding:2rem;gap:1rem;box-shadow:0 8px 24px rgba(0,0,0,0.12)}
  nav ul.open{display:flex}
  nav a{color:var(--warm-gray)}
  .menu-toggle{display:flex}
  .footer-top{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:0.75rem;text-align:center}
}

/* CTA CALL CARD (replaces form) */
.cta-call-card{background:var(--charcoal);padding:3.5rem;border-radius:var(--r);text-align:center}
.cta-call-card h3{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:0.75rem}
.cta-call-card>p{font-size:0.9rem;color:rgba(255,255,255,0.45);margin-bottom:2rem;line-height:1.7}
.phone-big{display:block;font-family:'Playfair Display',serif;font-size:2.4rem;font-weight:900;color:#fff;margin-bottom:1.75rem;letter-spacing:-0.02em;transition:color var(--transition)}
.phone-big:hover{color:var(--terra)}
.tap-btn{display:block;background:var(--terra);color:#fff;padding:1rem;border-radius:var(--r);font-family:'DM Sans',sans-serif;font-size:0.85rem;font-weight:500;letter-spacing:0.1em;text-transform:uppercase;text-align:center;transition:background var(--transition);margin-bottom:2rem}
.tap-btn:hover{background:var(--terra-dk);color:#fff}
.cta-divider{border:none;border-top:1px solid rgba(255,255,255,0.1);margin-bottom:1.5rem}
.cta-hours{font-size:0.75rem;color:rgba(255,255,255,0.3);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:0.75rem}
.cta-address{font-size:0.82rem;color:rgba(255,255,255,0.38);font-style:normal;line-height:1.7}
