    /* ── Reset & tokens ── */
    *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
    button { -webkit-tap-highlight-color: transparent; background: transparent; border: none; color: inherit; }
    button:focus:not(:focus-visible) { outline: none; }

    :root {
      --gold:          #c9a84c;
      --gold-light:    #e8d48b;
      --gold-soft:     rgba(201,168,76,0.08);
      --gold-border:   rgba(201,168,76,0.18);
      --ink:           #08080f;
      --ink-up:        #0e0e1a;
      --ink-card:      #12121f;       /* card bg — clearly distinct from ink */
      --ink-card-alt:  #161626;       /* slightly lighter for nested sections */
      --cream:         #f0ece2;
      --cream-muted:   #d4d0c8;
      --sage:          #7a9e7e;
      --sage-dim:      rgba(122,158,126,0.55);
      --warm:          #c77d6a;
      --font-display:  'Playfair Display', Georgia, serif;
      --font-body:     'Outfit', system-ui, sans-serif;
      --font-mono:     'JetBrains Mono', monospace;
      --radius-card:   1rem;
      --radius-sm:     0.6rem;
      --shadow-card:   0 4px 28px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.04);
    }

    html { scroll-behavior: smooth; }

    /* ── Mobile touch fixes ──────────────────────────────────────────────────
     * 1. Kill 300ms tap delay on all browsers
     * 2. Remove grey iOS tap flash — we use our own hover/active states
     * 3. Ensure div-based interactive elements fire touch reliably on iOS
     * 4. Enforce 44px minimum touch targets on all tappable elements
     * ─────────────────────────────────────────────────────────────────────── */
    html { touch-action: manipulation; }

    button, [role="button"],
    .nav-tab, .ritual-card, .ritual-pill, .angel-mob-tab,
    .aph-instr-toggle, .modal-tab-btn, .ritual-find-btn,
    .ritual-modal-close, .whl-legend-item, .pentacle-item,
    .accordion-button, .send-btn {
        -webkit-tap-highlight-color: transparent;
        touch-action: manipulation;
    }

    /* Minimum 44px touch target on nav tabs and modal tab buttons */
    .nav-tab { min-height: 44px; }
    .modal-tab-btn { min-height: 44px; padding-top: 0.75rem; padding-bottom: 0.75rem; }
    .angel-mob-tab { min-height: 40px; }

    /* div-based tappable elements need cursor:pointer for iOS click to fire */
    .ritual-card,
    .ritual-pill,
    .whl-legend-item,
    .pentacle-item {
        cursor: pointer;
    }

    /* Active state feedback on touch — replaces :hover which doesn't fire on mobile */
    .ritual-card:active    { background: rgba(255,255,255,0.06); }
    .ritual-pill:active    { opacity: 0.75; }
    .nav-tab:active        { opacity: 0.8; }
    .modal-tab-btn:active  { opacity: 0.8; }
    .ritual-find-btn:active { opacity: 0.8; }
    body {
      font-family: var(--font-body);
      background: var(--ink);
      color: var(--cream);
      min-height: 100vh;
      overflow-x: hidden;
      -webkit-font-smoothing: antialiased;
    }

    /* ── Grain ── */
    body::after {
      content: ''; position: fixed; inset: 0; z-index: 9999; pointer-events: none; opacity: 0.025;
      background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    }

    /* ── PROFILE HEADER ── */
    .profile-header {
      background: linear-gradient(160deg, #111122 0%, #0d0d1e 60%, #08080f 100%);
      border-bottom: 1px solid rgba(201,168,76,0.1);
      padding: 2rem 1.5rem 1.5rem;
      text-align: center; position: relative;
      box-shadow: 0 4px 40px rgba(0,0,0,0.4);
    }
    .profile-header::after {
      content: ''; position: absolute; bottom: 0; left: 10%; right: 10%; height: 1px;
      background: linear-gradient(90deg, transparent, rgba(201,168,76,0.2), transparent);
    }
    .profile-header h1 {
      font-family: var(--font-display); font-weight: 400; font-size: 1.7rem;
      margin: 0; color: var(--cream); letter-spacing: 0.01em;
    }
    .profile-header .subtitle {
      color: var(--cream-muted); font-size: 0.82rem; font-weight: 300;
      margin-top: 0.3rem; letter-spacing: 0.02em;
    }
    .zodiac-badges { margin-top: 0.85rem; display: flex; justify-content: center; flex-wrap: wrap; gap: 0.4rem; }
    .zodiac-badge {
      display: inline-flex; align-items: center; gap: 0.35rem;
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      padding: 0.28rem 0.75rem; border-radius: 2rem;
      font-size: 0.78rem; color: var(--gold-light); font-weight: 400;
    }
    .zodiac-badge .zodiac-glyph { color: var(--gold); }
    .zodiac-glyph-gold { color: var(--gold); }

    .guardian-advice-btn {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
      margin: 0.85rem auto 0; padding: 0.5rem 1.35rem;
      background: rgba(180,160,220,0.1); border: 1px solid rgba(180,160,220,0.3);
      color: #c4b4e8; border-radius: 2rem; font-size: 0.78rem;
      font-family: var(--font-mono); letter-spacing: 0.06em; text-transform: uppercase;
      cursor: pointer; transition: all 0.3s;
      -webkit-tap-highlight-color: transparent; touch-action: manipulation;
      opacity: 0.38; pointer-events: none;
    }
    .guardian-advice-btn.ready { opacity: 1; pointer-events: auto; }
    .guardian-advice-btn:hover { background: rgba(180,160,220,0.2); border-color: rgba(180,160,220,0.55); }
    .guardian-advice-btn:active { transform: scale(0.97); }
    .guardian-advice-btn .gab-spinner {
      display: inline-block; width: 10px; height: 10px;
      border: 1.5px solid rgba(180,160,220,0.3); border-top-color: #c4b4e8;
      border-radius: 50%; animation: spin 0.8s linear infinite;
    }
    .guardian-advice-btn.ready .gab-spinner { display: none; }

    /* ── NAV TABS ── */
    .nav-tabs-custom {
      background: rgba(8,8,15,0.97);
      border-bottom: 1px solid rgba(255,255,255,0.05);
      padding: 0.4rem 0.75rem;
      display: flex; justify-content: center; gap: 0.2rem; flex-wrap: wrap;
      position: sticky; top: 0; z-index: 100;
      backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
    }
    .nav-tab {
      background: transparent; border: none; color: var(--cream-muted);
      padding: 0.55rem 1.1rem; border-radius: var(--radius-sm); cursor: pointer;
      transition: all 0.2s; font-size: 0.82rem; font-family: var(--font-body);
      display: flex; align-items: center; gap: 0.4rem; font-weight: 400;
    }
    .nav-tab:hover { background: rgba(255,255,255,0.05); color: var(--cream); }
    .nav-tab.active {
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      color: var(--gold-light); font-weight: 500;
    }
    .nav-tab-icon { font-size: 1rem; }

    @media (max-width: 768px) {
      .nav-tabs-custom {
        position: fixed; bottom: 0; left: 0; right: 0; top: auto;
        padding: 0.3rem 0.2rem;
        padding-bottom: calc(0.3rem + env(safe-area-inset-bottom, 0px));
        gap: 0; flex-wrap: nowrap; justify-content: space-around;
        background: rgba(8,8,15,0.98);
        border-top: 1px solid rgba(255,255,255,0.06);
        border-bottom: none;
      }
      .nav-tab {
        flex-direction: column; gap: 0.12rem; padding: 0.3rem 0.1rem;
        font-size: 0.6rem; border-radius: 0.4rem; flex: 1; min-width: 0;
        border: none !important;
      }
      .nav-tab.active { background: transparent; color: var(--gold-light); }
      .nav-tab-icon { font-size: 1.1rem; line-height: 1; }
      .nav-tab-text { display: block; font-size: 0.52rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
      .main-content { padding-bottom: 5rem; }
    }

    /* ── MAIN CONTENT ── */
    .main-content { padding: 1.25rem; max-width: 1200px; margin: 0 auto; }
    .tab-pane { display: none; }
    .tab-pane.active { display: block; }

    /* ── CARDS ── */
    /* Cards sit on var(--ink) background and use var(--ink-card) = #12121f */
    .card {
      background: var(--ink-card);
      border: 1px solid rgba(255,255,255,0.07);
      border-radius: var(--radius-card);
      box-shadow: var(--shadow-card);
      color: var(--cream);
      margin-bottom: 1rem; overflow: hidden;
      position: relative;
    }
    /* Subtle top-edge gold line on every card */
    .card::before {
      content: ''; position: absolute; top: 0; left: 8%; right: 8%; height: 1px;
      background: linear-gradient(90deg, transparent, rgba(201,168,76,0.12), transparent);
      pointer-events: none;
    }
    .card-header {
      background: linear-gradient(135deg, #252545 0%, #1c1c38 100%);
      border-bottom: 1px solid rgba(201,168,76,0.16);
      color: var(--gold-light);
      padding: 0.9rem 1.25rem;
      font-weight: 500; font-size: 0.92rem;
      font-family: var(--font-display);
      display: flex; align-items: center; justify-content: space-between;
    }
    .card-body { padding: 1.25rem; }

    /* ── STAT BOXES ── */
    .stat-box {
      background: var(--ink-up);
      border: 1px solid rgba(255,255,255,0.06);
      border-radius: var(--radius-sm); padding: 0.85rem; text-align: center;
      height: 100%;
    }
    .stat-label {
      font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase;
      letter-spacing: 0.12em; color: var(--cream-muted); margin-bottom: 0.3rem;
    }
    .stat-value { font-size: 0.95rem; font-weight: 500; color: var(--cream); }

    /* ── SECTION TITLE (within card body) ── */
    .section-title {
      font-family: var(--font-mono); font-size: 0.62rem; font-weight: 400;
      text-transform: uppercase; letter-spacing: 0.18em;
      color: var(--sage); margin-bottom: 0.85rem;
      padding-bottom: 0.5rem; border-bottom: 1px solid rgba(255,255,255,0.05);
    }

    /* ── LOADING / ERROR ── */
    .skeleton {
      background: linear-gradient(90deg, #1a1a2e 25%, #22223a 50%, #1a1a2e 75%);
      background-size: 200% 100%;
      animation: shimmer 1.5s infinite;
      border-radius: 0.4rem;
    }
    @keyframes shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
    .tab-loading { text-align: center; padding: 3.5rem 1rem; color: var(--cream-muted); }
    .tab-loading .spinner {
      display: inline-block; width: 2rem; height: 2rem;
      border: 2px solid rgba(201,168,76,0.15); border-top-color: var(--gold);
      border-radius: 50%; animation: spin 0.8s linear infinite;
    }
    @keyframes spin { to { transform: rotate(360deg); } }
    .tab-error {
      text-align: center; padding: 2rem; color: var(--warm);
      background: rgba(199,125,106,0.08); border: 1px solid rgba(199,125,106,0.2);
      border-radius: var(--radius-card); margin: 1rem 0;
    }

    /* ── ZODIAC SIGN CARDS ── */
    .zodiac-card-expanded {
      background: var(--ink-card-alt); border: 1px solid rgba(255,255,255,0.07);
      border-radius: var(--radius-card); overflow: hidden; height: 100%;
      display: flex; flex-direction: column;
    }
    .zodiac-header { padding: 0.65rem 1rem; text-align: center; flex-shrink: 0; }
    .zodiac-header.sun  { background: linear-gradient(135deg, #3a2800, #5c3e00); border-bottom: 1px solid rgba(201,168,76,0.2); }
    .zodiac-header.moon { background: linear-gradient(135deg, #1a1a3a, #252548); border-bottom: 1px solid rgba(122,158,126,0.2); }
    .zodiac-header.rising { background: linear-gradient(135deg, #1e1a3a, #2a1f50); border-bottom: 1px solid rgba(122,100,180,0.2); }
    .zodiac-header-label { font-size: 0.78rem; font-weight: 500; color: var(--cream); letter-spacing: 0.04em; }
    .zodiac-name-row {
      display: flex; align-items: center; justify-content: center;
      gap: 0.5rem; padding: 0.9rem 1rem; flex-shrink: 0;
    }
    .zodiac-sign-img { height: 90px; width: 90px; display: inline-block; }
    img.zodiac-sign-img,
    .zodiac-sign-art {
      object-fit: contain;
      object-position: center;
      filter: drop-shadow(0 0 14px rgba(201,168,76,0.16));
    }
    .zodiac-attributes {
      display: flex; justify-content: center; gap: 0.5rem;
      padding: 0 0.75rem 0.75rem; flex-wrap: wrap; flex-shrink: 0;
    }
    .zodiac-attr { text-align: center; flex: 1; min-width: 70px; }
    .zodiac-attr-label { display: block; font-family: var(--font-mono); font-size: 0.56rem; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(212,208,200,0.75); }
    .zodiac-attr-value { display: block; font-size: 0.82rem; font-weight: 500; color: var(--cream); margin-top: 0.15rem; }
    .element-fire  { color: #e07060; }
    .element-earth { color: #7a9e7e; }
    .element-air   { color: #7a9ab8; }
    .element-water { color: #9b7ab8; }
    .zodiac-meaning {
      background: var(--ink-up); padding: 0.85rem; font-size: 0.8rem;
      color: var(--cream-muted); line-height: 1.6;
      border-top: 1px solid rgba(255,255,255,0.04);
      margin-top: auto; flex-grow: 1; font-weight: 300;
    }
    .zodiac-meaning strong { color: var(--gold-light); }

    /* ── PLANET TABLE ── */
    .planet-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .planet-table { width: 100%; border-collapse: collapse; }
    .planet-table th {
      font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase;
      letter-spacing: 0.1em; color: var(--cream-muted);
      padding: 0.3rem 0.6rem; border-bottom: 1px solid rgba(255,255,255,0.07); text-align: left;
    }
    .planet-table td {
      padding: 0.35rem 0.6rem; font-size: 0.83rem;
      border-bottom: 1px solid rgba(255,255,255,0.04); vertical-align: middle; color: var(--cream);
    }
    .planet-table tr:last-child td { border-bottom: none; }
    .planet-table tr:hover td { background: rgba(255,255,255,0.02); }
    .planet-table .planet-name-cell { font-weight: 500; white-space: nowrap; }
    .planet-table .degree-cell {
      font-family: var(--font-mono); font-size: 0.75rem; color: var(--cream-muted);
    }
    /* ── PLANET GLYPHS ── */
    .planet-glyph {
      font-family: 'Segoe UI Symbol','Apple Symbols','Noto Sans Symbols2','Symbola',sans-serif;
      display: inline-block; line-height: 1; vertical-align: middle;
      font-style: normal; font-weight: 400;
      filter: drop-shadow(0 0 3px currentColor);
    }
    .planet-glyph-inline { font-size: 1.05rem; margin-right: 0.15em; }
    .planet-glyph-sm     { font-size: 1.35rem; }
    .planet-glyph-xs     { font-size: 0.9rem;  margin-right: 0.1em; }
    .planet-glyph-lg     { font-size: 2.1rem;  }
    /* Legacy image refs kept in case any external code still links them */
    .planet-badge-img-inline { height: 1.05rem; width: 1.05rem; vertical-align: middle; margin-right: 2px; }
    .planet-badge-img-sm     { height: 1.35rem; width: 1.35rem; vertical-align: middle; }
    .planet-badge-img        { height: 2.1rem;  width: 2.1rem; }
    .planet-badge-img-xs     { height: 0.9rem;  width: 0.9rem; vertical-align: middle; }

    /* ── ANGEL GRID ── */
    /* ── NATAL ANGEL SELECTOR ── */
    .angel-selector-strip {
      display: flex; gap: 0; border-bottom: 1px solid rgba(255,255,255,0.06);
      background: var(--ink-up);
    }
    .angel-selector-btn {
      flex: 1; display: flex; align-items: center; justify-content: center;
      gap: 0.5rem; padding: 0.65rem 0.75rem;
      background: transparent; border: none; border-right: 1px solid rgba(255,255,255,0.06);
      color: var(--cream-muted); cursor: pointer; transition: all 0.18s;
      -webkit-tap-highlight-color: transparent; position: relative;
    }
    .angel-selector-btn:last-child { border-right: none; }
    .angel-selector-btn:hover { background: rgba(255,255,255,0.03); color: var(--cream); }
    .angel-selector-btn.active { background: rgba(160,130,220,0.08); color: var(--cream); }
    .angel-selector-btn.active::after {
      content: ''; position: absolute; bottom: 0; left: 15%; right: 15%; height: 2px;
      background: linear-gradient(90deg, var(--gold), #b090e8);
      border-radius: 2px 2px 0 0;
    }
    .angel-sel-icon { font-size: 1rem; line-height: 1; flex-shrink: 0; }
    .angel-sel-info { display: flex; flex-direction: column; align-items: flex-start; min-width: 0; }
    .angel-sel-name {
      font-family: var(--font-display); font-size: 0.82rem; font-weight: 500;
      color: inherit; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%;
    }
    .angel-sel-type {
      font-family: var(--font-mono); font-size: 0.52rem; text-transform: uppercase;
      letter-spacing: 0.1em; color: var(--cream-muted);
    }
    .angel-selector-btn.active .angel-sel-type { color: #c4aef0; }

    /* ── ANGEL CARD HEADER override ── */
    /* ── NATAL TRANSIT CARDS (ntc-*) — used in natal Transits view + horoscope Influences ── */
    .ntc-list { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 0.25rem; }
    .ntc-card {
      border-radius: var(--radius-sm);
      border: 1px solid rgba(255,255,255,0.07);
      background: rgba(255,255,255,0.02);
      padding: 0.55rem 0.75rem 0.45rem;
    }
    .ntc-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 0.5rem; }
    .ntc-planets { font-size: 0.8rem; color: var(--cream); line-height: 1.4; flex: 1; min-width: 0; }
    .ntc-role { font-family: var(--font-mono); font-size: 0.56rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--cream-muted); opacity: 0.7; }
    .ntc-house { display: inline-block; font-size: 0.62rem; font-family: var(--font-mono); color: var(--cream-muted); background: rgba(255,255,255,0.05); border-radius: 3px; padding: 1px 5px; margin-left: 3px; vertical-align: middle; }
    .ntc-arrow { color: var(--cream-muted); opacity: 0.5; font-size: 0.75rem; }
    .ntc-score { text-align: right; font-family: var(--font-mono); font-size: 0.9rem; font-weight: 600; flex-shrink: 0; line-height: 1.1; }
    .ntc-tier { display: block; font-size: 0.52rem; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 400; opacity: 0.8; }
    .ntc-badges { display: flex; flex-wrap: wrap; gap: 0.22rem; margin-top: 0.3rem; }
    .ntc-badge {
      display: inline-block; padding: 1px 6px; border-radius: 3px;
      font-size: 0.6rem; font-family: var(--font-mono); letter-spacing: 0.04em;
      background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.09);
      color: var(--cream-muted);
    }
    .ntc-hard { background: rgba(199,125,106,0.12); border-color: rgba(199,125,106,0.25); color: #e07060; }
    .ntc-soft { background: rgba(122,158,126,0.12); border-color: rgba(122,158,126,0.22); color: #7a9e7e; }
    .ntc-dignity { background: rgba(201,168,76,0.1); border-color: rgba(201,168,76,0.2); color: var(--gold-light); }
    .ntc-lifetime { display: inline-block; padding: 1px 6px; border-radius: 3px; font-size: 0.6rem; font-family: var(--font-mono); letter-spacing: 0.04em; background: rgba(160,130,220,0.12); border: 1px solid rgba(160,130,220,0.25); color: #c4aef0; }

    /* ── NATAL STELLIUMS ── */
    .stell-grid {
      display: flex; flex-wrap: wrap; gap: 0.75rem;
    }
    .stell-card {
      flex: 1 1 160px;
      background: linear-gradient(135deg, rgba(201,168,76,0.07), rgba(180,140,50,0.03));
      border: 1px solid rgba(201,168,76,0.2);
      border-radius: var(--radius-sm);
      padding: 0.7rem 0.9rem;
    }
    .stell-type {
      font-family: var(--font-mono); font-size: 0.58rem; text-transform: uppercase;
      letter-spacing: 0.12em; color: var(--gold); opacity: 0.75; margin-bottom: 0.2rem;
    }
    .stell-label {
      font-family: var(--font-display); font-size: 1rem; font-weight: 500;
      color: var(--cream); line-height: 1.2;
    }
    .stell-meaning {
      font-size: 0.7rem; color: var(--cream-muted); font-style: italic;
      margin-top: 0.15rem; line-height: 1.4;
    }
    .stell-insight {
      font-size: 0.75rem; color: var(--cream-muted); line-height: 1.5;
      margin-top: 0.5rem; border-top: 1px solid rgba(201,168,76,0.12); padding-top: 0.45rem;
    }
    .stell-planets {
      display: flex; flex-wrap: wrap; gap: 0.25rem; margin-top: 0.45rem;
    }
    .stell-planet {
      display: inline-block; padding: 0.15rem 0.5rem; border-radius: 2rem;
      background: rgba(201,168,76,0.1); border: 1px solid rgba(201,168,76,0.2);
      font-size: 0.68rem; color: var(--gold-light);
    }

    #natal-angels-card > .card-header {
      background: linear-gradient(135deg, #1e1640 0%, #241545 50%, #1a1030 100%);
      border-bottom: 1px solid rgba(160,130,220,0.25);
      color: #d4c0f8;
    }

    /* ── ANGEL PANEL (portrait layout) ── */
    .angel-panel-wrap { display: none; }
    .angel-panel-wrap.active { display: block; }

    /* ── NATAL ANGEL CARDS (nc-*) ── */
    .nc-card {
      position: relative;
      overflow: hidden;
      background: var(--ink-card);
      border-radius: var(--radius-card);
      border: 1px solid rgba(255,255,255,0.06);
      box-shadow: var(--shadow-card);
    }
    .nc-col-right { position: relative; overflow: hidden; }
    .nc-card-sigil-bg {
      position: absolute; inset: 0;
      width: 100%; height: 100%;
      object-fit: cover;
      object-position: center 25%;
      opacity: 0.45;
      pointer-events: none;
      filter: grayscale(0.2) brightness(0.75);
      z-index: 0;
    }
    /* Single scrim overlay instead of per-element boxes */
    .nc-col-right::after {
      content: ''; position: absolute; inset: 0;
      background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.55) 100%);
      pointer-events: none; z-index: 1;
    }
    .nc-col-right > *:not(.nc-card-sigil-bg) { position: relative; z-index: 2; }
    .nc-card-sigil-fade { display: none; }

    /* Header: portrait + identity (now lives inside left col) */
    .nc-header {
      display: flex; align-items: center; gap: 0.7rem;
      padding: 0.75rem 0.6rem 0.65rem;
      border-bottom: 1px solid rgba(255,255,255,0.05);
      margin: -0.6rem -0.6rem 0.6rem;
    }
    .nc-portrait {
      width: 56px; height: 56px; border-radius: 50%; flex: none;
      object-fit: cover; object-position: center 20%;
      border: 2px solid rgba(227,193,98,0.35);
      box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    }
    .nc-identity { min-width: 0; }
    .nc-name {
      font-family: var(--font-display); font-size: 1rem; font-weight: 500;
      color: var(--cream); line-height: 1.2;
    }
    .nc-hebrew { font-size: 0.82rem; color: var(--gold-light); margin-top: 0.06rem; }
    .nc-meaning {
      font-size: 0.7rem; font-style: italic; color: var(--cream-muted);
      margin-top: 0.1rem; font-weight: 300;
    }

    /* 2-column body (full card) */
    .nc-body {
      display: grid; grid-template-columns: 1fr 1.6fr;
    }
    .nc-col-left {
      border-right: 1px solid rgba(255,255,255,0.05);
      display: flex; flex-direction: column;
      padding: 0.6rem;
      gap: 0.4rem;
    }
    .nc-col-right {
      display: flex; flex-direction: column; align-self: stretch;
      padding: 0.6rem 0.75rem;
    }
    @media (max-width: 560px) {
      .nc-body { grid-template-columns: 1fr; }
      .nc-col-left { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.05); }
      .nc-card-sigil-bg { max-height: 160px; }
    }

    /* Stats grid (left col) */
    .nc-stats {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.25rem;
    }
    @media (max-width: 560px) {
      .nc-stats { grid-template-columns: 1fr 1fr; }
    }
    .nc-stat {
      background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05);
      border-radius: 0.35rem; padding: 0.28rem 0.4rem; text-align: center;
    }
    .nc-stat.nc-stat-wide { grid-column: 1 / -1; }
    .nc-stat-label {
      font-family: var(--font-mono); font-size: 0.55rem; text-transform: uppercase;
      letter-spacing: 0.07em; color: var(--cream-muted); opacity: 0.65;
    }
    .nc-stat-value {
      font-size: 0.72rem; font-weight: 500; color: var(--cream);
      margin-top: 0.05rem; line-height: 1.25;
    }
    .nc-stat-sub {
      font-size: 0.62rem; color: var(--gold); opacity: 0.75;
      margin-top: 0.05rem; line-height: 1.2; font-weight: 300;
    }
    .nc-orient-up { font-size: 0.58rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.06em; color: var(--sage); }
    .nc-orient-rev { font-size: 0.58rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.06em; color: var(--warm); }

    /* Domain / Shadow (left col) */
    .nc-domain {
      padding: 0.35rem 0.45rem;
      background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05);
      border-radius: 0.35rem;
    }
    .nc-domain.nc-shadow-block { border-color: rgba(160,130,220,0.12); background: rgba(160,130,220,0.04); }
    .nc-domain-label {
      font-family: var(--font-mono); font-size: 0.55rem; text-transform: uppercase;
      letter-spacing: 0.1em; margin-bottom: 0.2rem;
      display: inline-flex; align-items: center; gap: 0.25rem;
    }
    .nc-domain-label::before { content: ''; width: 3px; height: 0.55rem; border-radius: 2px; flex: none; }
    .nc-label-gold { color: var(--gold); }
    .nc-label-gold::before { background: var(--gold); }
    .nc-label-purple { color: #c4aef0; }
    .nc-label-purple::before { background: #c4aef0; }
    .nc-label-cream { color: var(--cream-muted); }
    .nc-label-cream::before { background: var(--cream-muted); }
    .nc-kw-row { display: flex; flex-wrap: wrap; gap: 0.2rem; margin-bottom: 0.15rem; }
    .nc-kw { display: inline-block; padding: 0.08rem 0.35rem; border-radius: 2rem; font-size: 0.62rem; font-weight: 400; }
    .nc-kw-gold { background: rgba(201,168,76,0.1); border: 1px solid rgba(201,168,76,0.2); color: var(--gold-light); }
    .nc-kw-purple { background: rgba(160,130,220,0.1); border: 1px solid rgba(160,130,220,0.2); color: #d4c0f8; }
    .nc-expr { font-size: 0.7rem; color: var(--cream-muted); line-height: 1.45; font-weight: 300; margin-top: 0.1rem; }

    /* Share button in left col */
    .nc-actions { display: flex; gap: 0.5rem; margin-top: auto; padding-top: 0.35rem; }
    .nc-actions .angel-share-btn { margin: 0; flex: 1; }

    /* Expressions list (right col) */
    .nc-expressions { padding: 0; }
    .nc-expr-list { margin: 0.2rem 0 0; padding: 0 0 0 0.8rem; list-style: none; }
    .nc-expr-item {
      font-size: 0.72rem; line-height: 1.45; color: var(--cream-muted);
      font-weight: 300; padding: 0.12rem 0;
      border-bottom: 1px solid rgba(255,255,255,0.03); position: relative;
    }
    .nc-expr-item::before { content: '·'; position: absolute; left: -0.7rem; color: var(--gold); opacity: 0.5; }

    /* Verse (right col) */
    .nc-verse {
      padding: 0.6rem 0.75rem; margin-top: auto;
      font-size: 0.72rem; font-style: italic; color: var(--cream-muted);
      font-weight: 300; line-height: 1.5;
    }
    .nc-verse cite {
      display: block; margin-top: 0.18rem; font-style: normal;
      font-family: var(--font-mono); color: var(--gold); font-size: 0.58rem;
      letter-spacing: 0.05em; opacity: 0.7;
    }

    /* ── CURRENT INFLUENCES ── */
    .current-box {
      background: var(--ink-card-alt); border: 1px solid rgba(255,255,255,0.06);
      border-radius: var(--radius-card); padding: 0.45rem; text-align: center; height: 100%;
      min-height: 0; display: flex; flex-direction: column; overflow: hidden;
    }
    .current-box .section-title { flex-shrink: 0; }
    .current-box .section-title.planetary-hour-title {
      color: var(--gold-light); background: linear-gradient(135deg, #2a1e00, #1e1600);
      margin: -0.45rem -0.45rem 0.5rem -0.45rem; padding: 0.45rem 0.75rem;
      border-bottom: 1px solid rgba(201,168,76,0.15);
      border-radius: var(--radius-card) var(--radius-card) 0 0;
      font-family: var(--font-mono); letter-spacing: 0.12em;
    }
    .current-box .section-title.moon-phase-title {
      color: #c8d8f0; background: linear-gradient(135deg, #0e1a2e, #0a1220);
      margin: -0.45rem -0.45rem 0.5rem -0.45rem; padding: 0.45rem 0.75rem;
      border-bottom: 1px solid rgba(122,158,126,0.15);
      border-radius: var(--radius-card) var(--radius-card) 0 0;
      font-family: var(--font-mono); letter-spacing: 0.12em;
    }
    .current-box-content { flex: 1; display: flex; flex-direction: column; justify-content: center; align-items: center; }
    .current-box-footer { flex-shrink: 0; padding-top: 0.22rem; border-top: 1px solid rgba(255,255,255,0.05); font-size: 0.78rem; color: var(--cream-muted); }
    .daily-ruler-footer {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 0.45rem;
      color: rgba(255,238,204,0.82);
    }
    .daily-ruler-badge {
      display: inline-flex;
      align-items: center;
      gap: 0.28rem;
      padding: 0.18rem 0.5rem;
      border-radius: 999px;
      color: var(--gold-light);
      background: linear-gradient(180deg, rgba(201,168,76,0.18), rgba(201,168,76,0.08));
      border: 1px solid rgba(201,168,76,0.28);
      box-shadow: 0 0 14px rgba(201,168,76,0.1), inset 0 0 0 1px rgba(255,255,255,0.03);
      white-space: nowrap;
    }
    .current-box-time { flex-shrink: 0; margin-top: auto; padding-top: 0.3rem; font-family: var(--font-mono); font-size: 0.78rem; color: var(--cream-muted); }
    .planet-symbol { font-size: 1.6rem; display: block; margin-bottom: 0.25rem; }
    .current-box-planetary { min-height: 14.6rem; }
    .current-box-content-planetary {
      justify-content: flex-start;
      gap: 0.18rem;
      padding: 0.04rem 0 0.08rem;
      text-align: center;
    }
    .current-box-content-planetary > span { display: none; }
    .ph-spinner-inline {
      width: 100%;
      margin-top: 0;
      border: 1px solid rgba(255,255,255,0.06);
      border-radius: calc(var(--radius-card) - 4px);
      background:
        radial-gradient(circle at top, rgba(201,168,76,0.08), transparent 38%),
        linear-gradient(180deg, rgba(20,19,30,0.7), rgba(11,11,19,0.92));
      overflow: hidden;
    }
    .ph-spinner-inline .ph-spinner-track { padding: 0; }
    .ph-spinner-inline .ph-spinner-nav { padding: 0; min-height: 1.8rem; }
    .ph-spinner-inline .planetary-hour-row { border-radius: 0; margin-bottom: 0; }
    .ph-spinner-inline .ph-divider:first-child { border-top: 0; }
    .current-box-moon { min-height: 14.6rem; }
    .current-box-content-moon {
      position: relative;
      justify-content: center;
      gap: 0.16rem;
      padding: 0.08rem 0.2rem 0.14rem;
      text-align: center;
    }
    .current-box-content-moon > span:first-child {
      font-size: 4.25rem;
      line-height: 1;
      margin-bottom: 0.1rem;
      filter: drop-shadow(0 0 14px rgba(200,216,255,0.18));
    }
    .current-box-content-moon > span:nth-child(2) {
      display: block;
      font-size: 1.08rem;
      font-weight: 600;
      color: var(--cream);
      letter-spacing: 0.01em;
    }
    .current-box-content-moon > span:nth-child(3) {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      margin-top: 0.06rem;
      padding: 0.26rem 0.55rem;
      border-radius: 999px;
      background: rgba(200,216,255,0.08);
      border: 1px solid rgba(200,216,255,0.16);
      font-family: var(--font-mono);
      font-size: 0.68rem;
      color: #d7e4f7;
      letter-spacing: 0.06em;
      text-transform: uppercase;
    }
    .current-box-moon > div[style] {
      margin-top: 0.02rem !important;
      display: flex;
      gap: 0.35rem !important;
      width: 100%;
    }
    .current-box-content-moon > span:first-child,
    .current-box-content-moon > span:nth-child(2),
    .current-box-content-moon > span:nth-child(3) { position: relative; z-index: 1; }
    .current-box-content-moon::before {
      content: '';
      position: absolute;
      width: 8.4rem;
      height: 8.4rem;
      border-radius: 50%;
      background:
        radial-gradient(circle, rgba(200,216,255,0.12), rgba(155,196,255,0.04) 55%, transparent 72%);
      filter: blur(4px);
      top: 0.35rem;
      left: 50%;
      transform: translateX(-50%);
      pointer-events: none;
    }
    .current-angel-box {
      position: relative;
      background: var(--ink-card-alt); border: 1px solid rgba(255,255,255,0.06);
      border-radius: var(--radius-card); padding: 0; text-align: center; height: 100%;
      overflow: hidden;
      background:
        radial-gradient(circle at top right, rgba(201,168,76,0.08), transparent 36%),
        linear-gradient(160deg, rgba(18,18,31,0.96), rgba(10,10,18,0.98));
    }
    .current-angel-full-bg,
    .current-angel-header-bg,
    .current-angel-header-sheen {
      position: absolute;
      inset: 0;
    }
    .current-angel-full-bg { z-index: 0; }
    .current-angel-full-bg::before {
      content: '';
      position: absolute;
      left: 50%;
      top: 4.15rem;
      width: 8.6rem;
      height: 8.6rem;
      transform: translateX(-50%);
      border-radius: 50%;
      background:
        radial-gradient(circle, rgba(10,12,18,0.78), rgba(10,12,18,0.58) 46%, rgba(10,12,18,0.14) 70%, transparent 82%);
      filter: blur(5px);
      pointer-events: none;
      z-index: 1;
    }
    .current-angel-full-bg::after {
      content: '';
      position: absolute;
      inset: 0.45rem;
      border-radius: calc(var(--radius-card) - 6px);
      border: 1px solid rgba(222,187,96,0.32);
      box-shadow: inset 0 0 0 1px rgba(255,255,255,0.03);
      pointer-events: none;
    }
    .current-angel-typebar {
      position: absolute;
      top: 0.45rem;
      left: 50%;
      right: auto;
      transform: translateX(-50%);
      z-index: 2;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 1.7rem;
      min-width: 0;
      padding: 0.34rem 0.78rem;
      font-size: 0.62rem;
      color: var(--gold-light);
      font-family: var(--font-mono);
      letter-spacing: 0.14em;
      text-transform: uppercase;
      text-align: center;
      background: linear-gradient(180deg, rgba(12,12,18,0.94), rgba(8,8,14,0.88));
      border: 1px solid rgba(201,168,76,0.22);
      border-radius: 999px;
      box-shadow: 0 8px 18px rgba(0,0,0,0.22), inset 0 -1px 0 rgba(255,255,255,0.03);
    }
    .current-angels-card > .current-angels-header {
      background:
        linear-gradient(135deg, rgba(33,22,24,0.96), rgba(28,24,44,0.96));
      border-bottom: 1px solid rgba(201,168,76,0.18);
      box-shadow: inset 0 -1px 0 rgba(255,255,255,0.02);
    }
    .current-angel-header {
      position: relative;
      padding: 3.15rem 0.8rem 0.7rem;
      z-index: 1;
    }
    .current-angel-header-bg {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center top;
      opacity: 1;
      filter: saturate(1.08) contrast(1.05) brightness(1.02);
    }
    .current-angel-header-sheen {
      background:
        radial-gradient(circle at center 24%, rgba(255,217,132,0.18), transparent 30%),
        linear-gradient(180deg, rgba(6,8,14,0.08), rgba(6,8,14,0.34) 42%, rgba(6,8,14,0.68));
    }
    .current-angel-box-intellectual .current-angel-header-bg,
    .current-angel-box-operative .current-angel-header-bg {
      filter: saturate(1.14) contrast(1.12) brightness(1.06);
    }
    .current-angel-box-intellectual .current-angel-header-bg {
      object-position: center 34%;
      filter: saturate(1.18) contrast(1.18) brightness(1.1);
    }
    .current-angel-box-intellectual .current-angel-header-sheen,
    .current-angel-box-operative .current-angel-header-sheen {
      background:
        radial-gradient(circle at center 25%, rgba(255,217,132,0.14), transparent 28%),
        linear-gradient(180deg, rgba(6,8,14,0.04), rgba(6,8,14,0.24) 40%, rgba(6,8,14,0.58));
    }
    .current-angel-box-intellectual .current-angel-header-sheen {
      background:
        radial-gradient(circle at center 24%, rgba(255,217,132,0.12), transparent 26%),
        linear-gradient(180deg, rgba(6,8,14,0.02), rgba(6,8,14,0.18) 40%, rgba(6,8,14,0.48));
    }
    .current-angel-box-intellectual .current-angel-header-sheen::before,
    .current-angel-box-operative .current-angel-header-sheen::before {
      content: '';
      position: absolute;
      inset: 0.45rem;
      border-radius: calc(var(--radius-card) - 6px);
      background:
        radial-gradient(circle at 50% 30%, rgba(255,255,255,0.04), transparent 46%),
        linear-gradient(180deg, rgba(255,255,255,0.02), transparent 32%);
      pointer-events: none;
      z-index: 1;
    }
    .current-angel-portrait-wrap {
      position: relative;
      display: flex;
      justify-content: center;
      margin-top: 0.18rem;
      margin-bottom: 0.65rem;
    }
    .current-angel-title-block {
      position: relative;
      z-index: 1;
      max-width: 11.6rem;
      margin: 0 auto;
      padding: 0.42rem 0.75rem 0.5rem;
      border-radius: 0.95rem;
      background: linear-gradient(180deg, rgba(8,10,16,0.62), rgba(8,10,16,0.38));
      border: 1px solid rgba(214,182,95,0.14);
      box-shadow: 0 10px 18px rgba(0,0,0,0.16), inset 0 1px 0 rgba(255,255,255,0.04);
      backdrop-filter: blur(5px);
    }
    .current-angel-portrait {
  display: block;
  width: 96px;
  height: 96px;
  object-fit: cover;
  object-position: center center;
  border-radius: 50%;
  opacity: 0.9;
  border: 1px solid rgba(227,193,98,0.48);
  background: radial-gradient(circle at 50% 38%, rgba(201,168,76,0.24), rgba(201,168,76,0.06) 62%, transparent 78%);
  position: relative;
  z-index: 1;
  box-shadow: 0 10px 20px rgba(0,0,0,0.24), 0 0 0 3px rgba(17,15,26,0.55);
  filter: brightness(0.82) contrast(1.1);
    }
    .current-angel-name {
      font-size: 1rem; font-weight: 500; color: var(--cream);
      font-family: 'Playfair Display', Georgia, serif; position: relative; z-index: 1;
      text-shadow: 0 1px 10px rgba(0,0,0,0.28);
    }
    .current-angel-hebrew {
      color: var(--gold-light); font-size: 0.95rem; position: relative; z-index: 1;
      text-shadow: 0 1px 10px rgba(0,0,0,0.24);
    }
    .current-angel-meta {
      font-size: 0.7rem; color: var(--gold); opacity: 0.85; position: relative; z-index: 1;
      text-shadow: 0 1px 8px rgba(0,0,0,0.22); font-family: var(--font-mono); letter-spacing: 0.03em;
    }
    .current-angel-info-block {
      position: relative;
      z-index: 1;
      margin: 0.14rem 0.75rem 0.8rem;
      padding: 0.38rem 0.75rem 0.8rem;
      min-height: 11rem;
      border-radius: calc(var(--radius-card) - 6px);
      border: 1px solid rgba(201,168,76,0.24);
      background:
        linear-gradient(180deg, rgba(10,10,18,0.86), rgba(14,14,24,0.92)),
        radial-gradient(circle at top, rgba(201,168,76,0.08), transparent 45%);
      box-shadow: 0 14px 28px rgba(0,0,0,0.28), inset 0 0 0 1px rgba(255,255,255,0.04);
      backdrop-filter: blur(6px);
      text-align: left;
    }
    .current-angel-meaning {
      font-size: 0.78rem; font-style: italic; color: var(--cream-muted);
      margin-top: 0; position: relative; z-index: 1;
    }
    .current-angel-text-label {
      display: inline-flex;
      align-items: center;
      gap: 0.38rem;
      margin-top: 0.06rem;
      margin-bottom: 0.1rem;
      padding: 0.12rem 0.38rem 0.12rem 0.18rem;
      border-radius: 999px;
      background: rgba(201,168,76,0.08);
      border: 1px solid rgba(201,168,76,0.18);
      font-size: 0.62rem;
      color: var(--gold-light);
      font-family: var(--font-mono);
      letter-spacing: 0.14em;
      text-transform: uppercase;
    }
    .current-angel-text-label::before {
      content: '';
      width: 0.34rem;
      height: 0.34rem;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(255,220,138,0.95), rgba(201,168,76,0.55));
      box-shadow: 0 0 10px rgba(201,168,76,0.35);
      flex: none;
    }
    .current-angel-text {
      font-size: 0.75rem; line-height: 1.6; color: var(--cream);
      margin-top: 0.2rem;
      padding: 0.55rem 0.65rem 0.4rem;
      min-height: 9rem;
      border-top: 1px solid rgba(255,255,255,0.08);
      position: relative; z-index: 1;
    }
    .current-angel-remaining {
      margin-top: 0.45rem;
      padding-top: 0.35rem;
      border-top: 1px solid rgba(255,255,255,0.06);
      font-size: 0.68rem;
      color: var(--cream-muted);
      font-family: var(--font-mono);
      letter-spacing: 0.04em;
      opacity: 0.7;
    }
    @media (max-width: 767px) {
      .current-angel-typebar { min-height: 1.55rem; padding: 0.28rem 0.58rem; font-size: 0.56rem; }
      .current-angel-full-bg,
      .current-angel-header-bg,
      .current-angel-header-sheen { inset: 1.8rem 0 0 0; }
      .current-angel-header { padding-top: 2.75rem; padding-bottom: 0.65rem; }
      .current-angel-portrait { width: 82px; height: 82px; }
      .current-angel-info-block { margin: 0.12rem 0.55rem 0.65rem; padding: 0.34rem 0.65rem 0.65rem; min-height: 11.5rem; }
      .current-angel-text { min-height: 8.5rem; }
    }

    /* ── CURRENT TAB — compact overrides ── */
    #tab-current .card { margin-bottom: 0.35rem; }
    #tab-current .card-body { padding: 0.5rem 0.75rem; }
    #tab-current .card-header { padding: 0.45rem 0.75rem; font-size: 0.82rem; }

    /* ── POSITION BADGES ── */
    .position-badge {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.35rem;
      padding: 0.28rem 0.75rem; border-radius: 2rem; font-weight: 500;
      font-size: 0.82rem; margin-bottom: 0.4rem; min-width: 130px;
    }
    .position-badge.sun-badge  { background: rgba(201,168,76,0.12); border: 1px solid rgba(201,168,76,0.2); color: var(--gold-light); }
    .position-badge.moon-badge { background: rgba(122,158,126,0.1); border: 1px solid rgba(122,158,126,0.18); color: #b0d4b8; }

    /* ── PLANETARY POSITIONS GRID ── */
    .planet-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem; padding: 0.55rem 0.75rem; }
    .planet-grid-full { grid-template-columns: 1fr 1fr 1fr; }
    .planet-row {
        position: relative;
        display: flex; align-items: center; gap: 0.45rem;
        padding: 0.34rem 0.58rem; border-radius: var(--radius-sm);
        background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.04);
        overflow: hidden;
        transition: background 0.12s, border-color 0.12s, transform 0.12s;
    }
    .planet-row::before {
        content: '';
        position: absolute;
        inset: -18px;
        opacity: 0.55;
        pointer-events: none;
        filter: blur(18px);
        background: transparent;
    }
    .planet-row:hover { background: rgba(255,255,255,0.045); transform: translateY(-1px); }
    .planet-row-glyph { font-size: 1.05rem; flex-shrink: 0; line-height: 1; }
    .planet-row-info { flex: 1; min-width: 0; text-align: left; }
    .planet-row-name { display:inline-flex; align-items:center; gap:0.28rem; flex-wrap:wrap; font-size: 0.65rem; font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; color: rgba(196,191,181,0.75); line-height: 1.1; }
    .planet-row-pos  { font-size: 0.82rem; font-weight: 500; color: var(--cream); line-height: 1.3; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    /* Vedic Big Three */
    .vedic-b3-grid {
      display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    }
    .vedic-b3-col {
      padding: 1.2rem 1rem; border-right: 1px solid rgba(255,255,255,0.04);
      border-top: 1px solid rgba(255,255,255,0.03);
    }
    .vedic-b3-col:last-child { border-right: none; }
    .vedic-b3-title {
      font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase;
      letter-spacing: 0.1em; color: var(--gold); opacity: 0.7; margin-bottom: 2px;
    }
    .vedic-b3-subtitle {
      font-size: 0.7rem; color: var(--cream-muted); opacity: 0.5; margin-bottom: 0.6rem;
    }
    .vedic-b3-main {
      font-family: var(--font-display); font-size: 1.4rem; font-weight: 500;
      color: var(--cream); line-height: 1.2; margin-bottom: 0.5rem;
    }
    .vedic-b3-detail {
      font-size: 0.78rem; color: var(--cream-muted); line-height: 1.5;
    }
    .vedic-b3-gana {
      font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.04em;
      padding: 1px 5px; border-radius: 3px;
      background: rgba(201,168,76,0.08); border: 1px solid rgba(201,168,76,0.15);
      color: var(--gold-light);
    }
    .vedic-b3-dasha {
      display: flex; align-items: center; gap: 0.75rem; padding: 0.7rem 1rem;
      border-top: 1px solid rgba(255,255,255,0.04);
      background: rgba(180,140,220,0.03);
    }
    .vedic-b3-dasha-label {
      font-family: var(--font-mono); font-size: 0.58rem; text-transform: uppercase;
      letter-spacing: 0.08em; color: #c8b0f0; opacity: 0.7; flex-shrink: 0;
    }
    .vedic-b3-dasha-value {
      font-family: var(--font-mono); font-size: 0.82rem; color: var(--cream);
      font-weight: 500;
    }
    @media (max-width: 700px) {
      .vedic-b3-grid { grid-template-columns: 1fr; }
      .vedic-b3-col { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.04); }
      .vedic-b3-col:last-child { border-bottom: none; }
    }

    .planet-row-nakshatra { font-size: 0.62rem; font-family: var(--font-mono); color: var(--cream-muted); opacity: 0.65; letter-spacing: 0.03em; line-height: 1.2; margin-top: 1px; }
    /* Nakshatra grid (Vedic) */
    .nak-list {
      display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.4rem;
      padding: 0.5rem 0.75rem;
    }
    .nak-row {
      display: flex; align-items: flex-start; gap: 0.5rem;
      padding: 0.4rem 0.5rem; border: 1px solid rgba(255,255,255,0.04);
      border-radius: 6px; opacity: 0.4; transition: opacity 0.15s;
      background: rgba(255,255,255,0.015);
    }
    .nak-row.nak-occupied { opacity: 1; border-color: rgba(201,168,76,0.2); background: rgba(201,168,76,0.03); }
    @media (max-width: 860px) { .nak-list { grid-template-columns: repeat(3, 1fr); } }
    @media (max-width: 600px) { .nak-list { grid-template-columns: repeat(2, 1fr); } }
    @media (max-width: 400px) { .nak-list { grid-template-columns: 1fr; } }
    .nak-row-num {
      font-family: var(--font-mono); font-size: 0.6rem; color: var(--cream-muted);
      opacity: 0.5; width: 1.4rem; flex-shrink: 0; text-align: right; padding-top: 2px;
    }
    .nak-row-body { flex: 1; min-width: 0; }
    .nak-row-top { display: flex; align-items: baseline; gap: 0.5rem; flex-wrap: wrap; }
    .nak-row-name {
      font-family: var(--font-display); font-size: 0.88rem; color: var(--cream);
      font-weight: 500;
    }
    .nak-row-ruler {
      font-family: var(--font-mono); font-size: 0.62rem; color: var(--gold);
      opacity: 0.6; letter-spacing: 0.04em;
    }
    .nak-gana {
      font-family: var(--font-mono); font-size: 0.52rem; letter-spacing: 0.04em;
      padding: 1px 5px; border-radius: 3px;
    }
    .nak-row-detail {
      margin-top: 2px;
    }
    .nak-row-deity {
      font-size: 0.72rem; color: var(--cream-muted); opacity: 0.6;
    }
    .nak-row-planets { display: flex; gap: 0.4rem; margin-top: 0.3rem; flex-wrap: wrap; }
    .nak-chip {
      display: inline-flex; align-items: center; gap: 0.25rem;
      background: rgba(201,168,76,0.08); border: 1px solid rgba(201,168,76,0.2);
      border-radius: 4px; padding: 2px 6px;
    }
    .nak-chip-name { font-size: 0.72rem; color: var(--cream); font-weight: 400; }
    .nak-chip-pada { font-family: var(--font-mono); font-size: 0.58rem; color: var(--gold); opacity: 0.6; }
    .planet-row-nakshatra .nakshatra-ruler { color: var(--gold); opacity: 0.6; }
    /* Rahu/Ketu accent colours */
    .planet-row.p-rahu { border-color: rgba(180,140,220,0.3); background: rgba(120,80,180,0.10); box-shadow: inset 0 0 18px rgba(180,140,220,0.06); }
    .planet-row.p-rahu::before { background: radial-gradient(circle at 14% 50%, rgba(180,140,220,0.22), transparent 58%); }
    .planet-row.p-rahu .planet-row-pos, .planet-row.p-rahu .planet-row-glyph { color: #c8b0f0; }
    .planet-row.p-ketu { border-color: rgba(180,140,220,0.25); background: rgba(100,60,140,0.08); box-shadow: inset 0 0 18px rgba(180,140,220,0.05); }
    .planet-row.p-ketu::before { background: radial-gradient(circle at 14% 50%, rgba(180,140,220,0.18), transparent 58%); }
    .planet-row.p-ketu .planet-row-pos, .planet-row.p-ketu .planet-row-glyph { color: #b8a0d8; }
    /* Planet-specific accent colours */
    .planet-row.p-sun     { border-color: rgba(201,168,76,0.35);  background: rgba(201,168,76,0.12); box-shadow: inset 0 0 18px rgba(201,168,76,0.08); }
    .planet-row.p-sun::before { background: radial-gradient(circle at 14% 50%, rgba(201,168,76,0.32), transparent 58%); }
    .planet-row.p-sun  .planet-row-pos  { color: var(--gold-light); }
    .planet-row.p-sun  .planet-row-glyph { color: var(--gold); }
    .planet-row.p-moon    { border-color: rgba(180,200,220,0.3);  background: rgba(180,200,220,0.09); box-shadow: inset 0 0 18px rgba(180,200,220,0.08); }
    .planet-row.p-moon::before { background: radial-gradient(circle at 14% 50%, rgba(180,200,220,0.26), transparent 58%); }
    .planet-row.p-moon .planet-row-pos  { color: #c8dcf4; }
    .planet-row.p-moon .planet-row-glyph { color: #b8ccf0; }
    .planet-row.p-mercury { border-color: rgba(132,120,214,0.3); background: rgba(96,86,170,0.11); box-shadow: inset 0 0 18px rgba(132,120,214,0.08); }
    .planet-row.p-mercury::before { background: radial-gradient(circle at 14% 50%, rgba(132,120,214,0.24), transparent 58%); }
    .planet-row.p-mercury .planet-row-pos,
    .planet-row.p-mercury .planet-row-glyph { color: #bcb4ff; }
    .planet-row.p-venus { border-color: rgba(88,170,122,0.3); background: rgba(56,114,78,0.11); box-shadow: inset 0 0 18px rgba(88,170,122,0.08); }
    .planet-row.p-venus::before { background: radial-gradient(circle at 14% 50%, rgba(88,170,122,0.24), transparent 58%); }
    .planet-row.p-venus .planet-row-pos,
    .planet-row.p-venus .planet-row-glyph { color: #a7dfb6; }
    .planet-row.p-mars { border-color: rgba(212,96,86,0.32); background: rgba(128,42,38,0.12); box-shadow: inset 0 0 18px rgba(212,96,86,0.09); }
    .planet-row.p-mars::before { background: radial-gradient(circle at 14% 50%, rgba(212,96,86,0.26), transparent 58%); }
    .planet-row.p-mars .planet-row-pos,
    .planet-row.p-mars .planet-row-glyph { color: #f0a299; }
    .planet-row.p-jupiter { border-color: rgba(78,132,220,0.3); background: rgba(42,72,132,0.12); box-shadow: inset 0 0 18px rgba(78,132,220,0.08); }
    .planet-row.p-jupiter::before { background: radial-gradient(circle at 14% 50%, rgba(78,132,220,0.24), transparent 58%); }
    .planet-row.p-jupiter .planet-row-pos,
    .planet-row.p-jupiter .planet-row-glyph { color: #a9c3ff; }
    .planet-row.p-saturn { border-color: rgba(168,154,122,0.28); background: rgba(92,82,58,0.12); box-shadow: inset 0 0 18px rgba(168,154,122,0.08); }
    .planet-row.p-saturn::before { background: radial-gradient(circle at 14% 50%, rgba(168,154,122,0.22), transparent 58%); }
    .planet-row.p-saturn .planet-row-pos,
    .planet-row.p-saturn .planet-row-glyph { color: #d9ccb1; }
    .planet-row.p-uranus { border-color: rgba(82,198,212,0.3); background: rgba(34,98,112,0.11); box-shadow: inset 0 0 18px rgba(82,198,212,0.08); }
    .planet-row.p-uranus::before { background: radial-gradient(circle at 14% 50%, rgba(82,198,212,0.24), transparent 58%); }
    .planet-row.p-uranus .planet-row-pos,
    .planet-row.p-uranus .planet-row-glyph { color: #9de7ef; }
    .planet-row.p-neptune { border-color: rgba(90,112,226,0.3); background: rgba(40,52,118,0.11); box-shadow: inset 0 0 18px rgba(90,112,226,0.08); }
    .planet-row.p-neptune::before { background: radial-gradient(circle at 14% 50%, rgba(90,112,226,0.25), transparent 58%); }
    .planet-row.p-neptune .planet-row-pos,
    .planet-row.p-neptune .planet-row-glyph { color: #aeb9ff; }
    .planet-row.p-pluto { border-color: rgba(190,108,208,0.3); background: rgba(92,42,102,0.12); box-shadow: inset 0 0 18px rgba(190,108,208,0.08); }
    .planet-row.p-pluto::before { background: radial-gradient(circle at 14% 50%, rgba(190,108,208,0.24), transparent 58%); }
    .planet-row.p-pluto .planet-row-pos,
    .planet-row.p-pluto .planet-row-glyph { color: #e0aaf1; }
    .planet-row.p-sunset  { border-color: rgba(160,100,200,0.3);  background: rgba(140,80,180,0.1); }
    .planet-row.p-sunset::before { background: radial-gradient(circle at 14% 50%, rgba(160,100,200,0.22), transparent 58%); }
    .planet-row.p-sunset .planet-row-pos  { color: #c8a8e8; }
    .planet-row.p-sunset .planet-row-glyph { color: #b890d8; }
    /* Compact planet position row for Current tab */
    .planet-row .planet-row-badges {
        display: inline-flex; gap: 0.18rem; align-items: center; vertical-align: middle;
    }
    .planet-row .planet-row-badges .motion-badge,
    .planet-row .planet-row-badges .combustion-badge {
        font-size: 0.5rem; padding: 0.03rem 0.26rem;
    }
    /* ── SKY BOX — unified aligned rows ── */
    .sky-rows { width: 100%; display: flex; flex-direction: column; }
    .sky-row {
      display: grid; grid-template-columns: 1.5rem 1fr auto;
      align-items: center; padding: 0.3rem 0.1rem;
      border-bottom: 1px solid rgba(255,255,255,0.04); font-size: 0.8rem;
    }
    .sky-row:last-child { border-bottom: none; }
    .sky-row-glyph { text-align: center; font-size: 0.95rem; line-height: 1; }
    .sky-row-label { color: var(--cream-muted); padding: 0 0.4rem;
      font-size: 0.77rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .sky-row-val { font-family: var(--font-mono); font-size: 0.73rem;
      color: var(--cream); text-align: right; white-space: nowrap; }
    .sky-row.sky-sep { border-top: 1px solid rgba(255,255,255,0.07); margin-top: 0.1rem; }
    .planet-grid-label {
        grid-column: 1 / -1; padding: 0.3rem 0.5rem 0.1rem;
        font-family: var(--font-mono); font-size: 0.58rem; text-transform: uppercase;
        letter-spacing: 0.14em; color: var(--sage); opacity: 0.7;
    }

    /* ── PLANETARY HOURS ── */
    .planetary-hours-list { padding: 0.25rem; }
    .planetary-hour-row {
      display: flex; align-items: center; padding: 0.45rem 0.6rem;
      border-radius: var(--radius-sm); font-size: 0.8rem; color: var(--cream-muted);
    }
    .planetary-hour-row:nth-child(odd) { background: rgba(255,255,255,0.02); }
    .planetary-hour-planet { flex: 1; display: flex; align-items: center; gap: 0.5rem; }
    .planetary-hour-time { font-family: var(--font-mono); color: var(--cream-muted); font-size: 0.73rem; }

    /* ── MOTION / COMBUSTION ── */
    .motion-badge { display: inline-block; font-family: var(--font-mono); font-size: 0.62rem; font-weight: 500; padding: 0.1rem 0.45rem; border-radius: 0.25rem; white-space: nowrap; }
    .motion-badge.retrograde  { background: rgba(199,125,106,0.15); color: var(--warm); border: 1px solid rgba(199,125,106,0.25); }
    .motion-badge.direct      { background: rgba(122,158,126,0.12); color: var(--sage); border: 1px solid rgba(122,158,126,0.2); }
    .motion-badge.station     { background: rgba(201,168,76,0.1); color: var(--gold); border: 1px solid rgba(201,168,76,0.2); }
    .combustion-badge { display: inline-block; font-family: var(--font-mono); font-size: 0.62rem; font-weight: 500; padding: 0.1rem 0.45rem; border-radius: 0.25rem; white-space: nowrap; }
    .combustion-badge.cazimi     { background: rgba(201,168,76,0.15); color: var(--gold-light); border: 1px solid rgba(201,168,76,0.25); }
    .combustion-badge.combust    { background: rgba(199,125,106,0.15); color: var(--warm); border: 1px solid rgba(199,125,106,0.2); }
    .combustion-badge.under-beams { background: rgba(199,125,106,0.08); color: #d4a090; border: 1px solid rgba(199,125,106,0.15); }

    /* ── ASPECT TABLE ── */
    .aspect-table { width: 100%; border-collapse: collapse; }
    .aspect-table th { font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--cream-muted); padding: 0.4rem 0.5rem; border-bottom: 1px solid rgba(255,255,255,0.07); text-align: left; }
    .aspect-table td { padding: 0.48rem 0.5rem; font-size: 0.82rem; border-bottom: 1px solid rgba(255,255,255,0.04); vertical-align: middle; color: var(--cream); overflow: hidden; text-overflow: ellipsis; }
    .aspect-table tr:last-child td { border-bottom: none; }
    .aspect-table tr:hover td { background: rgba(255,255,255,0.02); }
    .aspect-table .col-pair { font-weight: 500; }
    .aspect-table .col-type { color: var(--cream-muted); }
    .aspect-table .col-orb  { font-family: var(--font-mono); font-size: 0.73rem; color: var(--cream-muted); text-align: right; }
    /* ── ACCORDION CARD ── */
    .card-accordion > .card-header { cursor: pointer; user-select: none; }
    .card-accordion > .card-header .acc-chevron { font-size: 0.7rem; opacity: 0.6; transition: transform 0.25s; }
    .card-accordion.acc-open > .card-header .acc-chevron { transform: rotate(180deg); }
    .card-accordion > .acc-body-wrap { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; }
    .card-accordion.acc-open > .acc-body-wrap { max-height: 2000px; }

    .aspect-dir-badge { display: inline-block; font-family: var(--font-mono); font-size: 0.58rem; font-weight: 500; padding: 0.1rem 0.38rem; border-radius: 0.2rem; letter-spacing: 0.04em; }
    .aspect-dir-badge.applying   { background: rgba(122,158,126,0.12); color: var(--sage); border: 1px solid rgba(122,158,126,0.18); }
    .aspect-dir-badge.separating { background: rgba(122,100,180,0.1); color: #b09ad4; border: 1px solid rgba(122,100,180,0.18); }

    /* ── INGRESS ── */
    .ingress-row { display: flex; align-items: center; padding: 0.45rem 0; border-bottom: 1px solid rgba(255,255,255,0.04); font-size: 0.82rem; }
    .ingress-row:last-child { border-bottom: none; }
    .ingress-planet { font-weight: 500; min-width: 90px; white-space: nowrap; color: var(--cream); }
    .ingress-transition { flex: 1; text-align: center; white-space: nowrap; }
    .ingress-from  { color: var(--cream-muted); text-decoration: line-through; font-size: 0.77rem; }
    .ingress-arrow { color: var(--gold); margin: 0 0.3rem; }
    .ingress-to    { font-weight: 500; color: var(--cream); }
    .ingress-date  { font-family: var(--font-mono); font-size: 0.72rem; color: var(--cream-muted); text-align: right; white-space: nowrap; min-width: 100px; }
    .ingress-transition .motion-badge { margin-left: 0.3rem; }

    /* ── HOROSCOPE ── */
    .horoscope-reading { font-size: 0.9rem; line-height: 1.8; color: var(--cream-muted); font-weight: 300; }
    .horoscope-reading p { margin-bottom: 1rem; }
    .horoscope-reading p:last-child { margin-bottom: 0; }
    .horoscope-section-label { font-family: var(--font-mono); font-size: 0.62rem; font-weight: 400; text-transform: uppercase; letter-spacing: 0.15em; color: var(--sage); margin-bottom: 0.5rem; padding-bottom: 0.4rem; border-bottom: 1px solid rgba(255,255,255,0.05); }
    .horoscope-error { background: rgba(199,125,106,0.1); border: 1px solid rgba(199,125,106,0.2); border-radius: var(--radius-sm); padding: 0.75rem 1rem; font-size: 0.85rem; color: var(--warm); }
    .horoscope-transit-hero {
      position: relative;
      display: grid;
      grid-template-columns: minmax(0, 1fr);
      gap: 1rem;
      margin-bottom: 1rem;
      padding: 1rem;
      border: 1px solid rgba(201,168,76,0.2);
      border-radius: calc(var(--radius-card) - 4px);
      background:
        radial-gradient(circle at top right, rgba(201,168,76,0.12), transparent 34%),
        linear-gradient(145deg, rgba(24,24,40,0.98), rgba(15,15,26,0.94));
      overflow: hidden;
    }
    .horoscope-transit-hero::before {
      content: '';
      position: absolute;
      inset: 0 auto auto 0;
      width: 100%;
      height: 1px;
      background: linear-gradient(90deg, rgba(201,168,76,0), rgba(201,168,76,0.45), rgba(201,168,76,0));
    }
    .horoscope-transit-hero-art img {
      width: 100%;
      height: 100%;
      min-height: 210px;
      object-fit: cover;
      border-radius: calc(var(--radius-card) - 8px);
      border: 1px solid rgba(201,168,76,0.18);
      opacity: 0.82;
      box-shadow: 0 14px 30px rgba(0,0,0,0.35);
    }
    .horoscope-transit-hero-art {
      position: relative;
      min-width: 0;
    }
    .horoscope-transit-hero-art-badge {
      position: absolute;
      right: -0.35rem;
      bottom: -0.35rem;
      width: 72px;
      height: 72px;
      padding: 0.3rem;
      border-radius: 18px;
      background: rgba(8,8,15,0.88);
      border: 1px solid rgba(201,168,76,0.2);
      box-shadow: 0 10px 24px rgba(0,0,0,0.35);
    }
    .horoscope-transit-hero-art-badge img {
      width: 100%;
      height: 100%;
      min-height: 0;
      border-radius: 14px;
      object-fit: cover;
      opacity: 0.95;
      border: 1px solid rgba(255,255,255,0.08);
      box-shadow: none;
    }
    .horoscope-transit-hero-inner { min-width: 0; }
    .horoscope-transit-hero-inner .transit-card-header {
      padding: 0 0 0.55rem; background: none;
      border-bottom: 1px solid rgba(201,168,76,0.12);
      margin-bottom: 0.65rem;
    }
    .horoscope-transit-hero-kicker {
      margin-bottom: 0.45rem;
      font-family: var(--font-mono);
      font-size: 0.62rem;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: var(--gold);
    }
    .horoscope-transit-hero-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 0.8rem;
      margin-bottom: 0.7rem;
    }
    .horoscope-transit-hero-title {
      margin: 0;
      font-family: var(--font-display);
      font-size: 1.25rem;
      line-height: 1.15;
      color: var(--cream);
    }
    .horoscope-transit-hero-subtitle {
      margin-top: 0.25rem;
      font-size: 0.82rem;
      line-height: 1.55;
      color: var(--cream-muted);
    }
    .horoscope-transit-hero-score {
      display: flex;
      flex-direction: column;
      align-items: flex-end;
      gap: 0.08rem;
      min-width: 74px;
      font-family: var(--font-mono);
    }
    .horoscope-transit-hero-score-value {
      font-size: 1rem;
      font-weight: 700;
      color: var(--gold-light);
    }
    .horoscope-transit-hero-score-tier {
      font-size: 0.58rem;
      letter-spacing: 0.12em;
      color: var(--cream-muted);
    }
    .horoscope-transit-hero-body {
      font-size: 0.92rem;
      line-height: 1.78;
      color: var(--cream-muted);
    }
    .horoscope-transit-hero-topline {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: 0.8rem;
      margin-bottom: 0.95rem;
    }
    .horoscope-transit-hero-synthesis,
    .horoscope-transit-hero-takeaway {
      padding: 0.75rem 0.85rem;
      border-radius: 12px;
      border: 1px solid rgba(201,168,76,0.14);
      background: rgba(255,255,255,0.03);
    }
    .horoscope-transit-hero-synthesis-label,
    .horoscope-transit-hero-takeaway-label {
      font-family: var(--font-mono);
      font-size: 0.58rem;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: rgba(201,168,76,0.74);
      margin-bottom: 0.35rem;
    }
    .horoscope-transit-hero-synthesis-deck {
      font-size: 0.76rem;
      line-height: 1.55;
      color: rgba(245,234,205,0.76);
    }
    .horoscope-transit-hero-synthesis-list {
      display: flex;
      flex-wrap: wrap;
      gap: 0.35rem;
      margin-top: 0.55rem;
    }
    .horoscope-transit-hero-synthesis-chip {
      padding: 0.16rem 0.46rem;
      border-radius: 999px;
      border: 1px solid rgba(201,168,76,0.2);
      background: rgba(201,168,76,0.08);
      color: var(--gold-light);
      font-size: 0.62rem;
      font-family: var(--font-mono);
      letter-spacing: 0.06em;
      text-transform: uppercase;
    }
    .horoscope-transit-hero-takeaway-text {
      font-size: 0.8rem;
      line-height: 1.6;
      color: rgba(245,234,205,0.82);
    }
    .horoscope-transit-hero-takeaway-inline {
      margin: 0 0 0.75rem;
      border-top: 1px solid rgba(201,168,76,0.1);
      border-radius: 0.7rem;
    }
    .tc-takeaway {
      background: rgba(201,168,76,0.06);
      border: 1px solid rgba(201,168,76,0.15);
      border-radius: calc(var(--radius-card) - 6px);
      padding: 0.65rem 0.9rem;
      font-size: 0.84rem; line-height: 1.75;
      color: var(--cream); font-weight: 400;
      margin-bottom: 0.75rem;
    }
    .tc-takeaway-prefix {
      display: inline-block;
      margin-right: 0.45rem;
      font-family: var(--font-mono);
      font-size: 0.62rem;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(201,168,76,0.78);
      white-space: nowrap;
    }
    .horoscope-transit-hero-body p { margin-bottom: 0.7rem; }
    .horoscope-transit-hero-body p:last-child { margin-bottom: 0; }
.horoscope-transit-hero-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.9rem;
}
.horoscope-transit-hero-anchors {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.9rem;
}
.horoscope-transit-hero-anchor {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(201,168,76,0.12);
  color: var(--cream);
}
.horoscope-transit-hero-anchor-glyph {
  color: var(--gold-light);
  font-size: 0.95rem;
  line-height: 1;
}
.horoscope-transit-hero-anchor-text {
  font-size: 0.72rem;
  color: var(--cream-muted);
}
.horoscope-transit-hero-chip {
  min-width: 0;
  padding: 0.6rem 0.72rem;
      border-radius: 10px;
      background: rgba(255,255,255,0.04);
      border: 1px solid rgba(255,255,255,0.08);
    }
    .horoscope-transit-hero-chip-label {
      font-size: 0.75rem;
      color: var(--cream);
      line-height: 1.35;
    }
    .horoscope-transit-hero-chip-meta {
      margin-top: 0.18rem;
      font-family: var(--font-mono);
      font-size: 0.6rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--gold);
    }
    .horoscope-transit-hero-natal {
      margin-top: 0.75rem;
      padding-top: 0.7rem;
      border-top: 1px solid rgba(255,255,255,0.06);
      font-size: 0.73rem;
      line-height: 1.6;
      color: var(--cream-muted);
    }
    .horoscope-transit-hero-links {
      display: flex;
      flex-wrap: wrap;
      gap: 0.55rem;
      margin-top: 0.85rem;
    }
    .horoscope-transit-hero-link {
      display: inline-flex;
      align-items: center;
      padding: 0.42rem 0.7rem;
      border-radius: 999px;
      background: rgba(255,255,255,0.04);
      border: 1px solid rgba(255,255,255,0.08);
      color: var(--gold-light);
      text-decoration: none;
      font-size: 0.71rem;
      letter-spacing: 0.04em;
    }
    .horoscope-transit-hero-link:hover {
      border-color: rgba(201,168,76,0.3);
      color: var(--gold);
    }

    /* ── TRANSIT CARDS (paired score + reading) ── */
    .transit-card {
      background: var(--ink-card-alt);
      border: 1px solid rgba(255,255,255,0.06);
      border-radius: var(--radius-sm);
      margin-bottom: 0.75rem;
      overflow: hidden;
    }
    .transit-card:last-child { margin-bottom: 0; }
    .transit-card-header {
      display: flex; align-items: center; gap: 10px;
      padding: 0.6rem 0.85rem;
      border-bottom: 1px solid rgba(255,255,255,0.05);
      background: rgba(255,255,255,0.02);
    }
    .transit-card-header .tc-planets {
      font-family: var(--font-display);
      font-size: 0.88rem; font-weight: 500; color: var(--cream);
      flex: 1; min-width: 0;
      display: flex;
      align-items: center;
      gap: 0.18rem;
      flex-wrap: wrap;
    }
    .transit-card-header .tc-house-inline {
      font-family: var(--font-mono);
      font-size: 0.58rem;
      letter-spacing: 0.05em;
      color: var(--gold-light);
      font-weight: 600;
      white-space: nowrap;
      display: inline-flex;
      align-items: center;
      padding: 0.05rem 0.32rem;
      margin-left: 0.22rem;
      border-radius: 999px;
      background: rgba(201,168,76,0.1);
      border: 1px solid rgba(201,168,76,0.16);
    }
    .transit-card-header .tc-arrow {
      color: var(--cream-muted);
      margin: 0 0.08rem;
    }
    .transit-card-header .tc-aspect {
      font-family: var(--font-mono);
      font-size: 0.65rem; color: var(--cream-muted);
      letter-spacing: 0.04em;
    }
    .transit-card-header .tc-meta {
      display: flex; align-items: center; gap: 6px; flex-shrink: 0;
    }
    .transit-card-header .tc-orb {
      font-family: var(--font-mono); font-size: 0.68rem; color: var(--cream-muted);
    }
    .transit-card-header .tc-score-wrap { text-align: right; min-width: 62px; }
    .transit-card-header .tc-score {
      font-family: var(--font-mono); font-size: 0.78rem; font-weight: 700;
    }
    .transit-card-header .tc-bar {
      width: 54px; height: 3px; background: rgba(255,255,255,0.08);
      border-radius: 2px; margin-top: 2px;
    }
    .transit-card-header .tc-bar-fill { height: 100%; border-radius: 2px; }
    .transit-card-header .tc-tier {
      font-family: var(--font-mono); font-size: 0.58rem; letter-spacing: 0.08em;
      margin-top: 1px;
    }
    .transit-card-body {
      padding: 0.7rem 0.85rem;
      font-size: 0.87rem; line-height: 1.75; color: var(--cream-muted); font-weight: 300;
    }
    .transit-card-body p { margin-bottom: 0.6rem; }
    .transit-card-body p:last-child { margin-bottom: 0; }
    .transit-card-badges { display: flex; gap: 5px; align-items: center; flex-wrap: wrap; }
    .transit-card.tier-dominant { border-left: 2px solid rgba(232,128,106,0.5); }
    .transit-card.tier-significant { border-left: 2px solid rgba(212,168,106,0.4); }
    .transit-card.tier-supporting { border-left: 2px solid rgba(255,255,255,0.1); }
    .transit-card.tier-sky-dominant { border-left: 2px solid rgba(232,212,139,0.5); }
    .transit-card.tier-sky-significant { border-left: 2px solid rgba(212,168,106,0.4); }
    .transit-card.lifetime-event {
      border: 1px solid rgba(180,120,255,0.35);
      box-shadow: 0 0 10px rgba(160,80,255,0.08);
    }
    .transit-card .tc-house-context {
      font-size: 0.72rem; color: var(--cream-muted); margin-top: 2px;
    }
    .transit-card .tc-takeaway {
      border: none;
      border-top: 1px solid rgba(201,168,76,0.1);
      border-radius: 0;
      margin-bottom: 0;
    }

    /* ── SACRED OIL ── */
    .window-zodiac {
      display: inline-block; background: var(--gold-soft); color: var(--gold-light);
      border: 1px solid var(--gold-border); padding: 0.2rem 0.65rem; border-radius: 2rem; font-size: 0.78rem;
    }
    /* Accordion window header content */
    .acc-window-left { flex: 1; }
    .acc-window-date { font-weight: 600; font-size: 0.9rem; color: var(--cream); }
    .acc-window-meta { font-size: 0.8rem; color: var(--cream-muted); margin-top: 0.15rem; }
    .acc-window-count { color: var(--gold); }
    .acc-window-no-match { font-size: 0.85rem; }
    .oil-windows-desc { font-size: 0.9rem; }
    .oil-planet-selector { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
    .oil-selector-label { font-family: var(--font-mono); font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--cream-muted); white-space: nowrap; }
    .oil-planet-chips { display: flex; gap: 0.4rem; flex-wrap: wrap; }
    .oil-planet-chip {
      display: inline-flex; align-items: center; gap: 0.25rem;
      padding: 0.3rem 0.65rem; border-radius: 2rem; font-size: 0.75rem; font-weight: 400;
      border: 1px solid rgba(255,255,255,0.07); background: rgba(255,255,255,0.03); color: rgba(196,191,181,0.75); cursor: pointer;
      transition: all 0.2s; font-family: var(--font-body);
    }
    .oil-planet-chip:hover { border-color: var(--gold-border); color: var(--cream-muted); background: rgba(201,168,76,0.05); }
    .oil-planet-chip.active { background: rgba(201,168,76,0.15); color: var(--gold-light); border-color: rgba(201,168,76,0.5); font-weight: 500; box-shadow: 0 0 8px rgba(201,168,76,0.12); }
    .optimal-hours { background: var(--ink-up); border: 1px solid rgba(255,255,255,0.05); border-radius: var(--radius-sm); padding: 0.75rem; margin-top: 0.75rem; }
    .optimal-hours-title { font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--sage); margin-bottom: 0.5rem; }
    .optimal-hour { display: flex; align-items: center; padding: 0.38rem 0; border-bottom: 1px solid rgba(255,255,255,0.04); font-size: 0.83rem; color: var(--cream-muted); }
    .optimal-hour:last-child { border-bottom: none; }
    .optimal-hour-planet { width: 28px; font-size: 1rem; }
    .optimal-hour-time { flex: 1; font-family: var(--font-mono); font-size: 0.78rem; }
    .optimal-hour-type { font-family: var(--font-mono); font-size: 0.62rem; color: var(--cream-muted); background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); padding: 0.1rem 0.4rem; border-radius: 0.2rem; }
    .optimal-hour-notify { background: none; border: 1px solid rgba(255,255,255,0.1); color: var(--cream-muted); font-size: 0.72rem; padding: 0.15rem 0.45rem; border-radius: 0.25rem; cursor: pointer; margin-left: 0.5rem; white-space: nowrap; transition: all 0.2s; }
    .optimal-hour-notify:hover { border-color: var(--gold); color: var(--gold); }
    .optimal-hour-notify.scheduled { background: rgba(212,175,55,0.12); border-color: var(--gold); color: var(--gold); }
    .optimal-hour-notify:disabled { opacity: 0.5; cursor: wait; }
    .oil-lead-dropdown { position: absolute; right: 0; top: 100%; z-index: 20; background: var(--ink-up); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--radius-sm); padding: 0.3rem 0; box-shadow: 0 4px 16px rgba(0,0,0,0.4); min-width: 90px; }
    .oil-lead-option { display: block; width: 100%; background: none; border: none; color: var(--cream-muted); font-family: var(--font-mono); font-size: 0.72rem; padding: 0.35rem 0.75rem; text-align: left; cursor: pointer; }
    .oil-lead-option:hover { background: rgba(212,175,55,0.15); color: var(--gold); }
    .oil-lead-option--current { color: var(--gold); font-weight: 600; }
    /* Eclipse card */
    .eclipse-items { display: flex; gap: 0.5rem; flex-wrap: wrap; }
    .eclipse-item { flex: 1; min-width: 140px; background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05); border-radius: 0.5rem; padding: 0.6rem 0.75rem; display: flex; align-items: center; gap: 0.5rem; }
    .eclipse-item-icon { font-size: 1.2rem; flex-shrink: 0; }
    .eclipse-item-info { min-width: 0; }
    .eclipse-item-type { font-size: 0.82rem; font-weight: 500; color: var(--cream); }
    .eclipse-item-date { font-size: 0.7rem; color: var(--cream-muted); font-family: var(--font-mono); margin-top: 0.1rem; }

    /* ── ALERT SETTINGS ── */
    .alert-pref-row {
      display: flex; align-items: center; gap: 0.75rem;
      padding: 0.65rem 0;
      border-bottom: 1px solid rgba(255,255,255,0.04);
    }
    .alert-pref-row:last-child { border-bottom: none; }
    .alert-pref-row.disabled { opacity: 0.45; }
    .alert-pref-icon { font-size: 1.1rem; flex: none; width: 1.6rem; text-align: center; }
    .alert-pref-info { flex: 1; min-width: 0; }
    .alert-pref-label { font-size: 0.82rem; font-weight: 500; color: var(--cream); display: flex; align-items: center; gap: 0.4rem; }
    .alert-pref-desc { font-size: 0.68rem; color: var(--cream-muted); margin-top: 0.1rem; }
    .alert-pref-soon {
      font-family: var(--font-mono); font-size: 0.52rem; text-transform: uppercase;
      letter-spacing: 0.06em; color: var(--cream-muted);
      background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.08);
      padding: 0.05rem 0.35rem; border-radius: 2rem;
    }
    /* Toggle switch */
    .alert-pref-toggle { position: relative; display: inline-block; width: 36px; height: 20px; flex: none; }
    .alert-pref-toggle input { opacity: 0; width: 0; height: 0; }
    .alert-pref-slider {
      position: absolute; inset: 0; cursor: pointer;
      background: rgba(255,255,255,0.1); border-radius: 20px;
      transition: background 0.2s;
    }
    .alert-pref-slider::before {
      content: ''; position: absolute;
      width: 16px; height: 16px; left: 2px; bottom: 2px;
      background: var(--cream-muted); border-radius: 50%;
      transition: transform 0.2s, background 0.2s;
    }
    .alert-pref-toggle input:checked + .alert-pref-slider { background: rgba(201,168,76,0.35); }
    .alert-pref-toggle input:checked + .alert-pref-slider::before { transform: translateX(16px); background: var(--gold); }
    .alert-pref-toggle input:disabled + .alert-pref-slider { cursor: not-allowed; }

    /* ── METHODOLOGY ── */
    .natal-reading { font-size: 0.95rem; line-height: 1.85; color: var(--cream); font-weight: 300; }
    .natal-reading p { margin-bottom: 1rem; }

    /* Section titles */
    .natal-section-title {
      font-family: var(--font-display);
      font-size: 1.05rem;
      color: var(--gold);
      margin: 0 0 0.75rem 0;
      letter-spacing: 0.03em;
      font-weight: 600;
    }

    /* Drop cap on first paragraph of first section */
    .natal-reading-section:first-child .natal-section-body p:first-of-type::first-letter {
      font-family: var(--font-display);
      font-size: 3.2em;
      float: left;
      line-height: 0.8;
      margin-right: 0.1em;
      margin-top: 0.07em;
      color: var(--gold);
      font-weight: 700;
    }

    /* Section divider */
    .natal-section-divider {
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 1.5rem 0;
      gap: 0.5rem;
    }
    .natal-section-divider::before,
    .natal-section-divider::after {
      content: '';
      flex: 1;
      height: 1px;
      background: linear-gradient(to var(--dir, right), transparent, rgba(201,168,76,0.25), transparent);
    }
    .natal-section-divider::after { --dir: left; }
    .natal-section-divider-dot {
      color: var(--gold);
      font-size: 0.5rem;
      opacity: 0.6;
    }

    /* Card header with regenerate button */
    #natal-portrait-card .card-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .btn-regenerate {
      background: none;
      border: 1px solid var(--gold-border);
      border-radius: 50%;
      width: 30px;
      height: 30px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      color: var(--gold);
      opacity: 0.5;
      transition: opacity 0.2s, transform 0.3s;
      font-size: 0.8rem;
      padding: 0;
    }
    .btn-regenerate:hover { opacity: 1; }
    .btn-regenerate.spinning svg { animation: regen-spin 1s linear infinite; }
    @keyframes regen-spin { to { transform: rotate(360deg); } }
    .methodology-discipline { margin-bottom: 1.75rem; }
    .methodology-discipline-header {
      display: flex; align-items: flex-start; gap: 0.75rem;
      padding: 0.85rem 1.1rem; margin-bottom: 0.85rem;
      border-radius: var(--radius-sm); border: 1px solid rgba(255,255,255,0.07);
    }
    .methodology-discipline[data-discipline="astronomical_engine"] .methodology-discipline-header { background: linear-gradient(135deg, #0e1e30, #0a1825); border-color: rgba(45,106,159,0.25); }
    .methodology-discipline[data-discipline="kabbalistic_angel_system"] .methodology-discipline-header { background: linear-gradient(135deg, #1e1600, #160f00); border-color: var(--gold-border); }
    .methodology-discipline[data-discipline="astrological_framework"] .methodology-discipline-header { background: linear-gradient(135deg, #1a0e2a, #120a20); border-color: rgba(118,75,162,0.25); }
    .methodology-discipline-header h5 { margin: 0; font-size: 0.95rem; font-weight: 500; color: var(--cream); font-family: var(--font-display); }
    .methodology-discipline-header .discipline-desc { font-size: 0.78rem; color: var(--cream-muted); margin: 0.2rem 0 0; font-weight: 300; }
    .methodology-section { background: var(--ink-up); border: 1px solid rgba(255,255,255,0.05); border-radius: var(--radius-sm); padding: 1rem; margin-bottom: 0.75rem; border-left: 2px solid rgba(255,255,255,0.12); }
    .methodology-section h6 { margin-bottom: 0.3rem; font-weight: 500; font-size: 0.92rem; color: var(--cream); }
    .methodology-discipline[data-discipline="astronomical_engine"] .methodology-section { border-left-color: rgba(45,106,159,0.5); }
    .methodology-discipline[data-discipline="astronomical_engine"] .methodology-section h6 { color: #7ab0d4; }
    .methodology-discipline[data-discipline="astronomical_engine"] .methodology-details em { color: #7ab0d4; }
    .methodology-discipline[data-discipline="kabbalistic_angel_system"] .methodology-section { border-left-color: var(--gold-border); }
    .methodology-discipline[data-discipline="kabbalistic_angel_system"] .methodology-section h6 { color: var(--gold-light); }
    .methodology-discipline[data-discipline="kabbalistic_angel_system"] .methodology-details em { color: var(--gold); }
    .methodology-discipline[data-discipline="astrological_framework"] .methodology-section { border-left-color: rgba(118,75,162,0.4); }
    .methodology-discipline[data-discipline="astrological_framework"] .methodology-section h6 { color: #b09ad4; }
    .methodology-discipline[data-discipline="astrological_framework"] .methodology-details em { color: #b09ad4; }
    .methodology-discipline[data-discipline="interpretation_layer"] .methodology-discipline-header { background: linear-gradient(135deg, #0e1e16, #0a1810); border-color: rgba(122,158,126,0.25); }
    .methodology-discipline[data-discipline="interpretation_layer"] .methodology-section { border-left-color: rgba(122,158,126,0.4); }
    .methodology-discipline[data-discipline="interpretation_layer"] .methodology-section h6 { color: #9ac49e; }
    .methodology-discipline[data-discipline="interpretation_layer"] .methodology-details em { color: #7a9e7e; }
    .methodology-desc { font-size: 0.82rem; color: var(--cream-muted); font-style: italic; margin-bottom: 0.5rem; font-weight: 300; }
    .methodology-details { font-size: 0.8rem; color: var(--cream-muted); line-height: 1.65; font-weight: 300; }
    .methodology-details ul { margin: 0.25rem 0 0.5rem; padding-left: 1.25rem; }
    .engine-notes { background: var(--ink-up); border: 1px solid rgba(255,255,255,0.05); border-radius: var(--radius-sm); padding: 1rem; margin-top: 1rem; font-size: 0.82rem; color: var(--cream-muted); line-height: 1.65; font-weight: 300; }
    .engine-notes strong { color: var(--sage); }

    /* ── ANGEL GUIDE ── */
    .angels-intro { text-align: center; padding: 1.5rem 1rem 1rem; }
    .angels-intro-title { font-family: var(--font-display); font-size: 1.15rem; font-weight: 500; color: var(--gold-light); margin: 0 0 0.3rem; }
    .angels-intro-subtitle { font-size: 0.82rem; color: var(--cream-muted); font-style: italic; margin-bottom: 0.6rem; font-weight: 300; }
    .angels-intro-body { font-size: 0.8rem; color: var(--cream-muted); line-height: 1.7; max-width: 600px; margin: 0 auto; font-weight: 300; }
    .angels-toc { display: flex; flex-wrap: wrap; gap: 0.4rem; padding: 0 1rem 1rem; justify-content: center; }
    .angels-toc-btn {
      background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
      border-radius: 2rem; padding: 0.35rem 0.85rem; cursor: pointer;
      display: inline-flex; align-items: center; gap: 0.4rem;
      font-family: var(--font-body); font-size: 0.78rem; color: var(--cream-muted);
      transition: background 0.15s, border-color 0.15s;
    }
    .angels-toc-btn:hover { background: rgba(201,168,76,0.08); border-color: var(--gold-border); color: var(--gold-light); }
    .angels-toc-icon { font-size: 0.9rem; }
    .angels-toc-label { font-weight: 400; }
    .angels-content { padding: 0 0.5rem; }
    .angels-section { margin-bottom: 1.75rem; }
    .angels-section-header {
      display: flex; align-items: flex-start; gap: 0.75rem;
      padding: 0.85rem 1.1rem; margin-bottom: 0.85rem;
      border-radius: var(--radius-sm);
      background: linear-gradient(135deg, #1e1600, #160f00);
      border: 1px solid var(--gold-border);
    }
    .angels-section-icon { font-size: 1.2rem; flex-shrink: 0; margin-top: 0.1rem; }
    .angels-section-title { margin: 0; font-size: 0.95rem; font-weight: 500; color: var(--cream); font-family: var(--font-display); }
    .angels-section-intro { font-size: 0.78rem; color: var(--cream-muted); margin: 0.2rem 0 0; font-weight: 300; line-height: 1.6; }
    .angels-cards-grid { display: grid; grid-template-columns: 1fr; gap: 0.75rem; }
    .angels-card {
      background: var(--ink-up); border: 1px solid rgba(255,255,255,0.05);
      border-radius: var(--radius-sm); padding: 1rem;
      border-left: 2px solid var(--gold-border);
    }
    .angels-card-header { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.5rem; }
    .angels-card-icon { font-size: 1.1rem; flex-shrink: 0; }
    .angels-card-title { margin: 0; font-weight: 500; font-size: 0.9rem; color: var(--gold-light); font-family: var(--font-display); }
    .angels-card-subtitle { font-size: 0.72rem; color: var(--cream-muted); font-style: italic; font-weight: 300; }
    .angels-card-body { font-size: 0.8rem; color: var(--cream-muted); line-height: 1.65; font-weight: 300; }
    .angels-card-detail { font-size: 0.78rem; color: var(--cream-muted); line-height: 1.6; font-weight: 300; margin-top: 0.5rem; padding-top: 0.5rem; border-top: 1px solid rgba(255,255,255,0.04); }
    .angels-card-source { font-size: 0.72rem; color: rgba(196,191,181,0.6); margin-top: 0.4rem; font-weight: 300; }
    .angels-section-footer { font-size: 0.75rem; color: var(--cream-muted); font-style: italic; font-weight: 300; padding: 0.5rem 0.25rem 0; opacity: 0.7; }

    /* ── ACCORDION ── */
    .accordion-item { border: 1px solid rgba(255,255,255,0.07) !important; border-radius: var(--radius-card) !important; margin-bottom: 0.75rem; overflow: hidden; background: var(--ink-card-alt); }
    .accordion-button {
      background: var(--ink-card-alt) !important; padding: 1rem; color: var(--cream) !important;
      font-family: var(--font-body); border: none; width: 100%; text-align: left;
      display: flex; align-items: center; cursor: pointer; transition: background 0.2s;
    }
    .accordion-button:not(.collapsed) { background: var(--gold-soft) !important; }
    .accordion-button::after { display: none; }
    .accordion-button .acc-arrow {
      margin-left: auto; transition: transform 0.3s; color: var(--cream-muted); font-size: 0.8rem;
    }
    .accordion-button:not(.collapsed) .acc-arrow { transform: rotate(180deg); color: var(--gold); }
    .accordion-collapse { display: none; }
    .accordion-collapse.show { display: block; }
    .accordion-body { background: var(--ink-up); padding: 1rem; border-top: 1px solid rgba(255,255,255,0.05); }

    /* ── SOLOMONIC SEALS ── */
    .seal-hero {
      display: flex; align-items: center; gap: 0.85rem;
      padding: 0.65rem 1rem;
      background: linear-gradient(135deg, #1a1200, #120d00);
      border-bottom: 1px solid rgba(201,168,76,0.15);
    }
    .seal-glyph-ring {
      flex-shrink: 0; width: 48px; height: 48px; border-radius: 50%;
      background: radial-gradient(circle at 40% 35%, #3a2800, #1a1000);
      border: 1px solid rgba(201,168,76,0.35);
      display: flex; align-items: center; justify-content: center;
      font-size: 1.5rem; box-shadow: 0 0 18px rgba(201,168,76,0.12); position: relative;
    }
    .seal-glyph-ring::after {
      content: ''; position: absolute; inset: 3px; border-radius: 50%;
      border: 1px solid rgba(201,168,76,0.12);
    }
    .seal-hero-info { flex: 1; min-width: 0; }
    .seal-planet-name { font-family: var(--font-display); font-size: 1.25rem; font-weight: 500; color: var(--gold-light); }
    .seal-archangel { font-size: 0.78rem; color: var(--cream-muted); margin-top: 0.15rem; font-weight: 300; }
    .seal-intent { font-size: 0.78rem; color: rgba(196,191,181,0.7); margin-top: 0.35rem; font-style: italic; line-height: 1.5; font-weight: 300; }
    .seal-meta-row { display: flex; gap: 0.5rem; flex-wrap: wrap; padding: 0.45rem 1rem; border-bottom: 1px solid rgba(255,255,255,0.05); }
    .seal-chip { display: inline-flex; align-items: center; gap: 0.3rem; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 2rem; padding: 0.2rem 0.7rem; font-size: 0.72rem; color: var(--cream-muted); }
    .seal-chip .seal-chip-label { font-family: var(--font-mono); font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(196,191,181,0.75); margin-right: 0.1rem; }
    .seal-psalm { padding: 0.35rem 1rem; font-size: 0.73rem; color: rgba(196,191,181,0.78); font-style: italic; font-weight: 300; border-bottom: 1px solid rgba(255,255,255,0.04); }
    .pentacles-header { padding: 0.45rem 1rem 0.35rem; font-family: var(--font-mono); font-size: 0.6rem; font-weight: 400; text-transform: uppercase; letter-spacing: 0.18em; color: var(--sage); display: flex; align-items: center; justify-content: space-between; }
    .pentacles-count-badge { background: var(--gold-soft); border: 1px solid var(--gold-border); color: var(--gold); padding: 0.1rem 0.45rem; border-radius: 0.25rem; font-size: 0.62rem; letter-spacing: 0.06em; }
    .pentacle-item { padding: 0.5rem 1rem; border-top: 1px solid rgba(255,255,255,0.04); cursor: pointer; transition: background 0.15s; }
    .pentacle-item:hover { background: rgba(255,255,255,0.02); }
    .pentacle-top { display: flex; align-items: flex-start; gap: 0.75rem; }
    .pentacle-num { flex-shrink: 0; width: 24px; height: 24px; border-radius: 50%; background: rgba(201,168,76,0.1); border: 1px solid rgba(201,168,76,0.25); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 0.65rem; color: var(--gold); margin-top: 0.1rem; }
    .pentacle-title-wrap { flex: 1; min-width: 0; }
    .pentacle-title { font-size: 0.88rem; font-weight: 500; color: var(--cream); font-family: var(--font-display); line-height: 1.3; }
    .pentacle-divine { font-size: 0.7rem; color: var(--gold); margin-top: 0.15rem; font-family: var(--font-mono); letter-spacing: 0.04em; }
    .pentacle-expand-icon { flex-shrink: 0; color: rgba(196,191,181,0.55); font-size: 0.7rem; margin-top: 0.15rem; transition: transform 0.25s, color 0.15s; }
    .pentacle-item.open .pentacle-expand-icon { transform: rotate(180deg); color: var(--gold); }
    .pentacle-body { display: none; padding-top: 0.65rem; padding-left: 2.25rem; }
    .pentacle-item.open .pentacle-body { display: flex !important; gap: 1rem; align-items: flex-start; }
    .pentacle-art-wrap {
      flex: 0 0 150px; width: 150px; height: 150px;
      display: flex; justify-content: center; align-items: center;
      padding: 0.4rem;
      background: rgba(0,0,0,0.35); border: 1px solid rgba(255,255,255,0.06);
      border-radius: var(--radius-sm);
    }
    .pentacle-art-wrap img {
      max-width: 134px; max-height: 134px; width: auto; height: auto;
      filter: invert(0.9) sepia(0.1) saturate(0.7) brightness(0.95);
      image-rendering: -webkit-optimize-contrast;
      image-rendering: crisp-edges;
    }
    .pentacle-art-wrap img.is-photo {
      filter: brightness(0.88) contrast(1.08);
      image-rendering: auto;
    }
    .pentacle-body-text { flex: 1; min-width: 0; }
    @media (max-width: 575px) {
      .pentacle-item.open .pentacle-body { flex-direction: column !important; }
      .pentacle-art-wrap { flex: none; width: 100%; height: auto; }
      .pentacle-art-wrap img { max-width: 150px; max-height: 150px; }
    }
    .pentacle-purpose { font-size: 0.8rem; color: var(--cream-muted); line-height: 1.65; font-weight: 300; margin-bottom: 0.45rem; }
    .pentacle-psalm { font-size: 0.72rem; color: rgba(196,191,181,0.75); font-style: italic; font-weight: 300; padding-top: 0.35rem; border-top: 1px solid rgba(255,255,255,0.05); margin-bottom: 0.5rem; }
    .pentacle-prescription { display: flex; flex-direction: column; gap: 0.3rem; padding: 0.55rem 0.7rem; margin-top: 0.5rem; background: rgba(0,0,0,0.25); border: 1px solid rgba(255,255,255,0.06); border-radius: var(--radius-sm); }
    .pentacle-presc-row { display: flex; align-items: flex-start; gap: 0.5rem; font-size: 0.73rem; }
    .pentacle-presc-label { flex-shrink: 0; font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--gold); opacity: 0.6; padding-top: 0.1rem; min-width: 4.5rem; }
    .pentacle-presc-val { color: var(--cream-muted); font-weight: 300; line-height: 1.5; }
    .pentacle-presc-override { border-color: rgba(201,168,76,0.18); background: rgba(201,168,76,0.04); }
    .pentacle-presc-override .pentacle-presc-label { opacity: 1; }
    .seal-source-note { padding: 0.35rem 1rem; font-size: 0.65rem; color: rgba(196,191,181,0.55); font-style: italic; border-top: 1px solid rgba(255,255,255,0.04); font-weight: 300; }

    /* ── RITUAL BROWSER ── */
    .ritual-filters { padding:0.65rem 1.25rem; border-bottom:1px solid rgba(255,255,255,0.05); display:flex; flex-direction:column; gap:0.5rem; }
    .ritual-filter-row { display:flex; gap:0.3rem; flex-wrap:wrap; align-items:center; }
    .ritual-filter-label { font-family:var(--font-mono); font-size:0.55rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--gold); opacity:0.6; white-space:nowrap; padding-right:0.25rem; }
    .ritual-pill {
      display:inline-flex; align-items:center; gap:0.2rem;
      padding:0.15rem 0.55rem; border-radius:2rem; font-size:0.67rem; font-weight:400;
      border:1px solid rgba(255,255,255,0.1); color:var(--cream-muted);
      background:transparent; cursor:pointer; transition:all 0.18s; white-space:nowrap;
    }
    .ritual-pill:hover { border-color:rgba(255,255,255,0.25); color:var(--cream); }
    .ritual-pill.active { background:rgba(201,168,76,0.12); border-color:var(--gold); color:var(--gold); }
    .ritual-pill.active-intent { background:rgba(122,158,126,0.1); border-color:var(--sage); color:#b8d4ba; }
    .ritual-pill.active-source { background:rgba(122,158,126,0.08); border-color:rgba(122,100,180,0.6); color:rgba(180,160,220,0.9); }
    /* Grid */
    .ritual-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:1px; background:rgba(255,255,255,0.04); }
    .ritual-card {
      display:flex; flex-direction:column; align-items:center; justify-content:flex-start;
      padding:0.85rem 0.6rem 0.7rem; gap:0.35rem;
      background:var(--ink-up); cursor:pointer; transition:background 0.15s;
      text-align:center; overflow:hidden;
    }
    .ritual-card:hover { background:rgba(255,255,255,0.04); }
    .ritual-card-thumb {
      width:54px; height:54px; flex-shrink:0;
      background:rgba(0,0,0,0.35); border:1px solid rgba(255,255,255,0.07);
      border-radius:5px; display:flex; align-items:center; justify-content:center; overflow:hidden;
    }
    .ritual-card-thumb img { width:46px; height:46px; object-fit:contain; filter:invert(0.9) sepia(0.1) saturate(0.6) brightness(0.9); }
    .ritual-card-name { font-size:0.72rem; font-weight:500; color:var(--cream); font-family:var(--font-display); line-height:1.3; }
    .ritual-card-intent { font-size:0.58rem; font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.06em; color:var(--cream-muted); }
    .ritual-natal-badge {
        display:inline-block; font-size:0.5rem; font-family:var(--font-mono);
        text-transform:uppercase; letter-spacing:0.08em;
        padding:0.1rem 0.35rem; border-radius:1rem; margin-top:0.15rem;
        background:rgba(201,168,76,0.15); border:1px solid rgba(201,168,76,0.4); color:var(--gold);
        white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:100%;
    }
    /* Modal */
    .ritual-modal-overlay {
      display:none; position:fixed; inset:0; z-index:2000;
      background:rgba(8,8,15,0.82); backdrop-filter:blur(6px);
      align-items:center; justify-content:center; padding:1rem;
    }
    .ritual-modal-overlay.open { display:flex; }
    .ritual-modal {
      background:var(--ink-up); border:1px solid rgba(255,255,255,0.08);
      border-radius:8px; width:100%; max-width:680px;
      max-height:72vh; display:flex; flex-direction:column;
      box-shadow:0 24px 64px rgba(0,0,0,0.6); position:relative;
    }
    .ritual-modal-header {
      flex-shrink:0; display:flex; align-items:center; gap:0.75rem;
      padding:1rem 1.25rem; border-bottom:1px solid rgba(255,255,255,0.06);
    }
    .ritual-modal-thumb {
      flex-shrink:0; width:52px; height:52px;
      background:rgba(0,0,0,0.35); border:1px solid rgba(255,255,255,0.08);
      border-radius:5px; display:flex; align-items:center; justify-content:center; overflow:hidden;
    }
    .ritual-modal-thumb img { width:44px; height:44px; object-fit:contain; filter:invert(0.9) sepia(0.1) saturate(0.6) brightness(0.92); }
    .ritual-modal-title-wrap { flex:1; min-width:0; }
    .ritual-modal-title { font-family:var(--font-display); font-size:1.05rem; font-weight:600; color:var(--cream); }
    .ritual-modal-intent { font-size:0.68rem; font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.08em; margin-top:0.15rem; }
    .ritual-modal-close {
      flex-shrink:0; width:28px; height:28px; border-radius:50%;
      border:1px solid rgba(255,255,255,0.1); background:transparent; color:var(--cream-muted);
      font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center;
      transition:all 0.2s; line-height:1;
    }
    .ritual-modal-close:hover { border-color:var(--cream); color:var(--cream); }
    .ritual-modal-body { padding:0; flex:1; min-height:0; overflow:hidden; display:flex; flex-direction:column; }
    /* ── Ars Paulina Hour modal — no tab system, body scrolls naturally ── */
    .ritual-modal--ap-hour { max-height:90vh; }
    .ritual-modal--ap-hour .ritual-modal-body { overflow-y:auto; display:block; padding:0; }
    .ritual-modal-section { margin-bottom:1.1rem; }
    .ritual-modal-section:last-child { margin-bottom:0; }
    .ritual-modal-section-label {
      font-family:var(--font-mono); font-size:0.58rem; text-transform:uppercase;
      letter-spacing:0.14em; color:var(--gold); opacity:0.7; margin-bottom:0.4rem;
    }
    .ritual-purpose { font-size:0.82rem; color:var(--cream-muted); line-height:1.65; font-weight:300; }
    .ritual-psalm { font-size:0.72rem; color:rgba(212,208,200,0.65); font-style:italic; font-weight:300; padding-top:0.35rem; border-top:1px solid rgba(255,255,255,0.05); margin-top:0.5rem; }
    .ritual-materials { display:flex; flex-direction:column; gap:0.25rem; padding:0.5rem 0.65rem; background:rgba(0,0,0,0.25); border:1px solid rgba(255,255,255,0.06); border-radius:4px; }
    .ritual-mat-row { display:flex; align-items:flex-start; gap:0.5rem; font-size:0.72rem; }
    .ritual-mat-label { flex-shrink:0; font-family:var(--font-mono); font-size:0.58rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--gold); opacity:0.7; padding-top:0.1rem; min-width:4.5rem; }
    .ritual-mat-val { color:var(--cream-muted); font-weight:300; }
    .ritual-divine { font-size:0.72rem; color:var(--gold); font-family:var(--font-mono); letter-spacing:0.04em; line-height:1.6; }
    /* Optimal conditions */
    .ritual-optimal-grid { display:flex; flex-wrap:wrap; gap:0.4rem; }
    .ritual-optimal-chip {
      font-size:0.65rem; font-family:var(--font-mono);
      padding:0.18rem 0.55rem; border-radius:1rem;
      background:rgba(122,158,126,0.1); border:1px solid rgba(122,158,126,0.35); color:#b8d4ba;
    }
    /* Modal action buttons */
    .ritual-find-btn {
      display:inline-flex; align-items:center; gap:0.4rem;
      padding:0.4rem 1rem; border-radius:2rem;
      border:1px solid var(--gold); color:var(--gold);
      background:transparent; font-size:0.75rem; font-weight:500;
      cursor:pointer; transition:all 0.25s; font-family:var(--font-body);
    }
    .ritual-find-btn:hover { background:var(--gold); color:var(--ink); }
    .ritual-find-btn:disabled { opacity:0.4; cursor:not-allowed; }
    .ritual-btn-row { display:flex; gap:0.5rem; flex-wrap:wrap; margin-bottom:0.75rem; }
    .ritual-instr-btn { border-color:rgba(122,158,126,0.6); color:var(--sage); }
    .ritual-instr-btn:hover { background:var(--sage); color:var(--ink); border-color:var(--sage); }
    .ritual-windows-wrap { margin-top:0; }
    .ritual-window-card { padding:0.6rem 0.75rem; margin-bottom:0.4rem; background:rgba(0,0,0,0.2); border:1px solid rgba(255,255,255,0.06); border-radius:4px; border-left:3px solid transparent; }
    /* ── Ars Paulina hour modal ───────────────────────────── */
    .aph-meta-row { display:flex; align-items:center; gap:0.6rem; padding:0.6rem 1.25rem 0.5rem; border-bottom:1px solid rgba(255,255,255,0.05); }
    .aph-meta-chip { font-family:var(--font-mono); font-size:0.6rem; text-transform:uppercase; letter-spacing:0.08em; color:rgba(180,160,220,1); background:rgba(180,160,220,0.1); border:1px solid rgba(180,160,220,0.3); padding:0.2rem 0.5rem; border-radius:2rem; white-space:nowrap; }
    .aph-meta-note { font-size:0.75rem; color:rgba(212,208,200,0.65); font-style:italic; }
    .aph-dukes-details { padding:0.5rem 1.25rem; border-bottom:1px solid rgba(255,255,255,0.05); }
    .aph-dukes-summary { font-size:0.72rem; color:rgba(212,208,200,0.65); cursor:pointer; list-style:none; user-select:none; }
    .aph-dukes-summary::-webkit-details-marker { display:none; }
    .aph-dukes-summary::before { content:'▸ '; }
    details[open] .aph-dukes-summary::before { content:'▾ '; }
    .aph-dukes-text { font-family:var(--font-mono); font-size:0.68rem; color:rgba(201,168,76,0.85); line-height:1.7; margin-top:0.4rem; }
    .aph-loading { padding:1rem 1.25rem; color:rgba(212,208,200,0.6); font-size:0.78rem; font-style:italic; }
    .aph-summon-block { padding:0.85rem 1.25rem 0.75rem; border-bottom:1px solid rgba(255,255,255,0.06); }
    .aph-summon-label { font-family:var(--font-mono); font-size:0.55rem; text-transform:uppercase; letter-spacing:0.14em; color:rgba(180,160,220,0.6); margin-bottom:0.3rem; }
    .aph-summon-angel { font-family:var(--font-display); font-size:1rem; font-weight:600; color:var(--cream); margin-bottom:0.2rem; }
    .aph-summon-intro { font-size:0.8rem; color:var(--cream-muted); line-height:1.6; font-weight:300; margin-bottom:0.55rem; }
    .aph-summon-quote { font-size:0.75rem; color:rgba(212,208,200,0.72); font-style:italic; line-height:1.65; padding:0.5rem 0.75rem; border-left:2px solid rgba(180,160,220,0.3); background:rgba(180,160,220,0.04); border-radius:0 3px 3px 0; margin-bottom:0.35rem; }
    .aph-summon-quote-src { font-size:0.6rem; font-family:var(--font-mono); color:rgba(212,208,200,0.35); font-style:normal; margin-top:0.25rem; }
    .aph-windows-container { padding:0.5rem 1rem; }
    .aph-window { padding:0.75rem; margin-bottom:0.5rem; background:rgba(0,0,0,0.18); border:1px solid rgba(255,255,255,0.06); border-radius:4px; }
    .aph-window:last-child { margin-bottom:0; }
    .aph-win-header { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:0.4rem; }
    .aph-win-date { font-size:0.85rem; font-weight:500; color:var(--cream); }
    .aph-win-time { font-size:0.72rem; color:rgba(212,208,200,0.65); margin-top:0.1rem; }
    .aph-win-planet { font-family:var(--font-mono); font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:0.06em; }
    .aph-win-ops { font-size:0.8rem; color:var(--cream); line-height:1.55; margin-bottom:0.5rem; }
    .aph-win-details { display:flex; flex-direction:column; gap:0.25rem; margin-bottom:0.5rem; padding:0.45rem 0.6rem; background:rgba(255,255,255,0.02); border-radius:3px; border:1px solid rgba(255,255,255,0.05); }
    .aph-win-detail-row { display:flex; gap:0.6rem; align-items:baseline; }
    .aph-win-detail-key { font-size:0.65rem; color:rgba(212,208,200,0.6); white-space:nowrap; min-width:3.5rem; }
    .aph-win-detail-val { font-size:0.75rem; color:var(--cream-muted); line-height:1.4; }
    .aph-instr-toggle { background:none; border:none; padding:0; font-size:0.72rem; color:rgba(212,208,200,0.6); cursor:pointer; text-decoration:underline; text-underline-offset:3px; }
    .aph-instr-toggle:hover { color:var(--gold); }
    .aph-instr-panel { margin-top:0.6rem; padding:0.75rem; background:rgba(0,0,0,0.2); border:1px solid rgba(255,255,255,0.06); border-radius:3px; }
    .aph-instr-footer { padding:0.75rem 1.25rem 1rem; border-top:1px solid rgba(255,255,255,0.05); }
    .ap-hour-card { border-left-color:rgba(180,160,220,0.4); padding:0.75rem; }
    .ap-hour-date-row { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:0.5rem; }
    .ap-hour-ops-row { margin-bottom:0.4rem; }
    .ap-hour-planet { font-family:var(--font-mono); font-size:0.65rem; text-transform:uppercase; letter-spacing:0.1em; font-weight:600; margin-bottom:0.15rem; }
    .ap-hour-ops { font-size:0.78rem; color:var(--cream); line-height:1.5; }
    .ap-hour-element-row { margin:0.35rem 0; padding:0.3rem 0.5rem; background:rgba(255,255,255,0.03); border-radius:3px; }
    .ap-hour-element-label { font-family:var(--font-mono); font-size:0.58rem; text-transform:uppercase; letter-spacing:0.08em; color:rgba(212,208,200,0.45); margin-bottom:0.1rem; }
    .ap-hour-element-text { font-size:0.72rem; color:var(--cream-muted); font-style:italic; }
    .ap-hour-asc-row { display:flex; align-items:baseline; flex-wrap:wrap; gap:0.25rem; margin:0.3rem 0; padding-top:0.3rem; border-top:1px solid rgba(255,255,255,0.04); }
    .ap-hour-perfume-row { display:flex; align-items:baseline; gap:0.4rem; margin-top:0.25rem; }
    .ap-hour-instr-row { margin-top:0.6rem; padding-top:0.5rem; border-top:1px solid rgba(255,255,255,0.05); }
    .ap-hour-instr-btn {
        background:none; border:1px solid rgba(255,255,255,0.12); color:var(--cream-muted);
        font-family:var(--font-mono); font-size:0.62rem; text-transform:uppercase;
        letter-spacing:0.08em; padding:0.3rem 0.65rem; border-radius:3px; cursor:pointer;
        transition:border-color 0.15s, color 0.15s;
    }
    .ap-hour-instr-btn:hover { border-color:rgba(201,168,76,0.4); color:var(--gold); }
    .ap-hour-instr-panel {
        margin-top:0.6rem; padding:0.75rem; background:rgba(0,0,0,0.25);
        border:1px solid rgba(255,255,255,0.06); border-radius:4px;
    }
    .ap-win-instr-section { margin-bottom:0.75rem; }
    .ap-win-instr-label {
        font-family:var(--font-mono); font-size:0.58rem; text-transform:uppercase;
        letter-spacing:0.12em; color:var(--gold); opacity:0.8; margin-bottom:0.4rem;
    }
    .ap-win-instr-note { font-size:0.73rem; color:var(--cream-muted); margin-bottom:0.5rem; }
    .ap-win-seal-steps {
        margin:0 0 0.5rem 1.1rem; padding:0;
        font-size:0.77rem; color:var(--cream); line-height:1.7;
    }
    .ap-win-seal-steps li { margin-bottom:0.1rem; }
    .ap-win-instr-source {
        font-size:0.62rem; font-family:var(--font-mono); font-style:italic;
        color:rgba(212,208,200,0.35); margin-top:0.3rem;
    }
    .ritual-window-card.q-optimal    { border-left-color:var(--gold); }
    .ritual-window-card.q-good       { border-left-color:#7a9e7e; }
    .ritual-window-card.q-acceptable { border-left-color:rgba(196,191,181,0.5); }
    .ritual-window-card.q-basic      { border-left-color:rgba(196,191,181,0.2); }
    .ritual-window-head { display:flex; align-items:center; justify-content:space-between; gap:0.5rem; flex-wrap:wrap; }
    .ritual-window-date { font-size:0.82rem; font-weight:500; color:var(--cream); }
    .ritual-window-time { font-size:0.75rem; color:var(--cream-muted); font-family:var(--font-mono); }
    .ritual-window-quality { flex-shrink:0; font-size:0.65rem; font-family:var(--font-mono); padding:0.12rem 0.45rem; border-radius:1rem; border:1px solid rgba(255,255,255,0.18); color:var(--cream); }
    .ritual-window-quality.q-optimal { border-color:var(--gold); color:var(--gold); background:var(--gold-soft); }
    .ritual-window-quality.q-good    { border-color:#7a9e7e; color:#b8d4ba; background:rgba(122,158,126,0.18); }
    .ritual-window-quality.q-acceptable { border-color:rgba(196,191,181,0.5); color:var(--cream); background:rgba(255,255,255,0.06); }
    .ritual-window-quality.q-basic   { border-color:rgba(196,191,181,0.3); color:var(--cream-muted); background:transparent; }
    .ritual-window-meta { display:flex; flex-wrap:wrap; gap:0.35rem; margin-top:0.35rem; }
    .ritual-window-chip { font-size:0.65rem; font-family:var(--font-mono); padding:0.1rem 0.4rem; border-radius:1rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.14); color:var(--cream); }
    .ritual-window-chip.warn { border-color:rgba(231,130,80,0.4); color:rgba(231,130,80,0.9); background:rgba(231,130,80,0.06); }
    .ritual-windows-none { font-size:0.78rem; color:var(--cream-muted); padding:0.5rem 0; font-style:italic; }
    .ritual-instructions { margin:0; }
    .instr-section { margin-bottom:0.75rem; }
    .instr-section:last-child { margin-bottom:0; }
    .instr-section-label { font-family:var(--font-mono); font-size:0.58rem; text-transform:uppercase; letter-spacing:0.14em; color:var(--gold); opacity:0.7; margin-bottom:0.35rem; }
    .instr-entry { margin-bottom:0.5rem; padding-left:0.65rem; border-left:2px solid rgba(201,168,76,0.15); }
    .instr-entry:last-child { margin-bottom:0; }
    .instr-entry-title { font-size:0.75rem; font-weight:500; color:var(--cream); margin-bottom:0.15rem; }
    .instr-entry-text { font-size:0.77rem; color:var(--cream-muted); line-height:1.65; font-weight:300; }
    .instr-quote { font-size:0.68rem; color:rgba(212,208,200,0.68); font-style:italic; margin-top:0.3rem; padding-top:0.3rem; border-top:1px solid rgba(255,255,255,0.04); }
    .instr-chapter { font-style:normal; font-family:var(--font-mono); font-size:0.6rem; color:rgba(212,208,200,0.5); margin-left:0.4rem; }
    .instr-chapter-only { font-family:var(--font-mono); font-size:0.6rem; color:rgba(212,208,200,0.5); margin-top:0.2rem; }

    /* ── MODAL TAB SYSTEM ── */
    /* Tabs sit flush against the modal body top edge, replacing the expand-in-place button row */
    .modal-tab-nav { display:flex; gap:0; border-bottom:1px solid rgba(255,255,255,0.08); flex-shrink:0; padding:0 1rem; background:rgba(0,0,0,0.15); }
    .modal-tab-btn { font-family:var(--font-mono); font-size:0.59rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--cream-muted); background:none; border:none; border-bottom:2px solid transparent; padding:0.6rem 0.9rem 0.55rem; cursor:pointer; transition:color 0.15s, border-color 0.15s; white-space:nowrap; }
    .modal-tab-btn:hover { color:var(--cream); }
    .modal-tab-btn.mtab-active { color:var(--gold); border-bottom-color:var(--gold); }
    .modal-tab-pane { display:none; }
    .modal-tab-pane.mtab-active { display:block; flex:1; min-height:0; overflow-y:auto; padding:1.25rem; }
    .modal-tab-loading { color:var(--cream-muted); font-size:0.78rem; padding:0.5rem 0; font-style:italic; }

    /* ── HOUSE SYSTEM ── */
    .house-wheel { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.35rem; }
    .house-cell {
      background:
        linear-gradient(135deg, var(--house-tint-start, rgba(255,255,255,0.04)), var(--house-tint-end, rgba(255,255,255,0.02))),
        var(--ink-up);
      border: 1px solid rgba(255,255,255,0.06);
      border-radius: var(--radius-sm); padding: 0.5rem 0.55rem;
      border-left: 2px solid rgba(255,255,255,0.08); min-height: 62px;
      transition: border-color 0.2s;
      display: flex; flex-direction: column;
    }
    .house-cell:hover { border-left-color: var(--gold-border); }
    .house-cell.has-planets { border-left-color: rgba(122,100,180,0.5); }
    .house-cell.angular { border-left-color: var(--gold-border); }
    .house-header-block {
      display: grid; grid-template-columns: auto minmax(0, 1fr); column-gap: 0.35rem; align-items: stretch;
      margin-bottom: 0.32rem; padding: 0.12rem 0.16rem 0.14rem;
      border-radius: 0.46rem; background: rgba(255,255,255,0.04);
      border: 1px solid rgba(255,255,255,0.055);
    }
    .house-num-rail {
      min-width: 1.45rem; display: flex; align-items: stretch; justify-content: center;
      padding-right: 0.02rem; border-right: 1px solid rgba(255,255,255,0.07);
    }
    .house-num {
      font-family: var(--font-body); font-size: 0.68rem; font-weight: 500; color: rgba(201,168,76,0.88);
      text-transform: uppercase; letter-spacing: 0.02em; line-height: 1;
      display: flex; align-items: center; justify-content: center; min-height: 100%;
      text-align: center;
    }
    .house-header-copy { min-width: 0; display: flex; flex-direction: column; align-items: flex-start; }
    .house-header-panel {
      width: 100%; padding: 0.08rem 0.08rem 0.04rem;
      border-radius: 0; background: transparent;
      border: 0;
    }
    .house-header-line { display: flex; align-items: center; justify-content: flex-start; gap: 0.55rem; flex-wrap: wrap; }
    .house-cusp { font-family: var(--font-mono); font-size: 0.7rem; color: var(--cream-muted); margin-top: 0.1rem; }
    .house-meaning { font-size: 0.6rem; color: rgba(196,191,181,0.8); margin-top: 0.12rem; line-height: 1.3; }
    .house-planets-list {
      margin-top: 0.24rem; display: grid; gap: 0.22rem; align-items: stretch;
      flex: 1 1 auto; min-height: 3rem;
    }
    .house-planet-column {
      min-width: 0; display: flex; flex-direction: column; gap: 0.18rem;
      padding: 0.22rem 0.18rem; border-radius: 0.42rem;
      border: 1px solid rgba(255,255,255,0.035); background: rgba(255,255,255,0.02);
      height: 100%; min-height: 100%;
    }
    .house-planet-column-start { align-items: flex-start; }
    .house-planet-column-middle { align-items: center; }
    .house-planet-column-end { align-items: flex-end; }
    .house-planets-list-compact .house-planet-column {
      flex-direction: row; flex-wrap: wrap; align-content: flex-start;
    }
    .house-planets-list-compact .house-planet-column-start { justify-content: flex-start; }
    .house-planets-list-compact .house-planet-column-middle { justify-content: center; }
    .house-planets-list-compact .house-planet-column-end { justify-content: flex-end; }
    .house-planet-column-fire { background: rgba(224,112,96,0.13); border-color: rgba(224,112,96,0.28); }
    .house-planet-column-earth { background: rgba(122,158,126,0.13); border-color: rgba(122,158,126,0.28); }
    .house-planet-column-air { background: rgba(122,154,184,0.13); border-color: rgba(122,154,184,0.28); }
    .house-planet-column-water { background: rgba(155,122,184,0.13); border-color: rgba(155,122,184,0.28); }
    .house-planet-chip {
      display: inline-flex; align-items: center; gap: 0.2rem;
      background: rgba(201,168,76,0.08); border: 1px solid rgba(201,168,76,0.15);
      color: var(--gold-light); padding: 0.12rem 0.4rem;
      border-radius: 1rem; font-size: 0.68rem; font-weight: 400; font-family: var(--font-display);
      max-width: 100%;
      white-space: nowrap;
    }
    .house-planet-chip-fire { border-color: rgba(224,112,96,0.65); background: rgba(224,112,96,0.13); color: #f0c0b8; }
    .house-planet-chip-earth { border-color: rgba(122,158,126,0.65); background: rgba(122,158,126,0.13); color: #c6dbc8; }
    .house-planet-chip-air { border-color: rgba(122,154,184,0.65); background: rgba(122,154,184,0.13); color: #cad8e7; }
    .house-planet-chip-water { border-color: rgba(155,122,184,0.65); background: rgba(155,122,184,0.13); color: #dcc7ef; }
    .house-angles-row {
      display: flex; justify-content: center; gap: 0.75rem; flex-wrap: wrap;
      margin-top: 0.75rem; margin-bottom: 0.85rem; padding-bottom: 0.75rem; border-bottom: 1px solid rgba(255,255,255,0.05);
    }
    .house-angle-badge {
      display: inline-flex; align-items: center; gap: 0.35rem;
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      padding: 0.28rem 0.75rem; border-radius: 2rem; font-size: 0.74rem;
    }
    .house-angle-label { color: var(--gold); font-weight: 500; }
    .house-angle-value { color: var(--cream-muted); font-family: var(--font-mono); font-weight: 400; font-size: 0.7rem; }
    .house-system-badge {
      display: inline-block; font-family: var(--font-mono); font-size: 0.58rem;
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      color: var(--gold); padding: 0.1rem 0.45rem; border-radius: 0.25rem;
      text-transform: uppercase; letter-spacing: 0.06em; vertical-align: middle; margin-left: 0.5rem;
    }
    .house-angle-inline {
      display: inline-block; font-family: var(--font-mono); font-size: 0.53rem;
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      color: var(--gold); padding: 0.05rem 0.3rem; border-radius: 0.2rem;
      margin-left: 0.3rem; vertical-align: middle; letter-spacing: 0.04em;
    }
    .house-table td { font-size: 0.8rem; vertical-align: middle; color: var(--cream-muted); }
    .house-table th { font-size: 0.75rem; }
    .house-badge {
      display: inline-block; font-family: var(--font-mono); font-size: 0.58rem; font-weight: 500;
      padding: 0.1rem 0.3rem; border-radius: 0.2rem; text-align: center;
      min-width: 1.4rem; letter-spacing: 0.04em; vertical-align: middle;
    }
    .house-badge.current { background: var(--gold-soft); color: var(--gold); border: 1px solid var(--gold-border); }
    .house-badge.natal   { background: rgba(122,100,180,0.1); color: #b09ad4; border: 1px solid rgba(122,100,180,0.2); }
    .transit-aspect-tbl .col-house-cell {
      text-align: center; padding: 0.25rem 0.32rem 0.25rem 0.12rem; white-space: nowrap; width: 2.3rem;
    }
    .transit-aspect-tbl .col-house-hdr {
      text-align: center; font-size: 0.6rem; padding: 0.25rem 0.32rem 0.25rem 0.12rem; white-space: nowrap; width: 2.3rem;
    }
    .transit-aspect-tbl { width: 100%; }
    .transit-aspect-tbl .col-pair {
      white-space: nowrap;
      width: 1%;
      padding-right: 0.18rem;
    }
    .transit-aspect-tbl .col-type {
      white-space: normal;
      width: 99%;
      text-align: center;
    }
    .transit-aspect-tbl .col-orb  { white-space: nowrap; text-align: center; }
    .transit-aspect-tbl .col-dir  { white-space: nowrap; text-align: right; }
    .transit-aspect-tbl td,
    .transit-aspect-tbl th { padding-left: 0.5rem; padding-right: 0.5rem; }

    /* ── RESPONSIVE ── */
    @media (max-width: 991px) {
      /* Force horoscope data cards full width below desktop */
      .col-12.col-lg-6 { width: 100% !important; flex: 0 0 100% !important; max-width: 100% !important; }
    }
    @media (max-width: 767px) {
      .profile-header h1 { font-size: 1.4rem; }
      .main-content { padding: 0.85rem; padding-bottom: 5rem; }
      .card-header { padding: 0.8rem 1rem; font-size: 0.88rem; }
      .card-body { padding: 1rem; }
      /* Card spacing on mobile */
      .card { margin-bottom: 0.75rem; }
      .row.g-3 { gap: 0.75rem 0; }
      .row.g-2 { gap: 0.5rem 0; }
      /* Spacing between horoscope text and ranking footer */
      .horoscope-reading { padding-bottom: 0.5rem; }
      .horoscope-transit-hero {
        grid-template-columns: 1fr;
        padding: 0.85rem;
      }
      .horoscope-transit-hero-art img {
        min-height: 160px;
        max-height: 180px;
      }
      .horoscope-transit-hero-art-badge {
        width: 62px;
        height: 62px;
      }
      .horoscope-transit-hero-head {
        flex-direction: column;
        align-items: flex-start;
      }
      .horoscope-transit-hero-topline {
        grid-template-columns: 1fr;
      }
      .horoscope-transit-hero-score {
        align-items: flex-start;
        min-width: 0;
      }
      .horoscope-transit-hero-title { font-size: 1.08rem; }
      .horoscope-transit-hero-body { font-size: 0.85rem; }
      /* Transit cards on mobile */
      .transit-card-header { padding: 0.5rem 0.7rem; gap: 8px; }
      .transit-card-body { padding: 0.6rem 0.7rem; font-size: 0.84rem; }
      .tc-takeaway { padding: 0.5rem 0.7rem; font-size: 0.82rem; }
      .transit-card-header .tc-planets { font-size: 0.82rem; }
    }
    @media (max-width: 767px) { .house-wheel { grid-template-columns: repeat(3, 1fr); } }
    @media (max-width: 575px) {
      .house-wheel { grid-template-columns: repeat(2, 1fr); }
      .zodiac-card-expanded .zodiac-name-row { padding: 0.4rem 0.5rem; }
      .zodiac-card-expanded .zodiac-sign-img { height: 52px; width: 52px; }
      .zodiac-card-expanded .zodiac-header { padding: 0.4rem 0.5rem; }
      .zodiac-card-expanded .zodiac-header-label { font-size: 0.65rem; }
      .zodiac-card-expanded .zodiac-attributes { padding: 0 0.3rem 0.4rem; gap: 0.2rem; }
      .zodiac-card-expanded .zodiac-attr-label { font-size: 0.5rem; }
      .zodiac-card-expanded .zodiac-attr-value { font-size: 0.65rem; }
      .zodiac-card-expanded .zodiac-meaning { padding: 0.5rem; font-size: 0.72rem; }
    }
    .celestial-row { flex-wrap: nowrap !important; }
    .celestial-row > .col-md-4 { flex: 1 1 0 !important; min-width: 0; max-width: 100%; padding: 0 0.2rem; }
    .celestial-row .current-box { padding: 0.4rem 0.35rem; }
    .celestial-row .planet-symbol { font-size: 1.4rem; }
    .celestial-row .current-box-footer,
    .celestial-row .current-box-time { font-size: 0.68rem; }
    .celestial-row .position-badge { font-size: 0.7rem; padding: 0.2rem 0.45rem; min-width: 0; }
    .celestial-row small { font-size: 0.65rem; }

    /* Natal drop cap smaller on mobile */
    @media (max-width: 600px) {
      .natal-reading-section:first-child .natal-section-body p:first-of-type::first-letter {
        font-size: 2.5em;
      }
    }

    /* Angels 2x2 on mobile */
    @media (max-width: 767px) {
      .angels-row > .col-md-3 { flex: 0 0 50% !important; max-width: 50%; width: 50%; }
    }

    /* ── Bootstrap grid shim (only what we need) ── */
    .container-fluid,.container{width:100%}
    .row{display:flex;flex-wrap:wrap;margin-right:-0.5rem;margin-left:-0.5rem}
    .row.g-2{margin-right:-0.25rem;margin-left:-0.25rem}
    .row.g-2>[class^="col"]{padding-right:0.25rem;padding-left:0.25rem}
    .row.g-3{margin-right:-0.375rem;margin-left:-0.375rem}
    .row.g-3>[class^="col"]{padding-right:0.375rem;padding-left:0.375rem}
    .mt-1{margin-top:0.25rem}.mt-2{margin-top:0.5rem}.mt-3{margin-top:0.75rem}.mt-4{margin-top:1rem}.me-1{margin-right:0.25rem}.me-2{margin-right:0.5rem}.me-3{margin-right:0.75rem}.me-4{margin-right:1rem}
    .mb-0{margin-bottom:0!important}.mb-3{margin-bottom:0.75rem}.mb-3{margin-bottom:1rem}
    .p-0{padding:0!important}
    .col-1{flex:0 0 auto;width:8.333%}
    .col-2{flex:0 0 auto;width:16.667%}
    .col-3{flex:0 0 auto;width:25%}
    .col-4{flex:0 0 auto;width:33.333%}
    .col-5{flex:0 0 auto;width:41.667%}
    .col-6{flex:0 0 auto;width:50%}
    .col-7{flex:0 0 auto;width:58.333%}
    .col-8{flex:0 0 auto;width:66.667%}
    .col-9{flex:0 0 auto;width:75%}
    .col-10{flex:0 0 auto;width:83.333%}
    .col-11{flex:0 0 auto;width:91.667%}
    .col-12{flex:0 0 auto;width:100%}
    [class^="col"]{padding-right:0.5rem;padding-left:0.5rem;width:100%;flex:0 0 auto}
    @media(min-width:576px){.col-sm-6{flex:0 0 auto;width:50%}}
    @media(min-width:768px){
      .col-md-3{flex:0 0 auto;width:25%}
      .col-md-4{flex:0 0 auto;width:33.333%}
      .col-md-6{flex:0 0 auto;width:50%}
      .col-md-8{flex:0 0 auto;width:66.667%}
      .col-md-12{flex:0 0 auto;width:100%}
      .d-none.d-md-table-cell{display:table-cell!important}
      .d-md-table-cell{display:table-cell!important}
      .planet-grid { grid-template-columns: repeat(5, 1fr); }
    }
    @media (min-width: 576px) and (max-width: 767px) {
      .planet-grid { grid-template-columns: repeat(3, 1fr); }
    }
    @media(min-width:992px){
      .col-lg-6{flex:0 0 auto;width:50%}
      .col-lg-12{flex:0 0 auto;width:100%}
      .d-none.d-lg-table-cell{display:table-cell!important}
    }
    .d-none{display:none!important}
    .h-100{height:100%}
    .text-muted{color:var(--cream-muted)!important}
    .text-center{text-align:center}
    .float-end{float:right}
    .btn-close{background:none;border:none;cursor:pointer;color:var(--cream-muted);font-size:0.85rem;padding:0.1rem 0.3rem}
    .btn-close:hover{color:var(--cream)}
    .spinner-border{display:inline-block;width:1.1rem;height:1.1rem;border:2px solid rgba(255,255,255,0.2);border-top-color:var(--cream);border-radius:50%;animation:spin 0.7s linear infinite;vertical-align:middle;margin-right:0.4rem}
    .spinner-border.d-none{display:none!important}
    .btn{display:inline-flex;align-items:center;justify-content:center;padding:0.4rem 0.9rem;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-body);font-size:0.82rem;font-weight:500;border:1px solid transparent;transition:all 0.2s}
    .btn-sm{padding:0.3rem 0.7rem;font-size:0.78rem}
    .alert{border-radius:var(--radius-sm);padding:0.7rem 1rem;font-size:0.83rem;margin-bottom:0.75rem}
    .alert-info{background:rgba(122,158,126,0.1);border:1px solid rgba(122,158,126,0.2);color:#9dcba1}
    .accordion{width:100%}

    /* ── Planetary Hours Spinner ── */
    .ph-spinner { position: relative; }
    .ph-spinner-track { overflow: hidden; }
    .ph-spinner-list { transition: transform 0.25s ease; }
    .ph-spinner-nav {
        display: flex; justify-content: center; gap: 0.5rem;
        padding: 0.3rem 0; border-top: 1px solid rgba(255,255,255,0.05);
    }
    .ph-spinner-btn {
        background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
        color: var(--cream-muted); border-radius: var(--radius-sm);
        padding: 0.2rem 0.6rem; font-size: 0; cursor: pointer;
        font-family: var(--font-mono); transition: all 0.15s;
    }
    .ph-spinner-btn::before { font-size: 0.7rem; }
    .ph-spinner-btn.ph-up-btn::before { content: '\25B2'; }
    .ph-spinner-btn.ph-down-btn::before { content: '\25BC'; }
    .ph-spinner-btn:hover { background: rgba(255,255,255,0.08); color: var(--cream); }
    .ph-spinner-btn:disabled { opacity: 0.3; cursor: default; }
    .ph-spinner-btn:disabled:hover { background: rgba(255,255,255,0.04); color: var(--cream-muted); }
    .ph-divider {
        text-align: center; font-size: 0.6rem; font-family: var(--font-mono);
        color: var(--cream-muted); opacity: 0.5; padding: 0.15rem 0;
        text-transform: uppercase; letter-spacing: 0.15em;
        border-top: 1px solid rgba(255,255,255,0.06);
    }
    .planetary-hour-row.current {
        background:
          linear-gradient(90deg, rgba(201,168,76,0.34), rgba(201,168,76,0.12)),
          rgba(255,255,255,0.03);
        border-left: 3px solid var(--gold);
        border-right: 1px solid rgba(201,168,76,0.28);
        box-shadow:
          inset 0 0 0 1px rgba(201,168,76,0.18),
          0 0 18px rgba(201,168,76,0.14);
        font-weight: 600; color: var(--cream);
        position: relative;
        transform: scale(1.015);
    }
    .planetary-hour-row.current::before {
        content: '▶'; position: absolute; left: 0.2rem; font-size: 0.5rem;
        color: var(--gold-light); top: 50%; transform: translateY(-50%);
        text-shadow: 0 0 10px rgba(201,168,76,0.45);
    }
    .planetary-hour-row.current .planetary-hour-planet {
        padding-left: 0.45rem;
        color: var(--gold-light);
    }
    .planetary-hour-row.current .planetary-hour-time { color: var(--cream); }

    /* ── Angel mobile tab switcher ── */
    .angels-desktop { display: none; }
    .angels-mobile  { display: block; }
    @media(min-width: 768px) {
      .angels-desktop { display: block; }
      .angels-mobile  { display: none; }
    }
    .angel-mob-tab-bar {
      display: flex; gap: 0.35rem; flex-wrap: wrap;
      margin-bottom: 0.85rem;
    }
    .angel-mob-tab {
      flex: 1; min-width: 0;
      background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07);
      color: rgba(196,191,181,0.75); border-radius: 2rem;
      padding: 0.35rem 0.5rem; font-size: 0.72rem; font-family: var(--font-body);
      cursor: pointer; transition: all 0.2s; text-align: center; white-space: nowrap;
    }
    .angel-mob-tab.active {
      background: rgba(201,168,76,0.15); color: var(--gold-light);
      border-color: rgba(201,168,76,0.5); font-weight: 500;
    }
    .angel-mob-pane { display: none; }
    .angel-mob-pane.active { display: block; }

    /* ── Natal angel mobile tab switcher ── */
    .natal-angels-desktop { display: none; }
    .natal-angels-mobile  { display: block; }
    @media(min-width: 768px) {
      .natal-angels-desktop { display: block; }
      .natal-angels-mobile  { display: none; }
    }

    /* ── NATAL TAB CARD FLOW ── */
    #tab-natal > .card { margin-bottom: 1.5rem; }
    #tab-natal > .card:last-child { margin-bottom: 0; }

/* ── BIG THREE HERO ── */
.big-three-shell {
  display: block;
}
.big-three-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  padding: 1.15rem 1rem;
}
.big-three-col {
  position: relative;
  min-height: 0;
  overflow: visible;
  border-radius: 0.9rem;
  border: 1px solid rgba(255,255,255,0.06);
  background: linear-gradient(180deg, rgba(16,16,24,0.52), rgba(10,10,18,0.42));
  padding: 0.8rem 0.85rem 0.9rem;
}
.big-three-col:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 14%;
  height: 72%;
  width: 1px;
  background: rgba(201,168,76,0.16);
}
.big-three-backdrop,
.big-three-sheen {
  display: none;
}
.big-three-content {
  display: block;
  text-align: left;
  padding: 0;
  z-index: auto;
  overflow: visible;
}
.big-three-card-visual {
  float: right;
  width: 145px;
  margin: 0 0 0.55rem 0.8rem;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.big-three-emblem {
  position: relative;
  width: 100%;
  max-width: 180px;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.big-three-emblem::before {
  content: '';
  position: absolute;
  inset: 13%;
  border-radius: 50%;
  border: 1px solid rgba(214,182,95,0.48);
  box-shadow: inset 0 0 0 1px rgba(255,239,188,0.08);
  pointer-events: none;
  z-index: 1;
}
.big-three-emblem::after {
  content: '';
  position: absolute;
  inset: 18%;
  border-radius: 50%;
  background: rgba(201,168,76,0.12);
  filter: blur(18px);
  pointer-events: none;
  z-index: 0;
}
.big-three-label {
  font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase;
  letter-spacing: 0.14em; color: rgba(255,255,255,0.62); margin-bottom: 0.24rem;
}
.big-three-icon {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  margin-bottom: 0;
  padding: 0;
  border-radius: 0;
  background: none;
  border: 0;
  filter: drop-shadow(0 0 20px rgba(230,196,104,0.16));
  opacity: 0.9;
}
.big-three-element-frame {
  position: absolute;
  inset: -4%;
  width: 108%;
  height: 108%;
  object-fit: contain;
  object-position: center;
  pointer-events: none;
  z-index: 1;
  opacity: 0.96;
  filter: drop-shadow(0 0 14px rgba(0,0,0,0.22));
}
.big-three-element-fire .big-three-emblem::after {
  background: radial-gradient(circle, rgba(245,138,54,0.34), rgba(245,138,54,0.12) 52%, transparent 74%);
}
.big-three-element-fire .big-three-backdrop img {
  box-shadow:
    0 0 0 1px rgba(233,192,112,0.54),
    0 0 0 3px rgba(10,10,18,0.96),
    0 0 18px rgba(245,138,54,0.18),
    0 12px 26px rgba(0,0,0,0.18);
}
.big-three-element-earth .big-three-emblem::after {
  background: radial-gradient(circle, rgba(118,162,96,0.28), rgba(118,162,96,0.1) 52%, transparent 74%);
}
.big-three-element-air .big-three-emblem::after {
  background: radial-gradient(circle, rgba(136,176,236,0.28), rgba(136,176,236,0.1) 52%, transparent 74%);
}
.big-three-element-water .big-three-emblem::after {
  background: radial-gradient(circle, rgba(113,154,224,0.32), rgba(113,154,224,0.12) 52%, transparent 74%);
}
.big-three-emblem-copy {
  position: relative;
  z-index: 2;
  width: 72%;
  padding: 1rem 0.9rem;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(8,10,16,0.78), rgba(8,10,16,0.42) 60%, transparent 78%);
  border: 1px solid rgba(214,182,95,0.22);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.03), 0 8px 18px rgba(0,0,0,0.18);
  text-align: center;
}
.big-three-element-fire .big-three-emblem-copy {
  background:
    radial-gradient(circle, rgba(10,10,16,0.84), rgba(10,10,16,0.5) 60%, transparent 78%);
}
.big-three-sign {
  font-family: var(--font-display); font-size: 1.15rem; font-weight: 500;
  color: #f0d78f; margin-bottom: 0.15rem;
}
.big-three-degree {
  font-family: var(--font-mono); font-size: 0.72rem;
  color: rgba(255,255,255,0.65); letter-spacing: 0.04em;
}
.big-three-house {
  font-family: var(--font-body);
  font-size: 0.68rem;
  color: rgba(240,236,226,0.74);
  margin-top: 0.22rem;
}
.big-three-card-synthesis {
  width: 100%;
  max-width: none;
  padding: 0.1rem 0 0;
  border-radius: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}
.big-three-card-synthesis-title {
  font-family: var(--font-display);
  font-size: 0.9rem;
  line-height: 1.2;
  color: var(--gold-light);
  margin-bottom: 0.28rem;
}
.big-three-card-synthesis p {
  margin: 0;
  color: rgba(232,224,208,0.82);
  font-size: 0.76rem;
  line-height: 1.55;
  text-wrap: pretty;
}
.big-three-card-synthesis p + p {
  margin-top: 0.4rem;
}
.big-three-content::after {
  content: '';
  display: block;
  clear: both;
}
@media (max-width: 860px) {
  .big-three-grid {
    padding: 1rem 0.75rem;
  }
  .big-three-col {
    min-height: 0;
  }
  .big-three-card-visual {
    float: none;
    width: 138px;
    margin: 0 0 0.8rem 0;
  }
  .big-three-col:not(:last-child)::after {
    top: auto;
    right: 10%;
    bottom: 0;
    width: 80%;
    height: 1px;
  }
  .big-three-emblem { max-width: 168px; }
  .big-three-element-frame { inset: -3%; width: 106%; height: 106%; }
  .big-three-emblem-copy { width: 74%; padding: 0.8rem 0.7rem; }
  .big-three-card-synthesis { max-width: none; }
  .big-three-sign { font-size: 0.95rem; }
  .big-three-degree { font-size: 0.65rem; }
  .big-three-label { font-size: 0.55rem; }
}

    /* ── BIG THREE HERO (tab-natal) ── */
    .big-three-hero {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 0; padding: 1.25rem;
    }
    .bth-item {
      display: flex; flex-direction: column; align-items: center;
      text-align: center; padding: 0.5rem 0.25rem;
      position: relative;
    }
    .bth-item:not(:last-child)::after {
      content: ''; position: absolute; right: 0; top: 15%; height: 70%;
      width: 1px; background: rgba(201,168,76,0.13);
    }
    .bth-glyph {
      font-size: 1.75rem; color: var(--gold); margin-bottom: 0.35rem;
      line-height: 1;
    }
    .bth-label {
      font-family: var(--font-mono); font-size: 0.62rem; text-transform: uppercase;
      letter-spacing: 0.14em; color: rgba(255,255,255,0.45); margin-bottom: 0.5rem;
    }
    .bth-sign {
      font-family: var(--font-display); font-size: 1.15rem; font-weight: 500;
      color: var(--gold);
    }
    @media (max-width: 860px) {
      .big-three-hero { padding: 1rem 0.75rem; }
      .bth-glyph { font-size: 1.35rem; }
      .bth-sign { font-size: 0.95rem; }
      .bth-label { font-size: 0.55rem; }
    }

    /* ── GUARDIAN BUTTON (tab-natal) ── */
    .guardian-section {
      display: flex; justify-content: center; padding: 0.75rem 1.25rem;
    }
    .guardian-btn {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
      padding: 0.5rem 1.35rem;
      background: rgba(180,160,220,0.1); border: 1px solid rgba(180,160,220,0.3);
      color: #c4b4e8; border-radius: 2rem; font-size: 0.78rem;
      font-family: var(--font-mono); letter-spacing: 0.06em; text-transform: uppercase;
      cursor: pointer; transition: all 0.3s;
      -webkit-tap-highlight-color: transparent; touch-action: manipulation;
    }
    .guardian-btn:hover { background: rgba(180,160,220,0.2); border-color: rgba(180,160,220,0.55); }
    .guardian-btn:active { transform: scale(0.97); }

    /* ── WHEEL SECTION WRAPPER (tab-natal) ── */
    .wheel-section {
      padding: 1rem 0; display: flex; flex-direction: column; align-items: center;
    }
    .wheel-section .wheel-view-toggle {
      margin-top: 0.5rem; text-align: center;
    }

    /* ── PLANET TABLE SECTION WRAPPER (tab-natal) ── */
    .planet-table-section {
      padding: 0.5rem 1.25rem 1.25rem; overflow-x: auto;
      -webkit-overflow-scrolling: touch; margin-bottom: 0.5rem;
    }

    /* ── NATAL READING SECTION WRAPPER (tab-natal) ── */
    .natal-reading-section { padding: 1.25rem; }

    /* ── ANGEL CARDS (tab-natal) ── */
    .angel-cards-section { padding: 1rem 1.25rem 1.25rem; }
    .angel-cards {
      display: grid; grid-template-columns: repeat(3, 1fr);
      gap: 1rem;
    }
    .angel-card {
      background: var(--ink-up); border: 1px solid rgba(255,255,255,0.07);
      border-radius: var(--radius-card); padding: 1.25rem 1rem;
      text-align: center; position: relative; overflow: hidden;
    }
    .angel-card::before {
      content: ''; position: absolute; top: 0; left: 10%; right: 10%; height: 1px;
      background: linear-gradient(90deg, transparent, rgba(201,168,76,0.15), transparent);
      pointer-events: none;
    }
    .angel-card h4 {
      font-family: var(--font-display); font-size: 1.05rem; font-weight: 600;
      color: var(--gold); margin: 0 0 0.5rem 0; letter-spacing: 0.03em;
    }
    .angel-hebrew {
      font-size: 1.35rem; color: var(--gold-light);
      font-family: var(--font-display), serif; margin-bottom: 0.4rem;
      line-height: 1.2;
    }
    .angel-meaning {
      font-family: var(--font-mono); font-size: 0.68rem; text-transform: uppercase;
      letter-spacing: 0.1em; color: rgba(255,255,255,0.45);
      font-style: italic; margin-bottom: 0.65rem;
    }
    .angel-radiation {
      font-size: 0.83rem; color: var(--cream-muted); line-height: 1.6;
      font-weight: 300;
    }
    @media (max-width: 860px) {
      .angel-cards { grid-template-columns: 1fr; }
      .angel-card { padding: 1rem 0.85rem; }
    }

    /* ── PLANETARY PLACEMENTS GRID ── */
    #natal-placements-card .planet-grid {
      display: grid; grid-template-columns: 1fr 1fr;
      gap: 0.5rem; padding: 0.55rem 0.75rem;
    }
    #natal-placements-card .planet-grid-item {
      display: flex; align-items: center; gap: 0.7rem;
      padding: 0.7rem 0.62rem;
      border-bottom: 1px solid rgba(255,255,255,0.05);
    }
    #natal-placements-card .planet-grid-item:nth-child(odd) {
      border-right: 1px solid rgba(255,255,255,0.05);
    }
    #natal-placements-card .planet-grid-item:nth-last-child(-n+2) { border-bottom: none; }
    #natal-placements-card .planet-grid-glyph {
      font-size: 1.25rem; color: var(--gold);
      width: 26px; text-align: center; flex-shrink: 0;
    }
    #natal-placements-card .planet-grid-info { flex: 1; min-width: 0; }
    #natal-placements-card .planet-grid-name {
      font-family: var(--font-display); font-size: 0.88rem;
      font-weight: 500; color: var(--cream);
    }
    #natal-placements-card .planet-grid-rx {
      font-family: var(--font-mono); font-size: 0.6rem;
      color: var(--warm); margin-left: 0.25rem; opacity: 0.85;
    }
    #natal-placements-card .planet-grid-detail {
      display: flex; align-items: baseline; gap: 0.45rem; margin-top: 0.12rem;
    }
    #natal-placements-card .planet-grid-sign { font-size: 0.8rem; color: var(--cream-muted); }
    #natal-placements-card .planet-grid-degree {
      font-family: var(--font-mono); font-size: 0.72rem;
      color: rgba(255,255,255,0.4); letter-spacing: 0.02em;
    }
    #natal-placements-card .planet-grid-house {
      font-family: var(--font-mono); font-size: 0.6rem;
      text-transform: uppercase; letter-spacing: 0.06em;
      color: #b09ad4; background: rgba(122,100,180,0.1);
      border: 1px solid rgba(122,100,180,0.2);
      padding: 0.08rem 0.32rem; border-radius: 0.25rem;
    }
    @media (max-width: 860px) {
      #natal-placements-card .planet-grid { grid-template-columns: 1fr; }
      #natal-placements-card .planet-grid-item:nth-child(odd) { border-right: none; }
      #natal-placements-card .planet-grid-item:nth-last-child(2) { border-bottom: 1px solid rgba(255,255,255,0.05); }
      #natal-placements-card .planet-grid-item:last-child { border-bottom: none; }
    }

    /* ── NATAL WHEEL ── */
    .natal-wheel-wrap {
      display: flex; flex-direction: column; align-items: center;
      padding: 1.25rem 1rem 0.75rem;
    }
    /* 3-column desktop layout: placements | wheel | legend */
    .natal-wheel-layout {
      display: grid;
      grid-template-columns: 220px minmax(0, 1fr) 220px;
      grid-template-areas: "placements wheel legend";
      gap: 0; align-items: start;
    }
    .natal-wheel-center-col            { grid-area: wheel; min-width: 0; display: flex; flex-direction: column; align-items: stretch; }
    .natal-wheel-center-col .natal-wheel-wrap { width: 100%; }
    .natal-wheel-sidebar-left          { grid-area: placements; padding: 0.75rem 0.25rem 0.75rem 0.75rem; transition: opacity 0.18s; }
    .natal-wheel-sidebar-right         { grid-area: legend; padding: 0.75rem 0.75rem 0.75rem 0.25rem; display: flex; flex-direction: column; }
    /* Mobile: single column */
    @media (max-width: 860px) {
      .natal-wheel-layout {
        grid-template-columns: 1fr;
        grid-template-areas: "wheel" "placements" "legend";
      }
      .natal-wheel-sidebar-left,
      .natal-wheel-sidebar-right { padding: 0.5rem 1rem; }
    }
    .whl-modality-row { margin-top: 0.5rem; }

    /* Sidebar planet list */
    .whl-sidebar-label {
      font-size: 0.52rem; font-family: var(--font-mono); color: rgba(201,168,76,0.65);
      text-transform: uppercase; letter-spacing: 0.14em; margin-bottom: 0.5rem;
    }
    /* Sidebar zodiac cards — same component, scaled for 160px column */
    .natal-wheel-sidebar-left { padding: 0.75rem 0.25rem 0.75rem 0.75rem; transition: opacity 0.18s; }
    .whl-side-zodiac-card { margin-bottom: 0.5rem; }
    .whl-side-zodiac-card:last-child { margin-bottom: 0; }
    .whl-side-zodiac-card .zodiac-sign-img  { height: 52px; width: 52px; }
    .whl-side-zodiac-card .zodiac-name-row  { padding: 0.5rem 0.5rem; }
    .whl-side-zodiac-card .zodiac-header    { padding: 0.4rem 0.75rem; }
    .whl-side-zodiac-card .zodiac-header-label { font-size: 0.68rem; }
    .whl-side-zodiac-card .zodiac-attributes { padding: 0 0.4rem 0.4rem; gap: 0.2rem; }
    .whl-side-zodiac-card .zodiac-attr      { min-width: 0; }
    .whl-side-zodiac-card .zodiac-attr-label { font-size: 0.48rem; }
    .whl-side-zodiac-card .zodiac-attr-value { font-size: 0.68rem; }
    .whl-side-zodiac-card .zodiac-meaning   { padding: 0.5rem 0.6rem; font-size: 0.68rem; line-height: 1.45; }
    .natal-wheel-svg {
      width: 100%; max-width: 480px; height: auto;
      display: block; margin: 0 auto;
      filter: drop-shadow(0 4px 24px rgba(0,0,0,0.6));
    }
    .natal-wheel-legend {
      display: flex; flex-direction: column;
      gap: 0.3rem; width: 100%;
    }
    /* On mobile show as 2-col grid */
    @media (max-width: 860px) {
      .natal-wheel-legend { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.3rem; }
    }
    .whl-legend-group {
      display: flex; flex-direction: column; gap: 0.3rem;
      padding: 0.45rem 0.65rem;
      background: rgba(255,255,255,0.03);
      border: 1px solid rgba(201,168,76,0.14);
      border-radius: 6px;
    }
    .whl-legend-label {
      display: flex; align-items: center;
      font-size: 0.58rem; font-family: var(--font-mono); color: var(--cream);
      text-transform: uppercase; letter-spacing: 0.16em; white-space: nowrap;
      padding-bottom: 0.3rem; margin-bottom: 0.1rem;
      border-bottom: 1px solid rgba(201,168,76,0.2);
    }
    .whl-legend-group.hidden .whl-legend-items { display: none; }
    .whl-legend-group.hidden .whl-legend-label { opacity: 0.4; border-bottom-style: dashed; }
    .whl-legend-items { display: flex; flex-direction: column; gap: 0.2rem; }
    .whl-legend-item {
      display: flex; align-items: center; gap: 0.35rem; width: 100%;
      font-size: 0.67rem; color: var(--cream-muted); font-family: var(--font-mono);
    }
    .whl-legend-item-text { display: flex; flex-direction: column; gap: 0.05rem; min-width: 0; }
    .whl-legend-item { transition: opacity 0.14s; }
    .whl-legend-item:hover { opacity: 0.8; }
    .whl-legend-item.whl-legend-active { background: rgba(201,168,76,0.18); border-radius: 5px; outline: 2px solid rgba(201,168,76,0.55); color: var(--gold-light); }
    .whl-legend-item.whl-legend-active .whl-legend-name { color: var(--gold-light); font-weight: 600; }
    .whl-legend-item.whl-legend-dimmed { opacity: 0.30; }
    .whl-legend-pos  { color: rgba(255,255,255,0.65); font-size: 0.58rem; line-height: 1.2; }
    .whl-legend-dot  { display: none; }
    /* legacy alias — download button uses shared ctrl style */
    .whl-download-btn { display: inline-flex; align-items: center; gap: 0.4rem;
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      color: var(--gold-light); padding: 0.38rem 1rem; border-radius: 2rem;
      font-size: 0.76rem; font-family: var(--font-body); cursor: pointer;
      transition: background 0.2s, border-color 0.2s; font-weight: 400; }
    .whl-download-btn:hover { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.35); }

    .whl-planet-badge {
      transform-box: fill-box;
      transform-origin: center;
      transition: transform 0.14s ease, opacity 0.14s;
    }
    .whl-planet-badge:hover { transform: scale(1.22); }
    /* Highlight ring — hidden by default, shown on hover */
    .whl-planet-badge .whl-badge-ring { opacity: 0; transition: opacity 0.14s; }
    .whl-planet-badge:hover .whl-badge-ring { opacity: 1; }

    /* ── ASPECT LINES — CSS-driven opacity so transitions work ── */
    .whl-asp-line {
      opacity: 0.82;
      transition: opacity 0.18s ease, stroke-width 0.18s ease;
      pointer-events: none;
      filter: drop-shadow(0 0 3px rgba(255,255,255,0.08));
    }
    .whl-asp-line.whl-asp-active { opacity: 1; }
    .whl-asp-line.whl-asp-dim    { opacity: 0.05; }

    /* ── WHEEL CONTROL BUTTONS ── */
    .whl-controls {
      display: flex; gap: 0.5rem; justify-content: center; flex-wrap: wrap;
      margin-top: 0.65rem;
    }
    .whl-ctrl-btn {
      display: inline-flex; align-items: center; gap: 0.4rem;
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      color: var(--gold-light); padding: 0.38rem 1rem; border-radius: 2rem;
      font-size: 0.76rem; font-family: var(--font-body); cursor: pointer;
      transition: background 0.2s, border-color 0.2s; font-weight: 400;
    }
    .whl-ctrl-btn:hover { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.35); }

    /* ── PLANET INFO BUBBLE ── */
    /* Backdrop dimmer — mobile only, appears behind the sheet */
    .whl-bubble-backdrop {
      display: none;
      position: fixed; inset: 0; z-index: 1190;
      background: rgba(0,0,0,0.55);
      opacity: 0; transition: opacity 0.2s;
      pointer-events: none;
    }
    .whl-bubble-backdrop.visible { opacity: 1; pointer-events: auto; }
    @media (max-width: 768px) { .whl-bubble-backdrop { display: block; } }

    /* Shared base — desktop floating card */
    .whl-planet-bubble {
      position: fixed; z-index: 1200;
      background: var(--ink-card);
      border: 1px solid rgba(201,168,76,0.30);
      border-radius: 1rem;
      box-shadow: 0 8px 40px rgba(0,0,0,0.72), inset 0 1px 0 rgba(255,255,255,0.05);
      width: 260px;
      overflow: hidden;
      pointer-events: auto;
      transition: opacity 0.15s, transform 0.15s;
      opacity: 0; transform: scale(0.94);
      cursor: grab;
      /* Never wider than viewport */
      max-width: calc(100vw - 16px);
    }
    .whl-planet-bubble.visible { opacity: 1; transform: scale(1); }

    /* Mobile: bottom sheet sitting above the fixed nav bar */
    @media (max-width: 768px) {
      .whl-planet-bubble {
        position: fixed;
        left: 0 !important; right: 0 !important;
        bottom: 62px !important;          /* clear the mobile nav */
        top: auto !important;
        width: 100% !important; max-width: 100% !important;
        border-radius: 1.25rem 1.25rem 0 0;
        border-bottom: none;
        transform: translateY(100%);
        transition: opacity 0.2s, transform 0.25s;
        max-height: 60vh; overflow-y: auto;
        -webkit-overflow-scrolling: touch;
      }
      .whl-planet-bubble.visible { transform: translateY(0); opacity: 1; }
      .whl-planet-bubble.dragging {
        left: unset !important;
        right: unset !important;
        bottom: unset !important;
        top: unset !important;
        width: 260px !important;
        max-width: calc(100vw - 16px) !important;
        border-radius: 1rem;
        transform: scale(1);
        max-height: none;
        overflow-y: visible;
      }
      /* Drag handle indicator */
      .whl-planet-bubble::before {
        content: ''; display: block; width: 36px; height: 4px;
        background: rgba(255,255,255,0.15); border-radius: 2px;
        margin: 8px auto 4px;
      }
    }

    /* Close button */
    .whl-bubble-close {
      position: absolute; top: 0.55rem; right: 0.6rem;
      background: rgba(255,255,255,0.06); border: none; border-radius: 50%;
      width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
      color: var(--cream-muted); font-size: 0.85rem; cursor: pointer; line-height: 1;
      transition: background 0.15s; -webkit-tap-highlight-color: transparent;
    }
    .whl-bubble-close:hover { background: rgba(255,255,255,0.12); color: var(--cream); }

    /* Header band */
    .whl-bubble-header {
      display: flex; align-items: center; gap: 0.75rem;
      padding: 0.85rem 1rem 0.7rem;
      background: linear-gradient(135deg, rgba(12,12,24,0.9), rgba(20,20,38,0.9));
      border-bottom: 1px solid rgba(201,168,76,0.14);
    }
    .whl-bubble-photo {
      flex-shrink: 0; width: 44px; height: 44px; border-radius: 50%;
      overflow: hidden; border: 1.5px solid rgba(201,168,76,0.35);
      background: #0b1a30; display: flex; align-items: center; justify-content: center;
      font-size: 1.4rem; position: relative;
    }
    .whl-bubble-photo img {
      width: 100%; height: 100%; object-fit: cover;
      filter: brightness(0.88) contrast(1.1) saturate(0.9);
    }
    .whl-bubble-title { flex: 1; min-width: 0; }
    .whl-bubble-name {
      font-family: var(--font-display); font-size: 1.05rem; font-weight: 500;
      color: var(--cream); line-height: 1.2;
    }
    .whl-bubble-glyph { font-size: 1.1rem; margin-right: 0.2em; }
    .whl-bubble-sign {
      font-size: 0.7rem; color: var(--cream-muted); font-family: var(--font-mono);
      margin-top: 0.15rem; letter-spacing: 0.04em;
    }

    /* Stats row */
    .whl-bubble-stats {
      display: flex; gap: 0; border-bottom: 1px solid rgba(255,255,255,0.05);
    }
    .whl-bubble-stat {
      flex: 1; padding: 0.55rem 0.6rem; text-align: center;
      border-right: 1px solid rgba(255,255,255,0.05);
    }
    .whl-bubble-stat:last-child { border-right: none; }
    .whl-bubble-stat-label {
      font-family: var(--font-mono); font-size: 0.5rem; text-transform: uppercase;
      letter-spacing: 0.12em; color: rgba(201,168,76,0.55); display: block; margin-bottom: 0.18rem;
    }
    .whl-bubble-stat-val {
      font-size: 0.78rem; font-weight: 500; color: var(--cream);
      font-family: var(--font-mono);
    }

    /* Governs */
    .whl-bubble-governs {
      padding: 0.5rem 1rem; font-size: 0.7rem; color: var(--cream-muted);
      font-style: italic; font-weight: 300; line-height: 1.5;
      border-bottom: 1px solid rgba(255,255,255,0.04);
    }

    /* Aspect list */
    .whl-bubble-aspects { padding: 0.5rem 0.75rem 0.7rem; }
    .whl-bubble-aspects-label {
      font-family: var(--font-mono); font-size: 0.5rem; text-transform: uppercase;
      letter-spacing: 0.14em; color: var(--sage); margin-bottom: 0.4rem; display: block;
    }
    .whl-bubble-asp-item {
      display: flex; align-items: center; gap: 0.45rem;
      padding: 0.2rem 0; font-size: 0.72rem; color: var(--cream-muted);
    }
    .whl-bubble-asp-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
    .whl-bubble-asp-type { font-weight: 500; font-size: 0.68rem; font-family: var(--font-mono); }
    .whl-bubble-asp-orb  { margin-left: auto; font-size: 0.6rem; color: rgba(196,191,181,0.68); font-family: var(--font-mono); }

    /* Calculated for */
    .whl-calc-for {
      text-align: center; padding: 0.45rem 0.5rem 0.35rem;
      border-top: 1px solid rgba(201,168,76,0.12);
      margin-top: 0.5rem;
      display: flex; flex-direction: column; gap: 0.1rem;
    }
    .whl-calc-label {
      font-size: 0.52rem; color: rgba(201,168,76,0.50);
      font-family: var(--font-mono); letter-spacing: 0.10em; text-transform: uppercase;
    }
    .whl-calc-value {
      font-size: 0.60rem; color: rgba(196,191,181,0.72); font-family: var(--font-mono);
    }

    /* Tap hint */
    .whl-tap-hint {
      text-align: center; font-size: 0.60rem; color: rgba(201,168,76,0.55);
      font-family: var(--font-mono); letter-spacing: 0.08em;
      padding: 0.5rem 0.5rem 0.25rem;
      border-top: 1px solid rgba(201,168,76,0.15);
      margin-top: 0.4rem;
    }

    /* Angles bar — centered above the wheel SVG in center column */
    .whl-angles-top {
      display: flex; flex-wrap: wrap; justify-content: center; gap: 0.3rem 0.75rem;
      padding: 0.45rem 0.75rem 0.4rem;
      border-bottom: 1px solid rgba(201,168,76,0.15);
      background: rgba(201,168,76,0.03);
    }
    .whl-angles-top .house-angle-badge {
      display: flex; flex-direction: column; align-items: center; gap: 0;
    }
    .whl-angles-top .house-angle-label {
      font-size: 0.50rem; color: rgba(201,168,76,0.58);
      font-family: var(--font-mono); letter-spacing: 0.08em; text-transform: uppercase;
    }
    .whl-angles-top .house-angle-value {
      font-size: 0.70rem; color: var(--cream); font-family: var(--font-mono); font-weight: 500;
    }

    /* Modality × Element grid */
    .mod-grid {
      display: grid; grid-template-columns: auto repeat(3, 1fr);
      gap: 1px; margin: 0.5rem 0 0;
      border: 1px solid rgba(201,168,76,0.30); border-radius: 0.5rem;
      overflow: hidden; background: rgba(201,168,76,0.18);
    }
    .mod-cell {
      padding: 0.28rem 0.3rem; background: var(--ink-card);
      display: flex; align-items: center; justify-content: center;
      gap: 0.15rem; flex-wrap: wrap; min-height: 1.8rem;
    }
    .mod-header {
      background: rgba(201,168,76,0.06);
      font-family: var(--font-mono); font-size: 0.58rem; font-weight: 600;
      letter-spacing: 0.06em; color: rgba(201,168,76,0.80);
      flex-direction: column; gap: 0;
    }
    .mod-el-label {
      font-family: var(--font-mono); font-size: 0.58rem; font-weight: 700;
      letter-spacing: 0.06em; flex-direction: column; gap: 0;
      color: rgba(255,255,255,0.90);
    }
    .mod-abbr { font-size: 0.60rem; }
    .mod-count { font-size: 0.52rem; color: rgba(255,255,255,0.45); font-weight: 400; }
    .mod-el-label .mod-count { color: rgba(255,255,255,0.55); }
    .mod-body { gap: 0.1rem; flex-wrap: wrap; min-height: 1.8rem; }
    .mod-glyph {
      font-size: 0.82rem; font-family: 'Segoe UI Symbol','Apple Symbols','Noto Sans Symbols','Symbola',serif;
      line-height: 1; color: rgba(255,255,255,0.90);
    }
    .mod-glyph-vx {
      font-size: 0.60rem; font-family: var(--font-mono); color: rgba(255,255,255,0.90); line-height:1;
    }

    /* ── ANGEL SHARE CARD ── */
    .angel-share-btn {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem;
      background: rgba(201,168,76,0.07); border: 1px solid rgba(201,168,76,0.2);
      color: var(--gold); padding: 0.32rem 0.85rem; border-radius: 2rem;
      font-size: 0.72rem; font-family: var(--font-mono); letter-spacing: 0.06em;
      text-transform: uppercase; cursor: pointer; transition: all 0.18s;
      margin-top: 0.75rem; width: 100%;
    }
    .angel-share-btn:hover { background: rgba(201,168,76,0.14); border-color: rgba(201,168,76,0.4); }
    .angel-share-btn:active { transform: scale(0.97); }
    .angel-share-btn.generating { opacity: 0.6; pointer-events: none; }
    .angel-share-btn .share-spinner {
      display: none; width: 12px; height: 12px; border: 1.5px solid rgba(201,168,76,0.3);
      border-top-color: var(--gold); border-radius: 50%; animation: spin 0.7s linear infinite;
    }
    .angel-share-btn.generating .share-spinner { display: inline-block; }
    .angel-share-btn.generating .share-icon { display: none; }
    @keyframes spin { to { transform: rotate(360deg); } }

    /* ── Angel Chat Modal ─────────────────────────────────────────────── */
    .angel-chat-btn {
      display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem;
      background: rgba(180,160,220,0.08); border: 1px solid rgba(180,160,220,0.25);
      color: #c4b4e8; padding: 0.32rem 0.85rem; border-radius: 2rem;
      font-size: 0.72rem; font-family: var(--font-mono); letter-spacing: 0.06em;
      text-transform: uppercase; cursor: pointer; transition: all 0.18s;
      margin-top: 0.4rem; width: 100%;
      -webkit-tap-highlight-color: transparent; touch-action: manipulation;
    }
    .angel-chat-btn:hover { background: rgba(180,160,220,0.15); border-color: rgba(180,160,220,0.5); }
    .angel-chat-btn:active { transform: scale(0.97); }

    .angel-chat-overlay {
      display: none; position: fixed; inset: 0; z-index: 2100;
      background: rgba(8,8,15,0.85); backdrop-filter: blur(8px);
      align-items: center; justify-content: center; padding: 1rem;
    }
    .angel-chat-overlay.open { display: flex; }
    .angel-chat-modal {
      background: var(--ink-card); border: 1px solid rgba(180,160,220,0.15);
      border-radius: 10px; width: 100%; max-width: 640px;
      max-height: 82vh; display: flex; flex-direction: column;
      box-shadow: 0 24px 64px rgba(0,0,0,0.7);
    }
    .angel-chat-hdr {
      flex-shrink: 0; display: flex; align-items: center; gap: 0.75rem;
      padding: 0.85rem 1.1rem; border-bottom: 1px solid rgba(255,255,255,0.07);
    }
    .angel-chat-hdr-seal {
      width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0;
      border: 1px solid rgba(180,160,220,0.3); display: flex; align-items: center; justify-content: center;
      background: radial-gradient(circle at 40% 35%, rgba(180,160,220,0.15), rgba(201,168,76,0.05));
      color: #c4b4e8; font-size: 1rem;
    }
    .angel-chat-hdr-name { font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--cream); }
    .angel-chat-hdr-meta { font-family: var(--font-mono); font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.1em; color: #c4b4e8; margin-top: 0.1rem; }
    .angel-chat-close {
      margin-left: auto; flex-shrink: 0; width: 28px; height: 28px; border-radius: 50%;
      border: 1px solid rgba(255,255,255,0.1); background: transparent; color: var(--cream-muted);
      cursor: pointer; display: flex; align-items: center; justify-content: center;
      font-size: 0.85rem; transition: all 0.2s;
      -webkit-tap-highlight-color: transparent; touch-action: manipulation;
    }
    .angel-chat-close:hover { border-color: var(--cream); color: var(--cream); }
    .angel-chat-messages {
      flex: 1; min-height: 0; overflow-y: auto; padding: 1rem;
      display: flex; flex-direction: column; gap: 0.85rem; scroll-behavior: smooth;
    }
    .angel-chat-messages::-webkit-scrollbar { width: 3px; }
    .angel-chat-messages::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 2px; }
    .angel-chat-msg { display: flex; gap: 0.55rem; align-items: flex-start; animation: fadeUp 0.25s ease both; }
    .angel-chat-av {
      flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center; font-size: 0.7rem; margin-top: 2px;
    }
    .angel-chat-av.av-angel { background: rgba(180,160,220,0.15); border: 1px solid rgba(180,160,220,0.3); color: #c4b4e8; }
    .angel-chat-av.av-user  { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); color: var(--cream-muted); }
    .angel-chat-lbl { font-family: var(--font-mono); font-size: 0.58rem; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 0.2rem; }
    .angel-chat-msg.ac-angel .angel-chat-lbl { color: #c4b4e8; }
    .angel-chat-msg.ac-user  .angel-chat-lbl { color: var(--cream-muted); }
    .angel-chat-txt { font-family: 'Playfair Display', Georgia, serif; font-size: 0.97rem; line-height: 1.75; color: var(--cream); font-style: italic; }
    .angel-chat-msg.ac-user .angel-chat-txt { font-family: var(--font-body); font-size: 0.85rem; font-style: normal; color: var(--cream-muted); }
    .angel-chat-typing-dot { width: 5px; height: 5px; border-radius: 50%; background: #c4b4e8; display: inline-block; animation: typingBounce 1.2s ease-in-out infinite; }
    .angel-chat-typing-dot:nth-child(2) { animation-delay: 0.2s; }
    .angel-chat-typing-dot:nth-child(3) { animation-delay: 0.4s; }
    .angel-chat-divider {
      display: flex; align-items: center; gap: 0.5rem;
      font-family: var(--font-mono); font-size: 0.55rem; text-transform: uppercase;
      letter-spacing: 0.1em; color: rgba(240,236,226,0.3);
    }
    .angel-chat-divider::before, .angel-chat-divider::after { content:''; flex:1; height:1px; background:rgba(255,255,255,0.06); }
    .angel-chat-input-row {
      flex-shrink: 0; display: flex; gap: 0.55rem; align-items: flex-end;
      padding: 0.75rem 1rem; border-top: 1px solid rgba(255,255,255,0.07);
    }
    .angel-chat-input-wrap {
      flex: 1; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1);
      border-radius: 8px; padding: 0.55rem 0.8rem; transition: border-color 0.2s;
    }
    .angel-chat-input-wrap:focus-within { border-color: rgba(180,160,220,0.4); }
    #angel-chat-input {
      width: 100%; background: none; border: none; resize: none;
      color: var(--cream); font-family: var(--font-body); font-size: 0.85rem;
      font-weight: 300; line-height: 1.5; max-height: 100px; overflow-y: auto;
    }
    #angel-chat-input::placeholder { color: rgba(240,236,226,0.3); }
    .angel-chat-send {
      flex-shrink: 0; width: 36px; height: 36px; border-radius: 8px;
      background: rgba(180,160,220,0.1); border: 1px solid rgba(180,160,220,0.3); color: #c4b4e8;
      cursor: pointer; display: flex; align-items: center; justify-content: center;
      font-size: 0.85rem; transition: all 0.2s;
      -webkit-tap-highlight-color: transparent; touch-action: manipulation;
    }
    .angel-chat-send:hover:not(:disabled) { background: rgba(180,160,220,0.2); border-color: rgba(180,160,220,0.55); }
    .angel-chat-send:disabled { opacity: 0.3; cursor: not-allowed; }

    /* ── TAB BADGE DOT ── */
    .nav-tab { position: relative; }
    .tab-badge {
      display: none; position: absolute; top: 5px; right: 5px;
      width: 6px; height: 6px; border-radius: 50%;
      background: var(--gold); box-shadow: 0 0 6px rgba(201,168,76,0.7);
      pointer-events: none;
    }
    @media (max-width: 768px) {
      .tab-badge { top: 2px; right: calc(50% - 16px); }
    }
    .nav-tab.has-badge .tab-badge { display: block; }

    /* ── TIMING CALENDAR ── */

    /* ── Calendar card container ── */
    #timing-calendar-card {
      border: 1px solid rgba(201,168,76,0.22);
      box-shadow: 0 4px 28px rgba(0,0,0,0.45), 0 0 0 1px rgba(201,168,76,0.06);
    }

    /* ── Color Calendar: CSS variable overrides + transparent root ── */
    #timing-calendar-card .color-calendar {
      --cal-color-primary: var(--gold);
      --cal-font-family-header: var(--font-display);
      --cal-font-family-body: var(--font-body);
      --cal-font-family-weekdays: var(--font-mono);
      --cal-drop-shadow: none;
      --cal-border: none;
      background: transparent;
      color: var(--cream);
      width: 100%;
      border: none;
      box-shadow: none;
    }

    /* ── Card body layout ── */
    #timing-calendar-card .card-body,
    #timing-calendar-card .cal-card-body {
      padding: 0.5rem 0.5rem 0.75rem;
    }
    #cal-container {
      width: 100%;
      margin-bottom: 0.5rem;
    }

    /* ── Header (month label + nav arrows) ── */
    #timing-calendar-card .calendar-header,
    #timing-calendar-card .color-calendar__header {
      background: transparent;
      padding: 0.75rem 0.75rem;
      border-bottom: 1px solid rgba(255,255,255,0.07);
    }
    #timing-calendar-card .calendar-header .month-year,
    #timing-calendar-card .color-calendar__header .color-calendar__month-year {
      font-family: var(--font-display);
      font-size: 1.15rem;
      font-style: italic;
      color: var(--cream);
      letter-spacing: 0.06em;
    }
    #timing-calendar-card .calendar-header .arrow,
    #timing-calendar-card .color-calendar__header .color-calendar__arrow {
      color: var(--cream-muted);
      background: rgba(255,255,255,0.02);
      border: 1px solid rgba(255,255,255,0.16);
      border-radius: 50%;
      width: 2.2rem;
      height: 2.2rem;
      min-width: 2.2rem;
      min-height: 2.2rem;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: background 0.18s, border-color 0.18s, color 0.18s, box-shadow 0.18s;
      -webkit-tap-highlight-color: transparent;
      touch-action: manipulation;
    }
    #timing-calendar-card .calendar-header .arrow:hover,
    #timing-calendar-card .color-calendar__header .color-calendar__arrow:hover {
      background: rgba(201,168,76,0.1);
      border-color: var(--gold-border);
      color: var(--gold);
      box-shadow: 0 0 0 1px var(--gold);
    }

    /* ── Weekday labels ── */
    #timing-calendar-card .calendar-weekdays,
    #timing-calendar-card .color-calendar__weekday-container {
      background: transparent;
    }
    #timing-calendar-card .calendar-weekday,
    #timing-calendar-card .color-calendar__weekday {
      font-family: var(--font-mono);
      font-size: 0.6rem;
      text-transform: uppercase;
      letter-spacing: 0.09em;
      color: var(--cream-muted);
      padding: 0.35rem 0 0.32rem;
      background: var(--ink-card);
    }

    /* ── Day cells ── */
    #timing-calendar-card .calendar-day,
    #timing-calendar-card .color-calendar__day {
      min-height: 3rem;
      background: var(--ink-card-alt);
      color: var(--cream);
      font-family: var(--font-mono);
      font-size: 0.8rem;
      font-weight: 600;
      cursor: pointer;
      transition: background 0.16s ease, box-shadow 0.16s ease;
      -webkit-tap-highlight-color: transparent;
      touch-action: manipulation;
      border: none;
      border-radius: 0;
      position: relative;
    }
    #timing-calendar-card .calendar-day:hover,
    #timing-calendar-card .color-calendar__day:hover {
      background: rgba(201,168,76,0.08);
      box-shadow: inset 0 0 0 1px rgba(201,168,76,0.22);
      z-index: 1;
    }
    #timing-calendar-card .calendar-day:active,
    #timing-calendar-card .color-calendar__day:active {
      background: rgba(201,168,76,0.14);
    }

    /* ── Today: gold circle badge on number (not full-cell flood) ── */
    #timing-calendar-card .color-calendar__day--today {
      background: transparent !important;
      color: var(--cream) !important;
    }
    #timing-calendar-card .color-calendar__day--today::before {
      content: '';
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 1.6rem;
      height: 1.6rem;
      border-radius: 50%;
      background: var(--gold);
      z-index: 0;
      box-shadow: 0 0 8px rgba(201,168,76,0.4);
      pointer-events: none;
    }
    /* Keep the number text above the circle badge */
    #timing-calendar-card .color-calendar__day--today > * {
      position: relative;
      z-index: 1;
      color: var(--ink) !important;
    }
    /* Legacy selectors for any custom calendar variant */
    #timing-calendar-card .calendar-day.today .day-text,
    #timing-calendar-card .calendar-day--today .calendar-day__number {
      background: var(--gold) !important;
      color: var(--ink) !important;
      border-radius: 50%;
      width: 1.6rem;
      height: 1.6rem;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      font-weight: 700;
      box-shadow: 0 0 8px rgba(201,168,76,0.35);
    }

    /* ── Selected day ── */
    #timing-calendar-card .calendar-day.selected,
    #timing-calendar-card .color-calendar__day--active {
      background: rgba(201,168,76,0.16) !important;
      box-shadow: inset 0 0 0 2px rgba(201,168,76,0.8) !important;
    }

    /* ── Other-month / disabled days ── */
    #timing-calendar-card .calendar-day.disabled,
    #timing-calendar-card .color-calendar__day--disabled {
      opacity: 0.28;
      pointer-events: none;
    }

    /* ── Oil day background tinting ── */
    #timing-calendar-card .calendar-day.cal-has-oil,
    #timing-calendar-card .color-calendar__day.cal-has-oil {
      background: rgba(201,168,76,0.14);
      box-shadow: inset 0 0 0 1px rgba(201,168,76,0.26), inset 0 -3px 10px rgba(201,168,76,0.12);
      border-bottom: 2px solid rgba(201,168,76,0.55);
    }
    #timing-calendar-card .calendar-day.cal-has-oil:hover,
    #timing-calendar-card .color-calendar__day.cal-has-oil:hover {
      background: rgba(201,168,76,0.19);
    }
    /* Candle indicator — 2×6px gold rectangle at bottom-center */
    #timing-calendar-card .calendar-day.cal-has-oil::after,
    #timing-calendar-card .color-calendar__day.cal-has-oil::after {
      content: '';
      position: absolute;
      bottom: 3px;
      left: 50%;
      transform: translateX(-50%);
      width: 2px;
      height: 6px;
      background: var(--gold);
      border-radius: 1px;
      opacity: 0.7;
      pointer-events: none;
      z-index: 1;
    }

    /* ── Grid gap/border styling ── */
    #timing-calendar-card .calendar-days,
    #timing-calendar-card .color-calendar__days-container {
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 2px;
      background: rgba(255,255,255,0.06);
      border-radius: var(--radius-sm);
      overflow: hidden;
    }

    /* ── Legend ── */
    .cal-legend {
      display: flex; gap: 0.75rem; flex-wrap: wrap;
      padding: 0.3rem 0.15rem 0.1rem;
      font-size: 0.62rem; font-family: var(--font-mono); color: var(--cream-muted);
      letter-spacing: 0.04em;
    }
    .cal-legend-item { display: flex; align-items: center; gap: 0.3rem; }
    .cal-legend-swatch { width: 10px; height: 10px; border-radius: 3px; display: inline-block; }
    .cal-legend-swatch--oil { background: rgba(201,168,76,0.3); border: 1px solid rgba(201,168,76,0.45); }

    /* ── Event dots ── */
    .cal-dot { width: 5px; height: 5px; border-radius: 50%; margin: 1px; box-shadow: 0 0 0 1px rgba(8,8,15,0.25); }
    .cal-dot--red   { background: #d35; }
    .cal-dot--cream { background: var(--cream-muted); }
    .cal-dot--warm  { background: var(--warm); box-shadow: 0 0 4px currentColor; }
    /* Gold-tinted dots get extra glow */
    #timing-calendar-card .color-calendar__event-bullet,
    #timing-calendar-card .color-calendar__event-indicator {
      width: 5px;
      height: 5px;
      border-radius: 50%;
      margin: 1px;
    }
    #timing-calendar-card .color-calendar__event-bullet[style*="gold"],
    #timing-calendar-card .color-calendar__event-indicator[style*="gold"] {
      box-shadow: 0 0 4px currentColor;
    }

    /* ── Detail panel ── */
    .cal-detail {
      border-top: 1px solid rgba(255,255,255,0.12);
      margin-top: 0;
      padding-top: 0;
      opacity: 0;
      transform: translateY(-4px);
      max-height: 0;
      overflow: hidden;
      transition: max-height 0.25s ease, opacity 0.2s ease, transform 0.2s ease, margin-top 0.2s ease, padding-top 0.2s ease;
    }
    .cal-detail:empty { display: none; }
    .cal-detail.cal-detail--open {
      margin-top: 0.7rem;
      padding-top: 0.7rem;
      padding-left: 0.6rem;
      opacity: 1;
      transform: translateY(0);
      max-height: 36rem;
      border-radius: var(--radius-sm);
      background: rgba(255,255,255,0.035);
      border-left: 3px solid rgba(201,168,76,0.4);
      animation: calDetailOpen 0.24s ease;
    }
    .cal-detail-header {
      display: flex; justify-content: space-between; align-items: center; margin-bottom: 0.5rem;
    }
    .cal-detail-date {
      font-family: var(--font-display); font-size: 1rem; font-style: italic; line-height: 1.2; color: var(--cream);
    }
    .cal-detail-close {
      min-height: 2rem; min-width: 2rem;
      background: rgba(255,255,255,0.03);
      border: 1px solid rgba(255,255,255,0.12);
      border-radius: var(--radius-sm);
      color: var(--cream-muted); cursor: pointer;
      font-size: 0.78rem; opacity: 0.85; padding: 0.2rem;
      transition: color 0.16s ease, border-color 0.16s ease, background 0.16s ease;
    }
    .cal-detail-close:hover {
      color: var(--gold);
      border-color: rgba(201,168,76,0.45);
      background: rgba(201,168,76,0.1);
    }
    .cal-detail-close:focus-visible {
      outline: 2px solid rgba(201,168,76,0.55);
      outline-offset: 1px;
    }
    .cal-detail-list { display: flex; flex-direction: column; gap: 0.42rem; }
    .cal-detail-item {
      display: flex; align-items: flex-start; gap: 0.55rem;
      padding: 0.52rem 0.62rem; background: rgba(255,255,255,0.03);
      border-radius: var(--radius-sm); border-left: 3px solid transparent;
    }
    .cal-detail-item--gold  { border-left-color: var(--gold); }
    .cal-detail-item--red   { border-left-color: #d35; }
    .cal-detail-item--cream { border-left-color: var(--cream-muted); }
    .cal-detail-item--warm  { border-left-color: var(--warm); }
    .cal-detail-icon { font-size: 0.95rem; flex-shrink: 0; line-height: 1.2; }
    .cal-detail-body { flex: 1; min-width: 0; }
    .cal-detail-title { font-size: 0.83rem; font-weight: 600; line-height: 1.3; color: var(--cream); }
    .cal-detail-sub {
      font-size: 0.69rem; font-family: var(--font-mono); color: var(--cream-muted);
      margin-top: 0.1rem; line-height: 1.35;
    }

    @keyframes calDetailOpen {
      from { opacity: 0; transform: translateY(-8px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ── Mobile responsive ── */
    @media (max-width: 575px) {
      #timing-calendar-card .calendar-day,
      #timing-calendar-card .color-calendar__day {
        min-height: 2.85rem;
      }
      /* Keep circular arrows on mobile — slightly larger tap target */
      #timing-calendar-card .calendar-header .arrow,
      #timing-calendar-card .color-calendar__header .color-calendar__arrow {
        width: 2.5rem;
        height: 2.5rem;
        min-width: 2.5rem;
        min-height: 2.5rem;
      }
      #timing-calendar-card .calendar-header,
      #timing-calendar-card .color-calendar__header {
        padding: 0.6rem 0.5rem;
      }
      #timing-calendar-card .calendar-weekday,
      #timing-calendar-card .color-calendar__weekday {
        font-size: 0.53rem;
        padding: 0.3rem 0;
      }
      .cal-detail-title { font-size: 0.86rem; }
      .cal-detail-sub   { font-size: 0.71rem; }
      .cal-detail-close { min-height: 2.2rem; min-width: 2.2rem; padding: 0.5rem; }
      .cal-legend { gap: 0.48rem; font-size: 0.54rem; }
      #timing-calendar-card .cal-card-body { padding: 0.35rem 0.4rem 0.55rem; }
      /* Candle indicator slightly smaller on mobile */
      #timing-calendar-card .calendar-day.cal-has-oil::after,
      #timing-calendar-card .color-calendar__day.cal-has-oil::after {
        height: 5px;
        bottom: 2px;
      }
    }
    @media (min-width: 576px) and (max-width: 767px) {
      #timing-calendar-card .calendar-day,
      #timing-calendar-card .color-calendar__day {
        min-height: 2.6rem;
      }
      #timing-calendar-card .calendar-header .arrow,
      #timing-calendar-card .color-calendar__header .color-calendar__arrow {
        width: 2.3rem;
        height: 2.3rem;
        min-width: 2.3rem;
        min-height: 2.3rem;
      }
    }

    /* ── ALERT BELL ── */
    .alert-bell {
      width: 36px; height: 36px; border-radius: 50%;
      background: rgba(201,168,76,0.08); border: 1px solid rgba(201,168,76,0.2);
      color: var(--gold); cursor: pointer; font-size: 1rem;
      display: flex; align-items: center; justify-content: center;
      transition: all 0.2s; position: relative; padding: 0;
    }
    .alert-bell:hover {
      background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.4);
    }
    .alert-bell-badge {
      position: absolute; top: -2px; right: -2px;
      min-width: 16px; height: 16px; border-radius: 8px;
      background: #e74c3c; color: white;
      font-size: 0.6rem; font-weight: 700;
      display: none; align-items: center; justify-content: center;
      padding: 0 4px; font-family: var(--font-mono);
    }
    .alert-bell.has-count .alert-bell-badge { display: flex; }

    /* ── ALERT DROPDOWN ── */
    .alert-dropdown {
      position: absolute; top: calc(100% + 0.5rem); right: 0;
      width: 320px; max-height: 400px; overflow-y: auto;
      background: var(--ink-dark, #1a1a2e);
      border: 1px solid rgba(201,168,76,0.25); border-radius: 12px;
      box-shadow: 0 8px 32px rgba(0,0,0,0.4);
      z-index: 1000; display: none; padding: 0;
    }
    .alert-dropdown.open { display: block; }
    .alert-dropdown-header {
      padding: 0.75rem 1rem; border-bottom: 1px solid rgba(201,168,76,0.15);
      font-family: var(--font-mono); font-size: 0.65rem;
      text-transform: uppercase; letter-spacing: 0.1em; color: var(--gold);
      display: flex; justify-content: space-between; align-items: center;
    }
    .alert-dropdown-empty {
      padding: 1.5rem 1rem; text-align: center;
      color: var(--cream-muted); font-size: 0.8rem;
    }
    .alert-item {
      padding: 0.75rem 1rem; border-bottom: 1px solid rgba(255,255,255,0.05);
      transition: background 0.15s; cursor: default;
    }
    .alert-item:last-child { border-bottom: none; }
    .alert-item:hover { background: rgba(201,168,76,0.04); }
    .alert-item-title {
      font-size: 0.82rem; font-weight: 600; color: var(--cream); margin-bottom: 0.2rem;
    }
    .alert-item-time {
      font-size: 0.7rem; font-family: var(--font-mono); color: var(--cream-muted);
    }
    .alert-item-dismiss {
      float: right; background: none; border: none;
      color: var(--cream-muted); cursor: pointer;
      font-size: 0.7rem; opacity: 0.5; padding: 0.2rem;
    }
    .alert-item-dismiss:hover { opacity: 1; color: var(--gold); }

    /* ── RITUAL NOTIFY BUTTON ── */
    .ritual-notify-btn {
        display: inline-flex; align-items: center; gap: 0.4rem;
        padding: 0.5rem 1rem; border-radius: 8px;
        background: rgba(201,168,76,0.08); border: 1px solid rgba(201,168,76,0.25);
        color: var(--gold); font-family: var(--font-mono); font-size: 0.7rem;
        text-transform: uppercase; letter-spacing: 0.08em;
        cursor: pointer; transition: all 0.2s; margin-top: 0.75rem;
    }
    .ritual-notify-btn:hover { background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.4); }
    .ritual-notify-btn.subscribed {
        background: rgba(201,168,76,0.15); border-color: rgba(201,168,76,0.5);
        color: var(--gold);
    }
    .ritual-notify-btn:disabled { opacity: 0.4; cursor: not-allowed; }

    .oil-notify-toggle {
        display: inline-flex; align-items: center; gap: 0.4rem;
        padding: 0.4rem 0.85rem; border-radius: 8px;
        background: rgba(201,168,76,0.06); border: 1px solid rgba(201,168,76,0.2);
        color: var(--cream-muted); font-family: var(--font-mono); font-size: 0.65rem;
        text-transform: uppercase; letter-spacing: 0.08em;
        cursor: pointer; transition: all 0.2s; margin-left: auto;
    }
    .oil-notify-toggle:hover { background: rgba(201,168,76,0.12); color: var(--gold); }
    .oil-notify-toggle.subscribed {
        background: rgba(201,168,76,0.12); border-color: rgba(201,168,76,0.4); color: var(--gold);
    }
    .oil-notify-toggle:disabled { opacity: 0.4; cursor: not-allowed; }

    /* ── UPCOMING SCHEDULE ── */
    .upcoming-card { margin-top: 1rem; }
    .upcoming-list { display: flex; flex-direction: column; gap: 0.5rem; }
    .upcoming-item {
        display: flex; align-items: center; gap: 0.75rem;
        padding: 0.6rem 0.75rem; border-radius: 8px;
        background: rgba(201,168,76,0.04); border: 1px solid rgba(201,168,76,0.12);
    }
    .upcoming-item-icon { font-size: 1.1rem; flex-shrink: 0; }
    .upcoming-item-body { flex: 1; min-width: 0; }
    .upcoming-item-title { font-size: 0.8rem; font-weight: 600; color: var(--cream); }
    .upcoming-item-time { font-size: 0.68rem; font-family: var(--font-mono); color: var(--cream-muted); }
    .upcoming-empty { padding: 1rem; text-align: center; color: var(--cream-muted); font-size: 0.8rem; font-style: italic; }

    /* ── SUBSCRIPTION MANAGEMENT ── */
    .subs-list { display: flex; flex-direction: column; gap: 0.5rem; }
    .sub-item {
        display: flex; align-items: center; gap: 0.75rem;
        padding: 0.6rem 0.75rem; border-radius: 8px;
        background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06);
    }
    .sub-item-body { flex: 1; min-width: 0; }
    .sub-item-type { font-size: 0.78rem; font-weight: 600; color: var(--cream); }
    .sub-item-detail { font-size: 0.65rem; font-family: var(--font-mono); color: var(--cream-muted); }
    .sub-item-actions { display: flex; gap: 0.4rem; flex-shrink: 0; }
    .sub-item-delete {
        background: none; border: 1px solid rgba(231,76,60,0.25); color: rgba(231,76,60,0.7);
        border-radius: 6px; padding: 0.25rem 0.5rem; font-size: 0.65rem; cursor: pointer;
        transition: all 0.15s;
    }
    .sub-item-delete:hover { border-color: rgba(231,76,60,0.5); color: #e74c3c; background: rgba(231,76,60,0.08); }
    .sub-item-delete--confirming { border-color: rgba(201,168,76,0.5) !important; color: var(--gold) !important; background: rgba(201,168,76,0.08) !important; }
    .sub-lead-select {
        background: rgba(201,168,76,0.06); border: 1px solid rgba(201,168,76,0.2);
        color: var(--cream); border-radius: 6px; padding: 0.2rem 0.35rem;
        font-size: 0.65rem; font-family: var(--font-mono); cursor: pointer;
    }

    /* ── HEADER LIVE ANGEL PILL ── */
    .header-angel-live {
      display: none; align-items: center; justify-content: center; gap: 0.4rem;
      margin-top: 0.45rem;
      font-family: var(--font-mono); font-size: 0.63rem; letter-spacing: 0.09em;
      text-transform: uppercase; color: rgba(201,168,76,0.6);
    }
    .header-angel-live.visible { display: flex; }
    .header-angel-live-dot {
      width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0;
      background: var(--gold); opacity: 0.65;
      animation: pulse 2.5s ease-in-out infinite;
    }
    @keyframes pulse { 0%,100%{opacity:0.4;transform:scale(1)} 50%{opacity:1;transform:scale(1.3)} }

    /* ── SETTINGS MODAL ── */
    .settings-overlay {
      display: none; position: fixed; inset: 0; z-index: 2000;
      background: rgba(8,8,15,0.82); backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      align-items: center; justify-content: center; padding: 1.25rem;
    }
    .settings-overlay.open { display: flex; }
    .settings-modal {
      background: var(--ink-card); border: 1px solid rgba(255,255,255,0.08);
      border-radius: 1rem; width: 100%; max-width: 520px;
      max-height: 88vh; display: flex; flex-direction: column;
      box-shadow: 0 24px 64px rgba(0,0,0,0.75); overflow: hidden;
    }
    .settings-hdr {
      flex-shrink: 0; display: flex; align-items: center;
      padding: 1rem 1.25rem; border-bottom: 1px solid rgba(255,255,255,0.06);
      background: linear-gradient(135deg, #1a1a30, #141428);
    }
    .settings-hdr-title {
      font-family: var(--font-display); font-size: 1rem; font-weight: 500;
      color: var(--cream); flex: 1;
    }
    .settings-close-btn {
      width: 28px; height: 28px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.1);
      background: transparent; color: var(--cream-muted); cursor: pointer;
      display: flex; align-items: center; justify-content: center; font-size: 0.85rem;
      transition: all 0.2s; flex-shrink: 0;
      -webkit-tap-highlight-color: transparent;
    }
    .settings-close-btn:hover { border-color: var(--cream); color: var(--cream); }
    .settings-body {
      flex: 1; overflow-y: auto; padding: 1.1rem;
      display: flex; flex-direction: column; gap: 0.85rem;
    }
    .settings-section {
      background: var(--ink-card-alt); border: 1px solid rgba(255,255,255,0.06);
      border-radius: var(--radius-sm); overflow: hidden;
    }
    .settings-section-hdr {
      padding: 0.55rem 0.9rem; background: rgba(255,255,255,0.025);
      border-bottom: 1px solid rgba(255,255,255,0.05);
      font-family: var(--font-mono); font-size: 0.6rem; letter-spacing: 0.14em;
      text-transform: uppercase; color: var(--sage);
    }
    .settings-section-body { padding: 0.75rem 0.9rem; }
    .settings-stat {
      display: flex; justify-content: space-between; align-items: baseline;
      padding: 0.3rem 0; border-bottom: 1px solid rgba(255,255,255,0.04);
      font-size: 0.82rem;
    }
    .settings-stat:last-child { border-bottom: none; }
    .settings-stat-label { color: var(--cream-muted); font-size: 0.74rem; }
    .settings-stat-value { color: var(--cream); font-weight: 400; text-align: right; max-width: 60%; word-break: break-all; }
    .settings-link-row {
      display: flex; align-items: center; justify-content: space-between;
      padding: 0.75rem 0.9rem; cursor: pointer; transition: background 0.2s;
      font-size: 0.85rem; color: var(--cream); border-radius: var(--radius-sm);
      -webkit-tap-highlight-color: transparent;
    }
    .settings-link-row:hover { background: rgba(255,255,255,0.04); }
    .settings-signout-btn {
      width: 100%; padding: 0.7rem; border-radius: var(--radius-sm);
      background: rgba(199,125,106,0.07); border: 1px solid rgba(199,125,106,0.18);
      color: var(--warm); font-family: var(--font-body); font-size: 0.85rem;
      cursor: pointer; transition: all 0.2s; font-weight: 400;
      -webkit-tap-highlight-color: transparent;
    }
    .settings-signout-btn:hover { background: rgba(199,125,106,0.14); border-color: rgba(199,125,106,0.35); }
    .settings-select {
        background: rgba(255,255,255,0.05);
        color: var(--cream);
        border: 1px solid rgba(255,255,255,0.12);
        border-radius: 6px;
        padding: 0.4rem 0.6rem;
        font-size: 0.85rem;
        font-family: inherit;
        width: 100%;
        max-width: 220px;
        cursor: pointer;
        appearance: auto;
    }
    .settings-select:focus {
        outline: none;
        border-color: var(--gold);
    }
    .settings-admin-note {
        color: var(--cream-muted);
        font-size: 0.78rem;
        line-height: 1.6;
        margin-bottom: 0.9rem;
    }
    .settings-admin-row {
        display: flex;
        flex-direction: column;
        gap: 0.35rem;
        margin-bottom: 0.85rem;
    }
    .settings-admin-input {
        background: rgba(255,255,255,0.05);
        color: var(--cream);
        border: 1px solid rgba(255,255,255,0.12);
        border-radius: 8px;
        padding: 0.55rem 0.7rem;
        font-size: 0.85rem;
        font-family: var(--font-mono);
    }
    .settings-admin-input:focus {
        outline: none;
        border-color: rgba(201,168,76,0.5);
        box-shadow: 0 0 0 1px rgba(201,168,76,0.18);
    }
    .settings-admin-actions {
        display: flex;
        flex-direction: column;
        gap: 0.6rem;
    }
    .settings-admin-btn {
        width: 100%;
        padding: 0.7rem 0.85rem;
        border-radius: 8px;
        cursor: pointer;
        text-align: left;
        font-size: 0.82rem;
        font-family: var(--font-mono);
        letter-spacing: 0.05em;
        text-transform: uppercase;
        transition: all 0.2s;
    }
    .settings-admin-btn:disabled {
        opacity: 0.55;
        cursor: not-allowed;
    }
    .settings-admin-btn-warn {
        background: rgba(201,168,76,0.08);
        border: 1px solid rgba(201,168,76,0.24);
        color: var(--gold-light);
    }
    .settings-admin-btn-warn:hover:not(:disabled) {
        background: rgba(201,168,76,0.14);
        border-color: rgba(201,168,76,0.4);
    }
    .settings-admin-btn-danger {
        background: rgba(199,125,106,0.1);
        border: 1px solid rgba(199,125,106,0.24);
        color: #e8a898;
    }
    .settings-admin-btn-danger:hover:not(:disabled) {
        background: rgba(199,125,106,0.16);
        border-color: rgba(199,125,106,0.38);
    }
    .settings-admin-status {
        margin-top: 0.85rem;
        min-height: 1.1rem;
        font-size: 0.74rem;
        color: var(--sage);
        line-height: 1.5;
    }
    .settings-admin-status.error {
        color: #e8a898;
    }

    /* ── NATAL WHEEL TOGGLE ── */
    .wheel-view-toggle {
      display: inline-flex; border: 1px solid rgba(255,255,255,0.1);
      border-radius: 2rem; overflow: hidden; margin-left: auto; gap: 0;
    }
    .wheel-toggle-btn {
      background: transparent; border: none; color: var(--cream-muted);
      padding: 0.22rem 0.75rem; font-family: var(--font-mono); font-size: 0.6rem;
      letter-spacing: 0.08em; text-transform: uppercase; cursor: pointer;
      transition: all 0.18s; white-space: nowrap;
      -webkit-tap-highlight-color: transparent;
    }
    .wheel-toggle-btn.active {
      background: rgba(201,168,76,0.15); color: var(--gold-light);
    }
    .wheel-toggle-btn + .wheel-toggle-btn { border-left: 1px solid rgba(255,255,255,0.1); }

    /* ── SYNASTRY TAB ── */
    #tab-synastry .syn-partner-section,
    #tab-synastry #synastry-portrait-card {
      margin-bottom: 1rem;
    }
    #tab-synastry .syn-partner-row {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr) auto;
      align-items: end;
      gap: 0.75rem;
    }
    #tab-synastry .syn-label,
    #tab-synastry .syn-field-label {
      display: block;
      font-family: var(--font-mono);
      font-size: 0.62rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--cream-muted);
    }
    #tab-synastry .syn-select,
    #tab-synastry .syn-input {
      width: 100%;
      background: var(--ink-card-alt);
      border: 1px solid rgba(255,255,255,0.12);
      border-radius: var(--radius-sm);
      color: var(--cream);
      padding: 0.55rem 0.72rem;
      font-size: 0.84rem;
      font-family: var(--font-body);
      transition: border-color 0.18s, box-shadow 0.18s;
    }
    #tab-synastry .syn-select {
      cursor: pointer;
      appearance: auto;
      min-height: 2.15rem;
    }
    #tab-synastry .syn-select:focus,
    #tab-synastry .syn-input:focus {
      outline: none;
      border-color: var(--gold-border);
      box-shadow: 0 0 0 1px rgba(201,168,76,0.18);
    }
    #tab-synastry .syn-select option {
      background: #141425;
      color: var(--cream);
    }
    #tab-synastry .syn-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.35rem;
      min-height: 2.15rem;
      border-radius: 999px;
      border: 1px solid rgba(255,255,255,0.14);
      background: rgba(255,255,255,0.03);
      color: var(--cream-muted);
      padding: 0.45rem 0.9rem;
      font-family: var(--font-mono);
      font-size: 0.68rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      white-space: nowrap;
      cursor: pointer;
      transition: background 0.18s, border-color 0.18s, color 0.18s, transform 0.15s;
    }
    #tab-synastry .syn-btn:hover:not(:disabled) {
      border-color: rgba(255,255,255,0.24);
      color: var(--cream);
      background: rgba(255,255,255,0.06);
    }
    #tab-synastry .syn-btn:active:not(:disabled) {
      transform: translateY(1px);
    }
    #tab-synastry .syn-btn:disabled {
      opacity: 0.55;
      cursor: not-allowed;
      pointer-events: none;
    }
    #tab-synastry .syn-btn-primary {
      background: var(--gold-soft);
      border-color: var(--gold-border);
      color: var(--gold-light);
    }
    #tab-synastry .syn-btn-primary:hover:not(:disabled) {
      background: rgba(201,168,76,0.2);
      border-color: rgba(201,168,76,0.35);
      color: var(--gold-light);
    }
    #tab-synastry .syn-btn-secondary {
      background: rgba(255,255,255,0.02);
      border-color: rgba(255,255,255,0.15);
      color: var(--cream-muted);
    }
    #tab-synastry .syn-btn-danger {
      background: rgba(199,125,106,0.09);
      border-color: rgba(199,125,106,0.26);
      color: #e8a898;
    }
    #tab-synastry .syn-btn-danger:hover:not(:disabled) {
      background: rgba(199,125,106,0.16);
      border-color: rgba(199,125,106,0.42);
      color: #f0b5a7;
    }
    #tab-synastry .syn-partner-detail {
      margin-top: 0.85rem;
      padding: 0.8rem 0.9rem;
      background: var(--ink-card-alt);
      border: 1px solid rgba(255,255,255,0.07);
      border-radius: var(--radius-sm);
      display: flex;
      flex-direction: column;
      gap: 0.7rem;
    }
    #tab-synastry .syn-partner-meta {
      color: var(--cream-muted);
      font-size: 0.82rem;
      line-height: 1.55;
    }
    #tab-synastry .syn-partner-meta strong {
      color: var(--cream);
      font-weight: 500;
    }
    #tab-synastry .syn-partner-actions {
      display: flex;
      gap: 0.5rem;
      flex-wrap: wrap;
    }
    #tab-synastry .syn-partner-form {
      margin-top: 0.9rem;
      background: rgba(255,255,255,0.015);
      border: 1px solid rgba(255,255,255,0.07);
      border-radius: var(--radius-sm);
      padding: 0.95rem;
      display: flex;
      flex-direction: column;
      gap: 0.75rem;
    }
    #tab-synastry .syn-form-title {
      color: var(--gold-light);
      font-family: var(--font-display);
      font-size: 0.96rem;
      font-weight: 500;
    }
    #tab-synastry .syn-form-row {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0.75rem;
    }
    #tab-synastry .syn-field {
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
      min-width: 0;
    }
    #tab-synastry .syn-field-hint {
      color: rgba(212,208,200,0.72);
      font-size: 0.72rem;
      line-height: 1.4;
    }
    #tab-synastry .syn-form-actions {
      display: flex;
      gap: 0.5rem;
      flex-wrap: wrap;
      padding-top: 0.15rem;
    }
    #tab-synastry .syn-form-error {
      margin-top: 0.25rem;
      padding: 0.6rem 0.75rem;
      border-radius: 0.55rem;
      font-size: 0.76rem;
      line-height: 1.45;
      text-align: left;
    }
    #tab-synastry .syn-form-error[hidden] {
      display: none !important;
    }
    #tab-synastry .reading-card {
      overflow: hidden;
    }
    #tab-synastry .reading-card-header {
      position: relative;
      overflow: hidden;
      background: linear-gradient(135deg, #1e1640 0%, #241545 50%, #1a1030 100%);
      border-bottom: 1px solid rgba(160,130,220,0.2);
      min-height: 3.5rem;
      padding: 0.75rem 1rem;
      gap: 0.6rem;
      flex-wrap: wrap;
      align-items: center;
    }
    #tab-synastry .syn-card-banner {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      opacity: 0.18;
      z-index: 0;
      pointer-events: none;
      user-select: none;
    }
    #tab-synastry .reading-card-header > *:not(.syn-card-banner) {
      position: relative;
      z-index: 1;
    }
    #tab-synastry .reading-card-title {
      color: var(--gold-light);
      font-family: var(--font-display);
      font-weight: 500;
      min-width: 180px;
      flex: 1 1 auto;
    }
    #tab-synastry .reading-card-body {
      padding-top: 1rem;
    }
    #tab-synastry .view-toggle-group {
      display: inline-flex;
      margin-left: auto !important;
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: 2rem;
      overflow: hidden;
      gap: 0 !important;
      flex-shrink: 0;
    }
    #tab-synastry .synastry-view-toggle {
      background: transparent;
      border: none;
      color: var(--cream-muted);
      padding: 0.22rem 0.75rem;
      font-family: var(--font-mono);
      font-size: 0.6rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      cursor: pointer;
      transition: background 0.18s, color 0.18s;
      white-space: nowrap;
    }
    #tab-synastry .synastry-view-toggle + .synastry-view-toggle {
      border-left: 1px solid rgba(255,255,255,0.1);
    }
    #tab-synastry .synastry-view-toggle:hover:not(.active) {
      color: var(--cream);
      background: rgba(255,255,255,0.05);
    }
    #tab-synastry .synastry-view-toggle.active {
      background: rgba(201,168,76,0.15);
      color: var(--gold-light);
    }
    #tab-synastry .syn-regenerate-btn {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 0.32rem;
      min-height: 2rem;
      padding: 0.35rem 0.78rem;
      margin-left: 0.2rem;
      border-radius: 999px;
      border: 1px solid rgba(201,168,76,0.28);
      background: rgba(201,168,76,0.1);
      color: var(--gold-light);
      font-family: var(--font-mono);
      font-size: 0.63rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      white-space: nowrap;
      cursor: pointer;
      transition: background 0.18s, border-color 0.18s, color 0.18s;
    }
    #tab-synastry .syn-regenerate-btn:hover:not(:disabled) {
      background: rgba(201,168,76,0.18);
      border-color: rgba(201,168,76,0.4);
      color: var(--gold-light);
    }
    #tab-synastry .syn-regenerate-btn:disabled {
      opacity: 0.6;
      cursor: not-allowed;
    }
    #tab-synastry .syn-regenerate-btn .spinner-border {
      width: 0.78rem;
      height: 0.78rem;
      border-width: 0.12rem;
      margin-right: 0.2rem;
    }
    #tab-synastry .syn-birthtime-notice {
      margin-top: 0.2rem;
      margin-bottom: 0.2rem;
      padding: 0.52rem 0.68rem;
      border-radius: 0.5rem;
      border: 1px solid var(--gold-border);
      background: var(--gold-soft);
      color: var(--gold-light);
      font-size: 0.74rem;
      line-height: 1.45;
    }
    #tab-synastry .syn-prose {
      color: var(--cream-muted);
      font-size: 0.9rem;
      line-height: 1.76;
      font-weight: 300;
    }
    #tab-synastry .syn-prose p + p {
      margin-top: 0.82rem;
    }
    #tab-synastry .syn-prose > p:first-of-type::first-letter {
      font-family: var(--font-display);
      font-size: 3.2em;
      float: left;
      line-height: 0.8;
      margin: 0.1em 0.08em 0 0;
      color: var(--gold);
      font-weight: 700;
    }
    @media (max-width: 600px) {
      #tab-synastry .syn-prose > p:first-of-type::first-letter {
        font-size: 2.5em;
      }
    }
    #tab-synastry .syn-section-title {
      margin: 1.4rem 0 0.55rem;
      font-family: var(--font-display);
      font-size: 1rem;
      font-weight: 500;
      letter-spacing: 0.01em;
      color: var(--gold);
    }
    #tab-synastry .syn-prose > .syn-section-title:first-child {
      margin-top: 0;
    }
    #tab-synastry .syn-section-divider {
      display: flex;
      align-items: center;
      justify-content: center;
      margin: 1.4rem 0;
      gap: 0.5rem;
    }
    #tab-synastry .syn-section-divider::before,
    #tab-synastry .syn-section-divider::after {
      content: '';
      flex: 1;
      height: 1px;
      background: linear-gradient(to var(--dir, right), transparent, rgba(201,168,76,0.25), transparent);
    }
    #tab-synastry .syn-section-divider::after { --dir: left; }
    #tab-synastry .syn-section-divider-dot {
      color: var(--gold);
      font-size: 0.5rem;
      opacity: 0.6;
    }
    #tab-synastry .syn-empty {
      border: 1px dashed rgba(255,255,255,0.15);
      border-radius: var(--radius-sm);
      background: rgba(255,255,255,0.02);
      color: var(--cream-muted);
      font-size: 0.84rem;
      line-height: 1.55;
      padding: 0.95rem 1rem;
      text-align: center;
    }
    #tab-synastry .syn-aspects-list {
      display: flex;
      flex-direction: column;
      gap: 0.35rem;
    }
    #tab-synastry .syn-aspect-row {
      display: grid;
      grid-template-columns: minmax(0, 1.4fr) minmax(86px, 1fr) minmax(0, 1.4fr) minmax(52px, 0.6fr) minmax(56px, 0.65fr);
      align-items: center;
      gap: 0.5rem;
      padding: 0.5rem 0.7rem;
      background: rgba(255,255,255,0.04);
      border: 1px solid rgba(255,255,255,0.11);
      border-radius: 0.55rem;
    }
    #tab-synastry .syn-aspect-row > span {
      min-width: 0;
      word-break: break-word;
    }
    #tab-synastry .syn-aspect-row-head {
      background: rgba(201,168,76,0.08);
      border-color: rgba(201,168,76,0.2);
      color: rgba(232,212,139,0.85);
      font-family: var(--font-mono);
      font-size: 0.58rem;
      text-transform: uppercase;
      letter-spacing: 0.09em;
    }
    #tab-synastry .syn-aspect-header span {
      white-space: nowrap;
    }
    #tab-synastry .syn-aspect-planet {
      color: var(--cream);
      font-size: 0.82rem;
      line-height: 1.4;
    }
    #tab-synastry .syn-aspect-type {
      color: var(--cream-muted);
      text-align: center;
      font-size: 0.76rem;
      line-height: 1.35;
    }
    #tab-synastry .syn-aspect-orb,
    #tab-synastry .syn-aspect-score {
      font-family: var(--font-mono);
      font-size: 0.7rem;
      text-align: right;
      white-space: nowrap;
      letter-spacing: 0.03em;
    }
    #tab-synastry .syn-aspect-orb {
      color: rgba(212,208,200,0.85);
    }
    #tab-synastry .syn-aspect-score {
      color: var(--gold-light);
      font-weight: 600;
    }
    #tab-synastry .syn-tier-harmonious,
    #tab-synastry .syn-tier-supportive,
    #tab-synastry .syn-tier-easy,
    #tab-synastry .syn-tier-soft {
      border-color: rgba(122,158,126,0.38);
      background: rgba(122,158,126,0.14);
    }
    #tab-synastry .syn-tier-challenging,
    #tab-synastry .syn-tier-tense,
    #tab-synastry .syn-tier-hard,
    #tab-synastry .syn-tier-difficult {
      border-color: rgba(199,125,106,0.42);
      background: rgba(199,125,106,0.14);
    }
    #tab-synastry .syn-tier-neutral,
    #tab-synastry .syn-tier-mixed {
      border-color: rgba(255,255,255,0.1);
      background: rgba(255,255,255,0.03);
    }
    #tab-synastry .syn-compat-summary {
      margin-bottom: 1rem;
      padding: 0.75rem 0.9rem;
      background: rgba(201,168,76,0.06);
      border: 1px solid rgba(201,168,76,0.15);
      border-radius: 0.65rem;
      display: flex;
      flex-direction: column;
      gap: 0.5rem;
    }
    #tab-synastry .syn-compat-label {
      display: flex;
      justify-content: space-between;
      align-items: center;
    }
    #tab-synastry .syn-compat-title {
      font-family: var(--font-mono);
      font-size: 0.6rem;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: var(--cream-muted);
    }
    #tab-synastry .syn-compat-value {
      font-family: var(--font-display);
      font-size: 0.92rem;
      font-weight: 500;
      color: var(--gold-light);
    }
    #tab-synastry .syn-compat-track {
      height: 4px;
      background: rgba(255,255,255,0.07);
      border-radius: 99px;
      overflow: hidden;
    }
    #tab-synastry .syn-compat-fill {
      height: 100%;
      border-radius: 99px;
      background: linear-gradient(to right, var(--warm), var(--gold), var(--sage));
      transition: width 0.6s ease;
    }
    @media (max-width: 991px) {
      #tab-synastry .syn-partner-row {
        grid-template-columns: minmax(0, 1fr);
        align-items: stretch;
      }
      #tab-synastry .syn-partner-row .syn-label {
        margin-bottom: -0.15rem;
      }
      #tab-synastry #synastry-add-partner-btn {
        width: 100%;
      }
      #tab-synastry .reading-card-header {
        align-items: flex-start;
      }
    }
    @media (max-width: 767px) {
      #tab-synastry .reading-card-title {
        min-width: 0;
        width: 100%;
      }
      #tab-synastry .view-toggle-group {
        margin-left: 0 !important;
        width: 100%;
      }
      #tab-synastry .synastry-view-toggle {
        flex: 1 1 0;
        min-height: 2.1rem;
      }
      #tab-synastry .syn-regenerate-btn {
        width: 100%;
        margin-left: 0;
      }
      #tab-synastry .syn-form-row {
        grid-template-columns: minmax(0, 1fr);
        gap: 0.6rem;
      }
      #tab-synastry .syn-aspects-list {
        gap: 0.45rem;
      }
      #tab-synastry .syn-aspect-row {
        grid-template-columns: minmax(0, 1fr) auto;
        grid-template-areas:
          'user score'
          'type type'
          'partner orb';
        gap: 0.3rem 0.5rem;
        padding: 0.56rem 0.62rem;
      }
      #tab-synastry .syn-aspect-row-head {
        display: none;
      }
      #tab-synastry .syn-aspect-user { grid-area: user; }
      #tab-synastry .syn-aspect-type {
        grid-area: type;
        text-align: left;
        font-size: 0.73rem;
      }
      #tab-synastry .syn-aspect-partner { grid-area: partner; }
      #tab-synastry .syn-aspect-orb { grid-area: orb; }
      #tab-synastry .syn-aspect-score {
        grid-area: score;
        font-size: 0.76rem;
      }
    }

    /* ── SYNASTRY: location field container ── */
    #tab-synastry .syn-location-field {
      position: relative; /* anchor for the city suggestion dropdown */
    }

    /* ── SYNASTRY: city suggestion dropdown ── */
    #tab-synastry .syn-city-suggestions {
      position: absolute;
      top: calc(100% + 2px);
      left: 0;
      right: 0;
      z-index: 320;
      background: var(--ink-card);
      border: 1px solid var(--gold-border);
      border-radius: var(--radius-sm);
      max-height: 15rem;
      overflow-y: auto;
      box-shadow: 0 8px 28px rgba(0,0,0,0.55);
      /* custom scrollbar */
      scrollbar-width: thin;
      scrollbar-color: rgba(201,168,76,0.3) transparent;
    }
    #tab-synastry .syn-city-suggestions::-webkit-scrollbar {
      width: 4px;
    }
    #tab-synastry .syn-city-suggestions::-webkit-scrollbar-thumb {
      background: rgba(201,168,76,0.3);
      border-radius: 2px;
    }
    /* suggestion rows — button elements */
    #tab-synastry .syn-city-suggestion {
      display: flex;
      flex-direction: column;
      align-items: flex-start;
      gap: 0.15rem;
      width: 100%;
      padding: 0.62rem 0.8rem;
      background: transparent;
      border: none;
      border-bottom: 1px solid rgba(255,255,255,0.05);
      color: var(--cream);
      font-size: 0.84rem;
      font-family: var(--font-body);
      line-height: 1.4;
      text-align: left;
      cursor: pointer;
      transition: background 0.14s, color 0.14s;
      -webkit-tap-highlight-color: transparent;
    }
    #tab-synastry .syn-city-suggestion:last-child {
      border-bottom: none;
    }
    #tab-synastry .syn-city-suggestion small {
      color: var(--cream-muted);
      font-size: 0.69rem;
      font-family: var(--font-mono);
      letter-spacing: 0.04em;
    }
    #tab-synastry .syn-city-suggestion:hover,
    #tab-synastry .syn-city-suggestion:focus {
      background: rgba(201,168,76,0.1);
      color: var(--gold-light);
      outline: none;
    }
    #tab-synastry .syn-city-suggestion:focus-visible {
      outline: 1px solid var(--gold-border);
      outline-offset: -1px;
    }
    #tab-synastry .syn-city-suggestion:active {
      background: rgba(201,168,76,0.18);
    }
    /* empty state row */
    #tab-synastry .syn-city-suggestion-empty {
      color: var(--cream-muted);
      font-size: 0.78rem;
      font-style: italic;
      padding: 0.72rem 0.8rem;
      cursor: default;
      text-align: center;
    }
    #tab-synastry .syn-city-suggestion-empty:hover {
      background: transparent;
      color: var(--cream-muted);
    }

    #tab-synastry .syn-input-wrap {
      position: relative;
    }

    #tab-synastry .syn-input-icon {
      position: absolute;
      right: 0.75rem;
      top: 50%;
      transform: translateY(-50%);
      pointer-events: none;
    }

    #tab-synastry .syn-location-selected {
      display: none;
      align-items: flex-start;
      justify-content: space-between;
      gap: 0.5rem;
      margin-top: 0.5rem;
      padding: 0.6rem 0.85rem;
      background: rgba(122,158,126,0.08);
      border: 1px solid rgba(122,158,126,0.15);
      border-radius: 0.6rem;
      font-size: 0.8rem;
      color: var(--sage);
    }

    #tab-synastry .syn-location-selected.show {
      display: flex;
    }

    #tab-synastry .syn-loc-name {
      flex: 1;
      line-height: 1.4;
    }

    #tab-synastry .syn-loc-coords {
      font-family: var(--font-mono);
      font-size: 0.65rem;
      color: rgba(122,158,126,0.6);
      margin-top: 0.15rem;
      white-space: nowrap;
    }

    #tab-synastry .syn-loc-clear {
      background: none;
      border: none;
      color: rgba(122,158,126,0.5);
      cursor: pointer;
      font-size: 0.85rem;
      padding: 0;
      line-height: 1;
      flex-shrink: 0;
    }

    #tab-synastry .syn-loc-clear:hover {
      color: var(--sage);
    }

    /* ── SYNASTRY: Flatpickr calendar — project palette ──
       Flatpickr appends .flatpickr-calendar directly to <body>; these
       rules are global but intentional — synastry is the sole consumer. */
    .flatpickr-calendar {
      background: var(--ink-card);
      border: 1px solid var(--gold-border);
      border-radius: var(--radius-sm);
      box-shadow: 0 8px 32px rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.04);
      color: var(--cream);
      font-family: var(--font-body);
      z-index: 9999 !important;
    }
    /* arrow tip that points to the input */
    .flatpickr-calendar.arrowTop::before {
      border-bottom-color: var(--gold-border);
    }
    .flatpickr-calendar.arrowTop::after {
      border-bottom-color: var(--ink-card);
    }
    .flatpickr-calendar.arrowBottom::before {
      border-top-color: var(--gold-border);
    }
    .flatpickr-calendar.arrowBottom::after {
      border-top-color: var(--ink-card);
    }
    /* month header */
    .flatpickr-months {
      background: var(--ink-card-alt);
      border-radius: var(--radius-sm) var(--radius-sm) 0 0;
      padding: 0.15rem 0;
      border-bottom: 1px solid rgba(255,255,255,0.06);
    }
    .flatpickr-months .flatpickr-month {
      color: var(--gold-light);
      fill: var(--gold-light);
    }
    .flatpickr-months .flatpickr-prev-month,
    .flatpickr-months .flatpickr-next-month {
      color: var(--gold-light);
      fill: var(--gold-light);
    }
    .flatpickr-months .flatpickr-prev-month svg,
    .flatpickr-months .flatpickr-next-month svg {
      fill: var(--gold-light);
    }
    .flatpickr-months .flatpickr-prev-month:hover svg,
    .flatpickr-months .flatpickr-next-month:hover svg {
      fill: var(--gold);
    }
    .flatpickr-current-month .flatpickr-monthDropdown-months {
      background: var(--ink-card-alt);
      color: var(--gold-light);
    }
    .flatpickr-current-month .flatpickr-monthDropdown-months option {
      background: var(--ink-card-alt);
      color: var(--cream);
    }
    .flatpickr-current-month input.cur-year {
      color: var(--gold-light);
      font-weight: 500;
    }
    /* weekday header row */
    .flatpickr-weekdays {
      background: var(--ink-card);
      border-bottom: 1px solid rgba(255,255,255,0.04);
    }
    span.flatpickr-weekday {
      background: transparent;
      color: var(--cream-muted);
      font-family: var(--font-mono);
      font-size: 0.62rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }
    /* day grid */
    .dayContainer {
      background: var(--ink-card);
    }
    .flatpickr-day {
      color: var(--cream);
      border-radius: 50%;
      transition: background 0.14s, border-color 0.14s, color 0.14s;
    }
    .flatpickr-day:hover,
    .flatpickr-day:focus {
      background: rgba(201,168,76,0.12);
      border-color: var(--gold-border);
      color: var(--gold-light);
      outline: none;
    }
    /* selected day */
    .flatpickr-day.selected,
    .flatpickr-day.selected:hover,
    .flatpickr-day.selected:focus,
    .flatpickr-day.startRange,
    .flatpickr-day.startRange:hover,
    .flatpickr-day.endRange,
    .flatpickr-day.endRange:hover {
      background: var(--gold);
      border-color: var(--gold);
      color: var(--ink);
      font-weight: 600;
    }
    /* in-range days */
    .flatpickr-day.inRange {
      background: rgba(201,168,76,0.14);
      border-color: transparent;
      box-shadow: none;
      color: var(--cream);
    }
    /* today marker */
    .flatpickr-day.today {
      border-color: var(--gold-border);
    }
    .flatpickr-day.today:hover,
    .flatpickr-day.today:focus {
      background: rgba(201,168,76,0.15);
      border-color: var(--gold);
    }
    /* disabled / prev-next month days */
    .flatpickr-day.flatpickr-disabled,
    .flatpickr-day.flatpickr-disabled:hover,
    .flatpickr-day.prevMonthDay,
    .flatpickr-day.nextMonthDay {
      color: rgba(212,208,200,0.25);
      border-color: transparent;
      background: transparent;
    }
    /* time picker strip */
    .flatpickr-time {
      background: var(--ink-card-alt);
      border-top: 1px solid rgba(255,255,255,0.07);
      border-radius: 0 0 var(--radius-sm) var(--radius-sm);
    }
    .flatpickr-time input,
    .flatpickr-time .flatpickr-am-pm {
      background: transparent;
      color: var(--cream);
      font-family: var(--font-body);
      font-size: 0.9rem;
    }
    .flatpickr-time input:hover,
    .flatpickr-time input:focus,
    .flatpickr-time .flatpickr-am-pm:hover,
    .flatpickr-time .flatpickr-am-pm:focus {
      background: rgba(201,168,76,0.08);
      color: var(--gold-light);
      outline: none;
    }
    .flatpickr-time .flatpickr-time-separator {
      color: var(--cream-muted);
    }
    /* spinner arrows on time inputs */
    .numInputWrapper:hover {
      background: rgba(201,168,76,0.05);
    }
    .numInputWrapper span.arrowUp::after {
      border-bottom-color: var(--cream-muted);
    }
    .numInputWrapper span.arrowDown::after {
      border-top-color: var(--cream-muted);
    }
    .numInputWrapper span:hover {
      background: rgba(201,168,76,0.12);
    }

    /* ── SYNASTRY pickers: mobile layout ── */
    @media (max-width: 767px) {
      #tab-synastry .syn-city-suggestions {
        max-height: 44vh;
        /* keep dropdown above soft-keyboard on small screens */
        position: absolute;
      }
      /* Flatpickr calendar — ensure it stays readable on narrow viewports */
      .flatpickr-calendar {
        width: 100% !important;
        max-width: calc(100vw - 2rem);
        left: 1rem !important;
        right: 1rem !important;
      }
    }

    /* Panels inside the wheel card */
    .wheel-panel { display: none; }
    .wheel-panel.active { display: block; }
    .wheel-panel.houses-panel .card-body { padding: 1rem; }

    .ritual-skel-wrap { padding: 0.75rem 0; }
    .ritual-skel-card {
      background: var(--ink-card-alt); border: 1px solid rgba(255,255,255,0.05);
      border-radius: var(--radius-sm); padding: 0.85rem 1rem; margin-bottom: 0.6rem;
      display: flex; gap: 0.75rem; align-items: center;
    }
    .ritual-skel-icon { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; }
    .ritual-skel-lines { flex: 1; }
    .ritual-skel-line { height: 0.85rem; border-radius: 0.3rem; margin-bottom: 0.45rem; }
    .ritual-skel-line:last-child { margin-bottom: 0; width: 55%; }

    /* ── TAB SKELETON SCREENS ── */
    .skel-card {
      background: var(--ink-card-alt); border: 1px solid rgba(255,255,255,0.05);
      border-radius: var(--radius-sm); padding: 1rem 1.15rem; margin-bottom: 0.75rem;
    }
    .skel-line {
      height: 0.85rem; border-radius: 0.3rem; margin-bottom: 0.6rem;
      background: linear-gradient(90deg, #1a1a2e 25%, #22223a 50%, #1a1a2e 75%);
      background-size: 200% 100%; animation: shimmer 1.5s infinite;
    }
    .skel-line:last-child { margin-bottom: 0; }
    .skel-line.w40 { width: 40%; }
    .skel-line.w55 { width: 55%; }
    .skel-line.w70 { width: 70%; }
    .skel-line.w85 { width: 85%; }
    .skel-line.w90 { width: 90%; }
    .skel-circle {
      border-radius: 50%;
      background: linear-gradient(90deg, #1a1a2e 25%, #22223a 50%, #1a1a2e 75%);
      background-size: 200% 100%; animation: shimmer 1.5s infinite;
    }
    .skel-block {
      border-radius: var(--radius-sm);
      background: linear-gradient(90deg, #1a1a2e 25%, #22223a 50%, #1a1a2e 75%);
      background-size: 200% 100%; animation: shimmer 1.5s infinite;
    }
    .skel-row { display: flex; gap: 0.75rem; }
    .skel-row > * { flex: 1; }

    /* ── GLOSSARY TOOLTIPS ── */
    .spirit-tip { border-bottom: 1px dotted rgba(201,168,76,0.45); cursor: help; position: relative; color: inherit; transition: border-color 0.15s; }
    .spirit-tip:hover { border-bottom-color: var(--gold); }
    .spirit-tip-bubble {
      position: fixed; z-index: 9999; max-width: 280px; width: max-content;
      background: #1a1a2e; border: 1px solid var(--gold-border); border-radius: 0.5rem;
      padding: 0.55rem 0.75rem; font-size: 0.74rem; line-height: 1.55; color: var(--cream-muted);
      font-family: var(--font-body); font-weight: 300; font-style: normal;
      box-shadow: 0 4px 24px rgba(0,0,0,0.5); pointer-events: auto; opacity: 0;
      transition: opacity 0.15s; display: none;
    }
    .spirit-tip-bubble.visible { display: block; opacity: 1; }
    .spirit-tip-bubble .tip-term { color: var(--gold); font-weight: 500; display: block; margin-bottom: 0.2rem; font-size: 0.72rem; letter-spacing: 0.03em; text-transform: uppercase; }
    .spirit-tip-bubble .tip-cat { font-size: 0.6rem; color: rgba(201,168,76,0.55); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.25rem; display: block; }
    .spirit-tip-link { display:inline-block; margin-top:0.5rem; padding-top:0.45rem; border-top:1px solid rgba(201,168,76,0.18); font-family: var(--font-mono); font-size:0.65rem; letter-spacing:0.08em; text-transform:uppercase; color: var(--gold); text-decoration:none; }
    .spirit-tip-link:hover { color: var(--gold-light); }
    @media (max-width: 767px) { .spirit-tip-bubble { max-width: min(280px, calc(100vw - 16px)); } }

    /* ── METHODS PAGE OVERHAUL ── */
    .methods-search-wrap { position: sticky; top: 0; z-index: 10; background: rgba(8,8,15,0.97); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); padding: 0.75rem 0; margin-bottom: 0.75rem; border-bottom: 1px solid rgba(255,255,255,0.05); }
    .methods-search { width: 100%; background: var(--ink-up); border: 1px solid rgba(255,255,255,0.08); border-radius: 0.5rem; color: var(--cream); font-family: var(--font-body); font-size: 0.82rem; padding: 0.55rem 0.85rem 0.55rem 2rem; transition: border-color 0.2s; }
    .methods-search:focus { border-color: var(--gold-border); }
    .methods-search-icon { position: absolute; left: 0.75rem; top: 50%; transform: translateY(-50%); color: var(--cream-muted); font-size: 0.82rem; pointer-events: none; }
    .methods-disc-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.5rem; margin-bottom: 0.75rem; }
    @media (max-width: 575px) { .methods-disc-row { grid-template-columns: repeat(2, 1fr); } }
    .methods-disc-btn {
      background: var(--ink-up); border: 1px solid rgba(255,255,255,0.06);
      border-radius: 0.6rem; padding: 0.6rem 0.5rem; cursor: pointer;
      text-align: center; transition: all 0.15s; -webkit-tap-highlight-color: transparent;
      display: flex; flex-direction: column; align-items: center; gap: 0.2rem;
    }
    .methods-disc-btn:hover { border-color: rgba(255,255,255,0.15); background: rgba(255,255,255,0.03); }
    .methods-disc-btn.active { border-width: 1.5px; }
    .methods-disc-btn[data-disc="astronomical_engine"] { border-left: 3px solid rgba(45,106,159,0.5); }
    .methods-disc-btn[data-disc="astronomical_engine"].active { border-color: rgba(45,106,159,0.7); background: rgba(45,106,159,0.08); }
    .methods-disc-btn[data-disc="astrological_framework"] { border-left: 3px solid rgba(118,75,162,0.4); }
    .methods-disc-btn[data-disc="astrological_framework"].active { border-color: rgba(118,75,162,0.6); background: rgba(118,75,162,0.08); }
    .methods-disc-btn[data-disc="interpretation_layer"] { border-left: 3px solid rgba(122,158,126,0.4); }
    .methods-disc-btn[data-disc="interpretation_layer"].active { border-color: rgba(122,158,126,0.6); background: rgba(122,158,126,0.08); }
    .methods-disc-btn[data-disc="kabbalistic_angel_system"] { border-left: 3px solid var(--gold-border); }
    .methods-disc-btn[data-disc="kabbalistic_angel_system"].active { border-color: var(--gold); background: rgba(201,168,76,0.08); }
    .methods-disc-icon { font-size: 1.1rem; }
    .methods-disc-label { font-size: 0.65rem; color: var(--cream-muted); font-family: var(--font-body); font-weight: 400; line-height: 1.2; }
    .methods-disc-btn.active .methods-disc-label { color: var(--cream); }
    .methods-disc-count { font-size: 0.55rem; color: rgba(196,191,181,0.4); font-family: var(--font-mono); margin-top: 0.1rem; }
    .methods-pills { display: flex; flex-wrap: wrap; gap: 0.35rem; margin-top: 0.5rem; max-height: 120px; overflow-y: auto; }
    .methods-pill { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08); border-radius: 1rem; color: var(--cream-muted); font-size: 0.7rem; padding: 0.2rem 0.6rem; cursor: pointer; transition: all 0.15s; font-family: var(--font-body); -webkit-tap-highlight-color: transparent; }
    .methods-pill:hover { border-color: rgba(201,168,76,0.3); color: var(--cream); }
    .methods-pill.active { border-color: var(--gold-border); color: var(--gold); background: rgba(201,168,76,0.08); }
    .methods-no-results { text-align: center; padding: 2rem 1rem; color: var(--cream-muted); font-size: 0.85rem; font-style: italic; }
    .methodology-section.search-hidden { display: none; }
    .methods-learn-callout {
      margin-bottom: 1rem;
      padding: 1rem;
      border-radius: 1rem;
      border: 1px solid rgba(201,168,76,0.16);
      background:
        radial-gradient(circle at top right, rgba(201,168,76,0.08), transparent 30%),
        linear-gradient(155deg, rgba(17,17,34,0.9), rgba(8,8,15,0.96));
    }
    .methods-learn-header {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 1rem;
      margin-bottom: 0.9rem;
    }
    .methods-learn-kicker {
      font-family: var(--font-mono);
      font-size: 0.6rem;
      text-transform: uppercase;
      letter-spacing: 0.16em;
      color: var(--gold);
      margin-bottom: 0.35rem;
    }
    .methods-learn-title {
      margin: 0 0 0.35rem;
      font-family: var(--font-display);
      font-size: 1.2rem;
      color: var(--cream);
    }
    .methods-learn-copy {
      margin: 0;
      font-size: 0.84rem;
      line-height: 1.7;
      color: var(--cream-muted);
      max-width: 620px;
    }
    .methods-learn-overview {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      white-space: nowrap;
      padding: 0.55rem 0.85rem;
      border-radius: 999px;
      text-decoration: none;
      color: var(--gold-light);
      border: 1px solid rgba(201,168,76,0.22);
      background: rgba(201,168,76,0.08);
      font-size: 0.72rem;
      font-family: var(--font-mono);
      letter-spacing: 0.06em;
      text-transform: uppercase;
    }
    .methods-learn-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 0.85rem;
    }
    .methods-learn-card {
      overflow: hidden;
      border-radius: 0.9rem;
      border: 1px solid rgba(255,255,255,0.06);
      background: rgba(255,255,255,0.03);
      text-decoration: none;
      transition: transform 0.18s ease, border-color 0.18s ease;
    }
    .methods-learn-card:hover {
      transform: translateY(-2px);
      border-color: rgba(201,168,76,0.2);
    }
    .methods-learn-card-art {
      display: block;
      width: 100%;
      height: 148px;
      object-fit: cover;
      border-bottom: 1px solid rgba(255,255,255,0.05);
      opacity: 0.86;
    }
    .methods-learn-card-body { padding: 0.85rem 0.9rem 0.95rem; }
    .methods-learn-card-kicker {
      margin-bottom: 0.28rem;
      font-family: var(--font-mono);
      font-size: 0.58rem;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: var(--gold);
    }
    .methods-learn-card h5 {
      margin: 0 0 0.35rem;
      font-family: var(--font-display);
      font-size: 1rem;
      color: var(--cream);
    }
    .methods-learn-card p {
      margin: 0;
      font-size: 0.79rem;
      line-height: 1.6;
      color: var(--cream-muted);
    }
    @media (max-width: 900px) {
      .methods-learn-grid { grid-template-columns: 1fr; }
      .methods-learn-card-art { height: 170px; }
    }
    @media (max-width: 767px) {
      .methods-learn-header {
        flex-direction: column;
        align-items: flex-start;
      }
    }

    .settings-learn-links {
      display: grid;
      gap: 0.6rem;
      margin-top: 0.75rem;
    }
    .settings-learn-card {
      display: block;
      padding: 0.8rem 0.9rem;
      border-radius: 0.8rem;
      text-decoration: none;
      background: rgba(255,255,255,0.03);
      border: 1px solid rgba(255,255,255,0.06);
      transition: border-color 0.15s ease, transform 0.15s ease;
    }
    .settings-learn-card:hover {
      border-color: rgba(201,168,76,0.24);
      transform: translateY(-1px);
    }
    .settings-learn-label {
      display: block;
      color: var(--cream);
      font-size: 0.88rem;
      margin-bottom: 0.2rem;
    }
    .settings-learn-desc {
      display: block;
      color: var(--cream-muted);
      font-size: 0.76rem;
      line-height: 1.55;
    }

    /* ── HOUSE RANGE ── */
    .house-range { font-family: var(--font-mono); font-size: 0.65rem; color: rgba(196,191,181,0.72); margin-top: 0.1rem; letter-spacing: 0.01em; }
    .house-range-inline { margin-top: 0; display: flex; align-items: baseline; justify-content: flex-start; gap: 0.35rem; text-align: left; line-height: 1; max-width: none; flex-wrap: wrap; }
    .house-range-segment { display: inline-flex; align-items: baseline; gap: 0.22rem; font-size: 0.62rem; }
    .house-range-sign { font-family: var(--font-display); font-size: 0.82rem; line-height: 1; color: var(--gold-light); }
    .house-range-degrees { font-size: 0.56rem; opacity: 0.92; color: var(--gold-light); }
    .house-range-arrow { display: inline-block; margin: 0 0.12rem; color: rgba(196,191,181,0.58); }

    /* ── ONBOARDING WALKTHROUGH ── */
    /* ── WELCOME SHOWCASE ── */
    .ws-overlay {
      position: fixed; inset: 0; z-index: 10000;
      background: rgba(4,4,10,0.95);
      opacity: 0; transition: opacity 0.4s ease;
      pointer-events: none; display: flex;
      align-items: center; justify-content: center;
      overflow-y: auto;
    }
    .ws-overlay.ws-active { opacity: 1; pointer-events: auto; }
    .ws-slide {
      max-width: 420px; width: calc(100vw - 2rem);
      text-align: center; padding: 2rem 1.5rem;
      animation: wsFadeIn 0.5s ease both;
    }
    @keyframes wsFadeIn { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
    .ws-icon { font-size: 3.5rem; margin-bottom: 0.8rem; line-height: 1; }
    .ws-title {
      font-family: var(--font-display); font-size: 1.5rem;
      color: var(--gold-light); margin-bottom: 0.4rem; font-weight: 500;
    }
    .ws-subtitle {
      font-size: 0.8rem; color: var(--cream-muted); opacity: 0.7;
      text-transform: uppercase; letter-spacing: 0.12em;
      margin-bottom: 1.2rem;
    }
    .ws-body {
      font-size: 0.9rem; color: var(--cream-muted); line-height: 1.7;
      margin-bottom: 1.5rem; font-weight: 300;
    }
    .ws-angel-name {
      font-family: var(--font-display); font-size: 1.8rem;
      color: var(--gold); margin-bottom: 0.3rem;
    }
    .ws-angel-meaning {
      font-size: 0.85rem; color: var(--cream-muted); font-style: italic;
      margin-bottom: 1rem;
    }
    .ws-angel-domain {
      font-size: 0.82rem; color: var(--cream-muted); line-height: 1.6;
      margin-bottom: 1.2rem; opacity: 0.85;
    }
    .ws-triad { display: flex; gap: 1rem; justify-content: center; margin-bottom: 1.5rem; flex-wrap: wrap; }
    .ws-triad-item {
      flex: 1; min-width: 90px; max-width: 120px;
      background: rgba(201,168,76,0.06); border: 1px solid rgba(201,168,76,0.15);
      border-radius: 10px; padding: 0.8rem 0.5rem;
    }
    .ws-triad-label { font-size: 0.6rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--cream-muted); opacity: 0.6; margin-bottom: 0.3rem; }
    .ws-triad-sign { font-size: 1.1rem; color: var(--gold-light); font-family: var(--font-display); }
    .ws-triad-element { font-size: 0.6rem; color: var(--cream-muted); opacity: 0.5; margin-top: 0.2rem; text-transform: lowercase; }
    .ws-triad-angel-name { font-family: var(--font-display); font-size: 1rem; color: var(--gold); margin-bottom: 0.15rem; }
    .ws-triad-angel-meaning { font-size: 0.68rem; color: var(--cream-muted); font-style: italic; opacity: 0.8; }
    .ws-triad-guardian {
      max-width: 180px; min-width: 140px;
      background: rgba(201,168,76,0.1); border: 1px solid rgba(201,168,76,0.3);
      border-radius: 10px; padding: 1.2rem 1rem;
      margin: 0 auto 1rem auto;
    }
    .ws-triad-guardian .ws-triad-angel-name { font-size: 1.3rem; }
    .ws-triad-secondary {
      display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap;
      margin-bottom: 1.5rem;
    }
    .ws-dots { display: flex; gap: 6px; justify-content: center; margin-bottom: 1rem; }
    .ws-dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: rgba(255,255,255,0.15); transition: all 0.2s;
    }
    .ws-dot.ws-active { background: var(--gold); width: 18px; border-radius: 3px; }
    .ws-dot.ws-done { background: rgba(201,168,76,0.4); }
    .ws-btns { display: flex; gap: 10px; justify-content: center; }
    .ws-btn {
      font-family: var(--font-mono); font-size: 0.72rem;
      text-transform: uppercase; letter-spacing: 0.08em;
      padding: 8px 20px; border-radius: 8px;
      border: 1px solid rgba(201,168,76,0.3); background: none;
      color: var(--cream-muted); cursor: pointer; transition: all 0.15s;
    }
    .ws-btn:hover { color: var(--cream); border-color: rgba(201,168,76,0.5); }
    .ws-btn-primary {
      background: linear-gradient(135deg, rgba(201,168,76,0.2), rgba(201,168,76,0.1));
      color: var(--gold); border-color: rgba(201,168,76,0.4);
    }
    .ws-btn-primary:hover { background: rgba(201,168,76,0.25); color: var(--gold-light); }
    .ws-skip {
      font-family: var(--font-mono); font-size: 0.6rem;
      color: var(--cream-muted); background: none; border: none;
      cursor: pointer; text-transform: uppercase; letter-spacing: 0.1em;
      opacity: 0.5; transition: opacity 0.15s; margin-top: 0.8rem;
    }
    .ws-skip:hover { opacity: 1; }
    .ws-img {
      display: block;
      max-width: 156px;
      max-height: 156px;
      margin: 0 auto 0.9rem;
      border-radius: 1rem;
      opacity: 0.82;
      object-fit: cover;
    }
    .ws-angel-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 0.8rem;
      margin-bottom: 1rem;
    }
    .ws-angel-grid-primary {
      grid-template-columns: minmax(0, 1fr);
      max-width: 218px;
      margin: 0 auto 0.9rem;
    }
    .ws-angel-card {
      position: relative;
      overflow: hidden;
      border-radius: 16px;
      border: 1px solid rgba(201,168,76,0.18);
      background: linear-gradient(180deg, rgba(18,20,34,0.98), rgba(12,14,24,0.98));
      box-shadow: 0 18px 38px rgba(0,0,0,0.25);
    }
    .ws-angel-card::before {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(180deg, rgba(255,255,255,0.06), transparent 32%, rgba(0,0,0,0.08));
      pointer-events: none;
    }
    .ws-angel-card-header {
      position: absolute;
      top: 0.55rem;
      left: 50%;
      transform: translateX(-50%);
      z-index: 2;
      padding: 0.32rem 0.76rem;
      border-radius: 999px;
      border: 1px solid rgba(214,182,95,0.28);
      background: linear-gradient(180deg, rgba(10,12,18,0.94), rgba(7,9,15,0.88));
      color: var(--gold-light);
      font-family: var(--font-mono);
      font-size: 0.56rem;
      letter-spacing: 0.26em;
      text-transform: uppercase;
      white-space: nowrap;
    }
    .ws-angel-card-art-wrap {
      position: relative;
      height: 180px;
      overflow: hidden;
      background: radial-gradient(circle at 50% 50%, rgba(214,182,95,0.18), transparent 58%), rgba(14,16,26,0.96);
    }
    .ws-angel-card-art {
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center 56%;
      display: block;
      opacity: 0.94;
      filter: contrast(1.05) saturate(1.1);
    }
    .ws-angel-card-body {
      position: relative;
      z-index: 1;
      padding: 0.72rem 0.8rem 0.82rem;
      background: linear-gradient(180deg, rgba(11,12,20,0.18), rgba(10,12,18,0.74));
    }
    .ws-big-three-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 0.72rem;
      margin-bottom: 1rem;
    }
    .ws-big-three-card {
      position: relative;
      border-radius: 16px;
      overflow: hidden;
      border: 1px solid rgba(214,182,95,0.16);
      background: linear-gradient(180deg, rgba(16,18,30,0.96), rgba(11,13,22,0.98));
      box-shadow: 0 14px 32px rgba(0,0,0,0.24);
      padding: 0.6rem 0.52rem 0.75rem;
    }
    .ws-big-three-header {
      position: relative;
      z-index: 2;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 1.4rem;
      padding: 0.18rem 0.55rem;
      margin-bottom: 0.45rem;
      border-radius: 999px;
      border: 1px solid rgba(214,182,95,0.24);
      background: linear-gradient(180deg, rgba(8,10,16,0.92), rgba(8,10,16,0.76));
      color: var(--gold-light);
      font-family: var(--font-mono);
      font-size: 0.54rem;
      letter-spacing: 0.22em;
      text-transform: uppercase;
    }
    .ws-big-three-medallion {
      position: relative;
      width: 100%;
      aspect-ratio: 1 / 1.08;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .ws-big-three-art,
    .ws-big-three-frame {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      border-radius: 14px;
    }
    .ws-big-three-art {
      opacity: 0.95;
    }
    .ws-big-three-frame {
      pointer-events: none;
      opacity: 0.94;
    }
    .ws-big-three-copy {
      position: relative;
      z-index: 1;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 0.16rem;
      min-height: 56%;
      min-width: 70%;
      padding: 0.6rem 0.45rem;
      border-radius: 999px;
      background: radial-gradient(circle, rgba(8,10,16,0.74), rgba(8,10,16,0.48) 64%, transparent 78%);
    }
    .ws-big-three-sign {
      font-family: var(--font-display);
      font-size: 1rem;
      line-height: 1;
      color: #f7ecd1;
    }
    .ws-big-three-element {
      font-size: 0.6rem;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(245,234,205,0.72);
    }
    .ws-big-three-fire .ws-big-three-copy {
      box-shadow: 0 0 20px rgba(245,138,54,0.18);
    }
    .ws-big-three-earth .ws-big-three-copy {
      box-shadow: 0 0 20px rgba(147,173,109,0.18);
    }
    .ws-big-three-air .ws-big-three-copy {
      box-shadow: 0 0 20px rgba(125,208,224,0.18);
    }
    .ws-big-three-water .ws-big-three-copy {
      box-shadow: 0 0 20px rgba(115,165,232,0.2);
    }
    .ws-big-three-synthesis {
      margin-top: 0.25rem;
      padding: 0.9rem 1rem;
      border-radius: 16px;
      border: 1px solid rgba(214,182,95,0.16);
      background:
        radial-gradient(circle at top, rgba(201,168,76,0.08), transparent 42%),
        linear-gradient(180deg, rgba(14,16,26,0.94), rgba(10,12,20,0.98));
      text-align: left;
      box-shadow: 0 14px 32px rgba(0,0,0,0.18);
    }
    .ws-big-three-synthesis-title {
      font-family: var(--font-display);
      font-size: 1rem;
      color: var(--gold-light);
      margin-bottom: 0.28rem;
    }
    .ws-big-three-synthesis-deck {
      font-size: 0.66rem;
      line-height: 1.6;
      color: rgba(245,234,205,0.68);
      margin-bottom: 0.65rem;
    }
    .ws-big-three-synthesis-copy {
      font-size: 0.76rem;
      line-height: 1.65;
      color: rgba(245,234,205,0.8);
    }
    .ws-big-three-synthesis-card {
      padding: 0.7rem 0.8rem;
      border-radius: 12px;
      border: 1px solid rgba(214,182,95,0.12);
      background: rgba(255,255,255,0.02);
    }
    .ws-big-three-synthesis-card + .ws-big-three-synthesis-card {
      margin-top: 0.55rem;
    }
    .ws-big-three-synthesis-card-label {
      font-family: var(--font-mono);
      font-size: 0.56rem;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: rgba(214,182,95,0.76);
      margin-bottom: 0.24rem;
    }
    .ws-big-three-synthesis-card-title {
      font-family: var(--font-display);
      font-size: 0.88rem;
      color: var(--gold-light);
      margin-bottom: 0.28rem;
      line-height: 1.25;
    }
    .ws-big-three-synthesis-copy + .ws-big-three-synthesis-copy {
      margin-top: 0.5rem;
    }
    .ws-divider {
      width: 60px; height: 1px; margin: 0 auto 1rem;
      background: linear-gradient(90deg, transparent, rgba(201,168,76,0.3), transparent);
    }
    @media (max-width: 767px) {
      .ws-slide { padding: 1.5rem 1rem; }
      .ws-title { font-size: 1.3rem; }
      .ws-img { max-width: 126px; max-height: 126px; }
      .ws-triad { gap: 0.6rem; }
      .ws-triad-guardian { max-width: 160px; }
      .ws-triad-secondary { gap: 0.6rem; }
      .ws-angel-grid {
        grid-template-columns: 1fr;
        gap: 0.7rem;
      }
      .ws-angel-grid-primary {
        max-width: 200px;
      }
      .ws-angel-card-art-wrap {
        height: 160px;
      }
      .ws-big-three-grid {
        grid-template-columns: 1fr;
        gap: 0.65rem;
      }
      .ws-big-three-card {
        padding: 0.56rem 0.52rem 0.68rem;
      }
      .ws-big-three-medallion {
        aspect-ratio: 1 / 0.74;
      }
      .ws-big-three-sign {
        font-size: 1.05rem;
      }
      .ws-big-three-synthesis {
        padding: 0.8rem 0.85rem;
      }
    }

    /* ── UX WALKTHROUGH ── */
    .wt-overlay {
      position: fixed; inset: 0; z-index: 10000;
      opacity: 0; transition: opacity 0.3s ease;
      pointer-events: none;
    }
    .wt-overlay.wt-active { opacity: 1; pointer-events: auto; }
    /* When no spotlight is visible, the overlay itself dims the screen */
    .wt-overlay.wt-active::before {
      content: ''; position: absolute; inset: 0;
      background: rgba(4,4,10,0.82);
    }
    @keyframes wtSpotlightPulse {
      0%, 100% { box-shadow: 0 0 0 9999px rgba(4,4,10,0.82), 0 0 0 2px rgba(201,168,76,0.25), 0 0 24px rgba(201,168,76,0.08); }
      50%      { box-shadow: 0 0 0 9999px rgba(4,4,10,0.82), 0 0 0 2px rgba(201,168,76,0.35), 0 0 32px rgba(201,168,76,0.12); }
    }
    .wt-spotlight {
      position: fixed; border-radius: 12px;
      box-shadow: 0 0 0 9999px rgba(4,4,10,0.82), 0 0 0 2px rgba(201,168,76,0.25), 0 0 24px rgba(201,168,76,0.08);
      background: transparent;
      transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
      z-index: 10001;
    }
    .wt-overlay.wt-has-spotlight .wt-spotlight { animation: wtSpotlightPulse 2.5s ease-in-out infinite; }
    /* When spotlight is active, it provides the dimming via box-shadow — hide overlay bg */
    .wt-overlay.wt-has-spotlight::before { display: none; }
    .wt-card {
      position: absolute; z-index: 10002;
      background: linear-gradient(160deg, #1a1a32 0%, #12121f 100%);
      border: 1px solid rgba(201,168,76,0.25);
      border-radius: var(--radius-card);
      box-shadow: 0 8px 40px rgba(0,0,0,0.6);
      padding: 1.5rem;
      max-width: 340px; width: calc(100vw - 2rem);
      transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
      opacity: 0; transform: translateY(10px);
    }
    .wt-card.wt-visible { opacity: 1; transform: translateY(0); }
    .wt-card::before {
      content: ''; position: absolute; top: 0; left: 10%; right: 10%; height: 1px;
      background: linear-gradient(90deg, transparent, rgba(201,168,76,0.2), transparent);
    }
    .wt-card h3 {
      font-family: var(--font-display);
      font-size: 1.1rem; color: var(--gold-light);
      margin-bottom: 0.6rem; font-weight: 500;
    }
    .wt-card p {
      font-size: 0.85rem; color: var(--cream-muted);
      line-height: 1.65; margin-bottom: 1rem; font-weight: 300;
    }
    .wt-card p:last-of-type { margin-bottom: 0.8rem; }
    .wt-footer {
      display: flex; align-items: center; justify-content: space-between;
      padding-top: 0.6rem; border-top: 1px solid rgba(255,255,255,0.06);
    }
    .wt-dots {
      display: flex; gap: 6px;
    }
    .wt-dot {
      width: 6px; height: 6px; border-radius: 50%;
      background: rgba(255,255,255,0.15); transition: all 0.2s;
    }
    .wt-dot.wt-dot-active { background: var(--gold); width: 18px; border-radius: 3px; }
    .wt-dot.wt-dot-done { background: rgba(201,168,76,0.4); }
    .wt-btns { display: flex; gap: 8px; }
    .wt-btn {
      font-family: var(--font-mono); font-size: 0.7rem;
      text-transform: uppercase; letter-spacing: 0.08em;
      padding: 6px 14px; border-radius: 6px;
      border: 1px solid rgba(201,168,76,0.3); background: none;
      color: var(--cream-muted); cursor: pointer; transition: all 0.15s;
    }
    .wt-btn:hover { color: var(--cream); border-color: rgba(201,168,76,0.5); }
    .wt-btn-primary {
      background: linear-gradient(135deg, rgba(201,168,76,0.2), rgba(201,168,76,0.1));
      color: var(--gold); border-color: rgba(201,168,76,0.4);
    }
    .wt-btn-primary:hover { background: rgba(201,168,76,0.25); color: var(--gold-light); }
    .wt-skip {
      font-family: var(--font-mono); font-size: 0.6rem;
      color: var(--cream-muted); background: none; border: none;
      cursor: pointer; text-transform: uppercase; letter-spacing: 0.1em;
      opacity: 0.6; transition: opacity 0.15s;
    }
    .wt-skip:hover { opacity: 1; }
    .wt-welcome-icon {
      font-size: 2.5rem; text-align: center;
      margin-bottom: 0.6rem; line-height: 1;
    }
    @media (max-width: 767px) {
      .wt-card { max-width: calc(100vw - 1.5rem); padding: 1.2rem; }
      .wt-card h3 { font-size: 1rem; }
      .wt-card p { font-size: 0.82rem; }
    }

    /* ── Empty states ── */
    .empty-state {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 3rem 1.5rem;
      text-align: center;
      color: var(--cream-muted);
      font-family: 'Outfit', sans-serif;
    }
    .empty-state-icon {
      font-size: 2.5rem;
      margin-bottom: 1rem;
      opacity: 0.5;
    }
    .empty-state-title {
      font-size: 1.1rem;
      font-weight: 500;
      color: var(--cream);
      margin-bottom: 0.5rem;
    }
    .empty-state-desc {
      font-size: 0.9rem;
      max-width: 280px;
      line-height: 1.5;
    }

    /* ── Focus-visible ── */
    *:focus-visible {
      outline: 2px solid var(--gold);
      outline-offset: 2px;
    }
    input:focus-visible, textarea:focus-visible, select:focus-visible {
      outline: 2px solid var(--gold);
      outline-offset: 0;
      box-shadow: 0 0 0 4px rgba(201,168,76,0.15);
    }
    button:focus-visible, a:focus-visible {
      outline: 2px solid var(--gold);
      outline-offset: 2px;
      border-radius: 2px;
    }

    /* ── Skip link ── */
    .skip-link {
      position: absolute;
      top: -100%;
      left: 1rem;
      padding: 0.5rem 1rem;
      background: var(--gold);
      color: var(--ink);
      font-family: 'Outfit', sans-serif;
      font-weight: 600;
      border-radius: 0 0 4px 4px;
      z-index: 10000;
      text-decoration: none;
    }
    .skip-link:focus {
      top: 0;
    }

    /* ===================================================================
       ADMIN CONSOLE — styles for htdocs/admin.php and assets/js/admin/*
       =================================================================== */

    /* ── Admin pill in profile header (visible to admins only) ── */
    .admin-pill {
      display: inline-flex; align-items: center; gap: 0.3rem;
      padding: 0.3rem 0.7rem; border-radius: 999px;
      background: rgba(201,168,76,0.08); border: 1px solid rgba(201,168,76,0.25);
      color: var(--gold); text-decoration: none;
      font-family: var(--font-mono); font-size: 0.72rem;
      letter-spacing: 0.06em; text-transform: uppercase;
      transition: all 0.2s;
    }
    .admin-pill:hover {
      background: rgba(201,168,76,0.18); border-color: rgba(201,168,76,0.5);
      color: var(--gold-light);
    }
    .admin-pill[hidden] { display: none; }

    /* ── Back link in admin page header ── */
    .admin-back-link {
      display: inline-flex; align-items: center; gap: 0.35rem;
      color: var(--gold); font-size: 0.82rem; text-decoration: none;
      font-family: var(--font-mono); letter-spacing: 0.04em;
      margin-left: auto; transition: color 0.2s;
      border-bottom: 1px solid transparent;
    }
    .admin-back-link:hover {
      color: var(--gold-light);
      border-bottom-color: rgba(201,168,76,0.45);
    }

    /* ── Stat grid ── */
    .admin-stat-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
      gap: 0.75rem;
    }

    /* ── Stat tile ── */
    .admin-stat-tile {
      background: var(--ink-card);
      border: 1px solid rgba(255,255,255,0.07);
      border-radius: var(--radius-sm);
      box-shadow: var(--shadow-card);
      padding: 1rem;
      display: flex; flex-direction: column; gap: 0.35rem;
      position: relative; overflow: hidden;
      transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
    }
    .admin-stat-tile::before {
      content: ''; position: absolute; top: 0; left: 8%; right: 8%; height: 1px;
      background: linear-gradient(90deg, transparent, rgba(201,168,76,0.12), transparent);
      pointer-events: none;
    }
    .admin-stat-tile-label {
      font-family: var(--font-mono); font-size: 0.6rem; text-transform: uppercase;
      letter-spacing: 0.12em; color: var(--cream-muted);
    }
    .admin-stat-tile-value {
      font-size: 1.7rem; font-weight: 600; color: var(--gold);
      line-height: 1.1; font-family: var(--font-display);
    }
    .admin-stat-tile-icon {
      position: absolute; top: 0.75rem; right: 0.9rem;
      font-size: 1.2rem; opacity: 0.45;
    }

    .admin-stat-tile:hover {
      transform: translateY(-2px);
      border-color: var(--gold-border);
      box-shadow: 0 6px 28px rgba(0,0,0,0.45), 0 0 0 1px rgba(201,168,76,0.08);
    }
    .admin-stat-tile:hover .admin-stat-tile-icon { opacity: 0.7; }

    /* ── Admin banner (comped / trial disclaimer) ── */
    .admin-banner {
      background: rgba(201,160,60,0.07);
      border: 1px solid rgba(201,160,60,0.26);
      border-radius: var(--radius-sm);
      padding: 0.75rem 1rem;
      font-size: 0.82rem; color: var(--gold-light);
      display: flex; align-items: flex-start; gap: 0.6rem;
      margin-bottom: 1rem;
    }
    .admin-banner-icon { flex-shrink: 0; font-size: 1rem; margin-top: 0.05rem; }

    /* ── Lifecycle bars ── */
    .admin-bars {
      display: flex; flex-direction: column; gap: 0.5rem;
    }
    .admin-bar {
      display: flex; align-items: center; gap: 0.65rem;
      font-size: 0.78rem; color: var(--cream-muted);
    }
    .admin-bar-label {
      min-width: 8rem; flex-shrink: 0;
      font-family: var(--font-mono); font-size: 0.7rem;
      overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .admin-bar-track {
      flex: 1; height: 8px;
      background: rgba(255,255,255,0.07);
      border-radius: 4px; overflow: hidden;
    }
    .admin-bar-fill {
      height: 100%; background: var(--gold);
      border-radius: 4px; transition: width 0.4s ease;
    }
    .admin-bar-value {
      min-width: 2.5rem; text-align: right;
      color: var(--cream); font-weight: 500; font-size: 0.75rem;
      font-family: var(--font-mono);
    }

    /* ── Admin table ── */
    .admin-table {
      width: 100%; border-collapse: collapse;
      font-size: 0.83rem; font-family: var(--font-body);
    }
    .admin-table th {
      position: sticky; top: 0; z-index: 2;
      background: var(--ink-card-alt);
      color: var(--cream-muted); font-family: var(--font-mono);
      font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.1em;
      padding: 0.6rem 0.85rem; text-align: left; font-weight: 500;
      border-bottom: 1px solid rgba(255,255,255,0.07);
    }
    .admin-table td {
      padding: 0.55rem 0.85rem; vertical-align: middle;
      border-bottom: 1px solid rgba(255,255,255,0.04);
      color: var(--cream);
    }
    .admin-table tbody tr:nth-child(even) td { background: rgba(255,255,255,0.025); }
    .admin-table tbody tr:hover td { background: rgba(201,168,76,0.06); }

    /* ── Admin badge (pill) ── */
    .admin-badge {
      display: inline-flex; align-items: center;
      padding: 0.18rem 0.6rem; border-radius: 2rem;
      font-size: 0.68rem; font-family: var(--font-mono);
      text-transform: uppercase; letter-spacing: 0.06em; font-weight: 500;
      border: 1px solid transparent;
    }
    .admin-badge-active {
      color: var(--sage); border-color: rgba(122,158,126,0.38);
      background: rgba(122,158,126,0.1);
    }
    .admin-badge-inactive {
      color: var(--cream-muted); border-color: rgba(255,255,255,0.1);
      background: rgba(255,255,255,0.05);
    }
    .admin-badge-deleted {
      color: var(--warm); border-color: rgba(199,125,106,0.3);
      background: rgba(199,125,106,0.08);
    }
    .admin-badge-admin {
      color: var(--gold-light); border-color: var(--gold-border);
      background: var(--gold-soft);
    }
    .admin-badge-trial {
      color: #a8c4e0; border-color: rgba(168,196,224,0.3);
      background: rgba(168,196,224,0.08);
    }
    .admin-badge-muted {
      color: var(--cream-muted); border-color: rgba(255,255,255,0.08);
      background: rgba(255,255,255,0.03);
    }

    /* ── Per-row action dropdown ── */
    .admin-row-actions {
      position: relative; display: inline-block;
    }
    .admin-row-actions-menu {
      position: absolute; right: 0; top: 100%; z-index: 200;
      min-width: 160px;
      background: var(--ink-card);
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: var(--radius-sm);
      box-shadow: 0 8px 32px rgba(0,0,0,0.6);
      padding: 0.35rem 0;
      display: none;
    }
    .admin-row-actions-menu.open { display: block; }
    .admin-row-action-item {
      display: block; width: 100%;
      padding: 0.5rem 0.9rem;
      text-align: left; font-size: 0.82rem;
      color: var(--cream-muted); background: none; border: none;
      cursor: pointer; transition: background 0.15s, color 0.15s;
      font-family: var(--font-body);
    }
    .admin-row-action-item:hover {
      background: rgba(255,255,255,0.06); color: var(--cream);
    }
    .admin-row-action-item.danger { color: var(--warm); }
    .admin-row-action-item.danger:hover {
      background: rgba(199,125,106,0.12); color: #e8a898;
    }

    /* ── Full-screen overlay / backdrop ── */
    .admin-overlay {
      position: fixed; inset: 0; z-index: 900;
      background: rgba(8,8,15,0.82);
      backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
      display: flex; align-items: center; justify-content: center;
    }
    .admin-overlay[hidden] { display: none; }
    .admin-overlay:not([hidden]) { display: flex !important; }

    /* ── Modal chrome inside overlay ── */
    .admin-modal {
      background: var(--ink-card);
      border: 1px solid rgba(255,255,255,0.09);
      border-radius: var(--radius-card);
      box-shadow: 0 8px 48px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.04);
      width: min(560px, calc(100% - 2rem));
      max-height: 90vh; overflow-y: auto;
      display: flex; flex-direction: column;
      position: relative;
    }
    .admin-modal-header {
      background: linear-gradient(135deg, #252545 0%, #1c1c38 100%);
      border-bottom: 1px solid rgba(201,168,76,0.16);
      color: var(--gold-light);
      padding: 0.9rem 1.25rem;
      font-weight: 500; font-size: 0.92rem;
      font-family: var(--font-display);
      display: flex; align-items: center; justify-content: space-between;
      flex-shrink: 0;
    }
    .admin-modal-body { padding: 1.25rem; flex: 1; }
    .admin-modal-close {
      display: flex; align-items: center; justify-content: center;
      width: 2rem; height: 2rem; border-radius: 50%;
      color: var(--cream-muted); background: none; border: none;
      cursor: pointer; font-size: 1.1rem;
      transition: background 0.15s, color 0.15s;
    }
    .admin-modal-close:hover { background: rgba(255,255,255,0.08); color: var(--cream); }

    /* ── Clickable user ID button ── */
    .admin-id-btn {
      background: none; border: none; padding: 0;
      color: var(--gold-light); font: inherit;
      text-decoration: underline; text-decoration-style: dotted;
      cursor: pointer;
    }
    .admin-id-btn:hover { color: var(--gold); text-decoration: none; }

    /* ── Themed input used inside admin modals (e.g. adminPrompt) ── */
    .admin-input {
      background: var(--ink-card-alt);
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: var(--radius-sm);
      color: var(--cream);
      padding: 0.5rem 0.75rem;
      font-size: 0.92rem;
      font-family: var(--font-body);
      transition: border-color 0.15s;
    }
    .admin-input:focus { border-color: var(--gold-border); outline: none; }

    /* ── adminPrompt dialog (themed window.prompt replacement) ── */
    .admin-prompt-footer {
      display: flex; justify-content: flex-end; gap: 0.5rem;
      padding: 0.75rem 1.25rem 1.1rem;
      border-top: 1px solid rgba(255,255,255,0.07);
    }
    .admin-prompt-message {
      margin: 0 0 0.85rem;
      color: var(--cream-muted); font-size: 0.9rem; line-height: 1.5;
    }
    .admin-prompt-input {
      width: 100%; box-sizing: border-box;
    }

    /* ── Filter bar above tables ── */
    .admin-filter-bar {
      display: flex; flex-wrap: wrap; gap: 0.5rem;
      align-items: center; margin-bottom: 0.75rem;
    }
    .admin-filter-bar input,
    .admin-filter-bar select {
      background: var(--ink-card-alt);
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: var(--radius-sm);
      color: var(--cream); padding: 0.45rem 0.75rem;
      font-size: 0.82rem; font-family: var(--font-body);
      transition: border-color 0.2s;
    }
    .admin-filter-bar input:focus,
    .admin-filter-bar select:focus { border-color: var(--gold-border); outline: none; }

    /* Explicit filter element class aliases (JS uses these class names) */
    .admin-filter-input,
    .admin-filter-select {
      background: var(--ink-card-alt);
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: var(--radius-sm);
      color: var(--cream); padding: 0.4rem 0.65rem;
      font-size: 0.82rem; font-family: var(--font-body);
      transition: border-color 0.2s;
    }
    .admin-filter-input:focus,
    .admin-filter-select:focus { border-color: var(--gold-border); outline: none; }
    .admin-users-filter-bar { display: flex; flex-wrap: wrap; gap: 0.5rem; align-items: center; margin-bottom: 0.75rem; }
    .admin-users-filter-card { margin-bottom: 0.85rem; }

    /* ── Pagination ── */
    .admin-pagination {
      display: flex; align-items: center; justify-content: center;
      gap: 0.3rem; margin-top: 0.75rem; flex-wrap: wrap;
    }
    .admin-pagination-btn {
      padding: 0.35rem 0.7rem; border-radius: var(--radius-sm);
      border: 1px solid rgba(255,255,255,0.1);
      background: var(--ink-card-alt); color: var(--cream-muted);
      font-size: 0.78rem; font-family: var(--font-mono);
      cursor: pointer; transition: all 0.15s;
    }
    .admin-pagination-btn:hover { border-color: var(--gold-border); color: var(--gold-light); }
    .admin-pagination-btn.active {
      background: var(--gold-soft); border-color: var(--gold-border);
      color: var(--gold-light); font-weight: 600;
    }
    .admin-pagination-btn:disabled {
      opacity: 0.35; cursor: default; pointer-events: none;
    }

    /* ── Toast notification ── */
    .admin-toast {
      position: fixed; bottom: 1.25rem; right: 1.25rem; z-index: 9500;
      display: flex; align-items: center; gap: 0.5rem;
      padding: 0.55rem 1rem; border-radius: 2rem;
      font-size: 0.82rem; font-family: var(--font-body);
      box-shadow: 0 4px 24px rgba(0,0,0,0.5);
      background: var(--ink-card); border: 1px solid rgba(255,255,255,0.1);
      color: var(--cream);
      opacity: 1; transition: opacity 0.4s ease;
    }
    .admin-toast.fading { opacity: 0; pointer-events: none; }
    .admin-toast-info {
      border-color: rgba(168,196,224,0.3); background: rgba(168,196,224,0.1);
      color: #c0d8f0;
    }
    .admin-toast-success {
      border-color: rgba(122,158,126,0.38); background: rgba(122,158,126,0.1);
      color: var(--sage);
    }
    .admin-toast-error {
      border-color: rgba(199,125,106,0.35); background: rgba(199,125,106,0.1);
      color: #e8a898;
    }

    /* ── Status pill below action groups ── */
    .admin-status-pill {
      margin-top: 0.85rem;
      min-height: 1.1rem;
      font-size: 0.74rem;
      color: var(--sage);
      line-height: 1.5;
    }
    .admin-status-pill.error { color: #e8a898; }

    /* ── Sub-tabs inside audit pane ── */
    .admin-sub-tabs {
      display: flex; gap: 0.2rem; flex-wrap: wrap;
      margin-bottom: 0.85rem;
      border-bottom: 1px solid rgba(255,255,255,0.06);
      padding-bottom: 0.35rem;
    }
    .admin-sub-tabs .admin-sub-tab {
      background: transparent; border: none; color: var(--cream-muted);
      padding: 0.35rem 0.85rem; border-radius: var(--radius-sm);
      cursor: pointer; font-size: 0.78rem; font-family: var(--font-body);
      transition: all 0.15s;
    }
    .admin-sub-tabs .admin-sub-tab:hover {
      background: rgba(255,255,255,0.05); color: var(--cream);
    }
    .admin-sub-tabs .admin-sub-tab.active {
      background: var(--gold-soft); border: 1px solid var(--gold-border);
      color: var(--gold-light); font-weight: 500;
    }

    /* ── Overview section header (title + Refresh button row) ── */
    .admin-section-header {
      display: flex; align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: 0.5rem;
      padding: 0.75rem 1rem;
      border-bottom: 1px solid rgba(201,168,76,0.12);
      background: linear-gradient(135deg, #252545 0%, #1c1c38 100%);
      font-family: var(--font-display); font-size: 0.92rem;
      color: var(--gold-light); font-weight: 500;
    }

    /* ── 3-card responsive grid on the overview pane ── */
    .admin-card-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
      gap: 1rem; margin-top: 1rem;
    }

    /* ── Base .button — used by all admin action buttons ── */
    .button {
      display: inline-flex; align-items: center; gap: 0.35rem;
      padding: 0.45rem 0.85rem;
      background: rgba(201,168,76,0.08);
      border: 1px solid rgba(201,168,76,0.18);
      color: var(--cream-muted);
      border-radius: var(--radius-sm);
      cursor: pointer;
      font-size: 0.8rem; font-family: var(--font-mono);
      letter-spacing: 0.04em;
      white-space: nowrap;
      transition: background 0.18s, border-color 0.18s, color 0.18s;
      text-align: center;
    }
    .button:hover:not(:disabled) {
      background: rgba(201,168,76,0.14);
      border-color: rgba(201,168,76,0.38);
      color: var(--gold-light);
    }
    .button:disabled {
      opacity: 0.38; cursor: not-allowed; pointer-events: none;
    }

    /* ── Utility: muted placeholder text ── */
    .muted { color: var(--cream-muted); font-style: italic; font-size: 0.85em; }
    /* ── Utility: error state text ── */
    .error { color: #e8a898; }

    /* ── Filter actions row (Refresh + Export CSV buttons) ── */
    .admin-filter-actions {
      display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap;
      margin-left: auto;
    }

    /* ── Audit pagination buttons group ── */
    .admin-pagination-buttons {
      display: flex; gap: 0.35rem; align-items: center;
    }

    /* ── Bulk-action bar (shown only when rows are selected) ── */
    .admin-bulk-bar {
      display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap;
      padding: 0.5rem 0.85rem; margin-bottom: 0.6rem;
      background: var(--gold-soft);
      border: 1px solid var(--gold-border);
      border-radius: var(--radius-sm);
      font-size: 0.82rem;
      transition: opacity 0.18s;
    }
    .admin-bulk-hidden { display: none; }
    .admin-bulk-label {
      font-family: var(--font-mono); font-size: 0.78rem;
      color: var(--cream-muted); flex-shrink: 0;
    }
    .admin-bulk-label strong { color: var(--gold); font-weight: 600; }
    .admin-bulk-actions { display: flex; gap: 0.4rem; flex-wrap: wrap; }
    .admin-bulk-btn {
      display: inline-flex; align-items: center;
      padding: 0.3rem 0.75rem;
      background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.14);
      border-radius: var(--radius-sm);
      color: var(--cream); font-size: 0.78rem; font-family: var(--font-body);
      cursor: pointer; white-space: nowrap;
      transition: background 0.15s, border-color 0.15s, color 0.15s;
    }
    .admin-bulk-btn:hover {
      background: rgba(255,255,255,0.12); border-color: rgba(255,255,255,0.28);
      color: var(--cream);
    }
    .admin-bulk-btn:focus-visible {
      outline: 2px solid var(--gold); outline-offset: 2px;
    }
    /* Danger variant (Delete) */
    .admin-bulk-danger {
      background: rgba(199,125,106,0.1) !important;
      border-color: rgba(199,125,106,0.28) !important;
      color: #e8a898 !important;
    }
    .admin-bulk-danger:hover:not(:disabled) {
      background: rgba(199,125,106,0.18) !important;
      border-color: rgba(199,125,106,0.44) !important;
    }
    /* Clear variant (low emphasis) */
    .admin-bulk-clear { opacity: 0.65; }
    .admin-bulk-clear:hover:not(:disabled) { opacity: 1; }
    .admin-bulk-btn.admin-bulk-clear {
      background: transparent; border-color: rgba(201,168,76,0.22);
      color: var(--gold);
    }
    .admin-bulk-btn.admin-bulk-clear:hover {
      background: var(--gold-soft); border-color: var(--gold-border);
      color: var(--gold-light);
    }

    /* ── Page X of Y span inside admin-pagination ── */
    .admin-page-status {
      font-size: 0.75rem; color: var(--cream-muted);
      font-family: var(--font-mono); padding: 0 0.4rem;
    }

    /* ── User detail wrapper ── */
    .admin-user-detail { padding: 0; }
    .admin-detail-header {
      display: flex; align-items: center; gap: 0.65rem; flex-wrap: wrap;
      margin-bottom: 1.25rem; padding-bottom: 0.75rem;
      border-bottom: 1px solid rgba(255,255,255,0.07);
    }
    .admin-detail-title {
      font-family: var(--font-display); font-size: 1rem; font-weight: 500;
      color: var(--cream); flex: 1; min-width: 0;
      overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    }
    .admin-detail-meta { display: flex; gap: 0.35rem; flex-wrap: wrap; align-items: center; }

    /* ── Sections within the detail view ── */
    .admin-detail-section { margin-bottom: 1.25rem; }
    .admin-detail-section h4 {
      font-size: 0.68rem; font-family: var(--font-mono);
      text-transform: uppercase; letter-spacing: 0.09em;
      color: var(--cream-muted); margin: 0 0 0.5rem;
      border-bottom: 1px solid rgba(255,255,255,0.05);
      padding-bottom: 0.25rem;
    }
    .admin-detail-dl {
      display: grid; grid-template-columns: auto 1fr;
      gap: 0.28rem 1rem; font-size: 0.85rem; margin: 0;
    }
    .admin-detail-dl dt {
      color: var(--cream-muted); font-family: var(--font-mono);
      font-size: 0.72rem; align-self: baseline;
    }
    .admin-detail-dl dd { color: var(--cream); margin: 0; word-break: break-word; }

    /* Billing provider details key-value list */
    .admin-provider-details {
      display: grid; grid-template-columns: auto 1fr;
      gap: 0.28rem 1rem; font-size: 0.85rem; margin: 0 0 0.85rem;
    }
    .admin-provider-details dt {
      color: var(--cream-muted); font-family: var(--font-mono);
      font-size: 0.72rem; align-self: baseline;
    }
    .admin-provider-details dd { color: var(--cream); margin: 0; word-break: break-word; }

    /* ── Edit profile form grid ── */
    .admin-form-grid {
      display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
      gap: 0.75rem; margin-bottom: 1rem;
    }
    .admin-form-field { display: flex; flex-direction: column; gap: 0.3rem; }
    .admin-form-field > span {
      font-size: 0.68rem; font-family: var(--font-mono);
      text-transform: uppercase; letter-spacing: 0.07em;
      color: var(--cream-muted);
    }
    .admin-form-field input,
    .admin-form-field select {
      background: var(--ink-card-alt);
      border: 1px solid rgba(255,255,255,0.1);
      border-radius: var(--radius-sm);
      color: var(--cream); padding: 0.45rem 0.75rem;
      font-size: 0.88rem; font-family: var(--font-body);
      transition: border-color 0.15s;
    }
    .admin-form-field input:focus,
    .admin-form-field select:focus { border-color: var(--gold-border); outline: none; }

    /* ── Form action footer (Cancel / Save row) ── */
    .admin-detail-form-actions {
      display: flex; justify-content: flex-end; gap: 0.5rem;
      margin-top: 1rem; padding-top: 0.75rem;
      border-top: 1px solid rgba(255,255,255,0.07);
    }
    .admin-detail-save {
      background: rgba(201,168,76,0.14);
      border-color: rgba(201,168,76,0.38);
      color: var(--gold-light);
    }
    .admin-detail-save:hover:not(:disabled) {
      background: rgba(201,168,76,0.22);
      border-color: rgba(201,168,76,0.55);
    }

    /* ── JSON expand/collapse in audit table ── */
    .admin-json-details { font-size: 0.78rem; }
    .admin-json-details > summary {
      cursor: pointer; color: var(--cream-muted);
      font-family: var(--font-mono); font-size: 0.72rem;
      list-style: none; user-select: none;
    }
    .admin-json-details > summary::-webkit-details-marker { display: none; }
    .admin-json-details > summary:hover { color: var(--cream); }
    .admin-json {
      font-family: var(--font-mono); font-size: 0.68rem;
      color: var(--cream-muted); background: var(--ink-card-alt);
      border-radius: var(--radius-sm); padding: 0.5rem 0.75rem;
      margin: 0.35rem 0 0; overflow-x: auto;
      white-space: pre-wrap; word-break: break-all;
    }

    /* ── Scrollable table container (base rule — responsive override already exists) ── */
    .admin-table-wrap { overflow-x: auto; }
    /* ── Empty and loading states ── */
    .admin-table-empty,
    .admin-table-loading {
      text-align: center; padding: 2rem 1rem;
      color: var(--cream-muted); font-size: 0.85rem;
      font-family: var(--font-body); font-style: italic;
    }

    .admin-empty-state {
      display: flex; flex-direction: column; align-items: center;
      gap: 0.85rem; padding: 2.5rem 1.5rem;
      color: var(--cream-muted); font-style: italic; font-size: 0.88rem;
      text-align: center;
    }
    .admin-empty-img { opacity: 0.35; display: block; }

    /* ── Visual distinction for deleted user rows ── */
    .admin-users-row-deleted td { opacity: 0.5; text-decoration: line-through; }
    .admin-users-row-self td { font-style: italic; }

    /* ── Admin responsive overrides ── */
    @media (max-width: 720px) {
      .admin-stat-grid { grid-template-columns: 1fr; }
      .admin-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
      .admin-modal { width: calc(100% - 1rem); }
      .admin-card-grid { grid-template-columns: 1fr; }
      .admin-form-grid { grid-template-columns: 1fr; }
      .admin-bulk-bar { flex-direction: column; align-items: flex-start; }
      .admin-filter-bar { gap: 0.35rem; }
      .admin-section-header { padding: 0.6rem 0.75rem; }
    }
