/* Grand Tarot v3 — shared design system */
:root{--bg:#0a0612;--bg2:#120a1f;--ink:#f5eee0;--ink2:#d9c8a5;--muted:#8a7d99;--gold:#d4af37;--gold2:#f5d77a;--purple:#6b2fa5;--purple2:#9b4dd4;--red:#b0395d;--ok:#4ade80;--err:#ef4444;--card:rgba(255,255,255,.04);--border:rgba(245,238,224,.1)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Cormorant Garamond',Georgia,serif;background:radial-gradient(ellipse at top,#1a0f2e 0%,#0a0612 60%,#000 100%);color:var(--ink);line-height:1.6;min-height:100vh;overflow-x:hidden}
.sans{font-family:'Inter',system-ui,-apple-system,sans-serif}
a{color:var(--gold2);text-decoration:none}
a:hover{text-decoration:underline}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;width:100%;transition:border .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold)}

/* Layout */
.wrap{max-width:1180px;margin:0 auto;padding:0 1.25rem}
.wrap-sm{max-width:760px;margin:0 auto;padding:0 1.25rem}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:800px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* Nav */
.nav{position:sticky;top:0;z-index:100;background:rgba(10,6,18,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;max-width:1180px;margin:0 auto}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;letter-spacing:.05em;color:var(--gold2)}
.logo::before{content:"✦ ";color:var(--gold)}
.nav-links{display:flex;gap:1.5rem;align-items:center}
.nav-links a{color:var(--ink2);font-family:'Inter',sans-serif;font-size:.9rem;font-weight:500}
.nav-links a:hover{color:var(--gold2);text-decoration:none}
.btn{display:inline-block;padding:.75rem 1.5rem;border-radius:999px;font-family:'Inter',sans-serif;font-weight:600;font-size:.95rem;transition:all .2s;text-align:center}
.btn-primary{background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 100%);color:#1a0f2e;box-shadow:0 4px 20px rgba(212,175,55,.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(212,175,55,.5);text-decoration:none}
.btn-ghost{border:1px solid var(--gold);color:var(--gold2)}
.btn-ghost:hover{background:rgba(212,175,55,.1);text-decoration:none}
@media(max-width:640px){.nav-links a:not(.btn){display:none}}

/* Hero */
.hero{padding:5rem 0 3rem;text-align:center;position:relative}
.hero h1{font-size:clamp(2.4rem,5.5vw,4.5rem);font-weight:500;line-height:1.1;letter-spacing:-.02em;margin-bottom:1.5rem}
.hero h1 em{font-style:italic;background:linear-gradient(135deg,var(--gold) 0%,var(--gold2) 50%,var(--purple2) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:400}
.hero-sub{font-size:clamp(1.1rem,2vw,1.35rem);color:var(--ink2);max-width:680px;margin:0 auto 2.5rem;font-weight:300}
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1rem}
.hero-meta{color:var(--muted);font-size:.85rem;font-family:'Inter',sans-serif}

/* Starfield */
.stars{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.stars::before,.stars::after{content:"";position:absolute;inset:-50%;background-image:radial-gradient(1px 1px at 20% 30%,#fff,transparent),radial-gradient(1px 1px at 60% 70%,rgba(255,255,255,.7),transparent),radial-gradient(1px 1px at 80% 20%,rgba(255,255,255,.5),transparent),radial-gradient(2px 2px at 40% 50%,rgba(245,215,122,.6),transparent),radial-gradient(1px 1px at 90% 80%,#fff,transparent);background-size:220px 220px;animation:drift 200s linear infinite;opacity:.6}
.stars::after{background-size:320px 320px;animation-duration:320s;animation-direction:reverse;opacity:.3}
@keyframes drift{to{transform:translate(220px,220px)}}

/* Cards / sections */
.section{padding:4rem 0;position:relative}
.section-title{text-align:center;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:500;margin-bottom:.75rem;letter-spacing:-.01em}
.section-title em{font-style:italic;color:var(--gold2)}
.section-sub{text-align:center;color:var(--ink2);font-size:1.1rem;max-width:620px;margin:0 auto 3rem}
.card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:2rem;backdrop-filter:blur(12px);transition:border .3s,transform .3s}
.card:hover{border-color:rgba(212,175,55,.3);transform:translateY(-4px)}
.card h3{font-size:1.6rem;font-weight:500;margin-bottom:.75rem;color:var(--gold2)}
.card h3 span{font-size:.85rem;display:block;color:var(--muted);font-family:'Inter',sans-serif;font-weight:400;letter-spacing:.15em;text-transform:uppercase;margin-bottom:.3rem}
.card p{color:var(--ink2);font-size:1.05rem}
.card-icon{font-size:2.5rem;margin-bottom:1rem;display:block}

/* Pricing */
.pricing-card{max-width:520px;margin:0 auto;background:linear-gradient(180deg,rgba(212,175,55,.1) 0%,rgba(107,47,165,.05) 100%);border:1px solid var(--gold);border-radius:24px;padding:3rem 2.5rem;text-align:center;position:relative;overflow:hidden}
.pricing-card::before{content:"";position:absolute;inset:-2px;background:conic-gradient(from 0deg,var(--gold),var(--purple2),var(--gold));border-radius:24px;z-index:-1;opacity:.3;animation:spin 8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.price-tag{font-family:'Cormorant Garamond',serif;margin:1rem 0}
.price-tag .amount{font-size:4.5rem;font-weight:500;color:var(--gold2)}
.price-tag .currency{font-size:2rem;color:var(--gold)}
.price-tag .period{color:var(--muted);font-family:'Inter',sans-serif;font-size:.95rem;letter-spacing:.05em}
.pricing-list{list-style:none;text-align:left;margin:1.75rem 0}
.pricing-list li{padding:.5rem 0;color:var(--ink2);display:flex;align-items:flex-start;gap:.75rem}
.pricing-list li::before{content:"✦";color:var(--gold);flex-shrink:0}

/* Testimonials */
.t-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
blockquote{background:var(--card);border-left:3px solid var(--gold);padding:1.5rem;border-radius:0 16px 16px 0;font-style:italic;color:var(--ink2)}
blockquote cite{display:block;margin-top:.75rem;font-style:normal;color:var(--muted);font-size:.9rem;font-family:'Inter',sans-serif}

/* Footer */
footer{padding:3rem 0;border-top:1px solid var(--border);color:var(--muted);font-size:.9rem;text-align:center;font-family:'Inter',sans-serif;margin-top:4rem}
footer a{color:var(--ink2);margin:0 .75rem}

/* Forms */
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;margin-bottom:.4rem;color:var(--ink2);font-family:'Inter',sans-serif;font-size:.9rem;font-weight:500}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}

/* Badge */
.badge{display:inline-block;padding:.3rem .8rem;border-radius:999px;font-family:'Inter',sans-serif;font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.badge-gold{background:rgba(212,175,55,.15);color:var(--gold2);border:1px solid rgba(212,175,55,.3)}
.badge-purple{background:rgba(107,47,165,.2);color:var(--purple2);border:1px solid rgba(107,47,165,.4)}

/* Result panels */
.result{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:2rem;margin:1.5rem 0}
.result h2,.result h3{color:var(--gold2);margin-bottom:1rem}
.result p{margin-bottom:1rem;color:var(--ink)}

/* Loading */
.loading{display:inline-block;width:16px;height:16px;border:2px solid rgba(212,175,55,.3);border-top-color:var(--gold);border-radius:50%;animation:l 1s linear infinite;vertical-align:middle}
@keyframes l{to{transform:rotate(360deg)}}

/* Tirage 3D */
.deck-stage{position:relative;min-height:420px;perspective:1800px;display:flex;justify-content:center;align-items:center;margin:2rem auto;max-width:900px}
.card3d{position:relative;width:160px;height:260px;transform-style:preserve-3d;transition:transform .9s cubic-bezier(.34,1.56,.64,1);cursor:pointer;border-radius:12px;will-change:transform}
.card3d.flipped{transform:rotateY(180deg)}
.card-face{position:absolute;inset:0;border-radius:12px;backface-visibility:hidden;overflow:hidden;box-shadow:0 12px 32px rgba(0,0,0,.6),inset 0 0 0 2px rgba(212,175,55,.25)}
.card-face img{width:100%;height:100%;object-fit:cover;display:block}
.card-back{background:linear-gradient(135deg,#1a0f2e 0%,#2a1550 100%)}
.card-front{transform:rotateY(180deg);background:#0a0612}
.card3d.reversed .card-front img{transform:rotate(180deg)}
.card3d::before{content:"";position:absolute;left:50%;top:50%;width:90%;height:90%;transform:translate(-50%,-50%) translateZ(-4px);background:#0a0612;border-radius:12px;box-shadow:0 0 0 1px rgba(0,0,0,.8);pointer-events:none}
.spread{display:flex;gap:1.25rem;justify-content:center;flex-wrap:wrap}
.spread .slot{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.slot-label{font-family:'Inter',sans-serif;font-size:.8rem;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.card-name{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:var(--gold2);text-align:center;min-height:1.4em;font-style:italic}
.shuffle-zone{min-height:260px;position:relative;margin:1rem auto 2rem}
.deck-pile{position:relative;width:160px;height:260px;margin:0 auto;transform-style:preserve-3d}
.deck-pile .card3d{position:absolute;top:0;left:0}

/* Chat / Oracle */
.chat{display:flex;flex-direction:column;gap:1rem;max-height:500px;overflow-y:auto;padding:1rem;background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:16px;margin-bottom:1rem}
.msg{display:flex;gap:.75rem;align-items:flex-start}
.msg.me{flex-direction:row-reverse}
.msg-body{background:rgba(255,255,255,.05);padding:.75rem 1rem;border-radius:16px;max-width:80%;color:var(--ink)}
.msg.me .msg-body{background:rgba(212,175,55,.15);border:1px solid rgba(212,175,55,.3)}
.msg-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--purple2));display:flex;align-items:center;justify-content:center;color:var(--gold2);font-family:'Cormorant Garamond',serif;font-size:1.2rem;flex-shrink:0}
.msg.me .msg-avatar{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#1a0f2e}

/* Utility */
.center{text-align:center}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.mb-1{margin-bottom:1rem}.mb-2{margin-bottom:2rem}
.hide{display:none!important}
.sparkle{display:inline-block;animation:sparkle 2s ease-in-out infinite}
@keyframes sparkle{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}

/* Chart SVG */
.chart-natal{max-width:520px;margin:1rem auto;display:block;background:radial-gradient(circle,rgba(107,47,165,.1) 0%,transparent 70%);border-radius:50%}

/* Numerology grid */
.num-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin:1.5rem 0}
.num-tile{text-align:center;padding:1.25rem 1rem;background:var(--card);border:1px solid var(--border);border-radius:16px}
.num-tile .big{font-family:'Cormorant Garamond',serif;font-size:3rem;font-weight:500;color:var(--gold2);display:block;line-height:1}
.num-tile .label{font-family:'Inter',sans-serif;font-size:.75rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:.4rem}
.num-tile .hint{font-size:.95rem;color:var(--ink2);margin-top:.5rem;font-style:italic;min-height:2.6em}
