/*
Theme Name: Faith Over Fear Roofing
Theme URI: https://faithoverfearroofing.local/
Author: Manus AI
Author URI: https://manus.im/
Description: Premium WordPress theme for Faith Over Fear Roofing in Chattanooga, Tennessee. Neo-Southern Storm Utility design with emergency banners, city/service landing pages, lead forms, SEO schema, and bold storm-response conversion tools.
Version: 1.0.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: faith-over-fear-roofing
Tags: roofing, contractor, local-business, seo, responsive, dark, custom-colors
*/

/*
Design reminder for this file: Neo-Southern Storm Utility. Reinforce deep navy storm surfaces (#0d1f3c), electric sky-blue proof/corridor accents (#4db3e6), orange conversion controls (#e8600a), gold trust cues (#f5c842), diagonal roof-plane geometry, and Barlow typography. Does this choice reinforce or dilute our design philosophy?
*/
:root {
  --foff-navy: #0d1f3c;
  --foff-navy-2: #071326;
  --foff-blue: #4db3e6;
  --foff-orange: #e8600a;
  --foff-gold: #f5c842;
  --foff-white: #f8f9fb;
  --foff-muted: #b8c7d8;
  --foff-card: rgba(248,249,251,.94);
  --foff-line: rgba(77,179,230,.22);
  --foff-shadow: 0 24px 80px rgba(0,0,0,.35);
  --foff-radius: 22px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; min-height:100%; overflow-x:hidden; overflow-y:auto; }
body { margin:0; min-height:100%; overflow-x:hidden; overflow-y:auto; font-family:'Barlow',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif; color:var(--foff-white); background:var(--foff-navy-2); line-height:1.62; }
a { color: inherit; }
img { max-width:100%; height:auto; display:block; }
.screen-reader-text { position:absolute; left:-10000px; width:1px; height:1px; overflow:hidden; }
.foff-page { overflow-x:hidden; overflow-y:auto; min-height:100vh; background:
  radial-gradient(circle at 18% 5%, rgba(77,179,230,.16), transparent 28%),
  linear-gradient(145deg, var(--foff-navy-2), var(--foff-navy) 38%, #09162a 100%); }
.foff-container { width:min(1180px, calc(100% - 40px)); margin:0 auto; }
.foff-top-alert { position:sticky; top:0; z-index:1000; background:linear-gradient(90deg,#411808,var(--foff-orange)); color:#fff; font-weight:800; letter-spacing:.02em; box-shadow:0 10px 34px rgba(0,0,0,.28); }
.foff-top-alert__inner { min-height:44px; display:flex; gap:14px; align-items:center; justify-content:center; padding:8px 48px; text-transform:uppercase; font-family:'Barlow Condensed',sans-serif; font-size:18px; }
.foff-pulse { width:12px; height:12px; border-radius:999px; background:#fff; box-shadow:0 0 0 0 rgba(255,255,255,.8); animation:foffPulse 1.5s infinite; flex:0 0 12px; }
.foff-alert-close { position:absolute; right:12px; top:5px; width:32px; height:32px; border:0; border-radius:999px; background:rgba(255,255,255,.18); color:#fff; font-size:20px; cursor:pointer; }
.foff-header { position:sticky; top:44px; z-index:900; backdrop-filter:blur(18px); background:rgba(7,19,38,.82); border-bottom:1px solid var(--foff-line); }
.admin-bar .foff-header { top:76px; }
.foff-nav { min-height:86px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.foff-brand { display:flex; align-items:center; gap:12px; text-decoration:none; min-width:240px; }
.foff-logo-mark { width:58px; height:58px; border-radius:18px; display:grid; place-items:center; background:linear-gradient(145deg,var(--foff-blue),#ffffff); color:var(--foff-navy); font-family:'Barlow Condensed',sans-serif; font-weight:900; box-shadow:0 12px 30px rgba(77,179,230,.24); transform:skew(-7deg); }
.foff-brand strong { display:block; font-family:'Barlow Condensed',sans-serif; font-weight:900; line-height:.9; font-size:28px; letter-spacing:.01em; }
.foff-brand span { color:var(--foff-blue); font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; }
.foff-menu { display:flex; align-items:center; gap:20px; flex-wrap:wrap; justify-content:center; }
.foff-menu a { text-decoration:none; color:rgba(248,249,251,.9); font-weight:700; font-size:15px; }
.foff-menu a:hover { color:var(--foff-blue); }
.foff-nav-actions { display:flex; gap:12px; align-items:center; }
.foff-btn, .foff-form button, .foff-submit { appearance:none; border:0; text-decoration:none; display:inline-flex; align-items:center; justify-content:center; gap:9px; min-height:48px; padding:13px 22px; border-radius:12px; font-weight:900; text-transform:uppercase; letter-spacing:.04em; font-family:'Barlow Condensed',sans-serif; cursor:pointer; transition:.22s ease; }
.foff-btn--orange, .foff-form button, .foff-submit { background:linear-gradient(135deg,var(--foff-orange),#ff8d31); color:#fff; box-shadow:0 16px 36px rgba(232,96,10,.34); }
.foff-btn--orange:hover { transform:translateY(-2px); box-shadow:0 20px 44px rgba(232,96,10,.42); }
.foff-btn--blue { background:rgba(77,179,230,.16); color:#fff; border:1px solid rgba(77,179,230,.48); }
.foff-btn--white { background:#fff; color:var(--foff-navy); }
.foff-hero { position:relative; min-height:780px; display:flex; align-items:center; isolation:isolate; padding:88px 0 90px; }
.foff-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(90deg,rgba(7,19,38,.98) 0%,rgba(7,19,38,.86) 38%,rgba(7,19,38,.38) 72%,rgba(7,19,38,.72)), url('https://d2xsxph8kpxj0f.cloudfront.net/310519663553289406/Qibbvmke6WH7axoFKBjhB7/foff-hero-storm-roofing-4MS4UPEjLWjeFs3FvZEBDZ.webp') center/cover no-repeat; z-index:-3; }
.foff-hero::after { content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(77,179,230,.09) 1px, transparent 1px), linear-gradient(90deg, rgba(77,179,230,.09) 1px, transparent 1px); background-size:42px 42px; mask-image:linear-gradient(90deg,#000,transparent 72%); z-index:-2; animation:gridDrift 16s linear infinite; }
.foff-hero-grid { display:grid; grid-template-columns:minmax(0,1.08fr) minmax(330px,.72fr); gap:48px; align-items:center; }
.foff-kicker { display:inline-flex; align-items:center; gap:9px; color:var(--foff-blue); font-family:'Barlow Condensed',sans-serif; font-size:19px; font-weight:900; text-transform:uppercase; letter-spacing:.12em; }
.foff-kicker::before { content:''; width:34px; height:3px; background:var(--foff-orange); display:block; }
.foff-h1, .foff-h2, .foff-h3 { margin:0; font-family:'Barlow Condensed',sans-serif; font-weight:900; text-transform:uppercase; line-height:.88; letter-spacing:-.025em; }
.foff-h1 { font-size:clamp(56px, 9vw, 118px); max-width:760px; text-shadow:0 16px 70px rgba(0,0,0,.5); animation:riseIn .7s ease both; }
.foff-h2 { font-size:clamp(42px,6.2vw,78px); }
.foff-h3 { font-size:32px; line-height:1; }
.foff-lead { font-size:clamp(18px,2vw,23px); color:#e9f4ff; max-width:690px; margin:24px 0 0; }
.foff-hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.foff-proof-strip { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:36px; max-width:790px; }
.foff-proof { padding:16px 14px; background:rgba(248,249,251,.08); border:1px solid var(--foff-line); border-radius:18px; backdrop-filter:blur(12px); }
.foff-proof strong { display:block; font-family:'Barlow Condensed',sans-serif; font-size:33px; line-height:1; color:#fff; }
.foff-proof span { color:var(--foff-muted); font-size:13px; font-weight:700; text-transform:uppercase; }
.foff-card { background:var(--foff-card); color:#142038; border-radius:var(--foff-radius); box-shadow:var(--foff-shadow); overflow:hidden; border:1px solid rgba(255,255,255,.2); }
.foff-estimate-card { transform:rotate(1deg); }
.foff-card__head { background:linear-gradient(135deg,var(--foff-blue),#ecfbff); color:var(--foff-navy); padding:22px 24px; }
.foff-card__head h2, .foff-card__head h3 { margin:0; font-family:'Barlow Condensed'; font-size:32px; text-transform:uppercase; line-height:1; }
.foff-form { padding:24px; }
.foff-form label { display:block; color:#20314c; font-weight:800; font-size:13px; text-transform:uppercase; margin:14px 0 6px; }
.foff-form input, .foff-form select, .foff-form textarea { width:100%; border:1px solid #d6e1ef; background:#fff; color:#0d1f3c; padding:13px 14px; border-radius:12px; font:inherit; }
.foff-form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.foff-form-step { display:none; }
.foff-form-step.is-active { display:block; animation:riseIn .25s ease both; }
.foff-form-nav { display:flex; gap:10px; margin-top:18px; }
.foff-form-note { color:#50627e; font-size:14px; margin-top:12px; }
.foff-section { position:relative; padding:92px 0; }
.foff-section--light { background:#f8f9fb; color:#0d1f3c; }
.foff-section--light .foff-lead { color:#40536c; }
.foff-diagonal-top { clip-path:polygon(0 7%,100% 0,100% 100%,0 100%); margin-top:-58px; padding-top:128px; }
.foff-split { display:grid; grid-template-columns:1fr 1fr; gap:44px; align-items:center; }
.foff-services { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:38px; }
.foff-service-card { background:#fff; color:#15233a; padding:26px; border-radius:22px; border:1px solid #dde8f4; box-shadow:0 20px 50px rgba(13,31,60,.08); min-height:230px; position:relative; overflow:hidden; }
.foff-service-card::after { content:''; position:absolute; right:-45px; top:-45px; width:130px; height:130px; border-radius:50%; background:rgba(77,179,230,.12); }
.foff-service-card h3 { margin:0 0 12px; font-family:'Barlow Condensed'; text-transform:uppercase; font-size:31px; line-height:1; color:#0d1f3c; }
.foff-service-card p { color:#52647a; }
.foff-link { color:var(--foff-orange); font-weight:900; text-transform:uppercase; font-family:'Barlow Condensed'; text-decoration:none; }
.foff-route-card { background:rgba(248,249,251,.08); border:1px solid var(--foff-line); border-radius:26px; padding:18px; box-shadow:var(--foff-shadow); }
.foff-route-card img { border-radius:18px; }
.foff-city-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:24px; }
.foff-city-pill { display:flex; justify-content:space-between; gap:8px; padding:13px 14px; border:1px solid rgba(77,179,230,.28); border-radius:14px; color:#fff; text-decoration:none; background:rgba(255,255,255,.06); font-weight:700; }
.foff-city-pill:hover { background:rgba(77,179,230,.16); color:#fff; }
.foff-before-after { position:relative; border-radius:26px; overflow:hidden; box-shadow:var(--foff-shadow); border:1px solid rgba(255,255,255,.18); }
.foff-before-after img { width:100%; }
.foff-ba-line { position:absolute; top:0; bottom:0; left:50%; width:4px; background:#fff; box-shadow:0 0 0 9999px rgba(7,19,38,.0); }
.foff-ba-handle { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:58px; height:58px; border-radius:50%; background:var(--foff-orange); color:#fff; display:grid; place-items:center; font-weight:900; box-shadow:0 12px 30px rgba(0,0,0,.34); }
.foff-testimonials { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:36px; }
.foff-quote { background:rgba(248,249,251,.08); border:1px solid var(--foff-line); border-radius:22px; padding:24px; }
.foff-stars { color:var(--foff-gold); letter-spacing:2px; font-size:22px; }
.foff-faq { max-width:900px; margin:34px auto 0; }
.foff-faq details { background:#fff; color:#0d1f3c; border-radius:16px; margin-bottom:12px; padding:18px 22px; border:1px solid #dce7f5; }
.foff-faq summary { font-weight:900; cursor:pointer; font-family:'Barlow Condensed'; font-size:24px; text-transform:uppercase; }
.foff-footer { background:#06111f; color:#fff; padding:62px 0 100px; border-top:1px solid var(--foff-line); }
.foff-footer-grid { display:grid; grid-template-columns:1.2fr .8fr .8fr 1fr; gap:30px; }
.foff-footer a { color:#d7ecfb; text-decoration:none; }
.foff-mobile-cta { display:none; position:fixed; z-index:1100; left:0; right:0; bottom:0; background:rgba(6,17,31,.96); border-top:1px solid var(--foff-line); padding:8px; gap:8px; }
.foff-mobile-cta a { flex:1; text-decoration:none; text-align:center; border-radius:12px; padding:12px 8px; font-weight:900; font-family:'Barlow Condensed'; text-transform:uppercase; }
.foff-mobile-cta a:nth-child(1) { background:var(--foff-orange); color:#fff; }
.foff-mobile-cta a:nth-child(2) { background:rgba(77,179,230,.15); border:1px solid var(--foff-line); color:#fff; }
.foff-mobile-cta a:nth-child(3) { background:#fff; color:#0d1f3c; }
.foff-exit { position:fixed; inset:0; z-index:2000; background:rgba(0,0,0,.62); display:none; align-items:center; justify-content:center; padding:20px; }
.foff-exit.is-open { display:flex; }
.foff-exit-card { max-width:560px; background:#fff; color:#0d1f3c; border-radius:26px; box-shadow:var(--foff-shadow); padding:34px; position:relative; }
.foff-exit-close { position:absolute; top:12px; right:12px; border:0; background:#eef4fb; width:34px; height:34px; border-radius:50%; font-size:20px; }
.foff-admin-preview { border-radius:26px; overflow:hidden; border:1px solid rgba(77,179,230,.2); box-shadow:var(--foff-shadow); }
.foff-small-label { color:var(--foff-blue); font-weight:900; font-family:'Barlow Condensed'; text-transform:uppercase; letter-spacing:.12em; }
.foff-copy { color:#d7e6f4; }
.foff-page-title { padding:86px 0 46px; background:linear-gradient(135deg,#071326,#0d1f3c); }
.foff-content { background:#f8f9fb; color:#0d1f3c; padding:70px 0; }
.foff-content .foff-lead { color:#40536c; }
.foff-breadcrumb { color:#92ccef; font-weight:800; text-transform:uppercase; letter-spacing:.08em; font-size:13px; }
.foff-map-embed { width:100%; min-height:360px; border:0; border-radius:22px; box-shadow:0 18px 60px rgba(13,31,60,.16); }
@keyframes foffPulse { 70% { box-shadow:0 0 0 12px rgba(255,255,255,0); } 100% { box-shadow:0 0 0 0 rgba(255,255,255,0); } }
@keyframes gridDrift { from { background-position:0 0; } to { background-position:42px 42px; } }
@keyframes riseIn { from { opacity:0; transform:translateY(18px); } to { opacity:1; transform:translateY(0); } }
@media (max-width: 980px) {
  .foff-header { top:44px; } .foff-nav { align-items:flex-start; flex-direction:column; padding:14px 0; } .foff-menu { justify-content:flex-start; } .foff-nav-actions { width:100%; }
  .foff-hero-grid, .foff-split { grid-template-columns:1fr; } .foff-hero { min-height:auto; padding:70px 0; } .foff-proof-strip, .foff-services, .foff-testimonials { grid-template-columns:1fr 1fr; } .foff-city-grid, .foff-footer-grid { grid-template-columns:1fr 1fr; } .foff-estimate-card { transform:none; }
}
@media (max-width: 680px) {
  .foff-container { width:min(100% - 28px, 1180px); } .foff-top-alert__inner { font-size:15px; justify-content:flex-start; padding-right:46px; } .foff-header { position:relative; top:auto; } .foff-menu { display:none; } .foff-nav-actions { display:none; } .foff-h1 { font-size:58px; } .foff-proof-strip, .foff-services, .foff-testimonials, .foff-city-grid, .foff-footer-grid, .foff-form-row { grid-template-columns:1fr; } .foff-mobile-cta { display:flex; } .foff-section { padding:68px 0; } .foff-diagonal-top { clip-path:none; margin-top:0; padding-top:68px; }
}
