/* LAYOUT CLASSIC - Editorial, generous spacing, elegant */

.classic-hero { min-height: 90vh; display: flex; align-items: center; background: linear-gradient(180deg, var(--bg-secondary) 0%, var(--bg-primary) 100%); }
.classic-hero-inner { width: 100%; position: relative; }
.classic-hero-content { text-align: center; max-width: 800px; margin: 0 auto; padding: 6rem 2rem; }
.classic-ornament { font-size: 3rem; color: var(--brand-accent); margin-bottom: 1.5rem; }
.classic-hero-tagline { font-family: var(--font-body, 'Lora', serif); font-style: italic; font-size: 1.125rem; color: var(--text-secondary); margin-bottom: 1rem; }
.classic-hero-title { font-family: var(--font-heading, 'Playfair Display', serif); font-size: clamp(3rem, 6vw, 5rem); font-weight: 400; line-height: 1.1; color: var(--text-primary); margin-bottom: 1.5rem; }
.classic-hero-divider { width: 60px; height: 2px; background: var(--brand-accent); margin: 2rem auto; }
.classic-hero-subtitle { font-size: 1.125rem; color: var(--text-secondary); margin-bottom: 3rem; }
.classic-hero-cta { display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap; }

.btn-classic-primary { display: inline-flex; align-items: center; padding: 1rem 2.5rem; background: var(--brand-primary); color: var(--text-light); font-family: var(--font-body, 'Lora', serif); font-weight: 500; text-decoration: none; letter-spacing: 0.05em; transition: all 0.3s; }
.btn-classic-primary:hover { background: var(--brand-primary-dark); color: var(--text-light); }
.btn-classic-secondary { display: inline-flex; align-items: center; padding: 1rem 2.5rem; background: transparent; color: var(--brand-primary); border: 2px solid var(--brand-primary); font-family: var(--font-body, 'Lora', serif); font-weight: 500; text-decoration: none; letter-spacing: 0.05em; transition: all 0.3s; }
.btn-classic-secondary:hover { background: var(--brand-primary); color: var(--text-light); }

.classic-section { padding: 8rem 0; background: var(--bg-primary); }
.classic-bg-cream { background: var(--bg-secondary); }
.classic-section-header { text-align: center; margin-bottom: 4rem; }
.classic-header-left { text-align: left; }
.classic-section-label { display: block; font-family: var(--font-alt, 'Cinzel', serif); font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.2em; color: var(--brand-primary); margin-bottom: 1rem; }
.classic-section-title { font-family: var(--font-heading, 'Playfair Display', serif); font-size: clamp(2rem, 4vw, 3rem); font-weight: 400; color: var(--text-primary); }
.classic-section-footer { text-align: center; margin-top: 4rem; }
.classic-link { color: var(--brand-primary); text-decoration: none; border-bottom: 1px solid var(--brand-accent); padding-bottom: 0.25rem; transition: all 0.3s; }
.classic-link:hover { border-bottom-width: 2px; }

.classic-intro { max-width: 700px; margin: 0 auto; text-align: center; }
.classic-lead { font-family: var(--font-body, 'Lora', serif); font-size: 1.5rem; font-style: italic; line-height: 1.8; color: var(--text-secondary); }

.classic-services-list { max-width: 800px; margin: 0 auto; }
.classic-service-row { display: flex; justify-content: space-between; align-items: center; padding: 1.5rem 0; border-bottom: 1px solid var(--border-color); }
.classic-service-name { font-family: var(--font-heading, 'Playfair Display', serif); font-size: 1.25rem; font-weight: 400; margin-bottom: 0.25rem; }
.classic-service-desc { color: var(--text-secondary); font-size: 0.9rem; }
.classic-service-meta { text-align: right; }
.classic-service-price { display: block; font-family: var(--font-heading, 'Playfair Display', serif); font-size: 1.5rem; color: var(--brand-primary); }
.classic-service-time { font-size: 0.875rem; color: var(--text-muted); }

.classic-team-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 4rem; }
.classic-team-member { text-align: center; }
.classic-team-portrait { width: 200px; height: 200px; margin: 0 auto 1.5rem; border-radius: 50%; overflow: hidden; border: 3px solid var(--brand-accent); }
.classic-team-portrait img { width: 100%; height: 100%; object-fit: cover; }
.classic-team-initials { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: var(--bg-tertiary); font-family: var(--font-heading, 'Playfair Display', serif); font-size: 4rem; color: var(--text-muted); }
.classic-team-name { font-family: var(--font-heading, 'Playfair Display', serif); font-size: 1.5rem; margin-bottom: 0.5rem; }
.classic-team-role { color: var(--brand-primary); font-style: italic; margin-bottom: 1rem; }
.classic-team-bio { color: var(--text-secondary); font-size: 0.95rem; line-height: 1.7; max-width: 300px; margin: 0 auto; }

.classic-testimonial { text-align: center; max-width: 800px; margin: 0 auto; padding: 2rem; position: relative; }
.classic-quote-open, .classic-quote-close { font-family: var(--font-heading, 'Playfair Display', serif); font-size: 6rem; color: var(--brand-accent); line-height: 1; opacity: 0.3; }
.classic-quote-open { position: absolute; top: -1rem; left: 0; }
.classic-quote-close { position: absolute; bottom: -3rem; right: 0; }
.classic-quote { font-family: var(--font-body, 'Lora', serif); font-size: 1.75rem; font-style: italic; line-height: 1.7; color: var(--text-primary); position: relative; z-index: 1; }
.classic-testimonial-author { margin-top: 2rem; }
.classic-author-dash { color: var(--brand-accent); margin-right: 0.5rem; }
.classic-testimonial-author cite { font-style: normal; color: var(--text-secondary); }

.classic-contact-details { margin-top: 2rem; }
.classic-address { font-family: var(--font-body, 'Lora', serif); font-size: 1.25rem; font-style: italic; color: var(--text-secondary); margin-bottom: 2rem; }
.classic-contact-item { display: block; padding: 1rem 0; border-bottom: 1px solid var(--border-color); color: var(--text-primary); text-decoration: none; }
.classic-contact-label { display: block; font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); margin-bottom: 0.25rem; }
.classic-contact-value { font-size: 1.125rem; }
.classic-hours { margin-top: 2rem; }
.classic-hours p { color: var(--text-secondary); line-height: 1.8; }
.classic-contact-actions { display: flex; gap: 1rem; margin-top: 2rem; flex-wrap: wrap; }

.classic-shop-image { position: relative; border-radius: 4px; overflow: hidden; }
.classic-shop-image img { width: 100%; height: 500px; object-fit: cover; }
.classic-image-caption { position: absolute; bottom: 0; left: 0; right: 0; padding: 1.5rem; background: linear-gradient(transparent, rgba(0,0,0,0.7)); color: white; font-style: italic; }

@media (max-width: 991px) {
  .classic-service-row { flex-direction: column; text-align: center; gap: 1rem; }
  .classic-service-meta { text-align: center; }
  .classic-team-gallery { grid-template-columns: 1fr; }
  .classic-quote-open, .classic-quote-close { font-size: 4rem; }
}
