.table-container{overflow-x:auto;border-radius:8px;border:1px solid #E0E0E0;background-color:var(--color-background, #FFFFFF);contain:layout style paint}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-base, 16px);font-family:var(--font-family, "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif)}.table__header{background-color:var(--color-primary, #6B1F1F);color:#fff;position:sticky;top:0;z-index:10}.table__header-cell{padding:var(--space-2, 16px) var(--space-3, 24px);text-align:left;font-weight:600;-webkit-user-select:none;user-select:none;white-space:nowrap}.table__header-cell--sortable{cursor:pointer;transition:background-color .15s ease-in-out}.table__header-cell--sortable:hover{background-color:#0000001a}.table__header-cell--sortable:focus{outline:2px solid var(--color-accent, #E85D2A);outline-offset:-2px}.table__header-cell--right{text-align:right}.table__header-cell--center{text-align:center}.table__sort-icon{display:inline-block;margin-left:var(--space-1, 8px);font-size:14px;opacity:.8}.table__body{background-color:var(--color-background, #FFFFFF)}.table__row{border-bottom:1px solid #E0E0E0;transition:background-color .15s ease-in-out}.table__row:nth-child(2n){background-color:#f9f9f9}.table__row:hover{background-color:#e85d2a0d}.table__cell{padding:var(--space-2, 16px) var(--space-3, 24px);vertical-align:middle}.table__cell--left{text-align:left}.table__cell--right{text-align:right}.table__cell--center{text-align:center}.table__loading{text-align:center;padding:var(--space-5, 40px);color:#666}.table__empty{text-align:center;padding:var(--space-5, 40px);color:#666;font-style:italic}@media (max-width: 768px){.table__header-cell,.table__cell{padding:var(--space-2, 16px)}.table{font-size:var(--font-size-sm, 14px)}}.table-container:focus-within{outline:2px solid var(--color-accent, #E85D2A);outline-offset:2px}@media (prefers-reduced-motion: reduce){.table__header-cell--sortable,.table__row{transition:none}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-3, 24px);overflow-y:auto;animation:modal-fade-in .2s ease-in-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:8px;border:1px solid var(--admin-border, #eaecf0);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;position:relative;animation:modal-scale-in .25s ease-in-out;contain:layout style}@keyframes modal-scale-in{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-content--small{max-width:400px}.modal-content--medium{max-width:600px}.modal-content--large{max-width:800px}.modal-content--full{max-width:95vw;max-height:95vh}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3, 24px);border-bottom:1px solid #E0E0E0;flex-shrink:0}.modal-header h2,.modal-header h3{margin:0;font-size:var(--font-size-xl, 24px);font-weight:600;color:var(--color-text, #000000)}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;padding:var(--space-1, 8px);color:#666;line-height:1;border-radius:4px;transition:color .2s ease-in-out,background-color .2s ease-in-out;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.modal-close:hover{color:#333;background-color:#0000000d}.modal-close:focus-visible{outline:2px solid var(--color-accent, #E85D2A);outline-offset:2px}.modal-body{padding:var(--space-4, 32px) var(--space-3, 24px);overflow-y:auto;flex:1}.modal-body p{margin:0 0 var(--space-2, 16px) 0;line-height:1.5}.modal-body p:last-child{margin-bottom:0}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-2, 16px);padding:var(--space-3, 24px);border-top:1px solid #E0E0E0;flex-shrink:0}.modal-footer button{min-width:100px}.modal-overlay--closing{animation:modal-fade-out .2s ease-in-out forwards}@keyframes modal-fade-out{0%{opacity:1}to{opacity:0}}.modal-content--closing{animation:modal-scale-out .25s ease-in-out forwards}@keyframes modal-scale-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(-20px)}}@media (max-width: 768px){.modal-overlay{padding:var(--space-2, 16px)}.modal-content{max-width:100%;max-height:95vh}.modal-content--small,.modal-content--medium,.modal-content--large{max-width:100%}.modal-header{padding:var(--space-2, 16px)}.modal-header h2,.modal-header h3{font-size:var(--font-size-lg, 20px)}.modal-body{padding:var(--space-3, 24px) var(--space-2, 16px)}.modal-footer{padding:var(--space-2, 16px);flex-direction:column}.modal-footer button{width:100%}}body.modal-open{overflow:hidden}@media (prefers-reduced-motion: reduce){.modal-overlay,.modal-content,.modal-overlay--closing,.modal-content--closing{animation:none}.modal-close{transition:none}}.bilingual-text{display:inline-flex;gap:var(--spacing-xs, 4px)}.bilingual-text--stacked{flex-direction:column;gap:var(--spacing-2xs, 2px)}.bilingual-text--inline{flex-direction:row;align-items:baseline;gap:var(--spacing-xs, 4px)}.bilingual-text__first{font-size:inherit;font-weight:inherit;line-height:inherit;color:inherit}.bilingual-text__second{font-size:.9em;font-weight:inherit;line-height:inherit;color:inherit}.bilingual-text__separator{opacity:.6;font-weight:400}.bilingual-text--left{text-align:left;align-items:flex-start}.bilingual-text--center{text-align:center;align-items:center}.bilingual-text--right{text-align:right;align-items:flex-end}.clock{font-family:var(--font-family);font-size:var(--font-size-clock);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);display:inline-block;color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant-numeric:tabular-nums;transition:none}.clock{letter-spacing:.02em}@media (prefers-reduced-motion: reduce){.clock{transition:none}}.station-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-medium, 24px) 0;gap:var(--spacing-large, 32px)}.station-header__logo{flex-shrink:0;display:flex;align-items:center}.station-header__name{flex:1;display:flex;align-items:center;min-width:0}.station-header__name-text{font-family:var(--font-family);font-size:var(--font-size-station-name, 56px);font-weight:var(--font-weight-bold, 700);line-height:var(--line-height-tight, 1.2);color:var(--color-text-primary, #000000);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.station-header__clock{flex-shrink:0;display:flex;align-items:center}@media (max-width: 1440px){.station-header{gap:var(--spacing-medium, 24px)}}.connection-status{position:fixed;top:var(--spacing-medium, 24px);right:var(--spacing-medium, 24px);z-index:9999;background-color:#000000d9;color:#fff;padding:var(--spacing-small, 16px) var(--spacing-medium, 24px);border-radius:8px;font-size:var(--font-size-secondary-text, 18px);font-weight:var(--font-weight-medium, 500);line-height:1.4;box-shadow:0 4px 12px #0000004d;animation:connection-status-slide-in .3s ease-out}.connection-status__text{display:inline-flex;align-items:center;gap:var(--spacing-xs, 4px)}.connection-status__separator{opacity:.7;font-weight:var(--font-weight-regular, 400)}@keyframes connection-status-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media (max-width: 768px){.connection-status{top:var(--spacing-small, 16px);right:var(--spacing-small, 16px);padding:var(--spacing-xs, 12px) var(--spacing-small, 16px);font-size:16px}}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-micro) var(--spacing-small);font-family:var(--font-family);font-size:var(--font-size-status-badge);font-weight:500;line-height:1.2;text-align:center;border-radius:4px}.status-badge__bilingual,.status-badge__text{white-space:nowrap}.status-badge--on-time{background-color:#e8f5e9;color:var(--color-on-time)}.status-badge--delayed{background-color:#fff3e0;color:var(--color-delayed)}.status-badge--cancelled{background-color:#ffebee;color:var(--color-cancelled)}.status-badge--boarding{background-color:#e8f5e9;color:var(--color-on-time)}.status-badge--final-call{background-color:#fff3e0;color:var(--color-delayed)}.status-badge--scheduled,.status-badge--arrived{background-color:#f5f5f5;color:var(--color-idle-text)}.passenger-train-row{display:flex;align-items:center;justify-content:space-between;min-height:var(--passenger-row-height);padding:0 var(--spacing-medium);background-color:var(--passenger-color-bg-card);border-radius:var(--passenger-border-radius-lg);border:var(--passenger-border-width-thin) solid var(--passenger-color-border-light);font-family:var(--passenger-font-family)}.passenger-train-row__main{display:flex;align-items:center;gap:var(--passenger-spacing-column-gap);flex:1}.passenger-train-row__details{display:flex;align-items:center;gap:var(--passenger-spacing-column-gap);flex-shrink:0}.passenger-train-row__train-number{display:flex;flex-direction:column;min-width:200px}.passenger-train-row__train-number .passenger-train-row__value{font-size:var(--font-size-train-number);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:.01em;color:var(--passenger-color-text-primary)}.passenger-train-row__destination,.passenger-train-row__origin{display:flex;flex-direction:column;gap:var(--passenger-spacing-xs);flex:1}.passenger-train-row__destination .passenger-train-row__value,.passenger-train-row__origin .passenger-train-row__value{font-size:var(--font-size-destination);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:0;color:var(--passenger-color-text-primary)}.passenger-train-row__time{display:flex;flex-direction:column;gap:var(--passenger-spacing-xs);min-width:150px;text-align:right}.passenger-train-row__time .passenger-train-row__value{font-size:var(--font-size-primary-time);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--passenger-color-text-primary);font-variant-numeric:tabular-nums}.passenger-train-row__label{font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--passenger-color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.passenger-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.passenger-train-row__delay{display:inline-block;margin-top:var(--passenger-spacing-xs);padding:var(--passenger-spacing-xs) var(--passenger-spacing-sm);font-size:var(--font-size-secondary-text);font-weight:600;color:var(--passenger-color-status-delayed);background-color:var(--passenger-color-status-delayed-bg);border-radius:var(--passenger-border-radius-sm)}.passenger-train-row__delay-info{display:flex;align-items:center}.passenger-train-row__status{display:flex;align-items:center;margin-left:var(--passenger-spacing-lg)}.passenger-train-row--intermediate .passenger-train-row__details{gap:var(--passenger-spacing-column-gap-small)}.passenger-train-row--intermediate .passenger-train-row__time{min-width:120px}.passenger-train-row--intermediate .passenger-train-row__time--arrival .passenger-train-row__value{font-size:var(--font-size-primary-time);font-weight:var(--font-weight-bold)}.passenger-train-row--intermediate .passenger-train-row__time--departure .passenger-train-row__value{font-size:calc(var(--font-size-primary-time) * .9);font-weight:var(--font-weight-regular);color:var(--passenger-color-text-secondary)}.passenger-train-row--cancelled{opacity:.7}.passenger-train-row--cancelled .passenger-train-row__train-number .passenger-train-row__value,.passenger-train-row--cancelled .passenger-train-row__destination .passenger-train-row__value,.passenger-train-row--cancelled .passenger-train-row__origin .passenger-train-row__value{text-decoration:line-through;color:var(--passenger-color-text-secondary)}@media (prefers-contrast: high){.passenger-train-row{border-width:var(--passenger-border-width-medium)}.passenger-train-row__train-number .passenger-train-row__value{font-weight:800}}.passenger-screen-layout{display:flex;flex-direction:column;min-height:100vh;background-color:var(--passenger-color-bg-primary);font-family:var(--passenger-font-family);color:var(--passenger-color-text-primary)}.passenger-screen-header{display:flex;align-items:center;justify-content:space-between;height:var(--passenger-header-height);padding:0 var(--passenger-spacing-screen-padding);background-color:var(--passenger-color-bg-header);color:var(--passenger-color-text-inverse);z-index:var(--passenger-z-header)}.passenger-screen-header__brand{display:flex;align-items:center;gap:var(--passenger-spacing-md)}.passenger-screen-header__logo{display:flex;align-items:center}.passenger-screen-header__logo-text{font-size:var(--font-size-station-name);font-weight:700;letter-spacing:-.02em}.passenger-screen-header__info{display:flex;flex-direction:column;align-items:center;gap:var(--passenger-spacing-xs);flex:1}.passenger-screen-header__station{font-size:var(--font-size-station-name);font-weight:700;margin:0;text-align:center}.passenger-screen-header__type{font-size:var(--font-size-secondary-text);font-weight:400;opacity:.9;text-transform:uppercase;letter-spacing:.1em}.passenger-screen-header__time{display:flex;align-items:center}.passenger-screen-header__time-value{font-size:var(--font-size-board-title);font-weight:600;font-variant-numeric:tabular-nums}.passenger-screen-content{flex:1;padding:var(--passenger-spacing-screen-padding);overflow:hidden}.passenger-screen-content--centered{display:flex;align-items:center;justify-content:center}.passenger-train-list{display:flex;flex-direction:column;gap:var(--passenger-spacing-row);max-width:1600px;margin:0 auto}.passenger-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--passenger-spacing-xl);padding:var(--passenger-spacing-3xl);text-align:center}.passenger-empty-state__icon{font-size:120px;opacity:.3}.passenger-empty-state__message{display:flex;flex-direction:column;gap:var(--passenger-spacing-md)}.passenger-empty-state__text-en{font-size:var(--font-size-idle-message);font-weight:var(--font-weight-bold);color:var(--passenger-color-text-primary);margin:0}.passenger-empty-state__text-sw{font-size:var(--font-size-board-title);font-weight:var(--font-weight-regular);color:var(--passenger-color-text-secondary);margin:0}.passenger-boarding-display{display:flex;flex-direction:column;align-items:center;gap:var(--passenger-spacing-2xl);width:100%;max-width:1400px}.passenger-boarding-display__banner{display:flex;justify-content:center;width:100%}.passenger-boarding-display__train{width:100%}.passenger-screen-footer{display:flex;align-items:center;justify-content:center;padding:var(--passenger-spacing-lg) var(--passenger-spacing-screen-padding);background-color:var(--passenger-color-bg-card);border-top:var(--passenger-border-width-thin) solid var(--passenger-color-border-light)}.passenger-screen-footer__text{font-size:var(--font-size-footer);color:var(--passenger-color-text-secondary);margin:0;text-align:center}.passenger-screen-layout--boarding-gate .passenger-screen-content{background:var(--passenger-color-bg-primary)}.passenger-screen-layout--arrival-hall .passenger-screen-header{background-color:var(--passenger-color-status-boarding)}@keyframes fade-in-content{0%{opacity:0}to{opacity:1}}.passenger-train-list{animation:fade-in-content var(--passenger-transition-fade)}@media (prefers-contrast: high){.passenger-screen-header{border-bottom:var(--passenger-border-width-thick) solid var(--passenger-color-text-inverse)}.passenger-screen-footer{border-top-width:var(--passenger-border-width-thick)}}@media (prefers-reduced-motion: reduce){.passenger-train-list{animation:none}.passenger-boarding-display__banner .status-badge,.passenger-boarding-display__train .passenger-train-row{transition:none}}@media (min-width: 1920px){.passenger-train-list{max-width:1800px}.passenger-boarding-display{max-width:1600px}}@media (max-width: 1919px) and (min-width: 1366px){.passenger-train-list{max-width:1400px}}@media (max-width: 1365px){.passenger-screen-header{height:100px;padding:0 var(--passenger-spacing-lg)}.passenger-screen-content{padding:var(--passenger-spacing-lg)}.passenger-train-list{max-width:1200px;gap:var(--passenger-spacing-row-compact)}}@media (max-width: 768px){.passenger-screen-header{height:var(--passenger-header-height-mobile);padding:0 var(--passenger-spacing-md);flex-wrap:wrap}.passenger-screen-header__brand{width:100%;justify-content:center}.passenger-screen-header__info{width:50%}.passenger-screen-header__time{width:50%;justify-content:flex-end}.passenger-screen-content{padding:var(--passenger-spacing-md)}.passenger-train-list{gap:var(--passenger-spacing-sm)}.passenger-empty-state{padding:var(--passenger-spacing-xl)}}@media print{.passenger-screen-layout{min-height:auto}.passenger-screen-header{background-color:transparent;color:var(--passenger-color-text-primary);border-bottom:2px solid var(--passenger-color-text-primary)}.passenger-screen-content{padding:var(--space-md)}.passenger-train-list{gap:var(--space-10px)}}.role-manager{display:flex;flex-direction:column;gap:var(--spacing-medium, 24px);padding:var(--spacing-medium, 24px);background:var(--color-background, #FFFFFF);min-height:100vh}.role-manager-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-small, 16px);border-bottom:1px solid #E5E7EB}.role-manager-header h2{font-size:30px;font-weight:600;margin:0;color:var(--color-text-primary, #000000)}.role-manager-loading,.role-manager-error{padding:var(--spacing-large, 32px);text-align:center;font-size:18px;color:var(--color-text-secondary, #374151)}.role-manager-error{background:#fee2e2;color:#991b1b;border-radius:8px;display:flex;justify-content:space-between;align-items:center;text-align:left}.role-manager-error button{background:none;border:none;font-size:24px;color:#991b1b;cursor:pointer;padding:0 8px}.role-manager-filters{display:flex;gap:var(--spacing-small, 16px);padding:var(--spacing-small, 16px);background:#f9fafb;border-radius:8px}.filter-group select{padding:8px 12px;font-size:16px;border:1px solid #D1D5DB;border-radius:6px;background:#fff;cursor:pointer}.role-manager-content{display:grid;grid-template-columns:1fr 400px;gap:var(--spacing-medium, 24px)}.user-list{overflow-x:auto}.user-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #E5E7EB;border-radius:8px;overflow:hidden}.user-table thead{background:#f9fafb}.user-table th{padding:12px 16px;text-align:left;font-size:14px;font-weight:600;color:var(--color-text-secondary, #374151);text-transform:uppercase;letter-spacing:.05em}.user-table tbody tr{border-top:1px solid #E5E7EB;cursor:pointer;transition:background-color .15s}.user-table tbody tr:hover{background:#f9fafb}.user-table tbody tr.selected{background:#eff6ff}.user-table td{padding:12px 16px;font-size:16px;color:var(--color-text-primary, #000000)}.user-table .no-users{text-align:center;padding:var(--spacing-large, 32px);color:var(--color-text-secondary, #374151)}.user-table .text-muted{color:var(--color-text-secondary, #374151);font-style:italic}.user-role{display:inline-block;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:500}.user-role-super-admin{background:#dbeafe;color:#1e40af}.user-role-ict-admin{background:#d1fae5;color:#065f46}.user-role-station-admin{background:#fef3c7;color:#92400e}.user-role-content-admin{background:#e0e7ff;color:#3730a3}.user-actions{display:flex;gap:var(--spacing-micro, 8px);justify-content:flex-end}.btn-icon{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .15s}.btn-icon.btn-danger:hover{background:#fee2e2}.user-details{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:var(--spacing-medium, 24px);height:fit-content}.user-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-small, 16px);padding-bottom:var(--spacing-small, 16px);border-bottom:1px solid #E5E7EB}.user-details-header h3{font-size:20px;font-weight:600;margin:0}.user-details-actions{display:flex;gap:var(--spacing-micro, 8px)}.user-details-content{display:flex;flex-direction:column;gap:var(--spacing-small, 16px)}.detail-row{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:14px;font-weight:500;color:var(--color-text-secondary, #374151)}.detail-value{font-size:16px;color:var(--color-text-primary, #000000)}.detail-description{font-size:14px;line-height:1.5;color:var(--color-text-secondary, #374151)}.user-editor,.user-creator{background:#fff;border:1px solid #E5E7EB;border-radius:8px;padding:var(--spacing-medium, 24px);height:fit-content}.user-editor h3,.user-creator h3{font-size:20px;font-weight:600;margin:0 0 var(--spacing-small, 16px) 0;padding-bottom:var(--spacing-small, 16px);border-bottom:1px solid #E5E7EB}.form-group{display:flex;flex-direction:column;gap:var(--spacing-micro, 8px);margin-bottom:var(--spacing-small, 16px)}.form-group label{font-size:14px;font-weight:500;color:var(--color-text-secondary, #374151)}.form-group input,.form-group select{padding:10px 12px;font-size:16px;border:1px solid #D1D5DB;border-radius:6px;background:#fff}.form-help{font-size:12px;color:var(--color-text-secondary, #374151);font-style:italic}.form-actions{display:flex;gap:var(--spacing-micro, 8px);margin-top:var(--spacing-medium, 24px);padding-top:var(--spacing-small, 16px);border-top:1px solid #E5E7EB}.btn-primary,.btn-secondary,.btn-danger{padding:10px 20px;font-size:16px;font-weight:500;border:none;border-radius:6px;cursor:pointer;transition:background-color .15s}.btn-primary{background:var(--color-divider, #1E40AF);color:#fff}.btn-secondary{background:#f3f4f6;color:var(--color-text-primary, #000000)}.btn-secondary:hover{background:#e5e7eb}.btn-danger{background:#dc2626;color:#fff}@media (max-width: 1200px){.role-manager-content{grid-template-columns:1fr}}@media (max-width: 768px){.role-manager{padding:var(--spacing-small, 16px)}.role-manager-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-small, 16px)}.role-manager-filters{flex-direction:column}.user-table{font-size:14px}.user-table th,.user-table td{padding:8px 12px}}.live-preview{display:flex;flex-direction:column;gap:var(--spacing-medium, 24px);width:100%;height:100%}.live-preview__controls{display:flex;align-items:center;gap:var(--spacing-medium, 24px);padding:var(--spacing-small, 16px);background-color:#f9fafb;border:1px solid #E5E7EB;border-radius:8px}.live-preview__control-group{display:flex;align-items:center;gap:var(--spacing-micro, 8px)}.live-preview__label{font-size:14px;font-weight:500;color:#374151}.live-preview__value{font-size:14px;font-weight:600;color:#1f2937;padding:4px 8px;background-color:#fff;border:1px solid #D1D5DB;border-radius:4px}.live-preview__status{margin-left:auto;padding:4px 12px;border-radius:4px;font-size:14px;font-weight:500}.live-preview__status--loading{background-color:#dbeafe;color:#1e40af}.live-preview__status--error{background-color:#fee2e2;color:#dc2626}.live-preview__container{position:relative;width:1920px;height:1080px;background-color:#fff;border:2px solid #E5E7EB;border-radius:8px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.live-preview__error{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:var(--spacing-large, 32px);text-align:center}.live-preview__error p{font-size:18px;color:#6b7280}@media (max-width: 1920px){.live-preview__container{transform-origin:top left}}.live-preview__container>*{width:100%;height:100%}.device-manager{display:flex;flex-direction:column;gap:var(--spacing-medium, 24px);padding:var(--spacing-large, 32px);background:var(--color-background, #FFFFFF);min-height:100vh}.device-manager-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-medium, 24px);border-bottom:1px solid #E5E7EB}.device-manager-header h2{font-size:30px;font-weight:600;margin:0;color:var(--color-text-primary, #000000)}.device-manager-loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:18px;color:var(--color-text-secondary, #374151)}.device-manager-error{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-small, 16px);background:#fee2e2;border:1px solid #DC2626;border-radius:4px;color:#dc2626;font-size:16px}.device-manager-error button{background:none;border:none;font-size:20px;cursor:pointer;color:#dc2626;padding:0 8px}.device-manager-filters{display:flex;gap:var(--spacing-medium, 24px);padding:var(--spacing-small, 16px);background:#f9fafb;border-radius:4px}.filter-group{display:flex;align-items:center;gap:var(--spacing-micro, 8px)}.filter-group label{font-size:16px;font-weight:500;color:var(--color-text-secondary, #374151)}.filter-group select{padding:8px 12px;font-size:16px;border:1px solid #D1D5DB;border-radius:4px;background:#fff;cursor:pointer}.filter-group select:disabled{background:#f3f4f6;cursor:not-allowed}.device-manager-content{display:grid;grid-template-columns:1fr 400px;gap:var(--spacing-medium, 24px)}.device-list{overflow-x:auto}.device-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid #E5E7EB;border-radius:4px}.device-table thead{background:#f9fafb}.device-table th{padding:12px 16px;text-align:left;font-size:14px;font-weight:600;color:var(--color-text-secondary, #374151);border-bottom:1px solid #E5E7EB}.device-table tbody tr{cursor:pointer;transition:background-color .2s}.device-table tbody tr:hover{background:#f9fafb}.device-table tbody tr.selected{background:#eff6ff}.device-table td{padding:12px 16px;font-size:16px;color:var(--color-text-primary, #000000);border-bottom:1px solid #E5E7EB}.device-table tbody tr:last-child td{border-bottom:none}.no-devices{text-align:center;padding:48px 16px!important;color:var(--color-text-secondary, #374151);font-size:18px}.device-status{display:inline-block;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:500;text-transform:capitalize}.device-status-online{background:#d1fae5;color:#065f46}.device-status-offline{background:#fee2e2;color:#991b1b}.device-status-maintenance{background:#fef3c7;color:#92400e}.device-actions{display:flex;gap:8px}.btn-icon{background:none;border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s}.btn-icon:hover{background:#f3f4f6}.btn-primary{padding:10px 20px;font-size:16px;font-weight:500;color:#fff;background:var(--color-divider, #1E40AF);border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-primary:hover{background:#1e3a8a}.btn-secondary{padding:10px 20px;font-size:16px;font-weight:500;color:var(--color-text-primary, #000000);background:#fff;border:1px solid #D1D5DB;border-radius:4px;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-danger{padding:10px 20px;font-size:16px;font-weight:500;color:#fff;background:#dc2626;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-danger:hover{background:#b91c1c}.device-details{background:#fff;border:1px solid #E5E7EB;border-radius:4px;padding:var(--spacing-medium, 24px);height:fit-content}.device-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-medium, 24px);padding-bottom:var(--spacing-small, 16px);border-bottom:1px solid #E5E7EB}.device-details-header h3{font-size:24px;font-weight:600;margin:0;color:var(--color-text-primary, #000000)}.device-details-actions{display:flex;gap:var(--spacing-micro, 8px)}.device-details-content{display:flex;flex-direction:column;gap:var(--spacing-small, 16px)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.detail-label{font-size:16px;font-weight:500;color:var(--color-text-secondary, #374151)}.detail-value{font-size:16px;color:var(--color-text-primary, #000000);text-align:right}.device-editor{background:#fff;border:1px solid #E5E7EB;border-radius:4px;padding:var(--spacing-medium, 24px);height:fit-content}.device-editor h3{font-size:24px;font-weight:600;margin:0 0 var(--spacing-medium, 24px) 0;color:var(--color-text-primary, #000000)}.device-editor form{display:flex;flex-direction:column;gap:var(--spacing-small, 16px)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-micro, 8px)}.form-group label{font-size:16px;font-weight:500;color:var(--color-text-secondary, #374151)}.form-group input,.form-group select{padding:10px 12px;font-size:16px;border:1px solid #D1D5DB;border-radius:4px;background:#fff}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-divider, #1E40AF);box-shadow:0 0 0 3px #1e40af1a}.form-actions{display:flex;gap:var(--spacing-small, 16px);margin-top:var(--spacing-small, 16px)}.device-creator{background:#fff;border:1px solid #E5E7EB;border-radius:4px;padding:var(--spacing-medium, 24px);height:fit-content}.device-creator h3{font-size:24px;font-weight:600;margin:0 0 var(--spacing-medium, 24px) 0;color:var(--color-text-primary, #000000)}.device-creator form{display:flex;flex-direction:column;gap:var(--spacing-small, 16px)}@media (max-width: 1024px){.device-manager-content{grid-template-columns:1fr}}@media (max-width: 768px){.device-manager{padding:var(--spacing-small, 16px)}.device-manager-filters{flex-direction:column;gap:var(--spacing-small, 16px)}.filter-group{flex-direction:column;align-items:flex-start}.device-table{font-size:14px}.device-table th,.device-table td{padding:8px 12px}}.emergency-screen{width:var(--canvas-width);height:var(--canvas-height);background-color:var(--color-background);display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden}.emergency-screen__banner{height:80px;background-color:var(--color-emergency-banner);display:flex;justify-content:center;align-items:center;gap:var(--spacing-small);flex-shrink:0}.emergency-screen__banner-text-english,.emergency-screen__banner-text-swahili{font-family:var(--font-family);font-size:var(--font-size-state-banner);font-weight:var(--font-weight-bold);color:#fff;letter-spacing:.05em;text-transform:uppercase}.emergency-screen__banner-separator{font-family:var(--font-family);font-size:var(--font-size-state-banner);font-weight:var(--font-weight-regular);color:#fff;opacity:.7}.emergency-screen__banner--pulse{animation:emergency-pulse 1.5s ease-in-out infinite}@keyframes emergency-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.02)}}.emergency-screen__content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-section) var(--margin-horizontal)}.emergency-screen__message{text-align:center;display:flex;flex-direction:column;gap:var(--spacing-large);max-width:1400px}.emergency-screen__message-english{font-family:var(--font-family);font-size:48px;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:1.3}.emergency-screen__message-swahili{font-family:var(--font-family);font-size:44px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:1.3}.idle-screen{width:var(--canvas-width);height:var(--canvas-height);background-color:var(--color-background);display:flex;flex-direction:column;padding:var(--margin-top) var(--margin-horizontal) var(--margin-bottom);box-sizing:border-box}.idle-screen__content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:var(--spacing-section)}.idle-screen__message{text-align:center;display:flex;flex-direction:column;gap:var(--spacing-small)}.idle-screen__message-english{font-family:var(--font-family);font-size:var(--font-size-idle-message);font-weight:var(--font-weight-semibold);color:var(--color-idle-text);margin:0;line-height:1.2}.idle-screen__message-swahili{font-family:var(--font-family);font-size:var(--font-size-idle-message);font-weight:var(--font-weight-regular);color:var(--color-idle-text);margin:0;line-height:1.2}.idle-screen__next-service{display:flex;flex-direction:column;gap:var(--spacing-small);text-align:center}.idle-screen__next-service-header{font-family:var(--font-family);font-size:var(--font-size-swahili-subtitle);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin:0}.idle-screen__next-service-separator{color:var(--color-text-secondary);opacity:.5}.idle-screen__next-service-details{font-family:var(--font-family);font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-regular);color:var(--color-text-primary);display:flex;justify-content:center;align-items:center;gap:var(--spacing-micro);flex-wrap:wrap}.idle-screen__next-service-time{font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.idle-screen__next-service-destination{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.idle-screen__next-service-train{font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.combined-screen{display:flex;flex-direction:column;width:100%;height:100%;background-color:var(--color-background);font-family:var(--font-family);padding:var(--margin-top) var(--margin-horizontal) var(--margin-bottom);box-sizing:border-box}.combined-screen--stacked .combined-screen__sections{display:flex;flex-direction:column;gap:var(--spacing-large);flex:1;margin-top:var(--spacing-medium)}.combined-screen--stacked .combined-screen__section--departures{flex:0 0 60%;min-height:0}.combined-screen--stacked .combined-screen__section--arrivals{flex:0 0 40%;min-height:0}.combined-screen--split .combined-screen__sections{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-large);flex:1;margin-top:var(--spacing-medium)}.combined-screen__section{display:flex;flex-direction:column;width:100%;min-height:0}.combined-screen__section-header{display:flex;flex-direction:column;gap:var(--spacing-micro);margin-bottom:var(--spacing-medium)}.combined-screen__section-title{font-size:var(--font-size-board-title);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.combined-screen__section-subtitle{font-size:var(--font-size-swahili-subtitle);font-weight:var(--font-weight-regular);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-tight)}.combined-screen__divider{width:100%;height:1px;background-color:var(--color-divider);margin-bottom:var(--spacing-medium)}.combined-screen__table{display:flex;flex-direction:column;width:100%;flex:1;min-height:0}.combined-screen__table-header{display:grid;grid-template-columns:20% 35% 25% 20%;gap:var(--spacing-small);padding-bottom:var(--spacing-small);border-bottom:1px solid var(--color-border-primary);margin-bottom:var(--spacing-small)}.combined-screen__header-cell{font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.05em}.combined-screen__header-cell--time,.combined-screen__header-cell--location,.combined-screen__header-cell--train,.combined-screen__header-cell--status{text-align:left}.combined-screen__table-body{display:flex;flex-direction:column;gap:var(--row-spacing);overflow:hidden}.combined-screen__row{display:grid;grid-template-columns:20% 35% 25% 20%;gap:var(--spacing-small);min-height:var(--row-height);padding:0;border-bottom:1px solid var(--color-border-primary);align-items:center}.combined-screen__row:last-child{border-bottom:none}.combined-screen__cell{text-align:left;line-height:var(--line-height-tight)}.combined-screen__cell--time{font-size:var(--font-size-primary-time);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.combined-screen__cell--location{font-size:var(--font-size-destination);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.combined-screen__cell--train{font-size:var(--font-size-train-number);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.combined-screen__cell--status{display:flex;align-items:center}.combined-screen__empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-large);font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-regular);color:var(--color-idle-text);text-align:center}.combined-screen,.combined-screen__section,.combined-screen__row,.combined-screen__cell{box-shadow:none;background-image:none}.combined-screen__cell--time,.combined-screen__cell--location{color:var(--color-text-primary)}.combined-screen__cell--train{color:var(--color-text-secondary)}.combined-screen__row:focus-within{outline:2px solid var(--color-focus-ring);outline-offset:2px}@media print{.combined-screen{padding:0}.combined-screen__divider{background-color:#000}.combined-screen--stacked .combined-screen__sections,.combined-screen--split .combined-screen__sections{gap:var(--spacing-medium)}}.intermediate-station-screen{display:flex;flex-direction:column;width:100%;height:100%;background-color:var(--color-background);font-family:var(--font-family);padding:var(--margin-top) var(--margin-horizontal) var(--margin-bottom);box-sizing:border-box}.intermediate-station-screen__panels{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-large);flex:1;margin-top:var(--spacing-medium)}.intermediate-station-screen__panel{display:flex;flex-direction:column;width:100%}.intermediate-station-screen__panel-header{display:flex;flex-direction:column;gap:var(--spacing-micro);margin-bottom:var(--spacing-medium)}.intermediate-station-screen__panel-title{font-size:var(--font-size-board-title);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.intermediate-station-screen__panel-subtitle{font-size:var(--font-size-swahili-subtitle);font-weight:var(--font-weight-regular);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-tight)}.intermediate-station-screen__divider{width:100%;height:1px;background-color:var(--color-divider);margin-bottom:var(--spacing-medium)}.intermediate-station-screen__table{display:flex;flex-direction:column;width:100%;flex:1}.intermediate-station-screen__table-header{display:grid;grid-template-columns:20% 35% 25% 20%;gap:var(--spacing-small);padding-bottom:var(--spacing-small);border-bottom:1px solid var(--color-border-primary);margin-bottom:var(--spacing-small)}.intermediate-station-screen__header-cell{font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.05em}.intermediate-station-screen__header-cell--time,.intermediate-station-screen__header-cell--location,.intermediate-station-screen__header-cell--train,.intermediate-station-screen__header-cell--status{text-align:left}.intermediate-station-screen__table-body{display:flex;flex-direction:column;gap:var(--row-spacing)}.intermediate-station-screen__row{display:grid;grid-template-columns:20% 35% 25% 20%;gap:var(--spacing-small);min-height:var(--row-height);padding:0;border-bottom:1px solid var(--color-border-primary);align-items:center}.intermediate-station-screen__row:last-child{border-bottom:none}.intermediate-station-screen__cell{text-align:left;line-height:var(--line-height-tight)}.intermediate-station-screen__cell--time{font-size:var(--font-size-primary-time);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.intermediate-station-screen__cell--location{font-size:var(--font-size-destination);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.intermediate-station-screen__cell--train{font-size:var(--font-size-train-number);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.intermediate-station-screen__cell--status{display:flex;align-items:center}.intermediate-station-screen__empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-large);font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-regular);color:var(--color-idle-text);text-align:center}.intermediate-station-screen,.intermediate-station-screen__panel,.intermediate-station-screen__row,.intermediate-station-screen__cell{box-shadow:none;background-image:none}.intermediate-station-screen__cell--time,.intermediate-station-screen__cell--location{color:var(--color-text-primary)}.intermediate-station-screen__cell--train{color:var(--color-text-secondary)}.intermediate-station-screen__row:focus-within{outline:2px solid var(--color-focus-ring);outline-offset:2px}@media print{.intermediate-station-screen{padding:0}.intermediate-station-screen__divider{background-color:#000}.intermediate-station-screen__panels{gap:var(--spacing-medium)}}.waiting-lounge-screen{display:flex;flex-direction:column;width:100%;height:100%;background-color:var(--color-background);font-family:var(--font-family);padding:var(--margin-top) var(--margin-horizontal) var(--margin-bottom);box-sizing:border-box}.waiting-lounge-screen__title-section{display:flex;flex-direction:column;gap:var(--spacing-micro);margin-top:var(--spacing-medium);margin-bottom:var(--spacing-large)}.waiting-lounge-screen__title{font-size:var(--font-size-board-title);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.waiting-lounge-screen__subtitle{font-size:var(--font-size-swahili-subtitle);font-weight:var(--font-weight-regular);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-tight)}.waiting-lounge-screen__card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(var(--card-width),1fr));gap:var(--spacing-large);width:100%;flex:1;align-items:stretch;justify-content:center}.waiting-lounge-screen__card-grid:has(.waiting-lounge-screen__card:nth-child(2):last-child){grid-template-columns:repeat(2,1fr)}.waiting-lounge-screen__card-grid:has(.waiting-lounge-screen__card:only-child){grid-template-columns:1fr}.waiting-lounge-screen__card{display:flex;flex-direction:column;gap:var(--spacing-small);padding:var(--spacing-large);background-color:#f9fafb;border:1px solid var(--color-border-primary);border-radius:0;box-sizing:border-box;width:100%;max-width:var(--card-width);height:100%;box-shadow:none;background-image:none}.waiting-lounge-screen__card--boarding{border-color:var(--color-on-time);border-width:2px}.waiting-lounge-screen__card-time{font-size:var(--font-size-primary-time);font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin-bottom:var(--spacing-micro)}.waiting-lounge-screen__card-destination{font-size:var(--font-size-destination);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:var(--line-height-tight);margin-bottom:var(--spacing-micro)}.waiting-lounge-screen__card-train{font-size:var(--font-size-train-number);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);line-height:var(--line-height-tight);margin-bottom:var(--spacing-small)}.waiting-lounge-screen__card-status{display:flex;align-items:center;margin-top:auto}.waiting-lounge-screen__empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-section);grid-column:1 / -1;text-align:center}.waiting-lounge-screen__empty-text{font-size:var(--font-size-destination);font-weight:var(--font-weight-regular);color:var(--color-idle-text);margin:0 0 var(--spacing-micro) 0;line-height:var(--line-height-tight)}.waiting-lounge-screen__empty-text-swahili{font-size:var(--font-size-swahili-subtitle);font-weight:var(--font-weight-regular);color:var(--color-idle-text);margin:0;line-height:var(--line-height-tight)}.waiting-lounge-screen,.waiting-lounge-screen__card{box-shadow:none;background-image:none}.waiting-lounge-screen__card-time,.waiting-lounge-screen__card-destination{color:var(--color-text-primary)}.waiting-lounge-screen__card-train{color:var(--color-text-secondary)}.waiting-lounge-screen__card:focus-within{outline:2px solid var(--color-focus-ring);outline-offset:2px}@media print{.waiting-lounge-screen{padding:0}.waiting-lounge-screen__card{border-color:#000;background-color:#fff}}.boarding-platform-screen{width:var(--canvas-width, 1920px);height:var(--canvas-height, 1080px);background-color:var(--color-background, #FFFFFF);padding:var(--margin-top, 60px) var(--margin-horizontal, 80px) var(--margin-bottom, 60px);display:flex;flex-direction:column;font-family:var(--font-family)}.boarding-platform-header{display:flex;flex-direction:column;gap:var(--spacing-medium, 24px)}.boarding-platform-title{font-size:var(--font-size-board-title, 30px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-primary, #000000);text-align:center}.boarding-platform-divider{width:100%;height:var(--divider-width, 1px);background-color:var(--color-divider, #1E40AF);margin:var(--spacing-large, 32px) 0}.boarding-platform-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-section, 48px);text-align:center}.boarding-platform-no-service{font-size:var(--font-size-state-banner, 48px);font-weight:var(--font-weight-bold, 700);color:var(--color-idle-text, #6B7280)}.boarding-platform-state-banner{font-size:var(--font-size-state-banner, 48px);font-weight:var(--font-weight-bold, 700);padding:var(--spacing-medium, 24px) var(--spacing-section, 48px);border-radius:8px}.boarding-platform-state-banner.state-boarding{background-color:var(--color-on-time, #16A34A);color:var(--color-background, #FFFFFF)}.boarding-platform-state-banner.state-final-call{background-color:var(--color-delayed, #EA580C);color:var(--color-background, #FFFFFF)}.boarding-platform-state-banner.state-boarding-soon{background-color:var(--color-divider, #1E40AF);color:var(--color-background, #FFFFFF)}.boarding-platform-destination-section{display:flex;flex-direction:column;gap:var(--spacing-small, 16px)}.boarding-platform-label{font-size:var(--font-size-secondary-text, 18px);font-weight:var(--font-weight-medium, 500);color:var(--color-text-secondary, #374151)}.boarding-platform-destination{font-size:var(--font-size-state-destination, 36px);font-weight:var(--font-weight-semibold, 600);color:var(--color-text-primary, #000000)}.boarding-platform-time{font-size:var(--font-size-state-departure-time, 44px);font-weight:var(--font-weight-bold, 700);color:var(--color-text-primary, #000000)}.boarding-platform-train{font-size:var(--font-size-state-train-number, 22px);font-weight:var(--font-weight-medium, 500);color:var(--color-text-secondary, #374151)}.boarding-platform-boarding-time{font-size:var(--font-size-secondary-text, 18px);font-weight:var(--font-weight-regular, 400);color:var(--color-text-secondary, #374151);margin-top:var(--spacing-medium, 24px)}.boarding-platform-screen *{box-shadow:none;text-shadow:none}.arrivals-board{display:flex;flex-direction:column;width:100%;height:100%;background-color:var(--color-background);font-family:var(--font-family);padding:var(--margin-top) var(--margin-horizontal) var(--margin-bottom);box-sizing:border-box}.arrivals-board__title-section{display:flex;flex-direction:column;gap:var(--spacing-micro);margin-top:var(--spacing-small);margin-bottom:var(--header-spacing)}.arrivals-board__title{font-size:var(--font-size-board-title);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.arrivals-board__subtitle{font-size:var(--font-size-swahili-subtitle);font-weight:var(--font-weight-regular);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-tight)}.arrivals-board__divider{width:100%;height:1px;background-color:var(--color-divider);margin-bottom:var(--header-spacing)}.arrivals-board__table{display:flex;flex-direction:column;width:100%;flex:1}.arrivals-board__table-header{display:grid;grid-template-columns:20% 40% 20% 20%;gap:var(--spacing-small);padding-bottom:var(--spacing-small);border-bottom:1px solid var(--color-border-primary);margin-bottom:var(--spacing-small)}.arrivals-board__header-cell{font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.05em}.arrivals-board__header-cell--time,.arrivals-board__header-cell--origin,.arrivals-board__header-cell--train,.arrivals-board__header-cell--status{text-align:left}.arrivals-board__table-body{display:flex;flex-direction:column;gap:var(--row-spacing)}.arrivals-board__row{display:grid;grid-template-columns:20% 40% 20% 20%;gap:var(--spacing-small);min-height:var(--row-height);padding:0;border-bottom:1px solid var(--color-border-primary);align-items:center}.arrivals-board__row:last-child{border-bottom:none}.arrivals-board__cell{text-align:left;line-height:var(--line-height-tight)}.arrivals-board__cell--time{font-size:var(--font-size-primary-time);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.arrivals-board__cell--origin{font-size:var(--font-size-destination);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.arrivals-board__cell--train{font-size:var(--font-size-train-number);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.arrivals-board__cell--status{display:flex;align-items:center}.arrivals-board__empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-section);font-size:var(--font-size-destination);font-weight:var(--font-weight-regular);color:var(--color-idle-text);text-align:center}.arrivals-board,.arrivals-board__row,.arrivals-board__cell{box-shadow:none;background-image:none}.arrivals-board__cell--time,.arrivals-board__cell--origin{color:var(--color-text-primary)}.arrivals-board__cell--train{color:var(--color-text-secondary)}.arrivals-board__row:focus-within{outline:2px solid var(--color-focus-ring);outline-offset:2px}@media print{.arrivals-board{padding:0}.arrivals-board__divider{background-color:#000}}.departures-board{display:flex;flex-direction:column;width:100%;height:100%;background-color:var(--color-background);font-family:var(--font-family);padding:var(--margin-top) var(--margin-horizontal) var(--margin-bottom);box-sizing:border-box}.departures-board__title-section{display:flex;flex-direction:column;gap:var(--spacing-micro);margin-top:var(--spacing-small);margin-bottom:var(--header-spacing)}.departures-board__title{font-size:var(--font-size-board-title);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;line-height:var(--line-height-tight)}.departures-board__subtitle{font-size:var(--font-size-swahili-subtitle);font-weight:var(--font-weight-regular);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-tight)}.departures-board__divider{width:100%;height:1px;background-color:var(--color-divider);margin-bottom:var(--header-spacing)}.departures-board__table{display:flex;flex-direction:column;width:100%;flex:1}.departures-board__table-header{display:grid;grid-template-columns:20% 40% 20% 20%;gap:var(--spacing-small);padding-bottom:var(--spacing-small);border-bottom:1px solid var(--color-border-primary);margin-bottom:var(--spacing-small)}.departures-board__header-cell{font-size:var(--font-size-secondary-text);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-align:left;text-transform:uppercase;letter-spacing:.05em}.departures-board__header-cell--time,.departures-board__header-cell--destination,.departures-board__header-cell--train,.departures-board__header-cell--status{text-align:left}.departures-board__table-body{display:flex;flex-direction:column;gap:var(--row-spacing)}.departures-board__row{display:grid;grid-template-columns:20% 40% 20% 20%;gap:var(--spacing-small);min-height:var(--row-height);padding:0;border-bottom:1px solid var(--color-border-primary);align-items:center}.departures-board__row:last-child{border-bottom:none}.departures-board__cell{text-align:left;line-height:var(--line-height-tight)}.departures-board__cell--time{font-size:var(--font-size-primary-time);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.departures-board__cell--destination{font-size:var(--font-size-destination);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.departures-board__cell--train{font-size:var(--font-size-train-number);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.departures-board__cell--status{display:flex;align-items:center}.departures-board__empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-section);font-size:var(--font-size-destination);font-weight:var(--font-weight-regular);color:var(--color-idle-text);text-align:center}.departures-board,.departures-board__row,.departures-board__cell{box-shadow:none;background-image:none}.departures-board__cell--time,.departures-board__cell--destination{color:var(--color-text-primary)}.departures-board__cell--train{color:var(--color-text-secondary)}.departures-board__row:focus-within{outline:2px solid var(--color-focus-ring);outline-offset:2px}@media print{.departures-board{padding:0}.departures-board__divider{background-color:#000}}
