/*
Theme Name: Vishv Publishers
Theme URI: https://vishvpublishers.example
Author: Vishv Publishers
Author URI: https://vishvpublishers.example
Description: Warm editorial landing page for Vishv Publishers handwriting work program. Animated, responsive, single-page landing theme.
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vishv-publishers
Tags: landing-page, one-column, custom-colors, custom-logo, editor-style, full-width-template
*/

:root{
  --bg:#fbf7ee;
  --fg:#2b1d12;
  --muted:#7a6a5a;
  --card:#ffffff;
  --border:#ece2cf;
  --secondary:#f3ead7;
  --primary:#b04a1e;
  --primary-fg:#fffaf2;
  --accent:#e2a043;
  --accent-fg:#2b1d12;
  --destructive:#c0392b;
  --radius:1rem;
  --shadow-soft:0 10px 40px -10px rgba(80,40,10,.18);
  --shadow-elegant:0 25px 60px -20px rgba(80,40,10,.28);
  --shadow-glow:0 0 60px rgba(226,160,67,.45);
  --gradient-hero:radial-gradient(ellipse at top,#fbeed4 0%,#fbf3e1 60%);
  --gradient-warm:linear-gradient(135deg,#fbeed4 0%,#f5d7a7 50%,#eebf86 100%);
  --gradient-accent:linear-gradient(135deg,#e2a043,#b04a1e);
}

*{box-sizing:border-box;border-color:var(--border)}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--fg);
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Fraunces','Playfair Display',Georgia,serif;letter-spacing:-.02em;margin:0;line-height:1.1}
p{margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}

.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}

/* NAV */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(251,247,238,.75);
  border-bottom:1px solid rgba(236,226,207,.6);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;max-width:1200px;margin:0 auto}
.brand{display:flex;align-items:center;gap:.6rem;font-family:'Fraunces',serif;font-size:1.2rem;font-weight:600}
.brand-mark{width:36px;height:36px;border-radius:12px;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;color:var(--primary-fg);box-shadow:var(--shadow-soft)}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.4rem;border-radius:999px;font-weight:600;cursor:pointer;border:none;transition:.3s;font-size:.95rem}
.btn-primary{background:var(--primary);color:var(--primary-fg);box-shadow:var(--shadow-soft)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}
.btn-outline{background:var(--card);border:1px solid var(--border)}
.btn-outline:hover{background:var(--secondary)}
.btn-lg{padding:1rem 1.75rem;font-size:1rem}

/* HERO */
.hero{position:relative;background:var(--gradient-hero);overflow:hidden;padding:4rem 0 6rem}
.hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr;gap:3rem;align-items:center;max-width:1200px;margin:0 auto;padding:0 1.5rem}
@media(min-width:960px){.hero-grid{grid-template-columns:1fr 1fr}}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;z-index:1}
.blob-1{width:500px;height:500px;background:rgba(226,160,67,.5);top:-160px;left:-160px;animation:blob 12s ease-in-out infinite}
.blob-2{width:450px;height:450px;background:rgba(176,74,30,.35);bottom:-120px;right:-120px;animation:blob 12s ease-in-out infinite 3s}
.grid-bg{position:absolute;inset:0;opacity:.08;z-index:1;background-image:linear-gradient(to right,#000 1px,transparent 1px),linear-gradient(to bottom,#000 1px,transparent 1px);background-size:40px 40px}

.badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:999px;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow-soft);font-size:.875rem;font-weight:500}
.ping{position:relative;width:8px;height:8px}
.ping::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--primary);animation:pulse-ring 2.4s cubic-bezier(.4,0,.6,1) infinite}
.ping::after{content:"";position:absolute;inset:0;border-radius:50%;background:var(--primary)}

.h1{margin-top:1.5rem;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:800}
.text-gradient{background:var(--gradient-accent);-webkit-background-clip:text;background-clip:text;color:transparent}
.h1 em{font-style:normal;position:relative}
.underline-svg{position:absolute;bottom:-.5rem;left:0;width:100%}
.lead{margin-top:1.5rem;font-size:1.1rem;color:var(--muted);max-width:520px}
.cta-row{margin-top:2rem;display:flex;flex-wrap:wrap;gap:1rem}
.trust{margin-top:2.5rem;display:flex;align-items:center;gap:1.5rem}
.avatars{display:flex}
.avatars span{width:40px;height:40px;border-radius:50%;border:3px solid var(--bg);margin-left:-12px}
.avatars span:first-child{margin-left:0}
.stars{color:var(--accent);letter-spacing:2px}

.hero-visual{position:relative}
.hero-img{border-radius:1.5rem;overflow:hidden;box-shadow:var(--shadow-elegant);position:relative}
.hero-img img{width:100%;display:block}
.hero-img::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(176,74,30,.3),transparent 50%)}
.float-card{position:absolute;background:var(--card);border-radius:1rem;padding:1rem;box-shadow:var(--shadow-elegant)}
.float-card-1{left:-1rem;top:3rem;width:220px;animation:float 6s ease-in-out infinite}
.float-card-2{right:-1rem;bottom:3rem;width:200px;animation:float-slow 9s ease-in-out infinite}
.float-card .row{display:flex;align-items:center;gap:.75rem}
.avatar-circle{width:44px;height:44px;border-radius:50%;background:rgba(226,160,67,.3);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:700;color:var(--primary)}
.big-money{font-family:'Fraunces',serif;font-size:1.875rem;font-weight:700;color:var(--primary)}
.progress{height:6px;border-radius:999px;background:var(--secondary);overflow:hidden;margin-top:.5rem}
.progress span{display:block;height:100%;width:80%;background:var(--gradient-accent)}

/* MARQUEE */
.marquee-wrap{background:var(--primary);color:var(--primary-fg);overflow:hidden;padding:2rem 0;border-top:1px solid rgba(0,0,0,.05);border-bottom:1px solid rgba(0,0,0,.05)}
.marquee{display:flex;gap:3rem;white-space:nowrap;animation:marquee 30s linear infinite;font-weight:500;font-size:1.1rem}

/* STATS */
.section{padding:5rem 0}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
@media(min-width:768px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;box-shadow:var(--shadow-soft);transition:.3s}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant)}
.stat-num{font-family:'Fraunces',serif;font-size:2.5rem;font-weight:700}
.stat-label{margin-top:.5rem;color:var(--muted);font-size:.9rem}

/* SECTION HEAD */
.section-bg{background:rgba(243,234,215,.4)}
.section-head{text-align:center;max-width:640px;margin:0 auto}
.eyebrow{display:inline-block;padding:.3rem .8rem;border-radius:999px;background:rgba(226,160,67,.3);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.section-head h2{margin-top:1rem;font-size:clamp(2rem,4vw,3rem);font-weight:700}
.section-head p{margin-top:1rem;font-size:1.1rem;color:var(--muted)}

/* FEATURES */
.features{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:3.5rem}
@media(min-width:640px){.features{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.features{grid-template-columns:repeat(3,1fr)}}
.feature{background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;transition:.3s}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-elegant);border-color:rgba(176,74,30,.3)}
.feature-icon{width:56px;height:56px;border-radius:1rem;background:var(--gradient-accent);display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:var(--shadow-soft);transition:transform .3s}
.feature:hover .feature-icon{transform:scale(1.1)}
.feature h3{margin-top:1.25rem;font-size:1.25rem}
.feature p{margin-top:.5rem;color:var(--muted)}

/* HOW IT WORKS */
.steps{display:grid;grid-template-columns:1fr;gap:2rem;margin-top:5rem;position:relative}
@media(min-width:768px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;box-shadow:var(--shadow-soft);position:relative}
.step-num{width:96px;height:96px;border-radius:50%;background:var(--gradient-accent);color:var(--primary-fg);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:1.875rem;font-weight:700;box-shadow:var(--shadow-elegant);margin:-4.5rem auto 0;border:8px solid var(--bg)}
.step h3{margin-top:1.5rem;font-size:1.25rem;text-align:center}
.step p{margin-top:.75rem;text-align:center;color:var(--muted)}

/* KIT */
.kit{background:var(--gradient-warm)}
.kit-grid{display:grid;grid-template-columns:1fr;gap:3rem;align-items:center}
@media(min-width:1024px){.kit-grid{grid-template-columns:1fr 1fr}}
.kit-image{position:relative}
.kit-image::before{content:"";position:absolute;inset:-1rem;background:rgba(226,160,67,.3);border-radius:1.5rem;filter:blur(40px);animation:blob 12s ease-in-out infinite}
.kit-image img{position:relative;border-radius:1.5rem;box-shadow:var(--shadow-elegant);width:100%}
.kit h2{margin-top:1rem;font-size:clamp(2rem,4vw,3rem)}
.kit-list{margin-top:1.5rem;padding:0;list-style:none}
.kit-list li{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.check{width:24px;height:24px;border-radius:50%;background:var(--primary);color:var(--primary-fg);display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0}

/* PLANS */
.plans{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:3.5rem}
@media(min-width:768px){.plans{grid-template-columns:repeat(3,1fr)}}
.plan{background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;box-shadow:var(--shadow-soft);transition:.3s;position:relative}
.plan:hover{transform:translateY(-8px);box-shadow:var(--shadow-elegant)}
.plan.popular{background:var(--primary);color:var(--primary-fg);border-color:var(--primary);transform:scale(1.04);box-shadow:var(--shadow-elegant)}
.plan-badge{position:absolute;top:-.75rem;left:50%;transform:translateX(-50%);padding:.3rem 1rem;border-radius:999px;background:var(--accent);color:var(--accent-fg);font-size:.75rem;font-weight:600;box-shadow:var(--shadow-soft)}
.plan-name{font-size:.875rem;color:var(--muted);font-weight:500}
.plan.popular .plan-name{color:rgba(255,250,242,.7)}
.plan-price{margin-top:1rem;display:flex;align-items:baseline;gap:.25rem}
.plan-price .num{font-family:'Fraunces',serif;font-size:3rem;font-weight:700}
.plan-rows{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.plan.popular .plan-rows{border-color:rgba(255,250,242,.2)}
.plan-row{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.75rem}
.plan-row .lbl{color:var(--muted)}
.plan.popular .plan-row .lbl{color:rgba(255,250,242,.7)}
.plan-cta{display:block;text-align:center;padding:.85rem;border-radius:999px;background:var(--primary);color:var(--primary-fg);font-weight:600;margin-top:1.5rem;transition:.3s}
.plan-cta:hover{opacity:.9}
.plan.popular .plan-cta{background:var(--primary-fg);color:var(--primary)}
.plan.popular .plan-cta:hover{background:var(--accent)}

/* TESTIMONIALS */
.t-grid{display:grid;grid-template-columns:1fr;gap:1.5rem;margin-top:3.5rem}
@media(min-width:768px){.t-grid{grid-template-columns:repeat(3,1fr)}}
.t-card{background:var(--card);border:1px solid var(--border);border-radius:1.5rem;padding:2rem;box-shadow:var(--shadow-soft);position:relative;transition:.3s}
.t-card:hover{box-shadow:var(--shadow-elegant)}
.t-quote{position:absolute;top:1.5rem;right:1.5rem;font-family:'Fraunces',serif;font-size:5rem;color:rgba(226,160,67,.3);line-height:1}
.t-card p{margin-top:1rem;font-style:italic;color:rgba(43,29,18,.9)}
.t-meta{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.t-meta .name{font-weight:600}
.t-meta .city{font-size:.75rem;color:var(--muted)}
.t-meta .amt{font-family:'Fraunces',serif;font-weight:700;color:var(--primary)}

/* COMPARISON */
.compare{max-width:900px;margin:3.5rem auto 0;background:var(--card);border:1px solid var(--border);border-radius:1.5rem;overflow:hidden;box-shadow:var(--shadow-soft)}
.compare-row{display:grid;grid-template-columns:2fr 1fr 1fr;padding:1.25rem 1.5rem;align-items:center}
.compare-row.head{background:rgba(243,234,215,.6);font-weight:600}
.compare-row:nth-child(even){background:rgba(243,234,215,.2)}
.compare-row.head .col-2{color:var(--primary);text-align:center}
.compare-row.head .col-3{color:var(--muted);text-align:center}
.compare-row .col-2,.compare-row .col-3{text-align:center}
.tick{display:inline-flex;width:32px;height:32px;border-radius:50%;background:var(--primary);color:var(--primary-fg);align-items:center;justify-content:center}
.cross{display:inline-flex;width:32px;height:32px;border-radius:50%;background:rgba(192,57,43,.2);color:var(--destructive);align-items:center;justify-content:center}
.dash{display:inline-flex;width:32px;height:32px;border-radius:50%;background:var(--secondary);color:var(--muted);align-items:center;justify-content:center}

/* FAQ */
.faq-list{max-width:760px;margin:3.5rem auto 0}
.faq{background:var(--card);border:1px solid var(--border);border-radius:1rem;padding:1.5rem;margin-bottom:1rem;box-shadow:var(--shadow-soft);transition:.3s}
.faq[open]{box-shadow:var(--shadow-elegant)}
.faq summary{display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:1.1rem;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq-toggle{width:32px;height:32px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;transition:transform .3s;font-size:1.25rem}
.faq[open] .faq-toggle{transform:rotate(45deg)}
.faq p{margin-top:1rem;color:var(--muted)}

/* FINAL CTA */
.final{padding:5rem 0}
.final-box{max-width:1000px;margin:0 auto;background:var(--primary);color:var(--primary-fg);padding:4rem 2rem;border-radius:2.5rem;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-elegant)}
.final-box .blob{opacity:.4}
.final-box h2{font-size:clamp(2.5rem,5vw,3.75rem);position:relative;z-index:2}
.final-box p{margin-top:1rem;color:rgba(255,250,242,.8);max-width:560px;margin-left:auto;margin-right:auto;position:relative;z-index:2}
.final-box .btn{margin-top:2rem;background:var(--primary-fg);color:var(--primary);position:relative;z-index:2}
.final-box .btn:hover{transform:scale(1.05)}

/* FOOTER */
.footer{border-top:1px solid var(--border);padding:2.5rem 0}
.footer-inner{display:flex;flex-direction:column;gap:1rem;justify-content:space-between;align-items:center;color:var(--muted);font-size:.875rem}
@media(min-width:640px){.footer-inner{flex-direction:row}}
.footer-links{display:flex;gap:1.5rem}
.footer-links a:hover{color:var(--primary)}

/* ANIMATIONS */
@keyframes float{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(3deg)}}
@keyframes float-slow{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-30px) rotate(-4deg)}}
@keyframes blob{0%,100%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}50%{border-radius:30% 60% 70% 40%/50% 60% 30% 60%}}
@keyframes pulse-ring{0%{transform:scale(.9);opacity:.7}100%{transform:scale(1.6);opacity:0}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes fade-up{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.animate-fade-up{animation:fade-up .8s ease-out both}
.delay-2{animation-delay:.2s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
}
