/*
Theme Name: Vishav Book Publication
Theme URI: https://vishav-book.local
Author: Vishav Book Publication
Description: Animated landing page theme for Vishav Book Publication - handwriting work from home. Includes gradient animations, floating graphics, blob blurs and animated CTAs.
Version: 2.0
License: GPL v2 or later
Text Domain: vishav
*/

:root{
  --primary:#5b6ee0;
  --primary-2:#8b5cf6;
  --accent:#a78bfa;
  --bg:#ffffff;
  --fg:#0f172a;
  --muted:#64748b;
  --card:#ffffff;
  --border:#e5e7eb;
  --shadow:0 10px 30px -10px rgba(91,110,224,.25);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--fg);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

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

/* ===== Animations ===== */
@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-33.333%)}}
@keyframes float-y{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes float-x{0%,100%{transform:translateX(0) rotate(-6deg)}50%{transform:translateX(14px) rotate(6deg)}}
@keyframes spin-slow{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes blob{0%,100%{border-radius:42% 58% 60% 40%/50% 45% 55% 50%;transform:translate(0,0) scale(1)}33%{border-radius:60% 40% 35% 65%/40% 60% 40% 60%;transform:translate(20px,-15px) scale(1.05)}66%{border-radius:40% 60% 55% 45%/60% 40% 60% 40%;transform:translate(-15px,10px) scale(.97)}}
@keyframes pop-in{0%{opacity:0;transform:translateY(20px) scale(.9)}100%{opacity:1;transform:translateY(0) scale(1)}}
@keyframes pulse-ring{0%{box-shadow:0 0 0 0 rgba(91,110,224,.55)}70%{box-shadow:0 0 0 18px rgba(91,110,224,0)}100%{box-shadow:0 0 0 0 rgba(91,110,224,0)}}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes tilt{0%,100%{transform:rotate(-2deg)}50%{transform:rotate(2deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

.gradient-bg,.btn-grad{background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;animation:gradient-shift 4s ease infinite}
.gradient-text{background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradient-shift 5s ease infinite}
.animate-float{animation:float-y 6s ease-in-out infinite}
.animate-float-x{animation:float-x 7s ease-in-out infinite}
.animate-blob{animation:blob 14s ease-in-out infinite}
.animate-spin-slow{animation:spin-slow 20s linear infinite}
.animate-pop-in{animation:pop-in .7s ease-out both}
.animate-pulse-ring{animation:pulse-ring 2s ease-out infinite}
.animate-tilt{animation:tilt 6s ease-in-out infinite;transform-origin:center}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px}
.logo-icon{width:38px;height:38px;border-radius:10px;background:rgba(91,110,224,.12);color:var(--primary);display:grid;place-items:center;font-size:18px}
.nav-links{display:flex;gap:32px;color:var(--muted);font-size:14px}
.nav-links a:hover{color:var(--fg)}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:999px;font-weight:600;font-size:14px;cursor:pointer;transition:all .25s;border:none}
.btn-grad{color:#fff;box-shadow:var(--shadow)}
.btn-grad:hover{transform:scale(1.05);opacity:.95}
.btn-outline{border:1px solid var(--border);background:#fff;color:var(--fg)}
.btn-outline:hover{background:#f8fafc}
.btn-lg{padding:14px 28px;font-size:15px}

@media(max-width:768px){.nav-links{display:none}}

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;padding:64px 0}
.hero .blob-a,.hero .blob-b{position:absolute;filter:blur(80px);opacity:.4;z-index:0}
.hero .blob-a{top:-100px;left:-100px;width:420px;height:420px;background:var(--primary)}
.hero .blob-b{bottom:-100px;right:-100px;width:480px;height:480px;background:var(--accent)}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:13px;box-shadow:0 2px 6px rgba(0,0,0,.04)}
.hero-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--primary);animation:pulse-dot 1.5s infinite}
.hero h1{font-size:clamp(36px,5vw,60px);font-weight:900;line-height:1.05;margin:24px 0;letter-spacing:-.02em}
.hero p.lead{font-size:18px;color:var(--muted);max-width:540px;margin-bottom:32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:40px}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:480px}
.stat{padding:16px;border:1px solid var(--border);border-radius:16px;background:#fff;transition:all .3s}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(91,110,224,.4)}
.stat .si{color:var(--primary);font-size:20px}
.stat .sv{font-weight:800;margin-top:4px}
.stat .sl{font-size:12px;color:var(--muted)}
.hero-badges{display:flex;flex-wrap:wrap;gap:24px;margin-top:24px;font-size:14px;color:var(--muted)}

.hero-visual{position:relative}
.hero-visual .glow{position:absolute;inset:-16px;border-radius:32px;opacity:.3;filter:blur(40px);animation:tilt 6s ease-in-out infinite}
.hero-image-wrap{position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--border);background:#fff;box-shadow:0 20px 60px rgba(0,0,0,.15);aspect-ratio:4/5}
.hero-image-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.hero-image-wrap:hover img{transform:scale(1.05)}
.hero-image-wrap::after{content:"";position:absolute;inset:0;background:linear-gradient(to top right,rgba(91,110,224,.18),transparent,rgba(167,139,250,.18))}
.float-card{position:absolute;background:#fff;border:1px solid var(--border);border-radius:14px;padding:10px 14px;font-size:13px;box-shadow:0 10px 30px rgba(0,0,0,.12)}
.float-card .lbl{color:var(--muted);font-size:11px}
.float-card .val{font-weight:700}
.fc-top{top:-16px;right:-16px}
.fc-mid{top:33%;left:-24px;color:#fff;border:none}
.fc-bot{bottom:-16px;left:-8px}
.float-kit{position:absolute;bottom:-24px;right:-24px;width:110px;height:110px;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(91,110,224,.3))}
.float-plane{position:absolute;top:80px;right:35%;width:64px;height:64px;z-index:2;pointer-events:none}
.float-coins{position:absolute;bottom:40px;left:20px;width:100px;height:100px;z-index:2;pointer-events:none}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .float-plane,.float-coins{display:none}
}

/* ===== Marquee ===== */
.marquee-wrap{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#f8fafc;overflow:hidden;padding:14px 0}
.marquee{display:flex;gap:40px;white-space:nowrap;animation:marquee 30s linear infinite;color:var(--muted);font-size:14px;font-weight:500}
.marquee span{display:inline-flex;align-items:center;gap:40px}
.marquee i{color:var(--primary);font-style:normal}

/* ===== Sections ===== */
section.padded{padding:80px 0}
.section-head{text-align:center;margin-bottom:48px}
.eyebrow{font-size:12px;font-weight:700;letter-spacing:.2em;color:var(--primary)}
.section-head h2{font-size:clamp(28px,4vw,48px);font-weight:900;margin:12px 0;letter-spacing:-.02em}
.section-head p{color:var(--muted);max-width:600px;margin:0 auto}

/* ===== Cards Grid ===== */
.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.cards-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards-grid{grid-template-columns:1fr}}
.card{padding:24px;border:1px solid var(--border);border-radius:16px;background:#fff;transition:all .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(91,110,224,.4)}
.card .ic{width:52px;height:52px;border-radius:14px;color:#fff;display:grid;place-items:center;font-size:24px;transition:all .3s;background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;animation:gradient-shift 4s ease infinite}
.card:hover .ic{transform:scale(1.1) rotate(6deg)}
.card h3{margin:16px 0 8px;font-size:18px}
.card p{color:var(--muted);font-size:14px}

/* ===== Process ===== */
.bg-soft{background:#f8fafc;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.step{position:relative;padding:28px;border:1px solid var(--border);border-radius:16px;background:#fff;transition:all .3s}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step-num{position:absolute;top:-12px;right:24px;padding:4px 12px;border-radius:999px;color:#fff;font-size:12px;font-weight:700;background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;animation:gradient-shift 4s ease infinite,pulse-ring 2s ease-out infinite}
.step-ic{width:56px;height:56px;border-radius:16px;color:#fff;display:grid;place-items:center;font-size:24px;background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;animation:gradient-shift 4s ease infinite;box-shadow:0 10px 20px rgba(91,110,224,.3)}
.process-cta{text-align:center;margin-top:40px}

/* ===== Plans ===== */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.plans{grid-template-columns:1fr}}
.plan{position:relative;padding:28px;border-radius:24px;background:#fff;border:1px solid var(--border);transition:all .3s}
.plan:hover{transform:translateY(-4px);border-color:rgba(91,110,224,.4)}
.plan.popular{border-color:var(--primary);box-shadow:0 20px 50px rgba(91,110,224,.18);transform:translateY(-8px)}
.plan-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);padding:4px 12px;border-radius:999px;color:#fff;font-size:11px;font-weight:700;letter-spacing:.05em;background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;animation:gradient-shift 4s ease infinite}
.plan-name{font-size:14px;color:var(--muted)}
.plan-price{font-size:36px;font-weight:900;margin:6px 0;background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:gradient-shift 5s ease infinite}
.plan-sub{font-size:14px;color:var(--muted)}
.plan-list{list-style:none;margin:24px 0;display:flex;flex-direction:column;gap:12px}
.plan-list li{display:flex;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid var(--border);font-size:14px}
.plan-list li span:first-child{color:var(--muted)}
.plan-list li span:last-child{font-weight:600}
.plan .btn{width:100%;justify-content:center;padding:12px 16px}

/* ===== CTA ===== */
.cta{position:relative;overflow:hidden;padding:80px 0;text-align:center}
.cta .overlay{position:absolute;inset:0;opacity:.1;background:linear-gradient(270deg,var(--primary),var(--accent),var(--primary));background-size:200% 200%;animation:gradient-shift 4s ease infinite}
.cta .blob-c,.cta .blob-d{position:absolute;width:280px;height:280px;filter:blur(80px);opacity:.3}
.cta .blob-c{top:50%;left:25%;background:var(--primary)}
.cta .blob-d{top:33%;right:25%;background:var(--accent)}
.cta-coins{position:absolute;top:40px;left:40px;width:80px;height:80px}
.cta-plane{position:absolute;bottom:40px;right:40px;width:80px;height:80px}
.cta-inner{position:relative;max-width:720px;margin:0 auto;padding:0 24px}
.cta h2{font-size:clamp(28px,4vw,48px);font-weight:900;letter-spacing:-.02em}
.cta p{margin:16px auto 32px;color:var(--muted);max-width:520px}

/* ===== Footer ===== */
.site-footer{border-top:1px solid var(--border);padding:32px 0;text-align:center;font-size:14px;color:var(--muted)}

@media(max-width:768px){
  .cta-coins,.cta-plane{display:none}
}
