@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500&family=Syne:wght@700;800&display=swap";.header{position:fixed;top:0;left:0;width:100%;padding:15px 4%;display:flex;justify-content:space-between;align-items:center;z-index:1000;transition:all .3s ease;opacity:0;transition:opacity .5s ease-in-out}.header.scrolled{background-color:#0a0a0af2;backdrop-filter:blur(10px);padding:12px 4%;box-shadow:0 2px 10px #0000001a}.header__logo a{font-family:var(--font-primary);font-weight:800;font-size:clamp(1rem,4vw,1.2rem);text-decoration:none;color:var(--color-text);white-space:nowrap}.logo-colored{background:linear-gradient(90deg,#F25022,#7FBA00,#00A4EF);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.header__menu-toggle{display:block;cursor:pointer;z-index:1100;width:30px;height:30px;position:relative;padding:8px;margin:-8px}.header__menu-toggle .line{width:100%;height:2px;background-color:var(--color-text);margin:6px 0;transition:all .3s ease;display:block}.header__menu-toggle.active .line-1{transform:rotate(-45deg) translate(-5px,6px)}.header__menu-toggle.active .line-2{transform:rotate(45deg) translate(-5px,-6px)}.fullscreen-menu{position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;background-color:var(--color-background);display:flex;justify-content:center;align-items:center;z-index:999;opacity:0;visibility:hidden;transition:opacity .5s ease,visibility .5s ease;overflow-y:auto}.fullscreen-menu.open{opacity:1;visibility:visible}.fullscreen-menu nav{display:flex;flex-direction:column;align-items:center;gap:clamp(15px,3vh,30px);padding:80px 20px;width:100%;max-height:100%}.fullscreen-menu .menu-item{font-family:var(--font-primary);font-size:clamp(1.5rem,6vw,2rem);text-decoration:none;color:var(--color-text);position:relative;padding:10px}.header__nav,.desktop-only{display:none}.menu-separator{width:clamp(30px,10vw,40px);height:1px;background-color:#ffffff4d;margin:8px 0}.auth-item{color:var(--color-accent-primary)}.btn-logout{background:var(--color-primary, #91d400);color:#000;border-radius:8px;font-weight:700;padding:.5em 1.2em;border:none;transition:background .2s,color .2s;cursor:pointer}.btn-logout span{color:#000}.btn-logout:hover,.btn-logout:focus{background:linear-gradient(90deg,#7FBA00 0%,#00A4EF 100%);color:#fff}.btn-logout:hover span,.btn-logout:focus span{color:#fff}.btn-dashboard{background:var(--color-primary, #91d400);color:#000;border-radius:8px;font-weight:700;padding:.5em 1.2em;border:none;margin-right:8px;transition:background .2s,color .2s;cursor:pointer}.btn-dashboard span{color:#000}.btn-dashboard:hover,.btn-dashboard:focus{background:linear-gradient(90deg,#0078d4 0%,#7FBA00 100%);color:#fff}.btn-dashboard:hover span,.btn-dashboard:focus span{color:#fff}.btn-logout{background:var(--color-primary, #91d400);color:#000;border-radius:8px;font-weight:700;padding:.5em 1.2em;border:none;transition:background .2s,color .2s;cursor:pointer}.btn-logout span{color:#000}.btn-logout:hover,.btn-logout:focus{background:linear-gradient(90deg,#7FBA00 0%,#00A4EF 100%);color:#fff}.btn-logout:hover span,.btn-logout:focus span{color:#fff}@media (max-width: 480px){.header{padding:12px 4%}.header.scrolled{padding:8px 4%}.fullscreen-menu .menu-item{font-size:clamp(1.2rem,5vw,1.8rem)}.fullscreen-menu nav{gap:12px}}@media (max-height: 500px) and (orientation: landscape){.fullscreen-menu nav{padding-top:60px;gap:10px}.fullscreen-menu .menu-item{font-size:1.2rem;padding:5px}.menu-separator{margin:5px 0}}@media (min-width: 768px){.header{padding:18px 4%}.header.scrolled{padding:15px 4%}.header__nav{display:flex;align-items:center}.desktop-only{display:flex}.header__menu-toggle{display:none}.header__nav{flex:1;display:flex;justify-content:space-between;align-items:center;margin-left:30px}.header__nav-links{display:flex;gap:clamp(15px,2vw,25px);flex-wrap:wrap;justify-content:center}.nav-link{font-size:clamp(.8rem,1.5vw,.95rem);text-decoration:none;color:var(--color-text);position:relative;padding:5px 0}.nav-link:after{content:"";position:absolute;width:0;height:1px;bottom:-2px;left:0;background-color:var(--color-accent-primary);transition:width .3s ease}.nav-link:hover:after{width:100%}.header__auth{display:flex;align-items:center;gap:clamp(10px,2vw,20px)}.auth-link{text-decoration:none;color:var(--color-text);font-size:clamp(.8rem,1.5vw,.95rem);white-space:nowrap}.btn-register{font-size:clamp(.8rem,1.5vw,.95rem);padding:8px 16px;white-space:nowrap}}@media (min-width: 1024px){.header{padding:22px 5%}.header.scrolled{padding:18px 5%}.fullscreen-menu .menu-item{font-size:2.5rem}.header__nav{margin-left:clamp(30px,4vw,50px)}.header__nav-links{gap:clamp(25px,3vw,35px)}.nav-link{font-size:1rem}}@media (min-width: 1440px){.header{padding:25px 8%}.header.scrolled{padding:20px 8%}.header__logo a{font-size:1.3rem}.header__nav{margin-left:60px}.nav-link,.auth-link,.btn-register{font-size:1.05rem}}.nav-link-underline{position:relative;text-decoration:none;transition:color .2s}.nav-link-underline:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:#0072ce;border-radius:2px;width:0;transition:width .2s}.nav-link-underline:hover:after,.nav-link-underline:focus:after{width:100%}.header__nav-links .nav-link,.fullscreen-menu .menu-item,.header__auth .auth-link,.header__auth .btn-register{user-select:none;-webkit-user-select:none;-webkit-user-drag:none;-moz-user-select:none;-ms-user-select:none}body.loaded .header{opacity:1}.footer{background-color:var(--color-background-dark, #111);color:var(--color-text-secondary, #999);width:100%;margin-top:auto}.footer__top{padding:60px 0 40px;border-top:1px solid var(--color-border, rgba(255, 255, 255, .1))}.footer__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.footer__col{display:flex;flex-direction:column}.footer__title{color:var(--color-text, #fff);font-family:var(--font-primary);font-weight:700;font-size:1.1rem;margin-bottom:20px;position:relative}.footer__title:after{content:"";position:absolute;left:0;bottom:-8px;width:30px;height:2px;background-color:var(--color-accent-primary)}.footer__description{margin-bottom:20px;line-height:1.6}.footer__links{list-style:none;padding:0;margin:0}.footer__links li{margin-bottom:12px}.footer__links a{color:var(--color-text-secondary);text-decoration:none;transition:color .3s;position:relative;padding-left:15px}.footer__links a:before{content:"\2192";position:absolute;left:0;transition:transform .3s}.footer__links a:hover{color:var(--color-accent-primary)}.footer__links a:hover:before{transform:translate(3px)}.footer__contact{font-style:normal;line-height:1.8}.footer__contact p{margin-bottom:8px}.footer__contact a{color:var(--color-text-secondary);text-decoration:none;transition:color .3s}.footer__contact a:hover{color:var(--color-accent-primary)}.footer__socials{display:flex;gap:15px;margin-top:5px}.social-icon{display:inline-block;width:35px;height:35px;background-color:#ffffff1a;border-radius:50%;color:var(--color-text);text-decoration:none;display:flex;align-items:center;justify-content:center;transition:background-color .3s,transform .3s;font-size:0}.social-icon:hover{background-color:var(--color-accent-primary);transform:translateY(-3px)}.social-icon span{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.linkedin:before{content:"in";font-size:14px;font-weight:700}.twitter:before{content:"X";font-size:14px;font-weight:700}.facebook:before{content:"f";font-size:14px;font-weight:700}.footer__bottom{padding:20px 0;text-align:center;border-top:1px solid rgba(255,255,255,.05);font-size:.9rem}.footer__copyright p{margin:0}@media (max-width: 1024px){.footer__grid{grid-template-columns:repeat(2,1fr);gap:30px 40px}}@media (max-width: 767px){.footer__top{padding:40px 0 20px}.footer__grid{grid-template-columns:1fr;gap:30px}.footer__title{margin-bottom:15px}}#root,.layout{display:flex;flex-direction:column;min-height:100vh}main{flex:1}.footer-link{color:var(--color-primary, #91d400);text-decoration:none;font-weight:600;transition:color .2s}.footer-link:hover{color:var(--color-primary-dark, #005fa3)}.custom-cursor{position:fixed;width:25px;height:25px;border:1px solid var(--color-accent-primary);border-radius:50%;pointer-events:none;z-index:var(--z-cursor);mix-blend-mode:difference;transition:transform .2s ease-out,width .3s ease,height .3s ease,background-color .3s ease;transform:translate(-50%,-50%)}.custom-cursor.hovered{width:60px;height:60px;background-color:#beff0033}body{cursor:none}@media (max-width: 768px){.custom-cursor{display:none}body{cursor:auto}}.preloader{position:fixed;top:0;left:0;width:100%;height:100%;background-color:var(--color-background);z-index:var(--z-preloader);display:flex;justify-content:center;align-items:center;clip-path:polygon(0% 0%,100% 0%,100% 100%,0% 100%)}.preloader__text{text-align:center;color:var(--color-text-secondary);font-size:5rem;text-transform:uppercase}.preloader__text .header__logo{font-family:var(--font-primary),sans-serif;font-weight:800;font-size:80px;text-decoration:none;color:var(--color-text);white-space:nowrap}.preloader__progress{width:300px;height:1px;background-color:var(--color-border);margin-top:10px;position:relative;overflow:hidden}.preloader__progress-bar{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,#F25022,#7FBA00,#00A4EF);transform:scaleX(0);transform-origin:left}.layout{display:flex;flex-direction:column;min-height:100vh}main{flex:1}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:0;text-align:center}.hero__content{width:90%;position:relative;z-index:2;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}.hero__title{font-family:var(--font-primary);font-size:clamp(1rem,7vw,5.5rem);font-weight:800;line-height:clamp(.9,.9 + .1vw,1.1);text-transform:uppercase;color:var(--color-text);margin-bottom:clamp(15px,2vw,30px);letter-spacing:clamp(-1px,-.05vw,0px);position:relative;z-index:10;isolation:isolate}.hero__title .line-wrapper{overflow:hidden;display:block;margin-bottom:clamp(.1rem,1vw,.5rem);position:relative;z-index:15;width:100%;text-align:center}.hero__title .line-wrapper>span{display:block;position:relative;z-index:20;transform:translateZ(0);will-change:transform;text-align:center;margin:0 auto}.hero__subtitle{font-size:clamp(.9rem,3vw,1.5rem);line-height:clamp(1.4,1.4 + .1vw,1.6);max-width:min(600px,95%);margin-left:auto;margin-right:auto;margin-bottom:clamp(20px,5vw,40px);font-weight:300;position:relative;z-index:10;text-align:center}.hero__tagline{margin-top:clamp(15px,3vw,25px);color:var(--color-text-secondary);font-size:clamp(.85rem,2.5vw,1.1rem);line-height:1.5;max-width:min(500px,90%);position:relative;z-index:10;text-align:center;margin-left:auto;margin-right:auto}.hero__cta{margin-top:clamp(20px,4vw,40px);display:flex;flex-wrap:wrap;gap:clamp(10px,3vw,20px);position:relative;z-index:25;justify-content:center}.hero__cta .btn{font-size:clamp(.85rem,2.5vw,1rem);padding:clamp(10px,2vw + 5px,15px) clamp(20px,4vw + 10px,30px);white-space:nowrap;position:relative;z-index:30}.hero__scroll-down{position:absolute;bottom:clamp(15px,4vw,30px);left:50%;transform:translate(-50%);color:var(--color-text-secondary);font-size:clamp(.7rem,1.5vw,.8rem);text-transform:uppercase;writing-mode:vertical-lr;letter-spacing:clamp(1px,.5vw,2px);display:flex;flex-direction:column;align-items:center;gap:clamp(8px,2vw,10px)}.scroll-arrow{width:1px;height:clamp(30px,5vw,40px);background:var(--color-text-secondary);position:relative;animation:scrollIndicator 1.5s ease-in-out infinite}@keyframes scrollIndicator{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}.hero__bg-shape{position:absolute;width:50vw;height:50vw;background-color:var(--color-accent-primary);border-radius:50%;filter:blur(150px);opacity:.15;z-index:var(--z-back);top:50%;left:50%;transform:translate(-50%,-50%)}@media (min-width: 768px){.hero__content{max-width:70%;margin:0 auto}}@media (min-width: 1024px){.hero__content{max-width:60%;padding:20px;position:relative;z-index:5;margin:0 auto}.hero__title{margin-bottom:30px;text-shadow:0px 0px 15px rgba(0,0,0,.2)}.hero__bg-shape{z-index:1}.hero__title .line-wrapper{margin-bottom:.5rem;overflow:visible}.hero__title .line-wrapper>span{overflow:visible;display:inline-block;font-size:400;padding:2px 0}}@media (min-width: 1440px){.hero__title{letter-spacing:-1px;font-size:min(5.5rem,5vw)}.hero__content{max-width:55%;padding:30px}}.hero *:before,.hero *:after{z-index:-1}.about{background-color:var(--color-background);position:relative}.about__content{max-width:700px;margin:0 auto;text-align:center}.about__content p{font-size:1.2rem;line-height:1.5;margin-bottom:40px;position:relative}.anim-text-reveal{clip-path:none!important;opacity:1!important;transform:none!important;color:var(--color-text-secondary)}@media (max-width: 768px){.about__content p{font-size:1.1rem}}.skills{padding:60px 0;overflow:hidden;border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.skills__marquee{display:flex;width:fit-content}.marquee__inner{display:flex;white-space:nowrap;font-family:var(--font-primary);font-size:clamp(1.5rem,6vw,3rem);font-weight:800;text-transform:uppercase}.marquee__inner span{margin:0 20px}.marquee__inner .lime{color:var(--color-accent-primary)}.projects{background-color:var(--color-background)}.projects__intro{max-width:800px;margin:0 auto 60px;text-align:center;font-size:1.2rem;color:var(--color-text-secondary)}.projects__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:40px}.project-card{text-decoration:none;color:var(--color-text);display:block}.project-card__image{overflow:hidden;aspect-ratio:4 / 5;background-color:var(--color-surface)}.project-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.23,1,.32,1)}.project-card:hover .project-card__image img{transform:scale(1.05)}.project-card__content{padding-top:20px}.project-card__category{display:block;color:var(--color-text-secondary);font-size:.9rem;text-transform:uppercase;margin-bottom:5px}.project-card__title{font-family:var(--font-primary);font-size:1.8rem;font-weight:700}@media (max-width: 768px){.projects__grid{grid-template-columns:1fr}}.contact{background-color:var(--color-background)}.contact__content{max-width:700px;margin:0 auto;text-align:center}.contact__content p{font-size:clamp(1.2rem,3vw,1.5rem);line-height:1.5;margin-bottom:40px}.contact__email{font-family:var(--font-primary);font-size:clamp(1.5rem,6vw,3.5rem);font-weight:700;color:var(--color-text);text-decoration:none;position:relative;display:inline-block}.contact__email:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:3px;background-color:var(--color-accent-primary);transform:scaleX(0);transform-origin:right;transition:transform .5s cubic-bezier(.23,1,.32,1)}.contact__email:hover:after{transform:scaleX(1);transform-origin:left}.contact__cta{margin-top:60px;display:flex;justify-content:center;gap:20px}.btn-primary{background-color:var(--color-accent-primary);color:var(--color-background);border:none}.btn-primary:hover{background-color:var(--color-accent-primary);filter:brightness(1.1)}.btn-secondary{background-color:transparent;border:1px solid var(--color-accent-primary);color:var(--color-accent-primary)}@media (max-width: 768px){.contact__cta{flex-direction:column;align-items:center}}.project-detail{background-color:var(--color-background);min-height:calc(100vh - var(--header-height));padding-top:120px}.back-button{display:inline-block;margin-bottom:40px;color:var(--color-text-secondary);text-decoration:none;font-weight:500;transition:color .3s ease}.back-button:hover{color:var(--color-accent-primary)}.back-button .arrow{margin-right:8px}.project-title{font-family:var(--font-primary);font-size:clamp(2.5rem,8vw,5rem);font-weight:800;margin-bottom:10px;text-transform:uppercase;line-height:1}.project-category{display:inline-block;font-size:1rem;color:var(--color-text-secondary);text-transform:uppercase;margin-bottom:40px}.project-image{width:100%;margin-bottom:60px;overflow:hidden}.project-image img{width:100%;height:auto;object-fit:cover}.project-content{display:grid;grid-template-columns:2fr 1fr;gap:60px}.project-description h2,.project-info h3{font-family:var(--font-primary);margin-bottom:20px;color:var(--color-text)}.project-description p{font-size:1.1rem;line-height:1.6;color:var(--color-text)}.info-block{margin-bottom:30px}.info-block h3{font-size:1.2rem;color:var(--color-accent-primary);margin-bottom:10px}.info-block p,.info-block ul{color:var(--color-text)}.info-block ul{list-style:none;padding:0}.info-block li{margin-bottom:5px}.project-not-found{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.5rem;color:var(--color-text)}@media (max-width: 768px){.project-content{grid-template-columns:1fr}.project-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}}.not-found{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-background);padding:2rem;overflow:hidden;position:relative}.not-found__content{max-width:600px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2;position:relative}.not-found__number{display:flex;align-items:center;justify-content:center;font-size:clamp(6rem,15vw,12rem);font-weight:900;letter-spacing:-2px;color:var(--color-accent-primary, #7928ca);margin-bottom:2rem}.digit-circle{width:clamp(3.5rem,10vw,8rem);height:clamp(3.5rem,10vw,8rem);border:clamp(.4rem,1vw,.8rem) solid var(--color-accent-primary, #7928ca);border-radius:50%;margin:0 clamp(.5rem,1vw,1rem);animation:pulse 3s infinite alternate}.digit{animation:float 3s infinite alternate;animation-delay:calc(var(--i, 0) * .5s)}.digit:first-child{--i: 0}.digit:last-child{--i: 1}.not-found__title{font-size:clamp(2rem,5vw,3rem);font-weight:700;margin-bottom:1.5rem;color:var(--color-text)}.not-found__message{font-size:clamp(1rem,3vw,1.2rem);line-height:1.6;color:var(--color-text-secondary);margin-bottom:2.5rem}.not-found__button{display:inline-flex;align-items:center;background:var(--color-accent-primary, #7928ca);color:#fff;padding:clamp(.8rem,2vw,1rem) clamp(1.5rem,4vw,2rem);border-radius:50px;font-weight:600;text-decoration:none;transition:all .3s ease;box-shadow:0 4px 20px #0000001a;margin-top:1rem}.not-found__button:hover{transform:translateY(-3px);box-shadow:0 10px 25px #0003}.button-text{margin-right:.5rem}.button-icon{transition:transform .3s ease}.not-found__button:hover .button-icon{transform:translate(5px)}.not-found:before,.not-found:after{content:"";position:absolute;width:clamp(300px,50vw,600px);height:clamp(300px,50vw,600px);border-radius:50%;background:var(--color-accent-primary, #7928ca);opacity:.05;filter:blur(100px);z-index:0}.not-found:before{top:-10%;right:-10%}.not-found:after{bottom:-10%;left:-10%}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}to{transform:scale(1);opacity:1}}@keyframes float{0%{transform:translateY(0)}to{transform:translateY(-10px)}}@media (max-width: 768px){.not-found__content{padding:0 1rem}}.auth-section{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background, #f7f7f7)}.auth-container{background:var(--color-surface, #181A1B);padding:2.5rem 2rem;border-radius:16px;box-shadow:0 4px 24px #0000001a;max-width:400px;width:100%;text-align:center;color:var(--color-text, #fff);margin-top:5rem}.auth-container h2{font-family:var(--font-primary, "Syne", sans-serif);font-weight:800;font-size:2rem;margin-bottom:1.2rem;color:var(--color-primary, #91d400);letter-spacing:1px}.auth-form{display:flex;flex-direction:column;gap:1.2rem;margin-top:1.5rem}.auth-form label{display:flex;flex-direction:column;align-items:flex-start;font-weight:600;color:var(--color-text, #fff);gap:.4rem;font-family:var(--font-primary, "Syne", sans-serif)}.auth-form input{width:100%;padding:.7rem 1rem;border:1.5px solid var(--color-border, #222);border-radius:8px;font-size:1rem;background:var(--color-background, #23272A);color:var(--color-text, #fff);transition:border .2s,background .2s}.auth-form input:focus{border-color:var(--color-primary, #0078d4);background:var(--color-surface, #181A1B);outline:none}.auth-form .btn.interactive{width:100%;padding:.8rem 0;background:var(--color-primary, #91d400);color:#000;border:none;border-radius:8px;font-weight:700;font-size:1.1rem;font-family:var(--font-primary, "Syne", sans-serif);cursor:pointer;transition:background .2s;box-shadow:0 2px 8px #0078d414}.auth-form .btn.interactive:hover{background:var(--color-primary-dark, #005fa3)}.auth-switch{margin-top:1.5rem;font-size:1rem;color:var(--color-text-secondary, #b0b0b0)}.auth-switch a{color:var(--color-primary, #91d400);text-decoration:underline;font-weight:600;font-family:var(--font-primary, "Syne", sans-serif)}.btn-bc-id{margin-top:1.2rem;width:100%;display:flex;align-items:center;justify-content:center;gap:.7rem;padding:.8rem 0;background:#fff;color:#181a1b;border:2px solid #91d400;border-radius:8px;font-weight:700;font-size:1.1rem;font-family:var(--font-primary, "Syne", sans-serif);cursor:pointer;transition:background .2s,color .2s,border .2s}.btn-bc-id:hover{background:#91d400;color:#181a1b;border-color:#91d400}.bc-id-box{display:inline-block;font-weight:800;border-radius:6px;padding:.7em;font-size:1.1em;margin-right:.5em;letter-spacing:1px;background:#0c1f2c}.bc-id-box span{background:linear-gradient(90deg,#F25022 0%,#7FBA00 33%,#00A4EF 66%,#FFB900 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.3em;line-height:1;display:inline-block}:root{--primary: #00A4EF;--secondary: #91d400;--danger: #e57373;--background: #181A1B;--surface: #23272A;--text-main: #fff;--text-secondary: #bfc9d1;--radius: 14px;--shadow: 0 4px 24px rgba(0,0,0,.1);--font-primary: "Syne", "Segoe UI", Arial, sans-serif}body{background:var(--background);color:var(--text-main);font-family:var(--font-primary);margin:0;padding:0}.dashboard-container{min-height:100vh;background:var(--background);padding:0;position:relative;z-index:1;margin-top:100px}.noise-overlay{position:absolute;inset:0;pointer-events:none;z-index:0;background:url(/images/noise.png),radial-gradient(circle at top right,rgba(0,120,212,.08),transparent 60%);opacity:.1}.dashboard-content{width:100%;margin:0;padding:2rem 4vw;box-sizing:border-box}.dashboard-grid{display:flex;gap:2rem;align-items:flex-start}.dashboard-sidebar{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);min-width:220px;max-width:260px;padding:2rem 1rem 1rem;display:flex;flex-direction:column;gap:2rem;position:sticky;top:1rem;height:fit-content}.dashboard-nav ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.dashboard-nav li{width:100%}.dashboard-nav a,.dashboard-nav button.logout-link{display:block;width:100%;background:none;border:none;color:var(--text-secondary);font-family:var(--font-primary);font-size:1rem;text-align:left;padding:.7em 1em;border-radius:8px;cursor:pointer;transition:background .18s,color .18s;text-decoration:none}.dashboard-nav a:hover,.dashboard-nav a:focus,.dashboard-nav li.active a{background:linear-gradient(90deg,var(--secondary) 0%,var(--primary) 100%);color:var(--background)}.dashboard-nav .logout-link{color:var(--danger)!important;font-weight:700}.dashboard-nav .logout-link:hover{background:rgba(198,40,40,.12)!important;color:#fff!important}.dashboard-nav .nav-divider{height:1px;margin:1rem 0;background:linear-gradient(90deg,transparent,rgba(0,120,212,.2),transparent)}.dashboard-header{background:var(--surface);border-radius:var(--radius);margin-bottom:2rem;padding:2rem 1.5rem;position:relative;overflow:hidden;z-index:1;box-shadow:var(--shadow)}.dashboard-header:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at top right,rgba(0,120,212,.18),transparent 60%);pointer-events:none}.dashboard-welcome{display:flex;align-items:center;gap:1.5rem}.user-avatar{width:90px;height:90px;border-radius:50%;overflow:hidden;background:var(--background);border:3px solid var(--primary);box-shadow:0 0 16px #0078d42e;position:relative}.user-avatar img{width:100%;height:100%;object-fit:cover}.avatar-edit-overlay{position:absolute;bottom:0;left:0;width:100%;height:35%;background:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:center;opacity:0;transition:opacity .3s;cursor:pointer;color:#fff;font-size:1.2rem}.user-avatar:hover .avatar-edit-overlay{opacity:1}.user-info h1{font-family:var(--font-primary);font-size:2rem;margin-bottom:.5rem;color:var(--text-main)}.badge{display:inline-block;padding:.4em 1em;border-radius:20px;font-size:.95em;font-weight:600}.badge.verified{background:rgba(46,125,50,.18);color:var(--secondary)}.badge.unverified,.badge-danger{background:rgba(198,40,40,.18);color:var(--danger)}.dashboard-main{flex:1;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem 1.5rem;min-width:0;min-height:500px;position:relative;z-index:1}.dashboard-section{display:none}.dashboard-section.active{display:block;animation:fadeIn .3s;max-width:100%;overflow-x:auto;box-sizing:border-box;word-break:break-word}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.dashboard-section-header{margin-bottom:2rem}.dashboard-section-header h2{font-family:var(--font-primary);font-size:1.5rem;color:var(--secondary);margin-bottom:.5rem}.dashboard-section-header p{color:var(--text-secondary);font-size:1rem}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.2rem;margin-bottom:2rem}.stat-card{background:linear-gradient(135deg,rgba(20,44,64,.8),rgba(12,31,44,.9));border-radius:10px;padding:1.2rem;display:flex;flex-direction:column;gap:.7rem;box-shadow:0 2px 10px #00000014;border:1px solid rgba(0,120,212,.1);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 25px #0000001f,0 0 15px #0078d414}.stat-icon{width:38px;height:38px;border-radius:10px;background:rgba(0,120,212,.12);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--primary)}.stat-info{flex:1}.stat-info h3{font-size:1rem;color:var(--text-secondary);margin-bottom:.3rem}.stat-value{font-family:var(--font-primary);font-size:1.2rem;color:var(--text-main);font-weight:600}.progress-bar{height:6px;background:rgba(255,255,255,.08);border-radius:3px;margin-bottom:.5rem;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:3px}.activity-timeline{position:relative;padding-left:24px}.activity-timeline:before{content:"";position:absolute;left:7px;top:10px;height:calc(100% - 20px);width:2px;background:rgba(0,120,212,.12)}.timeline-item{position:relative;padding-bottom:1.2rem}.timeline-icon{position:absolute;left:-24px;width:18px;height:18px;border-radius:50%;background:var(--surface);border:2px solid var(--primary);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--primary)}.timeline-content h4{font-size:1rem;color:var(--text-main);margin-bottom:.18rem}.timeline-content p{font-size:.9rem;color:var(--text-secondary);margin-bottom:.18rem}.timeline-time{font-size:.8rem;color:#ffffff80}.dashboard-panel{background:rgba(20,44,64,.6);border-radius:8px;border:1px solid rgba(0,120,212,.1);padding:1.2rem;margin-bottom:2rem}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.2rem;padding-bottom:.5rem;border-bottom:1px solid rgba(0,120,212,.1)}.panel-header h3{font-family:var(--font-primary);font-size:1.1rem;color:var(--text-main);margin:0}.panel-link{color:var(--primary);font-size:.9rem;text-decoration:none}.panel-link:hover{text-decoration:underline}.profile-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:flex;gap:1rem}.form-field-mockup{flex:1;display:flex;flex-direction:column}.form-label{color:var(--secondary);font-weight:700;margin-bottom:.3em}.profile-form input,.profile-form select{width:100%;padding:.5em;border-radius:6px;border:1.5px solid var(--secondary);background:var(--surface);color:var(--text-main);font-family:var(--font-primary);margin-bottom:.2em}.profile-form input:focus,.profile-form select:focus{border-color:var(--primary);outline:none}.form-actions{display:flex;gap:1rem;margin-top:.5rem}.form-button-mockup{background:linear-gradient(90deg,var(--secondary) 0%,var(--primary) 100%);color:var(--background);border-radius:8px;font-weight:700;padding:.5em 1.2em;border:none;transition:background .18s,color .18s;cursor:pointer}.form-button-mockup.secondary{background:rgba(255,255,255,.08);color:var(--text-main);border:1px solid var(--primary)}.form-button-mockup:hover,.form-button-mockup:focus{background:linear-gradient(90deg,#7FBA00 0%,#0078d4 100%);color:#fff}.edit-profile-btn{background:linear-gradient(90deg,var(--secondary) 0%,var(--primary) 100%);color:var(--background);border:none;border-radius:8px;font-weight:700;padding:.4em 1.1em;font-size:1rem;cursor:pointer;transition:background .18s,color .18s;margin-left:1rem}.edit-profile-btn:hover,.edit-profile-btn:focus{background:linear-gradient(90deg,#7FBA00 0%,#0078d4 100%);color:#fff;outline:none}.connections-list{display:flex;flex-direction:column;gap:1rem}.connection-item{display:flex;align-items:center;gap:1.2rem;padding:1rem;border-radius:8px;background:rgba(20,44,64,.3);border:1px solid rgba(0,120,212,.08)}.connection-logo{width:40px;height:40px;border-radius:8px;background:rgba(0,120,212,.1);display:flex;align-items:center;justify-content:center;font-size:1.2rem}.connection-info{flex:1}.connection-info h4{font-size:1.05rem;color:var(--text-main);margin-bottom:.18rem}.connection-info p{font-size:.9rem;color:var(--text-secondary);margin-bottom:.18rem}.connection-email{font-size:.8rem;color:var(--primary)}.apps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.2rem}.app-card{background:rgba(20,44,64,.3);border-radius:10px;border:1px solid rgba(0,120,212,.1);padding:1.2rem;display:flex;flex-direction:column;align-items:center;text-align:center;transition:transform .2s,box-shadow .2s}.app-card:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 25px #0000001f,0 0 15px #0078d41a;border-color:var(--primary)}.app-icon{width:48px;height:48px;border-radius:12px;background:rgba(0,120,212,.1);display:flex;align-items:center;justify-content:center;margin-bottom:1rem;font-size:1.5rem;color:var(--primary)}.app-info{margin-bottom:1rem}.app-info h3{font-family:var(--font-primary);font-size:1.1rem;color:var(--text-main);margin-bottom:.3rem}.app-info p{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.app-status{display:inline-block;padding:.18rem .7rem;border-radius:12px;font-size:.8rem}.app-status.connected{background:rgba(46,125,50,.18);color:var(--secondary)}.app-status.not-connected{background:rgba(198,40,40,.18);color:var(--danger)}.app-action{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1.2rem;border-radius:20px;background:var(--primary);color:#fff;font-weight:500;text-decoration:none;transition:all .18s;border:none;cursor:pointer}.app-action:hover{background:#1a8fff;box-shadow:0 5px 15px #0078d42e;transform:translateY(-2px)}.app-action.connect{background:rgba(255,255,255,.08);color:var(--text-main);border:1px solid var(--primary)}.app-action.connect:hover{background:rgba(255,255,255,.18)}@media (max-width: 1100px){.dashboard-content{padding:1.2rem .5rem}.dashboard-grid{flex-direction:column;gap:1.2rem}.dashboard-sidebar{max-width:100%;min-width:0;width:100%;flex-direction:row;gap:1rem;padding:1rem;position:static;height:auto}.dashboard-nav ul{flex-direction:row;gap:.5rem;justify-content:center}.dashboard-nav li{width:auto}.dashboard-main{width:100%;max-width:100%;min-width:0;flex:1 1 100%;box-sizing:border-box}}@media (max-width: 932px){.dashboard-header,.dashboard-main{padding:1rem .5rem}.dashboard-welcome{flex-direction:column;text-align:center;gap:1rem}.user-info h1{font-size:1.2rem}.stats-cards{grid-template-columns:1fr;gap:.7rem}.form-row{flex-direction:column;gap:.7rem}.apps-grid{grid-template-columns:1fr;gap:.7rem}.app-icon{width:38px;height:38px}.dashboard-sidebar{flex-direction:column;align-items:stretch;padding:.5rem;gap:.5rem}.dashboard-nav ul{flex-direction:column;gap:.3rem}}@media (max-width: 480px){.dashboard-header,.dashboard-main,.dashboard-content{padding:.5rem .2rem}.dashboard-section-header h2{font-size:1.1rem}.panel-header h3{font-size:1rem}}:root{--color-bg: #121821;--color-surface: #1a222e;--color-text: #e2e8f0;--color-text-secondary: #94a3b8;--color-primary: #38bdf8;--color-primary-dark: #0ea5e9;--color-accent: #60a5fa;--color-border: #334155;--color-alert-warning: #facc15;--color-alert-info: #60a5fa;--color-alert-danger: #f87171;--color-skipped: #f87171;--color-countdown: #fb923c;--font-primary: "Syne", sans-serif}body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-primary)}.traintrip-section{max-width:100vw;width:100%;padding:2.5vw 0;margin:80px auto 0;display:flex;justify-content:center;align-items:flex-start;min-height:100vh;box-sizing:border-box}.traintrip-container{width:100%;max-width:900px;min-width:320px;margin:0 2vw;border-radius:18px;box-shadow:0 6px 32px #00000021;padding:2.5rem;background:var(--color-surface);transition:max-width .3s,padding .3s}.traintrip-container h2{color:var(--color-primary);font-family:var(--font-primary);font-weight:800;font-size:2rem;margin-bottom:1.5rem;letter-spacing:1px}.traintrip-form{background:#202a1f;border-radius:10px;padding:2rem;margin-bottom:2rem;border:1px solid #2d5016}.form-row{margin-bottom:1.5rem}.form-row label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--color-primary);font-family:var(--font-primary)}.form-input,.form-select{background:#23272A;color:var(--color-text);border:2px solid var(--color-primary);font-family:var(--font-primary);width:100%;padding:.75rem;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-input:focus,.form-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 2px #3498db44;outline:none}.station-inputs{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:end}.station-input-group,.input-with-suggestions{position:relative}.swap-button{background:var(--color-primary);color:#23272a;border:none;border-radius:50%;width:40px;height:40px;font-size:1.2rem;cursor:pointer;transition:background .3s;margin-bottom:.5rem}.swap-button:hover{background:var(--color-primary-dark);color:#fff;transform:rotate(180deg)}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background:#23272A;color:var(--color-text);border:1px solid var(--color-primary);border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:200px;overflow-y:auto}.suggestion-item{padding:.75rem;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.suggestion-item:hover,.suggestion-item:focus{background:#91d400;color:#23272a}.suggestion-item:last-child{border-bottom:none}.btn{padding:.75rem 2rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.btn-primary{background:linear-gradient(135deg,#91d400,#3498db);color:#23272a;font-weight:700;border:none}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#5a8c00,#1a5490);color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #3498db4d}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.loading{position:relative}.btn.loading:after{content:"";position:absolute;width:16px;height:16px;margin:auto;border:2px solid transparent;border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;top:0;left:0;bottom:0;right:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.traintrip-error{background:#2d5016;color:#ffb900;border:1px solid #ffb900;padding:1rem;border-radius:6px;margin-bottom:1rem}.search-summary{background:#23272A;border:1px solid var(--color-primary);color:var(--color-primary);padding:1rem;border-radius:6px;margin-bottom:2rem}.search-summary h3,.search-summary p{color:var(--color-primary);margin:0}.traintrip-results{margin-top:2rem}.results-grid{display:grid;gap:1.5rem}.train-card{background:#202a1f;border:1px solid #91d400;color:var(--color-text);padding:1.5rem;transition:all .3s ease;border-radius:8px;box-shadow:0 2px 4px #0000000d}.train-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-2px)}.train-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #91d400}.train-info{display:flex;flex-direction:column;gap:.25rem}.train-category{font-weight:600;color:var(--color-primary);font-size:1.1rem}.train-name{font-size:.9rem;color:#7f8c8d}.train-duration{background:var(--color-accent);color:#fff;padding:.5rem 1rem;font-size:.9rem;border-radius:6px;margin-top:4px;margin-bottom:4px;font-weight:500;display:inline-block}.train-duration.delay-low{background:#d4edda;color:#155724}.train-duration.delay-medium{background:#fff3cd;color:#856404}.train-duration.delay-high{background:#f8d7da;color:#721c24}.train-duration.delay-none{background:#e2e3e5;color:#383d41}.train-duration.delay-cancelled{background:#c82333;color:#fff;font-weight:700;letter-spacing:1px}.journey-details{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center;margin-bottom:1rem}.journey-point{text-align:center}.journey-point:first-child{text-align:left}.journey-point:last-child{text-align:right}.journey-point .time{font-size:1.25rem;font-weight:600;color:#186bbe;margin-bottom:.25rem}.journey-point .station{font-size:.9rem;color:#7f8c8d;line-height:1.2;font-family:Syne,sans-serif}.journey-arrow{font-size:1.5rem;color:#3498db;text-align:center}.changes-info{background:#23272A;color:#ffb900;border:1px solid #ffb900;padding:.5rem;border-radius:4px;font-size:.9rem;margin-bottom:.5rem;text-align:center}.price-info{background:#23272A;color:#91d400;border:1px solid #91d400;padding:.5rem;border-radius:4px;font-size:.9rem;font-weight:500;margin-bottom:.5rem;text-align:center}.train-status{display:flex;justify-content:flex-end}.status{padding:.25rem .75rem;border-radius:12px;font-size:.8rem;font-weight:500;text-transform:capitalize;background:#23272A;color:var(--color-primary);border:1px solid #91d400}.status.scheduled{background:#e8f5e8;color:#2d5016}.status.delayed{background:#fff3cd;color:#856404}.status.cancelled{background:#f8d7da;color:#721c24}.search-mode-switch{display:flex;gap:12px;margin-bottom:24px;overflow-x:auto;padding-bottom:6px;scrollbar-width:thin;scrollbar-color:var(--color-primary) #23272A}.search-mode-switch button{border:none;background:#414344;color:#fff;padding:10px 28px;border-radius:999px;font-size:1em;font-weight:500;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap;outline:none;border:2px solid transparent}.search-mode-switch button.active,.search-mode-switch button:focus{background:var(--color-primary);color:#000;border:2px solid rgb(73,70,70);font-weight:600}.search-mode-switch button:hover:not(.active){background:#2c3e50;color:#fff}@media (max-width: 600px){.search-mode-switch{gap:8px;padding-bottom:10px;margin-bottom:18px}.search-mode-switch button{font-size:.98em;padding:10px 18px}}@media (max-width: 768px){.traintrip-container,.traintrip-form{padding:1rem}.station-inputs{grid-template-columns:1fr;gap:1rem}.swap-button{transform:rotate(90deg);justify-self:center}.swap-button:hover{transform:rotate(270deg)}.journey-details{grid-template-columns:1fr;gap:.5rem;text-align:center}.journey-point:first-child,.journey-point:last-child{text-align:center}.journey-arrow{transform:rotate(90deg)}.train-header{flex-direction:column;align-items:flex-start;gap:1rem}.train-duration{align-self:flex-end}.train-card{background:var(--color-surface);color:var(--color-text);border-left:4px solid var(--color-accent-secondary);border-top:1px solid var(--color-border);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.train-category{color:var(--color-accent-primary)}.train-duration{background:var(--color-accent-secondary);color:var(--color-background)}.status{background:var(--color-surface);color:var(--color-accent-secondary);border:1px solid var(--color-accent-secondary)}.train-header{border-bottom:1px solid var(--color-accent-secondary)}.journey-arrow{color:var(--color-accent-primary)}}@media (max-width: 600px){.traintrip-section{margin-top:0;padding:0}.traintrip-container{border-radius:10px;margin:0;min-width:0}}@media (min-width: 1200px){.traintrip-container{max-width:1100px;padding:3rem 4rem}}@media (max-width: 900px){.traintrip-container{max-width:98vw;padding:1.2rem .5rem;margin-top:80px}}@media (max-width: 480px){.traintrip-container h2{font-size:1.5rem}.train-card{padding:1rem}.journey-point .time{font-size:1.1rem}.suggestions-dropdown{max-height:150px}}.traintrip-form.loading{opacity:.7;pointer-events:none}.train-card{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-input:focus,.form-select:focus,.btn:focus,.suggestion-item:focus{outline:2px solid #3498db;outline-offset:2px}@media (prefers-contrast: high){.train-card{border:2px solid #000}.train-duration,.btn-primary{background:#000;color:#fff}}@media (prefers-reduced-motion: reduce){.train-card,.btn,.swap-button,.form-input,.form-select{transition:none}.btn.loading:after{animation:none}.train-card{animation:none}}.station-alert{background:#fff3cd;color:#856404;border:1px solid #ffeeba;border-radius:6px;padding:8px 16px;margin-bottom:16px;margin-top:4px;font-weight:500}.featured-trains-header{margin-top:24px;margin-bottom:16px;border-left:4px solid #1976d2;padding-left:12px}.featured-trains-header h3{margin-bottom:8px;color:#1976d2}.spinner{width:32px;height:32px;border:4px solid #e3e3e3;border-top:4px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite;margin:30px auto auto}.train-options-container{margin-top:20px}.train-options-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;margin-top:15px}.train-option-card{background:#202a1f;border:1px solid #91d400;color:var(--color-text);padding:1.5rem;transition:all .3s ease;border-radius:8px;box-shadow:0 2px 4px #0000000d}.train-option-card:hover{box-shadow:0 8px 16px #0000001a;transform:translateY(-2px);background-color:#23272a;border-color:#1976d2}.train-option-header{font-size:1.1em;margin-bottom:8px;color:var(--color-primary)}.train-option-details{font-size:.9em;color:#7f8c8d}.clear-input-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:18px;color:#888;padding:0;z-index:2}.input-with-suggestions{position:relative}@media (max-width: 768px){body{background-color:var(--color-bg);overscroll-behavior:none}.traintrip-section{padding:0;margin-top:0;min-height:100vh;background:var(--color-bg);display:block}.traintrip-container{padding:65px 1rem 80px;margin:0;max-width:100%;min-width:100%;width:100%;height:100%;border-radius:0;box-shadow:none;background:transparent}.traintrip-container h2{position:fixed;top:0;left:0;right:0;background:var(--color-surface);color:var(--color-text);font-size:1.2rem;padding:1rem;margin:0;z-index:100;text-align:center;border-bottom:1px solid var(--color-border, #333);box-shadow:0 2px 10px #0003}.search-mode-switch{position:fixed;top:42px;left:0;right:0;background:var(--color-surface);padding:.5rem 1rem;z-index:99;border-bottom:1px solid var(--color-border, #333);margin-bottom:0}.traintrip-form{padding:1rem 0;margin-top:50px;background:transparent;border:none}.station-inputs{grid-template-columns:1fr;gap:1rem}.swap-button{display:none}.traintrip-form .btn-primary{position:fixed;bottom:20px;right:20px;width:auto;padding:1rem 1.5rem;border-radius:50px;font-size:1rem;z-index:101;box-shadow:0 4px 12px #0000004d}.traintrip-form .btn-primary:hover:not(:disabled){transform:none}.traintrip-results{margin-top:1rem}.train-card{padding:1rem;border-left:4px solid var(--color-primary);border-top:1px solid var(--color-border, #333);border-right:1px solid var(--color-border, #333);border-bottom:1px solid var(--color-border, #333);background:var(--color-surface)}.train-header{flex-direction:row;align-items:center;gap:1rem}.train-duration{font-size:.8rem;padding:.4rem .8rem;margin-left:auto}.journey-details{grid-template-columns:1fr;gap:.5rem;text-align:left;margin-top:1rem;border-top:1px solid var(--color-border, #333);padding-top:1rem}.journey-point:first-child,.journey-point:last-child{text-align:left}.journey-arrow{display:none}.journey-point .time{font-size:1rem;color:var(--color-text)}.journey-point .station{font-size:1.1rem;font-weight:700;color:var(--color-primary)}.train-popup{width:100%;max-width:100%;height:90vh;max-height:90vh;position:fixed;bottom:0;left:0;border-radius:16px 16px 0 0;transform:translateY(0);animation:fadeIn .25s ease-out}.train-popup-overlay{animation:overlayFadeIn .2s ease-out}.train-popup-overlay.closing .train-popup{animation:fadeOut .2s ease-in}.train-popup-overlay.closing{animation:overlayFadeOut .25s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes overlayFadeIn{0%{background:rgba(0,0,0,0)}to{background:rgba(0,0,0,.6)}}@keyframes overlayFadeOut{0%{background:rgba(0,0,0,.6)}to{background:rgba(0,0,0,0)}}}@media (max-width: 480px){.traintrip-container{padding:65px .5rem 80px}.traintrip-container h2{font-size:1.1rem}.search-mode-switch button{padding:8px 14px;font-size:.9em}}.search-btn-icon{display:none;vertical-align:middle}.search-btn-text{display:inline;color:#000}.search-btn:hover{font-weight:600}@media (max-width: 768px){.search-btn-text{display:none}.search-btn-icon{display:inline-block}.search-btn{padding:.9em 1.1em!important;border-radius:50%;min-width:0;width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:1.3rem}}.desktop-only{display:block}@media (max-width: 768px){.desktop-only{display:none!important}}.mobile-fromto{display:none;font-size:.98em;margin-bottom:6px;color:var(--color-text-secondary)}@media (max-width: 768px){.mobile-fromto{display:flex;flex-direction:row;gap:10px}}.mobile-fromto strong{color:var(--color-text-secondary);font-weight:700}.mobile-fromto .station-name{color:var(--color-primary);font-weight:700}.fromto-label{display:none;color:var(--color-text-secondary);font-weight:700;margin-right:4px}@media (max-width: 768px){.fromto-label{display:inline}}@media (max-width: 768px){.stations-label{font-weight:700;display:inline-block;margin-right:4px}.journey-point .station{display:flex;flex-direction:row;align-items:center;flex-wrap:wrap}}@media (min-width: 769px){body{background:var(--color-background);color:var(--color-text)}.traintrip-section{background:var(--color-background)}.traintrip-container{background:var(--color-surface);color:var(--color-text);box-shadow:0 6px 32px #00000021;border-radius:18px}.traintrip-container h2{color:var(--color-text-secondary)}.traintrip-form{background:var(--color-surface);border:1px solid var(--color-border)}.form-input,.form-select{background:var(--color-surface);color:var(--color-text);border:2px solid var(--color-accent-secondary)}.form-input:focus,.form-select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px var(--color-accent-primary)}.suggestions-dropdown{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-accent-secondary)}.suggestion-item:hover,.suggestion-item:focus{background:var(--color-accent-secondary);color:var(--color-background)}.btn-primary{background:linear-gradient(135deg,var(--color-accent-secondary),var(--color-accent-primary));color:var(--color-background)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-accent-secondary),var(--color-accent-primary));color:var(--color-text)}.train-card{background:var(--color-surface);border:1px solid var(--color-accent-secondary);color:var(--color-text)}.train-header{border-bottom:1px solid var(--color-accent-secondary)}.train-category{color:var(--color-text-secondary)}.train-duration{background:var(--color-accent-secondary);color:var(--color-background)}.train-duration.delay-low{background:var(--color-alert-warning);color:var(--color-background)}.train-duration.delay-medium{background:var(--color-alert-info);color:var(--color-background)}.train-duration.delay-high{background:var(--color-alert-danger);color:var(--color-background)}.train-duration.delay-cancelled{background:var(--color-skipped);color:var(--color-background)}.changes-info{background:var(--color-alert-warning);color:var(--color-background);border:1px solid var(--color-alert-warning)}.price-info{background:var(--color-surface);color:var(--color-accent-secondary);border:1px solid var(--color-accent-secondary)}.train-status .status{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-accent-secondary)}.status.scheduled{background:var(--color-alert-warning);color:var(--color-background)}.status.delayed{background:var(--color-alert-danger);color:var(--color-background)}.status.cancelled{background:var(--color-skipped);color:var(--color-background)}}.train-popup-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center}.train-popup{background:var(--color-surface);color:var(--color-text);padding:24px;border-radius:12px;width:90vw;max-width:480px;max-height:85vh;overflow-y:hidden;display:flex;flex-direction:column;position:relative;box-shadow:0 10px 30px #0003}.close-btn{position:absolute;top:12px;right:16px;background:none;border:none;font-size:2.2rem;color:#888;cursor:pointer;line-height:1;transition:color .2s}.close-btn:hover{color:#fff}.train-popup h3{text-align:center;color:var(--color-primary);margin-bottom:24px;padding-right:24px}.progress-line{background:#1976d2!important;z-index:2}.popup-train-line{margin-top:12px;max-height:100%;overflow-y:auto;padding:0 12px}.popup-stop-row-line{display:flex;position:relative;align-items:stretch;min-height:80px}.popup-stop-row-line:last-child{min-height:50px}.stop-dot-container{display:flex;flex-direction:column;align-items:center;width:28px}.stop-dot{width:18px;height:18px;border-radius:50%;background:#ccc;border:4px solid #888;margin-top:0;z-index:2;transition:border-color .3s ease}.past-stop .stop-dot{border-color:var(--color-primary)}.past-dot{background:#1976d2}.current-dot{background:#ff9800}.late-dot{background:#d32f2f}.progress-line{background:#1976d2}.current-stop{font-weight:700}.late-stop .stop-dot,.late-stop .current-dot{background:#d32f2f!important}.stop-line{width:4px;background:#888;flex-grow:1;z-index:1;transition:background-color .3s ease;margin-bottom:-9px}.past-stop .stop-line,.progress-line{background:#1976d2!important}.popup-stop-row-line:last-child .stop-line{display:none}.stop-info{margin-left:16px;flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;padding-bottom:12px}.stop-station{font-weight:700;font-size:1.1em;color:var(--color-text);margin-bottom:8px}.past-stop .stop-station{color:#aaa}.stop-times-container{font-size:.9em;display:flex;flex-direction:column;gap:6px}.time-row{display:flex;justify-content:space-between;align-items:center;width:100%}.time-group{display:flex;align-items:center;gap:8px}.time-group.actual{min-width:50px;justify-content:flex-end}.time-label{color:#ccc;width:65px;font-size:.95em}.time-value{font-weight:600}.scheduled-time{color:var(--color-text)}.actual-time{color:var(--color-accent);font-weight:700}.stop-platform{font-size:.9em;color:#ccc;margin-top:8px}.stop-time-label{margin-right:6px}.platform-row,.delay-row{display:flex;justify-content:space-between;align-items:center}.platform-row+.platform-row,.delay-row+.delay-row,.platform-row+.delay-row,.delay-row+.platform-row{margin-top:5px}.train-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9999;display:flex;align-items:center;justify-content:center;cursor:default}.train-popup{padding:20px;border-radius:8px;box-shadow:0 4px 12px #00000026;position:relative;max-width:800px;width:90%;max-height:90vh;overflow-y:auto;cursor:default}.train-popup .close-btn{position:absolute;top:10px;background:none;border:none;font-size:40px;cursor:pointer;color:#fff;display:block}.back-btn{display:none}@media (max-width: 768px){.train-popup-overlay{background:transparent;align-items:stretch;justify-content:stretch;animation:none;cursor:default}.train-popup{width:100vw;height:100vh;max-width:100vw;max-height:100vh;border-radius:0;box-shadow:none;padding-top:48px;cursor:default;border:none;animation:slideInFromRight .3s forwards;background:var(--color-surface)}.train-popup-overlay.slide-out .train-popup{animation:slideOutToRight .3s forwards}.train-popup-overlay.slide-out{opacity:0;pointer-events:none;transition:opacity .3s}.train-popup h3{margin-left:8%}.back-btn{position:fixed;top:10px;left:10px;width:48px;height:48px;background:transparent;border:none;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#1976d2;z-index:10000}.train-popup .close-btn{display:none}.next-stop-mobile{margin-top:4px;margin-bottom:0;padding:2px 6px;border:1px solid #3199ff;border-radius:5px;cursor:pointer;color:#1e8fff;font-weight:700;white-space:nowrap;flex-shrink:1;display:inline-block;font-size:12px;max-width:80vw;overflow:hidden;text-overflow:ellipsis;line-height:1.2}}@keyframes slideInFromRight{0%{transform:translate(100vw)}to{transform:translate(0)}}@keyframes slideOutToRight{0%{transform:translate(0)}to{transform:translate(100vw)}}.mini-spinner{width:16px;height:16px;border:2px solid #1976d2;border-top:2px solid #e3f2fd;border-radius:50%;animation:spin .7s linear infinite;display:inline-block;margin-right:4px;vertical-align:middle}.big-spinner{width:64px;height:64px;border:8px solid #e3e3e3;border-top:8px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite;margin:auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skipped-line{background:repeating-linear-gradient(135deg,#e53935,#e53935 8px,#fff 8px,#fff 12px)!important;opacity:.8}.done-line{background:#1976d2!important}.skipped-dot{border:2px solid #e53935!important;background:#fff!important}.unexpected-stop .stop-station{color:#ff9800;font-style:italic}.unexpected-dot{border:2px solid #ff9800!important;background:#fffbe6!important}.unknown-stop .stop-station{color:#bdbdbd}.unknown-dot{border:2px solid #bdbdbd!important;background:#f5f5f5!important}.cancelled-text{text-decoration:line-through;color:#e53935!important;opacity:1}.cancelled-line .popup-stop-row-line .stop-dot-container>div:not(.stop-dot){background:#e53935!important}.popup-train-line{scrollbar-width:thin;scrollbar-color:#1976d2 #f3f3f3}@media (prefers-color-scheme: dark){.popup-train-line{scrollbar-color:#1976d2 #222}}.popup-train-line::-webkit-scrollbar{width:8px;background:#f3f3f3}.popup-train-line::-webkit-scrollbar-thumb{background:#1976d2;border-radius:6px}@media (prefers-color-scheme: dark){.popup-train-line::-webkit-scrollbar{background:#222}.popup-train-line::-webkit-scrollbar-thumb{background:#1976d2}}@keyframes pulse-dot{0%{box-shadow:0 0 8px #ffc10788,0 0 #ffc10744}70%{box-shadow:0 0 16px #ffc107cc,0 0 0 10px #ffc10722}to{box-shadow:0 0 8px #ffc10788,0 0 #ffc10744}}.last-detection-dot{animation:pulse-dot 1.2s infinite}.last-detection-dot-with-bubble .last-detection-bubble.right{display:none}.last-detection-dot-with-bubble:hover .last-detection-bubble.right{display:block}:root{--color-background: #121821;--color-surface: #1a222e;--color-surface-light: #242f3d;--color-text-primary: #e2e8f0;--color-text-secondary: #94a3b8;--color-accent-primary: #38bdf8;--color-accent-secondary: #0ea5e9;--color-border: #334155;--color-success: #4ade80;--color-warning: #facc15;--color-danger: #f87171;--color-info: #60a5fa;--color-skipped: #f87171;--color-countdown: #fb923c;--font-primary: "Syne", sans-serif;--font-secondary: "Inter", sans-serif;--header-height: 80px;--container-width: 1400px;--container-padding: 5%;--z-back: -1;--z-normal: 1;--z-header: 100;--z-menu: 99;--z-cursor: 9999;--z-preloader: 1000}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{background-color:var(--color-background);color:var(--color-text);font-family:var(--font-secondary);font-weight:300;line-height:1.6;overscroll-behavior:none;overflow-x:hidden}html.lenis{height:auto}.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-stopped{overflow:hidden}.layout{display:flex;flex-direction:column;min-height:100vh}main{flex:1}.section-padding{padding:60px 0}h1,h2,h3,h4,h5,h6{font-family:var(--font-primary);font-weight:800;line-height:1.1}.section-title{font-size:clamp(2rem,8vw,7rem);margin-bottom:40px;line-height:.9;text-transform:uppercase}.line-wrapper{display:block;overflow:hidden}.line-wrapper>span{display:block}.btn{display:inline-block;padding:12px 28px;border:1px solid var(--color-accent-primary);border-radius:50px;color:var(--color-accent-primary);text-decoration:none;font-weight:500;position:relative;overflow:hidden;transition:color .4s cubic-bezier(.23,1,.32,1)}.btn:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-color:var(--color-accent-primary);transform:scaleY(0);transform-origin:bottom;transition:transform .4s cubic-bezier(.23,1,.32,1);z-index:-1}.btn:hover{color:var(--color-background)}.btn:hover:before{transform:scaleY(1);transform-origin:top}.anim-fade-in{opacity:0}.anim-text-reveal{clip-path:polygon(0 100%,100% 100%,100% 100%,0% 100%)}body{font-size:16px;line-height:1.6}.container{width:90%;margin:0 auto}img{max-width:100%;height:auto;display:block}.colonna{width:100%;margin-bottom:1rem}@media (min-width: 768px){body{font-size:18px}.container{width:85%}.griglia{display:flex;flex-wrap:wrap;gap:1rem}.colonna{flex:1 1 45%}.section-padding{padding:80px 0}.section-title{margin-bottom:60px}}@media (min-width: 1024px){.container{width:80%;max-width:1200px}.colonna{flex:1 1 30%}.section-padding{padding:120px 0}.section-title{margin-bottom:80px}}
