@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--primary:#007aff;--primary-light:#007aff1f;--red-line:#ff3b30;--green-line:#34c759;--blue-line:#007aff;--bg-primary:#f2f2f7;--bg-secondary:#fff;--glass-bg:#ffffffb3;--glass-border:#fff6;--fill-primary:#7878801f;--fill-secondary:#78788029;--fill-tertiary:#7878803d;--text-primary:#000;--text-secondary:#000000b3;--text-tertiary:#00000080;--shadow-sm:0 1px 3px #0000000a;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 12px 40px #0000001f;--blur-amount:20px;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px)}.dark{--bg-primary:#000;--bg-secondary:#1c1c1e;--glass-bg:#1c1c1eb3;--glass-border:#ffffff1a;--fill-primary:#7878803d;--fill-secondary:#78788052;--fill-tertiary:#7878805c;--text-primary:#fff;--text-secondary:#ffffffb3;--text-tertiary:#ffffff80;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 12px 40px #00000080}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}button,a{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation}button{min-width:44px;min-height:44px}button:active,a:active{opacity:.7;transform:scale(.98)}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}body{background:var(--bg-primary);color:var(--text-primary);width:100%;min-height:100dvh;overflow-x:hidden}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.app-container{background-image:url(/zermatt_background.jpg);background-position:50%;background-size:cover;flex-direction:column;width:100%;max-width:430px;min-height:100dvh;margin:0 auto;display:flex;position:relative;overflow-x:hidden}.app-container:before{content:"";-webkit-backdrop-filter:blur(4px);z-index:0;background:#ffffffbf;position:absolute;inset:0}.dark .app-container:before{background:#000000b3}.app-content{z-index:1;flex-direction:column;flex:1;padding-bottom:90px;display:flex;position:relative}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--blur-amount))saturate(180%);border:1px solid var(--glass-border);box-shadow:var(--shadow-md);border-radius:24px}.glass-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--blur-amount))saturate(180%);border-bottom:1px solid var(--glass-border)}.status-bar{height:44px;padding:0 20px;padding-top:var(--safe-top);z-index:10;justify-content:space-between;align-items:center;display:flex;position:relative}.status-time{font-size:14px;font-weight:600}.status-icons{align-items:center;gap:6px;display:flex}.status-icons .material-symbols-outlined{font-size:18px}.app-header{z-index:10;padding:16px 20px 24px;position:relative}.header-top{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.header-logo{align-items:center;gap:10px;display:flex}.logo-icon{background:var(--glass-bg);width:36px;height:36px;-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);border-radius:12px;justify-content:center;align-items:center;display:flex}.app-title{letter-spacing:-.5px;font-size:20px;font-weight:700}.theme-toggle{background:var(--glass-bg);width:40px;height:40px;-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;transition:transform .15s;display:flex}.theme-toggle:active{transform:scale(.95)}.weather-card{color:#fff;box-shadow:var(--shadow-lg);background:linear-gradient(135deg,#74abe2 0%,#557392 100%);border-radius:24px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:20px;display:flex}.weather-info{flex:1}.weather-location{opacity:.8;margin-bottom:4px;font-size:12px;font-weight:500}.weather-temp{letter-spacing:-1px;margin-bottom:2px;font-size:28px;font-weight:700}.weather-condition{opacity:.7;font-size:11px}.weather-icon{font-size:48px}.search-container{margin-bottom:16px;position:relative}.search-icon{color:var(--text-tertiary);pointer-events:none;position:absolute;top:50%;left:16px;transform:translateY(-50%)}.search-input{background:var(--glass-bg);width:100%;height:52px;-webkit-backdrop-filter:blur(var(--blur-amount));border:1px solid var(--glass-border);color:var(--text-primary);border-radius:16px;outline:none;padding:0 16px 0 48px;font-size:15px;font-weight:500;transition:all .2s}.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #007aff1a}.search-input::placeholder{color:var(--text-tertiary)}.main-content{z-index:10;flex-direction:column;flex:1;gap:16px;padding:0 20px 20px;display:flex;position:relative;overflow-y:auto}.nearest-stop-card{padding:16px}.nearest-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.nearest-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.nearest-distance{color:var(--primary);font-size:13px;font-weight:600}.map-preview{background:#e5e5ea;border-radius:16px;width:100%;height:160px;position:relative;overflow:hidden}.stop-marker{box-shadow:var(--shadow-md);background:#fff;border-radius:12px;align-items:center;gap:8px;padding:8px 12px;display:flex;position:absolute;bottom:16px;left:16px}.marker-dot{border-radius:50%;width:8px;height:8px}.marker-dot.red{background:var(--red-line)}.marker-dot.green{background:var(--green-line)}.marker-name{font-size:13px;font-weight:600}.line-selector{gap:12px;display:flex}.line-btn{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:16px;flex:1;justify-content:center;align-items:center;gap:8px;height:48px;font-size:15px;font-weight:600;transition:all .2s;display:flex}.line-btn.active{border-color:currentColor;box-shadow:0 4px 12px}.line-btn.red{color:var(--red-line)}.line-btn.green{color:var(--green-line)}.line-dot{border-radius:50%;width:10px;height:10px}.line-dot.red{background:var(--red-line)}.line-dot.green{background:var(--green-line)}.departures-section{padding:20px}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-title{letter-spacing:-.5px;font-size:22px;font-weight:700}.view-all-link{color:var(--primary);font-size:15px;font-weight:600;text-decoration:none}.departure-list{flex-direction:column;gap:12px;display:flex}.departure-card{box-shadow:var(--shadow-sm);background:#fff;border-radius:20px;align-items:center;gap:16px;padding:16px;display:flex}.departure-icon{width:48px;height:48px;color:var(--red-line);background:#ff3b301a;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.departure-icon.green{color:var(--green-line);background:#34c7591a}.departure-info{flex:1;min-width:0}.departure-destination{letter-spacing:-.3px;margin-bottom:2px;font-size:17px;font-weight:600}.departure-via{color:var(--text-tertiary);font-size:13px}.departure-time{text-align:right}.time-countdown{letter-spacing:-1px;color:var(--red-line);font-size:24px;font-weight:700}.time-countdown.green{color:var(--green-line)}.time-status{color:var(--text-tertiary);margin-top:2px;font-size:11px}.bottom-nav{height:calc(70px + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--blur-amount))saturate(180%);border-top:1px solid var(--glass-border);z-index:100;justify-content:space-around;align-items:center;max-width:430px;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-tertiary);flex-direction:column;align-items:center;gap:4px;padding:8px 16px;text-decoration:none;transition:all .2s;display:flex}.nav-item.active{color:var(--primary)}.nav-item .material-symbols-outlined{font-size:24px}.nav-label{font-size:11px;font-weight:500}.timeline-container{padding:20px}.timeline-item{gap:16px;padding-bottom:24px;display:flex;position:relative}.timeline-icon-wrapper{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:relative}.timeline-icon-wrapper.current{background:var(--red-line);animation:2s infinite pulse-red}.timeline-icon-wrapper.upcoming{background:var(--primary)}.timeline-icon-wrapper.scheduled{background:var(--text-tertiary);opacity:.3}@keyframes pulse-red{0%,to{transform:scale(1);box-shadow:0 0 #ff3b30b3}50%{transform:scale(1.05);box-shadow:0 0 0 12px #ff3b3000}}.timeline-content{flex:1;padding-top:4px}.timeline-stop-name{margin-bottom:4px;font-size:18px;font-weight:600}.timeline-status{font-size:14px;font-weight:500}.timeline-time{font-variant-numeric:tabular-nums;font-size:20px;font-weight:700}@media (min-width:768px){.app-container{box-shadow:var(--shadow-lg);border-radius:32px;margin-top:24px;margin-bottom:24px;overflow:hidden}.bottom-nav{border-radius:0 0 32px 32px}}.hide-scrollbar::-webkit-scrollbar{display:none}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.timeline-container{position:relative}.timeline-item{align-items:flex-start;gap:16px;padding-bottom:28px;display:flex;position:relative}.timeline-item:not(:last-child):after{content:"";background:linear-gradient(180deg,var(--text-tertiary)0%,transparent 100%);opacity:.3;width:3px;position:absolute;top:48px;bottom:0;left:23px}.timeline-icon-wrapper{z-index:1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;transition:all .3s;display:flex;position:relative}.timeline-icon-wrapper.current{background:var(--red-line);animation:2s infinite pulse-red;box-shadow:0 0 #ff3b30b3}.timeline-icon-wrapper.upcoming{background:var(--primary);box-shadow:0 4px 12px #007aff4d}.timeline-icon-wrapper.passed{background:var(--text-tertiary);opacity:.4}.timeline-icon-wrapper.scheduled{background:var(--fill-primary);border:2px solid var(--separator)}.timeline-content{flex:1;min-width:0;padding-top:8px}.timeline-stop-name{letter-spacing:-.3px;margin-bottom:4px;font-size:18px;font-weight:600}.timeline-status{margin-top:4px;font-size:14px;font-weight:500}.timeline-status.current{color:var(--red-line)}.timeline-status.upcoming{color:var(--primary)}.timeline-status.scheduled{color:var(--text-tertiary)}.timeline-time{font-variant-numeric:tabular-nums;letter-spacing:-.5px;text-align:right;min-width:60px;padding-top:8px;font-size:20px;font-weight:700}.skeleton{background:linear-gradient(90deg,var(--fill-primary)0%,var(--fill-secondary)50%,var(--fill-primary)100%);background-size:200% 100%;border-radius:8px;animation:1.5s ease-in-out infinite skeleton-loading}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-spinner{border:3px solid var(--fill-primary);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.3s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:.35s cubic-bezier(.32,.72,0,1) slideUp}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.scale-in{animation:.2s cubic-bezier(.34,1.56,.64,1) scaleIn}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}button,a,.nav-item,.departure-card,.stop-list-item{transition:all .2s cubic-bezier(.4,0,.2,1)}.departure-card:hover,.stop-list-item:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.page-transition{animation:.3s ease-out pageTransition}@keyframes pageTransition{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.error-container{text-align:center;padding:40px 20px}.error-icon{opacity:.5;margin-bottom:16px;font-size:64px}.error-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:600}.error-message{color:var(--text-tertiary);margin-bottom:20px;font-size:15px}.error-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:12px 24px;font-size:15px;font-weight:600}@media (max-width:380px){.time-value{font-size:48px}.departure-time{font-size:24px}.nav-label{font-size:10px}}@media (min-width:768px){.departure-card:hover{cursor:pointer}.glass-card{transition:transform .2s,box-shadow .2s}.glass-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}button:disabled{opacity:.5;cursor:not-allowed}.will-change-transform{will-change:transform}.gpu-accelerated{backface-visibility:hidden;transform:translateZ(0)}
