/* ═══════════════════════════════════════════════════
   ORACOOLIO — Astrolog Subapp Styles v1.2 (Sprint B)
   ═══════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@400;600;700&family=Crimson+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');

:root {
  --gold:        #c9a84c;
  --gold-light:  #e8c97a;
  --gold-dim:    #7a6230;
  --bg-deep:     #06060f;
  --bg-card:     #0d0d20;
  --bg-panel:    #111128;
  --border:      rgba(201,168,76,0.22);
  --border-glow: rgba(201,168,76,0.55);
  --text:        #ddd8cc;
  --text-dim:    #8a8278;
  --text-faint:  #4a4640;
  --ok:          #2a7a5a;
  --ok-light:    #5aaa88;
  --warn:        #7a6020;
  --warn-light:  #c8a860;
  --err:         #7a2a2a;
  --radius:      6px;
  --radius-lg:   12px;
}

/* ── Reset ── */
#astrolog-root *, #astrolog-root *::before, #astrolog-root *::after {
  box-sizing: border-box; margin: 0; padding: 0;
}
#astrolog-root {
  font-family: 'Crimson Pro', Georgia, serif;
  background: var(--bg-deep); color: var(--text);
  min-height: 100vh; position: relative; overflow-x: hidden;
}

/* ── Canvas ── */
#astrolog-canvas {
  position: fixed; top:0; left:0; width:100%; height:100%;
  pointer-events:none; z-index:0; opacity:0.5;
}

/* ── Wrap ── */
.astrolog-wrap {
  position:relative; z-index:1; max-width:860px;
  margin:0 auto; padding:24px 20px 60px;
}

/* ── Header ── */
.astrolog-header {
  display:flex; align-items:center; gap:16px;
  margin-bottom:36px; padding-bottom:20px;
  border-bottom:1px solid var(--border);
}
.astrolog-back {
  background:none; border:1px solid var(--border); color:var(--gold-dim);
  font-family:'Cinzel',serif; font-size:0.7rem; letter-spacing:0.1em;
  padding:6px 14px; border-radius:var(--radius);
  cursor:pointer; transition:all 0.25s; text-transform:uppercase;
}
.astrolog-back:hover { border-color:var(--gold); color:var(--gold); background:rgba(201,168,76,0.07); }
.astrolog-title-group { flex:1; }
.astrolog-title {
  font-family:'Cinzel',serif; font-size:1.8rem; font-weight:700;
  color:var(--gold); letter-spacing:0.06em; line-height:1;
}
.astrolog-subtitle { font-size:0.9rem; color:var(--text-dim); font-style:italic; margin-top:4px; }
.astrolog-sigil { width:48px; height:48px; opacity:0.7; }

/* ── Section headings ── */
.astrolog-section-title {
  font-family:'Cinzel',serif; font-size:0.75rem; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--gold-dim); margin-bottom:16px;
  display:flex; align-items:center; gap:12px;
}
.astrolog-section-title::after { content:''; flex:1; height:1px; background:var(--border); }

/* ── Steps ── */
.astrolog-steps { display:flex; gap:8px; margin-bottom:32px; }
.astrolog-step {
  flex:1; padding:10px 8px; border:1px solid var(--border);
  border-radius:var(--radius); background:var(--bg-card);
  font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--text-faint); text-align:center; transition:all 0.3s;
}
.astrolog-step span { display:block; font-size:0.9rem; margin-bottom:2px; }
.astrolog-step.active { border-color:var(--gold); color:var(--gold); background:rgba(201,168,76,0.06); }
.astrolog-step.done   { border-color:var(--gold-dim); color:var(--gold-dim); }

/* ─── BIRTH FORM ─────────────────────────── */
.birth-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px;
}
@media(max-width:480px){ .birth-grid{ grid-template-columns:1fr; } }

.birth-field { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.birth-label {
  font-family:'Cinzel',serif; font-size:0.7rem;
  letter-spacing:0.12em; text-transform:uppercase; color:var(--gold-dim);
}
.astrolog-input {
  background:var(--bg-panel); border:1px solid var(--border);
  border-radius:var(--radius); color:var(--text);
  font-family:'Crimson Pro',serif; font-size:1rem;
  padding:8px 12px; width:100%; outline:none;
  transition:border-color 0.2s; color-scheme:dark;
}
.astrolog-input:focus { border-color:var(--gold); }
.astrolog-input::placeholder { color:var(--text-faint); }
.astrolog-input[type="date"]::-webkit-calendar-picker-indicator,
.astrolog-input[type="time"]::-webkit-calendar-picker-indicator {
  filter:invert(0.6) sepia(1) saturate(2) hue-rotate(5deg); opacity:0.7; cursor:pointer;
}
.field-note { font-size:0.8rem; font-style:italic; color:var(--text-faint); margin-top:2px; }

/* ── City search ── */
.city-search-row { display:flex; gap:8px; }
.city-search-row .astrolog-input { flex:1; }
.btn-search {
  background:var(--bg-panel); border:1px solid var(--border); border-radius:var(--radius);
  color:var(--gold-dim); font-family:'Cinzel',serif; font-size:0.7rem;
  letter-spacing:0.1em; text-transform:uppercase;
  padding:8px 16px; cursor:pointer; transition:all 0.2s; white-space:nowrap; flex-shrink:0;
}
.btn-search:hover:not(:disabled) { border-color:var(--gold); color:var(--gold); }
.btn-search:disabled { opacity:0.5; cursor:wait; }
.city-result-wrap { min-height:30px; margin-top:4px; }
.coord-display {
  display:flex; align-items:center; flex-wrap:wrap; gap:8px;
  padding:8px 12px; background:rgba(42,122,90,0.1);
  border:1px solid rgba(42,122,90,0.35); border-radius:var(--radius);
  animation:fadeIn 0.3s ease;
}
.coord-name { font-size:0.88rem; color:var(--text); flex:1; min-width:160px; }
.coord-badge {
  font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.08em;
  color:var(--ok-light); background:rgba(42,122,90,0.15);
  padding:2px 8px; border-radius:10px; border:1px solid rgba(42,122,90,0.3);
}
.city-error {
  padding:8px 12px; background:rgba(122,42,42,0.15);
  border:1px solid rgba(122,42,42,0.4); border-radius:var(--radius);
  font-size:0.88rem; color:#c07070; animation:fadeIn 0.3s ease;
}
.city-searching { padding:8px 12px; font-size:0.85rem; color:var(--gold-dim); font-style:italic; animation:pulse 1.2s ease infinite; }

/* ── Selects ── */
.astrolog-select, .select-sm {
  background:var(--bg-panel); border:1px solid var(--border);
  border-radius:var(--radius); color:var(--text);
  font-family:'Crimson Pro',serif;
  cursor:pointer; outline:none; transition:border-color 0.2s;
  -webkit-appearance:none; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23c9a84c' opacity='0.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
}
.astrolog-select { font-size:0.95rem; padding:8px 32px 8px 12px; width:100%; background-position:right 12px center; }
.select-sm       { font-size:0.9rem;  padding:5px 26px 5px 8px;  width:100%; background-position:right 8px center; }
.astrolog-select:focus, .select-sm:focus { border-color:var(--gold); }
.astrolog-select option, .select-sm option { background:#111128; color:var(--text); }
.astrolog-select optgroup { color:var(--gold-dim); font-style:normal; }

/* ── Boxes / notes ── */
.warn-box {
  background:rgba(122,96,32,0.15); border:1px solid rgba(122,96,32,0.4);
  border-radius:var(--radius); padding:10px 14px;
  font-size:0.83rem; color:var(--warn-light); line-height:1.5; margin-bottom:16px;
}
.birth-tip {
  background:rgba(201,168,76,0.05); border:1px solid rgba(201,168,76,0.15);
  border-radius:8px; padding:12px 16px;
  font-size:0.85rem; color:var(--text-dim); line-height:1.6; margin-bottom:20px;
}

/* ─── CALC BANNER (Sprint B) ─────────────── */
.calc-banner {
  border-radius:var(--radius-lg); padding:14px 18px;
  margin-bottom:20px; animation:fadeIn 0.4s ease;
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:12px; flex-wrap:wrap;
}
.calc-banner.ok {
  background:rgba(42,122,90,0.12); border:1px solid rgba(42,122,90,0.4);
}
.calc-banner.partial {
  background:rgba(122,96,32,0.12); border:1px solid rgba(122,96,32,0.4);
}
.calc-banner.info {
  background:rgba(201,168,76,0.05); border:1px solid rgba(201,168,76,0.18);
}
.calc-banner-icon { font-size:1.2rem; flex-shrink:0; margin-top:1px; }
.calc-banner-body { flex:1; }
.calc-banner-title {
  font-family:'Cinzel',serif; font-size:0.78rem; letter-spacing:0.08em;
  text-transform:uppercase; margin-bottom:4px;
}
.calc-banner.ok      .calc-banner-title { color:var(--ok-light); }
.calc-banner.partial .calc-banner-title { color:var(--warn-light); }
.calc-banner.info    .calc-banner-title { color:var(--gold-dim); }
.calc-banner-detail { font-size:0.85rem; color:var(--text-dim); line-height:1.5; }
.calc-banner-detail li { margin-left:16px; margin-top:2px; }
.calc-banner-actions { display:flex; gap:8px; align-items:center; flex-shrink:0; }

.btn-recalc {
  background:none; border:1px solid var(--border); border-radius:var(--radius);
  color:var(--gold-dim); font-family:'Cinzel',serif; font-size:0.65rem;
  letter-spacing:0.1em; text-transform:uppercase;
  padding:6px 14px; cursor:pointer; transition:all 0.2s;
}
.btn-recalc:hover { border-color:var(--gold); color:var(--gold); }

/* ── Planet table ── */
.planet-table { width:100%; border-collapse:collapse; margin-bottom:24px; }
.planet-table th {
  font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--gold-dim); padding:8px 12px;
  text-align:left; border-bottom:1px solid var(--border);
}
.planet-table td { padding:6px 8px; border-bottom:1px solid rgba(201,168,76,0.07); vertical-align:middle; }
.planet-table tr:hover td { background:rgba(201,168,76,0.03); }
.planet-table tr.autofilled td { background:rgba(42,122,90,0.04); }
.planet-name-cell { display:flex; align-items:center; gap:8px; }
.planet-glyph { font-size:1.1rem; width:24px; text-align:center; opacity:0.9; }
.planet-label { font-family:'Cinzel',serif; font-size:0.8rem; color:var(--text); }
.planet-deg   { font-size:0.75rem; color:var(--text-faint); margin-left:4px; font-style:italic; }
.astrolog-checkbox { width:16px; height:16px; accent-color:var(--gold); cursor:pointer; }

/* ── Categories ── */
.category-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-bottom:28px; }
@media(max-width:520px){ .category-grid{ grid-template-columns:repeat(2,1fr); } }
.category-card {
  border:1px solid var(--border); border-radius:var(--radius-lg);
  background:var(--bg-card); padding:16px 12px;
  text-align:center; cursor:pointer; transition:all 0.25s; user-select:none;
}
.category-card:hover { border-color:var(--gold-dim); background:rgba(201,168,76,0.04); }
.category-card.selected { border-color:var(--gold); background:rgba(201,168,76,0.09); box-shadow:0 0 18px rgba(201,168,76,0.12); }
.category-icon { font-size:1.8rem; display:block; margin-bottom:6px; line-height:1; }
.category-name { font-family:'Cinzel',serif; font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--text-dim); }
.category-card.selected .category-name { color:var(--gold); }

/* ── Buttons ── */
.astrolog-btn {
  font-family:'Cinzel',serif; font-size:0.78rem; letter-spacing:0.12em;
  text-transform:uppercase; border:none; border-radius:var(--radius);
  padding:12px 28px; cursor:pointer; transition:all 0.25s;
}
.astrolog-btn-primary {
  background:linear-gradient(135deg,#a87c28,#c9a84c,#a87c28);
  background-size:200% auto; color:#0a0a14; font-weight:700;
}
.astrolog-btn-primary:hover { background-position:right center; box-shadow:0 0 24px rgba(201,168,76,0.35); }
.astrolog-btn-primary:disabled { opacity:0.4; cursor:not-allowed; }
.astrolog-btn-secondary {
  background:var(--bg-panel); border:1px solid var(--border); color:var(--gold-dim);
}
.astrolog-btn-secondary:hover { border-color:var(--gold); color:var(--gold); }
.btn-row { display:flex; gap:12px; justify-content:flex-end; margin-top:20px; }

/* ─── HOUSE SYSTEM TOGGLE (Sprint C) ─────────── */
.house-sys-row {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:10px; margin-bottom:16px;
}
.house-sys-toggle {
  display:flex; background:var(--bg-panel);
  border:1px solid var(--border); border-radius:var(--radius); overflow:hidden;
}
.house-btn {
  background:none; border:none; color:var(--text-faint);
  font-family:'Cinzel',serif; font-size:0.7rem; letter-spacing:0.1em;
  text-transform:uppercase; padding:9px 22px; cursor:pointer; transition:all 0.2s;
}
.house-btn.active  { background:rgba(201,168,76,0.12); color:var(--gold); }
.house-btn:hover:not(.active) { color:var(--text-dim); background:rgba(201,168,76,0.04); }
.house-btn + .house-btn { border-left:1px solid var(--border); }
.house-sys-label { font-size:0.78rem; color:var(--text-faint); font-style:italic; }

/* ── Results ── */
.results-summary {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:14px 20px; margin-bottom:24px;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.results-count { font-family:'Cinzel',serif; font-size:0.8rem; color:var(--gold-dim); letter-spacing:0.08em; }
.results-count strong { color:var(--gold); font-size:1.1rem; }
.results-note { font-size:0.82rem; color:var(--text-faint); font-style:italic; }
.result-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-left:3px solid var(--gold-dim); border-radius:var(--radius-lg);
  padding:18px 20px; margin-bottom:14px; transition:border-color 0.2s;
  animation:cardIn 0.4s ease both;
}
.result-card.high   { border-left-color:var(--gold); }
.result-card.medium { border-left-color:var(--gold-dim); }
.result-card.low    { border-left-color:var(--text-faint); }
.result-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:10px; }
.result-tema { font-family:'Cinzel',serif; font-size:0.95rem; color:var(--gold-light); letter-spacing:0.04em; }
.result-badge {
  font-size:0.65rem; font-family:'Cinzel',serif; letter-spacing:0.1em;
  text-transform:uppercase; padding:2px 8px; border-radius:20px; border:1px solid;
}
.badge-high   { color:var(--gold);       border-color:var(--gold);       background:rgba(201,168,76,0.10); }
.badge-medium { color:var(--gold-dim);   border-color:var(--gold-dim);   background:rgba(201,168,76,0.05); }
.badge-low    { color:var(--text-faint); border-color:var(--text-faint); background:transparent; }
.result-kategorie { display:flex; gap:5px; flex-wrap:wrap; margin-bottom:8px; }
.kat-tag {
  font-size:0.65rem; font-family:'Cinzel',serif; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--text-faint); padding:1px 7px; border:1px solid var(--text-faint); border-radius:10px; opacity:0.6;
}
.result-text { font-size:1rem; line-height:1.65; color:var(--text); font-style:italic; }
.result-source { margin-top:8px; font-size:0.72rem; color:var(--text-faint); letter-spacing:0.05em; }

/* ── Misc ── */
.empty-state { text-align:center; padding:60px 20px; color:var(--text-faint); }
.empty-state .empty-icon { font-size:3rem; margin-bottom:16px; opacity:0.4; }
.empty-state p { font-style:italic; font-size:1rem; }
.ornament { text-align:center; color:var(--gold-dim); opacity:0.4; font-size:1.2rem; margin:20px 0; letter-spacing:0.5em; }
.astrolog-loading {
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:40px; color:var(--gold-dim); font-family:'Cinzel',serif; font-size:0.8rem; letter-spacing:0.1em;
}
.astrolog-loading::before { content:'✦'; animation:spin 2s linear infinite; display:inline-block; }

/* ── Animations ── */
@keyframes fadeIn  { from{opacity:0;transform:translateY(-4px)} to{opacity:1;transform:translateY(0)} }
@keyframes cardIn  { from{opacity:0;transform:translateY(8px)}  to{opacity:1;transform:translateY(0)} }
@keyframes pulse   { 0%,100%{opacity:0.5} 50%{opacity:1} }
@keyframes spin    { to{transform:rotate(360deg)} }

/* ── Scrollbar ── */
#astrolog-root ::-webkit-scrollbar { width:6px; }
#astrolog-root ::-webkit-scrollbar-track { background:var(--bg-deep); }
#astrolog-root ::-webkit-scrollbar-thumb { background:var(--gold-dim); border-radius:3px; }

/* ─── LANGUAGE SWITCH ────────────────────────── */
.lang-switch {
  display:flex; align-items:center; gap:4px;
  font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.1em;
}
.lang-btn {
  background:none; border:1px solid var(--border); border-radius:var(--radius);
  color:var(--text-faint); padding:3px 8px; cursor:pointer;
  font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.08em;
  text-transform:uppercase; transition:all 0.2s;
}
.lang-btn.active { border-color:var(--gold); color:var(--gold); }
.lang-btn:hover:not(.active) { color:var(--text-dim); }
.lang-sep { color:var(--text-faint); font-size:0.7rem; }

/* ─── SEKTA BADGE (Modul A) ──────────────────── */
.sekta-row {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  margin-top:6px; padding-top:6px;
  border-top:1px solid rgba(201,168,76,0.12);
  font-size:0.85rem;
}
.sekta-badge {
  font-family:'Cinzel',serif; font-size:0.72rem; letter-spacing:0.08em;
  padding:2px 10px; border-radius:20px; border:1px solid;
}
.sekta-badge.diurnal  { color:#e8c87a; border-color:rgba(232,200,122,0.4); background:rgba(232,200,122,0.08); }
.sekta-badge.nocturnal{ color:#8ab4d8; border-color:rgba(138,180,216,0.4); background:rgba(138,180,216,0.08); }
.sekta-light { color:var(--text-dim); font-size:0.82rem; }

/* ─── INFO DETAILS TOGGLE ────────────────────── */
.info-details {
  display:inline-block; margin-left:auto;
}
.info-details summary {
  list-style:none; cursor:pointer; width:20px; height:20px;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border); border-radius:50%;
  color:var(--text-faint); font-size:0.75rem;
  transition:all 0.2s; user-select:none;
}
.info-details summary::-webkit-details-marker { display:none; }
.info-details[open] summary { border-color:var(--gold); color:var(--gold); }
.info-panel {
  position:absolute; right:0; margin-top:8px; z-index:100;
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:14px 16px;
  max-width:340px; font-size:0.87rem; line-height:1.6;
  color:var(--text-dim); box-shadow:0 8px 32px rgba(0,0,0,0.4);
  animation:fadeIn 0.2s ease;
}
.info-panel strong { color:var(--gold); font-family:'Cinzel',serif; font-size:0.78rem; letter-spacing:0.06em; }
.calc-banner-body { position:relative; }
.planet-table tr.highlighted td { background:rgba(201,168,76,0.10) !important; }
.planet-table tr.highlighted .planet-label { color:var(--gold); }

/* ─── ESENCIÁLNÍ HODNOSTI — MODUL B ─────── */
.dig-tag {
  font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.07em;
  padding:2px 7px; border-radius:10px; border:1px solid;
  white-space:nowrap; display:inline-block;
}
.dig-none  { color:var(--text-faint); border-color:var(--text-faint); opacity:0.4; }
.dig-dom   { color:#e8c87a; border-color:rgba(232,200,122,0.5); background:rgba(232,200,122,0.10); }
.dig-exalt { color:#c8e8a0; border-color:rgba(200,232,160,0.5); background:rgba(200,232,160,0.10); }
.dig-trip  { color:#90c8e0; border-color:rgba(144,200,224,0.4); background:rgba(144,200,224,0.08); }
.dig-term  { color:#a0b8d8; border-color:rgba(160,184,216,0.4); background:rgba(160,184,216,0.07); }
.dig-face  { color:#8898b8; border-color:rgba(136,152,184,0.4); background:rgba(136,152,184,0.06); }
.dig-fall  { color:#e8a060; border-color:rgba(232,160,96,0.5);  background:rgba(232,160,96,0.10); }
.dig-det   { color:#e07070; border-color:rgba(224,112,112,0.5); background:rgba(224,112,112,0.10); }

.dignity-panel-wrap {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:16px 18px;
  margin-bottom:20px; animation:fadeIn 0.4s ease;
}
.dignity-panel-head {
  display:flex; align-items:center; justify-content:space-between; margin-bottom:12px;
}
.dignity-panel-title {
  font-family:'Cinzel',serif; font-size:0.75rem; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--gold-dim);
}
.dignity-grid { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.dignity-row  {
  display:grid; align-items:center; gap:8px;
  grid-template-columns:20px 80px 1fr 32px 22px;
}
@media(max-width:480px){ .dignity-row{ grid-template-columns:20px 64px 1fr 28px 20px; } }
.dignity-glyph { font-size:1rem; text-align:center; }
.dignity-pname { font-family:'Cinzel',serif; font-size:0.72rem; color:var(--text-dim); }
.dignity-bar-wrap {
  height:6px; background:rgba(255,255,255,0.06); border-radius:3px; overflow:hidden;
}
.dignity-bar-fill { height:100%; border-radius:3px; transition:width 0.6s ease; }
.grade-a { background:linear-gradient(90deg,#c8a84c,#e8d080); }
.grade-b { background:linear-gradient(90deg,#5a9a50,#80c070); }
.grade-c { background:linear-gradient(90deg,#3878a0,#5088b0); }
.grade-d { background:linear-gradient(90deg,#b86830,#d08050); }
.grade-f { background:linear-gradient(90deg,#983030,#b85050); }
.dignity-score {
  font-family:'Cinzel',serif; font-size:0.7rem; text-align:right; color:var(--text-dim);
}
.dignity-grade {
  font-family:'Cinzel',serif; font-size:0.75rem; font-weight:700;
  text-align:center; border-radius:3px; padding:1px 3px;
}
.dignity-grade.grade-a { color:#e8d080; }
.dignity-grade.grade-b { color:#80c070; }
.dignity-grade.grade-c { color:#5088b0; }
.dignity-grade.grade-d { color:#d08050; }
.dignity-grade.grade-f { color:#b85050; }

.almuten-card {
  background:rgba(201,168,76,0.07); border:1px solid rgba(201,168,76,0.3);
  border-radius:var(--radius); padding:12px 14px; margin-top:4px;
}
.almuten-head { display:flex; align-items:center; gap:12px; }
.almuten-glyph { font-size:1.8rem; opacity:0.85; flex-shrink:0; }
.almuten-label {
  font-family:'Cinzel',serif; font-size:0.7rem; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--gold-dim); margin-bottom:3px;
}
.almuten-planet { font-family:'Cinzel',serif; font-size:0.95rem; color:var(--gold); }

/* ─── HOROSCOPE WHEEL (Sprint D) ────────── */
.wheel-wrap { text-align:center; margin-bottom:24px; animation:fadeIn 0.5s ease; }
.wheel-wrap svg {
  max-width:460px; width:100%; border-radius:50%;
  box-shadow:0 0 50px rgba(201,168,76,0.08), 0 0 100px rgba(201,168,76,0.04);
}

/* ─── ARABSKÉ LOSY — MODUL C ──────────────── */
.lots-panel-wrap {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:16px 18px;
  margin-bottom:20px; animation:fadeIn 0.4s ease;
}
.lots-panel-head {
  display:flex; align-items:center; justify-content:space-between; margin-bottom:12px;
}
.lots-panel-title {
  font-family:'Cinzel',serif; font-size:0.75rem; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--gold-dim);
}
.lots-grid { display:flex; flex-direction:column; gap:7px; }
.lot-row {
  display:flex; align-items:center; gap:10px;
  padding:7px 10px; border-radius:var(--radius);
  background:rgba(201,168,76,0.03); border:1px solid rgba(201,168,76,0.08);
  transition:border-color 0.2s;
}
.lot-row:hover { border-color:rgba(201,168,76,0.18); }
.lot-sym {
  font-size:1.1rem; width:22px; text-align:center;
  flex-shrink:0; opacity:0.85;
}
.lot-body { flex:1; display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; }
.lot-name {
  font-family:'Cinzel',serif; font-size:0.78rem; letter-spacing:0.05em;
  color:var(--gold-light); white-space:nowrap;
}
.lot-pos { font-size:0.88rem; color:var(--text-dim); }
.lot-info { margin-left:auto; flex-shrink:0; }

/* ─── TEMPERAMENT — MODUL D ───────────────── */
.temp-panel-wrap {
  border-radius:var(--radius-lg); padding:16px 18px;
  margin-bottom:20px; animation:fadeIn 0.4s ease;
  border:1px solid; background:var(--bg-card);
}
.temp-sang  { border-color:rgba(144,200,224,0.35); }
.temp-chol  { border-color:rgba(232,160,80,0.35);  }
.temp-phleg { border-color:rgba(100,180,200,0.35); }
.temp-melan { border-color:rgba(160,140,180,0.35); }

.temp-header { display:flex; gap:14px; align-items:flex-start; margin-bottom:14px; }
.temp-icon-wrap {
  width:44px; height:44px; flex-shrink:0; display:flex;
  align-items:center; justify-content:center;
  border-radius:50%; background:rgba(201,168,76,0.08);
  border:1px solid rgba(201,168,76,0.2);
}
.temp-icon { font-size:1.4rem; line-height:1; }
.temp-title-wrap { flex:1; }
.temp-title-row { display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-bottom:6px; }
.temp-name {
  font-family:'Cinzel',serif; font-size:1rem; font-weight:700; color:var(--gold-light);
}
.temp-elem {
  font-size:0.78rem; color:var(--text-faint);
  font-style:italic;
}
.temp-desc { font-size:0.9rem; line-height:1.6; color:var(--text-dim); }

.temp-quals { display:flex; flex-direction:column; gap:5px; margin-top:6px; }
.temp-qual-row {
  display:grid; grid-template-columns:60px 1fr 28px;
  align-items:center; gap:8px;
}
.temp-qual-label {
  font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.08em;
  text-transform:uppercase; color:var(--text-faint);
}
.temp-bar-wrap {
  height:5px; background:rgba(255,255,255,0.06); border-radius:3px; overflow:hidden;
}
.temp-bar-fill { height:100%; border-radius:3px; transition:width 0.6s ease; }
.temp-bar-sanguine  { background:linear-gradient(90deg,#5090c0,#80b8e0); }
.temp-bar-choleric  { background:linear-gradient(90deg,#c06020,#e08840); }
.temp-bar-phlegmatic{ background:linear-gradient(90deg,#3080a0,#50a8c8); }
.temp-bar-melancholic{ background:linear-gradient(90deg,#706090,#9080b0); }
.temp-qual-val {
  font-family:'Cinzel',serif; font-size:0.68rem; color:var(--text-dim); text-align:right;
}

/* ─── PREDIKCE — MODUL E ──────────────────── */
.pred-panel-wrap {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:16px 18px;
  margin-bottom:20px; animation:fadeIn 0.4s ease;
}
.pred-panel-title {
  font-family:'Cinzel',serif; font-size:0.75rem; letter-spacing:0.14em;
  text-transform:uppercase; color:var(--gold-dim); margin-bottom:12px;
}
.pred-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
@media(max-width:520px){ .pred-grid{ grid-template-columns:1fr; } }

.pred-card {
  background:rgba(201,168,76,0.04); border:1px solid rgba(201,168,76,0.14);
  border-radius:var(--radius); padding:12px 14px;
}
.pred-card-head {
  display:flex; align-items:center; justify-content:space-between; margin-bottom:10px;
}
.pred-card-title {
  font-family:'Cinzel',serif; font-size:0.72rem; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--gold-dim);
}
.pred-rows { display:flex; flex-direction:column; gap:5px; margin-bottom:10px; }
.pred-row  { display:flex; justify-content:space-between; align-items:baseline; gap:8px; }
.pred-label {
  font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.08em;
  text-transform:uppercase; color:var(--text-faint); flex-shrink:0;
}
.pred-val  { font-size:0.9rem; color:var(--text); text-align:right; }
.pred-hl   { color:var(--gold-light); font-family:'Cinzel',serif; font-size:0.85rem; }
.pred-dim  { color:var(--text-faint); font-size:0.8rem; font-style:italic; }
.pred-tema {
  font-size:0.88rem; font-style:italic; color:var(--text-dim);
  line-height:1.5; border-top:1px solid rgba(201,168,76,0.1); padding-top:8px;
}
