/* ══════════════════════════════════════════════════════════════
   PersonaCode — Shared Design System
   Matched to personacode.ai reference (Tailwind tokens → vanilla)
   ══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600;700&family=DM+Sans:wght@400;500&display=swap');

:root {
    /* ── Colors (from reference HSL tokens) ── */
    --background: hsl(0 0% 4%);
    --foreground: hsl(0 0% 96%);
    --primary: hsl(44 54% 54%);         /* gold  #C5A55A */
    --primary-foreground: hsl(0 0% 100%);
    --muted: hsl(46 13% 19%);
    --muted-foreground: hsl(0 0% 96%);
    --border: hsl(0 0% 24%);
    --card: hsl(0 0% 4%);
    --accent-blue: hsl(224 54% 54%);

    /* ── Convenience aliases ── */
    --gold: hsl(44 54% 54%);
    --gold-dim: hsl(44 54% 42%);
    --lavender: hsl(270 28% 60%);
    --bg: hsl(0 0% 4%);
    --bg-card: rgba(255,255,255,0.03);
    --bg-glass: rgba(255,255,255,0.04);
    --text: hsl(0 0% 96%);
    --text-muted: hsl(0 0% 60%);
    --border-subtle: rgba(255,255,255,0.06);
    --glow-violet: rgba(165,148,199,0.12);
    --glow-gold: rgba(197,165,90,0.12);

    /* ── Typography ── */
    --font-body: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-heading: 'Cormorant Garamond', Georgia, serif;

    /* ── Spacing ── */
    --radius: 0.5rem;
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;border-width:0;border-style:solid;border-color:var(--border)}
html{scroll-behavior:smooth;line-height:1.5;-webkit-text-size-adjust:100%;text-size-adjust:100%;tab-size:4}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);overflow-x:hidden;-webkit-font-smoothing:antialiased;margin:0;line-height:inherit}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading)!important}
a{color:inherit;text-decoration:inherit}
img,svg,video{display:block;max-width:100%;height:auto}
button{cursor:pointer;background:transparent;border:0;font:inherit;color:inherit}
ul,ol{list-style:none}
.particle-canvas{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;z-index:1!important;pointer-events:none!important;opacity:0.85!important}

/* ── Utility ── */
.text-gold{color:var(--gold)}
.text-primary{color:var(--primary)}
.text-muted{color:var(--text-muted)}
.uppercase{text-transform:uppercase}
.tracking-widest{letter-spacing:0.1em}
.tracking-wider{letter-spacing:0.05em}

/* ══════════════════════════════════════════════════════════════
   Navigation
   ══════════════════════════════════════════════════════════════ */

.landing-nav{
    display:flex;justify-content:space-between;align-items:center;
    padding:16px 48px;
    position:fixed;top:0;left:0;right:0;z-index:50;
    background:rgba(10,10,10,0.85);
    -webkit-backdrop-filter:blur(20px);
    backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border-subtle);
    transition:background .3s;
}
.nav-brand{
    font-family:var(--font-heading)!important;font-weight:700;font-size:24px;
    text-decoration:none;letter-spacing:0.02em;
    background:linear-gradient(135deg,#A594C7,#C5A55A);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
}
.pc-gradient-logo{font-family:var(--font-heading);font-weight:700;line-height:1;background:linear-gradient(135deg,#A594C7,#C5A55A);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.02em}
.pc-gradient-logo-accent{font-weight:700;background:linear-gradient(135deg,#C5A55A,#E8D5A3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.nav-logo{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1.5px solid rgba(197,165,90,0.25)}
.nav-links{display:flex;gap:28px;align-items:center}
.nav-link{
    color:var(--text-muted);text-decoration:none;
    font-size:0.8125rem;font-weight:500;
    letter-spacing:0.1em;text-transform:uppercase;
    transition:color .3s;position:relative;
}
.nav-link:hover{color:var(--primary)}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--primary);transition:width .25s}
.nav-link:hover::after{width:100%}

.nav-cta{
    display:inline-flex;align-items:center;gap:6px;
    padding:10px 20px;border-radius:9999px;
    background:var(--primary);color:#000;
    text-decoration:none;
    font-size:0.75rem;font-weight:600;
    letter-spacing:0.1em;text-transform:uppercase;
    transition:all .3s;border:0;cursor:pointer;
    position:relative;overflow:hidden;
}
.nav-cta:hover{background:var(--gold-dim);transform:translateY(-1px);box-shadow:0 8px 24px var(--glow-gold)}

.nav-hamburger{display:none;flex-direction:column;gap:5px;background:0;border:0;cursor:pointer;padding:8px}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text);transition:.2s}

/* ══════════════════════════════════════════════════════════════
   Buttons
   ══════════════════════════════════════════════════════════════ */

.btn-cta{
    display:inline-flex;align-items:center;gap:8px;
    padding:14px 28px;border-radius:9999px;
    text-decoration:none;font-size:0.8125rem;font-weight:600;
    letter-spacing:0.1em;text-transform:uppercase;
    transition:all .3s;border:0;cursor:pointer;
}
.btn-cta--primary{background:var(--primary);color:#000}
.btn-cta--primary:hover{background:var(--gold-dim);transform:translateY(-2px);box-shadow:0 12px 40px var(--glow-gold)}
.btn-cta--outline{border:1px solid var(--border);color:var(--text);background:transparent}
.btn-cta--outline:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ── Store Buttons ── */
.store-buttons{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.store-button{min-width:172px;display:inline-flex;align-items:center;gap:10px;padding:11px 18px;border-radius:14px;background:#070707;border:1px solid rgba(255,255,255,0.1);color:var(--text);text-decoration:none;box-shadow:0 14px 40px rgba(0,0,0,0.28);transition:all .25s}
.store-button:hover{transform:translateY(-3px);border-color:var(--primary);box-shadow:0 18px 48px var(--glow-gold)}
.store-button-icon{font-size:28px;color:var(--primary)}
.store-button small{display:block;font-size:10px;line-height:1;text-transform:uppercase;letter-spacing:0.7px;color:var(--text-muted);margin-bottom:4px}
.store-button strong{display:block;font-size:17px;line-height:1.1;font-weight:800;color:var(--text)}
.store-buttons--compact{margin:12px 0 18px}
.store-buttons--compact .store-button{min-width:142px;padding:9px 14px;border-radius:12px}
.store-buttons--compact .store-button-icon{font-size:22px}
.store-buttons--compact .store-button strong{font-size:14px}

/* ══════════════════════════════════════════════════════════════
   Section Titles (matching reference)
   ══════════════════════════════════════════════════════════════ */

.section-label{
    display:inline-block;padding:0;
    border-radius:0;
    background:transparent;border:0;
    color:var(--primary);
    font-family:var(--font-body);
    font-size:0.625rem;font-weight:500;
    letter-spacing:0.15em;text-transform:uppercase;
    margin-bottom:20px;
}
.section-title{
    font-family:var(--font-heading)!important;
    font-size:clamp(2rem,4vw,3.2rem);
    font-weight:600;text-align:center;
    margin-bottom:14px;
    color:var(--text);
    line-height:1.2;
    letter-spacing:-0.01em;
}
.section-sub{
    text-align:center;color:var(--text-muted);
    font-size:1rem;margin-bottom:64px;
    max-width:560px;margin-left:auto;margin-right:auto;
    line-height:1.7;font-weight:400;
}

/* ── Cards ── */
.glass-card{background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:32px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color .3s,transform .3s,box-shadow .3s}
.glass-card:hover{border-color:var(--primary);transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,0.3)}

/* ══════════════════════════════════════════════════════════════
   Pricing / Paywall Cards
   ══════════════════════════════════════════════════════════════ */

.pricing{padding:80px 24px 100px}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:960px;margin:0 auto}

.pricing-card{
    position:relative;
    background:rgba(255,255,255,0.03);
    border:1px solid rgba(255,255,255,0.08);
    border-radius:20px;
    padding:36px 28px 32px;
    -webkit-backdrop-filter:blur(12px);
    backdrop-filter:blur(12px);
    transition:all .4s cubic-bezier(.4,0,.2,1);
}
.pricing-card:hover{
    border-color:rgba(197,165,90,0.3);
    transform:translateY(-8px);
    box-shadow:0 24px 60px rgba(0,0,0,0.4),0 0 40px var(--glow-gold);
}

/* Featured / "Most Popular" card */
.pricing-card--featured{
    border-color:rgba(197,165,90,0.35);
    background:rgba(197,165,90,0.05);
    transform:scale(1.04);
    box-shadow:0 8px 32px rgba(197,165,90,0.1);
}
.pricing-card--featured:hover{
    transform:scale(1.04) translateY(-8px);
    box-shadow:0 28px 72px rgba(0,0,0,0.5),0 0 60px var(--glow-gold);
}

.pricing-badge{
    position:absolute;top:-13px;left:50%;transform:translateX(-50%);
    background:linear-gradient(135deg,#E9C349,#B8860B);
    color:#000;font-size:10px;font-weight:700;
    letter-spacing:1.5px;text-transform:uppercase;
    padding:5px 18px;border-radius:9999px;
    white-space:nowrap;
    animation:pulse 2s ease-in-out infinite;
}

.pricing-tier{
    font-family:var(--font-heading)!important;
    font-size:1.2rem;font-weight:700;
    color:var(--text);margin-bottom:8px;
}
.pricing-amount{
    font-family:var(--font-heading)!important;
    font-size:2.4rem;font-weight:700;
    background:linear-gradient(135deg,var(--gold),#FFE088);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:20px;
}
.pricing-features{
    list-style:none;padding:0;margin:0 0 8px;
}
.pricing-features li{
    display:flex;align-items:center;gap:8px;
    font-size:14px;color:var(--text-muted);
    padding:7px 0;
    border-bottom:1px solid rgba(255,255,255,0.04);
}
.pricing-features li:last-child{border-bottom:0}
.pricing-features .material-symbols-outlined{
    font-size:16px;color:var(--gold);
}

@media(max-width:768px){
    .pricing-grid{grid-template-columns:1fr;max-width:400px}
    .pricing-card--featured{transform:scale(1)}
    .pricing-card--featured:hover{transform:translateY(-8px)}
}


/* ── Numbered card index ── */
.cap-num{
    font-family:var(--font-heading)!important;
    font-size:2rem;font-weight:700;
    color:rgba(197,165,90,0.2);
    margin-bottom:12px;line-height:1;
}

/* ══════════════════════════════════════════════════════════════
   Animations
   ══════════════════════════════════════════════════════════════ */

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-20px) scale(1.1)}}
@keyframes pulse{0%,100%{opacity:0.4}50%{opacity:1}}
@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.fade-up{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════════════════════════════
   Footer
   ══════════════════════════════════════════════════════════════ */

.landing-footer{text-align:center;padding:64px 24px 48px;border-top:1px solid var(--border-subtle)}
.footer-inner{max-width:1100px;margin:0 auto}
.footer-brand{font-family:var(--font-heading);font-weight:700;color:var(--primary);font-size:18px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:10px}
.footer-logo{width:32px;height:32px;border-radius:50%;object-fit:cover;border:1px solid rgba(197,165,90,0.25)}
.footer-tagline{color:var(--text-muted);font-size:13px;margin-bottom:24px}
.footer-cols{display:flex;gap:64px;justify-content:center;flex-wrap:wrap;margin-bottom:32px;text-align:left}
.footer-col h4{font-size:0.6875rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}
.footer-col a{display:block;color:var(--text-muted);text-decoration:none;font-size:14px;padding:4px 0;transition:color .25s}
.footer-col a:hover{color:var(--primary)}
.footer-copy{color:var(--text-muted);font-size:12px;opacity:0.5;margin-top:24px}
.footer-credit{margin-top:6px;font-size:11px;color:var(--gold-dim);opacity:0.5}

/* ══════════════════════════════════════════════════════════════
   Responsive
   ══════════════════════════════════════════════════════════════ */

@media(max-width:768px){
    .landing-nav{padding:16px 20px}
    .nav-links{
        display:none;position:fixed;top:0;left:0;right:0;bottom:0;
        background:rgba(5,5,5,0.97);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);
        flex-direction:column;align-items:center;justify-content:center;
        gap:32px;z-index:999;
    }
    .nav-links.open{display:flex}
    .nav-links .nav-link{font-size:20px;color:var(--text)}
    .nav-hamburger{display:flex;z-index:1000}
    .footer-cols{flex-direction:column;align-items:center;text-align:center;gap:32px}
}
@media(max-width:480px){
    .landing-nav{padding:14px 16px}
}
