/* UTBILDNINGSKORT */
.education-card {
  border: 1px solid #ece9e3;
  border-left: 3px solid #c8996a;
  padding: 32px;
  margin-bottom: 48px;
  border-radius: 0;
}
.education-card-eyebrow {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 16px;
}
.education-card h2 {
  font-family: 'Crimson Pro', Georgia, serif;
  font-size: 22px;
  font-weight: 400;
  font-style: italic;
  letter-spacing: -0.03em;
  color: var(--black);
  margin-bottom: 20px;
}
.education-details {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.detail-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.detail-label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.detail-value {
  font-size: 15px;
  color: var(--dark);
  line-height: 1.4;
}

/* CHECKLISTA */
.checklist-section { margin-bottom: 48px; }
.checklist-section h2 { font-family: 'Crimson Pro', Georgia, serif; font-size: 28px; font-weight: 300; letter-spacing: -0.03em; color: var(--black); margin-bottom: 8px; }
.checklist-sub { font-size: 14px; color: var(--muted); margin-bottom: 24px; }
.checklist { display: flex; flex-direction: column; gap: 1px; background: var(--border); border: 1px solid var(--border); }
.checklist-item { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; background: var(--white); cursor: pointer; transition: background 0.15s; }
.checklist-item:hover { background: var(--bg); }
.checklist-left { display: flex; align-items: center; gap: 16px; }
.checklist-dot { width: 24px; height: 24px; border: 2px solid var(--border); border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.checklist-item.done .checklist-dot { border-color: var(--green); background: var(--green); }
.checklist-item.done .checklist-dot::after { content: ''; width: 8px; height: 5px; border-left: 2px solid var(--white); border-bottom: 2px solid var(--white); transform: rotate(-45deg) translateY(-1px); }
.checklist-title { font-size: 15px; color: var(--dark); font-weight: 400; }
.checklist-desc { font-size: 13px; color: var(--muted); margin-top: 2px; }
.checklist-arrow { font-size: 18px; color: var(--border); transition: color 0.15s; }
.checklist-item:hover .checklist-arrow { color: var(--mid); }

/* DITT TEAM */
.team-section { margin-bottom: 48px; }
.team-section h2 { font-family: 'Crimson Pro', Georgia, serif; font-size: 28px; font-weight: 300; letter-spacing: -0.03em; color: var(--black); margin-bottom: 8px; }
.team-sub { font-size: 14px; color: var(--muted); margin-bottom: 24px; }
.team-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 1px; background: var(--border); border: 1px solid var(--border); }
.team-card { background: var(--white); padding: 28px 24px; text-align: center; transition: background 0.15s; }
.team-card.clickable { cursor: pointer; }
.team-card.clickable:hover { background: var(--bg); }
.team-avatar { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; margin-bottom: 16px; filter: grayscale(20%); }
.team-name { font-family: 'Crimson Pro', Georgia, serif; font-size: 18px; font-weight: 400; letter-spacing: -0.02em; color: var(--black); margin-bottom: 4px; }
.team-role { font-size: 12px; color: var(--muted); line-height: 1.5; }
.team-action { font-size: 12px; color: var(--accent); margin-top: 12px; font-weight: 500; }
.team-card.clickable:hover .team-action { color: var(--accent-hover); }

/* COACH CHAT */
.coach-chat {
  background: var(--white);
  border: 1px solid var(--border);
  padding: 40px;
  margin-bottom: 48px;
  position: relative;
}
.coach-chat::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--accent);
}
.coach-chat-eyebrow {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
}
.coach-chat h2 {
  font-family: 'Crimson Pro', Georgia, serif;
  font-size: 32px;
  font-weight: 300;
  letter-spacing: -0.03em;
  color: var(--black);
  margin-bottom: 12px;
  line-height: 1.2;
}
.coach-chat-intro {
  font-size: 15px;
  color: var(--mid);
  line-height: 1.65;
  max-width: 480px;
  margin-bottom: 24px;
}
.coach-messages {
  max-height: 400px;
  overflow-y: auto;
  margin-bottom: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.coach-msg {
  max-width: 85%;
  padding: 14px 18px;
  font-size: 14px;
  line-height: 1.6;
  border-radius: 8px;
}
.coach-msg-label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.coach-msg.user .coach-msg-label {
  color: rgba(255, 255, 255, 0.7);
  text-align: right;
}
.coach-msg.assistant .coach-msg-label {
  color: var(--accent);
}
.coach-msg.user {
  align-self: flex-end;
  background: #c8996a;
  color: #FFFFFF;
  border-radius: 8px;
}
.coach-msg.assistant {
  align-self: flex-start;
  background: var(--bg);
  color: var(--dark);
  border-radius: 8px;
}
.coach-msg.assistant strong {
  color: var(--accent);
  font-weight: 600;
}
.coach-input-wrap {
  display: flex;
  gap: 8px;
}
.coach-input {
  flex: 1;
  padding: 14px 16px;
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 15px;
  color: var(--dark);
  background: var(--bg);
  border: 1px solid var(--border);
  outline: none;
}
.coach-input::placeholder {
  color: var(--muted);
}
.coach-input:focus {
  border-color: var(--accent);
}
.coach-send-btn {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: var(--accent);
  color: var(--white);
  border: none;
  padding: 14px 24px;
  cursor: pointer;
  transition: background 0.15s;
}
.coach-send-btn:hover {
  background: var(--accent-hover);
}
.coach-send-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.coach-konv-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.coach-konv-bar select {
  flex: 1;
  min-width: 0;
  padding: 8px 12px;
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 13px;
  color: var(--dark);
  background: var(--bg);
  border: 1px solid var(--border);
  outline: none;
  cursor: pointer;
}
.coach-konv-bar select:focus { border-color: var(--accent); }
.coach-konv-ny {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: var(--accent);
  background: none;
  border: 1px solid var(--accent);
  padding: 7px 14px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.coach-konv-ny:hover { background: var(--accent); color: var(--white); }
.coach-konv-radera {
  font-size: 16px;
  color: var(--muted);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 6px;
  line-height: 1;
}
.coach-konv-radera:hover { color: var(--dark); }
.coach-typing {
  font-size: 13px;
  color: var(--muted);
  padding: 8px 0;
  display: none;
}
.coach-typing-dots span {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  margin: 0 2px;
  animation: coachDot 1.4s infinite ease-in-out both;
}
.coach-typing-dots span:nth-child(1) { animation-delay: -0.32s; }
.coach-typing-dots span:nth-child(2) { animation-delay: -0.16s; }
@keyframes coachDot {
  0%, 80%, 100% { opacity: 0.2; transform: scale(0.8); }
  40% { opacity: 1; transform: scale(1); }
}

/* DIGITAL COACH (gammal fallback) */
.digital-coach {
  background: var(--black);
  border: none;
  padding: 48px 40px;
  margin-bottom: 48px;
  position: relative;
  overflow: hidden;
}
.digital-coach::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--accent);
}
.digital-coach-eyebrow {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 16px;
}
.digital-coach h2 {
  font-family: 'Crimson Pro', Georgia, serif;
  font-size: 32px;
  font-weight: 300;
  letter-spacing: -0.03em;
  color: var(--white);
  margin-bottom: 12px;
  line-height: 1.2;
}
.digital-coach p {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.6);
  line-height: 1.65;
  max-width: 480px;
  margin-bottom: 28px;
}
.btn-coach {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: var(--accent);
  color: var(--white);
  border: none;
  padding: 14px 28px;
  cursor: pointer;
  transition: background 0.15s;
}
.btn-coach:hover {
  background: var(--accent-hover);
}

/* REFERRAL / BJUD IN */
.referral-section { background: #fdf6ee; border-radius: 0; padding: 32px; margin-bottom: 48px; position: relative; overflow: hidden; }
.referral-deco-1 { position: absolute; top: -40px; right: -40px; width: 140px; height: 140px; border-radius: 50%; background: #c8996a; opacity: 0.07; pointer-events: none; }
.referral-deco-2 { position: absolute; bottom: -30px; right: 60px; width: 90px; height: 90px; border-radius: 50%; background: #c8996a; opacity: 0.05; pointer-events: none; }
.referral-quote-mark { font-family: 'Crimson Pro', Georgia, serif; font-size: 4rem; line-height: 1; color: #c8996a; opacity: 0.3; margin-bottom: -12px; }
.referral-citat-text { font-family: 'Crimson Pro', Georgia, serif; font-size: 1.25rem; font-weight: 400; color: var(--dark); line-height: 1.5; font-style: italic; transition: opacity 0.4s; }
.referral-citat-namn { font-size: 12px; color: var(--muted); margin-top: 8px; transition: opacity 0.4s; }
.referral-sep { border: none; border-top: 0.5px solid var(--border); margin: 20px 0; }
.referral-bottom-text { font-size: 14px; color: var(--mid); line-height: 1.6; margin-bottom: 16px; }

/* 360-SEKTION */
.three60-panel {
  display: none;
  padding: 0 24px 20px;
  background: var(--white);
}
.three60-panel.open {
  display: block;
}
.three60-tab-bar {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 24px;
}
.three60-tab {
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  background: none;
  border: none;
  padding: 12px 20px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all 0.15s;
}
.three60-tab.active {
  color: var(--black);
  border-bottom-color: var(--accent);
}
.three60-tab-content {
  display: none;
}
.three60-tab-content.active {
  display: block;
}
.three60-question {
  margin-bottom: 20px;
}
.three60-question label {
  display: block;
  font-size: 14px;
  color: var(--dark);
  margin-bottom: 6px;
  line-height: 1.5;
}
.three60-question textarea {
  width: 100%;
  min-height: 70px;
  padding: 12px 14px;
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 14px;
  color: var(--black);
  border: 1px solid var(--border);
  background: var(--bg);
  resize: vertical;
  box-sizing: border-box;
}
.three60-question textarea:focus {
  outline: none;
  border-color: var(--accent);
}
.three60-ability {
  margin-bottom: 20px;
}
.three60-ability-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--dark);
  margin-bottom: 2px;
}
.three60-ability-desc {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 8px;
}
.three60-rating {
  display: flex;
  gap: 6px;
}
.three60-rating-btn {
  width: 38px;
  height: 38px;
  border: 2px solid var(--border);
  border-radius: 50%;
  background: var(--white);
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--muted);
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.three60-rating-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.three60-rating-btn.selected {
  border-color: var(--accent);
  background: var(--accent);
  color: var(--white);
}
.three60-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
}
.three60-status {
  font-size: 13px;
  color: var(--muted);
}
.three60-extern-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-light);
  font-size: 14px;
}
.three60-extern-row .name {
  color: var(--dark);
  font-weight: 400;
}
.three60-extern-row .roll {
  color: var(--muted);
  font-size: 12px;
}
.three60-extern-row .status-tag {
  margin-left: auto;
  font-size: 12px;
  font-weight: 500;
}
.three60-extern-row .status-tag.waiting {
  color: var(--muted);
}
.three60-extern-row .status-tag.done {
  color: var(--green);
}
.three60-invite-form {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 8px;
  align-items: end;
  margin-top: 16px;
  max-width: 100%;
  overflow: hidden;
}
.three60-invite-form .btn-primary {
  grid-column: 1 / -1;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.three60-invite-form input,
.three60-invite-form select {
  padding: 10px 12px;
  font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 14px;
  border: 1px solid var(--border);
  background: var(--bg);
  min-width: 0;
  box-sizing: border-box;
}
.three60-invite-form input:focus,
.three60-invite-form select:focus {
  outline: none;
  border-color: var(--accent);
}
.three60-chart-wrap {
  max-width: 360px;
  margin: 24px auto;
}
.three60-summering {
  background: var(--accent-light);
  border: 1px solid rgba(255, 159, 70, 0.2);
  border-left: 3px solid var(--accent);
  padding: 24px;
  margin-top: 20px;
  font-size: 14px;
  color: var(--dark);
  line-height: 1.65;
}
@media (max-width: 768px) {
  .three60-invite-form {
    grid-template-columns: 1fr;
  }
  .three60-invite-form .btn-primary {
    width: 100%;
    min-width: 0;
  }
}

/* CHECKLIST EXPAND (matpreferenser) */
.checklist-expand { display: none; padding: 0 24px 20px; background: var(--white); }
.checklist-expand.open { display: block; }
.checklist-expand textarea { width: 100%; min-height: 80px; padding: 14px 16px; font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 15px; color: var(--black); border: 1px solid var(--border); background: var(--bg); resize: vertical; box-sizing: border-box; }
.checklist-expand textarea:focus { outline: none; border-color: var(--accent); }
.checklist-expand-actions { display: flex; align-items: center; gap: 12px; margin-top: 12px; }
.matpref-status { font-size: 13px; color: var(--muted); }

/* VY-TOGGLE */
.vy-toggle { display:flex; gap:8px; margin-bottom:20px; margin-top:16px; }
.vy-btn { font-size:12px; font-weight:500; letter-spacing:0.04em; padding:6px 14px; border-radius:20px; cursor:pointer; border:0.5px solid var(--border); background:none; color:var(--mid); font-family:inherit; }
.vy-btn.aktiv { background:var(--dark); color:#fff; border-color:var(--dark); }

/* GANTT */
.gantt-wrap { overflow-x: auto; }
.gantt { min-width: 560px; }
.gantt-header { display: grid; grid-template-columns: 160px 1fr; margin-bottom: 8px; }
.gantt-manad-labels { display: grid; grid-template-columns: repeat(6, 1fr); }
.gantt-manad { font-size: 10px; color: var(--muted); text-align: center; letter-spacing: 0.04em; text-transform: uppercase; }
.gantt-row { display: grid; grid-template-columns: 160px 1fr; align-items: center; margin-bottom: 8px; min-height: 36px; }
.gantt-label { padding-right: 12px; }
.gantt-mal-titel { font-size: 10px; font-weight: 500; letter-spacing: 0.05em; text-transform: uppercase; color: var(--muted); margin-bottom: 2px; }
.gantt-kort-rubrik { font-size: 12px; font-weight: 500; color: var(--dark); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gantt-track { position: relative; height: 36px; background: var(--bg); border-radius: 4px; }
.gantt-bar { position: absolute; height: 24px; top: 6px; border-radius: 4px; display: flex; align-items: center; padding: 0 8px; font-size: 11px; font-weight: 500; color: white; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: default; }
.gantt-today { position: absolute; top: 0; bottom: 0; width: 1.5px; background: #c8996a; z-index: 10; }

/* COMMITMENTS — DIN FÖRFLYTTNING */
.commitments-section { margin-bottom: 48px; }
.commitments-section h2 { font-family: 'Crimson Pro', Georgia, serif; font-size: 28px; font-weight: 300; letter-spacing: -0.03em; color: var(--black); margin-bottom: 8px; }
.commitments-sub { font-size: 14px; color: var(--muted); margin-bottom: 24px; }
.commitments-empty { font-size: 14px; color: var(--muted); font-style: italic; padding: 24px 0; text-align: center; }
.commitment-new-btn { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 13px; font-weight: 500; letter-spacing: 0.04em; text-transform: uppercase; background: var(--white); color: var(--accent); border: 1px solid var(--accent); padding: 10px 20px; cursor: pointer; transition: all 0.15s; margin-bottom: 24px; }
.commitment-new-btn:hover { background: var(--accent); color: var(--white); }
.kanban { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 12px; }
.kanban-kolumn { min-height: 80px; transition: background 0.15s; padding: 4px; }
.kanban-col-header { font-size: 12px; font-weight: 500; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); padding: 8px 0; margin-bottom: 8px; border-bottom: 2.5px solid var(--border); display: flex; align-items: center; gap: 8px; }
.kanban-col-header .count { font-size: 11px; background: var(--bg); border-radius: 10px; padding: 1px 7px; color: var(--muted); }
.kanban-kolumn[data-status="aktiv"] .kanban-col-header { border-color: #888780; }
.kanban-kolumn[data-status="paborjad"] .kanban-col-header { border-color: #EF9F27; }
.kanban-kolumn[data-status="stoppad"] .kanban-col-header { border-color: #E24B4A; }
.kanban-kolumn[data-status="klar"] .kanban-col-header { border-color: #639922; }
.commitment-card { background: var(--white); border: 0.5px solid var(--border); border-left: 7px solid transparent; border-radius: 8px; border-top-left-radius: 0; border-bottom-left-radius: 0; padding: 12px 12px 12px 14px; margin-bottom: 10px; cursor: grab; position: relative; transition: box-shadow 0.15s, background 0.15s; }
.commitment-card:active { cursor: grabbing; }
.card-goal { font-size: 10px; font-weight: 500; letter-spacing: 0.05em; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.card-level { display: none; }
.card-title { font-size: 15px; font-weight: 600; color: var(--dark); line-height: 1.3; margin-bottom: 6px; }
.card-mal { font-size: 13px; color: var(--mid); line-height: 1.5; margin-bottom: 10px; }
.card-footer { display: flex; align-items: center; justify-content: space-between; }
.card-time { font-size: 11px; color: var(--muted); background: var(--bg); border-radius: 20px; padding: 2px 8px; border: 0.5px solid var(--border); display: flex; align-items: center; gap: 4px; }
.card-menu { font-size: 16px; color: var(--muted); cursor: pointer; padding: 0 4px; }
.card-menu:hover { color: var(--dark); }
.sibling-highlight { background: #FAEEDA !important; border-top-color: #FAC775 !important; border-right-color: #FAC775 !important; border-bottom-color: #FAC775 !important; }
.kanban-dropdown { display: none; position: absolute; top: 32px; right: 8px; background: var(--white); border: 1px solid var(--border); box-shadow: 0 4px 12px rgba(0,0,0,0.08); z-index: 100; min-width: 160px; }
.kanban-dropdown.open { display: block; }
.kanban-dropdown button { display: block; width: 100%; text-align: left; padding: 10px 16px; font-size: 13px; font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; background: none; border: none; cursor: pointer; color: var(--dark); }
.kanban-dropdown button:hover { background: var(--bg); }
.kanban-dropdown button.danger { color: #E24B4A; }
.kanban-kolumn.drag-hover { background: var(--bg); border-radius: 4px; }

/* MÅL-LISTA */
.mal-box { border: 0.5px solid var(--border); border-radius: 8px; padding: 14px 16px; margin-bottom: 12px; background: var(--white); }
.mal-box-header { display: flex; align-items: center; justify-content: space-between; }
.mal-box-titel { font-size: 13px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--dark); }
.mal-box-radera { font-size: 16px; color: var(--mid); cursor: pointer; padding: 0 4px; transition: color 0.15s; }
.mal-box-radera:hover { color: var(--dark); }
.mal-box-linje { border-top: 1.5px solid var(--border); margin: 8px 0; }
.mal-niva-btns { display: flex; gap: 8px; flex-wrap: wrap; }
.mal-niva-btn { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 12px; font-weight: 500; background: var(--white); border: 1px solid var(--border); padding: 6px 14px; cursor: pointer; border-radius: 4px; transition: all 0.15s; }
.mal-niva-btn:hover { opacity: 0.75; }
.kort-arkivera { font-size: 11px; color: var(--muted); cursor: pointer; text-decoration: underline; margin-left: 8px; }
.kort-arkivera:hover { color: var(--dark); }
.arkiv-toggle { font-size: 13px; color: var(--muted); cursor: pointer; margin-top: 24px; padding: 8px 0; }
.arkiv-toggle:hover { color: var(--dark); }
.arkiv-lista { display: none; margin-top: 12px; }
.arkiv-lista.open { display: block; }
.arkiv-lista .commitment-card { opacity: 0.6; }

@media (max-width: 600px) {
  .kanban { grid-template-columns: 1fr 1fr; gap: 8px; }
  .education-details { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr 1fr; }
}

/* KALENDARIUM */
.kalendarium-panel { background: var(--white); border: 1px solid var(--border); border-radius: 8px; padding: 28px 32px; margin-bottom: 32px; }
.kalendarium-panel h3 { font-family: 'Crimson Pro', serif; font-size: 22px; font-weight: 300; margin-bottom: 16px; }
.kalendarium-rad { display: flex; align-items: center; padding: 12px 16px; border-left: 3px solid var(--accent); margin-bottom: 8px; background: var(--bg); border-radius: 0 6px 6px 0; text-decoration: none; color: inherit; transition: background 0.15s; }
.kalendarium-rad:hover { background: #fff8f0; }
.kalendarium-rad-namn { font-weight: 500; font-size: 14px; color: #1a1a1a; }
.kalendarium-rad-sep { margin: 0 10px; color: #ccc; }
.kalendarium-rad-datum, .kalendarium-rad-ort { font-size: 13px; color: var(--mid); }
.kalendarium-rad-arrow { margin-left: auto; color: var(--accent); font-size: 14px; }

/* SPRÅKMÖNSTER PANEL */
.sprak-panel { background: #f9f7f4; border-radius: 8px; padding: 20px 24px; margin-top: 16px; margin-bottom: 32px; }
.sprak-panel p { font-size: 14px; color: var(--mid); line-height: 1.6; margin-bottom: 12px; }
.sprak-panel h3 { font-family: 'Crimson Pro', serif; font-size: 20px; margin-bottom: 8px; }
.sprak-panel.alumni { border-left: 3px solid var(--accent); }
.sprak-link { color: var(--accent); font-weight: 600; text-decoration: none; }
.sprak-link:hover { color: var(--accent-hover); }

/* CHECKLIST COMPRESSED */
.checklist-compressed { display: flex; align-items: center; justify-content: space-between; padding: 16px 24px; border: 1px solid var(--border); margin-bottom: 24px; font-size: 15px; color: var(--green); }
.checklist-compressed .visa-link { font-size: 13px; color: var(--accent); cursor: pointer; text-decoration: underline; text-underline-offset: 3px; }

/* ÖVNINGSBANK */
.ovningsbank-section { border: 1px solid var(--border); border-radius: 8px; padding: 32px; margin-bottom: 32px; background: var(--white); }
.ovningsbank-section h3 { font-family: 'Crimson Pro', serif; font-size: 22px; font-weight: 300; margin-bottom: 4px; }
.ovningsbank-section .ovn-intro { font-size: 14px; color: var(--mid); line-height: 1.6; margin-bottom: 20px; }
.ovn-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.ovn-filter-btn { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 12px; font-weight: 500; letter-spacing: 0.03em; background: var(--bg); color: var(--mid); border: 1px solid var(--border); border-radius: 20px; padding: 6px 14px; cursor: pointer; transition: all 0.15s; }
.ovn-filter-btn:hover { border-color: var(--accent); color: var(--accent); }
.ovn-filter-btn.active { background: var(--accent); color: var(--white); border-color: var(--accent); }
.ovn-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px) { .ovn-grid { grid-template-columns: 1fr; } }
.ovn-card { border: 1px solid var(--border); border-radius: 8px; padding: 20px; background: var(--white); transition: border-color 0.15s; cursor: pointer; }
.ovn-card:hover { border-color: var(--accent); }
.ovn-card.done { opacity: 0.55; }
.ovn-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 6px; }
.ovn-card-title { font-family: 'Crimson Pro', serif; font-size: 17px; font-weight: 400; line-height: 1.3; }
.ovn-card-meta { font-size: 11px; color: #999; margin-bottom: 8px; }
.ovn-card-meta span { margin-right: 10px; }
.ovn-card-syfte { font-size: 13px; color: var(--mid); line-height: 1.5; }
.ovn-card-body { display: none; margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border); }
.ovn-card-body.open { display: block; }
.ovn-card-body p { font-size: 13px; color: #333; line-height: 1.65; margin-bottom: 8px; white-space: pre-line; }
.ovn-done-btn { margin-top: 12px; font-size: 12px; font-weight: 500; background: none; border: 1px solid var(--green); color: var(--green); border-radius: 20px; padding: 5px 14px; cursor: pointer; }
.ovn-done-btn.marked { background: var(--green); color: var(--white); }
.ovn-badge { display: inline-block; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; padding: 2px 8px; border-radius: 10px; background: #f0f0f0; color: #888; }
.ovn-badge.niva-1 { background: #e8f5e9; color: #2e7d32; }
.ovn-badge.niva-2 { background: #fff3e0; color: #e65100; }
.ovn-badge.niva-3 { background: #fce4ec; color: #c62828; }
.ovn-counter { font-size: 13px; color: var(--mid); margin-bottom: 16px; }
.ovn-start-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 20px; }
@media (max-width: 480px) { .ovn-start-grid { grid-template-columns: 1fr; } }
.ovn-formaga-kort { border: 2px solid var(--border); border-radius: 10px; padding: 20px; cursor: pointer; transition: all 0.15s; text-align: center; }
.ovn-formaga-kort:hover { border-color: var(--accent); transform: translateY(-1px); }
.ovn-formaga-kort.active { border-color: var(--accent); background: #fff8f0; }
.ovn-formaga-kort-namn { font-family: 'Crimson Pro', serif; font-size: 18px; font-weight: 400; margin-bottom: 4px; }
.ovn-formaga-kort-count { font-size: 12px; color: #999; }
.ovn-kontext-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.ovn-visa-alla { display: block; text-align: center; margin-top: 16px; font-size: 13px; color: var(--accent); cursor: pointer; text-decoration: underline; text-underline-offset: 3px; }

/* SPRÅKMÖNSTERÖVNINGAR (quiz) */
.sprakmonster-section { border: 1px solid var(--border); border-radius: 8px; padding: 32px; margin-bottom: 32px; background: var(--white); }
.sprakmonster-section h3 { font-family: 'Crimson Pro', serif; font-size: 22px; font-weight: 300; margin-bottom: 4px; }
.sprakmonster-intro { font-size: 14px; color: var(--mid); line-height: 1.6; margin-bottom: 20px; }
.sprak-quiz-wrap { position: relative; }
.sprak-mascot { width: 80px; height: 80px; object-fit: contain; transition: opacity 0.3s; margin: 0 auto 16px; display: block; }
/* sprak-meta-pills removed — stats shown in collapsible section */
.sprak-quiz-card { border: 1px solid var(--border); border-radius: 8px; padding: 24px; background: #fafafa; margin-bottom: 16px; }
.sprak-quiz-category { font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--mid); margin-bottom: 12px; }
.sprak-quiz-text { font-family: 'Crimson Pro', Georgia, serif; font-style: italic; font-size: 22px; line-height: 1.5; border-left: 3px solid var(--accent); padding-left: 16px; margin-bottom: 16px; color: var(--dark); }
.sprak-quiz-question { font-weight: 400; font-size: 13px; color: #888; margin-top: 10px; margin-bottom: 12px; }
.sprak-quiz-options { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 16px; }
@media (max-width: 480px) { .sprak-quiz-options { grid-template-columns: 1fr; } }
.sprak-quiz-opt { padding: 10px 14px; border: 1px solid var(--border); border-radius: 6px; background: var(--white); font-family: inherit; font-size: 14px; cursor: pointer; transition: all 0.15s; text-align: left; }
.sprak-quiz-opt:hover { border-color: var(--accent); }
.sprak-quiz-opt.correct { border-color: var(--green); background: #e8f5e9; }
.sprak-quiz-opt.wrong { border-color: #e53935; background: #fce4ec; }
.sprak-quiz-opt:disabled { cursor: default; opacity: 0.85; }
.sprak-quiz-feedback { display: none; padding: 12px 16px; background: #f5f3f0; border-radius: 6px; font-size: 14px; line-height: 1.55; margin-bottom: 12px; }
.sprak-quiz-feedback.show { display: block; }
.sprak-quiz-next { display: none; font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; font-size: 13px; font-weight: 500; background: var(--accent); color: var(--white); border: none; border-radius: 20px; padding: 8px 20px; cursor: pointer; }
.sprak-quiz-next.show { display: inline-block; }
.sprak-quiz-score { font-size: 13px; color: var(--mid); text-align: right; margin-bottom: 12px; }
.sprak-stats-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 16px; }
@media (max-width: 480px) { .sprak-stats-grid { grid-template-columns: 1fr; } }
.sprak-stat-card { border: 1px solid var(--border); border-radius: 6px; padding: 12px 16px; background: #fafafa; }
.sprak-stat-label { font-size: 12px; color: var(--mid); margin-bottom: 4px; }
.sprak-stat-value { font-family: 'Crimson Pro', serif; font-size: 20px; font-weight: 400; }

/* ALUMNI HISTORIK */
.alumni-historik { border: 1px solid var(--border); padding: 32px; margin-bottom: 32px; }
.alumni-historik h3 { font-family: 'Crimson Pro', serif; font-size: 22px; font-weight: 300; margin-bottom: 16px; }
.alumni-historik .mini-chart-wrap { max-width: 400px; margin: 0 auto 20px; overflow: hidden; }
.alumni-historik .mini-chart-wrap canvas { width: 100% !important; height: auto !important; }
.alumni-historik .forv-list { font-size: 14px; color: var(--mid); line-height: 1.65; }
.alumni-historik .forv-list strong { color: var(--dark); }

/* COACH ALUMNI */
.coach-alumni-note { font-size: 13px; color: var(--muted); margin-bottom: 16px; }

/* === FÖRFLYTTNING HERO === */
.forflyttning-hero { width:100%; background:#fff; border-bottom:1px solid #ece9e3; padding:40px 48px; max-width:960px; margin:0 auto; box-sizing:border-box; }
.forflyttning-eyebrow { font-size:9px; text-transform:uppercase; color:#c8996a; letter-spacing:0.12em; margin-bottom:8px; font-family:'DM Sans',sans-serif; }
.forflyttning-rubrik { font-family:'Playfair Display',Georgia,serif; font-style:italic; font-size:28px; font-weight:400; color:#1a1a1a; margin-bottom:4px; margin-top:0; }
.forflyttning-under { font-size:13px; color:#999; margin-bottom:28px; }
.tidslinje { display:flex; justify-content:space-between; align-items:center; position:relative; padding:0 20px; }
.tidslinje::before { content:''; position:absolute; top:50%; left:20px; right:20px; height:2px; background:#ece9e3; transform:translateY(-50%); }
.tidslinje-punkt { display:flex; flex-direction:column; align-items:center; gap:6px; position:relative; z-index:1; }
.tidslinje-dot { width:14px; height:14px; border-radius:50%; background:#ece9e3; border:2px solid #ece9e3; }
.tidslinje-dot.done { background:#c8996a; border-color:#c8996a; }
.tidslinje-dot.active { background:#fff; border-color:#c8996a; box-shadow:0 0 0 4px rgba(200,153,106,0.2); }
.tidslinje-label { font-size:10px; color:#999; white-space:nowrap; }
.tidslinje-label.active { color:#1a1a1a; font-weight:500; }

/* === SCORE-RAD === */
.score-rad { display:grid; grid-template-columns:repeat(3,1fr); gap:0; background:#faf9f7; border-top:1px solid #ece9e3; border-bottom:1px solid #ece9e3; max-width:960px; margin:0 auto; }
.score-kort { padding:24px 28px; text-align:center; border-right:1px solid #ece9e3; }
.score-kort:last-child { border-right:none; }
.score-label { font-size:9px; text-transform:uppercase; letter-spacing:0.1em; color:#bbb; margin-bottom:8px; font-family:'DM Sans',sans-serif; }
.score-tal { font-family:'Playfair Display',Georgia,serif; font-style:italic; font-size:32px; font-weight:400; color:#1a1a1a; margin-bottom:8px; }
.score-bar { width:100%; height:2px; background:#ece9e3; margin-bottom:6px; }
.score-bar-fill { height:100%; background:#c8996a; transition:width 0.5s; }
.score-undertext { font-size:11px; color:#999; }

/* === SPIDER-SEKTION === */
.spider-sektion { display:grid; grid-template-columns:200px 1fr; gap:32px; background:#fff; border-bottom:1px solid #ece9e3; max-width:960px; margin:0 auto; padding:32px 28px; }
.spider-info h3 { font-family:'Playfair Display',Georgia,serif; font-style:italic; font-size:20px; font-weight:400; color:#1a1a1a; margin-bottom:8px; }
.spider-info p { font-size:13px; color:#999; line-height:1.6; margin-bottom:16px; }
.spider-legend { display:flex; flex-direction:column; gap:6px; }
.spider-legend-item { display:flex; align-items:center; gap:8px; font-size:11px; color:#666; }
.spider-legend-dot { width:8px; height:8px; border-radius:50%; }

/* === MÅL-SEKTION === */
.mal-sektion { background:#fff; border-bottom:1px solid #ece9e3; max-width:960px; margin:0 auto; padding:32px 28px; }
.mal-sektion-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.mal-rad { display:flex; align-items:center; gap:16px; padding:16px 0; border-bottom:1px solid #f5f0e8; cursor:pointer; }
.mal-rad:last-child { border-bottom:none; }
.mal-progress-ring { flex-shrink:0; }
.mal-rad-info { flex:1; }
.mal-rad-titel { font-size:14px; font-weight:500; color:#1a1a1a; }
.mal-rad-status { font-size:11px; color:#999; }
.mal-rad-pil { font-size:16px; color:#ccc; }

/* === KAMPANJ-BANNER === */
.kampanj-banner { margin:16px auto; max-width:960px; background:#fff8f0; border:1px solid #e8d5bb; padding:24px 28px; display:flex; justify-content:space-between; align-items:center; box-sizing:border-box; gap:16px; }
.kampanj-banner > div { flex:1; min-width:0; }
.kampanj-banner p { font-size:14px; color:#5a5a5a; line-height:1.5; margin:0; word-wrap:break-word; }
.kampanj-banner strong { color:#1a1a1a; }

/* === VERKTYG-GRID === */
.verktyg-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; background:#faf9f7; max-width:960px; margin:0 auto; border-bottom:1px solid #ece9e3; }
.verktyg-kort { padding:24px 20px; text-align:center; border-right:1px solid #ece9e3; cursor:pointer; transition:background 0.15s; }
.verktyg-kort:last-child { border-right:none; }
.verktyg-kort:hover { background:#f5f2ee; }
.verktyg-kort svg { margin-bottom:8px; }
.verktyg-kort-titel { font-size:12px; font-weight:500; color:#1a1a1a; margin-bottom:2px; }
.verktyg-kort-sub { font-size:10px; color:#bbb; }

/* === MOBILE HERO === */
@media (max-width: 768px) {
  .spider-sektion { grid-template-columns:1fr; }
  .score-rad { grid-template-columns:1fr; }
  .score-kort { border-right:none; border-bottom:1px solid #ece9e3; }
  .verktyg-grid { grid-template-columns:repeat(2,1fr); }
  .tidslinje { overflow-x:auto; }
  .kampanj-banner { flex-direction:column; gap:12px; text-align:center; }
}

/* Dashboard grid */
.dashboard-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; max-width: 960px; width: 100%; box-sizing: border-box; margin: 0 auto 32px; }
.dashboard-grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.dash-status { max-width: 960px; width: 100%; box-sizing: border-box; margin: 0 auto 8px; }
.dash-status-inner { background: var(--white); border: 0.5px solid #e8e8e8; border-left: 3px solid #c8996a; border-radius: 0; padding: 1.25rem 1.5rem; display: flex; justify-content: space-between; align-items: flex-start; }
#dash-utbildningsnamn, .dash-status-left h2 { font-weight: 700 !important; font-family: 'Crimson Pro', Georgia, serif !important; font-size: 18px; margin: 0 0 4px; }
.dash-status-subtitle { font-size: 13px; color: #888; margin: 0; }
.dash-status-nasta { font-size: 13px; color: #c8996a; font-weight: 500; margin: 6px 0 0; }
.dash-status-right { text-align: right; font-size: 13px; color: #888; }
.dash-status-right strong { display: block; font-size: 15px; font-weight: 500; color: var(--dark); }
.dash-dagar { display: inline-block; background: #fdf6ee; color: #c8996a; border: 0.5px solid #e8d5bb; font-size: 13px; font-weight: 500; padding: 3px 10px; border-radius: 20px; margin-top: 4px; }
.modul-kort { background: #fff; border: 1px solid #ece9e3; border-radius: 0; padding: 28px 26px; min-height: 140px; transition: border-color 0.15s, transform 0.15s; position: relative; }
.modul-kort.podd-kort { min-height: 280px; }
.modul-kort.podd-kort .modul-kort-header { margin-bottom: 16px; }
.modul-kort.wide { grid-column: 1 / -1; }
.modul-kort:hover { border-color: #c8996a; transform: translateY(-1px); box-shadow: none; }
.modul-kort-header { display: flex; align-items: flex-start; gap: 16px; }
.modul-ikon { width: 40px; height: 40px; border-radius: 0; background: none; display: flex; align-items: center; justify-content: center; flex-shrink: 0; color: #1a1a1a; }
.modul-info { flex: 1; min-width: 0; }
.modul-kort .modul-rubrik { font-family: 'Crimson Pro', Georgia, serif !important; font-size: 16px; font-weight: 500; color: var(--dark); margin: 0 0 2px; letter-spacing: -0.01em; }
.modul-kort .modul-status { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif !important; font-size: 14px; line-height: 1.6; color: #888; margin: 0; }
.modul-innehall { display: none; margin-top: 1rem; padding-top: 1rem; border-top: 0.5px solid #e8e8e8; }
.modul-kort.expanderad { grid-column: 1 / -1; border-color: #c8996a; }
.modul-kort.expanderad .modul-innehall { display: block; }
.modul-innehall > * { max-width: 680px; }
.innehall-stang { display: flex; justify-content: flex-end; margin-bottom: 1rem; max-width: none; }
.modul-chevron { display: none; }
.modul-kort-header::after { content: ''; display: inline-block; width: 16px; height: 16px; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 8h10M9 4l4 4-4 4' stroke='%23c8996a' stroke-width='1.2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-size: contain; opacity: 0; transform: translateX(-4px); transition: opacity 0.2s, transform 0.2s; flex-shrink: 0; margin-left: auto; }
.modul-kort:hover .modul-kort-header::after { opacity: 1; transform: translateX(0); }
.modul-kort.expanderad .modul-chevron { transform: rotate(90deg); color: #c8996a; }
.extern-pil { font-size: 11px; color: #bbb; margin-left: 4px; }
.dashboard-botten { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; max-width: 960px; width: 100%; box-sizing: border-box; margin-left: auto; margin-right: auto; margin-top: 32px; padding-left: 1.5rem; padding-right: 1.5rem; }
.botten-kort { background: var(--white); border: 1px solid #ece9e3; border-radius: 0; padding: 28px 26px; }
.botten-kort-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px solid #ece9e3; }
.botten-kort .botten-kort-rubrik { font-family: 'Crimson Pro', Georgia, serif !important; font-size: 16px; font-weight: 500; color: var(--dark); text-transform: none; letter-spacing: -0.01em; margin: 0; }
.botten-kort .modul-ikon { color: #1a1a1a; background: none; }
.artikel-rad { padding: 8px 0; border-bottom: 0.5px solid #e8e8e8; font-size: 13px; color: var(--dark); line-height: 1.4; }
.artikel-rad:last-child { border-bottom: none; padding-bottom: 0; }
.artikel-rubrik { font-family: 'DM Sans', 'Helvetica Neue', Arial, sans-serif; font-size: 13px; display: block; color: var(--dark); text-decoration: none; }
.artikel-rubrik:hover { color: var(--accent); }

/* SECTION LABEL */
.section-label {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #bbb;
  max-width: 960px;
  width: 100%;
  box-sizing: border-box;
  margin: 28px auto 10px;
}
.section-label:first-of-type {
  margin-top: 8px;
}

@media (max-width: 768px) {
  .dashboard-grid,
  .dashboard-grid.cols-3,
  .dashboard-botten {
    grid-template-columns: 1fr;
  }
}

/* MOBIL */
@media (max-width: 768px) {
  #commitments-section { display: none !important; }
  #commitments-mobile-notice { display: block !important; }

  .nav-right { gap: 12px; }
  .nav-right span { display: none; }

  .wrap { padding: 32px 16px 60px; }

  .team-grid { grid-template-columns: 1fr !important; }

  .education-details { flex-direction: column; gap: 8px; }

  .message-box {
    width: 100% !important; max-width: 100% !important;
    margin: 0 !important; border-radius: 0 !important;
    min-height: 100vh;
  }
  .message-overlay.active { align-items: flex-start; }

  .three60-tab-bar { overflow-x: auto; }
  .three60-tab { white-space: nowrap; font-size: 13px; }

  .forum-topbar { flex-direction: column; align-items: stretch; }
  .forum-ny-btn { width: 100%; text-align: center; }

  .coach-input-wrap { flex-direction: column; }
  .coach-input { width: 100%; }

  .referral-section { padding: 24px 16px; }
}
