/*
Theme Name: Hand Writing Work
Theme URI: https://example.com/hand-writing-work
Author: Hand Writing Work
Author URI: https://example.com
Description: Vibrant, animated landing-page theme for the Hand Writing Work platform — saffron-to-green gradient hero, parallax floating badges, marquee, animated pricing tiers and a rotating-gradient CTA. Built as a single-page theme with Framer-Motion-style CSS animations.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hwwork
Tags: landing-page, one-column, custom-colors, full-width-template
*/

@import url("https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Fraunces:opsz,wght@9..144,500;9..144,700;9..144,900&display=swap");

:root{
  --background:#fbf8f1;
  --foreground:#1a2238;
  --muted:#f3eee2;
  --muted-foreground:#6b6b7b;
  --card:#ffffff;
  --border:#ece6d6;
  --saffron:#e8852a;
  --saffron-soft:#fde6cf;
  --leaf:#1f9d6b;
  --leaf-soft:#d5f0e2;
  --primary-fg:#fffaf2;
  --radius:1rem;
  --gradient-hero:linear-gradient(135deg,#fde6cf 0%,#fdf5e0 45%,#d5f0e2 100%);
  --gradient-cta:linear-gradient(95deg,#e8852a,#f4b942,#1f9d6b);
  --gradient-text:linear-gradient(95deg,#e8852a,#1f9d6b);
  --shadow-soft:0 10px 40px -12px rgba(232,133,42,.35);
  --shadow-card:0 20px 50px -20px rgba(26,34,56,.18);
}

*{box-sizing:border-box;border-color:var(--border);margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--background);
  color:var(--foreground);
  font-family:"Plus Jakarta Sans",system-ui,sans-serif;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;letter-spacing:-.02em;line-height:1.05}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:0;background:transparent}

.container{max-width:1100px;margin:0 auto;padding:0 1.25rem}
.text-gradient{background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.bg-cta{background:var(--gradient-cta);color:var(--primary-fg)}
.shadow-soft{box-shadow:var(--shadow-soft)}
.shadow-card{box-shadow:var(--shadow-card)}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:.75rem;left:50%;transform:translateX(-50%);
  z-index:50;width:min(1100px,95%);
  opacity:0;animation:fadeDown .6s .1s ease forwards;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(255,255,255,.7);backdrop-filter:blur(14px);
  border:1px solid var(--border);border-radius:999px;
  padding:.625rem 1.25rem;box-shadow:var(--shadow-card);
}
.brand{display:flex;align-items:center;gap:.625rem;font-weight:700;font-family:"Fraunces",serif}
.brand .logo{
  width:36px;height:36px;border-radius:999px;display:grid;place-items:center;
  background:var(--gradient-cta);color:var(--primary-fg);font-weight:800;font-size:14px;
}
.nav-links{display:none;gap:1.75rem;font-size:.9rem;color:var(--muted-foreground);font-weight:500}
.nav-links a:hover{color:var(--foreground)}
@media(min-width:768px){.nav-links{display:flex}}
.btn{
  display:inline-flex;align-items:center;gap:.5rem;border-radius:999px;
  padding:.625rem 1.1rem;font-weight:600;font-size:.9rem;transition:transform .2s,box-shadow .2s;
}
.btn-primary{background:var(--gradient-cta);color:var(--primary-fg);box-shadow:var(--shadow-soft)}
.btn-primary:hover{transform:translateY(-2px) scale(1.02)}
.btn-ghost{background:var(--card);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--muted)}
.btn-lg{padding:.95rem 1.6rem;font-size:1rem}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;padding:8rem 0 6rem;background:var(--gradient-hero)}
.hero-grid{
  position:absolute;inset:0;opacity:.4;pointer-events:none;
  background-image:
    linear-gradient(to right,rgba(232,133,42,.1) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(232,133,42,.1) 1px,transparent 1px);
  background-size:48px 48px;
}
.blob{position:absolute;border-radius:999px;filter:blur(64px);pointer-events:none}
.blob-1{top:-6rem;right:-5rem;width:20rem;height:20rem;background:rgba(232,133,42,.3);animation:float 8s ease-in-out infinite}
.blob-2{bottom:-8rem;left:-6rem;width:24rem;height:24rem;background:rgba(31,157,107,.25);animation:float 10s ease-in-out infinite reverse}

.hero-inner{position:relative;text-align:center}
.chip{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.8);backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:999px;
  padding:.375rem 1rem;font-size:.85rem;font-weight:500;
}
.chip .dot{width:8px;height:8px;border-radius:999px;background:var(--saffron)}
h1.hero-title{margin-top:1.5rem;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900}
.hero-sub{margin:1.5rem auto 0;max-width:640px;color:var(--muted-foreground);font-size:1.1rem}
.hero-sub b{color:var(--foreground)}
.hero-ctas{margin-top:2rem;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}

.hero-media{
  position:relative;margin:3rem auto 0;max-width:960px;
}
.hero-media-frame{
  border-radius:1.5rem;overflow:hidden;border:1px solid var(--border);
  box-shadow:var(--shadow-card);
}
.hero-media-frame img{width:100%;height:clamp(320px,40vw,460px);object-fit:cover}
.float-card{
  position:absolute;background:var(--card);border:1px solid var(--border);
  border-radius:1rem;padding:.75rem 1rem;box-shadow:var(--shadow-card);
  display:flex;align-items:center;gap:.75rem;
}
.float-card .icon{width:40px;height:40px;border-radius:999px;display:grid;place-items:center}
.float-card .icon.saffron{background:var(--saffron-soft);color:var(--saffron)}
.float-card .icon.leaf{background:var(--leaf-soft);color:var(--leaf)}
.float-card .label{font-size:.75rem;color:var(--muted-foreground)}
.float-card .value{font-weight:700}
.float-card .value.leaf{color:var(--leaf)}
.fc-1{left:-1rem;top:2.5rem;animation:floatY 4s ease-in-out infinite}
.fc-2{right:-.5rem;bottom:2.5rem;animation:floatY 5s ease-in-out infinite reverse}
@media(min-width:640px){.fc-1{left:-2.5rem}.fc-2{right:-2rem}}

.stats{margin-top:3.5rem;display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:720px;margin-left:auto;margin-right:auto}
@media(min-width:640px){.stats{gap:1.25rem}}
.stat{
  background:rgba(255,255,255,.8);backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:1rem;
  padding:1.25rem;text-align:center;box-shadow:var(--shadow-card);
}
.stat-v{font-size:clamp(1.5rem,3vw,2rem);font-weight:800;font-family:"Fraunces",serif;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-l{margin-top:.25rem;font-size:.8rem;color:var(--muted-foreground)}

/* ---------- MARQUEE ---------- */
.marquee{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--gradient-cta);padding:1rem 0;overflow:hidden;color:var(--primary-fg)}
.marquee-track{display:flex;gap:2.5rem;white-space:nowrap;animation:marquee 30s linear infinite;font-weight:600}
.marquee-track span{display:inline-flex;align-items:center;gap:.75rem}

/* ---------- SECTIONS ---------- */
section{padding:6rem 0;position:relative}
.eyebrow{display:inline-block;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:700}
.eyebrow.saffron{background:var(--saffron-soft);color:var(--saffron)}
.eyebrow.leaf{background:var(--leaf-soft);color:var(--leaf)}
.section-head{text-align:center;margin-bottom:3.5rem}
.section-head h2{margin-top:1rem;font-size:clamp(2rem,4.5vw,3rem);font-weight:700}
.section-head p{margin-top:.75rem;color:var(--muted-foreground);max-width:560px;margin-left:auto;margin-right:auto}

/* features */
.features-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:640px){.features-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.features-grid{grid-template-columns:repeat(3,1fr)}}
.feature{
  position:relative;background:var(--card);border:1px solid var(--border);
  border-radius:1.5rem;padding:1.5rem;box-shadow:var(--shadow-card);
  overflow:hidden;transition:transform .3s;
}
.feature:hover{transform:translateY(-6px)}
.feature::before{
  content:"";position:absolute;top:-4rem;right:-4rem;width:10rem;height:10rem;
  border-radius:999px;background:rgba(232,133,42,.1);filter:blur(32px);transition:background .3s;
}
.feature:hover::before{background:rgba(232,133,42,.2)}
.feature-icon{
  position:relative;width:48px;height:48px;border-radius:.85rem;display:grid;place-items:center;
  background:var(--gradient-cta);color:var(--primary-fg);box-shadow:var(--shadow-soft);
}
.feature h3{margin-top:1.25rem;font-family:"Plus Jakarta Sans",sans-serif;letter-spacing:0;font-size:1.25rem;font-weight:700}
.feature p{margin-top:.5rem;font-size:.9rem;color:var(--muted-foreground);line-height:1.6}

/* how it works */
.how{background:rgba(243,238,226,.5)}
.steps{display:flex;flex-direction:column;gap:5rem;margin-top:4rem}
.step{display:grid;grid-template-columns:1fr;gap:2.5rem;align-items:center}
@media(min-width:768px){.step{grid-template-columns:1fr 1fr}}
.step-num{font-family:"Fraunces",serif;font-weight:900;font-size:clamp(4rem,10vw,7rem);line-height:1;background:var(--gradient-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.step-label{margin-top:.5rem;font-size:.75rem;font-weight:700;letter-spacing:.15em;color:var(--saffron)}
.step h3{margin-top:.75rem;font-family:"Plus Jakarta Sans",sans-serif;letter-spacing:0;font-size:1.75rem;font-weight:700}
.step p{margin-top:.75rem;color:var(--muted-foreground);max-width:28rem;line-height:1.6}
.step-img{position:relative;border-radius:1.5rem;overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-card);aspect-ratio:4/3;transition:transform .4s}
.step-img:hover{transform:scale(1.02) rotate(1deg)}
.step:nth-child(even) .step-img:hover{transform:scale(1.02) rotate(-1deg)}
.step:nth-child(even) > div:first-child{order:2}
.step-img img{width:100%;height:100%;object-fit:cover}
.step-tag{position:absolute;top:.75rem;left:.75rem;background:rgba(255,255,255,.9);backdrop-filter:blur(8px);border-radius:999px;padding:.25rem .75rem;font-size:.75rem;font-weight:700}
.how-cta{margin-top:4rem;text-align:center}

/* plans */
.plans-grid{display:grid;gap:1.5rem;grid-template-columns:1fr}
@media(min-width:768px){.plans-grid{grid-template-columns:repeat(3,1fr)}}
.plan{
  position:relative;background:var(--card);border:1px solid var(--border);
  border-radius:1.5rem;padding:1.75rem;box-shadow:var(--shadow-card);
  transition:transform .3s;
}
.plan:hover{transform:translateY(-8px)}
.plan.popular{background:var(--gradient-cta);color:var(--primary-fg);border-color:transparent}
@media(min-width:768px){.plan.popular{transform:scale(1.05)}.plan.popular:hover{transform:scale(1.05) translateY(-8px)}}
.popular-badge{
  position:absolute;top:-.75rem;left:50%;transform:translateX(-50%);
  background:var(--background);color:var(--saffron);border:1px solid rgba(232,133,42,.3);
  border-radius:999px;padding:.25rem .75rem;font-size:.75rem;font-weight:700;box-shadow:var(--shadow-soft);
}
.plan-name{font-size:.75rem;font-weight:700;letter-spacing:.15em;color:var(--muted-foreground)}
.plan.popular .plan-name{color:rgba(255,255,255,.8)}
.plan-price{margin-top:.75rem;font-size:3rem;font-family:"Fraunces",serif;font-weight:900;line-height:1}
.plan-sub{font-size:.9rem;color:var(--muted-foreground)}
.plan.popular .plan-sub{color:rgba(255,255,255,.8)}
.plan ul{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}
.plan li{display:flex;gap:.5rem;font-size:.9rem;align-items:flex-start}
.check{flex-shrink:0;width:18px;height:18px;color:var(--leaf);margin-top:2px}
.plan.popular .check{color:var(--primary-fg)}
.plan-deposit{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.plan.popular .plan-deposit{border-color:rgba(255,255,255,.2)}
.plan-deposit-label{font-size:.9rem;color:var(--muted-foreground)}
.plan.popular .plan-deposit-label{color:rgba(255,255,255,.8)}
.plan-cta{
  margin-top:1.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem;
  width:100%;border-radius:999px;padding:.85rem;font-weight:600;transition:transform .2s;
  background:var(--gradient-cta);color:var(--primary-fg);
}
.plan.popular .plan-cta{background:var(--background);color:var(--foreground)}
.plan-cta:hover{transform:translateY(-2px)}
.plans-note{margin-top:2rem;text-align:center;font-size:.9rem;color:var(--muted-foreground)}

/* CTA */
.cta-section{padding:6rem 0}
.cta-card{
  position:relative;max-width:1000px;margin:0 auto;border-radius:2.5rem;
  background:var(--gradient-cta);color:var(--primary-fg);
  padding:4rem 2rem;text-align:center;box-shadow:var(--shadow-card);overflow:hidden;
}
@media(min-width:640px){.cta-card{padding:4rem 3rem}}
.cta-card h2{font-size:clamp(2rem,4.5vw,3rem);font-weight:900;margin-top:1.25rem}
.cta-card p{margin:1rem auto 0;max-width:520px;font-size:1.1rem;opacity:.9}
.cta-orb{position:absolute;border-radius:999px;background:rgba(255,255,255,.1);filter:blur(64px);width:20rem;height:20rem}
.cta-orb-1{top:-5rem;left:-5rem;animation:spin 30s linear infinite}
.cta-orb-2{bottom:-5rem;right:-5rem;animation:spin 40s linear infinite reverse}
.cta-chip{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border-radius:999px;padding:.375rem 1rem;font-size:.75rem;font-weight:600}
.cta-btn{
  margin-top:2rem;display:inline-flex;align-items:center;gap:.5rem;
  background:var(--background);color:var(--foreground);
  border-radius:999px;padding:1rem 1.75rem;font-weight:700;box-shadow:var(--shadow-soft);
  transition:transform .2s;
}
.cta-btn:hover{transform:translateY(-2px)}

/* footer */
footer{border-top:1px solid var(--border);padding:2.5rem 1.25rem;text-align:center;color:var(--muted-foreground);font-size:.9rem}
footer .brand{justify-content:center;color:var(--foreground)}
footer p{margin-top:.75rem}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* keyframes */
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-20px)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes fadeDown{from{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%,0)}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* icon sizing */
.i{width:18px;height:18px;flex-shrink:0}
.i-sm{width:14px;height:14px}
.i-lg{width:22px;height:22px}
