/* Atlas Moon Publishing — site stylesheet */
:root{
  --indigo:#1E1B4B; --indigo-deep:#15123a; --midnight:#2B2D5C; --gold:#F5B942;
  --honey:#FCD787; --cream:#FAF5EA; --violet:#7C6FA8; --ink:#3a3654; --ink-soft:#5b5577;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Nunito Sans',sans-serif;background:var(--indigo);color:var(--cream);font-size:1.08rem;line-height:1.65}
h1,h2,h3,h4{font-family:'Fraunces',serif;font-weight:600;line-height:1.22}
img{max-width:100%;display:block}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}
.script{font-family:'Caveat',cursive;color:var(--honey);font-size:1.5rem}
.label{letter-spacing:.18em;text-transform:uppercase;font-size:.78rem;font-weight:700;color:#9D92C7;margin-bottom:14px}
.light .label{color:#6e6395}

/* accessibility */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:var(--gold);color:var(--indigo);padding:10px 18px;border-radius:0 0 12px 0;font-weight:700;text-decoration:none}
.skip-link:focus{left:0}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,summary:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* buttons */
.btn{display:inline-block;padding:14px 32px;border-radius:999px;font-weight:700;text-decoration:none;font-size:1rem;transition:all .3s ease;cursor:pointer;border:none;font-family:'Nunito Sans',sans-serif}
.btn-gold{background:var(--gold);color:var(--indigo)}
.btn-gold:hover{box-shadow:0 0 24px rgba(245,185,66,.45);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--cream);border:1.5px solid rgba(250,245,234,.5)}
.btn-ghost:hover{color:var(--gold);border-color:var(--gold)}
.light .btn-ghost{color:var(--ink);border-color:var(--ink)}
.light .btn-ghost:hover{color:var(--violet);border-color:var(--violet)}
.btn-soon{background:rgba(124,111,168,.25);color:var(--cream);border:1.5px dashed rgba(250,245,234,.4);cursor:default}

/* header */
header{padding:18px 0;position:sticky;top:0;background:rgba(30,27,75,.93);backdrop-filter:blur(8px);z-index:50;border-bottom:1px solid rgba(250,245,234,.08)}
header .wrap{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.logo{font-family:'Fraunces',serif;font-size:1.3rem;color:var(--cream);text-decoration:none;display:flex;align-items:center;gap:10px}
.logo .moon{width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 35% 35%,var(--honey),var(--gold));box-shadow:0 0 18px rgba(245,185,66,.5);flex:none}
nav{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
nav a{color:rgba(250,245,234,.85);text-decoration:none;font-size:.95rem;font-weight:600}
nav a:hover,nav a.active{color:var(--gold)}
@media(max-width:820px){nav{gap:14px}nav a{font-size:.88rem}}
@media(max-width:560px){
  header{padding:12px 0}
  header .wrap{flex-direction:column;gap:10px}
  .logo{font-size:1.15rem}
  nav{justify-content:center;gap:14px;row-gap:8px}
  nav .btn{padding:8px 18px !important;font-size:.9rem}
}

/* sections */
section{padding:88px 0}
h1{font-size:clamp(2.2rem,5vw,3.4rem)}
h2{font-size:clamp(1.7rem,3.5vw,2.4rem);margin-bottom:18px}
.light{background:var(--cream);color:var(--ink)}
.light h1,.light h2,.light h3,.light h4{color:var(--indigo)}
.mid{background:var(--midnight)}
.muted{color:rgba(250,245,234,.78)}
.light .muted{color:var(--ink-soft)}

/* hero */
.hero{position:relative;padding:80px 0 90px;overflow:hidden;background:linear-gradient(180deg,var(--indigo-deep) 0%,var(--indigo) 60%,#252259 100%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr}}
.hero h1 em{font-style:italic;color:var(--honey)}
.hero p.lead{margin:20px 0 34px;color:rgba(250,245,234,.85);font-size:1.16rem;max-width:520px}
.hero-art{border-radius:22px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.5);border:1px solid rgba(245,185,66,.2)}
.ctas{display:flex;gap:16px;flex-wrap:wrap}
.star{position:absolute;background:#fff;border-radius:50%;opacity:.6;animation:twinkle 4.5s infinite ease-in-out}
@keyframes twinkle{0%,100%{opacity:.2}50%{opacity:.8}}

/* page hero (interior pages) */
.page-hero{padding:70px 0 60px;background:linear-gradient(180deg,var(--indigo-deep),var(--indigo))}

/* book grids */
.book-grid{display:grid;grid-template-columns:320px 1fr;gap:56px;align-items:center}
.book-grid-sm{grid-template-columns:240px 1fr;gap:44px}
@media(max-width:820px){.book-grid,.book-grid-sm{grid-template-columns:1fr;max-width:460px;margin-left:auto;margin-right:auto}.book-grid-sm .cover-img{max-width:240px;margin:0 auto}}

/* meet-lumo grid */
.lumo-grid{display:grid;grid-template-columns:240px 1fr;gap:56px;align-items:center}
@media(max-width:760px){.lumo-grid{grid-template-columns:1fr;gap:24px;text-align:center}.lumo-grid svg{width:150px;height:auto;margin:0 auto}}
.cover-img{border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.35);border:1px solid rgba(245,185,66,.25)}
.meta{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 22px}
.chip{border-radius:999px;padding:5px 14px;font-size:.82rem;font-weight:700;background:rgba(245,185,66,.1);border:1px solid rgba(245,185,66,.4);color:var(--honey)}
.light .chip{background:rgba(124,111,168,.12);border-color:rgba(124,111,168,.45);color:#5b5380}

/* shelf (series covers row) */
.shelf{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:44px}
@media(max-width:900px){.shelf{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.shelf{grid-template-columns:1fr;max-width:300px;margin-left:auto;margin-right:auto}}
.shelf a{text-decoration:none;color:inherit;display:block;transition:transform .3s ease}
.shelf a:hover{transform:translateY(-6px)}
.shelf .feeling{margin-top:14px;text-align:center}
.shelf .feeling .f-label{display:inline-block;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--honey)}
.light .shelf .feeling .f-label{color:#8d7fb8}
.shelf .feeling h3{font-size:1.06rem;margin-top:4px}

/* cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
@media(max-width:760px){.cards{grid-template-columns:1fr}}
.card{background:rgba(43,45,92,.6);border:1px solid rgba(250,245,234,.1);border-radius:20px;padding:32px}
.light .card{background:#fff;border-color:rgba(124,111,168,.18);box-shadow:0 10px 30px rgba(30,27,75,.07)}
.card .ico{font-size:1.7rem;margin-bottom:12px}
.card h3{font-size:1.12rem;color:var(--honey);margin-bottom:10px}
.light .card h3{color:var(--indigo)}
.card p{font-size:.96rem}

/* method strip */
.method{margin-top:48px;text-align:center;padding:28px;border-radius:20px;background:rgba(245,185,66,.07);border:1px solid rgba(245,185,66,.3)}
.method .steps{font-family:'Fraunces',serif;font-size:clamp(1.15rem,2.6vw,1.55rem);color:var(--honey)}
.light .method{background:rgba(245,185,66,.12);border-color:rgba(245,185,66,.5)}
.light .method .steps{color:#a06b10}

/* calm kit band */
.kit{background:linear-gradient(135deg,#3a2f12 0%,#4a3a14 50%,#3a2f12 100%);position:relative;overflow:hidden}
.kit::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(245,185,66,.22),transparent 60%)}
.kit .wrap{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:56px;align-items:center}
@media(max-width:820px){.kit .wrap{grid-template-columns:1fr}}
.kit h2{color:var(--honey)}
.kit ul{list-style:none;margin:20px 0 28px}
.kit li{padding:7px 0 7px 32px;position:relative;color:rgba(250,245,234,.9)}
.kit li::before{content:"★";position:absolute;left:0;color:var(--gold);font-size:.85rem;top:9px}
.form{display:flex;gap:12px;flex-wrap:wrap}
.form input,.cform input,.cform select,.cform textarea{padding:14px 20px;border-radius:999px;border:1.5px solid rgba(250,245,234,.3);background:rgba(30,27,75,.5);color:var(--cream);font-size:1rem;font-family:inherit}
.form input{flex:1;min-width:220px}
.form input::placeholder{color:rgba(250,245,234,.5)}
.fineprint{font-size:.83rem;color:rgba(250,245,234,.55);margin-top:14px}
.kit-card{background:rgba(250,245,234,.07);border:1px solid rgba(245,185,66,.35);border-radius:20px;padding:36px;text-align:center}
.kit-card .moonbig{width:70px;height:70px;border-radius:50%;margin:0 auto 18px;background:radial-gradient(circle at 35% 35%,var(--honey),var(--gold));box-shadow:0 0 40px rgba(245,185,66,.55)}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:36px}
@media(max-width:700px){.gallery{grid-template-columns:1fr}}
.gallery figure{border-radius:16px;overflow:hidden;box-shadow:0 16px 40px rgba(30,27,75,.18)}
.gallery figcaption{font-size:.88rem;padding:10px 14px;background:#fff;color:var(--ink-soft)}

/* two-col lists */
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:30px}
@media(max-width:760px){.twocol{grid-template-columns:1fr}}
.checklist{list-style:none}
.checklist li{padding:8px 0 8px 34px;position:relative}
.checklist li::before{content:"✦";position:absolute;left:4px;color:var(--gold);top:9px;font-size:.9rem}

/* FAQ */
details{border-bottom:1px solid rgba(124,111,168,.25);padding:6px 0}
details summary{cursor:pointer;font-weight:700;padding:14px 0;font-size:1.05rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
details summary::after{content:"+";font-family:'Fraunces',serif;font-size:1.4rem;color:var(--violet);transition:transform .25s}
details[open] summary::after{transform:rotate(45deg)}
details p{padding:0 0 16px;color:var(--ink-soft)}

/* trust */
.trust-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:36px}
@media(max-width:760px){.trust-cols{grid-template-columns:1fr}}
.trust-cols h3{font-size:1.12rem;margin-bottom:10px}
.trust-cols p{font-size:.97rem;color:var(--ink-soft)}

/* contact form */
.cform{display:grid;gap:16px;max-width:560px}
.cform input,.cform select{width:100%}
.cform textarea{width:100%;border-radius:20px;min-height:140px;resize:vertical}
.light .cform input,.light .cform select,.light .cform textarea{background:#fff;border-color:rgba(124,111,168,.4);color:var(--ink)}

/* prose pages */
.prose{max-width:760px}
.prose p{margin-bottom:18px}
.prose h2{margin-top:36px}

/* footer */
footer{background:var(--indigo-deep);padding:60px 0 40px;border-top:1px solid rgba(250,245,234,.08)}
footer .fnav{display:flex;gap:22px;flex-wrap:wrap}
footer a{color:rgba(250,245,234,.7);text-decoration:none;font-size:.9rem}
footer a:hover{color:var(--gold)}
.copyright{width:100%;text-align:center;margin-top:40px;font-size:.85rem;color:rgba(250,245,234,.45)}

/* misc */
.center{text-align:center}
.note{font-size: