:root {
  --bg-0: #11100d;
  --bg-1: #1d1a15;
  --bg-2: #2a251d;
  --panel: rgba(22, 19, 14, 0.9);
  --panel-border: #5f4b2e;
  --gold: #ddc089;
  --gold-bright: #f0d59b;
  --text: #f3ece0;
  --muted: #b3a48a;
  --danger: #ef7676;
  --ok: #7fd18c;
  --warn: #f5c56e;
  --blue: #8bb5dd;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  font-family: "Trebuchet MS", "Verdana", "Segoe UI", sans-serif;
  line-height: 1.4;
  color: var(--text);
  background:
    radial-gradient(circle at 10% 0%, #2e2619 0%, transparent 40%),
    radial-gradient(circle at 100% 10%, #292017 0%, transparent 33%),
    linear-gradient(180deg, var(--bg-0) 0%, #0f0e0b 100%);
  min-height: 100vh;
}

.wrap {
  width: min(1300px, 95vw);
  margin: 24px auto 40px;
}

.hero {
  border: 1px solid var(--panel-border);
  border-radius: 14px;
  padding: 20px;
  background:
    linear-gradient(
      160deg,
      rgba(221, 192, 137, 0.08) 0%,
      rgba(20, 16, 11, 0.9) 55%
    ),
    var(--panel);
  box-shadow:
    0 20px 50px rgba(0, 0, 0, 0.35),
    inset 0 0 30px rgba(255, 210, 120, 0.02);
  margin-bottom: 16px;
}

h1 {
  margin: 0 0 8px;
  color: var(--gold-bright);
  font-size: clamp(26px, 4vw, 38px);
}

.subtitle {
  color: var(--muted);
  margin: 0;
}

.panel {
  border: 1px solid var(--panel-border);
  border-radius: 14px;
  background: var(--panel);
  padding: 20px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 18px;
}

.setup-note {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.setup-layout {
  margin-top: 12px;
  display: grid;
  gap: 12px;
}

.setup-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(180px, 1fr));
  gap: 12px;
}

.field-wide {
  max-width: 520px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

label {
  color: var(--muted);
  font-size: 13px;
  letter-spacing: 0.02em;
}

input {
  width: 100%;
  border: 1px solid #6f5a3b;
  border-radius: 9px;
  background: #15120d;
  color: var(--text);
  padding: 10px 12px;
  font-size: 15px;
  color-scheme: dark;
}

select {
  width: 100%;
  border: 1px solid #6f5a3b;
  border-radius: 9px;
  background: #15120d;
  color: var(--text);
  padding: 10px 12px;
  font-size: 15px;
  color-scheme: dark;
}

select[multiple] {
  padding: 8px;
}

option {
  background: #15120d;
  color: var(--text);
}

select[multiple] option {
  border-radius: 6px;
  padding: 5px 6px;
}

select[multiple] option:checked {
  background: #594527;
  color: #fff0cc;
}

input:focus,
select:focus {
  outline: none;
  border-color: var(--gold);
  box-shadow: 0 0 0 2px rgba(221, 192, 137, 0.18);
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}

.setup-row-three {
  grid-template-columns: repeat(3, minmax(150px, 1fr));
}

button {
  border: 1px solid #8f7449;
  background: linear-gradient(180deg, #3b2f1c 0%, #2a2216 100%);
  color: var(--gold-bright);
  border-radius: 9px;
  font-weight: 700;
  padding: 10px 14px;
  cursor: pointer;
}

button:hover {
  filter: brightness(1.08);
}

button.secondary {
  background: #17130e;
  border-color: #5f4b2e;
  color: var(--muted);
}

.status {
  margin-top: 12px;
  font-size: 14px;
  color: var(--blue);
  min-height: 18px;
}

.metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.metric {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid #4f3e26;
  border-radius: 10px;
  padding: 12px;
}

.metric .label {
  color: var(--muted);
  font-size: 13px;
}

.metric .value {
  margin-top: 4px;
  font-size: 22px;
  color: var(--gold-bright);
}

.hint {
  margin-top: 10px;
  color: var(--muted);
  font-size: 13px;
}

.pace-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.skill-pace-row {
  margin-top: 6px;
  padding: 8px;
  border: 1px solid #4f3e26;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.18);
}

.skill-pace-row strong {
  color: var(--gold-bright);
}

.skill-pace-status {
  font-size: 12px;
  margin-top: 3px;
}

.skill-pace-status.on-track {
  color: #d6f3b8;
}

.skill-pace-status.over-performing {
  color: #cfe7ff;
}

.skill-pace-status.under-performing {
  color: #ffd1d1;
}

.skills-panel {
  margin-top: 18px;
}

.skills-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

h2 {
  margin: 0;
  color: var(--gold-bright);
  font-size: clamp(20px, 2.3vw, 28px);
}

.inline-note {
  font-size: 13px;
  color: var(--muted);
  font-weight: 400;
}

h3 {
  margin: 0;
  color: var(--gold-bright);
  font-size: 16px;
}

.skills-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 10px;
}

.skill-card {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid #544126;
  border-radius: 10px;
  padding: 12px;
}

.skill-card.draggable {
  cursor: grab;
}

.skill-card.draggable.dragging {
  opacity: 0.6;
  cursor: grabbing;
}

.skill-card.draggable.drop-target {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px rgba(221, 192, 137, 0.35) inset;
}

.skill-card.ignored {
  opacity: 0.6;
}

.skill-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.skill-name-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
}

.skill-icon {
  width: 20px;
  height: 20px;
  image-rendering: pixelated;
}

.badge {
  border: 1px solid #6c5735;
  background: #20180f;
  border-radius: 999px;
  color: var(--muted);
  font-size: 12px;
  padding: 2px 8px;
}

.xp-line {
  margin-top: 8px;
  color: var(--muted);
  font-size: 13px;
}

.skill-metric {
  margin-top: 8px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  font-size: 13px;
}

.gp-breakdown {
  margin-top: 10px;
  border: 1px solid #4f3e26;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.015);
  padding: 8px 10px;
}

.gp-breakdown > summary {
  cursor: pointer;
  color: var(--gold-bright);
  font-size: 13px;
  font-weight: 700;
}

.gp-breakdown-list {
  margin-top: 8px;
  display: grid;
  gap: 8px;
}

.gp-breakdown-row {
  border: 1px solid #4f3e26;
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.18);
  padding: 8px;
  font-size: 12px;
  color: var(--muted);
  display: grid;
  gap: 3px;
}

.ignore-toggle {
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 13px;
}

.ignore-toggle input[type="checkbox"] {
  width: auto;
  margin: 0;
}

.empty-state {
  color: var(--muted);
  padding: 12px;
  border: 1px dashed #5f4b2e;
  border-radius: 10px;
}

.schedule-table-wrap {
  margin-top: 12px;
  overflow-x: auto;
}

.manual-panel {
  margin-top: 12px;
  padding: 14px;
  border: 1px solid #4f3e26;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
}

.manual-section {
  border: 1px solid #4f3e26;
  border-radius: 10px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.015);
  margin-bottom: 12px;
}

.manual-section > summary {
  cursor: pointer;
  color: var(--gold-bright);
  font-weight: 700;
  font-size: 15px;
}

.calendar-section-title {
  color: var(--gold-bright);
  font-weight: 700;
  font-size: 15px;
}

.calendar-edit-hint {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 13px;
}

.weekday-template-wrap {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.weekday-row {
  border: 1px solid #4f3e26;
  border-radius: 10px;
  padding: 10px;
  background: rgba(13, 11, 8, 0.45);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.weekday-row strong {
  color: var(--gold-bright);
  font-size: 13px;
  letter-spacing: 0.03em;
}

.selected-day-meta {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.selected-day-label {
  color: var(--muted);
  font-size: 12px;
}

.selected-day-panel {
  margin-top: 10px;
  border: 1px solid #4f3e26;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.015);
  padding: 10px 12px;
}

.selected-day-panel > summary {
  cursor: pointer;
  color: var(--gold-bright);
  font-weight: 700;
  font-size: 13px;
}

.selected-day-details {
  margin-top: 8px;
  padding: 4px 0 0;
  min-height: 58px;
  line-height: 1.35;
}

.override-day-actions {
  margin-top: 10px;
}

.override-controls select[multiple],
.weekday-row select[multiple] {
  min-height: 140px;
}

.override-actions {
  display: grid;
  gap: 8px;
}

.calendar-head {
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.override-calendar {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.calendar-weekday {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: center;
}

.calendar-day {
  border: 1px solid #4f3e26;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.02);
  min-height: 86px;
  padding: 8px 7px;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  text-align: left;
  color: var(--text);
}

.calendar-day-num {
  font-size: 14px;
  font-weight: 700;
}

.calendar-day-hours {
  font-size: 11px;
  color: var(--gold-bright);
}

.calendar-day-plan {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.25;
}

.calendar-day.off-month {
  opacity: 0.45;
}

.calendar-day.selected {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px rgba(221, 192, 137, 0.25) inset;
  background: rgba(221, 192, 137, 0.08);
}

.calendar-day.blocked {
  border-color: #8a3f3f;
  background: rgba(169, 70, 70, 0.16);
}

.calendar-day.blocked .calendar-day-hours {
  color: #ffd1d1;
}

.calendar-day.has-plan .calendar-day-plan {
  color: #d8c6a3;
}

#toggleBlockedDayBtn.danger {
  border-color: #8a3f3f;
  color: #ffd1d1;
  background: linear-gradient(180deg, #4a201f 0%, #2f1716 100%);
}

.schedule-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
  font-size: 13px;
}

.schedule-table th,
.schedule-table td {
  border: 1px solid #4f3e26;
  padding: 8px 10px;
  text-align: left;
  vertical-align: top;
}

.schedule-table th {
  background: #1b150f;
}

.schedule-table tr:nth-child(even) td {
  background: rgba(255, 255, 255, 0.02);
}

.modal-shell {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.72);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 10;
}

.modal {
  width: min(560px, 92vw);
  background: #1c1711;
  border: 1px solid #7a623c;
  border-radius: 12px;
  padding: 18px;
}

.modal h3 {
  margin: 0 0 10px;
  color: var(--gold-bright);
}

.modal p {
  color: var(--muted);
  line-height: 1.5;
  margin: 0 0 10px;
}

.ok {
  color: var(--ok);
}

.danger {
  color: var(--danger);
}

.warn {
  color: var(--warn);
}

.contact-panel {
  margin-bottom: 24px;
}

.contact-text {
  margin: 10px 0 0;
  color: var(--muted);
}

.contact-links {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  color: var(--text);
}

.contact-links a {
  color: var(--gold-bright);
  text-decoration: none;
}

.contact-links a:hover {
  text-decoration: underline;
}

.contact-divider {
  color: var(--muted);
}

@media (max-width: 960px) {
  .grid {
    grid-template-columns: 1fr;
  }
  .setup-row {
    grid-template-columns: 1fr;
  }
  .setup-row-three {
    grid-template-columns: 1fr;
  }
  .weekday-template-wrap {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .metrics {
    grid-template-columns: 1fr;
  }
  .weekday-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .weekday-template-wrap {
    grid-template-columns: 1fr;
  }
}
