/* ============================================================
   GUITARPRACTICE.PRO — THEME VARIABLES
   These map directly to WordPress Customizer color settings.
   Change any value here to re-skin the entire site.
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--color-accent);text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.08;letter-spacing:-.02em}

.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent)}


/* ---------- Header ---------- */
header{position:sticky;top:0;z-index:50;background:var(--color-header-bg);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{font-family:var(--font-display);font-weight:900;font-size:1.25rem;color:var(--color-text);letter-spacing:-.03em}
.logo span{color:var(--color-accent)}
.nav-links{display:flex;gap:28px;align-items:center;list-style:none}
.nav-links a{color:var(--color-text);font-size:.92rem;font-weight:500;transition:color .2s}
.nav-links a:not(.btn):hover{color:var(--color-nav-hover);text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:2px}
.btn{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:.95rem;background:var(--color-accent);color:var(--color-accent-ink);padding:12px 26px;border-radius:8px;transition:transform .15s,filter .15s}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.btn-sm{padding:9px 18px;font-size:.85rem}
.btn-ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-line)}
.btn-ghost:hover{border-color:var(--color-accent);color:var(--color-accent)}
.btn-red{background:var(--color-red);color:#fff}
.btn-dark-ink{color:#171206}

/* ---------- Light contrast sections ---------- */
.section-light{background:var(--color-light);color:var(--light-text)}
.section-light .section-head h2,.section-light h3{color:var(--light-text)}
.section-light .section-head p,.section-light p{color:var(--light-dim)}
.section-light .eyebrow{color:var(--color-red)}
.section-cream2{background:var(--color-light-2);color:var(--light-text)}
.section-cream2 h2,.section-cream2 .logo{color:var(--light-text)}
.section-cream2 p{color:var(--light-dim)}
.section-cream2 .eyebrow{color:var(--color-red)}
.section-cream2 .guarantee{background:#fff;border-color:var(--color-light-line);border-left-color:var(--color-red);color:var(--light-dim)}
.section-cream2 .guarantee b{color:var(--light-text)}

/* ---------- Hero with six-string motif ---------- */
.hero{position:relative;padding:96px 0 80px;overflow:hidden;border-bottom:1px solid var(--color-line);background:radial-gradient(120% 90% at 80% 0%,rgba(216,61,37,.10),transparent 55%),radial-gradient(90% 80% at 10% 100%,rgba(200,69,59,.08),transparent 50%)}
.strings{position:absolute;inset:0;display:flex;justify-content:space-evenly;pointer-events:none}
.strings i{width:1px;background:linear-gradient(to bottom,transparent,var(--color-line) 18%,var(--color-line) 82%,transparent)}
.strings i:nth-child(3){background:linear-gradient(to bottom,transparent,rgba(216,61,37,.35) 18%,rgba(216,61,37,.35) 82%,transparent)}
.strings i:nth-child(4){background:linear-gradient(to bottom,transparent,rgba(200,69,59,.30) 18%,rgba(200,69,59,.30) 82%,transparent)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(2.4rem,5.4vw,4rem);font-weight:900;margin:18px 0 20px}
.hero h1 em{font-style:normal;color:var(--color-accent)}
.hero p.lead{font-size:1.13rem;color:var(--color-text-dim);max-width:32em;margin-bottom:32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-art{position:relative}
.hero-art img{border-radius:12px;box-shadow:0 30px 60px rgba(0,0,0,.55);transform:rotate(2deg)}
.hero-badge{position:absolute;top:-16px;right:-10px;background:var(--color-accent);color:var(--color-accent-ink);font-family:var(--font-mono);font-weight:700;font-size:.78rem;padding:8px 14px;border-radius:999px;transform:rotate(6deg);box-shadow:0 10px 24px rgba(0,0,0,.4)}

/* ---------- Stats ---------- */
.stats{border-bottom:1px solid var(--color-line)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:34px 20px;text-align:center;border-left:1px solid var(--color-line)}
.stat:first-child{border-left:0}
.stat-ico{width:36px;height:36px;margin:0 auto 12px;display:block;color:var(--color-teal)}
.stat b{display:block;font-family:var(--font-display);font-weight:900;font-size:1.9rem;letter-spacing:-.02em}
.stat:nth-child(1) b{color:var(--color-accent)}
.stat:nth-child(2) b{color:var(--color-red)}
.stat:nth-child(3) b{color:var(--color-teal)}
.stat:nth-child(4) b{color:var(--color-accent)}
.stat span{font-size:.85rem;color:var(--color-text-dim)}

/* ---------- Sections ---------- */
section{padding:88px 0}
.section-head{max-width:620px;margin-bottom:52px}
.section-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:900;margin-top:14px}
.section-head p{color:var(--color-text-dim);margin-top:12px}

/* ---------- Product grid (Shopify style) ---------- */
.store{background:linear-gradient(180deg,#faf7f0 0%,#f0ead9 100%);color:var(--light-text)}
.store .section-head h2{color:var(--light-text)}
.store .section-head p{color:var(--light-dim)}
.store .eyebrow{color:var(--color-red)}
.products{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:var(--color-surface);border:1px solid var(--color-line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,border-color .2s}
.card:hover{transform:translateY(-5px);border-color:var(--color-accent)}
.card-img{background:var(--color-surface-2);padding:28px;display:flex;align-items:center;justify-content:center;min-height:280px}
.card-img img{max-height:260px;width:auto;border-radius:4px;box-shadow:0 14px 30px rgba(0,0,0,.45)}
.card-body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-tag{font-family:var(--font-mono);font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--color-teal)}
.card h3{font-size:1.18rem;font-weight:700}
.card p{font-size:.9rem;color:var(--color-text-dim);flex:1}
.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.price{font-family:var(--font-mono);font-weight:700;font-size:1.15rem;color:var(--color-accent)}
.card.bundle{border-color:var(--color-accent);position:relative}
.card.bundle::before{content:"BEST VALUE";position:absolute;top:14px;left:14px;background:var(--color-red);color:#fff;font-family:var(--font-mono);font-size:.62rem;font-weight:700;letter-spacing:.12em;padding:5px 10px;border-radius:4px;z-index:2}

/* ---------- Look inside ---------- */
.feature{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;padding:60px 0;border-top:1px solid var(--color-line)}
.feature:first-of-type{border-top:0;padding-top:0}
.feature img{border-radius:10px;box-shadow:0 24px 50px rgba(0,0,0,.5)}
.feature h3{font-size:1.7rem;font-weight:900;margin:12px 0 18px}
.feature ul{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:26px}
.feature li{padding-left:26px;position:relative;color:var(--color-text-dim);font-size:.97rem}
.feature li::before{content:"";position:absolute;left:0;top:9px;width:12px;height:2px;background:var(--color-accent)}
.feature li b{color:var(--color-text)}
.section-light .feature{border-top-color:var(--color-light-line)}
.section-light .feature li{color:var(--light-dim)}
.section-light .feature li b{color:var(--light-text)}
.section-light .feature img{box-shadow:0 24px 50px rgba(0,0,0,.18)}

/* ---------- Testimonials ---------- */
.testimonials{background:linear-gradient(180deg,#f5f1e8 0%,#ece4d2 100%);border-top:1px solid var(--color-light-line);border-bottom:1px solid var(--color-light-line);color:var(--light-text)}
.testimonials .section-head h2{color:var(--light-text)}
.testimonials .section-head p{color:var(--light-dim)}
.testimonials .eyebrow{color:var(--color-red)}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.quote{background:#fff;border:1px solid var(--color-light-line);border-radius:14px;padding:28px}
.stars{color:var(--color-accent);letter-spacing:3px;font-size:.95rem;margin-bottom:14px}
.quote p{font-size:.95rem;color:var(--light-dim)}
.quote footer{margin-top:18px}
.quote footer b{display:block;font-size:.92rem;color:var(--light-text)}
.quote footer span{font-size:.8rem;color:var(--light-dim)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:280px 1fr;gap:54px;align-items:start}
.about-grid img{border-radius:12px}
.about-grid h2{font-size:2rem;font-weight:900;margin:14px 0 18px}
.about-grid p{color:var(--color-text-dim);margin-bottom:14px}
.guarantee{margin-top:26px;background:var(--color-surface);border:1px solid var(--color-line);border-left:3px solid var(--color-accent);border-radius:10px;padding:20px 24px;font-size:.92rem}

/* ---------- Final CTA ---------- */
.cta-final{text-align:center;background:linear-gradient(180deg,#faf7f0 0%,#f0ead9 100%);border-top:1px solid var(--color-light-line);color:var(--light-text)}
.cta-final h2{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:900;max-width:18em;margin:14px auto 16px;color:var(--light-text)}
.cta-final p{color:var(--light-dim);margin-bottom:30px}
.cta-final .eyebrow{color:var(--color-red)}

/* ---------- Footer (3 columns) ---------- */
footer.site{border-top:1px solid var(--color-line);background:var(--color-surface);padding:64px 0 36px;font-size:.88rem;color:var(--color-text-dim)}
.foot-cols{display:grid;grid-template-columns:1.1fr 1.4fr 1fr;gap:48px;align-items:start}
.foot-col h4{font-family:var(--font-mono);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--color-text);margin-bottom:16px}
.foot-col .logo{font-size:1.4rem;margin-bottom:14px;display:inline-block}
.foot-col p{font-size:.9rem;color:var(--color-text-dim);max-width:30em}
.foot-links-v{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:6px}
.foot-links-v a{color:var(--color-text-dim);font-size:.9rem}
.foot-links-v a:hover{color:var(--color-accent)}
/* newsletter form */
.newsletter{display:flex;gap:8px;margin-top:6px;max-width:380px}
.newsletter input{flex:1;background:var(--color-bg);border:1px solid var(--color-line);border-radius:8px;padding:12px 14px;color:var(--color-text);font-family:var(--font-body);font-size:.92rem}
.newsletter input::placeholder{color:var(--color-text-dim)}
.newsletter input:focus{outline:none;border-color:var(--color-accent)}
.newsletter button{border:0;cursor:pointer;white-space:nowrap}
/* social icons */
.socials{display:flex;gap:12px;margin-top:6px}
.socials a{width:42px;height:42px;border:1px solid var(--color-line);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--color-text-dim);transition:all .2s}
.socials a:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-2px)}
.socials svg{width:20px;height:20px}
.foot-bottom{border-top:1px solid var(--color-line);margin-top:44px;padding-top:24px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.82rem}
.foot-bottom .foot-links{display:flex;gap:20px;list-style:none}
.foot-bottom .foot-links a{color:var(--color-text-dim)}
.foot-bottom .foot-links a:hover{color:var(--color-text)}

/* ============================================================
   BLOG PAGE STYLE — white background, dark readable text
   ============================================================ */
.blog-page{background:var(--blog-bg);color:var(--blog-text);min-height:100vh}
.blog-page .blog-header{background:var(--color-bg);border-bottom:1px solid var(--color-line)}
.blog-article{max-width:720px;margin:0 auto;padding:72px 24px 96px}
.blog-article .eyebrow{color:#D83D25}
.blog-article h1{font-size:clamp(2rem,4.6vw,3rem);font-weight:900;color:var(--blog-text);margin:16px 0 14px}
.blog-meta{font-size:.88rem;color:var(--blog-dim);margin-bottom:38px;padding-bottom:24px;border-bottom:1px solid #e7e7ea}
/* byline with avatar */
.blog-byline{display:flex;align-items:center;gap:12px;margin-bottom:38px;padding-bottom:24px;border-bottom:1px solid #e7e7ea}
.blog-byline img{width:46px;height:46px;border-radius:50%;object-fit:cover;flex:none;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.blog-byline .by-name{font-weight:600;color:var(--blog-text);font-size:.95rem}
.blog-byline .by-meta{font-size:.82rem;color:var(--blog-dim)}
/* author box */
.author-box{margin-top:56px;padding:28px;background:#f6f3ec;border:1px solid #eadfc8;border-radius:14px;display:flex;gap:22px;align-items:flex-start}
.author-box img{width:88px;height:88px;border-radius:50%;object-fit:cover;flex:none;box-shadow:0 6px 16px rgba(0,0,0,.2)}
.author-box .ab-name{font-family:var(--font-display);font-weight:900;font-size:1.2rem;color:var(--blog-text);margin-bottom:2px}
.author-box .ab-role{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#b53a26;margin-bottom:12px}
.author-box p{font-size:.95rem;line-height:1.7;color:var(--blog-dim);margin-bottom:14px}
.author-box .ab-social{display:flex;gap:10px}
.author-box .ab-social a{width:34px;height:34px;border:1px solid #ddd0b5;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#7a7263;transition:all .2s}
.author-box .ab-social a:hover{border-color:#D83D25;color:#D83D25}
.author-box .ab-social svg{width:17px;height:17px}
.blog-article p{font-size:1.08rem;line-height:1.85;color:var(--blog-text);margin-bottom:24px}
.blog-article h2{font-size:1.55rem;font-weight:700;color:var(--blog-text);margin:42px 0 16px}
.blog-article blockquote{border-left:3px solid var(--color-accent);padding:6px 0 6px 22px;margin:30px 0;font-style:italic;color:var(--blog-dim);font-size:1.1rem}
.blog-cta{margin-top:48px;background:#f6f3ec;border:1px solid #eadfc8;border-radius:14px;padding:28px;display:flex;gap:24px;align-items:center}
.blog-cta img{width:110px;border-radius:6px;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.blog-cta h3{font-size:1.15rem;margin-bottom:6px;color:var(--blog-text)}
.blog-cta p{font-size:.92rem;color:var(--blog-dim);margin:0 0 14px}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .hero-grid,.feature,.about-grid{grid-template-columns:1fr}
  .hero-art{max-width:380px;margin:0 auto}
  .products,.quotes{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(3){border-left:0}
  .stat{border-top:1px solid var(--color-line)}
  .stat:nth-child(-n+2){border-top:0}
  .nav-links li:not(:last-child){display:none}
}
@media(max-width:600px){
  .products,.quotes{grid-template-columns:1fr}
  section{padding:64px 0}
  .blog-cta{flex-direction:column;text-align:center}
  .foot-cols{grid-template-columns:1fr;gap:36px}
  .newsletter{max-width:none}
}

/* ============================================================
   HAMBURGER / MOBILE NAV (added for WordPress theme)
   ============================================================ */
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;margin:-8px;z-index:60}
@media(min-width:901px){
  .nav-toggle{display:none !important}
}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--color-text);margin:5px 0;transition:transform .25s,opacity .25s}
.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-open .nav-toggle span:nth-child(2){opacity:0}
.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:900px){
  .nav-toggle{display:block}
  /* Header becomes the positioning context; the menu drops below it full-width */
  header .nav{position:relative;flex-wrap:wrap}
  header .nav .logo{order:1}
  .nav-toggle{order:2}
  .nav-links{
    /* Hidden by default via max-height collapse; expands to fit ALL links */
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    flex-basis:100%;width:100%;order:3;
    max-height:0;overflow:hidden;
    transition:max-height .32s ease;
    background:var(--color-surface);
    margin:0 -24px;padding:0 24px;          /* bleed to full screen width */
  }
  .nav-open .nav-links{
    max-height:80vh;overflow-y:auto;-webkit-overflow-scrolling:touch;
    border-top:1px solid var(--color-line);margin-top:16px;
  }
  .nav-links li{width:100%;border-bottom:1px solid var(--color-line)}
  .nav-links li:last-child{border-bottom:0}
  .nav-links a{display:block;width:100%;padding:16px 0;font-size:1.08rem}
  .nav-links li:not(:last-child){display:block}      /* override desktop hide rule */
  /* The bundle button sits as a full-width button at the bottom of the list */
  .nav-links a.btn{margin:14px 0;text-align:center;padding:14px 0}
  .nav-links li.gpp-header-cta{border-bottom:0}
}

/* ============================================================
   WordPress-specific helpers
   ============================================================ */
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.sticky,.bypostauthor{display:block}
.wp-caption{max-width:100%}
.wp-caption-text{font-size:.82rem;color:var(--color-text-dim);text-align:center;margin-top:6px}
.aligncenter{margin-left:auto;margin-right:auto}
.alignright{float:right;margin:0 0 1em 1.5em}
.alignleft{float:left;margin:0 1.5em 1em 0}
/* native WP nav menu may add classes; keep our look */
.nav-links .menu-item a{color:inherit}
/* pagination */
.posts-nav{max-width:720px;margin:0 auto;padding:0 24px 80px;display:flex;justify-content:space-between;gap:16px}
.posts-nav a{color:var(--color-accent);font-weight:600}
/* blog index cards */
.blog-list{max-width:760px;margin:0 auto;padding:64px 24px 80px}
.post-card{padding:28px 0;border-bottom:1px solid var(--color-line)}
.post-card h2{font-size:1.5rem;margin-bottom:8px}
.post-card h2 a{color:var(--color-text)}
.post-card h2 a:hover{color:var(--color-accent)}
.post-card .post-meta{font-size:.85rem;color:var(--color-text-dim);margin-bottom:10px}
.post-card p{color:var(--color-text-dim)}

/* ============================================================
   Gutenberg block bridges — make editor blocks match the draft
   ============================================================ */
/* Buy buttons rendered as core/button blocks */
.wp-block-button.btn .wp-block-button__link,
.wp-block-button .wp-block-button__link{
  font-family:var(--font-display);font-weight:700;font-size:.85rem;
  background:var(--color-accent);color:var(--color-accent-ink);
  padding:9px 18px;border-radius:8px;transition:transform .15s,filter .15s;
}
.wp-block-button .wp-block-button__link:hover{filter:brightness(1.08);transform:translateY(-1px)}
.wp-block-buttons{margin:0}
/* core/group wrappers shouldn't add their own spacing inside cards */
.card .wp-block-group,.card-body.wp-block-group,.card-foot.wp-block-group{margin:0}
.card-foot.wp-block-group{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.card-body.wp-block-group{padding:22px 22px 26px;display:flex;flex-direction:column;gap:10px;flex:1}
/* the products grid is emitted around the editable card groups */
.products > .wp-block-group{margin:0}

/* ============================================================
   Store as a block group (pattern uses core/group, not <section>)
   Restore the section padding/light-gradient behavior.
   ============================================================ */
.wp-block-group.store{padding:88px 0;background:linear-gradient(180deg,#faf7f0 0%,#f0ead9 100%);color:var(--light-text)}
.wp-block-group.store .section-head h2{color:var(--light-text)}
.wp-block-group.store .section-head p{color:var(--light-dim)}
.wp-block-group.store .eyebrow{color:var(--color-red)}
/* the inner .wrap group keeps the same max-width container */
.wp-block-group.wrap{max-width:1140px;margin:0 auto;padding:0 24px}
/* products grid as a group */
.wp-block-group.products{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media(max-width:920px){ .wp-block-group.products{grid-template-columns:repeat(2,1fr)} }
@media(max-width:600px){ .wp-block-group.products{grid-template-columns:1fr} }
/* neutralize default block group margins that would break the grid */
.wp-block-group.products > .wp-block-group{margin-top:0}
.wp-block-group.store .section-head{margin-bottom:52px}
