/*
Theme Name: A A Nails & Spa
Theme URI: https://aanailsandspansb.com/
Author: A A Nails & Spa Inc
Author URI: https://aanailsandspansb.com/
Description: A bespoke WordPress theme for A A Nails & Spa Inc (New Smyrna Beach). Soft blush + wine + gold palette with elegant serif typography. Includes hero, services, gallery, Google reviews, and contact sections.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aa-nails-spa
Tags: nail-salon, spa, beauty, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* =============================================
   A A NAILS & SPA — THEME STYLES
   Color tokens, typography, components.
   ============================================= */

:root{
  --rose-50:#fbf3f3;
  --rose-100:#f7e6e6;
  --rose-200:#eccaca;
  --rose-300:#dba5a5;
  --rose-500:#b56a6a;
  --wine:#6b2a36;
  --wine-deep:#4a1c25;
  --gold:#c9a96e;
  --gold-soft:#dfc28a;
  --cream:#fdfaf6;
  --ink:#2b2123;
  --muted:#6c5e60;
  --line:#e7d6d6;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --shadow-soft:0 8px 30px rgba(107,42,54,.08);
  --shadow-card:0 12px 40px rgba(74,28,37,.10);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--wine);text-decoration:none}
a:hover{color:var(--rose-500)}

h1,h2,h3,h4,h5,h6{
  font-family:var(--serif);
  font-weight:500;
  color:var(--wine-deep);
  letter-spacing:.01em;
  margin:0 0 .4em;
  line-height:1.15;
}
h1{font-size:clamp(2.4rem, 5vw, 4.2rem); font-weight:500}
h2{font-size:clamp(1.9rem, 3.2vw, 2.8rem)}
h3{font-size:clamp(1.3rem, 1.8vw, 1.6rem)}
p{margin:0 0 1em}

.aa-eyebrow{
  font-family:var(--sans);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.75rem;
  color:var(--gold);
  font-weight:600;
  display:inline-block;
  margin-bottom:.8em;
}

.aa-container{max-width:1200px; margin:0 auto; padding:0 24px}
.aa-section{padding:96px 0}
.aa-section--tight{padding:64px 0}
.aa-center{text-align:center}

.aa-divider{
  width:64px; height:2px; margin:18px auto 28px;
  background:linear-gradient(90deg, transparent, var(--gold) 50%, transparent);
  position:relative;
}
.aa-divider::before, .aa-divider::after{
  content:""; position:absolute; top:50%; width:6px; height:6px; border-radius:50%;
  background:var(--gold); transform:translateY(-50%);
}
.aa-divider::before{left:-14px}
.aa-divider::after{right:-14px}

/* -------- nav -------- */
.aa-nav-wrap{
  position:sticky; top:0; z-index:50;
  background:rgba(253,250,246,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.aa-topbar{
  background:var(--wine-deep);
  color:var(--rose-100);
  font-size:.78rem;
  letter-spacing:.08em;
}
.aa-topbar .aa-container{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:8px; padding-bottom:8px; gap:18px; flex-wrap:wrap;
}
.aa-topbar a{color:var(--rose-100)}
.aa-topbar a:hover{color:var(--gold-soft)}

.aa-nav{display:flex; align-items:center; justify-content:space-between; padding:16px 0}
.aa-brand{display:flex; align-items:center; gap:14px}
.aa-brand-mark{
  width:54px; height:54px; border-radius:50%;
  background:linear-gradient(135deg, var(--rose-200), var(--rose-300));
  display:grid; place-items:center;
  font-family:var(--serif); color:var(--wine-deep);
  font-weight:600; font-size:1.4rem;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.5), 0 4px 14px rgba(107,42,54,.18);
}
.aa-brand-text{line-height:1.1}
.aa-brand-name{font-family:var(--serif); font-size:1.35rem; color:var(--wine-deep); font-weight:600}
.aa-brand-sub{font-size:.7rem; letter-spacing:.32em; color:var(--gold); text-transform:uppercase}

.aa-menu{display:flex; align-items:center; gap:28px; list-style:none; margin:0; padding:0}
.aa-menu a{
  font-size:.82rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink); font-weight:500;
}
.aa-menu a:hover{color:var(--rose-500)}

.aa-btn{
  display:inline-block; padding:14px 28px;
  background:var(--wine-deep); color:#fff;
  font-size:.78rem; letter-spacing:.22em; text-transform:uppercase; font-weight:600;
  border:1px solid var(--wine-deep);
  transition:all .25s ease;
  cursor:pointer;
}
.aa-btn:hover{background:transparent; color:var(--wine-deep)}
.aa-btn--gold{background:var(--gold); border-color:var(--gold); color:var(--wine-deep)}
.aa-btn--gold:hover{background:transparent; color:var(--gold)}
.aa-btn--ghost{background:transparent; color:var(--wine-deep)}
.aa-btn--ghost:hover{background:var(--wine-deep); color:#fff}
.aa-btn--light{background:rgba(255,255,255,.08); color:#fff; border-color:rgba(255,255,255,.6)}
.aa-btn--light:hover{background:#fff; color:var(--wine-deep)}

/* -------- hero -------- */
.aa-hero{
  position:relative;
  min-height:88vh;
  display:grid; place-items:center;
  color:#fff;
  overflow:hidden;
}
.aa-hero-inner{text-align:center; padding:120px 24px; max-width:880px; position:relative; z-index:2}
.aa-hero .aa-eyebrow{color:var(--gold-soft)}
.aa-hero h1{color:#fff; font-style:italic; font-weight:400}
.aa-hero h1 span{font-style:normal; display:block; font-weight:500}
.aa-hero p.aa-lede{
  font-family:var(--serif); font-size:clamp(1.1rem, 1.4vw, 1.35rem);
  font-style:italic; color:var(--rose-100);
  margin:18px auto 32px; max-width:620px;
}
.aa-hero-ctas{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}

/* -------- trust bar -------- */
.aa-trust{background:var(--wine-deep); color:#fff; padding:30px 0}
.aa-trust-grid{
  display:grid; grid-template-columns:repeat(4, 1fr);
  gap:24px; text-align:center;
}
.aa-trust-item strong{
  display:block; font-family:var(--serif);
  font-size:1.4rem; color:var(--gold-soft);
  margin-bottom:4px; font-weight:600;
}
.aa-trust-item span{
  font-size:.74rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--rose-100); opacity:.85;
}

/* -------- about -------- */
.aa-about{display:grid; grid-template-columns:1.05fr 1fr; gap:64px; align-items:center}
.aa-about-img{
  position:relative; aspect-ratio:4/5;
  background-size:cover; background-position:center;
  box-shadow:var(--shadow-card);
}
.aa-about-img::after{
  content:""; position:absolute; inset:18px;
  border:1px solid rgba(255,255,255,.55); pointer-events:none;
}

/* -------- services -------- */
.aa-services{background:var(--rose-50)}
.aa-service-grid{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:30px; margin-top:40px;
}
.aa-service-card{
  background:#fff; box-shadow:var(--shadow-soft);
  overflow:hidden; transition:transform .35s ease, box-shadow .35s ease;
}
.aa-service-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-card)}
.aa-service-card .aa-photo{
  aspect-ratio:4/3; background-size:cover; background-position:center;
}
.aa-service-card .aa-body{padding:26px 28px 30px}
.aa-service-card h3{margin-bottom:12px}
.aa-price-row{
  display:flex; justify-content:space-between; align-items:baseline;
  padding:8px 0; border-bottom:1px dashed var(--line); font-size:.93rem;
}
.aa-price-row:last-child{border-bottom:0}
.aa-price-row .aa-price{
  font-family:var(--serif); font-weight:600;
  color:var(--wine-deep); font-size:1.05rem;
}
.aa-price-row .aa-name{color:var(--muted)}

.aa-menu-foot{margin-top:42px; text-align:center}

/* -------- gallery -------- */
.aa-gallery-grid{
  display:grid; grid-template-columns:repeat(4, 1fr);
  grid-auto-rows:240px; gap:14px; margin-top:40px;
}
.aa-gallery-grid figure{
  margin:0; overflow:hidden; position:relative;
  background-size:cover; background-position:center;
  transition:transform .5s ease;
}
.aa-gallery-grid figure::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(74,28,37,.35));
  opacity:0; transition:opacity .35s ease;
}
.aa-gallery-grid figure:hover{transform:scale(1.015)}
.aa-gallery-grid figure:hover::after{opacity:1}
.aa-gallery-grid .aa-tall{grid-row:span 2}

/* -------- testimonials -------- */
.aa-testimonials{background:linear-gradient(180deg, var(--rose-50), var(--cream))}
.aa-reviews-meta{display:flex; align-items:center; gap:14px; justify-content:center; margin-bottom:8px}
.aa-google-pill{
  display:inline-flex; align-items:center; gap:10px;
  background:#fff; padding:8px 16px; border-radius:999px;
  box-shadow:var(--shadow-soft); font-weight:600; font-size:.85rem;
}
.aa-stars{color:#f4b400; letter-spacing:2px}
.aa-review-grid{
  display:grid; grid-template-columns:repeat(3, 1fr);
  gap:24px; margin-top:40px;
}
.aa-review-card{
  background:#fff; padding:30px 30px 28px;
  box-shadow:var(--shadow-soft); position:relative;
}
.aa-review-card::before{
  content:"\201C";
  font-family:var(--serif); font-size:5rem;
  color:var(--rose-200);
  position:absolute; top:-10px; left:18px; line-height:1;
}
.aa-review-card .aa-stars{margin-bottom:10px; display:block}
.aa-review-card p{font-style:italic; color:var(--ink); margin-bottom:18px}
.aa-review-card .aa-who{
  display:flex; align-items:center; gap:12px;
  padding-top:14px; border-top:1px solid var(--line);
}
.aa-review-card .aa-avatar{
  width:42px; height:42px; border-radius:50%;
  display:grid; place-items:center;
  background:var(--rose-200); color:var(--wine-deep);
  font-family:var(--serif); font-weight:600;
}
.aa-review-card .aa-who small{display:block; color:var(--muted); font-size:.78rem}
.aa-review-card .aa-who strong{font-size:.95rem; color:var(--wine-deep)}

/* -------- contact -------- */
.aa-contact-grid{
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:48px; margin-top:40px;
}
.aa-info-card{background:#fff; padding:42px; box-shadow:var(--shadow-soft)}
.aa-info-row{display:flex; gap:18px; padding:18px 0; border-bottom:1px solid var(--line)}
.aa-info-row:last-child{border-bottom:0}
.aa-info-row .aa-icon{
  flex:0 0 44px; height:44px; border-radius:50%;
  background:var(--rose-100); color:var(--wine-deep);
  display:grid; place-items:center; font-family:var(--serif); font-weight:700;
}
.aa-info-row .aa-label{
  font-size:.72rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); margin-bottom:4px; font-weight:600;
}
.aa-info-row .aa-value{font-size:1.02rem; color:var(--ink)}
.aa-info-row .aa-value strong{color:var(--wine-deep)}
.aa-map-frame iframe{
  width:100%; height:100%; min-height:460px;
  border:0; box-shadow:var(--shadow-card);
}

/* -------- footer -------- */
.aa-footer{background:var(--wine-deep); color:var(--rose-100); padding:64px 0 24px}
.aa-foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px}
.aa-footer h4{
  color:#fff; font-size:1rem; letter-spacing:.18em; text-transform:uppercase;
  font-family:var(--sans); font-weight:600; margin-bottom:18px;
}
.aa-footer ul{list-style:none; padding:0; margin:0}
.aa-footer li{margin-bottom:10px; font-size:.92rem}
.aa-footer a{color:var(--rose-100)}
.aa-footer a:hover{color:var(--gold-soft)}
.aa-foot-brand .aa-brand-name{color:#fff}
.aa-foot-brand p{font-size:.92rem; opacity:.85; margin-top:14px}
.aa-socials{display:flex; gap:10px; margin-top:18px}
.aa-socials a{
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.08);
  display:grid; place-items:center;
  transition:background .2s ease; font-size:.85rem;
}
.aa-socials a:hover{background:var(--gold); color:var(--wine-deep)}
.aa-legal{
  margin-top:48px; padding-top:24px;
  border-top:1px solid rgba(255,255,255,.12);
  display:flex; justify-content:space-between; align-items:center;
  gap:18px; font-size:.82rem; opacity:.75; flex-wrap:wrap;
}

/* mobile menu toggle */
.aa-menu-toggle{
  display:none; background:transparent; border:0; cursor:pointer;
  color:var(--wine-deep); font-size:1.4rem; padding:8px;
}

@media (max-width: 900px){
  .aa-menu{
    display:none; position:absolute; top:100%; left:0; right:0;
    background:var(--cream); flex-direction:column; gap:0;
    padding:12px 0; border-top:1px solid var(--line);
  }
  .aa-menu.is-open{display:flex}
  .aa-menu li{padding:10px 24px; width:100%}
  .aa-menu-toggle{display:inline-block}
  .aa-nav{position:relative}
  .aa-trust-grid{grid-template-columns:repeat(2, 1fr); gap:24px}
  .aa-about{grid-template-columns:1fr; gap:36px}
  .aa-service-grid{grid-template-columns:1fr}
  .aa-gallery-grid{grid-template-columns:repeat(2, 1fr); grid-auto-rows:200px}
  .aa-gallery-grid .aa-tall{grid-row:auto}
  .aa-review-grid{grid-template-columns:1fr}
  .aa-contact-grid{grid-template-columns:1fr}
  .aa-foot-grid{grid-template-columns:1fr 1fr; gap:32px}
  .aa-section{padding:64px 0}
}

/* WordPress alignment defaults */
.alignleft{float:left; margin:0 1.5em 1em 0}
.alignright{float:right; margin:0 0 1em 1.5em}
.aligncenter{display:block; margin:0 auto 1em}
.wp-caption{max-width:100%}
.screen-reader-text{
  border:0; clip:rect(1px,1px,1px,1px); -webkit-clip-path:inset(50%); clip-path:inset(50%);
  height:1px; width:1px; margin:-1px; padding:0; overflow:hidden; position:absolute; word-wrap:normal !important;
}
