/*
Theme Name: Harini Sangeeta Jhari
Theme URI: https://singingclassesnearme.com
Author: Harini Sangeeta Jhari
Description: Premium, mobile-first, SEO-optimized WordPress theme for online singing classes by Harini Sangeeta Jhari. Includes high-converting landing pages, WhatsApp integration, blog with FAQ schema, and a fully customizable Customizer panel.
Version: 1.0.0
License: GPL-2.0-or-later
Text Domain: hsj
Tags: education, music, one-column, custom-logo, custom-colors, custom-menu, featured-images, threaded-comments, translation-ready, blog, portfolio
*/

:root{
  --maroon:#800000;
  --maroon-dark:#5e0000;
  --maroon-glow:#a31515;
  --gold:#D4AF37;
  --gold-glow:#e9c558;
  --cream:#FFF9EF;
  --cream-2:#FBF1DE;
  --ink:#2a0808;
  --muted:#6b5a52;
  --border:#e7dccb;
  --whatsapp:#25D366;
  --shadow-soft:0 4px 20px -4px rgba(42,8,8,.08);
  --shadow-elegant:0 20px 60px -20px rgba(42,8,8,.25);
  --shadow-gold:0 10px 40px -10px rgba(212,175,55,.45);
  --shadow-maroon:0 12px 30px -8px rgba(128,0,0,.35);
  --grad-cta:linear-gradient(135deg,#800000 0%,#a31515 50%,#D4AF37 100%);
  --grad-gold:linear-gradient(135deg,#D4AF37,#e9c558);
  --grad-hero:linear-gradient(135deg,#FBF1DE 0%,#F4E4C5 50%,#EAD3A0 100%);
  --radius:14px;
  --radius-lg:22px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--maroon);text-decoration:none;transition:.25s}
a:hover{color:var(--gold)}

h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;color:var(--maroon);margin:0 0 .6em;line-height:1.15;font-weight:700}
h1{font-size:clamp(2rem,5vw,3.4rem)}
h2{font-size:clamp(1.6rem,3.6vw,2.4rem)}
h3{font-size:clamp(1.25rem,2.4vw,1.5rem)}
p{margin:0 0 1em}

.container{max-width:1180px;margin:0 auto;padding:0 20px}
section{padding:60px 0}
@media(min-width:768px){section{padding:90px 0}}

/* === Buttons === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  padding:14px 26px;border-radius:999px;font-weight:600;font-size:.98rem;
  border:0;cursor:pointer;transition:.3s;white-space:nowrap;line-height:1;
}
.btn-lg{padding:17px 32px;font-size:1.05rem}
.btn-xl{padding:20px 38px;font-size:1.12rem}
.btn-primary{background:var(--grad-cta);color:#fff;box-shadow:var(--shadow-maroon)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-gold);color:#fff}
.btn-gold{background:var(--grad-gold);color:#3b2208;box-shadow:var(--shadow-gold)}
.btn-gold:hover{transform:translateY(-2px);color:#3b2208}
.btn-outline{background:transparent;color:var(--maroon);border:2px solid var(--maroon)}
.btn-outline:hover{background:var(--maroon);color:#fff}
.btn-wa{background:var(--whatsapp);color:#fff}
.btn-wa:hover{background:#1ebe5d;color:#fff;transform:translateY(-2px)}
.btn .ico{width:20px;height:20px;flex:0 0 20px}

/* === Announcement Bar === */
.announce{
  background:linear-gradient(90deg,var(--maroon),var(--maroon-glow),var(--gold),var(--maroon-glow),var(--maroon));
  background-size:300% 100%;
  animation:shimmer 8s linear infinite;
  color:#fff;text-align:center;font-size:.85rem;padding:9px 14px;font-weight:500
}
.announce strong{color:#FFE9A8}
@keyframes shimmer{0%{background-position:0 0}100%{background-position:300% 0}}

/* === Header === */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,249,239,.92);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border)
}
.header-row{display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:46px;width:46px;border-radius:50%;object-fit:contain;background:#fff;box-shadow:var(--shadow-soft)}
.brand-text{font-family:'Playfair Display',serif;font-weight:700;color:var(--maroon);line-height:1.1;font-size:1.05rem}
.brand-text span{color:var(--gold);display:block;font-size:.85rem;letter-spacing:.5px}
.main-nav{display:none;gap:26px}
.main-nav a{color:#3b2208;font-weight:500;font-size:.94rem}
.main-nav a:hover{color:var(--maroon)}
@media(min-width:900px){.main-nav{display:flex}}
.menu-toggle{background:none;border:0;color:var(--maroon);padding:6px;cursor:pointer;display:block}
@media(min-width:900px){.menu-toggle{display:none}}
.mobile-nav{display:none;flex-direction:column;padding:14px 20px 20px;border-top:1px solid var(--border);background:var(--cream)}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:10px 0;font-weight:500;color:#3b2208;border-bottom:1px solid var(--border)}
.mobile-nav .btn{margin-top:14px}
.header-cta{display:none}
@media(min-width:900px){.header-cta{display:inline-flex}}

/* === Hero === */
.hero{background:var(--grad-hero);position:relative;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 20% 30%,rgba(128,0,0,.08) 1px,transparent 1px),radial-gradient(circle at 70% 60%,rgba(212,175,55,.12) 1px,transparent 1px);
  background-size:60px 60px,80px 80px;opacity:.5;pointer-events:none
}
.hero-grid{display:grid;gap:40px;align-items:center;position:relative}
@media(min-width:900px){.hero-grid{grid-template-columns:1.1fr 1fr;gap:60px}}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;background:rgba(212,175,55,.15);
  border:1px solid rgba(212,175,55,.4);padding:6px 14px;border-radius:999px;
  font-size:.82rem;color:#3b2208;margin-bottom:14px;font-weight:500
}
.urgency-pill{
  display:inline-flex;align-items:center;gap:8px;background:rgba(128,0,0,.1);
  border:1px solid rgba(128,0,0,.25);padding:5px 12px;border-radius:999px;
  font-size:.72rem;color:var(--maroon);text-transform:uppercase;letter-spacing:1px;
  font-weight:700;margin-bottom:18px
}
.urgency-pill .dot{width:8px;height:8px;background:var(--maroon);border-radius:50%;position:relative}
.urgency-pill .dot::after{content:"";position:absolute;inset:0;background:var(--maroon);border-radius:50%;animation:ping 1.6s cubic-bezier(0,0,.2,1) infinite}
@keyframes ping{75%,100%{transform:scale(2.2);opacity:0}}
.hero h1 .hl{position:relative;display:inline-block}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:4px;height:12px;background:rgba(212,175,55,.4);z-index:-1;border-radius:3px}
.hero .tagline{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold);font-size:1.25rem;margin:8px 0 0}
.hero p.lead{font-size:1.1rem;color:#5a3d2e;margin-top:18px;max-width:560px}
.hero-ctas{display:flex;flex-direction:column;gap:12px;margin-top:28px}
@media(min-width:560px){.hero-ctas{flex-direction:row}}
.hero-trust{display:flex;flex-wrap:wrap;gap:22px;margin-top:28px;color:#6b5a52;font-size:.92rem}
.hero-trust .item{display:flex;align-items:center;gap:8px}
.hero-image-wrap{position:relative}
.hero-image-wrap::before{content:"";position:absolute;inset:-16px;background:var(--grad-gold);border-radius:32px;opacity:.3;filter:blur(40px)}
.hero-image{position:relative;border-radius:28px;overflow:hidden;box-shadow:var(--shadow-elegant);border:4px solid #fff;animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hero-badge{position:absolute;bottom:-14px;left:-10px;background:#fff;border-radius:18px;padding:12px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-elegant)}
.hero-badge .star{width:46px;height:46px;border-radius:50%;background:var(--grad-gold);display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.3rem;color:#3b2208;font-weight:700}
.hero-badge .lbl{font-size:.85rem;font-weight:600;color:var(--maroon);line-height:1.2}
.hero-badge .sub{font-size:.72rem;color:#6b5a52}

/* === Section heading === */
.sec-eyebrow{display:block;text-align:center;font-size:.82rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:3px;margin-bottom:10px}
.sec-title{text-align:center;max-width:720px;margin:0 auto 14px}
.sec-sub{text-align:center;max-width:680px;margin:0 auto 50px;color:#6b5a52;font-size:1.08rem}

/* === Cards / Grids === */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:1fr}
.grid-3{grid-template-columns:1fr}
.grid-4{grid-template-columns:1fr}
@media(min-width:640px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}

.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;box-shadow:var(--shadow-soft);transition:.35s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant)}
.card .ic{width:54px;height:54px;border-radius:14px;background:rgba(212,175,55,.15);display:flex;align-items:center;justify-content:center;color:var(--maroon);margin-bottom:14px;font-size:1.5rem}
.card h3{font-size:1.2rem;margin-bottom:8px}
.card p{margin:0;color:#5a4a42;font-size:.97rem}

/* === Pain/Solution === */
.ps-grid{display:grid;gap:24px;grid-template-columns:1fr}
@media(min-width:900px){.ps-grid{grid-template-columns:1fr 1fr}}
.ps-card{padding:30px;border-radius:var(--radius-lg);border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-soft)}
.ps-card.pain{border-left:5px solid #c84444}
.ps-card.solution{border-left:5px solid var(--gold);background:linear-gradient(135deg,#fff,#fdf5e3)}
.ps-card ul{padding-left:20px;margin:0;color:#5a4a42}
.ps-card li{margin-bottom:8px}

/* === Steps === */
.steps{display:grid;gap:30px;grid-template-columns:1fr;counter-reset:step}
@media(min-width:900px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{position:relative;background:#fff;padding:34px 26px 26px;border-radius:var(--radius-lg);border:1px solid var(--border);text-align:center;box-shadow:var(--shadow-soft);counter-increment:step}
.step::before{content:counter(step,decimal-leading-zero);position:absolute;top:-22px;left:50%;transform:translateX(-50%);background:var(--grad-cta);color:#fff;width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-weight:700;font-size:1.1rem;box-shadow:var(--shadow-maroon)}

/* === Courses === */
.course{position:relative;padding:32px 26px;border-radius:var(--radius-lg);background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-soft);transition:.35s}
.course:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant)}
.course.featured{background:var(--grad-cta);color:#fff;transform:scale(1.02);box-shadow:var(--shadow-elegant)}
.course.featured h3,.course.featured p,.course.featured li{color:#fff}
.course .badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--grad-gold);color:#3b2208;font-weight:700;font-size:.72rem;padding:6px 16px;border-radius:999px;text-transform:uppercase;letter-spacing:1.5px;box-shadow:var(--shadow-gold)}
.course ul{list-style:none;padding:0;margin:18px 0 24px}
.course li{display:flex;align-items:flex-start;gap:10px;padding:6px 0;font-size:.96rem}
.course li::before{content:"✓";flex:0 0 22px;height:22px;background:var(--gold);color:#3b2208;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem;margin-top:2px}
.course.featured li::before{background:var(--gold-glow)}
.course .price{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;margin-bottom:6px}

/* === Testimonials === */
.t-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;box-shadow:var(--shadow-soft);position:relative}
.t-card .quote-mark{font-family:'Playfair Display',serif;font-size:4rem;line-height:.7;color:var(--gold);opacity:.5;position:absolute;top:14px;right:20px}
.t-card .stars{color:var(--gold);margin-bottom:12px;letter-spacing:2px}
.t-card .name{font-weight:700;color:var(--maroon);margin-top:14px}
.t-card .role{font-size:.85rem;color:#6b5a52}

/* === Premium Offer === */
.offer{background:linear-gradient(135deg,#3b0000,#800000 60%,#a31515);color:#fff;border-radius:28px;padding:50px 30px;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-elegant)}
.offer::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(212,175,55,.25),transparent 60%);pointer-events:none}
.offer h2{color:#fff}
.offer .price-row{display:flex;align-items:center;justify-content:center;gap:18px;margin:18px 0 8px;flex-wrap:wrap}
.offer .strike{font-size:1.4rem;color:rgba(255,255,255,.55);text-decoration:line-through}
.offer .free{font-family:'Playfair Display',serif;font-size:3rem;color:var(--gold);font-weight:800;line-height:1}
.offer .progress{max-width:420px;margin:24px auto 6px;background:rgba(255,255,255,.18);height:10px;border-radius:99px;overflow:hidden}
.offer .progress span{display:block;height:100%;background:var(--grad-gold);width:70%;border-radius:99px}
.offer .small{font-size:.85rem;color:rgba(255,255,255,.75);margin-top:6px}
.offer .btn{margin-top:24px}
.offer .guards{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin-top:24px;font-size:.9rem;color:rgba(255,255,255,.85)}

/* === FAQ === */
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:14px;overflow:hidden;box-shadow:var(--shadow-soft)}
.faq-q{padding:18px 22px;cursor:pointer;font-weight:600;color:var(--maroon);display:flex;justify-content:space-between;align-items:center;font-size:1.02rem;background:none;border:0;width:100%;text-align:left;font-family:inherit}
.faq-q::after{content:"+";font-size:1.6rem;color:var(--gold);transition:.3s;font-weight:300}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{padding:0 22px;max-height:0;overflow:hidden;transition:.4s;color:#5a4a42}
.faq-item.open .faq-a{padding:0 22px 20px;max-height:600px}

/* === Footer === */
.site-footer{background:var(--maroon);color:#f6e9d4;padding:60px 0 24px;margin-top:60px}
.site-footer h2,.site-footer h3{color:#fff}
.foot-cta{text-align:center;max-width:640px;margin:0 auto 40px}
.foot-cta p{color:rgba(246,233,212,.8)}
.foot-grid{display:grid;gap:30px;grid-template-columns:1fr;margin-bottom:30px}
@media(min-width:768px){.foot-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.foot-grid h4{color:var(--gold);font-size:1rem;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:14px;font-family:'Inter',sans-serif;font-weight:700}
.foot-grid a{color:#f6e9d4;display:block;padding:5px 0;font-size:.95rem}
.foot-grid a:hover{color:var(--gold)}
.socials{display:flex;gap:10px;margin-top:14px}
.socials a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;color:#fff;padding:0}
.socials a:hover{background:var(--gold);color:#3b2208}
.copy{text-align:center;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;font-size:.85rem;color:rgba(246,233,212,.65)}

/* === Sticky bottom CTA (mobile) === */
.sticky-bottom{
  position:fixed;left:0;right:0;bottom:0;z-index:60;background:#fff;
  border-top:1px solid var(--border);padding:10px 14px;display:flex;gap:8px;
  box-shadow:0 -8px 24px rgba(0,0,0,.08)
}
.sticky-bottom .btn{flex:1;padding:13px 12px;font-size:.92rem}
@media(min-width:900px){.sticky-bottom{display:none}}
body{padding-bottom:80px}
@media(min-width:900px){body{padding-bottom:0}}

/* === Floating WhatsApp === */
.fab-wa{
  position:fixed;right:20px;bottom:90px;z-index:55;width:60px;height:60px;
  border-radius:50%;background:var(--whatsapp);color:#fff;display:flex;
  align-items:center;justify-content:center;box-shadow:0 8px 30px rgba(37,211,102,.45);
  animation:pulse 2s infinite
}
@media(min-width:900px){.fab-wa{bottom:24px}}
.fab-wa:hover{color:#fff;transform:scale(1.05)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 20px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* === Forms === */
.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-row label{font-weight:600;color:var(--maroon);font-size:.92rem}
.form-row input,.form-row select,.form-row textarea{
  padding:13px 16px;border:1px solid var(--border);border-radius:12px;
  font:inherit;background:#fff;color:var(--ink);transition:.25s
}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:0;border-color:var(--maroon);box-shadow:0 0 0 3px rgba(128,0,0,.12)
}

/* === Blog === */
.post-grid{display:grid;gap:30px;grid-template-columns:1fr}
@media(min-width:700px){.post-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1000px){.post-grid{grid-template-columns:repeat(3,1fr)}}
.post-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft);transition:.35s}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant)}
.post-card .thumb{aspect-ratio:16/10;background:var(--grad-hero) center/cover}
.post-card .body{padding:22px}
.post-card h3{font-size:1.15rem;margin-bottom:8px}
.post-card .meta{font-size:.82rem;color:#9c8678;margin-bottom:10px}
.single-post-wrap{max-width:780px;margin:0 auto}
.single-post-wrap h1{margin-bottom:8px}
.post-meta{color:#9c8678;font-size:.9rem;margin-bottom:30px}
.entry-content h2{margin-top:1.4em}
.entry-content h3{margin-top:1.2em}
.entry-content ul,.entry-content ol{padding-left:22px}
.entry-content blockquote{border-left:4px solid var(--gold);padding:10px 20px;margin:20px 0;background:#fdf5e3;font-style:italic;border-radius:6px}

/* === Utility === */
.text-center{text-align:center}
.mt-0{margin-top:0}.mt-20{margin-top:20px}.mt-40{margin-top:40px}
.hidden-mobile{display:none}
@media(min-width:768px){.hidden-mobile{display:initial}.hidden-desktop{display:none}}

/* WP core compat */
.wp-block-image,.alignwide,.alignfull{margin:1.5em 0}
.screen-reader-text{position:absolute;left:-9999px}
