/* JK Beauty Studio — landing page styles
   Palette: beige, nude, old gold, white.
   Type: Cormorant Garamond (display) + Inter (text). */

:root{
  --bg:           #fbf8f4;
  --bg-cream:    #f3ece2;
  --bg-nude:     #e8d5c4;
  --ink:         #2d2520;
  --ink-soft:    #5b4f47;
  --ink-mute:    #8a7a6e;
  --gold:        #b79460;
  --gold-deep:   #9a7a47;
  --gold-soft:   #e6d4b2;
  --line:        rgba(45,37,32,.12);
  --line-strong: rgba(45,37,32,.22);
  --white:       #ffffff;

  --maxw: 1200px;
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 10px;
  --shadow-soft: 0 30px 80px -40px rgba(45,37,32,.35);
  --shadow-card: 0 18px 50px -28px rgba(45,37,32,.45);

  --serif: "Cormorant Garamond", "Cormorant", Georgia, "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* ============ base ============ */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg,iframe{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; transition:color .25s ease, border-color .25s ease, background .25s ease; }
a:hover{ color:var(--gold-deep); }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  letter-spacing:-.01em;
  color:var(--ink);
  margin:0 0 .4em;
  line-height:1.12;
}
h1{ font-size:clamp(2.4rem, 5.4vw, 4.4rem); font-weight:500; }
h2{ font-size:clamp(2rem, 4vw, 3.1rem); }
h3{ font-size:1.5rem; }
h4{ font-size:1.05rem; font-family:var(--sans); font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); }
p{ margin:0 0 1em; color:var(--ink-soft); }

.container{
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 24px;
}

.eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin:0 0 1rem;
  font-weight:500;
}
.eyebrow-light{ color:var(--gold-soft); }

.skip-link{
  position:absolute; left:-9999px; top:0;
  background:var(--ink); color:#fff; padding:.6rem 1rem;
  border-radius:0 0 8px 0; z-index:1000;
}
.skip-link:focus{ left:0; }

/* ============ header ============ */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(251,248,244,.86);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;
  align-items:center;
  gap:24px;
  height:74px;
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  font-family:var(--serif);
  font-size:1.35rem;
  letter-spacing:.02em;
  color:var(--ink);
}
.brand-mark{
  display:inline-grid;
  place-items:center;
  width:38px; height:38px;
  border-radius:50%;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  color:#fff;
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size:1rem;
  letter-spacing:.04em;
  box-shadow:0 6px 18px -6px rgba(154,122,71,.55);
}
.brand-word{ font-weight:500; }

.primary-nav{ flex:1; }
.primary-nav ul{
  display:flex;
  gap:30px;
  justify-content:center;
}
.primary-nav a{
  font-size:.95rem;
  color:var(--ink-soft);
  position:relative;
  padding:.25rem 0;
}
.primary-nav a::after{
  content:"";
  position:absolute; left:0; bottom:-4px;
  width:0; height:1px;
  background:var(--gold);
  transition:width .3s ease;
}
.primary-nav a:hover{ color:var(--ink); }
.primary-nav a:hover::after{ width:100%; }

.nav-toggle{
  display:none;
  width:44px; height:44px;
  background:transparent;
  border:1px solid var(--line);
  border-radius:50%;
  cursor:pointer;
  padding:0;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:4px;
}
.nav-toggle span{
  display:block;
  width:18px; height:1.5px;
  background:var(--ink);
  transition:transform .3s ease, opacity .3s ease;
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(5.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-5.5px) rotate(-45deg); }

.mobile-nav{
  border-top:1px solid var(--line);
  background:var(--bg);
}
.mobile-nav ul{
  display:flex;
  flex-direction:column;
  padding:8px 24px 20px;
  gap:4px;
}
.mobile-nav a{
  display:block;
  padding:14px 4px;
  font-size:1.05rem;
  color:var(--ink);
  border-bottom:1px solid var(--line);
}
.mobile-nav li:last-child a{ border-bottom:none; }
.mobile-nav .cta{ margin-top:14px; width:100%; justify-content:center; }

/* ============ CTAs ============ */
.cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  font-family:var(--sans);
  font-size:.95rem;
  font-weight:500;
  letter-spacing:.02em;
  padding:14px 26px;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  white-space:nowrap;
  transition:transform .2s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.cta-primary{
  background:linear-gradient(135deg, var(--ink) 0%, #443830 100%);
  color:#fff;
  box-shadow:0 14px 32px -16px rgba(45,37,32,.55);
}
.cta-primary:hover{
  color:#fff;
  transform:translateY(-1px);
  box-shadow:0 18px 36px -16px rgba(45,37,32,.65);
}
.cta-pill{
  background:var(--ink);
  color:#fff;
  padding:10px 20px;
  font-size:.85rem;
}
.cta-pill:hover{ color:#fff; background:var(--gold-deep); }

.cta-ghost{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--line-strong);
}
.cta-ghost:hover{ border-color:var(--ink); color:var(--ink); }
.cta-ghost-light{
  border-color:rgba(255,255,255,.6);
  color:#fff;
}
.cta-ghost-light:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.cta-large{ padding:18px 34px; font-size:1.02rem; }

/* ============ hero ============ */
.hero{
  position:relative;
  padding:64px 0 90px;
  overflow:hidden;
  background:
    radial-gradient(900px 600px at 95% -10%, rgba(183,148,96,.16), transparent 60%),
    radial-gradient(800px 600px at -10% 30%, rgba(232,213,196,.55), transparent 60%),
    var(--bg);
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:60px;
  align-items:center;
}
.hero-copy h1{
  margin-bottom:1.1rem;
}
.hero-copy h1::after{
  content:"";
  display:block;
  width:60px; height:1px;
  background:var(--gold);
  margin:24px 0 0;
}
.lead{
  font-size:1.1rem;
  color:var(--ink-soft);
  max-width:540px;
}
.hero-ctas{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin:34px 0 38px;
}
.hero-trust{
  display:grid;
  grid-template-columns:repeat(3, auto);
  gap:36px;
  max-width:520px;
  padding-top:28px;
  border-top:1px solid var(--line);
}
.hero-trust li{
  display:flex;
  flex-direction:column;
}
.hero-trust strong{
  font-family:var(--serif);
  font-size:2.1rem;
  font-weight:500;
  color:var(--ink);
  line-height:1;
}
.hero-trust span{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--ink-mute);
  margin-top:6px;
}

/* hero art (decorative cards) */
.hero-art{
  position:relative;
  aspect-ratio: 1 / 1.05;
  max-width:520px;
  margin-left:auto;
}
.hero-card{
  position:absolute;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-soft);
}
.hero-card-1{
  inset:0 18% 22% 0;
  background:
    linear-gradient(160deg, rgba(255,255,255,.4), transparent 60%),
    linear-gradient(135deg, #d4b48a 0%, #8e6d3f 100%);
}
.hero-card-2{
  inset:30% 0 0 28%;
  background:
    linear-gradient(135deg, rgba(255,255,255,.55), transparent 65%),
    var(--bg-nude);
}
.hero-card-3{
  position:absolute;
  inset:16% 12% 14% 20%;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(255,255,255,.55), transparent 60%),
    linear-gradient(160deg, #fff 0%, var(--bg-cream) 100%);
  display:grid;
  place-items:center;
}
.hero-monogram{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(4rem, 10vw, 7rem);
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  letter-spacing:.02em;
}
.hero-blur{
  position:absolute;
  width:260px; height:260px;
  background:radial-gradient(closest-side, rgba(183,148,96,.45), transparent 70%);
  filter:blur(40px);
  top:-40px; right:-30px;
  z-index:-1;
  border-radius:50%;
}

/* ============ marquee strip ============ */
.strip{
  background:var(--ink);
  color:#fff;
  padding:18px 0;
}
.strip-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
  gap:28px;
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  color:#eee2cd;
  letter-spacing:.03em;
}

/* ============ section base ============ */
.section{ padding:100px 0; }
.section-cream{ background:var(--bg-cream); }
.section-head{
  text-align:center;
  max-width:680px;
  margin:0 auto 56px;
}
.section-head h2{ margin-bottom:1rem; }
.section-sub{ font-size:1.05rem; color:var(--ink-soft); }

/* ============ pillars ============ */
.pillars{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
}
.pillar{
  position:relative;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:36px 28px 30px;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.pillar:hover{
  transform:translateY(-4px);
  border-color:var(--gold-soft);
  box-shadow:var(--shadow-card);
}
.pillar-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.05rem;
  color:var(--gold-deep);
  letter-spacing:.04em;
}
.pillar h3{
  margin:18px 0 14px;
  font-size:1.45rem;
}
.pillar p{ font-size:.96rem; }
.pillar em{ font-style:italic; color:var(--ink); }
.pillar-link{
  display:inline-block;
  margin-top:12px;
  font-size:.85rem;
  color:var(--gold-deep);
  letter-spacing:.06em;
  text-transform:uppercase;
}

/* ============ price list ============ */
.price-groups{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:36px 56px;
}
.price-group{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:32px 32px 28px;
}
.price-group:last-child{ grid-column:1 / -1; }
.price-group-title{
  font-size:1.35rem;
  padding-bottom:14px;
  margin-bottom:18px;
  border-bottom:1px solid var(--line);
  display:flex;
  align-items:center;
  gap:12px;
}
.price-group-title::before{
  content:"✦";
  color:var(--gold);
  font-size:.85rem;
}
.price-list li{
  display:grid;
  grid-template-columns:1fr auto auto;
  gap:18px;
  align-items:baseline;
  padding:12px 0;
  border-bottom:1px dashed var(--line);
  font-size:.97rem;
}
.price-list li:last-child{ border-bottom:none; }
.price-list .srv{ color:var(--ink); }
.price-list .srv em{
  font-style:italic;
  font-size:.8rem;
  color:var(--gold-deep);
  margin-left:6px;
}
.price-list .dur{
  color:var(--ink-mute);
  font-size:.82rem;
  letter-spacing:.04em;
  white-space:nowrap;
}
.price-list .prc{
  font-family:var(--serif);
  font-size:1.2rem;
  color:var(--ink);
  font-weight:500;
  letter-spacing:.01em;
  white-space:nowrap;
}
.price-note{
  font-size:.88rem;
  color:var(--ink-mute);
  margin:14px 0 0;
}
.price-cta{
  text-align:center;
  margin-top:48px;
}

/* ============ about ============ */
.about-grid{
  display:grid;
  grid-template-columns:.85fr 1.15fr;
  gap:64px;
  align-items:center;
}
.about-art{
  position:relative;
  aspect-ratio:4/5;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:
    radial-gradient(120% 100% at 20% 0%, rgba(255,255,255,.55), transparent 60%),
    linear-gradient(160deg, var(--bg-nude) 0%, #d8bfa6 100%);
  box-shadow:var(--shadow-soft);
}
.about-photo{
  position:absolute;
  inset:8% 8% 22% 8%;
  border-radius:var(--radius-md);
  background:
    radial-gradient(80% 60% at 50% 35%, rgba(255,255,255,.4), transparent 70%),
    linear-gradient(180deg, #efddc6 0%, #c79b71 100%);
}
.about-photo::before{
  content:"";
  position:absolute;
  inset:34% 24% 34% 24%;
  border-radius:50%;
  background:
    radial-gradient(closest-side, #fff 0%, rgba(255,255,255,0) 80%),
    radial-gradient(closest-side, var(--gold) 0%, transparent 90%);
  opacity:.7;
}
.about-badge{
  position:absolute;
  right:-18px; bottom:24px;
  background:#fff;
  border-radius:18px;
  padding:18px 22px;
  box-shadow:var(--shadow-card);
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:2px;
  min-width:120px;
}
.about-badge strong{
  font-family:var(--serif);
  font-size:2.2rem;
  color:var(--ink);
  line-height:1;
}
.about-badge span{ color:var(--gold); font-size:.95rem; letter-spacing:.1em; }
.about-badge small{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }

.about-copy h2{ margin-bottom:1rem; }
.bullets{
  margin-top:22px;
  display:grid;
  gap:10px;
}
.bullets li{
  position:relative;
  padding-left:26px;
  color:var(--ink-soft);
  font-size:.98rem;
}
.bullets li::before{
  content:"✦";
  position:absolute;
  left:0; top:1px;
  color:var(--gold);
  font-size:.85rem;
}

/* ============ reviews ============ */
.reviews{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.review{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:32px 28px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.stars{
  color:var(--gold);
  font-size:1.05rem;
  letter-spacing:.18em;
}
.review p{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.18rem;
  line-height:1.5;
  color:var(--ink);
  margin:0;
}
.review footer{
  margin-top:auto;
  font-size:.9rem;
  color:var(--ink-soft);
  letter-spacing:.02em;
}
.review footer span{ color:var(--ink-mute); }
.reviews-link{
  text-align:center;
  margin-top:36px;
  display:flex;
  flex-wrap:wrap;
  gap:14px 22px;
  justify-content:center;
  align-items:center;
}
.reviews-link a{
  color:var(--gold-deep);
  font-size:.95rem;
  letter-spacing:.04em;
  border-bottom:1px solid var(--gold-soft);
  padding-bottom:2px;
}
.reviews-sep{
  color:var(--ink-mute);
  font-size:.9rem;
}

/* ============ contact ============ */
.contact-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:60px;
  align-items:start;
}
.contact-copy h2{ margin-bottom:1rem; }
.contact-blocks{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  margin-top:30px;
}
.contact-block{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-md);
  padding:22px 22px 20px;
}
.contact-block h3{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:10px;
  font-weight:600;
}
.contact-block p{
  font-size:.95rem;
  color:var(--ink);
  margin-bottom:10px;
  line-height:1.55;
}
.contact-block a{
  color:var(--ink);
  border-bottom:1px solid var(--gold-soft);
}
.contact-block a:hover{ border-color:var(--gold-deep); }
.contact-block .phone-link{
  font-family:var(--serif);
  font-size:1.55rem;
  letter-spacing:.01em;
  color:var(--ink);
  border-bottom:none;
}
.contact-block .phone-link:hover{
  color:var(--gold-deep);
}
.contact-note{
  font-size:.84rem;
  color:var(--ink-mute);
  margin:6px 0 0;
  line-height:1.5;
}

.contact-map{
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  aspect-ratio:4/5;
  background:var(--bg-nude);
}
.contact-map iframe{
  width:100%; height:100%; border:0;
}

/* ============ closing CTA ============ */
.cta-band{
  background:
    radial-gradient(700px 400px at 90% 0%, rgba(183,148,96,.35), transparent 60%),
    linear-gradient(135deg, #2d2520 0%, #1a1410 100%);
  color:#fff;
  padding:80px 0;
}
.cta-band h2{ color:#fff; margin:0; }
.cta-band-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:40px;
  flex-wrap:wrap;
}

/* ============ footer ============ */
.site-footer{
  background:#1a1410;
  color:#cfc2b3;
  padding:64px 0 28px;
}
.site-footer a{ color:#cfc2b3; }
.site-footer a:hover{ color:#fff; }
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1.2fr;
  gap:40px;
  padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.brand-foot{
  display:flex;
  align-items:center;
  gap:12px;
  font-family:var(--serif);
  font-size:1.4rem;
  color:#fff;
  margin:0 0 14px;
}
.brand-mark-foot{ box-shadow:0 6px 18px -6px rgba(0,0,0,.6); }
.foot-meta{ font-size:.92rem; color:#b6a999; margin:0; }
.site-footer h4{ color:#fff; margin-bottom:14px; }
.site-footer ul{ display:grid; gap:8px; }
.site-footer ul a{ font-size:.94rem; }
.footer-bottom{
  padding-top:20px;
  text-align:center;
  color:#86796b;
  font-size:.85rem;
}

/* ============ responsive ============ */
@media (max-width: 1024px){
  .pillars{ grid-template-columns:repeat(2, 1fr); }
  .hero-grid{ grid-template-columns:1fr; }
  .hero-art{ max-width:420px; margin:24px auto 0; }
  .about-grid, .contact-grid{ grid-template-columns:1fr; gap:44px; }
  .about-art{ max-width:420px; margin:0 auto; aspect-ratio:5/5; }
  .reviews{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px 24px; }
}

@media (max-width: 720px){
  body{ font-size:16px; }
  .section{ padding:72px 0; }
  .nav{ height:64px; }
  .primary-nav, .cta-pill{ display:none; }
  .nav-toggle{ display:flex; }
  .hero{ padding:40px 0 70px; }
  .hero-trust{
    grid-template-columns:1fr;
    gap:18px;
  }
  .hero-trust li{ flex-direction:row; align-items:baseline; gap:12px; }
  .hero-trust strong{ font-size:1.6rem; }
  .price-groups{ grid-template-columns:1fr; gap:28px; }
  .price-group{ padding:24px 20px; }
  .price-list li{
    grid-template-columns:1fr auto;
    grid-template-areas:
      "srv prc"
      "dur dur";
    gap:6px 14px;
  }
  .price-list .srv{ grid-area:srv; }
  .price-list .prc{ grid-area:prc; }
  .price-list .dur{ grid-area:dur; }
  .pillars{ grid-template-columns:1fr; }
  .contact-blocks{ grid-template-columns:1fr; }
  .strip-row{ gap:16px; font-size:.95rem; }
  .footer-grid{ grid-template-columns:1fr; }
  .cta-band{ padding:60px 0; }
  .cta-band-row{ flex-direction:column; align-items:flex-start; }
  .about-badge{ right:12px; padding:14px 18px; }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{
    animation-duration:0.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.001ms !important;
  }
}

/* ============ small details ============ */
::selection{ background:var(--gold-soft); color:var(--ink); }
:focus-visible{
  outline:2px solid var(--gold-deep);
  outline-offset:3px;
  border-radius:4px;
}
