@import url("theme.css");

main{ padding: 24px 0 10px; }

.page-stack{
  display: grid;
  gap: 22px;
}

.grid--feature{
  align-items: start;
}

.section-copy{
  color: var(--muted);
  line-height: 1.55;
  margin-bottom: 18px;
}

.badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 16px;
  padding: 12px 14px;
  border-radius: 18px;
  background: color-mix(in oklab, var(--md-primary-container) 72%, var(--md-surface) 28%);
  border: 1px solid color-mix(in oklab, var(--md-primary) 26%, var(--md-outline-variant));
  color: var(--md-on-primary-container);
  font-size: .82rem;
  font-weight: 600;
  line-height: 1.45;
}

.compact-line{
  margin: 10px 0 0 0;
}

.result-grid--featured{
  gap: 12px;
}

/* ── Fact grid ── */
.fact-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.fact-grid--stacked{
  grid-template-columns: 1fr;
}

.fact-card{
  display: grid;
  gap: 7px;
  padding: 14px 16px;
  border-radius: 20px;
  background: color-mix(in oklab, var(--md-surface-container-high) 82%, white);
  border: 1px solid var(--md-outline-variant);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}

.fact-card__label{
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--md-on-surface-variant);
  font-weight: 700;
}

/* ── Forms ── */
.inline-form{
  display: grid;
  gap: 14px;
}

.feature-layout{
  grid-template-columns: 1.1fr .9fr;
  align-items: start;
}

@media (min-width: 720px){
  .inline-form{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: end;
  }
}

.section-actions--end{
  align-items: end;
}

.inputx select,
.inputx textarea{
  width: 100%;
  min-height: 52px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--md-outline);
  background: rgba(255,255,255,.82);
  color: var(--md-on-surface);
  font-size: .98rem;
  font-family: inherit;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
  transition: border-color .18s;
}

.inputx textarea{
  min-height: 96px;
  resize: vertical;
}

.number-picker-block{
  display: grid;
  gap: 10px;
  margin: 20px 0 18px;
}

.number-picker-label{
  font-size: .76rem;
  font-weight: 700;
  color: var(--md-on-surface-variant);
  letter-spacing: .01em;
}

.number-picker{
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.picker-ball{
  min-height: 46px;
  border-radius: 999px;
  border: 1px solid var(--md-outline-variant);
  background: color-mix(in oklab, var(--md-surface-container-high) 88%, white);
  color: var(--md-on-surface);
  font: inherit;
  font-size: .92rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.76);
  transition: transform .08s, background .15s, border-color .15s, color .15s, box-shadow .15s;
}

.picker-ball:hover{
  border-color: color-mix(in oklab, var(--md-primary) 32%, var(--md-outline-variant));
  background: color-mix(in oklab, var(--md-primary-container) 60%, white);
}

.picker-ball:focus-visible{
  outline: 3px solid color-mix(in oklab, var(--md-primary) 24%, transparent);
  outline-offset: 1px;
}

.picker-ball:active{
  transform: translateY(1px);
}

.picker-ball--active{
  border-color: color-mix(in oklab, var(--lotofacil-ball-edge) 68%, black);
  color: var(--lotofacil-ball-text);
  background:
    radial-gradient(circle at 50% 46%,
      var(--lotofacil-ball-soft) 0%,
      var(--lotofacil-ball) 58%,
      var(--lotofacil-ball-dark) 84%,
      var(--lotofacil-ball-edge) 100%),
    linear-gradient(180deg,
      var(--lotofacil-ball-highlight) 0%,
      transparent 26%,
      var(--lotofacil-ball-shadow) 100%);
  box-shadow:
    0 4px 12px rgba(60, 0, 60, .18),
    inset 0 1px 0 rgba(255,255,255,.10),
    inset 0 -4px 8px rgba(0,0,0,.18);
  text-shadow: 0 1px 1px rgba(0,0,0,.42);
}

.inputx select:hover,
.inputx textarea:hover{
  border-color: var(--md-on-surface-variant);
}

.inputx select:focus-visible,
.inputx textarea:focus-visible{
  border-color: var(--md-primary);
  outline: 3px solid color-mix(in oklab, var(--md-primary) 26%, transparent);
  outline-offset: 1px;
}

/* ── Ranking ── */
.ranking-list{
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.ranking-list--compact .ranking-item{
  padding: 12px 14px;
}

.ranking-item{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid var(--md-outline-variant);
  background: color-mix(in oklab, var(--md-surface-container-high) 80%, white);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.78);
  transition: background .15s;
}

.ranking-item strong{
  color: var(--md-on-surface);
}

.ranking-item__left{
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.ranking-item__position{
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: color-mix(in oklab, var(--md-primary-container) 90%, white);
  color: var(--md-primary);
  font-weight: 700;
  font-size: .8rem;
  border: 1px solid color-mix(in oklab, var(--md-primary) 20%, var(--md-outline-variant));
}

.ranking-item__ball{
  min-width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  color: var(--lotofacil-ball-text);
  font-weight: 900;
  font-variant-numeric: tabular-nums;
  letter-spacing: .015em;
  border: 1px solid color-mix(in oklab, var(--lotofacil-ball-edge) 68%, black);
  text-shadow: 0 1px 1px rgba(0,0,0,.42);
  background:
    radial-gradient(circle at 50% 46%,
      var(--lotofacil-ball-soft) 0%,
      var(--lotofacil-ball) 58%,
      var(--lotofacil-ball-dark) 84%,
      var(--lotofacil-ball-edge) 100%),
    linear-gradient(180deg,
      var(--lotofacil-ball-highlight) 0%,
      transparent 26%,
      var(--lotofacil-ball-shadow) 100%);
  box-shadow:
    0 4px 12px rgba(60, 0, 60, .24),
    inset 0 1px 0 rgba(255,255,255,.10),
    inset 0 -4px 8px rgba(0,0,0,.18);
}

/* ── Generated balls / Tags ── */
.generated-balls,
.tag-list{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.analysis-list{
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.analysis-item{
  padding: 14px 16px;
  border-radius: 20px;
  border: 1px solid var(--md-outline-variant);
  background: color-mix(in oklab, var(--md-surface-container-high) 84%, white);
  color: var(--text);
  line-height: 1.55;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.76);
}

.mini-ball,
.tag{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--md-outline-variant);
  background: color-mix(in oklab, var(--md-surface-container-high) 88%, white);
  color: var(--text);
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}

.mini-ball{
  border-color: color-mix(in oklab, var(--lotofacil-ball-edge) 52%, var(--md-outline-variant));
  background:
    radial-gradient(circle at 50% 46%,
      var(--lotofacil-ball-soft) 0%,
      var(--lotofacil-ball) 58%,
      var(--lotofacil-ball-dark) 84%,
      var(--lotofacil-ball-edge) 100%),
    linear-gradient(180deg,
      var(--lotofacil-ball-highlight) 0%,
      transparent 26%,
      var(--lotofacil-ball-shadow) 100%);
  color: var(--lotofacil-ball-text);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  letter-spacing: .015em;
  text-shadow: 0 1px 1px rgba(0,0,0,.42);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10), inset 0 -4px 8px rgba(0,0,0,.18);
}

/* ── Feedback box ── */
.feedback-box{
  margin-top: 18px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid var(--md-outline-variant);
  background: var(--md-surface-container-high);
  color: var(--text);
  font-weight: 500;
  line-height: 1.5;
}

.feedback-box--neutral{
  background: var(--md-surface-container-high);
}

.feedback-box--success{
  background: color-mix(in oklab, var(--ok) 12%, white);
  border-color: color-mix(in oklab, var(--ok) 30%, var(--md-outline-variant));
  color: color-mix(in oklab, var(--ok) 80%, var(--md-on-surface));
}

.feedback-box--warn{
  background: color-mix(in oklab, var(--warn) 14%, white);
  border-color: color-mix(in oklab, var(--warn) 30%, var(--md-outline-variant));
  color: color-mix(in oklab, var(--warn) 80%, var(--md-on-surface));
}

.feedback-box--danger{
  background: color-mix(in oklab, var(--bad) 12%, white);
  border-color: color-mix(in oklab, var(--bad) 26%, var(--md-outline-variant));
  color: color-mix(in oklab, var(--bad) 80%, var(--md-on-surface));
}

.empty-state{
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px dashed var(--md-outline-variant);
  color: var(--md-on-surface-variant);
  font-weight: 500;
  background: color-mix(in oklab, var(--md-surface-container-high) 65%, transparent);
}

/* ── Responsive ── */
@media (max-width: 680px){
  .fact-grid{
    grid-template-columns: 1fr;
  }

  .feature-layout{
    grid-template-columns: 1fr;
  }

  .number-picker{
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
  }

  .ranking-item{
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (min-width: 860px){
  .grid--feature{
    grid-template-columns: 1.35fr .65fr;
  }

  .cardx--featured .cardx__bd{
    padding: 24px;
  }
}

.page-observatorio--internal main{
  padding: 0;
}

.page-observatorio--internal .inline-form--editorial{
  grid-template-columns: repeat(2, minmax(0, 1fr)) auto;
  gap: 18px;
  margin-bottom: 28px;
}

.page-observatorio--internal .inputx input,
.page-observatorio--internal .inputx select,
.page-observatorio--internal .inputx textarea{
  border-radius: 0;
  border: 1px solid var(--obs-rule);
  background: transparent;
  box-shadow: none;
  color: var(--obs-ink);
  font-family: "Instrument Sans", -apple-system, system-ui, sans-serif;
}

.page-observatorio--internal .inputx label,
.page-observatorio--internal .number-picker-label{
  display: block;
  margin-bottom: 10px;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--obs-ink-soft);
  font-weight: 500;
}

.page-observatorio--internal .inputx input:hover,
.page-observatorio--internal .inputx select:hover,
.page-observatorio--internal .inputx textarea:hover{
  border-color: var(--obs-ink);
}

.page-observatorio--internal .inputx input:focus-visible,
.page-observatorio--internal .inputx select:focus-visible,
.page-observatorio--internal .inputx textarea:focus-visible{
  border-color: var(--obs-accent);
  outline: 2px solid color-mix(in oklab, var(--obs-accent) 18%, transparent);
  outline-offset: 2px;
}

.page-observatorio--internal .number-picker--editorial{
  gap: 8px;
}

.page-observatorio--internal .picker-ball{
  min-height: 56px;
  border-radius: 0;
  border: 1px solid var(--obs-rule);
  background: transparent;
  box-shadow: none;
  color: var(--obs-ink);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 13px;
}

.page-observatorio--internal .picker-ball:hover{
  border-color: var(--obs-ink);
  background: var(--obs-paper-2);
}

.page-observatorio--internal .picker-ball--active{
  border-color: var(--obs-ink);
  color: var(--obs-paper);
  background: var(--obs-ink);
  text-shadow: none;
  box-shadow: none;
}

.page-observatorio--internal .fact-grid--editorial{
  gap: 1px;
  margin-top: 0;
  background: var(--obs-rule);
  border: 1px solid var(--obs-rule);
}

.page-observatorio--internal .fact-grid--editorial .fact-card{
  border: none;
  border-radius: 0;
  background: var(--obs-paper);
  box-shadow: none;
  padding: 18px 20px;
}

.page-observatorio--internal .fact-card__label{
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: .08em;
  color: var(--obs-ink-soft);
  font-weight: 500;
}

.page-observatorio--internal .fact-card strong{
  font-family: "Instrument Serif", Georgia, serif;
  font-size: 28px;
  font-weight: 400;
  line-height: 1.05;
  color: var(--obs-ink);
}

.page-observatorio--internal .ranking-list--editorial{
  gap: 0;
  margin-top: 24px;
  border-top: 1px solid var(--obs-rule);
}

.page-observatorio--internal .ranking-item{
  padding: 18px 0;
  border: none;
  border-bottom: 1px solid var(--obs-rule);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  animation: rankItemIn .35s ease both;
  animation-delay: calc(var(--i, 0) * 45ms);
}

@keyframes rankItemIn{
  from{ opacity: 0; transform: translateY(10px); }
  to{   opacity: 1; transform: translateY(0); }
}

.page-observatorio--internal .ranking-item__bar{
  flex: 1;
  height: 2px;
  background: var(--obs-rule);
  margin: 0 16px;
  align-self: center;
}

.page-observatorio--internal .ranking-item__bar span{
  display: block;
  height: 100%;
  background: var(--obs-ink);
  transition: width .6s cubic-bezier(.4,0,.2,1);
}

.page-observatorio--internal .ranking-item strong{
  color: var(--obs-ink);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 12px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.page-observatorio--internal .ranking-item__position{
  width: auto;
  height: auto;
  border: none;
  border-radius: 0;
  background: transparent;
  color: var(--obs-ink-soft);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 12px;
}

.page-observatorio--internal .ranking-item__ball{
  min-width: 46px;
  width: 46px;
  height: 46px;
  border-radius: 0;
  background: var(--obs-ink);
  border: 1px solid var(--obs-ink);
  box-shadow: none;
  text-shadow: none;
  font-family: "JetBrains Mono", ui-monospace, monospace;
}

.page-observatorio--internal .generated-balls--editorial,
.page-observatorio--internal .tag-list--editorial{
  gap: 8px;
  margin-top: 24px;
}

.page-observatorio--internal .mini-ball,
.page-observatorio--internal .tag{
  min-height: 44px;
  padding: 0 16px;
  border-radius: 0;
  border: 1px solid var(--obs-ink);
  background: var(--obs-paper);
  box-shadow: none;
  color: var(--obs-ink);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  text-shadow: none;
}

.page-observatorio--internal .mini-ball{
  background: var(--obs-ink);
  border-color: var(--obs-ink);
  color: var(--obs-paper);
}

.page-observatorio--internal .feedback-box{
  margin-top: 24px;
  border-radius: 0;
  border-color: var(--obs-rule);
  background: var(--obs-paper-2);
  color: var(--obs-ink);
  box-shadow: none;
}

.page-observatorio--internal .feedback-box--neutral{
  background: var(--obs-paper-2);
}

.page-observatorio--internal .feedback-box--success{
  background: color-mix(in oklab, var(--obs-paper) 76%, #e2efe5);
  border-color: color-mix(in oklab, var(--ok) 20%, var(--obs-rule));
  color: color-mix(in oklab, var(--ok) 80%, var(--obs-ink));
}

.page-observatorio--internal .feedback-box--warn{
  background: color-mix(in oklab, var(--obs-paper) 74%, #f8ecd7);
  border-color: color-mix(in oklab, var(--warn) 20%, var(--obs-rule));
  color: color-mix(in oklab, var(--warn) 85%, var(--obs-ink));
}

.page-observatorio--internal .feedback-box--danger{
  background: color-mix(in oklab, var(--obs-paper) 74%, #f7e2e4);
  border-color: color-mix(in oklab, var(--bad) 20%, var(--obs-rule));
  color: color-mix(in oklab, var(--bad) 85%, var(--obs-ink));
}

.page-observatorio--internal .empty-state{
  border-radius: 0;
  border-style: solid;
  border-color: var(--obs-rule);
  background: var(--obs-paper-2);
  color: var(--obs-ink-soft);
}

.page-observatorio--internal .btnx{
  border-radius: 0;
  background: var(--obs-ink);
  color: var(--obs-paper);
  box-shadow: none;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  border-color: var(--obs-ink);
}

.page-observatorio--internal .btnx:hover{
  background: color-mix(in oklab, var(--obs-ink) 82%, var(--obs-paper));
  box-shadow: none;
}

.page-observatorio--internal .btnx:active{
  transform: none;
}

.page-observatorio--internal .btnx--ghost{
  background: transparent;
  color: var(--obs-ink);
  border: 1px solid var(--obs-ink);
  box-shadow: none;
}

.page-observatorio--internal .btnx--ghost:hover{
  background: var(--obs-paper-2);
  box-shadow: none;
}

@media (max-width: 860px){
  .page-observatorio--internal .inline-form--editorial{
    grid-template-columns: 1fr;
  }
}

.page-observatorio--internal .obs-block{
  padding: 28px;
}

.page-observatorio--internal .observatory-ball-card{
  font-size: clamp(16px, 1.8vw, 22px);
}

.page-observatorio--internal .observatory-numbers-board{
  gap: 8px;
  margin-top: 14px;
}
