/* ---- Services Page Specific ---- */
.services-category { margin-bottom: 5rem; }
.category-header { display: flex; align-items: center; gap: 1.5rem; margin-bottom: 2.5rem; padding-bottom: 1rem; border-bottom: 1px solid var(--c-border); }
.category-icon { width: 56px; height: 56px; background: var(--c-rose-light); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--c-rose); font-size: 1.4rem; flex-shrink: 0; }
.category-header h2 { font-size: 2rem; }
.service-list { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.service-item { background: var(--c-sand); padding: 1.5rem; border-left: 3px solid var(--c-rose); transition: var(--trans); }
.service-item:hover { background: var(--c-rose-light); transform: translateX(4px); }
.service-item h4 { font-size: 1.1rem; margin-bottom: 0.35rem; }
.service-item p { font-size: 0.875rem; color: var(--c-muted); }
.service-price-tag { font-weight: 700; color: var(--c-rose); font-size: 0.9rem; margin-top: 0.25rem; }

/* ---- About Page Specific ---- */
.story-grid { display: grid; grid-template-columns: 1fr; gap: 4rem; align-items: center; }
.story-img { position: relative; }
.story-img img { border-radius: var(--radius-sm); }
.story-badge { position: absolute; bottom: -1.5rem; right: -1rem; background: var(--c-rose); color: white; padding: 1.5rem; text-align: center; border-radius: var(--radius-sm); }
.story-badge .num { font-family: var(--font-head); font-size: 2.5rem; font-weight: 700; line-height: 1; }
.story-badge .lbl { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 1px; opacity: 0.9; }
.achievement-card { background: var(--c-sand); padding: 2.5rem; border: 1px solid var(--c-border); text-align: center; border-radius: var(--radius-sm); }
.achievement-card i { font-size: 2rem; color: var(--c-gold); margin-bottom: 1rem; }
.achievement-card h3 { font-size: 1.3rem; margin-bottom: 0.5rem; }
.achievements-grid { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
.branches-list { display: grid; grid-template-columns: 1fr; gap: 1rem; }
.branch-item { background: var(--c-white); border: 1px solid var(--c-border); padding: 1.25rem 1.5rem; border-radius: var(--radius-sm); transition: var(--trans); }
.branch-item:hover { border-color: var(--c-rose); }
.branch-item h4 { font-size: 1rem; font-family: var(--font-body); font-weight: 600; margin-bottom: 0.35rem; color: var(--c-black); }
.branch-item p { font-size: 0.83rem; color: var(--c-muted); }

/* ---- Contact Page Specific ---- */
.contact-grid { display: grid; grid-template-columns: 1fr; gap: 4rem; }
.contact-info h2 { font-size: 2rem; margin-bottom: 1.5rem; }
.contact-info-items { display: flex; flex-direction: column; gap: 1.5rem; margin-bottom: 2.5rem; }
.ci-item { display: flex; gap: 1rem; align-items: flex-start; }
.ci-icon { width: 46px; height: 46px; background: var(--c-rose-light); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--c-rose); flex-shrink: 0; }
.ci-item h4 { font-size: 1rem; font-family: var(--font-body); font-weight: 600; margin-bottom: 0.25rem; }
.ci-item p { font-size: 0.875rem; color: var(--c-muted); }

/* Booking Form */
.booking-form-card { background: var(--c-sand); padding: 2.5rem; border-radius: var(--radius-sm); }
.booking-form-card h2 { font-size: 2rem; margin-bottom: 0.5rem; }
.booking-form-card p { font-size: 0.9rem; color: var(--c-muted); margin-bottom: 2rem; }
.form-row { display: grid; grid-template-columns: 1fr; gap: 1rem; margin-bottom: 1rem; }
.form-group { margin-bottom: 1rem; }
.form-group label { display: block; font-size: 0.82rem; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; color: var(--c-dark); margin-bottom: 0.4rem; }
.form-control {
    width: 100%;
    padding: 0.85rem 1.1rem;
    border: 1px solid var(--c-border);
    background: var(--c-white);
    color: var(--c-dark);
    font-family: var(--font-body);
    font-size: 0.95rem;
    transition: var(--trans);
    border-radius: var(--radius-sm);
}
.form-control:focus { outline: none; border-color: var(--c-rose); box-shadow: 0 0 0 3px rgba(201,132,122,0.15); }
textarea.form-control { resize: vertical; min-height: 120px; }
select.form-control { appearance: none; cursor: pointer; }

/* Map embed */
.map-embed { border-radius: var(--radius-sm); overflow: hidden; margin-top: 2.5rem; }
.map-embed iframe { width: 100%; height: 300px; display: block; border: none; }

/* Responsive additions */
@media (min-width: 640px) {
    .service-list { grid-template-columns: repeat(2, 1fr); }
    .achievements-grid { grid-template-columns: repeat(3, 1fr); }
    .form-row { grid-template-columns: 1fr 1fr; }
    .branches-list { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 768px) {
    .story-grid { grid-template-columns: 1fr 1fr; }
    .contact-grid { grid-template-columns: 5fr 7fr; }
    .branches-list { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 992px) {
    .service-list { grid-template-columns: repeat(3, 1fr); }
}

/* ---- FAQ Accordion ---- */
.faq-grid { display: flex; flex-direction: column; gap: 0.75rem; max-width: 850px; margin: 0 auto; }
.faq-item { background: var(--c-white); border: 1px solid var(--c-border); border-radius: var(--radius-sm); overflow: hidden; }
.faq-question {
    width: 100%; background: none; border: none;
    display: flex; justify-content: space-between; align-items: center;
    padding: 1.25rem 1.5rem; font-family: var(--font-body); font-size: 0.95rem;
    font-weight: 600; color: var(--c-dark); cursor: pointer; text-align: left;
    transition: var(--trans);
}
.faq-question:hover { color: var(--c-rose); }
.faq-question i { color: var(--c-rose); font-size: 0.85rem; flex-shrink: 0; margin-left: 1rem; transition: var(--trans); }
.faq-question.active { color: var(--c-rose); }
.faq-question.active i { transform: rotate(45deg); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s ease, padding 0.4s ease; }
.faq-answer.open { max-height: 300px; }
.faq-answer p { padding: 0 1.5rem 1.25rem; font-size: 0.9rem; color: var(--c-muted); line-height: 1.8; }

/* ---- Story content inline overrides ---- */
.story-content { padding-top: 2rem; }
