/*
 * ============================================================
 * FILE     : style.css
 * LOCATION : /assets/css/
 * PROJECT  : Asylum of Beauty – Nail Salon Management System
 * PURPOSE  : Public website design system. Bootstrap 5.3 base.
 *            Palette: ecru #F2EDE4 · charcoal #2D2D2D · white.
 *            Zero gold. WCAG 2.2 AA contrast throughout.
 * VERSION  : 3.0.0  2025-04-06  Full palette rewrite
 * ============================================================
 */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Jost:wght@300;400;500;600&display=swap');

/* ══════════════════════════════════════════════════════════════
   1. TOKENS
   ══════════════════════════════════════════════════════════════ */
:root {
    /* Core */
    --ab-bg:          #F2EDE4;   /* ecru page background          */
    --ab-bg-alt:      #EAE5DC;   /* deeper ecru – alt sections    */
    --ab-surface:     #FFFFFF;   /* cards, modals, inputs         */
    --ab-charcoal:    #2D2D2D;   /* primary dark accent           */
    --ab-charcoal-2:  #404040;   /* secondary dark                */
    --ab-charcoal-3:  #5A5A5A;   /* tertiary / muted on white     */
    --ab-border:      #D4CFC6;   /* warm grey border              */
    --ab-border-dark: #3A3A3A;   /* border on charcoal elements   */

    /* Text */
    --ab-text:        #1E1E1E;   /* 16:1 on white – AAA ✓         */
    --ab-text-inv:    #F2EDE4;   /* on charcoal backgrounds       */
    --ab-muted:       #6B6560;   /* 4.8:1 on white – AA ✓         */

    /* No gold – charcoal is the only accent */
    --ab-accent:      #2D2D2D;
    --ab-accent-2:    #4A4A4A;
    --ab-accent-pale: rgba(45,45,45,.07);

    /* Typography */
    --ab-ff-serif:    'Cormorant Garamond', Georgia, serif;
    --ab-ff-sans:     'Jost', system-ui, -apple-system, sans-serif;

    /* Layout */
    --ab-section-py:    5rem;
    --ab-section-py-sm: 3rem;
    --ab-radius-xs:     .375rem;
    --ab-radius-sm:     .5rem;
    --ab-radius:        .75rem;
    --ab-radius-lg:     1.25rem;

    /* Shadows – neutral */
    --ab-shadow-sm: 0 1px 4px rgba(0,0,0,.06);
    --ab-shadow:    0 3px 16px rgba(0,0,0,.08);
    --ab-shadow-lg: 0 8px 32px rgba(0,0,0,.10);
}

/* ══════════════════════════════════════════════════════════════
   2. BASE
   ══════════════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 70px; }
body {
    font-family: var(--ab-ff-sans);
    font-size: 1rem; line-height: 1.7;
    color: var(--ab-text);
    background: var(--ab-bg);
    -webkit-font-smoothing: antialiased;
}
h1,h2,h3,h4,h5 {
    font-family: var(--ab-ff-serif);
    font-weight: 500; color: var(--ab-charcoal); line-height: 1.25;
}
a { color: var(--ab-charcoal); }
a:hover { color: var(--ab-charcoal-2); }
:focus-visible { outline: 2px solid var(--ab-charcoal); outline-offset: 3px; border-radius: 3px; }

/* ══════════════════════════════════════════════════════════════
   3. NAVBAR
   ══════════════════════════════════════════════════════════════ */
.ab-navbar {
    background: var(--ab-surface);
    border-bottom: 1px solid var(--ab-border);
    padding: .75rem 0;
}
.ab-brand {
    font-family: var(--ab-ff-serif);
    font-size: 1.35rem; font-weight: 500;
    color: var(--ab-charcoal) !important;
    text-decoration: none; letter-spacing: .03em;
}
.ab-brand-name { color: var(--ab-charcoal); }
.ab-nav-link {
    font-size: .875rem; font-weight: 400;
    color: var(--ab-muted) !important;
    text-decoration: none; letter-spacing: .02em;
    padding: .4rem .85rem !important;
    border-radius: var(--ab-radius-xs);
    transition: color .15s, background .15s;
}
.ab-nav-link:hover  { color: var(--ab-charcoal) !important; background: var(--ab-bg-alt); }
.ab-nav-link.active { color: var(--ab-charcoal) !important; font-weight: 500; }

/* Hamburger icon */
.ab-nav-toggler {
    background: none; border: none; cursor: pointer;
    color: var(--ab-charcoal); font-size: 1.25rem; padding: .25rem;
}

/* ══════════════════════════════════════════════════════════════
   4. BUTTONS
   ══════════════════════════════════════════════════════════════ */
.btn-ab-primary, .btn-ab-gold {
    background: var(--ab-charcoal);
    border: 1.5px solid var(--ab-charcoal);
    color: var(--ab-text-inv) !important;
    font-family: var(--ab-ff-sans); font-weight: 500;
    border-radius: var(--ab-radius-xs);
    padding: .65rem 1.75rem;
    transition: background .15s, transform .1s;
    display: inline-block; text-decoration: none; cursor: pointer;
}
.btn-ab-primary:hover, .btn-ab-gold:hover {
    background: var(--ab-charcoal-2);
    border-color: var(--ab-charcoal-2);
    color: var(--ab-text-inv) !important;
    transform: translateY(-1px);
}
.btn-ab-secondary {
    background: transparent;
    border: 1.5px solid var(--ab-charcoal);
    color: var(--ab-charcoal) !important;
    font-family: var(--ab-ff-sans); font-weight: 500;
    border-radius: var(--ab-radius-xs);
    padding: .65rem 1.75rem;
    transition: background .15s, color .15s;
    display: inline-block; text-decoration: none; cursor: pointer;
}
.btn-ab-secondary:hover { background: var(--ab-charcoal); color: var(--ab-text-inv) !important; }
.btn-ab-ghost {
    background: transparent; border: none;
    color: var(--ab-muted); font-size: .875rem;
    padding: .4rem .75rem; border-radius: var(--ab-radius-xs);
    transition: background .15s, color .15s; cursor: pointer;
}
.btn-ab-ghost:hover { background: var(--ab-bg-alt); color: var(--ab-charcoal); }

/* ══════════════════════════════════════════════════════════════
   5. HERO
   ══════════════════════════════════════════════════════════════ */
.ab-hero {
    background: var(--ab-charcoal);
    color: var(--ab-text-inv);
    padding: 5rem 0 4rem;
    position: relative; overflow: hidden;
}
.ab-hero__title {
    font-family: var(--ab-ff-serif);
    font-size: clamp(2.5rem, 6vw, 4.5rem);
    font-weight: 500; line-height: 1.1;
    color: var(--ab-text-inv); margin-bottom: 1.25rem;
}
.ab-hero__title em { font-style: italic; color: var(--ab-bg); }
.ab-hero__sub {
    font-size: 1.05rem; color: rgba(242,237,228,.7);
    max-width: 520px; line-height: 1.7; margin-bottom: 2.5rem;
}
.ab-hero__img {
    border-radius: var(--ab-radius-lg);
    box-shadow: var(--ab-shadow-lg);
    width: 100%; object-fit: cover; aspect-ratio: 4/5; display: block;
}
.ab-hero__badge {
    display: inline-flex; align-items: center; gap: .5rem;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.15);
    border-radius: 2rem; padding: .4rem 1rem;
    font-size: .8rem; color: rgba(242,237,228,.8);
    margin-bottom: 1.5rem;
}

/* ══════════════════════════════════════════════════════════════
   6. SECTIONS
   ══════════════════════════════════════════════════════════════ */
.ab-section     { padding: var(--ab-section-py) 0; }
.ab-section--alt  { background: var(--ab-bg-alt); }
.ab-section--dark { background: var(--ab-charcoal); color: var(--ab-text-inv); }

.ab-section-label {
    font-size: .7rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: .14em;
    color: var(--ab-muted); margin-bottom: .75rem;
}
.ab-section-title {
    font-family: var(--ab-ff-serif);
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 500; color: var(--ab-charcoal);
    line-height: 1.15; margin-bottom: 1rem;
}
.ab-section-lead {
    font-size: 1.05rem; color: var(--ab-muted);
    max-width: 580px; margin-bottom: 2.5rem;
}
.ab-section--dark .ab-section-title { color: var(--ab-text-inv); }
.ab-section--dark .ab-section-label { color: rgba(242,237,228,.45); }
.ab-section--dark .ab-section-lead  { color: rgba(242,237,228,.65); }

/* ══════════════════════════════════════════════════════════════
   7. CARDS
   ══════════════════════════════════════════════════════════════ */
.ab-card {
    background: var(--ab-surface);
    border: 1px solid var(--ab-border);
    border-radius: var(--ab-radius);
    box-shadow: var(--ab-shadow-sm);
    overflow: hidden;
    transition: box-shadow .2s, transform .2s;
}
.ab-card:hover { box-shadow: var(--ab-shadow); transform: translateY(-2px); }
.ab-card__img  { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.ab-card__body { padding: 1.5rem; }
.ab-card__title { font-family: var(--ab-ff-serif); font-size: 1.25rem; font-weight: 500; color: var(--ab-charcoal); margin-bottom: .5rem; }
.ab-card__text  { color: var(--ab-muted); font-size: .9rem; }

.ab-service-card {
    background: var(--ab-surface);
    border: 1px solid var(--ab-border);
    border-radius: var(--ab-radius);
    padding: 1.75rem 1.5rem;
    box-shadow: var(--ab-shadow-sm);
    transition: box-shadow .2s, transform .2s; height: 100%;
}
.ab-service-card:hover { box-shadow: var(--ab-shadow); transform: translateY(-2px); }
.ab-service-icon {
    width: 48px; height: 48px;
    background: var(--ab-bg-alt);
    border: 1px solid var(--ab-border);
    border-radius: var(--ab-radius-xs);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: var(--ab-charcoal); margin-bottom: 1.1rem;
}

/* ══════════════════════════════════════════════════════════════
   8. PRICE LIST
   ══════════════════════════════════════════════════════════════ */
.ab-price-cat {
    font-family: var(--ab-ff-serif); font-size: 1.3rem; font-weight: 500;
    color: var(--ab-charcoal);
    padding-bottom: .6rem;
    border-bottom: 1.5px solid var(--ab-charcoal);
    margin-bottom: 1rem; margin-top: 2rem;
}
.ab-price-row {
    display: flex; align-items: baseline;
    justify-content: space-between; gap: 1rem;
    padding: .65rem 0; border-bottom: 1px solid var(--ab-border);
    font-size: .9rem;
}
.ab-price-row:last-child { border-bottom: none; }
.ab-price-name   { color: var(--ab-text); flex: 1; }
.ab-price-note   { color: var(--ab-muted); font-size: .8rem; margin-top: .15rem; }
.ab-price-amount { font-weight: 600; color: var(--ab-charcoal); white-space: nowrap; }
/* Alias used in some pages */
.ab-body { color: var(--ab-text); }

/* ══════════════════════════════════════════════════════════════
   9. BOOKING FORM
   ══════════════════════════════════════════════════════════════ */
.ab-form-label {
    font-size: .78rem; font-weight: 500;
    color: var(--ab-charcoal); letter-spacing: .02em;
    margin-bottom: .35rem; display: block;
}
.ab-form-control {
    width: 100%; background: var(--ab-surface);
    border: 1.5px solid var(--ab-border);
    border-radius: var(--ab-radius-xs);
    padding: .65rem 1rem;
    font-family: var(--ab-ff-sans); font-size: .9rem; color: var(--ab-text);
    outline: none; transition: border-color .15s, box-shadow .15s;
}
.ab-form-control:focus {
    border-color: var(--ab-charcoal);
    box-shadow: 0 0 0 3px rgba(45,45,45,.12);
}
.ab-form-control::placeholder { color: var(--ab-muted); }

/* Step indicator */
.ab-step { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; }
.ab-step__num {
    width: 32px; height: 32px;
    background: var(--ab-bg-alt); border: 1.5px solid var(--ab-border);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-size: .8rem; font-weight: 600; color: var(--ab-muted); flex-shrink: 0;
    transition: background .2s, border-color .2s, color .2s;
}
.ab-step__num.active { background: var(--ab-charcoal); border-color: var(--ab-charcoal); color: var(--ab-text-inv); }
.ab-step__num.done   { background: var(--ab-charcoal-2); border-color: var(--ab-charcoal-2); color: var(--ab-text-inv); }
.ab-step__label       { font-size: .82rem; color: var(--ab-muted); }
.ab-step__label.active { color: var(--ab-charcoal); font-weight: 500; }

/* Service chips */
.ab-chip {
    display: inline-flex; align-items: center;
    padding: .45rem 1rem;
    background: var(--ab-bg-alt); border: 1.5px solid var(--ab-border);
    border-radius: 2rem; font-size: .85rem;
    cursor: pointer; transition: all .15s; user-select: none;
}
.ab-chip:hover    { background: var(--ab-surface); border-color: var(--ab-charcoal); }
.ab-chip.selected { background: var(--ab-charcoal); border-color: var(--ab-charcoal); color: var(--ab-text-inv); }

/* ══════════════════════════════════════════════════════════════
   10. FAQ
   ══════════════════════════════════════════════════════════════ */
.ab-faq .accordion-item  { background: var(--ab-surface); border: 1px solid var(--ab-border); border-radius: var(--ab-radius) !important; margin-bottom: .5rem; overflow: hidden; }
.ab-faq .accordion-button { background: var(--ab-surface); color: var(--ab-text); font-weight: 500; box-shadow: none; padding: 1.1rem 1.25rem; }
.ab-faq .accordion-button:not(.collapsed) { background: var(--ab-bg-alt); color: var(--ab-charcoal); box-shadow: none; }
.ab-faq .accordion-body  { padding: 1rem 1.25rem 1.25rem; color: var(--ab-muted); font-size: .9rem; }

/* ══════════════════════════════════════════════════════════════
   11. GALLERY
   ══════════════════════════════════════════════════════════════ */
.ab-gallery-item { position: relative; overflow: hidden; border-radius: var(--ab-radius); aspect-ratio: 1; cursor: pointer; }
.ab-gallery-item img  { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; display: block; }
.ab-gallery-item:hover img { transform: scale(1.04); }
.ab-gallery-overlay { position: absolute; inset: 0; background: rgba(45,45,45,0); transition: background .3s; display: flex; align-items: flex-end; padding: 1rem; }
.ab-gallery-item:hover .ab-gallery-overlay { background: rgba(45,45,45,.5); }

/* ══════════════════════════════════════════════════════════════
   12. CONTACT
   ══════════════════════════════════════════════════════════════ */
.ab-contact-item  { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1.5rem; }
.ab-contact-icon  { width: 40px; height: 40px; background: var(--ab-bg-alt); border: 1px solid var(--ab-border); border-radius: var(--ab-radius-xs); display: flex; align-items: center; justify-content: center; font-size: 1rem; color: var(--ab-charcoal); flex-shrink: 0; }
.ab-contact-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--ab-muted); margin-bottom: .2rem; }
.ab-contact-value { color: var(--ab-text); font-weight: 500; }
.ab-map { border-radius: var(--ab-radius); overflow: hidden; border: 1px solid var(--ab-border); box-shadow: var(--ab-shadow-sm); }

/* USP icons */
.ab-usp-icon { color: var(--ab-charcoal) !important; }

/* ══════════════════════════════════════════════════════════════
   13. FOOTER
   ══════════════════════════════════════════════════════════════ */
.ab-footer { background: var(--ab-charcoal); color: var(--ab-text-inv); padding: 3rem 0 1.5rem; }
.ab-footer__brand  { font-family: var(--ab-ff-serif); font-size: 1.2rem; color: var(--ab-text-inv); margin-bottom: .4rem; }
.ab-footer__sub    { font-size: .78rem; color: rgba(242,237,228,.45); }
.ab-footer__link   { color: rgba(242,237,228,.6); text-decoration: none; font-size: .85rem; display: block; margin-bottom: .35rem; transition: color .15s; }
.ab-footer__link:hover { color: var(--ab-text-inv); }
.ab-footer__divider { border-color: rgba(255,255,255,.1); margin: 1.5rem 0; }
.ab-footer__copy   { font-size: .78rem; color: rgba(242,237,228,.35); }

/* ══════════════════════════════════════════════════════════════
   14. SCHEMA / SCHEMA.ORG helpers (invisible, structural only)
   ══════════════════════════════════════════════════════════════ */
[itemprop] { }

/* ══════════════════════════════════════════════════════════════
   15. UTILITIES
   ══════════════════════════════════════════════════════════════ */
.text-ab-charcoal  { color: var(--ab-charcoal) !important; }
.text-ab-muted     { color: var(--ab-muted) !important; }
/* Legacy gold utility classes → charcoal */
.ab-gold, .text-ab-gold, .ab-gold-text { color: var(--ab-charcoal) !important; }
.bg-ab-gold        { background: var(--ab-charcoal) !important; }
.ab-gold-soft      { background: var(--ab-bg-alt) !important; }
.bg-ab-bg          { background: var(--ab-bg) !important; }
.bg-ab-surface     { background: var(--ab-surface) !important; }
.bg-ab-charcoal    { background: var(--ab-charcoal) !important; }
.border-ab         { border-color: var(--ab-border) !important; }
.ab-divider        { height: 1px; background: var(--ab-border); margin: 2rem 0; }

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { transition-duration: .01ms !important; animation-duration: .01ms !important; }
}
