/* Umbrella Garage Doors - Main Stylesheet
   Author: Umbrella Garage Doors LLC
   Year: 2024
*/

:root {
  --c-primary: #d72638;
  --c-primary-dark: #a51d2b;
  --c-secondary: #1b2a41;
  --c-accent: #f5a623;
  --c-bg: #fafafa;
  --c-text: #1f2937;
  --c-muted: #6b7280;
  --c-light: #ffffff;
  --c-border: #e5e7eb;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-md: 0 8px 24px rgba(0,0,0,0.1);
  --shadow-lg: 0 20px 50px rgba(0,0,0,0.18);
  --radius: 10px;
  --max-w: 1200px;
  --transition: 0.3s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  color:var(--c-text);
  background:var(--c-bg);
  line-height:1.65;
  font-size:16px;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--c-primary-dark)}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:700;line-height:1.2;color:var(--c-secondary)}
h1{font-size:clamp(2.2rem,5vw,3.8rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:1rem}
h3{font-size:1.4rem;margin-bottom:.6rem}
p{margin-bottom:1rem;color:#374151}
.container{max-width:var(--max-w);margin:0 auto;padding:0 20px}

/* Top bar */
.topbar{
  background:var(--c-secondary);
  color:#dbeafe;
  font-size:.85rem;
  padding:8px 0;
}
.topbar .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.topbar a{color:#fff}
.topbar .info span{margin-right:18px}

/* Header */
.header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(10px);
  box-shadow:var(--shadow-sm);
  transition:all var(--transition);
}
.header .container{display:flex;align-items:center;justify-content:space-between;padding:14px 20px}
.logo{display:flex;align-items:center;gap:10px;font-family:'Playfair Display',serif;font-weight:700;font-size:1.4rem;color:var(--c-secondary)}
.logo svg{width:38px;height:38px}
.logo span{color:var(--c-primary)}
.nav ul{list-style:none;display:flex;gap:28px}
.nav a{color:var(--c-text);font-weight:500;position:relative;padding:6px 0}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--c-primary);transition:width var(--transition);
}
.nav a:hover::after,.nav a.active::after{width:100%}
.nav a.active{color:var(--c-primary)}
.btn{
  display:inline-block;padding:12px 26px;border-radius:var(--radius);
  font-weight:600;cursor:pointer;border:none;
  transition:all var(--transition);text-align:center;font-size:.95rem;
  letter-spacing:.3px;
}
.btn-primary{background:var(--c-primary);color:#fff;box-shadow:0 6px 18px rgba(215,38,56,.35)}
.btn-primary:hover{background:var(--c-primary-dark);transform:translateY(-2px);color:#fff;box-shadow:0 10px 24px rgba(215,38,56,.45)}
.btn-outline{background:transparent;color:#fff;border:2px solid #fff}
.btn-outline:hover{background:#fff;color:var(--c-secondary)}
.btn-dark{background:var(--c-secondary);color:#fff}
.btn-dark:hover{background:#0f1a2c;color:#fff;transform:translateY(-2px)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;font-size:1.6rem;color:var(--c-secondary)}

/* Hero */
.hero{
  position:relative;
  min-height:88vh;
  display:flex;align-items:center;
  background:linear-gradient(rgba(15,26,44,.72),rgba(15,26,44,.78)),url('../images/hero.jpg') center/cover no-repeat;
  color:#fff;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 20%,rgba(215,38,56,.25),transparent 60%);
  animation:pulse 8s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:.6}50%{opacity:1}}
.hero .container{position:relative;z-index:2}
.hero h1{color:#fff;margin-bottom:1.2rem;animation:fadeUp 1s ease both}
.hero .lead{font-size:1.2rem;max-width:640px;margin-bottom:2rem;color:#e5e7eb;animation:fadeUp 1.2s ease both}
.hero .actions{display:flex;gap:16px;flex-wrap:wrap;animation:fadeUp 1.4s ease both}
.hero .badges{display:flex;gap:18px;margin-top:3rem;flex-wrap:wrap;animation:fadeUp 1.6s ease both}
.hero .badge{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.2);
  padding:10px 18px;border-radius:30px;font-size:.85rem;
  backdrop-filter:blur(6px);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* Sections */
section{padding:80px 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 50px}
.section-head .eyebrow{
  display:inline-block;color:var(--c-primary);
  text-transform:uppercase;letter-spacing:2px;font-size:.85rem;font-weight:600;margin-bottom:.6rem;
}
.section-head p{color:var(--c-muted);font-size:1.05rem}

/* Reveal */
.reveal{opacity:0;transform:translateY(40px);transition:all .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Services grid */
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.grid-4{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}

.card{
  background:#fff;border-radius:var(--radius);padding:32px 26px;
  box-shadow:var(--shadow-sm);transition:all var(--transition);
  border:1px solid var(--c-border);position:relative;overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;width:100%;height:4px;
  background:linear-gradient(90deg,var(--c-primary),var(--c-accent));
  transform:scaleX(0);transform-origin:left;transition:transform .4s ease;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .icon{
  width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,#fee2e2,#fef3c7);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--c-primary);
  font-size:1.5rem;
}
.card h3{color:var(--c-secondary)}
.card p{font-size:.95rem;color:#4b5563;margin-bottom:0}

/* Image cards */
.img-card{
  position:relative;overflow:hidden;border-radius:var(--radius);
  box-shadow:var(--shadow-sm);
}
.img-card img{aspect-ratio:4/3;object-fit:cover;width:100%;transition:transform .6s ease}
.img-card:hover img{transform:scale(1.08)}
.img-card .overlay{
  position:absolute;inset:0;background:linear-gradient(to top,rgba(15,26,44,.85),transparent 60%);
  display:flex;align-items:flex-end;padding:20px;color:#fff;
}
.img-card .overlay h4{color:#fff;font-family:'Playfair Display',serif;font-size:1.2rem}

/* About / split */
.split{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;aspect-ratio:4/3;object-fit:cover}
.split .stats{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:24px}
.stat{background:#fff;padding:18px;border-radius:var(--radius);text-align:center;box-shadow:var(--shadow-sm)}
.stat .num{font-family:'Playfair Display',serif;font-size:2rem;color:var(--c-primary);font-weight:700}
.stat .lbl{font-size:.85rem;color:var(--c-muted);text-transform:uppercase;letter-spacing:1px}

/* Banner / CTA */
.cta-banner{
  background:linear-gradient(135deg,var(--c-secondary),#0a1422);
  color:#fff;padding:70px 30px;border-radius:var(--radius);text-align:center;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;inset:0;
  background:url('../images/garage3.jpg') center/cover no-repeat;
  opacity:.15;
}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h2{color:#fff;margin-bottom:1rem}
.cta-banner p{color:#cbd5e1;max-width:600px;margin:0 auto 2rem}

/* Testimonials */
.testimonial{
  background:#fff;padding:32px;border-radius:var(--radius);
  box-shadow:var(--shadow-sm);position:relative;
}
.testimonial::before{
  content:"\201C";position:absolute;top:-10px;left:20px;
  font-family:'Playfair Display',serif;font-size:5rem;color:var(--c-primary);
  line-height:1;opacity:.2;
}
.testimonial p{font-style:italic;color:#374151}
.testimonial .author{margin-top:14px;font-weight:600;color:var(--c-secondary)}
.testimonial .stars{color:var(--c-accent);margin-bottom:8px;letter-spacing:2px}

/* FAQ */
.faq-item{
  background:#fff;border:1px solid var(--c-border);border-radius:var(--radius);
  margin-bottom:14px;overflow:hidden;
}
.faq-q{
  padding:20px 24px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  font-weight:600;color:var(--c-secondary);user-select:none;
}
.faq-q:hover{background:#f9fafb}
.faq-a{padding:0 24px;max-height:0;overflow:hidden;transition:all .35s ease;color:#4b5563}
.faq-item.open .faq-a{padding:0 24px 20px;max-height:400px}
.faq-q .arrow{transition:transform .35s ease}
.faq-item.open .faq-q .arrow{transform:rotate(180deg)}

/* Forms */
.form{
  background:#fff;padding:36px;border-radius:var(--radius);box-shadow:var(--shadow-md);
}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{display:block;font-weight:500;margin-bottom:6px;color:var(--c-secondary);font-size:.9rem}
.form input,.form textarea,.form select{
  width:100%;padding:12px 14px;border:1px solid var(--c-border);border-radius:8px;
  font-family:inherit;font-size:.95rem;margin-bottom:16px;
  transition:border var(--transition),box-shadow var(--transition);
}
.form input:focus,.form textarea:focus,.form select:focus{
  outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(215,38,56,.15);
}
.form textarea{min-height:130px;resize:vertical}

/* Footer */
.footer{background:#0a1422;color:#cbd5e1;padding:60px 0 20px;margin-top:60px}
.footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:1rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:18px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer a{color:#cbd5e1;display:block;padding:5px 0;font-size:.92rem}
.footer a:hover{color:var(--c-primary)}
.footer .social{display:flex;gap:12px;margin-top:14px}
.footer .social a{
  width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;padding:0;
}
.footer .social a:hover{background:var(--c-primary);color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;
  font-size:.85rem;color:#94a3b8;
}

/* Cookie banner */
.cookie-banner{
  position:fixed;bottom:20px;left:20px;right:20px;max-width:520px;
  background:var(--c-secondary);color:#fff;padding:22px 24px;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);z-index:9999;
  transform:translateY(150%);transition:transform .5s ease;
}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner h4{color:#fff;font-family:'Inter',sans-serif;font-size:1rem;margin-bottom:8px}
.cookie-banner p{font-size:.88rem;color:#cbd5e1;margin-bottom:14px}
.cookie-banner .actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-banner .btn{padding:9px 18px;font-size:.85rem}

/* Page hero (subpages) */
.page-hero{
  background:linear-gradient(rgba(15,26,44,.78),rgba(15,26,44,.82)),url('../images/garage2.jpg') center/cover no-repeat;
  color:#fff;padding:90px 0 70px;text-align:center;
}
.page-hero h1{color:#fff;margin-bottom:.6rem}
.page-hero .crumbs{color:#cbd5e1;font-size:.9rem}
.page-hero .crumbs a{color:#fff}

/* Prose */
.prose{max-width:820px;margin:0 auto}
.prose h2{margin-top:2rem;margin-bottom:1rem;font-size:1.6rem}
.prose h3{margin-top:1.5rem}
.prose ul,.prose ol{margin:1rem 0 1.4rem 1.4rem}
.prose li{margin-bottom:.4rem}

/* Back to top */
.to-top{
  position:fixed;bottom:24px;right:24px;width:46px;height:46px;border-radius:50%;
  background:var(--c-primary);color:#fff;display:flex;align-items:center;justify-content:center;
  cursor:pointer;border:none;box-shadow:var(--shadow-md);opacity:0;visibility:hidden;
  transition:all var(--transition);z-index:998;font-size:1.2rem;
}
.to-top.show{opacity:1;visibility:visible}
.to-top:hover{background:var(--c-primary-dark);transform:translateY(-3px)}

/* Mobile */
@media(max-width:860px){
  .nav{
    position:fixed;top:0;right:-100%;width:280px;height:100vh;
    background:#fff;box-shadow:var(--shadow-lg);
    flex-direction:column;padding:80px 30px;
    transition:right .35s ease;z-index:999;
  }
  .nav.open{right:0}
  .nav ul{flex-direction:column;gap:18px}
  .menu-toggle{display:block;z-index:1001;position:relative}
  .topbar .info span{display:block;margin:2px 0}
  .split{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  section{padding:60px 0}
}
@media(max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .hero{min-height:78vh}
}
