@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@500;600&display=swap";:root{--warm-bg: #F0EEE9;--warm-surface: #FFFFFF;--warm-border: #E4E2DC;--warm-border-2: #D4D0C8;--warm-hover: #F9F8F5;--brand: #2563EB;--brand-hover: #1D4ED8;--brand-active: #1E40AF;--brand-soft: #EFF6FF;--brand-border: #BFDBFE;--violet: #7C3AED;--violet-soft: #F5F3FF;--violet-border: #DDD6FE;--teal: #0D9488;--teal-soft: #F0FDFA;--teal-border: #99F6E4;--rose: #E11D48;--rose-soft: #FFF1F2;--rose-border: #FECDD3;--amber: #D97706;--amber-soft: #FFFBEB;--amber-border: #FDE68A;--emerald: #059669;--emerald-soft: #ECFDF5;--emerald-border: #A7F3D0;--indigo: #4F46E5;--indigo-soft: #EEF2FF;--indigo-border: #C7D2FE;--success: var(--emerald);--success-soft: var(--emerald-soft);--success-border: var(--emerald-border);--warning: var(--amber);--warning-soft: var(--amber-soft);--warning-border: var(--amber-border);--danger: var(--rose);--danger-soft: var(--rose-soft);--danger-border: var(--rose-border);--info: #0284C7;--info-soft: #F0F9FF;--text-primary: #18181B;--text-secondary: #52525B;--text-muted: #71717A;--text-subtle: #A1A19A;--text-inverse: #FFFFFF;--text-placeholder: #D4D0C8;--bg-main: var(--warm-bg);--bg-surface: var(--warm-surface);--bg-elevated: #F5F4F0;--bg-hover: var(--warm-hover);--bg-overlay: rgba(0, 0, 0, .45);--border-subtle: #F0EEE9;--border-normal: var(--warm-border);--border-medium: var(--warm-border-2);--border-strong: #A1A19A;--border-focus: var(--brand);--border-color: var(--warm-border);--ir-maroon: #9e1b22;--ir-maroon-hover: #7b1218;--ir-maroon-soft: rgba(158, 27, 34, .08);--ir-blue: #1D4ED8;--ir-blue-hover: #1e40af;--ir-blue-soft: #EFF6FF;--ir-gold: #D97706;--ir-gold-soft: rgba(217, 119, 6, .1);--color-primary: var(--brand);--color-primary-hover: var(--brand-hover);--color-primary-active: var(--brand-active);--color-primary-dark: var(--brand-hover);--color-primary-light: var(--brand);--color-secondary: #6366F1;--color-accent: #D97706;--color-success: var(--success);--color-info: var(--info);--color-warning: var(--warning);--color-error: var(--danger);--error: var(--danger);--rail-green: var(--success);--rail-green-soft: var(--success-soft);--rail-sky: var(--info);--rail-sky-soft: var(--info-soft);--rail-purple: #7C3AED;--rail-purple-soft: #EDE9FE;--rail-orange: #EA580C;--rail-orange-soft: #FFF7ED;--font-family: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--font-size-xs: 11px;--font-size-sm: 12.5px;--font-size-base: 13.5px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 22px;--font-size-3xl: 26px;--font-size-4xl: 32px;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 700;--line-height-tight: 1.2;--line-height-snug: 1.35;--line-height-normal: 1.5;--line-height-relaxed: 1.65;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .03em;--letter-spacing-wider: .06em;--letter-spacing-widest: .1em;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 12px;--radius-inner: 8px;--radius-card: 12px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .1);--shadow-xl: 0 8px 32px rgba(0, 0, 0, .12);--shadow-pinterest-sm: var(--shadow-xs);--shadow-pinterest: var(--shadow-sm);--shadow-card-hover: var(--shadow-md);--shadow-maroon-sm: 0 2px 8px rgba(29, 78, 216, .12);--glass-shadow: var(--shadow-sm);--transition-fast: .12s ease;--transition-smooth: all .15s ease;--transition-bounce: all .15s ease;--transition-slow: all .25s ease;--z-below: -1;--z-base: 0;--z-raised: 10;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-toast: 600;--z-tooltip: 700;--ticket-rail-width: 6px;--perforated-line: repeating-linear-gradient(90deg, var(--warm-border) 0px, var(--warm-border) 6px, transparent 6px, transparent 12px);--dashed-track: repeating-linear-gradient(90deg, var(--warm-border-2) 0px, var(--warm-border-2) 5px, transparent 5px, transparent 9px)}[data-theme=dark]{--warm-bg: #1C1A17;--warm-surface: #242220;--warm-border: #3A3830;--warm-border-2: #4A4840;--warm-hover: #2A2825;--bg-main: var(--warm-bg);--bg-surface: var(--warm-surface);--bg-elevated: #2E2C28;--bg-hover: var(--warm-hover);--text-primary: #F4F3F0;--text-secondary: #A8A59E;--text-muted: #78756E;--text-subtle: #5A5852;--text-inverse: #1C1A17;--text-placeholder: #4A4840;--border-subtle: #2A2825;--border-normal: var(--warm-border);--border-medium: var(--warm-border-2);--border-strong: #6A6860;--border-color: var(--warm-border);--brand: #60A5FA;--brand-hover: #93C5FD;--brand-soft: rgba(96, 165, 250, .12);--brand-border: #1E40AF;--success-soft: rgba(22, 163, 74, .15);--warning-soft: rgba(217, 119, 6, .15);--danger-soft: rgba(220, 38, 38, .15);--info-soft: rgba(2, 132, 199, .15);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 2px 8px rgba(0, 0, 0, .5);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;overflow-x:hidden}img,video,svg{display:block;max-width:100%}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}button{cursor:pointer;border:none;background:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--text-primary);letter-spacing:var(--letter-spacing-tight)}:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:var(--radius-sm)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes chug{0%{transform:translate(0)}to{transform:translate(3px)}}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}@keyframes pulse-ring{0%{transform:scale(.9);opacity:.6}70%{transform:scale(1.6);opacity:0}to{transform:scale(.9);opacity:0}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--space-6)}.container--sm{max-width:680px}.container--md{max-width:960px}.container--lg{max-width:1400px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.grid{display:grid}.w-full{width:100%}.h-full{height:100%}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.card{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-lg);transition:var(--transition-smooth)}.card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-sm)}.ticket-card{display:flex;gap:0;border-radius:var(--radius-xl);overflow:hidden}.ticket-card__rail{width:var(--ticket-rail-width);flex-shrink:0;border-radius:var(--radius-xl) 0 0 var(--radius-xl)}.ticket-card__body{flex:1;background:var(--bg-surface);border:1.5px solid var(--border-normal);border-left:none;border-radius:0 var(--radius-xl) var(--radius-xl) 0;padding:16px 20px}.perforated{height:1px;background:var(--perforated-line);margin:12px -4px}.button-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);background:var(--brand);color:var(--text-inverse);border:none;border-radius:var(--radius-md);padding:8px 16px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-smooth);white-space:nowrap;font-family:var(--font-family)}.button-primary:hover{background:var(--brand-hover)}.button-primary:active{background:var(--brand-active)}.button-secondary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);background:var(--bg-surface);color:var(--text-primary);border:1.5px solid var(--border-normal);border-radius:var(--radius-md);padding:7px 14px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-smooth);white-space:nowrap;font-family:var(--font-family)}.button-secondary:hover{background:var(--bg-hover);border-color:var(--border-medium)}.button-ghost{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);background:transparent;color:var(--text-secondary);border:1.5px solid var(--border-medium);border-radius:var(--radius-md);padding:6px 13px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-smooth);white-space:nowrap;font-family:var(--font-family)}.button-ghost:hover{border-color:var(--border-strong);color:var(--text-primary)}.badge-success{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--success-soft);color:var(--success);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border:1px solid var(--success-border)}.badge-warning{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--warning-soft);color:var(--warning);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.badge-danger{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--danger-soft);color:var(--danger);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border:1px solid var(--danger-border)}.badge-info{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--info-soft);color:var(--info);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.badge-brand{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--brand-soft);color:var(--brand);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border:1px solid var(--brand-border)}.input{width:100%;height:38px;padding:0 var(--space-3);background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);font-family:var(--font-family);transition:var(--transition-fast);outline:none}.input:hover{border-color:var(--border-medium)}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.input::placeholder{color:var(--text-placeholder)}.input--error{border-color:var(--danger)}.input--error:focus{box-shadow:0 0 0 3px var(--danger-soft)}.input-label{display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-subtle);margin-bottom:var(--space-1);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.mono{font-family:var(--font-mono)}.divider{height:1px;background:var(--border-normal);border:none;margin:var(--space-4) 0}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.no-scrollbar::-webkit-scrollbar{display:none}.skeleton{background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--warm-hover) 50%,var(--bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.6s infinite ease-in-out;border-radius:var(--radius-sm)}.animate-fade-in{animation:fadeIn .2s ease forwards}.animate-fade-in-up{animation:fadeInUp .25s ease forwards}.animate-slide-up{animation:slideUp .25s ease forwards}.animate-scale-in{animation:scaleIn .2s ease forwards}::selection{background:var(--brand-soft);color:var(--brand)}.glass-panel,[data-theme=dark] .glass-panel{background:var(--bg-surface);border:1.5px solid var(--border-normal)}.hover-lift{transition:var(--transition-smooth)}.hover-lift:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.glow-on-hover{transition:var(--transition-smooth)}.glow-on-hover:after{display:none}.text-gradient-animate{color:var(--text-primary);background:none;-webkit-background-clip:unset;background-clip:unset;-webkit-text-fill-color:unset}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-info{color:var(--info)}.text-brand{color:var(--brand)}.text-muted{color:var(--text-muted)}.text-subtle{color:var(--text-subtle)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.app-navbar{position:sticky;top:0;z-index:200;background:var(--warm-surface);border-bottom:1.5px solid var(--warm-border)}.app-navbar__inner{display:flex;align-items:center;gap:16px;padding:0 24px;height:52px;max-width:1200px;margin:0 auto}.app-navbar__brand{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}.app-navbar__logo{width:30px;height:30px;border-radius:7px;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center}.app-navbar__brand-name{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;font-family:var(--font-family)}.app-navbar__desktop-links{display:none;flex:1;align-items:center;gap:2px;margin-left:16px}@media(min-width:768px){.app-navbar__desktop-links{display:flex}}.app-navbar__dlink{font-size:13px;font-weight:500;color:var(--text-muted);text-decoration:none;padding:5px 10px;border-radius:var(--radius-md);transition:var(--transition-smooth);font-family:var(--font-family)}.app-navbar__dlink:hover{color:var(--text-primary);background:var(--bg-elevated)}.app-navbar__dlink--active{color:var(--brand);background:var(--brand-soft)}.app-navbar__actions{display:flex;align-items:center;gap:4px;margin-left:auto}.app-navbar__icon-btn{position:relative;width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth);text-decoration:none}.app-navbar__icon-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.app-navbar__icon-btn--bell .app-navbar__bell-dot{position:absolute;top:6px;right:6px;width:6px;height:6px;border-radius:50%;background:var(--danger);border:1.5px solid var(--warm-surface)}.app-navbar__profile-wrap{position:relative}.app-navbar__avatar-btn{display:flex;align-items:center;gap:4px;border:none;background:transparent;cursor:pointer;padding:2px;border-radius:var(--radius-md);transition:var(--transition-smooth);color:var(--text-secondary)}.app-navbar__avatar-btn:hover{background:var(--bg-elevated)}.app-navbar__avatar{width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center}.app-navbar__dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:200px;background:var(--warm-surface);border:1.5px solid var(--warm-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;z-index:300}.app-dropdown__user-row{display:flex;align-items:center;gap:10px;padding:12px}.app-dropdown__big-avatar{width:32px;height:32px;border-radius:50%;background:var(--brand);color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-dropdown__user-name{font-size:13px;font-weight:600;color:var(--text-primary)}.app-dropdown__user-email{font-size:11px;color:var(--text-muted);margin-top:1px}.app-dropdown__divider{height:1px;background:var(--warm-border)}.app-dropdown__item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;font-size:13px;font-weight:500;color:var(--text-primary);text-decoration:none;background:transparent;border:none;cursor:pointer;transition:var(--transition-smooth);font-family:var(--font-family)}.app-dropdown__item:hover{background:var(--bg-elevated)}.app-dropdown__item--danger{color:var(--danger)}.app-dropdown__item--danger:hover{background:var(--danger-soft)}.app-navbar__auth-row{display:none;align-items:center;gap:6px}@media(min-width:768px){.app-navbar__auth-row{display:flex}}.app-navbar__btn-ghost{font-size:13px;font-weight:500;color:var(--text-secondary);text-decoration:none;padding:5px 12px;border-radius:var(--radius-md);border:1.5px solid var(--warm-border-2);transition:var(--transition-smooth);font-family:var(--font-family)}.app-navbar__btn-ghost:hover{border-color:var(--border-strong);color:var(--text-primary);background:var(--bg-elevated)}.app-navbar__btn-solid{font-size:13px;font-weight:600;color:#fff;text-decoration:none;padding:5px 14px;border-radius:var(--radius-md);background:var(--brand);transition:var(--transition-smooth);font-family:var(--font-family)}.app-navbar__btn-solid:hover{background:var(--brand-hover)}.app-navbar__hamburger{display:flex;width:32px;height:32px;border-radius:var(--radius-md);border:none;background:transparent;color:var(--text-muted);align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth)}.app-navbar__hamburger:hover{background:var(--bg-elevated);color:var(--text-primary)}@media(min-width:768px){.app-navbar__hamburger{display:none}}.app-subnav{border-top:1px solid var(--warm-border);display:none}@media(min-width:768px){.app-subnav{display:block}}.app-subnav__scroll{display:flex;align-items:center;gap:4px;padding:5px 24px;max-width:1200px;margin:0 auto;overflow-x:auto;scrollbar-width:none}.app-subnav__scroll::-webkit-scrollbar{display:none}.app-subnav__pill{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--text-muted);text-decoration:none;padding:4px 10px;border-radius:var(--radius-md);background:transparent;white-space:nowrap;transition:var(--transition-smooth);flex-shrink:0;font-family:var(--font-family)}.app-subnav__pill:hover{color:var(--text-primary);background:var(--bg-elevated)}.app-subnav__pill--active{background:var(--brand-soft);color:var(--brand);border:1px solid var(--brand-border)}.app-drawer{position:fixed;inset:0;z-index:400;background:var(--warm-bg);overflow-y:auto;display:flex;flex-direction:column;padding:0 0 80px}.app-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1.5px solid var(--warm-border);position:sticky;top:0;background:var(--warm-surface);z-index:1}.app-drawer__title{font-size:15px;font-weight:600;color:var(--text-primary)}.app-drawer__auth-banner{margin:12px 16px;padding:12px;background:var(--warm-surface);border:1.5px solid var(--warm-border);border-radius:var(--radius-lg)}.app-drawer__auth-msg{font-size:13px;color:var(--text-secondary);margin-bottom:10px}.app-drawer__auth-btns{display:flex;gap:8px}.app-drawer__group-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);padding:12px 16px 6px}.app-drawer__grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:0 16px}.app-drawer__tile{position:relative;display:flex;align-items:center;justify-content:center;text-align:center;font-size:13px;font-weight:500;color:var(--text-primary);text-decoration:none;padding:12px;border-radius:var(--radius-md);background:var(--warm-surface);border:1.5px solid var(--warm-border);transition:var(--transition-smooth);font-family:var(--font-family)}.app-drawer__tile:hover,.app-drawer__tile--active{background:var(--brand-soft);border-color:var(--brand-border);color:var(--brand)}.app-drawer__new-badge{position:absolute;top:4px;right:4px;font-size:9px;font-weight:700;background:var(--brand);color:#fff;padding:1px 4px;border-radius:3px;letter-spacing:.03em}.app-drawer__logout{display:flex;align-items:center;gap:8px;margin:0 16px;padding:10px 12px;font-size:13px;font-weight:500;color:var(--danger);background:var(--danger-soft);border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-smooth);width:calc(100% - 32px);font-family:var(--font-family)}.app-drawer__logout:hover{background:var(--danger);color:#fff}.app-bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:199;display:flex;background:var(--warm-surface);border-top:1.5px solid var(--warm-border);padding:4px 0 calc(4px + env(safe-area-inset-bottom))}@media(min-width:768px){.app-bottom-nav{display:none}}.app-bottom-nav__tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 0;font-size:10px;font-weight:600;color:var(--text-muted);text-decoration:none;background:transparent;border:none;cursor:pointer;transition:var(--transition-smooth);font-family:var(--font-family)}.app-bottom-nav__tab--active{color:var(--brand)}.ymn-bar{position:fixed;bottom:0;left:0;right:0;z-index:var(--layer-navigation, 1000);background-color:var(--bg-surface, #ffffff);border-top:1px solid var(--border-normal, #e2e8f0);box-shadow:0 -4px 12px #00000008;padding-bottom:env(safe-area-inset-bottom,var(--space-3, 12px));padding-top:var(--space-2, 8px)}.ymn-tabs-container{display:flex;justify-content:space-around;align-items:center;max-width:540px;margin:0 auto;padding:0 var(--space-2, 8px)}.ymn-track-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(to right,transparent,var(--border-normal, #e2e8f0) 15%,var(--border-normal, #e2e8f0) 85%,transparent)}.ymn-item{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-height:44px;text-decoration:none;color:var(--text-muted, #64748b);transition:color var(--transition-smooth, .2s ease);-webkit-tap-highlight-color:transparent}.ymn-item:active{transform:scale(.96)}.ymn-icon-wrapper{display:flex;align-items:center;justify-content:center;width:24px;height:24px;margin-bottom:3px;transition:transform var(--transition-fast, .15s cubic-bezier(.34, 1.56, .64, 1))}.ymn-label{font-size:10px;font-weight:var(--font-weight-medium, 500);letter-spacing:var(--letter-spacing-wide, .02em);line-height:1}.ymn-indicator{position:absolute;top:-8px;display:flex;justify-content:center;align-items:center;opacity:0;transform:translateY(4px) scale(.7);transition:opacity var(--transition-smooth, .2s ease),transform var(--transition-fast, .2s cubic-bezier(.34, 1.56, .64, 1));pointer-events:none}.ymn-indicator-train{color:var(--brand, #0284c7);filter:drop-shadow(0 2px 4px rgba(2,132,199,.2))}.ymn-item--active{color:var(--brand, #0284c7)}.ymn-item--active .ymn-icon-wrapper{transform:translateY(1px);color:var(--brand, #0284c7)}.ymn-item--active .ymn-label{font-weight:var(--font-weight-bold, 700);color:var(--text-primary, #0f172a)}.ymn-indicator--visible{opacity:1;transform:translateY(0) scale(1)}@media(min-width:769px){.ymn-bar{display:none!important}}.yf-footer{background-color:var(--bg-surface);border-top:1.5px solid var(--border-normal);color:var(--text-primary);font-family:var(--font-family);padding-top:var(--space-12);box-shadow:inset 0 2px 4px #00000003}.yf-container{max-width:1200px;margin:0 auto;padding:0 var(--space-6)}.yf-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:var(--space-12);padding-bottom:var(--space-10)}.yf-brand-section{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-4)}.yf-brand-link{display:inline-flex;align-items:center;gap:var(--space-3);text-decoration:none;color:inherit;transition:var(--transition-smooth)}.yf-brand-link:hover .yf-logo{transform:scale(1.05);background-color:var(--brand-hover)}.yf-logo{width:34px;height:34px;background-color:var(--brand);color:var(--text-inverse);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);transition:var(--transition-fast)}.yf-brand-text{display:flex;flex-direction:column}.yf-brand-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-none)}.yf-brand-tag{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--text-muted);margin-top:3px;text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.yf-desc{font-size:var(--font-size-sm);line-height:var(--line-height-normal);color:var(--text-secondary);max-width:440px}.yf-helpline-card{display:flex;align-items:center;gap:var(--space-3);background-color:var(--bg-main);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);margin-top:var(--space-2)}.yf-helpline-icon{width:26px;height:26px;background-color:var(--brand-soft);color:var(--brand);border:1px solid var(--brand-border);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.yf-helpline-body{display:flex;flex-direction:column}.yf-helpline-label{font-size:10px;font-weight:var(--font-weight-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.yf-helpline-num{font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-top:1px}.yf-links-col{display:flex;flex-direction:column;gap:var(--space-4)}.yf-col-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-primary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);padding-bottom:var(--space-1);position:relative}.yf-links-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.yf-link{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);text-decoration:none;transition:var(--transition-smooth);display:inline-flex;align-items:center;width:max-content}.yf-link:hover{color:var(--brand);transform:translate(2px)}.yf-ext-link{color:var(--text-secondary)}.yf-ext-link .yf-ext-link{gap:var(--space-1\.5)}.yf-ext-icon{color:var(--text-subtle);transition:var(--transition-smooth)}.yf-link:hover .yf-ext-icon{color:var(--brand);transform:translate(1px,-1px)}.yf-bottom-strip{background-color:var(--bg-main);border-top:1px solid var(--border-normal);padding:var(--space-5) 0}.yf-bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.yf-copyright{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:var(--font-weight-medium)}.yf-bottom-links{display:flex;align-items:center;gap:var(--space-3)}.yf-bottom-link{font-size:var(--font-size-xs);color:var(--text-muted);text-decoration:none;font-weight:var(--font-weight-semibold);transition:var(--transition-smooth)}.yf-bottom-link:hover{color:var(--text-primary)}.yf-bottom-sep{width:1px;height:12px;background-color:var(--border-normal)}@media(max-width:992px){.yf-grid{grid-template-columns:1fr 1fr;gap:var(--space-8)}.yf-brand-section{grid-column:span 2;max-width:100%}.yf-desc{max-width:100%}}@media(max-width:576px){.yf-footer{padding-top:var(--space-8)}.yf-grid{grid-template-columns:1fr;gap:var(--space-6)}.yf-brand-section{grid-column:span 1}.yf-bottom-inner{flex-direction:column;align-items:flex-start;gap:var(--space-3)}}.tdp-root{display:flex;flex-direction:column;gap:var(--space-6);max-width:1200px;margin:0 auto;padding:var(--space-4) var(--space-6) var(--space-12) var(--space-6);animation:fadeIn .2s ease forwards;font-family:var(--font-family)}.tdp-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);min-height:50vh;text-align:center;color:var(--text-secondary);font-family:var(--font-family)}.tdp-spinner{width:32px;height:32px;border:3px solid var(--border-normal);border-top-color:var(--brand);border-radius:var(--radius-full);animation:spin .8s linear infinite}.tdp-btn-primary{background:var(--brand);color:var(--text-inverse);border:none;border-radius:var(--radius-md);padding:8px 20px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);transition:var(--transition-smooth);cursor:pointer}.tdp-btn-primary:hover{background:var(--brand-hover)}.tdp-topbar{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-normal)}.tdp-back-btn{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1.5px solid var(--border-normal);background:var(--bg-surface);transition:var(--transition-smooth);cursor:pointer}.tdp-back-btn:hover{background:var(--bg-hover);border-color:var(--border-medium);color:var(--text-primary)}.tdp-topbar-meta{display:flex;align-items:center;gap:var(--space-3)}.tdp-topbar-meta .tdp-train-num{font-family:var(--font-mono);font-weight:var(--font-weight-semibold);color:var(--text-muted);font-size:var(--font-size-sm)}.tdp-type-tag{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--indigo-soft);color:var(--indigo);padding:3px 10px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);border:1px solid var(--indigo-border);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.tdp-hero{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.tdp-hero:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(to bottom,var(--brand),var(--violet),var(--teal))}.tdp-hero .tdp-train-num{font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--brand);text-transform:uppercase;margin-bottom:var(--space-1)}.tdp-train-name{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-bottom:var(--space-6)}.tdp-route{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-top:var(--space-4)}.tdp-station{display:flex;flex-direction:column;min-width:140px}.tdp-station:last-child{text-align:right}.tdp-stn-code{font-family:var(--font-mono);font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:var(--line-height-tight)}.tdp-stn-name{font-size:var(--font-size-sm);color:var(--text-muted);font-weight:var(--font-weight-medium);margin-top:var(--space-1)}.tdp-route-line{flex:1;height:2px;border-top:2px dashed var(--dashed-track);position:relative}.tdp-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.tdp-metric{border:1.5px solid var(--border-normal);border-radius:var(--radius-lg);padding:var(--space-4);display:flex;align-items:center;gap:var(--space-4);background:var(--bg-surface)}.tdp-metric div{display:flex;flex-direction:column}.tdp-metric strong{font-family:var(--font-mono);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.tdp-metric span{font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide)}.tdp-metric:nth-child(1){background:var(--amber-soft);border-color:var(--amber-border)}.tdp-metric:nth-child(1) svg{stroke:var(--amber)}.tdp-metric:nth-child(1) strong{color:var(--amber)}.tdp-metric:nth-child(2){background:var(--teal-soft);border-color:var(--teal-border)}.tdp-metric:nth-child(2) svg{stroke:var(--teal)}.tdp-metric:nth-child(2) strong{color:var(--teal)}.tdp-metric:nth-child(3){background:var(--indigo-soft);border-color:var(--indigo-border)}.tdp-metric:nth-child(3) svg{stroke:var(--indigo)}.tdp-metric:nth-child(3) strong{color:var(--indigo)}.tdp-metric:nth-child(4){background:var(--violet-soft);border-color:var(--violet-border)}.tdp-metric:nth-child(4) svg{stroke:var(--violet)}.tdp-metric:nth-child(4) strong{color:var(--violet)}.tdp-layout{display:grid;grid-template-columns:1fr 340px;gap:var(--space-6);align-items:start}.tdp-main-panel{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.tdp-panel-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1.5px solid var(--border-normal);padding-bottom:var(--space-3);margin-bottom:var(--space-4)}.tdp-panel-head h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary)}.tdp-panel-head span{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--text-muted);font-weight:var(--font-weight-semibold)}.tdp-timeline{display:flex;flex-direction:column}.tdp-stop-row{display:flex;align-items:stretch;gap:var(--space-4);cursor:pointer;padding:var(--space-3) var(--space-2);margin:0 calc(var(--space-2) * -1);border-radius:var(--radius-md);transition:var(--transition-fast);outline:none}.tdp-stop-row:hover,.tdp-stop-row:focus-visible{background:var(--bg-hover)}.tdp-track{display:flex;flex-direction:column;align-items:center;width:24px;flex-shrink:0}.tdp-track-line{flex:1;width:2px;background-color:var(--border-normal)}.tdp-track-dot{width:10px;height:10px;border-radius:var(--radius-full);border:2px solid var(--bg-surface);background-color:var(--text-subtle);margin:4px 0;z-index:var(--z-raised);transition:var(--transition-fast)}.tdp-stop-row:hover .tdp-track-dot{transform:scale(1.2)}.tdp-track-dot.source{background-color:var(--success);box-shadow:0 0 0 3px var(--success-soft);width:12px;height:12px}.tdp-track-dot.destination{background-color:var(--danger);box-shadow:0 0 0 3px var(--danger-soft);width:12px;height:12px}.tdp-stop-content{flex:1;display:flex;flex-direction:column;gap:var(--space-2);justify-content:center}.tdp-stop-header{display:flex;align-items:baseline;gap:var(--space-2)}.tdp-stop-name{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.tdp-stop-code{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--text-secondary);font-weight:var(--font-weight-bold);background:var(--bg-elevated);padding:1px 6px;border-radius:var(--radius-xs);border:1px solid var(--border-normal)}.tdp-stop-times{display:flex;gap:var(--space-6)}.tdp-stop-times div{display:flex;flex-direction:column}.tdp-stop-times label{font-size:var(--font-size-xs);color:var(--text-subtle);text-transform:uppercase;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide)}.tdp-stop-times span{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.tdp-day{font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--teal);background:var(--teal-soft);border:1px solid var(--teal-border);padding:2px 8px;border-radius:var(--radius-sm);align-self:center;height:max-content}.tdp-sidebar{display:flex;flex-direction:column;gap:var(--space-6)}.tdp-sidebar .tdp-card{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-sm)}.tdp-sidebar h3{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);margin-bottom:var(--space-4);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-2)}.tdp-classes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.tdp-class-card{border:1.5px solid var(--border-normal);border-radius:var(--radius-md);padding:var(--space-3) var(--space-1);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.tdp-class-card span{font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:var(--font-weight-bold)}.tdp-class-card small{font-size:11px;font-weight:var(--font-weight-semibold);margin-top:var(--space-1);white-space:nowrap}.tdp-class-card:nth-child(5n+1){background:var(--violet-soft);border-color:var(--violet-border);color:var(--violet)}.tdp-class-card:nth-child(5n+1) small{color:var(--violet);opacity:.8}.tdp-class-card:nth-child(5n+2){background:var(--indigo-soft);border-color:var(--indigo-border);color:var(--indigo)}.tdp-class-card:nth-child(5n+2) small{color:var(--indigo);opacity:.8}.tdp-class-card:nth-child(5n+3){background:var(--teal-soft);border-color:var(--teal-border);color:var(--teal)}.tdp-class-card:nth-child(5n+3) small{color:var(--teal);opacity:.8}.tdp-class-card:nth-child(5n+4){background:var(--amber-soft);border-color:var(--amber-border);color:var(--amber)}.tdp-class-card:nth-child(5n+4) small{color:var(--amber);opacity:.8}.tdp-class-card:nth-child(5n+5){background:var(--rose-soft);border-color:var(--rose-border);color:var(--rose)}.tdp-class-card:nth-child(5n+5) small{color:var(--rose);opacity:.8}.tdp-info-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2\.5) 0;border-bottom:1px dashed var(--border-subtle);font-size:var(--font-size-sm)}.tdp-info-row:last-of-type{border-bottom:none;padding-bottom:0}.tdp-info-row span{color:var(--text-muted);font-weight:var(--font-weight-medium)}.tdp-info-row strong{font-family:var(--font-mono);color:var(--text-primary);font-weight:var(--font-weight-semibold)}.tdp-map-stub{background:var(--brand-soft);border:1.5px dashed var(--brand-border);border-radius:var(--radius-lg);padding:var(--space-6) var(--space-4);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-3);color:var(--brand)}.tdp-map-stub span{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.tdp-map-stub .tdp-btn-primary{width:100%;font-size:var(--font-size-xs);padding:6px 12px}.tdp-muted{font-size:var(--font-size-sm);color:var(--text-muted);text-align:center;padding:var(--space-2) 0}@media(max-width:992px){.tdp-layout{grid-template-columns:1fr}.tdp-metrics{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.tdp-root{padding:var(--space-3) var(--space-4) var(--space-8) var(--space-4);gap:var(--space-4)}.tdp-hero{padding:var(--space-4) var(--space-5)}.tdp-stn-code{font-size:var(--font-size-2xl)}.tdp-train-name{font-size:var(--font-size-xl);margin-bottom:var(--space-4)}.tdp-metrics{grid-template-columns:1fr;gap:var(--space-2)}.tdp-stop-times{gap:var(--space-4)}.tdp-classes-grid{grid-template-columns:repeat(2,1fr)}}.station-details-page{max-width:1100px;margin:0 auto;padding:28px 20px 80px}.station-content{display:flex;flex-direction:column;gap:16px}.station-header{margin-bottom:4px}.back-button{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:13px;font-weight:500;margin-bottom:16px;transition:var(--transition-fast);cursor:pointer}.back-button:hover{color:var(--text-primary)}.station-header-main{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.station-code-badge{font-family:var(--font-mono);font-size:13px;font-weight:700;padding:3px 10px;background:var(--brand-soft);color:var(--brand);border:1px solid var(--brand-border);border-radius:var(--radius-sm);letter-spacing:.06em}.station-name{font-size:26px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px}.info-card{display:flex;gap:0;border-radius:var(--radius-lg);overflow:hidden}.info-card-rail{width:4px;background:var(--brand);flex-shrink:0;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.info-card-body{flex:1;background:var(--warm-surface);border:1.5px solid var(--warm-border);border-left:none;border-radius:0 var(--radius-lg) var(--radius-lg) 0;padding:14px 16px;display:flex;align-items:center;gap:12px}.info-icon{width:38px;height:38px;border-radius:var(--radius-md);background:var(--warm-bg);border:1px solid var(--warm-border);display:flex;align-items:center;justify-content:center;color:var(--brand);flex-shrink:0}.info-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin-bottom:3px}.info-value{font-size:14px;font-weight:700;color:var(--text-primary)}.station-map{background:var(--warm-surface);border:1.5px solid var(--warm-border);border-radius:var(--radius-xl);overflow:hidden}.map-header{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--warm-bg);border-bottom:1px solid var(--warm-border);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle)}.map-placeholder{padding:48px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.map-placeholder p{font-size:13.5px;color:var(--text-secondary);font-weight:500}.map-coords{font-family:var(--font-mono);font-size:12px!important;color:var(--text-subtle)!important}.trains-section{margin-top:8px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-title{display:flex;align-items:center;gap:8px}.section-title h2{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-subtle)}.section-subtitle{font-size:11px;color:var(--text-subtle)}.trains-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}.train-card{display:flex;gap:0;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:var(--transition-smooth)}.train-card:hover{box-shadow:var(--shadow-md)}.train-card:hover .tc-body-inner{background:var(--warm-hover);border-color:var(--warm-border-2)}.tc-rail-inner{width:4px;background:var(--brand);flex-shrink:0;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.tc-body-inner{flex:1;background:var(--warm-surface);border:1.5px solid var(--warm-border);border-left:none;border-radius:0 var(--radius-lg) var(--radius-lg) 0;padding:10px 16px;display:grid;grid-template-columns:2fr 1.5fr auto;align-items:center;gap:12px;transition:var(--transition-smooth)}.train-left{display:flex;flex-direction:column;gap:3px}.train-number{font-family:var(--font-mono);font-size:11px;font-weight:700;color:var(--brand);letter-spacing:.05em}.train-name{font-size:13.5px;font-weight:700;color:var(--text-primary)}.train-timing{display:flex;gap:24px}.timing{display:flex;flex-direction:column;gap:1px}.time-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle)}.time{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--text-primary)}.train-day{font-family:var(--font-mono);font-size:10px;font-weight:700;background:var(--rail-purple-soft);color:var(--rail-purple);padding:2px 7px;border-radius:4px}.load-more-container{display:flex;justify-content:center;margin-top:16px}.load-more-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 24px;background:var(--warm-surface);border:1.5px solid var(--warm-border-2);border-radius:var(--radius-md);font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;font-family:var(--font-family);transition:var(--transition-smooth)}.load-more-btn:hover:not(:disabled){background:var(--warm-hover)}.load-more-btn:disabled{opacity:.5;cursor:not-allowed}.no-trains{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;color:var(--text-muted);gap:8px}.station-details-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:40vh;gap:14px;color:var(--text-secondary)}.loading-spinner{width:28px;height:28px;border:2.5px solid var(--warm-border);border-radius:50%;border-top-color:var(--brand);animation:spin 1s linear infinite}.station-details-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;max-width:440px;margin:0 auto;padding:24px;gap:12px}.station-details-error svg{color:var(--danger)}.station-details-error h2{font-size:20px}.station-details-error p{color:var(--text-secondary);font-size:13.5px}.back-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--warm-surface);border:1.5px solid var(--warm-border-2);border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-family)}.back-btn:hover{background:var(--warm-hover)}@media(max-width:768px){.station-details-page{padding:16px 14px 64px}.station-name{font-size:20px}.tc-body-inner{grid-template-columns:1fr;gap:8px}.train-timing{background:var(--warm-bg);padding:8px 10px;border-radius:var(--radius-sm)}}.ctd-page{min-height:100vh;background-color:var(--bg-main);padding:var(--space-4) 0 var(--space-16) 0;font-family:var(--font-family);animation:fadeIn .2s ease forwards}.ctd-container{max-width:1200px;margin:0 auto;padding:0 var(--space-6);display:flex;flex-direction:column;gap:var(--space-5)}.ctd-error-screen{min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:var(--space-3);color:var(--text-secondary);padding:var(--space-8)}.ctd-error-screen h2{font-size:var(--font-size-xl);color:var(--text-primary);font-weight:var(--font-weight-bold)}.ctd-error-screen .ctd-back-btn{background:var(--brand);color:var(--text-inverse);border:none;border-radius:var(--radius-md);padding:8px 20px;font-weight:var(--font-weight-bold);cursor:pointer;transition:var(--transition-fast)}.ctd-error-screen .ctd-back-btn:hover{background:var(--brand-hover)}.ctd-topbar{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-2);border-bottom:1px solid var(--border-normal)}.ctd-back{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--bg-surface);color:var(--text-secondary);border:1.5px solid var(--border-normal);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-smooth)}.ctd-back:hover{background:var(--bg-hover);border-color:var(--border-medium);color:var(--text-primary)}.ctd-topbar-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--text-muted)}.ctd-hero{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.ctd-hero-rail{position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(180deg,var(--violet),var(--indigo))}.ctd-hero-body{padding:var(--space-6) var(--space-8);display:flex;flex-direction:column;gap:var(--space-5)}.ctd-hero-route{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.ctd-hero-station{display:flex;flex-direction:column;min-width:180px}.ctd-hero-station--right{text-align:right}.ctd-hero-time{font-family:var(--font-mono);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:var(--line-height-tight)}.ctd-hero-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-muted);margin-top:2px}.ctd-hero-arrow{flex:1;display:flex;align-items:center;gap:var(--space-3)}.ctd-hero-line{flex:1;height:2px;border-top:2px dashed var(--dashed-track)}.ctd-hero-icon-wrap{width:32px;height:32px;background:var(--brand-soft);border:1px solid var(--brand-border);color:var(--brand);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center}.ctd-perf{height:1px;background:var(--border-subtle)}.ctd-hero-meta{display:flex;align-items:center;gap:var(--space-6)}.ctd-meta-pill{display:flex;flex-direction:column}.ctd-meta-pill-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.ctd-meta-pill-val{font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary);margin-top:1px}.ctd-transfer-val{color:var(--amber)}.ctd-meta-sep{width:1px;height:24px;background:var(--border-normal)}.ctd-layout-grid{display:grid;grid-template-columns:1fr 400px;gap:var(--space-6);align-items:start}.ctd-main-panel,.ctd-sidebar-panel{display:flex;flex-direction:column;gap:var(--space-4)}.ctd-main-panel{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-sm)}.ctd-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);border-bottom:1px solid var(--border-subtle);padding-bottom:var(--space-2)}.ctd-badge-violet{background:var(--violet-soft);color:var(--violet);border:1px solid var(--violet-border)}.ctd-badge-indigo{background:var(--indigo-soft);color:var(--indigo);border:1px solid var(--indigo-border)}.ctd-visual-timeline{display:flex;flex-direction:column}.ctd-vt-row{display:grid;grid-template-columns:48px 1fr;align-items:flex-start}.ctd-vt-spine{display:flex;flex-direction:column;align-items:center;height:100%;position:relative}.ctd-vt-line{width:2px;background:var(--border-normal);flex:1;min-height:24px}.ctd-vt-line--transit{min-height:44px;background-style:dotted}.ctd-vt-dot{width:10px;height:10px;border-radius:var(--radius-full);border:2px solid var(--bg-surface);z-index:var(--z-raised);box-sizing:content-box}.ctd-vt-dot--start{background-color:var(--success);box-shadow:0 0 0 3px var(--success-soft)}.ctd-vt-dot--end{background-color:var(--rose);box-shadow:0 0 0 3px var(--rose-soft)}.ctd-vt-dot--transfer{width:18px;height:18px;background-color:var(--amber-soft);color:var(--amber);border:1.5px solid var(--amber-border);display:flex;align-items:center;justify-content:center;margin:2px 0}.ctd-vt-info{padding-bottom:var(--space-5);display:flex;flex-direction:column;gap:2px}.ctd-vt-info--final{padding-bottom:0}.ctd-vt-row--transit .ctd-vt-info{padding:var(--space-2) 0 var(--space-4) 0}.ctd-vt-time{font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary)}.ctd-vt-station{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-secondary)}.ctd-vt-label{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:var(--font-weight-medium)}.ctd-vt-train-badge{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1.5) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);width:max-content}.ctd-transfer-chip{display:inline-flex;align-items:center;background:var(--amber-soft);color:var(--amber);border:1px solid var(--amber-border);padding:var(--space-1) var(--space-2.5);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);width:max-content;margin-top:var(--space-1)}.ctd-transfer-chip .yf-ext-link{gap:var(--space-1\.5)}.ctd-leg-card{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);overflow:hidden;display:flex;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),border-color var(--transition-smooth)}.ctd-leg-card:hover{transform:translateY(-2px);border-color:var(--border-strong)}.ctd-leg-rail{width:6px;align-self:stretch;flex-shrink:0}.ctd-leg-rail-1{background:var(--violet)}.ctd-leg-rail-2{background:var(--indigo)}.ctd-leg-body{flex:1;padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.ctd-leg-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4)}.ctd-leg-meta-block{display:flex;flex-direction:column;align-items:flex-start;gap:3px}.ctd-leg-badge{font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);padding:1px 6px;border-radius:var(--radius-xs)}.ctd-leg-train-name{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary)}.ctd-leg-train-num{font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-muted)}.ctd-leg-duration{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-secondary);background:var(--bg-main);padding:var(--space-1) var(--space-2.5);border:1px solid var(--border-normal);border-radius:var(--radius-full)}.ctd-leg-route{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);background:var(--bg-main);padding:var(--space-3);border-radius:var(--radius-lg);border:1px solid var(--border-normal)}.ctd-leg-stop{display:flex;flex-direction:column;min-width:90px}.ctd-leg-stop--right{text-align:right}.ctd-leg-time{font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);color:var(--text-primary)}.ctd-leg-stn{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:var(--font-weight-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}.ctd-leg-arrow{flex:1;display:flex;align-items:center;color:var(--text-subtle)}.ctd-leg-line{flex:1;height:1px;background-color:var(--border-normal)}.ctd-leg-footer{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--brand);border-top:1px dashed var(--border-normal);padding-top:var(--space-3);margin-top:var(--space-1)}.ctd-transfer-banner{background:var(--amber-soft);border:1.5px dashed var(--amber-border);border-radius:var(--radius-xl);padding:var(--space-3.5) var(--space-4);display:flex;align-items:center;gap:var(--space-3)}.ctd-transfer-icon-wrap{width:28px;height:28px;border-radius:var(--radius-full);background:var(--bg-surface);color:var(--amber);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-sm)}.ctd-transfer-info{flex:1;display:flex;flex-direction:column}.ctd-transfer-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--text-primary)}.ctd-transfer-time{font-size:11px;color:var(--text-secondary);display:flex;align-items:center;gap:3px;margin-top:1px}.ctd-transfer-warning{display:flex;align-items:center;gap:var(--space-1);font-size:10px;font-weight:var(--font-weight-bold);color:var(--amber);text-transform:uppercase;background:var(--bg-surface);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);border:1px solid var(--amber-border)}.ctd-summary{background:var(--bg-surface);border:1.5px solid var(--border-normal);border-radius:var(--radius-xl);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;box-shadow:var(--shadow-sm)}.ctd-summary-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2\.5) 0;border-bottom:1px dashed var(--border-subtle);font-size:var(--font-size-sm)}.ctd-summary-row span{color:var(--text-muted);font-weight:var(--font-weight-medium)}.ctd-summary-row strong{font-family:var(--font-mono);color:var(--text-primary);font-weight:var(--font-weight-semibold)}.ctd-summary-row--total{border-bottom:none;padding-bottom:0;margin-top:var(--space-2);padding-top:var(--space-3);border-top:1.5px solid var(--border-normal)}.ctd-summary-row--total span{font-weight:var(--font-weight-bold);color:var(--text-primary)}.ctd-summary-row--total strong{font-size:var(--font-size-md);color:var(--brand);font-weight:var(--font-weight-bold)}@media(max-width:992px){.ctd-layout-grid{grid-template-columns:1fr;gap:var(--space-5)}}@media(max-width:640px){.ctd-hero-body{padding:var(--space-4) var(--space-5)}.ctd-hero-time{font-size:var(--font-size-xl)}.ctd-hero-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-2);text-align:center}.ctd-meta-sep{display:none}.ctd-transfer-banner{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.ctd-transfer-warning{align-self:flex-end}}
