/* Förbättringar av kalenderhändelser steg 2 – v7 feature styles */

.page-header {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-bottom: 8px;
}
.page-header__title { margin: 0; font-size: 28px; font-weight: 400; color: var(--gray-darker); }
.page-header__sub { margin: 0; color: var(--gray-dark); font-size: 14px; }
.page-header__context {
    display: inline-flex; align-items: center; gap: 8px;
    background: #eef1f7; color: var(--cl-hard);
    padding: 4px 12px; border-radius: 999px; font-size: 13px; font-weight: 500;
    width: fit-content; margin-top: 4px;
}
.page-header__persona-line { margin-top: 4px; color: var(--gray-dark); font-size: 13px; }

/* Calendar toolbar */
.calendar-toolbar {
    display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center;
    gap: 12px; margin: 16px 0;
}
.calendar-nav { display: flex; align-items: center; gap: 6px; }
.calendar-nav__btn {
    width: 36px; height: 36px; border-radius: 50%;
    border: 1px solid var(--gray-smooth); background: var(--white); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
}
.calendar-nav__btn:hover { background: var(--gray-lightest); }
.calendar-nav__label { font-weight: 500; margin: 0 12px; font-size: 15px; color: var(--gray-darker); min-width: 220px; text-align: center; }
.calendar-nav__today {
    border: 1px solid var(--cl-hard); background: transparent; color: var(--cl-hard);
    padding: 6px 14px; border-radius: 999px; cursor: pointer; font-weight: 500;
}
.calendar-nav__today:hover { background: rgba(38, 65, 143, 0.08); }

.view-toggle { display: flex; background: var(--gray-lightest); border-radius: 8px; padding: 2px; }
.view-toggle__btn {
    border: none; background: transparent; padding: 8px 14px; border-radius: 6px;
    cursor: pointer; font-size: 14px; color: var(--gray-dark);
    display: inline-flex; align-items: center; gap: 6px;
}
.view-toggle__btn .material-icons { font-size: 18px; }
.view-toggle__btn--active { background: var(--white); color: var(--cl-hard); box-shadow: 0 1px 3px rgba(0,0,0,.12); }

.calendar-actions { display: flex; gap: 8px; align-items: center; }

/* Filter bar */
.filter-bar {
    display: flex; flex-wrap: wrap; gap: 8px;
    padding: 8px 0 16px;
    border-bottom: 1px solid var(--gray-lighter);
    margin-bottom: 16px;
}
.filter-chip {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 6px 14px; border-radius: 999px;
    border: 1px solid var(--gray-smooth); background: var(--white);
    cursor: pointer; font-size: 13px; color: var(--gray-dark);
}
.filter-chip__dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; }
.filter-chip--active { background: #eef1f7; color: var(--cl-hard); border-color: var(--cl-medium); }

/* Summary chips */
.event-summary { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.summary-chip {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--gray-lightest); color: var(--gray-darker);
    padding: 6px 12px; border-radius: 999px; font-size: 13px;
}
.summary-chip .material-icons { font-size: 16px; color: var(--cl-hard); }
.summary-chip--legacy { background: #fff3e0; color: #e65100; }
.summary-chip--legacy .material-icons { color: #e65100; }

/* Calendar page layout */
.calendar-page {
    display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 24px;
    align-items: start;
}
@media (max-width: 1100px) {
    .calendar-page { grid-template-columns: 1fr; }
}

.calendar-panel {
    background: var(--white); border: 1px solid var(--gray-lighter);
    border-radius: 10px; box-shadow: 0 2px 8px rgba(0,0,0,.04); overflow: hidden;
}
.calendar-panel__header {
    padding: 14px 18px; border-bottom: 1px solid var(--gray-lighter);
    display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.calendar-panel__header h2 { margin: 0; font-size: 16px; font-weight: 500; color: var(--gray-darker); }

/* View panels */
.calendar-view-panel { display: none; }
.calendar-view-panel.is-active { display: block; }

/* Week view */
.week-grid {
    display: grid;
    grid-template-columns: 72px repeat(5, minmax(0, 1fr));
    position: relative;
}
.week-grid__day-header {
    padding: 10px 8px; text-align: left; border-bottom: 1px solid var(--gray-lighter);
    background: var(--gray-lightest);
    display: flex; flex-direction: column; gap: 2px;
}
.week-grid__day-name { font-size: 11px; font-weight: 700; letter-spacing: .08em; color: var(--gray-dark); }
.week-grid__day-date { font-size: 15px; color: var(--gray-darker); font-weight: 500; }

.week-grid__time-col {
    background: var(--gray-lightest); border-bottom: 1px solid var(--gray-lighter);
}

.week-grid__allday-row {
    display: grid; grid-template-columns: 72px repeat(5, minmax(0, 1fr));
    border-bottom: 2px solid var(--cl-hard); background: #fafbff;
}
.week-grid__allday-label {
    padding: 8px 10px; font-size: 11px; font-weight: 700; letter-spacing: .08em;
    color: var(--cl-hard); text-transform: uppercase;
    display: flex; align-items: center; gap: 6px;
    border-right: 1px solid var(--gray-lighter);
}
.week-grid__allday-label .material-icons { font-size: 16px; }
.week-grid__allday-col {
    padding: 6px 6px; display: flex; flex-direction: column; gap: 4px;
    border-right: 1px solid var(--gray-lighter); min-height: 40px;
}
.week-grid__allday-col:last-child { border-right: none; }

.allday-event {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 10px; border-radius: 6px; cursor: pointer;
    background: #e3eafb; color: var(--gray-darker); font-size: 13px;
    border: none; text-align: left; width: 100%;
    border-left: 3px solid var(--cl-hard);
}
.allday-event:hover { background: #d2dbf0; }
.allday-event--school { background: #f3e5f5; border-left-color: #7b1fa2; }
.allday-event--class  { background: #e3eafb; border-left-color: #1976d2; }
.allday-event--course { background: #e8f5e9; border-left-color: #388e3c; }
.allday-event--team   { background: #fff3e0; border-left-color: #f57c00; }
.allday-event__title  { font-weight: 500; flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.allday-event__dot { width: 8px; height: 8px; border-radius: 50%; }
.allday-event__badge { font-size: 14px; margin-left: auto; color: var(--gray-dark); }
.allday-event.is-legacy { opacity: .75; font-style: italic; }
.allday-slot--empty { min-height: 28px; }

.week-grid__body {
    position: relative;
    display: grid; grid-template-columns: 72px repeat(5, minmax(0, 1fr));
    min-height: 480px;
}
.week-grid__hours-col {
    display: flex; flex-direction: column;
    background: var(--gray-lightest);
}
.week-grid__hours-col .week-grid__time {
    font-size: 11px; color: var(--gray-dark); padding: 4px 10px 0 0; text-align: right;
    border-top: 1px solid var(--gray-lighter);
    flex: 1 1 42px; min-height: 42px; box-sizing: border-box;
}
.week-grid__day-col {
    position: relative;
    background: var(--white);
    border-right: 1px solid var(--gray-lighter);
    display: flex; flex-direction: column;
}
.week-grid__day-col:last-child { border-right: none; }
.week-grid__hourline {
    flex: 1 1 42px; min-height: 42px;
    border-top: 1px solid var(--gray-lighter);
    box-sizing: border-box;
}

/* Timed events */
.timed-event {
    position: absolute; left: 2%; right: 2%;
    padding: 4px 8px; border-radius: 6px; cursor: pointer;
    background: #e3eafb; color: var(--gray-darker); font-size: 12px;
    border: none; text-align: left;
    display: flex; flex-direction: column; gap: 2px;
    overflow: hidden;
    box-shadow: 0 1px 2px rgba(0,0,0,.1);
}
.timed-event--class  { background: #e3eafb; border-left: 3px solid #1976d2; }
.timed-event--course { background: #e8f5e9; border-left: 3px solid #388e3c; }
.timed-event--school { background: #f3e5f5; border-left: 3px solid #7b1fa2; }
.timed-event--team   { background: #fff3e0; border-left: 3px solid #f57c00; }
.timed-event__time { font-size: 11px; color: var(--gray-dark); }
.timed-event__title { font-weight: 500; line-height: 1.2; }
.timed-event__place { font-size: 11px; color: var(--gray-dark); }
.timed-event__badge { position: absolute; top: 4px; right: 4px; font-size: 14px; color: var(--cl-hard); }
.timed-event.is-recurring { border-right: 3px solid #fbc02d; }

/* Month view */
.month-view { padding: 16px; }
.month-view__title { font-size: 18px; font-weight: 500; margin-bottom: 12px; color: var(--gray-darker); text-transform: capitalize; }
.month-grid {
    display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 1px;
    background: var(--gray-lighter); border: 1px solid var(--gray-lighter); border-radius: 8px; overflow: hidden;
}
.month-cell { overflow: hidden; min-width: 0; }
.month-header { background: var(--gray-lightest); padding: 8px; font-size: 12px; font-weight: 700; color: var(--gray-dark); text-align: center; letter-spacing: .08em; }
.month-cell { background: var(--white); min-height: 100px; padding: 6px; display: flex; flex-direction: column; gap: 4px; }
.month-cell.is-outside { background: var(--gray-lightest); opacity: .5; }
.month-cell__date { font-size: 12px; font-weight: 500; color: var(--gray-darker); }
.month-cell__event { display: flex; align-items: center; gap: 4px; padding: 2px 4px; border-radius: 4px; background: #f5f7fb; border: none; cursor: pointer; font-size: 11px; color: var(--gray-darker); text-align: left; width: 100%; overflow: hidden; }
.month-cell__event:hover { background: #e3eafb; }
.month-cell__time { font-weight: 500; color: var(--gray-dark); }
.month-cell__dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.month-cell__title { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.month-cell__more { font-size: 10px; color: var(--cl-hard); font-weight: 500; }

/* Day view */
.day-view { padding: 18px; }
.day-view__header { margin-bottom: 16px; }
.day-view__header h3 { margin: 0; color: var(--gray-darker); font-weight: 500; text-transform: capitalize; }
.day-view__sub { margin: 4px 0 0; color: var(--gray-dark); font-size: 13px; }
.day-view__label { display: flex; align-items: center; gap: 6px; font-size: 13px; font-weight: 600; color: var(--cl-hard); margin: 12px 0 8px; text-transform: uppercase; letter-spacing: .08em; }
.day-view__label .material-icons { font-size: 16px; }
.day-view__allday, .day-view__timed { display: flex; flex-direction: column; gap: 8px; }

.event-card { display: flex; align-items: center; gap: 12px; padding: 12px; background: var(--white); border: 1px solid var(--gray-lighter); border-radius: 8px; cursor: pointer; text-align: left; width: 100%; }
.event-card:hover { border-color: var(--cl-medium); background: var(--gray-lightest); }
.event-card__left { width: 4px; align-self: stretch; border-radius: 2px; }
.event-card__body { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.event-card__title { font-weight: 500; color: var(--gray-darker); }
.event-card__meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: 13px; color: var(--gray-dark); align-items: center; }
.event-card__chevron { color: var(--gray-dark); }

/* List view */
.calendar-view-panel[data-view-panel="list"] { padding: 8px 0; }
.feature-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.feature-table thead th { text-align: left; padding: 12px 16px; background: var(--gray-lightest); border-bottom: 1px solid var(--gray-lighter); color: var(--gray-dark); font-weight: 500; font-size: 12px; letter-spacing: .06em; text-transform: uppercase; }
.feature-table tbody td { padding: 12px 16px; border-bottom: 1px solid var(--gray-lighter); vertical-align: middle; }
.event-row { cursor: pointer; }
.event-row:hover td { background: var(--gray-lightest); }
.event-row__title { font-weight: 500; color: var(--gray-darker); margin-right: 8px; }

/* Badges */
.badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 500; background: var(--gray-lightest); color: var(--gray-dark); }
.badge .material-icons { font-size: 12px; }
.badge--allday { background: #e1f5fe; color: #01579b; }
.badge--recurring { background: #fff8e1; color: #f57f17; }
.badge--legacy { background: #fbe9e7; color: #bf360c; }

/* Upcoming widget */
.calendar-sidebar { display: flex; flex-direction: column; gap: 16px; }
.widget { background: var(--white); border: 1px solid var(--gray-lighter); border-radius: 10px; overflow: hidden; }
.widget__header { padding: 12px 16px; border-bottom: 1px solid var(--gray-lighter); display: flex; justify-content: space-between; align-items: center; }
.widget__title { margin: 0; font-size: 15px; font-weight: 500; color: var(--gray-darker); }
.widget__body { padding: 10px 12px; display: flex; flex-direction: column; gap: 8px; }

.upcoming-item { display: flex; gap: 12px; align-items: center; padding: 8px; border-radius: 8px; border: none; background: transparent; cursor: pointer; text-align: left; }
.upcoming-item:hover { background: var(--gray-lightest); }
.upcoming-item__date { display: flex; flex-direction: column; align-items: center; justify-content: center; border: 2px solid var(--cl-hard); border-radius: 6px; width: 44px; height: 44px; flex-shrink: 0; }
.upcoming-item__day { font-size: 16px; font-weight: 700; color: var(--gray-darker); }
.upcoming-item__month { font-size: 10px; letter-spacing: .08em; color: var(--gray-dark); text-transform: uppercase; }
.upcoming-item__body { flex: 1; display: flex; flex-direction: column; gap: 2px; overflow: hidden; }
.upcoming-item__title { font-weight: 500; color: var(--gray-darker); }
.upcoming-item__meta { font-size: 12px; color: var(--gray-dark); display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

/* Quick actions panel */
.quick-actions { display: flex; flex-direction: column; gap: 8px; padding: 10px 12px; }
.quick-actions .mdc-button { justify-content: flex-start; width: 100%; }

/* Empty state */
.empty-state { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 32px 16px; color: var(--gray-dark); text-align: center; }
.empty-state .material-icons { font-size: 40px; color: var(--gray-smooth); }
.empty-state p { margin: 0; }
.empty-state--error .material-icons { color: #c62828; }

/* FAB */
.create-event-fab {
    position: fixed; right: 24px; bottom: 24px; z-index: 6;
    width: 56px; height: 56px; border-radius: 50%; border: none; cursor: pointer;
    background: #4caf50; color: var(--white);
    box-shadow: 0 4px 12px rgba(0,0,0,.2);
    display: flex; align-items: center; justify-content: center;
}
.create-event-fab:hover { background: #43a047; }

/* Dialogs */
.kal-dialog-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.45);
    display: none; justify-content: center; align-items: flex-start; padding: 48px 16px;
    z-index: 50;
}
.kal-dialog-overlay.is-open { display: flex; }
.kal-dialog {
    background: var(--white); border-radius: 12px;
    width: 100%; max-width: 640px;
    max-height: calc(100vh - 96px);
    display: flex; flex-direction: column; overflow: hidden;
    box-shadow: 0 12px 40px rgba(0,0,0,.25);
    position: relative;
}
.kal-dialog--form { max-width: 720px; }
.kal-dialog--scope, .kal-dialog--confirm, .kal-dialog--info { max-width: 540px; }
.kal-dialog__close {
    position: absolute; top: 10px; right: 10px; width: 36px; height: 36px; border-radius: 50%;
    border: none; background: transparent; cursor: pointer;
    display: flex; align-items: center; justify-content: center; color: var(--gray-dark);
}
.kal-dialog__close:hover { background: var(--gray-lightest); }
.kal-dialog__header { padding: 20px 24px 8px; border-bottom: 1px solid var(--gray-lighter); }
.kal-dialog__header h2 { margin: 0 0 6px; font-weight: 500; color: var(--gray-darker); }
.kal-dialog__subtitle { margin: 0; font-size: 13px; color: var(--gray-dark); }
.kal-dialog__body { padding: 16px 24px; overflow-y: auto; flex: 1; }
.kal-dialog__footer { padding: 12px 24px; border-top: 1px solid var(--gray-lighter); display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }

.event-header-tag {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 10px; border-radius: 999px; font-size: 12px; font-weight: 500;
    margin-bottom: 6px;
}
.event-header-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.readonly-note {
    display: flex; align-items: center; gap: 8px; padding: 10px 12px; border-radius: 8px;
    background: #fff8e1; color: #e65100; font-size: 13px; margin-bottom: 12px;
}
.event-info { display: grid; grid-template-columns: auto 1fr; gap: 6px 16px; margin: 12px 0; }
.event-info dt { display: flex; align-items: center; gap: 6px; color: var(--gray-dark); font-size: 13px; }
.event-info dt .material-icons { font-size: 16px; }
.event-info dd { margin: 0; color: var(--gray-darker); font-size: 14px; }

.event-description { margin-top: 16px; }
.event-description h3 { margin: 0 0 6px; font-size: 13px; text-transform: uppercase; letter-spacing: .08em; color: var(--gray-dark); font-weight: 600; }
.event-description p { margin: 0; line-height: 1.5; color: var(--gray-darker); word-break: break-word; }
.event-description a { color: var(--cl-hard); text-decoration: underline; display: inline-flex; align-items: center; gap: 4px; }
.event-description a .material-icons { font-size: 14px; }

/* Buttons */
.mdc-button {
    border: none; background: transparent; cursor: pointer; padding: 10px 16px; border-radius: 6px;
    font-weight: 500; font-size: 14px; color: var(--cl-hard);
    display: inline-flex; align-items: center; gap: 6px;
}
.mdc-button:hover { background: rgba(38, 65, 143, .08); }
.mdc-button--outlined { border: 1px solid var(--cl-hard); }
.mdc-button--primary { background: var(--cl-hard); color: var(--white); }
.mdc-button--primary:hover { background: var(--cl-medium); }
.mdc-button--danger { background: transparent; color: #c62828; }
.mdc-button--danger:hover { background: rgba(198, 40, 40, .08); }
.mdc-button[disabled] { opacity: .6; cursor: progress; }

/* Form */
.event-form { display: flex; flex-direction: column; gap: 14px; }
.form-field { display: flex; flex-direction: column; gap: 4px; }
.form-field input[type="text"],
.form-field input[type="date"],
.form-field input[type="time"],
.form-field select,
.form-field textarea {
    border: 1px solid var(--gray-smooth); border-radius: 6px; padding: 8px 10px;
    font-family: inherit; font-size: 14px; color: var(--gray-darker); background: var(--white);
}
.form-field label { font-weight: 500; color: var(--gray-darker); font-size: 13px; }
.form-field .hint { font-size: 12px; color: var(--gray-dark); }
.form-field .required { color: #c62828; }
.form-field--row { flex-direction: row; align-items: center; gap: 12px; flex-wrap: wrap; }
.form-field--row label { margin: 0; }
.checkbox-label { display: inline-flex; align-items: center; gap: 8px; font-weight: 500; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }

.form-preview {
    display: flex; align-items: flex-start; gap: 8px;
    background: #eef1f7; color: var(--cl-hard);
    padding: 10px 12px; border-radius: 8px; font-size: 13px;
}
.form-preview .material-icons { font-size: 18px; }

.form-errors { display: flex; flex-direction: column; gap: 6px; }
.form-errors .error {
    display: flex; align-items: center; gap: 6px; background: #fdecea; color: #b71c1c;
    padding: 8px 10px; border-radius: 6px; font-size: 13px;
}
.form-errors .error .material-icons { font-size: 16px; }

/* Scope options */
.scope-options { display: flex; flex-direction: column; gap: 10px; }
.scope-option {
    display: flex; gap: 12px; align-items: flex-start;
    padding: 12px; border: 1px solid var(--gray-smooth); border-radius: 8px; cursor: pointer;
}
.scope-option:hover { background: var(--gray-lightest); border-color: var(--cl-medium); }
.scope-option input[type="radio"] { margin-top: 4px; }
.scope-option strong { display: block; color: var(--gray-darker); margin-bottom: 2px; }
.scope-option span { display: block; color: var(--gray-dark); font-size: 13px; }
.scope-lead { margin: 0 0 12px; color: var(--gray-darker); }

.muted { color: var(--gray-dark); }

/* Toast */
.toast {
    position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%);
    background: #263238; color: var(--white); border-radius: 8px;
    padding: 12px 16px; display: flex; align-items: center; gap: 12px;
    box-shadow: 0 4px 16px rgba(0,0,0,.2); z-index: 60;
    max-width: 540px;
}
.toast__message { flex: 1; font-size: 14px; }
.toast__action {
    background: transparent; border: none; color: #90caf9; cursor: pointer;
    font-weight: 500; padding: 4px 8px;
}
.toast__close { background: transparent; border: none; color: var(--white); cursor: pointer; display: flex; align-items: center; justify-content: center; }

/* Dark mode tweaks */
body.dark-mode .calendar-panel,
body.dark-mode .widget,
body.dark-mode .event-card,
body.dark-mode .kal-dialog,
body.dark-mode .month-cell,
body.dark-mode .feature-table thead th,
body.dark-mode .week-grid__cell,
body.dark-mode .week-grid__day-header,
body.dark-mode .week-grid__time-col,
body.dark-mode .week-grid__time { background-color: var(--gray-darker); color: var(--gray-lighter); border-color: #3a3a3a; }
body.dark-mode .calendar-panel, body.dark-mode .widget, body.dark-mode .event-card, body.dark-mode .kal-dialog { border-color: #3a3a3a; }
body.dark-mode .page-header__context { background: #2a2e40; color: #dde3ff; }
body.dark-mode .summary-chip { background: #2a2a2a; color: #e0e0e0; }
body.dark-mode .filter-chip { background: var(--gray-darker); color: var(--gray-light); border-color: #3a3a3a; }
body.dark-mode .filter-chip--active { background: #2a2e40; color: #9fb0ff; border-color: #5b6cc4; }
body.dark-mode .form-field input, body.dark-mode .form-field select, body.dark-mode .form-field textarea { background: #1f1f1f; color: var(--white); border-color: #3a3a3a; }
body.dark-mode .allday-event, body.dark-mode .timed-event { color: #111; }
body.dark-mode .upcoming-item:hover { background: #2a2a2a; }
body.dark-mode .upcoming-item__title, body.dark-mode .page-header__title, body.dark-mode .widget__title, body.dark-mode .calendar-panel__header h2 { color: #f5f5f5; }
body.dark-mode .page-header__sub, body.dark-mode .page-header__persona-line, body.dark-mode .upcoming-item__meta, body.dark-mode .week-grid__day-name, body.dark-mode .week-grid__day-date { color: #d0d0d0; }
body.dark-mode .week-grid__day-header { background: #2a2a2a; }
body.dark-mode .calendar-nav__label { color: #e8e8e8; }

/* Utility */
.is-hidden { display: none !important; }

/* Mobile */
@media (max-width: 720px) {
    .week-grid, .week-grid__body, .week-grid__allday-row { grid-template-columns: 56px repeat(5, minmax(0, 1fr)); }
    .form-grid { grid-template-columns: 1fr; }
    .calendar-toolbar { flex-direction: column; align-items: stretch; }
    .view-toggle { justify-content: center; }
}
