
/* e-milie theme.css — V2 pages (journal, cercles, pro) */
/* Import base design system */
@import url('app.css');

/* footer-v2 styles */
.footer-v2 { background: var(--ink); color: var(--cream); padding: 72px 24px 32px; margin-top: 0; border-radius: 48px 48px 0 0; }
.footer-v2 .foot-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 40px; margin-bottom: 40px; max-width: 1180px; margin-left: auto; margin-right: auto; }
@media (max-width: 900px) { .footer-v2 .foot-grid { grid-template-columns: 1fr 1fr; } }
.footer-v2 a { color: rgba(253,250,243,.85); text-decoration: none; font-size: 14px; line-height: 2; display: block; transition: color .2s; }
.footer-v2 a:hover { color: var(--coral-soft); }
.foot-legal { padding-top: 24px; border-top: 1px solid rgba(255,255,255,.1); font-size: 12px; color: rgba(253,250,243,.5); text-align: center; max-width: 1180px; margin: 0 auto; }
.logo-foot { font-family: 'Fraunces', serif; font-size: 28px; font-weight: 500; color: var(--cream); text-decoration: none; letter-spacing: -.02em; display: block; margin-bottom: 10px; }
.baseline { font-size: 13px; color: rgba(253,250,243,.55); margin: 0; }

/* nav-v2 override for these pages */
.nav-v2 { position: fixed; top: 20px; left: 50%; transform: translateX(-50%); z-index: 100; padding: 12px 20px; background: rgba(253,250,243,.8); backdrop-filter: saturate(1.6) blur(16px); -webkit-backdrop-filter: saturate(1.6) blur(16px); border: 1px solid rgba(255,255,255,.6); border-radius: 999px; display: flex; align-items: center; gap: 8px; box-shadow: 0 10px 30px -10px rgba(30,27,46,.15); transition: top .4s, padding .3s; }
.nav-v2 .logo { font-family: 'Fraunces', serif; font-size: 20px; font-weight: 500; color: var(--ink); text-decoration: none; padding-right: 12px; border-right: 1px solid rgba(30,27,46,.1); margin-right: 4px; }
.nav-v2 .dot { color: var(--coral); }
.nav-v2 .nav-link { padding: 8px 14px; border-radius: 999px; color: var(--ink); text-decoration: none; font-size: 14px; font-weight: 500; transition: background .3s, color .3s; }
.nav-v2 .nav-link:hover { background: rgba(30,27,46,.06); }
.nav-v2 .nav-actions { display: flex; align-items: center; gap: 8px; }
.nav-v2 .cta { padding: 8px 16px; border-radius: 999px; background: var(--ink); color: var(--cream); text-decoration: none; font-size: 14px; font-weight: 500; transition: background .3s; }
.nav-v2 .cta:hover { background: var(--coral); }

/* pre-spinner */
.pre-spinner { width: 48px; height: 48px; border-radius: 50%; border: 3px solid rgba(232,89,60,.2); border-top-color: var(--coral); animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* btn-liquid used on these pages */
.btn-liquid { position: relative; display: inline-flex; align-items: center; gap: 10px; padding: 16px 32px; border-radius: 999px; background: var(--ink); color: var(--cream); font-weight: 500; font-size: 16px; border: none; cursor: pointer; overflow: hidden; isolation: isolate; transition: color .4s cubic-bezier(.2,1,.3,1); box-shadow: 0 10px 30px -10px rgba(30,27,46,.4); text-decoration: none; }
.btn-liquid::before { content: ''; position: absolute; inset: 0; background: var(--grad-dawn); border-radius: inherit; transform: translateY(101%); transition: transform .5s cubic-bezier(.2,1,.3,1); z-index: -1; }
.btn-liquid:hover { color: var(--ink); }
.btn-liquid:hover::before { transform: translateY(0); }
.btn-liquid.primary { background: var(--grad-healing); color: #fff; }
.btn-liquid.magnetic { will-change: transform; }

/* eyebrow for v2 sections */
.eyebrow { font-size: 13px; letter-spacing: .18em; text-transform: uppercase; color: var(--coral); margin-bottom: 20px; display: inline-block; padding: 6px 14px; border-radius: 999px; background: rgba(232,89,60,.08); }
