/* =========================
   ViviPractice — styles.css
   Premium, calm, structured
   Theme: lavender-grey quiet luxury
   ========================= */

/* ---------- Design tokens ---------- */
:root{
  --bg:#fbfaf7;
  --surface:#ffffff;
  --surface-2:#f7f4ef;
  --surface-3:#f2ede6;

  --ink:#0b0f14;
  --ink-2:rgba(11,15,20,0.82);
  --ink-3:rgba(11,15,20,0.66);
  --ink-4:rgba(11,15,20,0.52);

  --hair:#e7e2d9;
  --hair2:#f1ede6;

  --accent:#8a7198;
  --accent2:#a99ab1;
  --accent-soft:rgba(138,113,152,0.10);
  --accent-line:rgba(138,113,152,0.22);

  --shadow:0 18px 55px rgba(12,15,20,0.07);
  --shadow2:0 10px 30px rgba(12,15,20,0.05);
  --shadow3:0 24px 80px rgba(12,15,20,0.09);

  --radius:18px;
  --radius2:26px;
  --radius3:34px;

  --max:1160px;
  --measure:72ch;

  --font-sans:"Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --font-serif:"Cormorant Garamond", ui-serif, Georgia, "Times New Roman", Times, serif;
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
html,body{height:100%}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  color:var(--ink);
  font-family:var(--font-sans);
  line-height:1.55;
  letter-spacing:-0.01em;
  background:linear-gradient(180deg, var(--bg), #ffffff 72%);
}

/* subtle grain */
body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  opacity:0.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

a{color:inherit;text-decoration:none}
a:hover{opacity:0.94}

img{display:block;max-width:100%}

.container{
  width:100%;
  max-width:var(--max);
  margin:0 auto;
  padding:0 22px;
}

.hr{
  border:none;
  border-top:1px solid var(--hair2);
  margin:0;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
}
.skip-link:focus{
  left:16px;
  top:16px;
  width:auto;
  height:auto;
  padding:10px 12px;
  background:var(--surface);
  border:1px solid var(--hair);
  border-radius:12px;
  box-shadow:var(--shadow2);
  z-index:9999;
}

/* ---------- Header / Nav ---------- */
header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(251,250,247,0.82);
  border-bottom:1px solid rgba(231,226,217,0.75);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:18px;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:650;
  letter-spacing:0.01em;
}

.brand-mark{
  width:30px;
  height:30px;
  border-radius:10px;
  background:radial-gradient(120% 120% at 20% 10%, #b9a6c5 0%, var(--accent) 55%, #5b4a66 100%);
  box-shadow:0 10px 24px rgba(138,113,152,0.18);
  flex:0 0 auto;
}

.brand small{
  display:block;
  font-size:12px;
  color:rgba(11,15,20,0.55);
  font-weight:500;
  letter-spacing:0.01em;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
}

.nav-links a{
  font-size:13.5px;
  color:rgba(11,15,20,0.80);
  padding:8px 6px;
  border-radius:10px;
  position:relative;
}

.nav-links a.active{
  color:rgba(11,15,20,0.92);
}
.nav-links a.active:after{
  content:"";
  position:absolute;
  left:6px;
  right:6px;
  bottom:3px;
  height:1.5px;
  border-radius:999px;
  background:rgba(138,113,152,0.95);
}

.nav-cta{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:11px 14px;
  border-radius:14px;
  border:1px solid rgba(231,226,217,0.95);
  background:rgba(255,255,255,0.88);
  font-weight:650;
  font-size:14px;
  transition:transform .12s ease, box-shadow .12s ease, background .12s ease, border-color .12s ease;
  cursor:pointer;
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow2);
  border-color:rgba(215,208,198,0.95);
}
.btn:active{
  transform:translateY(0);
}

.btn-primary{
  background:linear-gradient(135deg, #0b0f14 0%, #1a2028 100%);
  color:#fff;
  border:1px solid rgba(255,255,255,0.10);
  box-shadow:0 16px 40px rgba(11,15,20,0.20);
}
.btn-primary:hover{
  box-shadow:0 22px 55px rgba(11,15,20,0.26);
}

.btn-ghost{
  background:transparent;
  border:1px solid rgba(231,226,217,0.95);
}

.btn-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 2px;
  font-weight:650;
  font-size:14px;
  color:rgba(11,15,20,0.82);
  border-bottom:1px solid rgba(138,113,152,0.35);
}
.btn-link:hover{
  color:rgba(11,15,20,0.92);
  border-bottom-color:rgba(138,113,152,0.65);
}

.pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(231,226,217,0.95);
  background:rgba(255,255,255,0.84);
  font-weight:650;
  font-size:13px;
}
.pill.primary{
  background:linear-gradient(135deg, #0b0f14 0%, #1a2028 100%);
  color:#fff;
  border:1px solid rgba(255,255,255,0.10);
}

/* ---------- Typography ---------- */
.h1{
  margin:18px 0 12px;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.03em;
  font-size:56px;
  line-height:1.03;
}

.lead{
  max-width:var(--measure);
  color:var(--ink-3);
  font-size:18px;
  line-height:1.7;
}

/* ---------- Shared premium page system ---------- */
.page-hero{
  padding:78px 0 46px;
  background:
    radial-gradient(900px 420px at 18% 10%, rgba(138,113,152,0.10), transparent 58%),
    radial-gradient(700px 360px at 88% 14%, rgba(169,154,177,0.08), transparent 58%);
}

.page-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border:1px solid rgba(231,226,217,0.95);
  border-radius:999px;
  background:rgba(255,255,255,0.72);
  font-size:13px;
  color:rgba(11,15,20,0.70);
}

.dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:rgba(138,113,152,0.95);
  box-shadow:0 0 0 6px rgba(138,113,152,0.14);
}

.page-hero-grid{
  margin-top:28px;
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:18px;
  align-items:stretch;
}

.page-hero-copy{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

.page-hero-visual{
  border-radius:var(--radius2);
  border:1px solid rgba(231,226,217,0.95);
  overflow:hidden;
  background:
    radial-gradient(900px 420px at 20% 10%, rgba(138,113,152,0.16), transparent 55%),
    radial-gradient(700px 360px at 90% 30%, rgba(169,154,177,0.14), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,0.92), rgba(255,255,255,0.62));
  box-shadow:var(--shadow);
  position:relative;
  min-height:360px;
}
.page-hero-visual:after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(11,15,20,0.08), transparent 55%),
    linear-gradient(90deg, rgba(255,255,255,0.05), rgba(255,255,255,0));
  pointer-events:none;
}
.page-hero-visual .label{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  padding:14px;
  border-radius:16px;
  border:1px solid rgba(231,226,217,0.95);
  background:rgba(255,255,255,0.80);
  backdrop-filter:blur(10px);
}
.page-hero-visual .label strong{
  display:block;
  font-size:14px;
}
.page-hero-visual .label span{
  display:block;
  margin-top:6px;
  font-size:13px;
  color:rgba(11,15,20,0.68);
}

.hero-actions,
.page-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.page-band{
  border-top:1px solid var(--hair2);
  border-bottom:1px solid var(--hair2);
  background:rgba(255,255,255,0.70);
}
.page-band-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px;
  padding:22px 0;
}
.page-band-item{
  text-align:center;
  font-size:13px;
  letter-spacing:0.04em;
  color:rgba(11,15,20,0.70);
}

.section{
  padding:56px 0;
  background:transparent;
}

.section-soft{
  background:rgba(255,255,255,0.42);
  border-top:1px solid var(--hair2);
  border-bottom:1px solid var(--hair2);
}

.section-head{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:18px;
}
.section-head h2{
  margin:0;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.02em;
  font-size:36px;
}
.section-head p{
  margin:0;
  color:var(--ink-3);
  max-width:var(--measure);
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:16px;
}

.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  align-items:start;
}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,0.97), rgba(255,255,255,0.90));
  border:1px solid rgba(231,226,217,0.95);
  border-radius:var(--radius2);
  box-shadow:var(--shadow);
  padding:22px;
}
.card h3{
  margin:0 0 10px;
  font-size:16px;
  letter-spacing:-0.01em;
}
.card p{
  margin:0;
  color:var(--ink-3);
}

.feature{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:var(--radius);
  padding:18px;
  background:rgba(255,255,255,0.92);
  box-shadow:var(--shadow2);
}
.feature h4{
  margin:0 0 8px;
  font-size:15px;
}
.feature p{
  margin:0;
  color:var(--ink-3);
  font-size:14px;
}
.feature .tag{
  display:inline-block;
  margin-top:12px;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(138,113,152,0.16);
  background:rgba(138,113,152,0.05);
  color:rgba(88,66,100,0.85);
}

.statement{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:var(--radius2);
  background:linear-gradient(135deg, rgba(138,113,152,0.10), rgba(169,154,177,0.08));
  box-shadow:var(--shadow2);
  padding:22px;
}
.statement h3{
  font-family:var(--font-serif);
  font-size:22px;
  font-weight:600;
  margin:0 0 8px;
}
.statement p{
  margin:0;
  color:var(--ink-3);
}

.editorial-panel{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:var(--radius2);
  overflow:hidden;
  background:rgba(255,255,255,0.92);
  box-shadow:var(--shadow);
}
.editorial-image{
  min-height:360px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:24px;
  background:
    linear-gradient(180deg, rgba(11,15,20,0.03), rgba(11,15,20,0.08)),
    linear-gradient(135deg, rgba(138,113,152,0.16), rgba(255,255,255,0.72));
  color:rgba(11,15,20,0.48);
  font-size:14px;
  line-height:1.7;
}
.editorial-copy{
  padding:18px;
}
.editorial-copy p{
  margin:0;
  color:var(--ink-3);
}

.insights-strip{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:var(--radius2);
  background:rgba(255,255,255,0.88);
  box-shadow:var(--shadow2);
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.insights-strip h3{
  margin:0 0 6px;
  font-size:18px;
  letter-spacing:-0.01em;
}
.insights-strip p{
  margin:0;
  color:var(--ink-3);
  font-size:14px;
  line-height:1.7;
}

.section-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:16px;
}

.section-cta{
  padding-top:46px;
}

.cta-bar{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:var(--radius2);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(255,255,255,0.90));
  box-shadow:var(--shadow);
  padding:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.cta-bar h3{
  margin:0 0 6px;
  font-size:24px;
  font-family:var(--font-serif);
  font-weight:600;
}
.cta-bar p{
  margin:0;
  color:var(--ink-3);
}
.cta-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* ---------- Lists ---------- */
.ulist{
  margin:0;
  padding-left:18px;
  color:var(--ink-3);
}
.ulist li{
  margin:8px 0;
}

/* ---------- Forms ---------- */
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.field{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.field label{
  font-weight:650;
  font-size:13px;
  color:rgba(11,15,20,0.82);
}
.input, .select, .textarea{
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(231,226,217,0.95);
  background:rgba(255,255,255,0.92);
  color:rgba(11,15,20,0.88);
  outline:none;
}
.input:focus, .select:focus, .textarea:focus{
  border-color:rgba(138,113,152,0.30);
  box-shadow:0 0 0 6px rgba(138,113,152,0.10);
}
.helper{
  font-size:12px;
  color:rgba(11,15,20,0.58);
  line-height:1.45;
}

/* ---------- Pricing ---------- */
.billing-toggle{
  display:inline-flex;
  align-items:center;
  padding:4px;
  border-radius:999px;
  border:1px solid rgba(231,226,217,0.95);
  background:rgba(255,255,255,0.72);
  box-shadow:0 10px 24px rgba(12,15,20,0.04);
}
.toggle-btn{
  appearance:none;
  border:0;
  background:transparent;
  padding:9px 14px;
  border-radius:999px;
  font-weight:650;
  font-size:13px;
  color:rgba(11,15,20,0.64);
  cursor:pointer;
  transition:background .12s ease, color .12s ease, box-shadow .12s ease;
}
.toggle-btn:hover{
  color:rgba(11,15,20,0.82);
}
.toggle-btn.active{
  background:rgba(11,15,20,0.92);
  color:#fff;
  box-shadow:0 12px 26px rgba(11,15,20,0.14);
}
.billing-note{
  color:rgba(11,15,20,0.58);
  font-size:13px;
}

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:16px;
  align-items:stretch;
  margin-top:18px;
}
.plan{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:30px;
  background:rgba(255,255,255,0.92);
  box-shadow:0 22px 70px rgba(12,15,20,0.07);
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:520px;
}
.plan-top{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:start;
  gap:12px;
}
.plan-name{
  font-weight:700;
  font-size:17px;
  letter-spacing:-0.015em;
}
.plan-sub{
  margin-top:4px;
  font-size:13px;
  color:rgba(11,15,20,0.60);
}
.plan-badge{
  justify-self:end;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(138,113,152,0.22);
  background:rgba(255,255,255,0.72);
  backdrop-filter:blur(10px);
  color:rgba(88,66,100,0.85);
  white-space:nowrap;
}
.plan-price{
  display:flex;
  align-items:baseline;
  gap:8px;
  padding-bottom:14px;
  border-bottom:1px solid rgba(241,237,230,1);
}
.plan-price-number{
  font-size:38px;
  font-weight:750;
  letter-spacing:-0.04em;
}
.plan-price-unit{
  color:rgba(11,15,20,0.60);
  font-size:13px;
}
.plan-desc{
  color:rgba(11,15,20,0.66);
  font-size:14px;
  line-height:1.5;
}
.plan-list{
  margin:12px 0 0;
  padding-left:18px;
  color:rgba(11,15,20,0.70);
}
.plan-list li{
  margin:7px 0;
}
.plan-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:12px;
}
.plan-micro{
  margin-top:auto;
  padding-top:10px;
  border-top:1px solid rgba(241,237,230,1);
  color:rgba(11,15,20,0.58);
  font-size:12px;
  line-height:1.45;
}
.plan-featured{
  border:1.5px solid rgba(138,113,152,0.32);
  background:
    radial-gradient(900px 420px at 30% 0%, rgba(138,113,152,0.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(138,113,152,0.05));
  box-shadow:0 28px 90px rgba(12,15,20,0.10);
  transform:translateY(-4px);
}

/* ---------- Insights Index ---------- */
.insights-wrap{
  max-width:var(--max);
  margin:0 auto;
  padding:0 22px;
}

.insights-mast{
  padding:26px 0 10px;
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.insights-mast .label{
  font-size:12px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--ink-4);
}
.insights-mast .note{
  font-size:12px;
  letter-spacing:0.06em;
  color:var(--ink-4);
}
.insights-rule{
  height:1px;
  background:rgba(231,226,217,0.95);
  margin:10px 0 0;
}

.cover-plate{
  border-radius:var(--radius2);
  border:1px solid rgba(231,226,217,0.95);
  overflow:hidden;
  box-shadow:var(--shadow);
  position:relative;
  background:
    radial-gradient(1050px 560px at 14% 16%, rgba(138,113,152,0.22), transparent 60%),
    radial-gradient(820px 520px at 82% 24%, rgba(169,154,177,0.18), transparent 64%),
    linear-gradient(135deg, rgba(255,255,255,0.96), rgba(255,255,255,0.68));
}
.cover-inner{
  padding:30px;
  display:grid;
  grid-template-columns:1.2fr 0.8fr;
  gap:20px;
  align-items:stretch;
}
.cover-kicker{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.58);
}
.cover-title{
  margin:12px 0 10px;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.03em;
  font-size:46px;
  line-height:1.03;
  max-width:24ch;
}
.cover-lede{
  margin:0;
  color:var(--ink-2);
  max-width:var(--measure);
  line-height:1.7;
  font-size:16px;
}
.cover-meta{
  margin-top:14px;
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  font-size:12px;
  color:var(--ink-4);
  letter-spacing:0.08em;
  text-transform:uppercase;
}
.cover-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.cover-aside{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:20px;
  background:rgba(255,255,255,0.76);
  backdrop-filter:blur(10px);
  box-shadow:var(--shadow2);
  padding:18px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.cover-aside h3{
  margin:0 0 8px;
  font-size:13px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.62);
}
.cover-aside p{
  margin:0;
  color:var(--ink-3);
  font-size:13px;
  line-height:1.7;
}
.cover-aside a{
  margin-top:14px;
  display:inline-block;
  font-weight:650;
  font-size:13px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.78);
  border-bottom:1px solid rgba(138,113,152,0.28);
  padding-bottom:3px;
}

.insights-section{
  padding:44px 0;
}
.section-head-aman{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.section-head-aman h2{
  margin:0;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.02em;
  font-size:30px;
}
.section-head-aman p{
  margin:0;
  max-width:60ch;
  color:var(--ink-3);
  font-size:13px;
  line-height:1.6;
}

.insights-list{
  border-top:1px solid rgba(241,237,230,1);
}
.insights-item{
  padding:18px 2px;
  display:grid;
  grid-template-columns:130px 1fr;
  gap:16px;
  border-bottom:1px solid rgba(241,237,230,1);
}
.insights-item .meta{
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--ink-4);
}
.insights-item h3{
  margin:0 0 8px;
  font-size:18px;
  letter-spacing:-0.01em;
}
.insights-item p{
  margin:0;
  color:var(--ink-3);
  line-height:1.65;
  max-width:var(--measure);
}
.insights-item a{
  display:inline-block;
  margin-top:10px;
  font-weight:650;
  font-size:13px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(138,113,152,0.28);
  padding-bottom:3px;
}

.insights-pagination{
  margin-top:22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
.insights-pagination .note{
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--ink-4);
}
.insights-pagination .controls{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* ---------- Journal / article systems ---------- */
.journal-hero{
  padding:56px 0 34px;
}

.journal-topline{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  padding-bottom:16px;
  border-bottom:1px solid rgba(241,237,230,1);
}

.journal-grid{
  display:grid;
  grid-template-columns:1.55fr 0.85fr;
  gap:22px;
  align-items:start;
  margin-top:18px;
}

.journal-h1{
  margin:8px 0 10px;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.03em;
  font-size:58px;
  line-height:1.02;
}

.journal-subhead{
  margin:0;
  max-width:var(--measure);
  font-size:18px;
  line-height:1.75;
  color:var(--ink-3);
}

.journal-byline{
  margin-top:16px;
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--ink-4);
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.journal-cta-row{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.journal-aside{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.aside-card{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:20px;
  background:rgba(255,255,255,0.86);
  box-shadow:var(--shadow2);
  padding:16px;
}
.aside-title{
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.60);
  margin-bottom:10px;
  font-weight:650;
}
.aside-text{
  margin:0;
  color:var(--ink-3);
  font-size:14px;
  line-height:1.7;
}
.aside-list{
  margin:0;
  padding-left:18px;
  color:var(--ink-3);
  font-size:14px;
  line-height:1.7;
}
.aside-list li{
  margin:8px 0;
}

.journal-body{
  padding:48px 0 64px;
}
.journal-article{
  max-width:var(--measure);
}

.journal-h2{
  margin:0 0 12px;
  padding-top:26px;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.02em;
  font-size:34px;
  line-height:1.12;
}

.journal-article p{
  margin:0 0 14px;
  font-size:18px;
  line-height:1.8;
  color:var(--ink-3);
}

.journal-bullets,
.journal-steps{
  margin:12px 0 18px;
  padding-left:20px;
  color:var(--ink-3);
  font-size:18px;
  line-height:1.8;
}
.journal-bullets li,
.journal-steps li{
  margin:10px 0;
}

.callout{
  margin:18px 0 12px;
  border:1px solid rgba(231,226,217,0.95);
  border-radius:22px;
  background:rgba(255,255,255,0.86);
  box-shadow:var(--shadow2);
  padding:16px 18px;
}
.callout-title,
.callout .k{
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.55);
  font-weight:650;
  margin-bottom:8px;
}
.callout-text,
.callout p{
  margin:0;
  color:var(--ink-3);
  font-size:16px;
  line-height:1.75;
}

.divider{
  margin:24px 0 6px;
  height:1px;
  background:rgba(241,237,230,1);
  border-radius:999px;
}

.journal-bottom-cta{
  margin-top:26px;
  border:1px solid rgba(231,226,217,0.95);
  border-radius:26px;
  background:rgba(255,255,255,0.86);
  box-shadow:var(--shadow2);
  padding:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.journal-bottom-cta h3{
  margin:0 0 6px;
  font-size:16px;
  letter-spacing:-0.01em;
}
.journal-bottom-cta p{
  margin:0;
  font-size:14px;
  color:var(--ink-3);
  line-height:1.7;
}
.journal-bottom-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.journal-disclaimer,
.disclaimer{
  margin-top:16px;
  color:var(--ink-4);
  font-size:12.5px;
  line-height:1.5;
}

.article-shell{
  padding:54px 0 72px;
  background:
    radial-gradient(700px 360px at 12% 0%, rgba(138,113,152,0.06), transparent 55%),
    radial-gradient(620px 320px at 88% 0%, rgba(169,154,177,0.05), transparent 55%);
}
.article-grid{
  display:grid;
  grid-template-columns:1.4fr 0.6fr;
  gap:22px;
  align-items:start;
}
.article-hero{
  padding:28px 0 18px;
  border-bottom:1px solid rgba(241,237,230,1);
  margin-bottom:18px;
}
.article-eyebrow{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  font-size:12px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.55);
}
.article-tags{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}
.article-title{
  margin:14px 0 12px;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.035em;
  font-size:56px;
  line-height:1.02;
  max-width:22ch;
}
.article-lede{
  margin:0;
  max-width:var(--measure);
  font-size:18px;
  line-height:1.8;
  color:rgba(11,15,20,0.70);
}
.article-meta{
  margin-top:16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  font-size:12px;
  letter-spacing:0.10em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.50);
}
.article-actions{
  margin-top:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.prose{
  max-width:var(--measure);
}
.prose h2{
  margin:34px 0 10px;
  font-family:var(--font-serif);
  font-weight:600;
  letter-spacing:-0.02em;
  font-size:34px;
  line-height:1.12;
}
.prose p{
  margin:0 0 14px;
  font-size:18px;
  line-height:1.85;
  color:rgba(11,15,20,0.72);
}
.prose ul,
.prose ol{
  margin:10px 0 18px;
  padding-left:20px;
  color:rgba(11,15,20,0.72);
  font-size:18px;
  line-height:1.85;
}
.prose li{
  margin:10px 0;
}

.pull{
  margin:18px 0;
  padding:10px 0 10px 16px;
  border-left:3px solid rgba(138,113,152,0.55);
  color:rgba(11,15,20,0.74);
  font-size:16px;
  line-height:1.7;
  max-width:var(--measure);
}

.aside{
  display:flex;
  flex-direction:column;
  gap:14px;
  position:sticky;
  top:92px;
}
.aside-cta{
  background:
    radial-gradient(700px 300px at 20% 0%, rgba(138,113,152,0.10), transparent 60%),
    rgba(255,255,255,0.88);
  border-color:rgba(138,113,152,0.22);
}

.endcap{
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid rgba(241,237,230,1);
  max-width:var(--measure);
}

.next-reads{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:14px;
  max-width:var(--measure);
}

.next-card{
  border:1px solid rgba(231,226,217,0.95);
  border-radius:22px;
  background:rgba(255,255,255,0.86);
  box-shadow:var(--shadow2);
  padding:16px;
}
.next-card .k{
  font-size:12px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(11,15,20,0.52);
  margin-bottom:8px;
}
.next-card h3{
  margin:0 0 8px;
  font-size:18px;
  letter-spacing:-0.01em;
}
.next-card p{
  margin:0 0 10px;
  color:rgba(11,15,20,0.66);
  font-size:14px;
  line-height:1.7;
}

/* ---------- Footer ---------- */
footer{
  border-top:1px solid rgba(241,237,230,1);
  padding:34px 0 44px;
  color:rgba(11,15,20,0.60);
  font-size:13px;
  background:linear-gradient(180deg, rgba(251,250,247,0.00) 0%, rgba(241,237,230,0.22) 100%);
}

.footer-top{
  display:grid;
  grid-template-columns:1.1fr 1.4fr;
  gap:28px;
  align-items:start;
  padding-top:8px;
}

.footer-brand{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.footer-logo{
  display:flex;
  align-items:center;
  gap:10px;
}
.footer-logo strong{
  font-size:14px;
  letter-spacing:0.01em;
}
.footer-tagline{
  font-size:12px;
  color:rgba(11,15,20,0.55);
  margin-top:2px;
}

.footer-contact{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.footer-email{
  font-weight:650;
  color:rgba(11,15,20,0.86);
}
.footer-note{
  font-size:12px;
  color:rgba(11,15,20,0.55);
}

.footer-cols{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:22px;
}
.footer-col{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.footer-title{
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  font-weight:650;
  color:rgba(11,15,20,0.72);
  margin-bottom:6px;
}
.footer-col a{
  color:rgba(11,15,20,0.62);
  padding:3px 0;
}
.footer-col a:hover{
  color:rgba(11,15,20,0.82);
}
.footer-muted{
  color:rgba(11,15,20,0.52);
  font-size:12px;
  line-height:1.4;
}

.footer-bottom{
  margin-top:22px;
  padding-top:16px;
  border-top:1px solid rgba(241,237,230,1);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.footer-bottom-links{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.footer-bottom-links a{
  color:rgba(11,15,20,0.58);
}
.footer-bottom-links a:hover{
  color:rgba(11,15,20,0.80);
}

/* ---------- Responsive ---------- */
@media (max-width: 980px){
  .h1{font-size:44px}

  .page-hero-grid,
  .hero-split,
  .grid-3,
  .split,
  .form-grid,
  .pricing-grid,
  .journal-grid,
  .article-grid,
  .footer-top,
  .footer-cols,
  .page-band-grid,
  .cover-inner,
  .next-reads{
    grid-template-columns:1fr;
  }

  .plan-featured{transform:none}
  .cover-title{font-size:36px}
  .insights-item{grid-template-columns:1fr}
  .journal-h1,
  .article-title{font-size:44px;max-width:none}
  .aside{position:static;top:auto}
}

@media (max-width: 720px){
  .nav{
    flex-wrap:wrap;
    justify-content:center;
  }
  .nav-cta{
    width:100%;
    justify-content:center;
  }
}