:root {
  --maroon: #6B2737;
  --maroon-dark: #4a1a26;
  --maroon-light: #8a3347;
  --orange: #C85A2A;
  --orange-light: #e06832;
  --cream: #FAF7F2;
  --white: #FFFFFF;
  --text-dark: #2C1810;
  --text-mid: #5a3525;
  --text-light: #5a3d30;
  --border: #e8ddd4;
  --shadow: 0 2px 12px rgba(44,24,16,0.08);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  background: var(--cream);
  color: var(--text-dark);
  font-family: 'Source Serif 4', Georgia, serif;
  font-size: 16px;
  line-height: 1.7;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--maroon); text-decoration: none; transition: color 0.25s; }
a:hover { color: var(--orange); }

h1, h2, h3, h4 { font-family: 'Playfair Display', Georgia, serif; line-height: 1.15; color: var(--maroon); }
h1 { font-size: clamp(2.2rem, 6vw, 3.8rem); font-weight: 900; }
h2 { font-size: clamp(1.6rem, 4vw, 2.4rem); font-weight: 700; }
.intro-text h2 { font-size: clamp(1.2rem, 2vw, 1.6rem); }
.about-story h2 { font-size: clamp(1.4rem, 2.5vw, 1.8rem); }
h3 { font-size: clamp(1.1rem, 2.5vw, 1.35rem); font-weight: 700; }
p { margin-bottom: 1rem; color: var(--text-mid); }
p:last-child { margin-bottom: 0; }

.container { max-width: 1060px; margin: 0 auto; padding: 0 1.5rem; }
.section { padding: 4rem 0; }
.section-alt { background: var(--white); }

.divider { display: flex; align-items: center; gap: 1rem; margin-bottom: 2.5rem; }
.divider::before, .divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }
.divider-text { font-size: 0.7rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--orange); font-weight: 600; white-space: nowrap; font-family: 'Source Serif 4', serif; }

/* TOP BANNER */
.top-banner { background: var(--maroon); color: rgba(250,247,242,0.85); text-align: center; padding: 0.55rem 1rem; font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 600; }
.top-banner span { color: var(--orange-light); }

/* NAV */
nav { background: var(--white); border-bottom: 2px solid var(--border); position: sticky; top: 0; z-index: 100; box-shadow: var(--shadow); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 0.9rem 1.5rem; max-width: 1060px; margin: 0 auto; }
.nav-logo { display: flex; flex-direction: column; line-height: 1; }
.nav-logo-main { font-family: 'Cinzel', serif; font-size: 1.6rem; font-weight: 900; color: var(--maroon); letter-spacing: 0.05em; }
.nav-logo-sub { font-size: 0.6rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--orange); font-weight: 600; margin-top: 0.1rem; }
.nav-links { display: flex; gap: 2rem; list-style: none; align-items: center; }
.nav-links a { font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600; color: var(--text-dark); padding-bottom: 2px; border-bottom: 2px solid transparent; transition: all 0.25s; font-family: 'Source Serif 4', serif; }
.nav-links a:hover, .nav-links a.active { color: var(--maroon); border-bottom-color: var(--orange); }
.nav-cta { background: var(--maroon) !important; color: white !important; padding: 0.5rem 1.25rem !important; border-bottom: none !important; }
.nav-cta:hover { background: var(--orange) !important; color: white !important; }
.nav-toggle { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 4px; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--maroon); }

/* HERO */
.hero { background: var(--maroon); color: var(--cream); position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, transparent, transparent 30px, rgba(255,255,255,0.015) 30px, rgba(255,255,255,0.015) 31px); }
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; max-width: 1060px; margin: 0 auto; padding: 4rem 1.5rem 3rem; position: relative; z-index: 1; }
.hero-shop-name { font-family: 'Cinzel', serif !important; font-size: clamp(2.8rem, 7vw, 4.5rem) !important; color: white !important; line-height: 1 !important; margin-bottom: 0.3em !important; letter-spacing: 0.05em; }
.hero-shop-name span { font-family: 'Source Serif 4', serif; font-size: 0.42em; letter-spacing: 0.25em; text-transform: uppercase; color: var(--orange-light); display: block; font-weight: 400; margin-top: 0.25em; }
.hero-tagline { font-size: clamp(0.95rem, 2vw, 1.1rem); color: rgba(250,247,242,0.88); margin-bottom: 0.75rem; font-style: italic; font-weight: 300; }
.hero-sub { font-size: clamp(0.95rem, 1.8vw, 1.08rem); color: rgba(250,247,242,0.9); max-width: 480px; margin-bottom: 1.75rem; font-weight: 300; line-height: 1.7; }
.hero-landline-note { font-size: 0.82rem; color: rgba(250,247,242,0.78); margin-top: 0.75rem; letter-spacing: 0.05em; font-style: italic; }
.hero-image img { width: 100%; height: 420px; object-fit: cover; object-position: center; display: block; border: 3px solid rgba(200,90,42,0.4); }
.hero-stats { background: rgba(0,0,0,0.25); border-top: 1px solid rgba(255,255,255,0.1); padding: 1.5rem 0; position: relative; z-index: 1; }
.hero-since { display: flex; align-items: center; gap: 2rem; flex-wrap: wrap; max-width: 1060px; margin: 0 auto; padding: 0 1.5rem; }
.hero-since-item { display: flex; flex-direction: column; }
.hero-since-number { font-family: 'Cinzel', serif; font-size: 2rem; font-weight: 900; color: var(--orange-light); line-height: 1; }
.hero-since-label { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: rgba(250,247,242,0.55); margin-top: 0.2rem; }
.hero-since-divider { width: 1px; height: 40px; background: rgba(255,255,255,0.15); }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.75rem 1.75rem; font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600; font-family: 'Source Serif 4', serif; cursor: pointer; transition: all 0.25s; border: none; }
.btn-primary { background: var(--orange); color: white; }
.btn-primary:hover { background: var(--orange-light); color: white; }
.btn-outline { background: transparent; color: white; border: 1px solid rgba(255,255,255,0.4); }
.btn-outline:hover { border-color: white; background: rgba(255,255,255,0.1); color: white; }

/* INTRO */
.intro-grid { display: grid; grid-template-columns: 3fr 2fr; gap: 4rem; align-items: end; }
.intro-quote { background: var(--maroon); color: var(--cream); padding: 1.5rem; position: relative; align-self: end; max-width: 380px; margin-left: auto; }
.intro-quote::before { content: '"'; font-family: 'Playfair Display', serif; font-size: 3rem; color: var(--orange); opacity: 0.3; position: absolute; top: -0.15rem; left: 1rem; line-height: 1; }
.intro-quote-text { font-size: 0.92rem; font-style: italic; color: var(--cream); line-height: 1.6; position: relative; z-index: 1; margin-bottom: 0.75rem !important; }
.intro-quote-attr { font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--orange-light); font-weight: 600; }

/* WORK GRID */
.work-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.75rem; }
.work-item { position: relative; overflow: hidden; background: var(--maroon-dark); }
.work-item img { width: 100%; height: 210px; object-fit: cover; object-position: center; display: block; transition: transform 0.4s ease; }
.work-item:hover img { transform: scale(1.05); }
.work-item-large { grid-column: span 2; }
.work-item-large img { height: 300px; }
.work-overlay { position: absolute; bottom: 0; left: 0; right: 0; background: linear-gradient(transparent, rgba(74,26,38,0.92)); padding: 1.5rem 1rem 0.75rem; transform: translateY(100%); transition: transform 0.3s ease; }
.work-item:hover .work-overlay { transform: translateY(0); }
.work-overlay span { font-size: 0.75rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--orange-light); font-weight: 600; font-family: 'Source Serif 4', serif; }

/* SERVICES */
.specialty-card { grid-column: 1 / -1; background: var(--maroon); border: none; border-left: 4px solid var(--orange); padding: 1.5rem 2rem; display: flex; align-items: center; gap: 1.5rem; }
.specialty-card h3 { color: white; margin-bottom: 0.3rem; }
.specialty-card p { color: rgba(250,247,242,0.75); font-size: 0.88rem; margin: 0; }
.specialty-icon { font-size: 1.5rem; color: var(--orange-light); flex-shrink: 0; }

/* ITALIC FINE PRINT — improved readability for helper/disclaimer text */
p[style*="font-style:italic"], p[style*="font-style: italic"],
.section p[style*="italic"], .section em,
p.fine-print { font-size: 0.9rem !important; color: var(--text-mid) !important; }

/* SERVICES BULLET GRID */
.services-bullet-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 0.5rem 2rem; margin-bottom: 1.25rem; }

/* WHY GRID */
.why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.why-item { background: var(--cream); border: 1px solid var(--border); padding: 1.5rem; display: flex; gap: 1rem; }
.why-number { font-family: 'Cinzel', serif; font-size: 2.5rem; font-weight: 900; color: var(--orange); opacity: 0.4; line-height: 1; flex-shrink: 0; }
.why-item h3 { font-size: 1rem; margin-bottom: 0.4rem; }
.why-item p { font-size: 0.85rem; margin: 0; }

/* CTA BAND */
.cta-band { background: var(--maroon); padding: 4rem 0; text-align: center; }
.cta-band h2 { color: white; margin-bottom: 0.5rem; }
.cta-band p { color: rgba(250,247,242,0.7); font-size: 1.05rem; margin-bottom: 2rem; }
.cta-phone { font-family: 'Cinzel', serif; font-size: clamp(2rem, 6vw, 3rem); font-weight: 900; color: white; display: block; margin-bottom: 1.5rem; transition: color 0.25s; }
.cta-phone:hover { color: var(--orange-light); }
.cta-address { font-size: 0.88rem; color: rgba(250,247,242,0.88); letter-spacing: 0.05em; margin-top: 1rem; }

/* SERVICE AREA */
.service-area-band { background: var(--orange); padding: 1rem 0; text-align: center; }
.service-area-band p { font-size: 0.72rem; letter-spacing: 0.25em; text-transform: uppercase; font-weight: 600; color: white; margin: 0; }

/* GALLERY */
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.gallery-item { position: relative; overflow: hidden; background: var(--maroon-dark); }
.gallery-item img { width: 100%; height: 220px; object-fit: cover; display: block; transition: transform 0.4s ease; }
.gallery-item:hover img { transform: scale(1.05); }
.gallery-caption { background: var(--maroon); color: var(--cream); padding: 0.5rem 0.75rem; font-size: 0.75rem; letter-spacing: 0.1em; font-weight: 600; }

/* PAGE HEADER */
.page-header { background: var(--maroon); padding: 1.75rem 0; position: relative; overflow: hidden; }
.page-header::before { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, transparent, transparent 30px, rgba(255,255,255,0.015) 30px, rgba(255,255,255,0.015) 31px); }
.page-header-inner { position: relative; z-index: 1; max-width: 1060px; margin: 0 auto; padding: 0 1.5rem; }
.page-header h1 { color: white; margin-bottom: 0.2em; }
.page-header p { color: rgba(250,247,242,0.75); font-size: 0.95rem; margin: 0; max-width: 600px; }
.breadcrumb { font-size: 0.7rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--orange-light); margin-bottom: 0.75rem; font-weight: 600; }
.breadcrumb a { color: rgba(250,247,242,0.4); }

/* CONTACT */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
.contact-info-item { display: flex; gap: 1rem; margin-bottom: 1.5rem; align-items: flex-start; }
.contact-info-icon { width: 40px; height: 40px; background: var(--maroon); color: white; display: flex; align-items: center; justify-content: center; font-size: 1rem; flex-shrink: 0; }
.contact-info-text h4 { color: var(--maroon); margin-bottom: 0.2rem; font-size: 0.85rem; letter-spacing: 0.05em; }
.contact-info-text p { font-size: 0.9rem; margin: 0; line-height: 1.5; }
.contact-info-text a { font-size: 1.2rem; font-family: 'Cinzel', serif; font-weight: 700; color: var(--maroon); }
.hours-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; margin-top: 1rem; }
.hours-table td { padding: 0.5rem 0; border-bottom: 1px solid var(--border); color: var(--text-mid); }
.hours-table td:first-child { font-weight: 600; color: var(--text-dark); width: 40%; }
.quote-policy { background: var(--maroon); color: var(--cream); padding: 2rem; margin-top: 2rem; border-left: 4px solid var(--orange); }
.quote-policy h3 { color: white !important; margin-bottom: 0.75rem; font-size: 1.05rem; }
.quote-policy p { color: rgba(250,247,242,0.85) !important; font-size: 0.88rem; margin: 0; line-height: 1.7; }

/* ABOUT */
.about-story { display: grid; grid-template-columns: 3fr 2fr; gap: 2.5rem; align-items: start; }
.about-story > div:last-child { align-self: start; }
.cliftons-difference { background: #6B2737; padding: 1.5rem; }
.cliftons-difference-label { font-size: 0.72rem; letter-spacing: 0.3em; text-transform: uppercase; color: #e06832; font-weight: 600; margin-bottom: 0.75rem; display: block; }
.cliftons-difference-quote { color: #FAF7F2 !important; font-size: 0.88rem; line-height: 1.65; font-style: italic; margin-bottom: 0 !important; }
.timeline { display: flex; flex-direction: column; gap: 0; margin-top: 2rem; }
.timeline-item { display: flex; gap: 1.5rem; padding-bottom: 1.5rem; position: relative; }
.timeline-item::before { content: ''; position: absolute; left: 2rem; top: 2rem; bottom: 0; width: 1px; background: var(--border); }
.timeline-item:last-child::before { display: none; }
.timeline-year { font-family: 'Cinzel', serif; font-size: 0.9rem; font-weight: 700; color: var(--orange); min-width: 4rem; padding-top: 0.1rem; }
.timeline-content h4 { color: var(--maroon); margin-bottom: 0.25rem; }
.timeline-content p { font-size: 0.85rem; margin: 0; }

/* FOOTER */
footer { background: var(--maroon-dark); color: rgba(250,247,242,0.6); padding: 3rem 0 2rem; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 3rem; margin-bottom: 2rem; }
.footer-brand-name { font-family: 'Cinzel', serif; font-size: 1.3rem; font-weight: 900; color: white; display: block; margin-bottom: 0.25rem; }
.footer-brand-sub { font-size: 0.6rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--orange-light); font-weight: 600; display: block; margin-bottom: 1rem; }
.footer-desc { font-size: 0.85rem; line-height: 1.6; color: rgba(250,247,242,0.85); margin: 0; }
.footer-heading { font-size: 0.65rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--orange-light); font-weight: 600; margin-bottom: 1rem; font-family: 'Source Serif 4', serif; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 0.5rem; }
.footer-links a { font-size: 0.85rem; color: rgba(250,247,242,0.88); }
.footer-links a:hover { color: var(--orange-light); }
.footer-contact-item { font-size: 0.85rem; color: rgba(250,247,242,0.85); margin-bottom: 0.5rem; line-height: 1.5; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.08); padding-top: 1.5rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 0.5rem; font-size: 0.82rem; }
.footer-bottom a { color: rgba(250,247,242,0.4); }
.footer-bottom a:hover { color: var(--orange-light); }

/* RESPONSIVE */
@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-toggle { display: flex; }
  .nav-links.open { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background: white; padding: 1rem 1.5rem; border-top: 1px solid var(--border); gap: 1rem; box-shadow: var(--shadow); }
  .hero-inner { grid-template-columns: 1fr; padding: 2.5rem 1.5rem 2rem; gap: 2rem; }
  .hero-image { display: none; }
  .intro-grid, .about-story, .contact-grid { grid-template-columns: 1fr; gap: 2rem; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .work-item-large { grid-column: span 2; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .hero-since { gap: 1.5rem; }
  .specialty-card { flex-direction: column; gap: 0.75rem; }
  .services-bullet-grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .work-grid { grid-template-columns: 1fr; }
  .work-item-large { grid-column: span 1; }
  .gallery-grid { grid-template-columns: 1fr; }
  .section { padding: 2.5rem 0; }
}
