*{box-sizing:border-box}body{margin:0;font-family:ui-serif,Georgia,Times New Roman,serif;background:#0b0b0f;color:#e8e6dd;-webkit-font-smoothing:antialiased}.container{max-width:560px;margin:10vh auto;padding:24px}h1{font-size:3rem;margin:0 0 4px;letter-spacing:-1.5px;color:#e8e6dd}.sub{color:#8a857a;margin:0 0 32px;font-style:italic}.form{gap:14px}.form,.form label{display:flex;flex-direction:column}.form label{gap:4px;font-size:.85rem;color:#b8b2a3}.form input{padding:10px 12px;background:#16161c;border:1px solid #2a2a33;border-radius:6px;color:#e8e6dd;font-size:1rem;font-family:inherit}.form input:focus{outline:none;border-color:#c9a355}.form button{padding:14px;background:#c9a355;color:#0b0b0f;border:0;border-radius:6px;font-weight:600;cursor:pointer;font-size:1rem;font-family:inherit;margin-top:8px;letter-spacing:.5px}.form button:disabled{opacity:.5;cursor:not-allowed}.dashboard{display:grid;grid-template-columns:40% 60%;min-height:100vh}.left{padding:32px 24px;border-right:1px solid #2a2a33}.right{display:flex;flex-direction:column;padding:24px;gap:16px;max-height:100vh;overflow:hidden}.left h2{margin:0 0 4px;color:#c9a355;font-size:1.5rem}.small{color:#8a857a;font-size:.8rem;margin:2px 0}.reset{margin-top:20px;background:transparent;border:1px solid #2a2a33;color:#b8b2a3;padding:8px 14px;border-radius:4px;cursor:pointer;font-family:inherit}.chart{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:1px;gap:1px;aspect-ratio:1;margin:24px 0;background:#2a2a33;border:1px solid #2a2a33}.cell{background:#0f0f14;padding:8px;font-size:.75rem;min-height:70px}.cell.center{background:#0b0b0f}.cell.asc{background:#1a1610;box-shadow:inset 0 0 0 2px #c9a355}.sign{color:#c9a355;font-weight:600;font-size:.7rem;letter-spacing:.5px}.planets{color:#e8e6dd;font-size:.85rem;margin-top:6px;line-height:1.4}.tabs{display:flex;gap:4px;flex-wrap:wrap}.tabs button{background:transparent;border:1px solid #2a2a33;color:#b8b2a3;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.8rem;font-family:inherit}.tabs button.active{background:#c9a355;color:#0b0b0f;border-color:#c9a355}.reading{background:#0f0f14;border:1px solid #2a2a33;border-radius:6px;padding:20px;max-height:45vh;overflow-y:auto}.reading h3{margin-top:0;color:#c9a355;font-size:1rem;text-transform:uppercase;letter-spacing:1px}.reading pre{white-space:pre-wrap;font-family:inherit;margin:0;line-height:1.7;color:#d8d4c6}.chat{background:#0f0f14;border:1px solid #2a2a33;border-radius:6px;min-height:240px;overflow:hidden}.chat,.messages{flex:1 1;display:flex;flex-direction:column}.messages{overflow-y:auto;padding:16px 20px;gap:14px}.msg{line-height:1.6;white-space:pre-wrap}.msg strong{color:#c9a355;display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.msg.user{color:#e8e6dd}.msg.assistant{color:#c9c6bb}.input{display:flex;gap:8px;padding:12px;border-top:1px solid #2a2a33;background:#0b0b0f}.input input{flex:1 1;padding:10px 12px;background:#16161c;border:1px solid #2a2a33;border-radius:4px;color:#e8e6dd;font-family:inherit;font-size:.95rem}.input input:focus{outline:none;border-color:#c9a355}.input button{padding:10px 20px;background:#c9a355;color:#0b0b0f;border:0;border-radius:4px;cursor:pointer;font-weight:600;font-family:inherit}.input button:disabled{opacity:.5}.compat-btn{margin-top:8px;background:transparent;border:1px solid #c9a355;color:#c9a355;padding:10px 14px;border-radius:4px;cursor:pointer;font-family:inherit;font-size:.85rem;font-weight:600;letter-spacing:.5px;width:100%}.compat-btn:hover{background:#c9a355;color:#0b0b0f}.compat-phase1,.compat-phase2{display:flex;flex-direction:column;gap:12px;height:100%}.compat-top-bar{display:flex;justify-content:space-between;align-items:center}.compat-title{margin:0;color:#c9a355;font-size:1rem;text-transform:uppercase;letter-spacing:1px}.compat-label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:#b8b2a3}.compat-select{padding:10px 12px;background:#16161c;border:1px solid #2a2a33;border-radius:6px;color:#e8e6dd;font-size:1rem;font-family:inherit}.compat-select:focus{outline:none;border-color:#c9a355}.compat-header{display:flex;align-items:center;gap:12px;padding:12px;background:#16161c;border:1px solid #2a2a33;border-radius:6px}.compat-person{flex:1 1;display:flex;flex-direction:column;gap:2px}.compat-person strong{color:#c9a355;font-size:.95rem}.relationship-badge{background:#c9a355;color:#0b0b0f;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.compat-phase2 .reading{max-height:40vh}.compat-phase2 .chat{flex:1 1;min-height:200px}@media (max-width:900px){.dashboard{grid-template-columns:1fr}.left{border-right:0;border-bottom:1px solid #2a2a33}.right{max-height:none}}