/* ============================================================
   EEF Dashboard — Global Styles
   Rebrand applied : 2026-04-09
   Revert with     : git checkout pre-rebrand-2026-04-09
   ============================================================ */

/* ── Brand tokens + Telerik theme variable overrides ──────── */
:root {
  /* EEF palette */
  --eef-navy:        #0a2240;
  --eef-blue:        #0057a8;
  --eef-blue-dark:   #004080;
  --eef-accent:      #0693e3;
  --eef-accent-pale: #e6f4fd;
  --body-bg:         #f0f4f8;
  --surface:         #ffffff;
  --border:          #dce3ed;
  --text-dark:       #1a2433;
  --text-mid:        #4a5568;
  --text-muted:      #718096;
  --radius:          6px;
  --shadow-sm:       0 1px 4px rgba(0,0,0,.08);
  --shadow:          0 2px 10px rgba(0,0,0,.10);

  /* Telerik kendo-theme-default overrides — replaces the default orange/red */
  --kendo-color-primary:                  #0057a8;
  --kendo-color-primary-hover:            #004080;
  --kendo-color-primary-active:           #003366;
  --kendo-color-on-primary:               #ffffff;
  --kendo-color-warning:                  #b45309;
  --kendo-color-warning-hover:            #92400e;
  --kendo-color-on-warning:               #ffffff;
}

/* ── Base ─────────────────────────────────────────────────── */
html, body {
  font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
  font-size: 14px;
  color: var(--text-dark);
  background: var(--body-bg);
}

a, .btn-link {
  color: var(--eef-accent);
}

h1:focus { outline: none; }

/* ── Bootstrap: Buttons ───────────────────────────────────── */
.btn-primary {
  background-color: var(--eef-blue);
  border-color:     var(--eef-blue);
  color: #fff;
  border-radius: var(--radius);
  font-weight: 500;
  padding: .45rem 1.1rem;
  transition: background .15s, box-shadow .15s;
}
.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--eef-blue-dark);
  border-color:     var(--eef-blue-dark);
  box-shadow: 0 2px 8px rgba(0,87,168,.28);
}
.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
  box-shadow: 0 0 0 .1rem white, 0 0 0 .25rem var(--eef-accent);
}

/* ── Telerik: Buttons — base ──────────────────────────────── */
.k-button {
  font-family: inherit !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  border-radius: var(--radius) !important;
  letter-spacing: .01em !important;
  transition: background .15s, border-color .15s, box-shadow .15s !important;
}

/* Primary (full class chain for specificity over Telerik default) */
.k-button.k-button-solid.k-button-solid-primary {
  background-color: var(--eef-blue) !important;
  border-color:     var(--eef-blue) !important;
  color: #fff !important;
}
.k-button.k-button-solid.k-button-solid-primary:hover {
  background-color: var(--eef-blue-dark) !important;
  border-color:     var(--eef-blue-dark) !important;
  box-shadow: 0 2px 6px rgba(0,87,168,.3) !important;
}
.k-button.k-button-solid.k-button-solid-primary:focus {
  background-color: var(--eef-blue-dark) !important;
  border-color:     var(--eef-blue-dark) !important;
  box-shadow: 0 0 0 2px rgba(6,147,227,.3) !important;
}
.k-button.k-button-solid.k-button-solid-primary.k-disabled,
.k-button.k-button-solid.k-button-solid-primary:disabled {
  background-color: #7aadd6 !important;
  border-color:     #7aadd6 !important;
  color: rgba(255,255,255,.8) !important;
  box-shadow: none !important;
}

/* Warning — muted amber to match the professional theme */
.k-button.k-button-solid.k-button-solid-warning {
  background-color: #b45309 !important;
  border-color:     #b45309 !important;
  color: #fff !important;
}
.k-button.k-button-solid.k-button-solid-warning:hover {
  background-color: #92400e !important;
  border-color:     #92400e !important;
  box-shadow: 0 2px 6px rgba(146,64,14,.3) !important;
}
.k-button.k-button-solid.k-button-solid-warning.k-disabled,
.k-button.k-button-solid.k-button-solid-warning:disabled {
  background-color: #d9a76a !important;
  border-color:     #d9a76a !important;
  color: rgba(255,255,255,.8) !important;
  box-shadow: none !important;
}

/* ── Telerik: Inputs & pickers ────────────────────────────── */
.k-input,
.k-textbox,
.k-dropdownlist,
.k-picker {
  font-family: inherit !important;
  font-size: 13.5px !important;
  border-radius: var(--radius) !important;
}
.k-input:focus-within,
.k-picker:focus-within {
  border-color: var(--eef-accent) !important;
  box-shadow: 0 0 0 2px rgba(6,147,227,.18) !important;
}
.k-input-inner::placeholder {
  color: var(--text-muted) !important;
}

/* ── Telerik: Grid ────────────────────────────────────────── */
.k-grid {
  border-radius: var(--radius) !important;
  border-color: var(--border) !important;
  box-shadow: var(--shadow-sm) !important;
  font-family: inherit !important;
  font-size: 13.5px !important;
  background: var(--surface) !important;
}
.k-grid-header,
.k-grid-header-wrap {
  background: #f5f8fc !important;
  border-color: var(--border) !important;
}
.k-grid th.k-header,
.k-grid-header th {
  color: var(--text-mid) !important;
  font-weight: 600 !important;
  font-size: 11.5px !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  border-color: var(--border) !important;
  background: #f5f8fc !important;
  padding: .7rem .85rem !important;
}
.k-grid td {
  border-color: var(--border) !important;
  padding: .6rem .85rem !important;
  color: var(--text-dark) !important;
}
.k-grid tbody tr:hover > td {
  background: var(--eef-accent-pale) !important;
  cursor: pointer;
}
.k-grid tbody tr.k-selected > td,
.k-grid tbody tr.k-state-selected > td {
  background: var(--eef-accent-pale) !important;
  color: var(--text-dark) !important;
}

/* ── Telerik: Pager ───────────────────────────────────────── */
.k-pager {
  background: #f8fafc !important;
  border-color: var(--border) !important;
  font-family: inherit !important;
  font-size: 13px !important;
  border-bottom-left-radius:  var(--radius) !important;
  border-bottom-right-radius: var(--radius) !important;
}
/* Unselected page numbers */
.k-pager-numbers .k-button:not(.k-selected) {
  color: var(--eef-blue) !important;
  background: transparent !important;
  border-color: transparent !important;
}
.k-pager-numbers .k-button:not(.k-selected):hover {
  background: var(--eef-accent-pale) !important;
  border-color: var(--border) !important;
  color: var(--eef-blue-dark) !important;
}
/* Selected page number */
.k-pager-numbers .k-button.k-selected,
.k-pager-numbers .k-state-selected {
  background-color: var(--eef-blue) !important;
  border-color:     var(--eef-blue) !important;
  color: #fff !important;
}
/* Prev / next / first / last arrow buttons */
.k-pager-nav {
  color: var(--eef-blue) !important;
}
.k-pager-nav:hover {
  background: var(--eef-accent-pale) !important;
  color: var(--eef-blue-dark) !important;
}

/* ── Page headings ────────────────────────────────────────── */
h3 {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 1.25rem;
  letter-spacing: -.01em;
}
h5 {
  font-size: .95rem;
  font-weight: 700;
  letter-spacing: -.01em;
}
h6 {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-muted);
}

/* ── Booking detail panel ─────────────────────────────────── */
.booking-detail {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem 1.75rem;
  box-shadow: var(--shadow-sm);
}
.booking-detail h5 {
  color: var(--eef-blue);
  margin-bottom: 1rem;
  padding-bottom: .65rem;
  border-bottom: 2px solid var(--eef-accent-pale);
}
.detail-table {
  width: 100%;
  font-size: 13.5px;
}
.detail-table td {
  border-color: var(--border) !important;
  padding: .5rem .75rem !important;
}
.detail-label {
  width: 210px;
  font-weight: 600;
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted);
  background: #f5f8fc !important;
  vertical-align: middle;
}

/* ── Validation ───────────────────────────────────────────── */
.valid.modified:not([type=checkbox]) { outline: 1px solid #22a356; }
.invalid                             { outline: 1px solid #d94040; }
.validation-message                  { color: #d94040; font-size: 12px; }

/* ── Blazor error boundary ────────────────────────────────── */
.blazor-error-boundary {
  background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
  padding: 1rem 1rem 1rem 3.7rem;
  color: white;
}
.blazor-error-boundary::after { content: "An error has occurred." }

.darker-border-checkbox.form-check-input { border-color: #929292; }

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}
.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
  text-align: start;
}

/* ═══════════════════════════════════════════════════════════
   Booking Amendment — shared styles (AmendBooking + Home)
   ═══════════════════════════════════════════════════════════ */

/* ── Full-page wrapper (used by /amend/booking/{id} route) ── */
.amend-wrapper {
    min-height: 100vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 60px 1rem 40px;
    background: var(--body-bg, #f0f4f8);
}

/* ── Inline section wrapper (used on home page) ───────────── */
.home-amend-section {
    max-width: 720px;
}

/* ── Card ─────────────────────────────────────────────────── */
.amend-card {
    width: 100%;
    max-width: 460px;
    background: #ffffff;
    border: 1px solid #dce3ed;
    border-radius: 8px;
    box-shadow: 0 4px 20px rgba(0,0,0,.10);
    overflow: hidden;
}
.amend-card-wide { max-width: 700px; }

.amend-header {
    background: #0a2240;
    border-left: 4px solid #0693e3;
    padding: 1rem 1.5rem;
    color: #ffffff;
    font-size: .95rem;
    font-weight: 700;
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: .5rem;
}
.amend-ref {
    font-weight: 400;
    opacity: .75;
    font-size: .85rem;
}
.amend-course-name {
    font-size: .8rem;
    font-weight: 400;
    opacity: .7;
    margin-left: auto;
}
.amend-body { padding: 1.75rem 1.5rem; }

/* ── Typography ───────────────────────────────────────────── */
.amend-intro {
    font-size: 14px;
    color: #1a2433;
    margin: 0 0 1rem;
    line-height: 1.6;
}
.amend-masked-email {
    font-size: 1rem;
    font-weight: 700;
    color: #0057a8;
    margin: 0 0 .75rem;
    letter-spacing: .02em;
}
.amend-hint {
    font-size: 12.5px;
    color: #718096;
    margin: 0 0 1.25rem;
    line-height: 1.5;
}
.amend-loading {
    padding: 2rem;
    text-align: center;
    color: #718096;
    font-size: 14px;
}
.amend-error {
    font-size: 13px;
    color: #d94040;
    margin: .5rem 0 1rem;
}
.amend-resend {
    margin: 1rem 0 0;
    font-size: 13px;
    color: #718096;
}
.amend-resend a { color: #0693e3; text-decoration: none; }
.amend-resend a:hover { text-decoration: underline; }

/* ── Form fields (lookup form) ────────────────────────────── */
.amend-field-group {
    display: flex;
    flex-direction: column;
    gap: .35rem;
    margin-bottom: 1rem;
}
.amend-field-label {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #4a5568;
}

/* ── OTP input row ────────────────────────────────────────── */
.amend-otp-row {
    display: flex;
    align-items: center;
    gap: .75rem;
    margin-bottom: .5rem;
}

/* ── Actions ──────────────────────────────────────────────── */
.amend-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* ── Course meta strip ────────────────────────────────────── */
.amend-course-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    background: #f5f8fc;
    border-bottom: 1px solid #dce3ed;
}
.amend-meta-item {
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: .7rem 1.4rem;
    border-right: 1px solid #dce3ed;
    flex: 1 1 auto;
}
.amend-meta-item:last-child { border-right: none; }
.amend-meta-icon {
    color: #0693e3;
    display: flex;
    align-items: center;
    flex-shrink: 0;
}
.amend-meta-item > div {
    display: flex;
    flex-direction: column;
    gap: .05rem;
}
.amend-meta-label {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .07em;
    color: #718096;
    line-height: 1;
}
.amend-meta-value {
    font-size: 13.5px;
    font-weight: 600;
    color: #1a2433;
    line-height: 1.3;
}

/* ── Attendee table ───────────────────────────────────────── */
.amend-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13.5px;
    margin-bottom: .5rem;
}
.amend-table th {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #718096;
    padding: .5rem .6rem;
    border-bottom: 2px solid #dce3ed;
    text-align: left;
}
.amend-table td {
    padding: .4rem .5rem;
    border-bottom: 1px solid #f0f4f8;
}
.amend-table tr:last-child td { border-bottom: none; }
.amend-num {
    color: #718096;
    font-weight: 600;
    text-align: center;
}

/* ── Success state ────────────────────────────────────────── */
.amend-success-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: #22a356;
    color: #fff;
    font-size: 1.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.25rem;
}
.amend-success .amend-intro { text-align: center; }
.amend-success .amend-hint  { text-align: center; }
