/* =========================================================
   SYNASTRY — J × D
   Sleek premium. Bottega/Prada quiet luxury.
   Black, cream, brass. No neon. No noise.
   ========================================================= */

:root{
  --bg:        #0a0a0a;
  --bg-2:      #111111;
  --bg-3:      #1a1a1a;
  --ink:       #f4efe6;
  --ink-mute:  #8e887d;
  --ink-faint: #4a463f;
  --line:      #232220;
  --line-2:    #2c2a26;
  --brass:     #b89968;
  --brass-2:   #d8b984;
  --rose:      #c08c7a;
  --water:     #6a8a9a;
  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, monospace;
  --pad: clamp(20px, 4vw, 56px);
  --max: 1280px;
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
  min-height:100vh;
}

a{color:inherit; text-decoration:none;}
button{font:inherit; color:inherit; background:none; border:none; cursor:pointer;}
img,svg{display:block; max-width:100%;}

::selection{background:var(--brass); color:var(--bg);}

/* ========== STAR CANVASES ========== */
#stars, #constellation{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:0;
}
#stars{ opacity:.65; }
#constellation{ opacity:.35; mix-blend-mode:screen;}

main, .topbar, .foot{ position:relative; z-index:2;}

/* ========== TOP BAR ========== */
.topbar{
  position:fixed;
  top:0; left:0; right:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 18px var(--pad);
  z-index:50;
  background: linear-gradient(180deg, rgba(10,10,10,.78) 0%, rgba(10,10,10,0) 100%);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.brand{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--serif);
  font-size:18px;
  letter-spacing:.04em;
}
.brand-mark{ color:var(--brass); font-size:13px;}
.nav{ display:flex; gap:28px;}
.nav a{
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
  transition:color .3s ease;
  position:relative;
}
.nav a::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-6px;
  height:1px;
  background:var(--brass);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s cubic-bezier(.7,0,.2,1);
}
.nav a:hover{color:var(--ink);}
.nav a:hover::after{transform:scaleX(1);}

.mute{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
  padding:6px 0;
}
.mute-dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--ink-faint);
  transition:background .3s ease;
}
.mute[aria-pressed="false"] .mute-dot{ background:var(--brass);}

@media (max-width: 760px){
  .nav{ display:none;}
}

/* ========== HERO ========== */
.hero{
  min-height:100vh;
  padding: 110px var(--pad) 40px;
  display:grid;
  grid-template-rows: auto 1fr auto;
  gap: 24px;
  position:relative;
}
.hero-meta{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
}
.lbl{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
}

.hero-center{
  align-self:center;
  text-align:center;
  max-width: 980px;
  margin: 0 auto;
  padding: 40px 0;
}
.hero-names{
  font-family:var(--serif);
  font-weight:300;
  font-size: clamp(56px, 11vw, 168px);
  line-height: .95;
  letter-spacing:-.02em;
  display:flex;
  justify-content:center;
  align-items:baseline;
  gap: clamp(20px, 4vw, 44px);
  flex-wrap:wrap;
}
.hero-name{
  display:inline-block;
  font-style:italic;
  position:relative;
  opacity:0;
  transform:translateY(40px);
  animation: rise .9s .1s cubic-bezier(.2,.8,.2,1) forwards;
}
.hero-name.right{ animation-delay:.35s; font-style:italic;}
.hero-amp{
  font-family:var(--serif);
  font-style:normal;
  color:var(--brass);
  font-size:.5em;
  opacity:0;
  animation: fade .8s .8s ease forwards;
}
.hero-subtitle{
  margin-top: 24px;
  font-size:14px;
  color:var(--ink-mute);
  letter-spacing:.04em;
  font-style:italic;
  opacity:0;
  animation: fade 1s 1s ease forwards;
}
.hero-coords{
  margin-top: 36px;
  display:flex;
  justify-content:center;
  gap: 40px;
  flex-wrap:wrap;
  opacity:0;
  animation: fade 1s 1.2s ease forwards;
}
.coord{
  display:inline-flex;
  align-items:baseline;
  gap:14px;
  font-family:var(--mono);
  font-size:11px;
  color:var(--ink-mute);
  letter-spacing:.04em;
}
.coord-key{
  width:22px; height:22px;
  display:inline-flex;
  align-items:center; justify-content:center;
  border:1px solid var(--brass);
  color:var(--brass);
  border-radius:50%;
  font-size:10px;
}

.hero-enter{ display:flex; justify-content:center;}
.enter{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink-mute);
  transition:color .3s ease;
}
.enter-line{
  width:60px; height:1px;
  background:var(--brass);
  transition:width .4s cubic-bezier(.2,.8,.2,1);
}
.enter:hover{ color:var(--ink);}
.enter:hover .enter-line{ width:120px;}

.scroll-hint{
  position:absolute;
  left:50%; bottom:24px;
  transform:translateX(-50%);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  opacity:0;
  animation: fade 1s 1.6s ease forwards;
}
.scroll-line{
  width:1px; height:34px;
  background:linear-gradient(to bottom, var(--brass), transparent);
  animation: pulse-line 2.4s ease-in-out infinite;
}
.scroll-word{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--ink-mute);
}

@keyframes rise{
  to{ opacity:1; transform:translateY(0);}
}
@keyframes fade{
  to{ opacity:1;}
}
@keyframes pulse-line{
  0%,100%{ transform:scaleY(.4); opacity:.4;}
  50%{ transform:scaleY(1); opacity:1;}
}

/* ========== CONTAINER / SECTION HEAD ========== */
.container{
  max-width:var(--max);
  margin: 0 auto;
  padding: 0 var(--pad);
}
.container.narrow{ max-width: 880px;}

section{
  padding: clamp(80px, 12vh, 160px) 0;
  position:relative;
}

.row-head{
  display:flex;
  align-items:center;
  gap: 18px;
  margin-bottom: 56px;
  padding-bottom: 16px;
  border-bottom:1px solid var(--line);
}
.section-num{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  color:var(--brass);
}
.section-title{
  font-family:var(--serif);
  font-style:italic;
  font-size:24px;
  font-weight:300;
}
.section-line{
  flex:1;
  height:1px;
  background:linear-gradient(to right, var(--line) 0%, transparent 100%);
}
.section-lede{
  max-width: 640px;
  color:var(--ink-mute);
  font-style:italic;
  margin-bottom: 32px;
  font-size:14px;
}

/* ========== IDENTITIES ========== */
.identity-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap: 1px;
  background:var(--line);
  border:1px solid var(--line);
}
.identity{
  background:var(--bg);
  padding: 48px 40px;
  display:flex;
  flex-direction:column;
  gap:24px;
  position:relative;
  transition:background .5s ease;
}
.identity:hover{ background:var(--bg-2);}
.identity-mark{
  width:64px; height:64px;
  display:flex;
  align-items:center; justify-content:center;
  border:1px solid var(--line-2);
  border-radius:50%;
  color:var(--brass);
}
.glyph{ font-size:24px; line-height:1;}

.identity-name{
  font-family:var(--serif);
  font-weight:300;
  font-size: clamp(22px, 2.4vw, 30px);
  line-height:1.15;
  letter-spacing:-.01em;
}
.identity-tag{
  margin-top:6px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--brass);
}

.identity-data{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap: 12px 32px;
  margin-top:8px;
  border-top:1px solid var(--line);
  padding-top:24px;
}
.identity-data > div{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:8px;
  padding-bottom:8px;
  border-bottom:1px solid var(--line);
}
.identity-data dt{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.identity-data dd{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--ink);
}
.identity-note{
  margin-top:8px;
  color:var(--ink-mute);
  font-style:italic;
  font-size:14px;
  line-height:1.6;
}

@media (max-width: 760px){
  .identity-grid{ grid-template-columns:1fr;}
  .identity{ padding:32px 24px;}
  .identity-data{ grid-template-columns:1fr;}
}

/* ========== CHARTS ========== */
.chart-grid{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 32px;
  align-items:start;
}
.chart-block{
  display:flex;
  flex-direction:column;
  gap:24px;
}
.chart-label{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  padding-bottom:12px;
  border-bottom:1px solid var(--line);
}
.chart-letter{
  font-family:var(--serif);
  font-style:italic;
  font-size:42px;
  color:var(--brass);
  line-height:1;
}
.chart-place{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.16em;
  color:var(--ink-mute);
  text-transform:uppercase;
}
.chart-wheel-wrap{
  position:relative;
  aspect-ratio: 1;
  width:100%;
  display:flex;
  align-items:center; justify-content:center;
}
.chart-wheel{
  width:100%; height:100%;
}
.chart-divider{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  height:100%;
  gap:14px;
  padding-top: 80px;
}
.chart-divider-line{
  width:1px;
  flex:1;
  background:linear-gradient(to bottom, transparent, var(--line-2), transparent);
  min-height:120px;
}
.chart-divider-mark{
  color:var(--brass);
  font-size:14px;
}

.legend{
  margin-top: 56px;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap: 24px 36px;
  padding-top:24px;
  border-top:1px solid var(--line);
}
.legend-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--ink-faint);
  display:inline-block;
}
.dot[data-dot="sun"]   { background:#f0c060;}
.dot[data-dot="moon"]  { background:#e8e3d8;}
.dot[data-dot="venus"] { background:#d09080;}
.dot[data-dot="mars"]  { background:#c45848;}
.dot[data-dot="mercury"]{background:#90a0b0;}
.dot[data-dot="jupiter"]{background:#a888d0;}
.dot[data-dot="saturn"] {background:#888070;}
.dot[data-dot="asc"]    {background:var(--brass); box-shadow:0 0 0 1px var(--brass-2);}

.cross-btn{
  margin: 56px auto 0;
  display:flex;
  align-items:center;
  gap:14px;
  padding: 14px 28px;
  border:1px solid var(--brass);
  color:var(--brass);
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.32em;
  text-transform:uppercase;
  transition: background .4s ease, color .4s ease;
}
.cross-btn:hover{ background:var(--brass); color:var(--bg);}
.cross-btn-line{
  width:24px; height:1px; background:currentColor;
  transition:width .4s ease;
}
.cross-btn:hover .cross-btn-line{ width:48px;}

@media (max-width: 880px){
  .chart-grid{ grid-template-columns:1fr;}
  .chart-divider{ flex-direction:row; padding-top:0; padding:16px 0;}
  .chart-divider-line{ height:1px; min-height:0; flex:1; background:linear-gradient(to right, transparent, var(--line-2), transparent);}
}

/* ========== ASPECT TABLE ========== */
.aspect-table-wrap{
  border:1px solid var(--line);
  overflow:auto;
}
.aspect-table{
  width:100%;
  border-collapse:collapse;
  font-family:var(--mono);
  font-size:11px;
}
.aspect-table th, .aspect-table td{
  padding: 14px 12px;
  text-align:center;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  letter-spacing:.1em;
}
.aspect-table th{
  color:var(--ink-mute);
  font-weight:400;
  text-transform:uppercase;
  font-size:10px;
  letter-spacing:.2em;
  background:var(--bg-2);
}
.aspect-table thead th:first-child,
.aspect-table tbody th:first-child{
  background:var(--bg-3);
  color:var(--brass);
}
.aspect-table tbody th{
  text-align:right;
  text-transform:uppercase;
  color:var(--ink-mute);
  font-weight:400;
  font-size:10px;
  letter-spacing:.2em;
  background:var(--bg-2);
}
.aspect-cell{
  cursor:pointer;
  position:relative;
  transition:background .3s ease;
}
.aspect-cell:hover{ background:var(--bg-2);}
.aspect-cell.is-active{ background:var(--bg-3); color:var(--brass-2);}
.aspect-glyph{
  display:inline-block;
  width:14px; height:14px;
  line-height:14px;
  font-size:13px;
}
.aspect-glyph.conj{ color:#f0c060;}
.aspect-glyph.trine{ color:#7ab084;}
.aspect-glyph.sext{ color:var(--brass);}
.aspect-glyph.sq{ color:#c45848;}
.aspect-glyph.opp{ color:#a888d0;}
.aspect-cell.empty{ color:var(--ink-faint);}

.aspect-detail{
  margin-top: 32px;
  padding: 28px 32px;
  border:1px solid var(--line);
  background:var(--bg-2);
  min-height: 120px;
  font-style:italic;
  color:var(--ink);
  font-size:15px;
  line-height:1.7;
}
.aspect-detail-title{
  display:block;
  font-family:var(--mono);
  font-style:normal;
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--brass);
  margin-bottom:12px;
}
.aspect-detail-prompt{
  font-family:var(--mono);
  font-style:normal;
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-faint);
}

.aspect-key{
  margin-top: 24px;
  display:flex;
  flex-wrap:wrap;
  gap: 18px 28px;
}
.aspect-key span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.ak{
  width:10px; height:10px;
  display:inline-block;
  border-radius:50%;
}
.ak-conj{ background:#f0c060;}
.ak-trine{ background:#7ab084;}
.ak-sext{ background:var(--brass);}
.ak-sq{ background:#c45848;}
.ak-opp{ background:#a888d0;}

/* ========== COMPATIBILITY ========== */
.compat-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 80px;
  align-items:start;
}
.compat-bars{
  display:flex;
  flex-direction:column;
  gap: 22px;
}
.bar{
  display:grid;
  grid-template-columns: 140px 1fr 50px;
  gap:24px;
  align-items:center;
}
.bar-label{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.bar-track{
  position:relative;
  height:1px;
  background:var(--line);
  overflow:visible;
}
.bar-fill{
  position:absolute;
  top:-1px; left:0;
  height:3px;
  width:0;
  background:linear-gradient(90deg, var(--brass-2), var(--brass));
  transition: width 1.6s cubic-bezier(.2,.8,.2,1);
}
.bar.in-view .bar-fill{ width:var(--v);}
.bar-num{
  font-family:var(--serif);
  font-style:italic;
  font-size:22px;
  color:var(--brass-2);
  text-align:right;
  letter-spacing:-.02em;
}

.compat-radial{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:24px;
  text-align:center;
}
.radial{ width:100%; max-width:260px;}
.radial-bg{
  fill:none;
  stroke:var(--line-2);
  stroke-width:1;
}
.radial-fg{
  fill:none;
  stroke:var(--brass);
  stroke-width:2;
  stroke-linecap:round;
  stroke-dasharray: 578;
  stroke-dashoffset: 578;
  transform-origin:center;
  transform: rotate(-90deg);
  transition: stroke-dashoffset 2s cubic-bezier(.2,.8,.2,1);
}
.radial-num{
  font-family:var(--serif);
  font-size:56px;
  fill:var(--ink);
  letter-spacing:-.04em;
}
.radial-cap{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.32em;
  fill:var(--ink-mute);
  text-transform:uppercase;
}
.compat-verdict{
  font-style:italic;
  font-size:14px;
  color:var(--ink-mute);
  max-width:280px;
  line-height:1.7;
}

@media (max-width: 880px){
  .compat-grid{ grid-template-columns:1fr; gap:48px;}
  .bar{ grid-template-columns:120px 1fr 40px; gap:16px;}
}

/* ========== BALANCE ========== */
.balance-grid{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background:var(--line);
  border:1px solid var(--line);
}
.balance-block{
  background:var(--bg);
  padding: 36px 32px;
}
.balance-h{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:18px;
  margin-bottom:24px;
  color:var(--ink);
}
.elem{
  display:grid;
  grid-template-columns: 80px 1fr 40px;
  gap:14px;
  align-items:center;
  margin-bottom:14px;
}
.elem-name{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-mute);
}
.elem-track{
  position:relative;
  height:1px;
  background:var(--line);
  overflow:visible;
}
.elem-fill{
  position:absolute; top:-1px; left:0;
  height:3px; width:0;
  background:var(--brass);
  transition:width 1.4s cubic-bezier(.2,.8,.2,1);
}
.balance-block.in-view .elem-fill{ width:var(--v);}
.elem-num{
  font-family:var(--mono);
  font-size:11px;
  text-align:right;
  color:var(--brass-2);
}
.balance-note{
  font-style:italic;
  color:var(--ink-mute);
  font-size:14px;
  line-height:1.7;
}

@media (max-width: 880px){
  .balance-grid{ grid-template-columns:1fr;}
}

/* ========== WORKS / SHADOW ========== */
.works-grid{
  display:grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background:var(--line);
  border:1px solid var(--line);
}
.work-card{
  background:var(--bg);
  padding: 36px 32px;
  display:flex;
  flex-direction:column;
  gap:14px;
  transition: background .4s ease;
}
.work-card:hover{ background:var(--bg-2);}
.work-num{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--brass);
}
.work-card h3{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:22px;
  line-height:1.2;
  letter-spacing:-.01em;
}
.work-card p{
  color:var(--ink-mute);
  font-size:14px;
  line-height:1.7;
}
.shadow-grid .work-num{ color:var(--rose);}
.shadow-grid .work-card h3::after{
  content:"";
  display:block;
  width:24px; height:1px;
  background:var(--rose);
  margin-top:6px;
}

@media (max-width: 880px){
  .works-grid{ grid-template-columns:1fr;}
}

/* ========== TIMELINE ========== */
.timeline{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:40px;
}
.t-item{
  display:grid;
  grid-template-columns: 160px 1fr;
  gap: 40px;
  padding-bottom: 40px;
  border-bottom:1px solid var(--line);
  position:relative;
}
.t-item:last-child{ border-bottom:none;}
.t-when{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--brass);
  padding-top:6px;
}
.t-item h4{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size:24px;
  margin-bottom:10px;
  letter-spacing:-.01em;
}
.t-item p{
  color:var(--ink-mute);
  font-size:14px;
  line-height:1.7;
  max-width:640px;
}
@media (max-width:760px){
  .t-item{ grid-template-columns:1fr; gap:8px;}
}

/* ========== VERDICT ========== */
.verdict-body{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  font-size: clamp(20px, 2.4vw, 28px);
  line-height:1.5;
  letter-spacing:-.01em;
  color:var(--ink);
}
.verdict-sig{
  margin-top: 32px;
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--brass);
}

/* ========== FOOT ========== */
.foot{
  padding: 80px 0 40px;
  border-top:1px solid var(--line);
}
.foot-grid{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap: 32px;
}
.foot-grid > div{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.foot-key{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-faint);
}
.foot-val{
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  color:var(--ink-mute);
}
.foot-mark{
  margin-top:80px;
  text-align:center;
  color:var(--brass);
  font-size:12px;
}
@media (max-width: 760px){
  .foot-grid{ grid-template-columns:repeat(2,1fr);}
}

/* ========== CHART WHEEL CROSS-MODE ========== */
.cross-btn.is-active{ background:var(--brass); color:var(--bg);}

/* ========== REVEAL ========== */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1);
}
.reveal.in-view{
  opacity:1;
  transform:none;
}

/* prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.01ms !important; transition-duration:.01ms !important;}
  .scroll-line{ animation:none;}
}
