@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=Quicksand:wght@300;400;500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--lavender:#7c6fa0;--rose:#c9a0a0;--rosegold:#b76e79;--blush:#f8f0f0;--deep:#3b2d5c;--cream:#faf8f6;--text:#2d2235}
html{scroll-behavior:smooth}
body{font-family:'Quicksand',sans-serif;color:var(--text);background:var(--cream);line-height:1.75}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:700;font-style:italic}
a{text-decoration:none;color:inherit}

.header-bar{position:sticky;top:0;z-index:100;background:var(--deep);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:60px}
.hb-logo{font-family:'Cormorant Garamond',serif;color:var(--rose);font-size:1.4rem;font-weight:700;font-style:italic;display:flex;align-items:center;gap:.5rem}
.hb-logo svg{width:28px;height:28px}
.hb-links{list-style:none;display:flex;gap:1.3rem}
.hb-links a{color:#d4c4d4;font-size:.9rem;font-weight:500;transition:color .2s}
.hb-links a:hover{color:var(--rose)}
.hb-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:4px}
.hb-toggle span{width:24px;height:3px;background:var(--rose);border-radius:2px}

@media(max-width:768px){
.hb-links{display:none;position:absolute;top:60px;left:0;right:0;background:var(--deep);flex-direction:column;padding:1rem 2rem;gap:.6rem}
.hb-links.active{display:flex}
.hb-toggle{display:flex}
}

.elegant-hero{background:linear-gradient(170deg,var(--deep) 0%,var(--lavender) 100%);color:#fff;padding:6rem 2rem 5rem;text-align:center}
.elegant-hero h1{font-size:clamp(2rem,5vw,3.4rem);color:var(--rose);margin-bottom:1rem;font-style:italic}
.elegant-hero p{max-width:660px;margin:0 auto 2rem;font-size:1.05rem;opacity:.9}
.rose-btn{display:inline-block;padding:.85rem 2.4rem;background:var(--rosegold);color:#fff;font-family:'Cormorant Garamond',serif;font-weight:700;font-size:1.1rem;font-style:italic;border-radius:30px;transition:transform .2s}
.rose-btn:hover{transform:translateY(-2px)}

.grace-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;padding:4rem 2rem;max-width:1100px;margin:0 auto}
.grace-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 20px rgba(124,111,160,.1);text-align:center;border-bottom:3px solid var(--rosegold)}
.grace-card .gc-icon{font-size:2.2rem;margin-bottom:.6rem}
.grace-card h3{color:var(--lavender);margin-bottom:.4rem;font-size:1.2rem}

.game-display{background:var(--blush);padding:4rem 2rem;text-align:center}
.game-display h2{color:var(--deep);margin-bottom:1.5rem;font-size:1.8rem}
.gd-wrap{max-width:830px;margin:0 auto;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:2px solid var(--rosegold);box-shadow:0 6px 24px rgba(183,110,121,.12)}
.gd-wrap iframe{width:100%;height:100%;border:none}

.narrative-section{padding:4rem 2rem;max-width:900px;margin:0 auto}
.narrative-section h2{color:var(--lavender);margin-bottom:1rem;font-size:1.7rem}
.narrative-section p{margin-bottom:1.1rem;font-size:1.02rem}

.traits{background:var(--deep);color:#d4c4d4;padding:4rem 2rem}
.traits h2{text-align:center;color:var(--rose);margin-bottom:2rem;font-size:1.6rem}
.traits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;max-width:1100px;margin:0 auto}
.trait{background:rgba(255,255,255,.05);padding:1.6rem;border-radius:12px}
.trait h3{color:var(--rosegold);margin-bottom:.4rem;font-size:1.05rem}
.trait p{font-size:.92rem}

.rose-cta{background:linear-gradient(90deg,var(--rosegold),var(--rose));text-align:center;padding:3rem 2rem;color:#fff}
.rose-cta h2{margin-bottom:.5rem;font-size:1.6rem}
.rose-cta a{display:inline-block;margin-top:1rem;padding:.75rem 2rem;background:#fff;color:var(--rosegold);border-radius:30px;font-family:'Cormorant Garamond',serif;font-weight:700;font-style:italic}

footer{background:var(--deep);color:#8a7a9a;text-align:center;padding:1.8rem;font-size:.85rem}
footer a{color:var(--rose);margin:0 .4rem}

.prose{max-width:900px;margin:0 auto;padding:3rem 2rem}
.prose h1{color:var(--lavender);margin-bottom:1.5rem;font-size:2rem}
.prose h2{color:var(--lavender);margin:2rem 0 .7rem;font-size:1.3rem}
.prose p,.prose li{margin-bottom:.8rem;font-size:1rem}
.prose ul{padding-left:1.4rem}

.play-area{max-width:960px;margin:2rem auto;padding:0 2rem}
.play-area h1{color:var(--lavender);text-align:center;margin-bottom:1.2rem}
.play-note{text-align:center;color:#888;font-size:.93rem;margin-top:1.2rem}

.age-curtain{position:fixed;inset:0;z-index:9999;background:rgba(59,45,92,.92);display:flex;align-items:center;justify-content:center}
.age-panel{background:#fff;border-radius:16px;padding:2.5rem;text-align:center;max-width:420px;width:90%;border-bottom:3px solid var(--rosegold)}
.age-panel h2{color:var(--deep);font-family:'Cormorant Garamond',serif;font-style:italic;margin-bottom:.5rem}
.age-panel p{margin-bottom:1.5rem;color:#666;font-size:.95rem}
.age-actions{display:flex;gap:1rem;justify-content:center}
.age-actions button{padding:.65rem 1.8rem;border:none;border-radius:30px;font-size:1rem;font-weight:600;cursor:pointer}
.aa-yes{background:var(--rosegold);color:#fff}
.aa-no{background:#e0e0e0;color:#555}
.aa-yes:hover{background:var(--lavender)}
