/*
Theme Name: Remix Modern Pilates
Theme URI: https://remixpilates.com
Author: Remix Modern Pilates
Author URI: https://remixpilates.com
Description: A fast, lightweight custom theme for Remix Modern Pilates — a boutique XFormer Pilates studio in Boca Raton. Editorial "Maison" design, Fraunces + Outfit typography, multi-page structure with a Journal (blog). Built clean to replace the previous heavy build.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
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: remix-modern-pilates
*/

/* ============================================================
   Remix Modern Pilates — shared stylesheet
   Aesthetic: editorial ivory "Maison"  ·  Fonts: Fraunces + Outfit
   ============================================================ */
:root{
  --ink:#16140f; --ivory:#f6f2ea; --paper:#fffdf8; --gold:#a98142; --gold-soft:#c9a96a;
  --line:#ddd4c4; --muted:#6f685b;
  --disp:'Fraunces',Georgia,serif; --body:'Outfit',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--ivory);color:var(--ink);font-family:var(--body);font-weight:300;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1240px;margin:0 auto;padding:0 32px}
.eyebrow{font-size:11px;letter-spacing:.42em;text-transform:uppercase;font-weight:500;color:var(--gold)}
h1,h2,h3,h4{font-family:var(--disp);font-weight:500;line-height:1.05;letter-spacing:-.01em}
.btn{display:inline-block;font-family:var(--body);font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:17px 36px;border:1px solid var(--ink);color:var(--ink);background:transparent;transition:.45s;cursor:pointer}
.btn:hover{background:var(--ink);color:var(--ivory)}
.btn-gold{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.btn-gold:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.reveal{opacity:0;transform:translateY(28px);transition:1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- sticky "New Here" book bar (from Design 2) ---------- */
.bookbar{position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--gold);color:#fff;display:flex;justify-content:center;align-items:center;gap:22px;padding:13px 32px;transform:translateY(100%);transition:.5s;flex-wrap:wrap}
.bookbar.show{transform:none}
.bookbar .bb-txt{font-family:var(--disp);font-style:italic;font-size:1.05rem;letter-spacing:.01em}
.bookbar a{background:var(--ink);color:#fff;padding:11px 26px;font-family:var(--body);font-size:11px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;transition:.3s}
.bookbar a:hover{background:#fff;color:var(--ink)}

/* ---------- nav ---------- */
header{position:fixed;inset:0 0 auto 0;z-index:50;transition:.5s;padding:22px 0}
header.solid{background:rgba(246,242,234,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:14px 0}
.nav{display:flex;align-items:center;justify-content:space-between}
.nav .logo{height:34px;transition:.4s}
.nav.on-dark .logo{filter:brightness(0) invert(1)}
header.solid .logo{filter:none}
.nav ul{display:flex;gap:34px;list-style:none;align-items:center}
.nav ul a{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);transition:.4s;position:relative;padding-bottom:3px}
.nav.on-dark ul a{color:#fff}
header.solid ul a{color:var(--ink)}
.nav ul a:hover{color:var(--gold-soft)}
.nav ul a.active{color:var(--gold)}
.nav ul a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--gold)}
.nav .cta{font-size:11px;letter-spacing:.2em;text-transform:uppercase;border:1px solid var(--ink);color:var(--ink);padding:11px 24px;transition:.4s}
.nav.on-dark .cta{border-color:rgba(255,255,255,.6);color:#fff}
header.solid .cta{border-color:var(--ink);color:var(--ink)}
.nav .cta:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.burger{display:none;background:none;border:none;color:inherit;font-size:22px;cursor:pointer}

/* ---------- hero (home) ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;color:#fff}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.4) 0%,transparent 30%,rgba(0,0,0,.15) 55%,rgba(10,9,6,.78) 100%)}
.hero .wrap{position:relative;z-index:2;padding-bottom:7vh;width:100%}
.hero .eyebrow{color:var(--gold-soft)}
.hero .kicker{font-family:var(--disp);font-style:italic;font-size:clamp(1.3rem,3vw,2rem);color:rgba(255,255,255,.92);margin:14px 0 4px}
.hero h1{font-size:clamp(2.9rem,7.4vw,6.2rem);margin:0 0 14px;letter-spacing:-.02em;font-weight:500}
.hero h1 em{font-style:italic;color:var(--gold-soft)}
.hero .sub{max-width:460px;font-size:1.05rem;color:rgba(255,255,255,.88);margin-bottom:30px}
.hero .actions{display:flex;gap:16px;flex-wrap:wrap}
.hero .btn{border-color:rgba(255,255,255,.8);color:#fff}
.hero .btn:hover{background:#fff;color:var(--ink)}
.scrollcue{position:absolute;right:32px;bottom:7vh;z-index:2;writing-mode:vertical-rl;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* ---------- NEW ribbon design: light, edge-faded, uppercase + gold diamonds ---------- */
.ribbon{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;overflow:hidden;position:relative;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.ribbon .track{display:inline-flex;align-items:center;gap:0;white-space:nowrap;animation:ribbon 34s linear infinite}
.ribbon .item{font-family:var(--body);font-size:13px;font-weight:500;letter-spacing:.34em;text-transform:uppercase;color:var(--ink);padding:0 40px;display:inline-flex;align-items:center}
.ribbon .item::after{content:"◆";color:var(--gold);font-size:9px;margin-left:40px;letter-spacing:0}
@keyframes ribbon{to{transform:translateX(-50%)}}

/* ---------- subpage banner ---------- */
.banner{position:relative;padding:180px 0 80px;color:#fff;overflow:hidden}
.banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,9,6,.55),rgba(10,9,6,.72))}
.banner .wrap{position:relative;z-index:2}
.banner .eyebrow{color:var(--gold-soft)}
.banner h1{font-size:clamp(2.6rem,6vw,4.6rem);margin:14px 0 10px;font-weight:500}
.banner h1 em{font-style:italic;color:var(--gold-soft)}
.banner p{max-width:520px;color:rgba(255,255,255,.85)}
.crumbs{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:8px}
.crumbs a:hover{color:var(--gold-soft)}

/* ---------- intro split ---------- */
.intro{padding:120px 0}
.intro .grid{display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:center}
.intro h2{font-size:clamp(2.2rem,4.5vw,3.6rem);margin:18px 0 24px;font-weight:500}
.intro h2 em{font-style:italic;color:var(--gold)}
.intro p{color:var(--muted);font-size:1.05rem;margin-bottom:18px;max-width:480px}
.intro .imgwrap{position:relative}
.intro .imgwrap img{aspect-ratio:4/5;object-fit:cover}
.intro .imgwrap::before{content:"";position:absolute;inset:-18px -18px auto auto;width:62%;height:60%;border:1px solid var(--gold);z-index:-1}
.intro .num{font-family:var(--disp);font-style:italic;font-size:1.1rem;color:var(--gold)}

/* ---------- offers ---------- */
.offers{background:var(--paper);padding:110px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{text-align:center;max-width:660px;margin:0 auto 60px}
.sec-head h2{font-size:clamp(2.2rem,5vw,3.8rem);margin:16px 0;font-weight:500}
.sec-head h2 em{font-style:italic;color:var(--gold)}
.sec-head p{color:var(--muted)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line)}
.card{padding:54px 38px;text-align:center;border-right:1px solid var(--line);transition:.5s;position:relative}
.card:last-child{border-right:none}
.card:hover{background:var(--ivory)}
.card .tag{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);font-weight:500}
.card h3{font-size:1.8rem;margin:18px 0 6px;font-weight:500}
.card .price{font-family:var(--disp);font-size:3.8rem;line-height:1;color:var(--ink);font-weight:500}
.card .price small{font-size:1rem;color:var(--muted);font-family:var(--body)}
.card .desc{color:var(--muted);font-size:.95rem;margin:18px 0 30px;min-height:48px}
.card.feat{background:var(--ink);color:var(--ivory)}
.card.feat .price,.card.feat h3{color:#fff}
.card.feat .desc{color:rgba(255,255,255,.7)}
.card.feat .btn{border-color:var(--gold);color:var(--gold)}
.card.feat .btn:hover{background:var(--gold);color:#fff}
.placeholder-note{font-size:10px;letter-spacing:.1em;color:var(--gold);text-transform:uppercase;display:block;margin-top:8px}

/* ---------- editorial rows ---------- */
.editorial{padding:110px 0}
.editorial .row{display:grid;grid-template-columns:1.3fr 1fr;gap:60px;align-items:center;margin-bottom:80px}
.editorial .row:last-child{margin-bottom:0}
.editorial .row.flip{grid-template-columns:1fr 1.3fr}
.editorial .row.flip .txt{order:2}
.editorial img{aspect-ratio:3/2;object-fit:cover;width:100%}
.editorial .txt h2,.editorial .txt h3{font-size:clamp(1.9rem,3.6vw,2.9rem);margin:14px 0 18px;font-weight:500}
.editorial .txt h2 em,.editorial .txt h3 em{font-style:italic;color:var(--gold)}
.editorial .txt p{color:var(--muted);max-width:440px;margin-bottom:14px}
.editorial .num{font-family:var(--disp);font-style:italic;font-size:1.1rem;color:var(--gold)}

/* ---------- reviews ---------- */
.social{background:var(--ink);color:var(--ivory);padding:110px 0;text-align:center}
.stars{color:var(--gold-soft);font-size:1.4rem;letter-spacing:.3em}
.social h2{font-size:clamp(1.9rem,4vw,3rem);margin:22px auto 12px;max-width:760px;font-style:italic;font-weight:500}
.social .rating{font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-bottom:56px}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:44px;max-width:1000px;margin:0 auto}
.quote p{font-family:var(--disp);font-size:1.3rem;font-style:italic;line-height:1.42;color:#fff;margin-bottom:14px;font-weight:400}
.quote .who{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft)}

/* ---------- FAQ ---------- */
.faq{padding:110px 0;background:var(--paper);border-top:1px solid var(--line)}
.faq .list{max-width:820px;margin:46px auto 0}
.faq details{border-bottom:1px solid var(--line);padding:24px 0}
.faq summary{font-family:var(--disp);font-size:1.35rem;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;font-weight:500}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:1.6rem;transition:.3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--muted);margin-top:14px;max-width:680px}

/* ---------- finale / email ---------- */
.finale{position:relative;color:#fff;text-align:center;padding:140px 0}
.finale img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.finale::after{content:"";position:absolute;inset:0;background:rgba(12,10,7,.66)}
.finale .wrap{position:relative;z-index:2}
.finale h2{font-size:clamp(2.4rem,6vw,4.6rem);font-weight:500}
.finale h2 em{font-style:italic;color:var(--gold-soft)}
.finale p{max-width:480px;margin:18px auto 34px;color:rgba(255,255,255,.85)}
.emailform{display:flex;gap:0;max-width:460px;margin:0 auto;border:1px solid rgba(255,255,255,.5)}
.emailform input{flex:1;background:transparent;border:none;padding:16px 20px;color:#fff;font-family:var(--body);font-size:14px;outline:none}
.emailform input::placeholder{color:rgba(255,255,255,.6)}
.emailform button{background:var(--gold);color:#fff;border:none;padding:0 28px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:.4s;font-family:var(--body)}
.emailform button:hover{background:#fff;color:var(--ink)}

/* ---------- generic content section ---------- */
.section{padding:100px 0}
.lead{font-size:1.15rem;color:var(--muted);max-width:620px}
.prose p{color:var(--muted);margin-bottom:18px;max-width:680px}
.prose h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin:40px 0 16px;font-weight:500}
.prose h2 em{font-style:italic;color:var(--gold)}

/* ---------- info grid (contact) ---------- */
.info{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.info .block{margin-bottom:30px}
.info h3{font-size:1.3rem;margin-bottom:8px;font-weight:500}
.info p,.info a{color:var(--muted)}
.info a:hover{color:var(--gold)}
.mapwrap img{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}

/* ---------- footer ---------- */
footer{background:var(--ivory);padding:80px 0 40px}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;padding-bottom:50px;border-bottom:1px solid var(--line)}
.foot .logo{height:40px;margin-bottom:20px}
.foot p{color:var(--muted);font-size:.95rem;max-width:300px}
.foot h4{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;font-family:var(--body);font-weight:600}
.foot ul{list-style:none}
.foot ul li{margin-bottom:11px;color:var(--muted);font-size:.95rem}
.foot ul a:hover{color:var(--gold)}
.copy{display:flex;justify-content:space-between;padding-top:28px;font-size:12px;color:var(--muted);letter-spacing:.04em}

@media(max-width:860px){
  .wrap{padding:0 22px}
  .nav ul,.nav .cta{display:none}
  .nav ul.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--ivory);border-bottom:1px solid var(--line);padding:10px 22px 20px}
  .nav ul.open a{padding:14px 0;border-bottom:1px solid var(--line)}
  .burger{display:block}
  .nav.on-dark .burger{color:#fff}
  header.solid .burger{color:var(--ink)}
  .intro .grid,.editorial .row,.editorial .row.flip,.info{grid-template-columns:1fr;gap:36px}
  .editorial .row.flip .txt{order:0}
  .cards{grid-template-columns:1fr}.card{border-right:none;border-bottom:1px solid var(--line)}
  .quotes{grid-template-columns:1fr;gap:32px}
  .foot{grid-template-columns:1fr;gap:34px}
  .copy{flex-direction:column;gap:10px}
  .scrollcue{display:none}
  .bookbar .bb-txt{font-size:.95rem}
}

/* ============================================================
   Journal / Blog
   ============================================================ */
.journal{padding:100px 0}
.featured{display:grid;grid-template-columns:1.15fr 1fr;gap:50px;align-items:center;margin-bottom:80px;padding-bottom:80px;border-bottom:1px solid var(--line)}
.featured .img{position:relative;overflow:hidden}
.featured .img img{aspect-ratio:4/3;object-fit:cover;width:100%;transition:.7s}
.featured:hover .img img{transform:scale(1.04)}
.post-cat{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);font-weight:500}
.featured h2{font-size:clamp(2rem,4vw,3.2rem);margin:14px 0 16px;font-weight:500;line-height:1.08}
.featured h2 a:hover{color:var(--gold)}
.featured p{color:var(--muted);max-width:480px;margin-bottom:20px}
.post-meta{font-size:12px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.post-card{display:flex;flex-direction:column}
.post-card .img{overflow:hidden;margin-bottom:18px}
.post-card .img img{aspect-ratio:3/2;object-fit:cover;width:100%;transition:.6s}
.post-card:hover .img img{transform:scale(1.05)}
.post-card h3{font-size:1.45rem;margin:10px 0 10px;font-weight:500;line-height:1.15}
.post-card h3 a:hover{color:var(--gold)}
.post-card p{color:var(--muted);font-size:.95rem;margin-bottom:14px;flex:1}
.post-card .more{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:3px;align-self:flex-start;transition:.3s}
.post-card .more:hover{color:var(--gold)}

/* single article */
.article{padding:60px 0 100px}
.article .head{max-width:760px;margin:0 auto 40px;text-align:center}
.article .head h1{font-size:clamp(2.2rem,5vw,3.6rem);margin:16px 0;font-weight:500;line-height:1.1}
.article .head .post-meta{margin-top:8px}
.article .hero-img{max-width:1000px;margin:0 auto 50px}
.article .hero-img img{width:100%;aspect-ratio:16/9;object-fit:cover}
.article .body{max-width:720px;margin:0 auto;font-size:1.08rem}
.article .body p{color:#39342b;margin-bottom:24px;line-height:1.85}
.article .body h2{font-family:var(--disp);font-size:1.9rem;margin:44px 0 16px;font-weight:500}
.article .body h2 em{font-style:italic;color:var(--gold)}
.article .body ul{margin:0 0 24px 22px;color:#39342b}
.article .body li{margin-bottom:10px}
.article .body blockquote{border-left:2px solid var(--gold);padding:6px 0 6px 26px;margin:30px 0;font-family:var(--disp);font-style:italic;font-size:1.4rem;color:var(--ink)}
.article .share{max-width:720px;margin:50px auto 0;padding-top:30px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}

@media(max-width:860px){
  .featured{grid-template-columns:1fr;gap:28px}
  .post-grid{grid-template-columns:1fr;gap:44px}
  .article .body{font-size:1.02rem}
}

/* ============================================================
   WordPress integration adjustments
   ============================================================ */
/* active menu state from wp_nav_menu */
.nav ul li.current-menu-item > a,
.nav ul li.current_page_item > a{color:var(--gold)}
.nav ul li.current-menu-item > a::after,
.nav ul li.current_page_item > a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--gold)}
/* keep fixed header clear of the WP admin bar */
.admin-bar header{top:32px}
@media(max-width:782px){.admin-bar header{top:46px}}
/* wp core alignment + caption helpers for blog content */
.article .body img{max-width:100%;height:auto}
.alignleft{float:left;margin:0 24px 16px 0}
.alignright{float:right;margin:0 0 16px 24px}
.aligncenter{display:block;margin-left:auto;margin-right:auto}
.wp-caption-text{font-size:.85rem;color:var(--muted);text-align:center;margin-top:8px}
.sticky,.gallery-caption,.bypostauthor{}

/* "Book a Class" CTA when added as a menu item with CSS class "cta" */
.nav ul li.cta > a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;border:1px solid rgba(255,255,255,.6);color:#fff;padding:11px 24px;transition:.4s}
header.solid .nav ul li.cta > a{border-color:var(--ink);color:var(--ink)}
.nav ul li.cta > a:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.nav ul li.cta > a::after{display:none}
