@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_Lt.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap}@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_LtIt.ttf") format("truetype");font-weight:300;font-style:italic;font-display:swap}@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_Rg.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_It.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap}@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_SBd.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap}@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_SBdIt.ttf") format("truetype");font-weight:600;font-style:italic;font-display:swap}@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_Bd.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:'SoleRepsol Text';src:url("../src/assets/fonts/Static Fonts/SoleRepsolText_BdIt.ttf") format("truetype");font-weight:700;font-style:italic;font-display:swap}@font-face{font-family:'SoleRepsol Display';src:url("../src/assets/fonts/Static Fonts/SoleRepsolDisplay_Rg.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:'SoleRepsol Display';src:url("../src/assets/fonts/Static Fonts/SoleRepsolDisplay_Md.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:'SoleRepsol Display';src:url("../src/assets/fonts/Static Fonts/SoleRepsolDisplay_Bd.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:'SoleRepsol Display';src:url("../src/assets/fonts/Static Fonts/SoleRepsolDisplay_XBd.ttf") format("truetype");font-weight:800;font-style:normal;font-display:swap}:root{--repsol-orange: #ff6b35;--repsol-blue: #003f7f;--repsol-dark-blue: #002a5c;--repsol-light-blue: #4a90e2;--repsol-gray: #6c757d;--repsol-light-gray: #f8f9fa;--repsol-white: #ffffff;--station-blue-ink: #001e37;--station-blue-deep: #00425c;--station-turquoise: #00bed4;--station-accent-orange: #ff8f25;--station-accent-gradient: linear-gradient(155deg, #001e37 8%, #00425c 95%);--station-card-shadow: 0 20px 44px rgba(0, 30, 55, 0.16);--station-card-shadow-soft: 0 12px 28px rgba(0, 30, 55, 0.12);--success-green: #28a745;--warning-yellow: #ffc107;--error-red: #dc3545;--info-cyan: #17a2b8;--gradient-primary: linear-gradient(135deg, var(--repsol-orange) 0%, var(--repsol-blue) 100%);--gradient-success: linear-gradient(135deg, var(--success-green) 0%, #20c997 100%);--gradient-warning: linear-gradient(135deg, var(--warning-yellow) 0%, #fd7e14 100%);--gradient-orange-red: linear-gradient(160deg, #ff8a3d 0%, #ff2745 100%);--font-family: 'SoleRepsol Text', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;--font-family-display: 'SoleRepsol Display', 'SoleRepsol Text', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;--font-size-xs: 0.75rem;--font-size-sm: 0.875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--spacing-xs: 0.25rem;--spacing-sm: 0.5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: 0.375rem;--radius-md: 0.5rem;--radius-lg: 0.75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);--transition-fast: 0.15s ease;--transition-base: 0.3s ease;--transition-slow: 0.5s ease;--z-loading: 9999;--z-modal: 1050;--z-header: 1030;--z-tooltip: 1020;--skin-peach: #fdebe5;--navy-deep: #001e37;--border-blue: #b6c5d9;--card-pad-x: 24px;--card-pad-top: 20px;--card-pad-bottom: 28px;--lock-size: 26px;--lock-gap: 8px}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;height:100%}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);border:0}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--repsol-dark-blue);background:var(--gradient-orange-red);height:100%;min-height:100vh;min-height:-webkit-fill-available;overflow-x:hidden;position:relative;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-display);font-weight:600;color:var(--station-blue-ink);letter-spacing:-0.01em}@supports (-webkit-touch-callout: none){body{min-height:-webkit-fill-available}}body::before{content:'';position:fixed;inset:0;background:radial-gradient(circle at 15% 40%, rgba(255,170,102,0.4) 0%, transparent 60%),radial-gradient(circle at 85% 70%, rgba(255,60,80,0.32) 0%, transparent 55%),radial-gradient(circle at 50% 85%, rgba(255,255,255,0.12) 0%, transparent 60%);pointer-events:none;z-index:-1}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--gradient-orange-red);display:flex;align-items:center;justify-content:center;z-index:var(--z-loading);transition:opacity var(--transition-slow),visibility var(--transition-slow)}.loading-screen.hidden{opacity:0;visibility:hidden}.loading-content{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:var(--spacing-2xl);text-align:center;color:var(--repsol-white)}.splash-title{font-size:clamp(1.15rem, 2.6vw, 1.8rem);font-weight:600;letter-spacing:0.015em;color:var(--repsol-white)}.welcome-screen{position:fixed;top:0;left:0;width:100%;height:100vh;height:100dvh;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;z-index:var(--z-loading);transition:opacity var(--transition-slow),visibility var(--transition-slow);overflow:hidden;padding:var(--spacing-md)}.welcome-screen.hidden{opacity:0;visibility:hidden}.welcome-content{text-align:center;color:var(--repsol-white);max-width:500px;width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;height:auto;max-height:90vh;max-height:90dvh;overflow-y:auto}.welcome-content .repsol-logo-large{margin-bottom:var(--spacing-lg)}.welcome-content .repsol-logo-large .logo-placeholder{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:#717B84;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin:0 auto;max-width:200px}.welcome-content .repsol-logo-large .logo-text{font-size:var(--font-size-2xl);font-weight:800;color:var(--repsol-orange);letter-spacing:2px}.welcome-animation{margin:var(--spacing-sm) auto;opacity:0;animation:fadeInUp 0.8s ease forwards 0.5s;display:none}.welcome-text h1{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-sm);opacity:0;animation:fadeInUp 0.8s ease forwards 0.7s}.welcome-text p{font-size:var(--font-size-base);margin-bottom:var(--spacing-xs);opacity:0.9;opacity:0;animation:fadeInUp 0.8s ease forwards 0.9s}.welcome-text .welcome-subtitle{font-size:var(--font-size-sm);font-weight:600;opacity:0.8;margin-bottom:var(--spacing-lg);opacity:0;animation:fadeInUp 0.8s ease forwards 1.1s}.welcome-actions{margin-top:var(--spacing-lg);opacity:0;animation:fadeInUp 0.8s ease forwards 1.3s}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;text-decoration:none;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md)}.btn-primary{background:var(--repsol-white);color:var(--repsol-blue)}.btn-primary:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:rgba(255,255,255,0.2);color:var(--repsol-white);border:2px solid rgba(255,255,255,0.3)}.btn-secondary:hover{background:rgba(255,255,255,0.3);border-color:rgba(255,255,255,0.5);transform:translateY(-2px)}.btn-large{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base);margin:var(--spacing-xs)}.team-setup{margin:var(--spacing-lg) 0;background:rgba(255,255,255,0.1);padding:var(--spacing-lg);border-radius:var(--radius-lg);backdrop-filter:blur(10px);width:100%;max-width:400px}.team-setup h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--repsol-white)}.input-group{margin-bottom:var(--spacing-md);text-align:left}.input-group label{display:block;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--repsol-white)}.input-group input,.input-group select{width:100%;padding:var(--spacing-sm);border:2px solid rgba(255,255,255,0.2);border-radius:var(--radius-sm);background:rgba(255,255,255,0.9);color:var(--repsol-dark-blue);font-family:var(--font-family);font-size:var(--font-size-sm);transition:all var(--transition-base)}.input-group input.error,.input-group select.error{border-color:var(--error-red);background:#ffe6e6;animation:shake 0.3s ease-in-out}.input-group input:focus,.input-group select:focus{outline:none;border-color:var(--repsol-white);background:var(--repsol-white);box-shadow:0 0 0 3px rgba(255,255,255,0.2)}.input-group input::placeholder{color:#6c757d}@media (max-width: 834px) and (min-height: 1000px), (min-width: 810px) and (max-width: 834px){.welcome-screen{padding:0.5rem;overflow:hidden;height:100dvh}.welcome-content{max-height:calc(100dvh - 1rem);padding:0;gap:0.25rem;overflow-y:auto;-webkit-overflow-scrolling:touch}.welcome-content .repsol-logo-large{margin-bottom:0.25rem;transform:scale(0.7)}.welcome-content .repsol-logo-large .logo-placeholder{padding:0.5rem 0.75rem;max-width:150px}.welcome-text h1{font-size:clamp(1rem, 2.5vw, 1.3rem);margin-bottom:0.25rem}.welcome-text p{font-size:clamp(0.75rem, 1.3vw, 0.85rem);margin-bottom:0.25rem}.welcome-text .welcome-subtitle{font-size:clamp(0.7rem, 1.2vw, 0.8rem);margin-bottom:0.5rem}.team-setup{margin:0.5rem 0;padding:0.5rem 0.75rem;max-width:90%}.team-setup h3{font-size:clamp(0.9rem, 1.8vw, 1.1rem);margin-bottom:0.5rem}.input-group{margin-bottom:0.5rem}.input-group label{font-size:clamp(0.75rem, 1.3vw, 0.85rem);margin-bottom:0.25rem}.input-group input,.input-group select{padding:0.4rem 0.6rem;font-size:clamp(0.8rem, 1.4vw, 0.9rem)}.welcome-actions{margin-top:0.5rem}.btn-large{padding:0.6rem 1.2rem;font-size:clamp(0.85rem, 1.5vw, 0.95rem);margin:0.25rem}.game-rules{padding:0.75rem;margin-bottom:0.5rem}.game-rules h3{font-size:clamp(0.9rem, 1.8vw, 1.1rem);margin-bottom:0.5rem}.game-rules li{padding:0.35rem 0;font-size:clamp(0.75rem, 1.3vw, 0.85rem)}}@media (max-height: 700px){.welcome-content{max-height:95vh;justify-content:flex-start;padding-top:var(--spacing-md)}.welcome-content .repsol-logo-large{margin-bottom:var(--spacing-sm)}.team-setup{margin:var(--spacing-sm) 0;padding:var(--spacing-md)}.welcome-actions{margin-top:var(--spacing-sm)}.welcome-text h1{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs)}.welcome-text p{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}}@media (max-width: 768px){.welcome-screen{padding:var(--spacing-sm)}.welcome-content{max-width:100%}.team-setup{max-width:100%}}.ranking-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--gradient-primary);display:flex;align-items:center;justify-content:center;z-index:var(--z-loading);transition:opacity var(--transition-slow),visibility var(--transition-slow);overflow-y:auto}.ranking-screen.hidden{opacity:0;visibility:hidden}.ranking-content{background:rgba(255,255,255,0.95);border-radius:var(--radius-xl);padding:var(--spacing-2xl);margin:var(--spacing-xl);max-width:800px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-xl);backdrop-filter:blur(10px)}.ranking-header{text-align:center;margin-bottom:var(--spacing-2xl);color:var(--repsol-dark-blue)}.ranking-header h1{font-size:var(--font-size-3xl);font-weight:700;margin-bottom:var(--spacing-sm);color:var(--repsol-orange)}.ranking-list{max-height:400px;overflow-y:auto;margin-bottom:var(--spacing-xl)}.ranking-item{display:flex;align-items:center;padding:var(--spacing-lg);margin-bottom:var(--spacing-md);background:var(--repsol-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.ranking-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.ranking-item.podium{background:linear-gradient(135deg, #fff9e6 0%, #fff3d3 100%);border:2px solid var(--repsol-orange)}.ranking-position{font-size:var(--font-size-2xl);font-weight:700;margin-right:var(--spacing-lg);min-width:60px;text-align:center}.ranking-team{flex:1}.team-name{font-size:var(--font-size-lg);font-weight:600;color:var(--repsol-dark-blue);margin-bottom:var(--spacing-xs)}.team-stats{display:flex;gap:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--repsol-gray)}.team-stats span{background:rgba(108,117,125,0.1);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm)}.ranking-score{font-size:var(--font-size-xl);font-weight:700;color:var(--repsol-orange)}.no-rankings{text-align:center;padding:var(--spacing-3xl);color:var(--repsol-gray)}.no-rankings p{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md)}.ranking-actions{display:flex;justify-content:center;gap:var(--spacing-lg);padding-top:var(--spacing-xl);border-top:1px solid #e9ecef}.game-rules{margin:var(--spacing-xl) 0;background:rgba(255,255,255,0.05);padding:var(--spacing-lg);border-radius:var(--radius-lg);backdrop-filter:blur(5px)}.game-rules h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--repsol-white);text-align:center}.rules-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:var(--spacing-md)}.rule-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:rgba(255,255,255,0.1);border-radius:var(--radius-md);color:var(--repsol-white);font-size:var(--font-size-sm)}.rule-icon{font-size:var(--font-size-lg);flex-shrink:0}.error-message{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.8);display:flex;align-items:center;justify-content:center;z-index:var(--z-loading)}.error-content{background:var(--repsol-white);padding:var(--spacing-2xl);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-xl);max-width:400px;margin:var(--spacing-xl)}.error-content h3{color:var(--error-red);margin-bottom:var(--spacing-lg)}.error-content p{margin-bottom:var(--spacing-xl)}.app-toast{position:fixed;top:clamp(1rem, 3vh, 2.5rem);left:50%;transform:translate(-50%, -20px);min-width:clamp(220px, 40vw, 420px);max-width:min(90vw, 480px);padding:clamp(0.75rem, 1.6vw, 1rem) clamp(1.1rem, 2vw, 1.6rem);border-radius:var(--radius-lg);background:linear-gradient(145deg, rgba(1,108,165,0.92) 0%, rgba(0,54,84,0.94) 100%);color:var(--repsol-white);box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;z-index:var(--z-modal);transition:opacity 0.3s ease, transform 0.3s ease;font-weight:600;letter-spacing:0.01em;text-align:center;line-height:1.4}.app-toast.is-visible{opacity:1;transform:translate(-50%, 0)}.app-toast--info{background:linear-gradient(145deg, rgba(0,118,186,0.95) 0%, rgba(0,59,94,0.95) 100%)}.app-container{min-height:100vh;min-height:100dvh;display:none;flex-direction:column;opacity:0;transition:opacity 0.5s ease-in;position:relative;--app-gutter: clamp(1.25rem, 3.5vw, 2.75rem);padding-inline:var(--app-gutter)}.app-container.active{display:flex;opacity:1}.app-header{position:sticky;top:0;z-index:var(--z-header);background:var(--repsol-white);box-shadow:0 6px 24px rgba(0,0,0,0.05);margin-inline:calc(var(--app-gutter) * -1)}.app-header__inner{max-width:1400px;margin:0 auto;padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg);flex-wrap:wrap}.app-header__brand{display:flex;align-items:center;gap:var(--spacing-lg)}.app-header__logo-group{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.app-header__logo{display:block;height:28px;width:auto}.app-header__logo--wordmark,.app-header__logo--iso{height:28px}.app-header__title{font-size:clamp(1.1rem, 2vw, 1.5rem);font-weight:600;color:var(--repsol-dark-blue);letter-spacing:0.5px;line-height:1.2}.app-header__actions{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;justify-content:flex-end}.app-header__team{display:inline-flex;align-items:center;justify-content:center;min-height:46px;min-width:220px;padding:0 var(--spacing-xl);border-radius:999px;border:2px solid rgba(32,161,214,0.45);background:rgba(186,229,255,0.28);color:var(--repsol-blue);font-weight:600;font-size:var(--font-size-sm);letter-spacing:0.04em;text-align:center;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header__icon-button{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;line-height:0;border:none;border-radius:16px;background:var(--repsol-dark-blue);cursor:pointer;box-shadow:0 10px 24px rgba(0,42,92,0.16);transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.app-header__icon-button:hover{transform:translateY(-2px);box-shadow:0 16px 28px rgba(0,42,92,0.22)}.app-header__icon-button:active{transform:translateY(0);box-shadow:0 8px 18px rgba(0,42,92,0.18)}.app-header__icon-button--ranking{background:var(--repsol-dark-blue)}.app-header__icon-button--ranking:hover{background:#001f4d}.app-header__icon-button--logout{background:#00bcd4;box-shadow:0 10px 24px rgba(0,188,212,0.25)}.app-header__icon-button--logout:hover{background:#00a6bd;box-shadow:0 16px 30px rgba(0,166,189,0.3)}.app-header__icon-button--logout:active{box-shadow:0 8px 18px rgba(0,166,189,0.24)}.app-header__icon{width:32px;height:32px;object-fit:contain;display:block;transition:filter var(--transition-fast)}.app-header__icon-button .app-header__icon{filter:brightness(0) invert(1)}.app-header__icon-button:hover .app-header__icon{filter:brightness(0) invert(1)}.timer{padding:var(--spacing-sm) var(--spacing-md);background:var(--gradient-primary);color:var(--repsol-white);border-radius:var(--radius-lg);font-weight:600;font-size:var(--font-size-lg)}.station-map{flex:1;display:flex;justify-content:center;align-items:center;background:transparent;width:100%;padding-block:clamp(1.5rem, 3vh, 2rem) !important;padding-inline:0;min-height:0;margin-block:auto}.station-map__inner{width:min(1240px, 100%);display:flex;flex-direction:column;gap:clamp(1.5rem, 2.25vw, 2.5rem);justify-content:center;align-items:center;height:100%;margin:0 auto}.station-grid{display:grid;gap:clamp(1.4rem, 2.2vw, 2.1rem);justify-content:center;align-content:center}.station-grid--top{grid-template-columns:repeat(4, minmax(220px, 1fr))}.station-grid--bottom{grid-template-columns:repeat(4, minmax(220px, 1fr));width:100%;margin:0 auto}.station-card{--station-number-size: clamp(2.6rem, 5.5vw, 3.6rem);position:relative;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:var(--card-pad-top) var(--card-pad-x) calc(var(--card-pad-bottom) + var(--lock-size) + var(--lock-gap));border:none;border-radius:26px;background:var(--repsol-white);color:var(--station-blue-ink);text-align:left;transition:transform var(--transition-base),box-shadow var(--transition-base),background var(--transition-base);cursor:pointer;aspect-ratio:6 / 5.3;box-shadow:none}.station-card:focus{outline:3px solid rgba(0,190,212,0.4);outline-offset:4px}.station-card:not([disabled]):hover{transform:translateY(-4px);box-shadow:var(--station-card-shadow)}.station-card[disabled]{cursor:not-allowed}.station-card__header{display:flex;align-items:center;justify-content:flex-start;width:100%;gap:12px;margin-bottom:6px}.station-card__number{font-size:var(--station-number-size);line-height:0.9;font-weight:700;letter-spacing:0.04em;color:currentColor;margin:0}.station-card__number--icon{display:inline-flex;align-items:center;justify-content:center;width:var(--station-number-size);height:var(--station-number-size);border-radius:50%;background:transparent}.station-card__number-icon{width:70%;height:70%;object-fit:contain;display:block}.station-card__icon{width:var(--station-number-size);height:var(--station-number-size);display:inline-flex;align-items:center;justify-content:center;color:currentColor;line-height:1;flex-shrink:0}.station-card__icon-img{width:100%;height:100%;object-fit:contain;display:block}.station-card__icon--double{width:auto;justify-content:flex-start}.station-card__icon--double .station-card__icon-img{width:var(--station-number-size);height:var(--station-number-size)}.station-card--available{background:var(--repsol-white);color:var(--station-blue-ink);box-shadow:var(--station-card-shadow-soft)}.station-card--available .station-card__subtitle{color:rgba(0,30,55,0.72)}.station-card--available .station-card__icon-img,.station-card--available .station-card__number-icon{filter:none}.station-card--available .station-card__lock{opacity:1}.station-card--available .station-card__lock img{filter:none}.station-card--active,.station-card--completed{background:linear-gradient(165deg, #001734 0%, #016ca5 100%);color:var(--repsol-white)}.station-card--active .station-card__subtitle,.station-card--completed .station-card__subtitle{color:rgba(255,255,255,0.88)}.station-card--active .station-card__icon-img,.station-card--completed .station-card__icon-img{filter:brightness(0) invert(1)}.station-card--active .station-card__number--icon,.station-card--completed .station-card__number--icon{background:transparent}.station-card--active .station-card__number-icon,.station-card--completed .station-card__number-icon{filter:brightness(0) invert(1)}.station-card--locked .station-card__number-icon{filter:none}.station-card--locked .station-card__number--icon{background:transparent}.station-card--active .station-card__lock,.station-card--completed .station-card__lock{opacity:0.92}.station-card--survival{align-items:flex-start}.station-card--survival .station-card__header{width:100%;justify-content:flex-start;margin-bottom:12px}.station-card--survival .station-card__number--icon{width:clamp(2.6rem, 5.5vw, 3.4rem);height:clamp(2.6rem, 5.5vw, 3.4rem)}.station-card--survival .station-card__number-icon{width:80%;height:80%}.station-card--survival .station-card__title{margin-top:0}.station-card__title{font-size:clamp(1.15rem, 2.2vw, 1.55rem);font-weight:700;color:inherit;margin:2px 0 2px;letter-spacing:0.02em;line-height:1.15}.station-card__subtitle{font-size:clamp(0.95rem, 1.8vw, 1.05rem);font-weight:400;line-height:1.35;color:rgba(0,30,55,0.72);margin:0 0 22px}.station-card__status{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);font-weight:600;letter-spacing:0.08em;text-transform:uppercase;color:currentColor}.station-card__lock{position:absolute;left:50%;bottom:var(--lock-gap);transform:translateX(-35%);width:var(--lock-size);height:var(--lock-size);display:grid;place-items:center;background:transparent;transition:transform var(--transition-base),opacity var(--transition-base)}.station-card__lock img{width:100%;height:100%;object-fit:contain;filter:brightness(0) invert(1)}.station-card--locked{background:var(--repsol-white);color:var(--station-blue-ink);box-shadow:var(--station-card-shadow-soft)}.station-card--locked .station-card__title,.station-card--locked .station-card__subtitle{display:none}.station-card--locked .station-card__lock{top:50%;left:50%;bottom:auto;transform:translate(-50%, -50%);width:clamp(2.1rem, 4.5vw, 3rem);height:clamp(2.1rem, 4.5vw, 3rem)}.station-card--locked .station-card__lock img{filter:none}@media (max-width: 1180px){.station-grid--top{grid-template-columns:repeat(4, minmax(200px, 1fr))}.station-grid--bottom{grid-template-columns:repeat(4, minmax(200px, 1fr))}}@media (max-width: 1024px){.station-grid--top{grid-template-columns:repeat(4, minmax(180px, 1fr));gap:clamp(1.15rem, 1.8vw, 1.6rem)}.station-grid--bottom{grid-template-columns:repeat(4, minmax(180px, 1fr));gap:clamp(1.15rem, 1.8vw, 1.6rem);width:100%}}@media (max-width: 900px){.station-grid--top{grid-template-columns:repeat(3, minmax(200px, 1fr))}.station-grid--bottom{grid-template-columns:repeat(3, minmax(200px, 1fr))}}@media (max-width: 834px) and (min-height: 1000px), (min-width: 810px) and (max-width: 834px){.app-header{box-shadow:0 2px 8px rgba(0,0,0,0.05)}.app-header__inner{padding:0.5rem 0.75rem;gap:0.5rem}.app-header__logo{height:20px}.app-header__logo--wordmark,.app-header__logo--iso{height:20px}.app-header__title{font-size:clamp(0.85rem, 1.5vw, 1rem)}.app-header__team{min-height:36px;min-width:160px;padding:0 0.75rem;font-size:clamp(0.75rem, 1.3vw, 0.85rem)}.app-header__icon-button{width:38px;height:38px}.app-header__icon{width:24px;height:24px}.app-footer{padding:0.6rem}.app-footer__text{font-size:clamp(0.75rem, 1.3vw, 0.85rem)}.station-map{padding-block:clamp(2.5rem, 8vh, 4rem) clamp(1.25rem, 4vh, 2.5rem) !important;padding-inline:0;min-height:clamp(600px, 88vh, 760px);margin-block:auto}.station-map__inner{gap:0.75rem}.station-grid{gap:0.75rem}.station-grid--top,.station-grid--bottom{grid-template-columns:repeat(4, minmax(145px, 1fr))}.station-card__header{gap:0.4rem}.station-card__number{font-size:clamp(1.5rem, 3.5vw, 1.9rem)}.station-card__icon{width:clamp(1.5rem, 3.5vw, 1.9rem);height:clamp(1.5rem, 3.5vw, 1.9rem)}.station-card__icon--double{width:auto;gap:clamp(0.2rem, 0.5vw, 0.35rem)}.station-card__icon--double .station-card__icon-img{width:clamp(1.5rem, 3.5vw, 1.9rem);height:clamp(1.5rem, 3.5vw, 1.9rem)}.station-card__title{font-size:clamp(0.8rem, 1.5vw, 1rem);margin-top:0.2rem}.station-card__subtitle{font-size:clamp(0.7rem, 1.2vw, 0.85rem);line-height:1.25}.station-card__lock{width:clamp(1.4rem, 3vw, 1.8rem);height:clamp(1.4rem, 3vw, 1.8rem);bottom:0.75rem}}@media (max-width: 720px){.station-grid--top,.station-grid--bottom{grid-template-columns:repeat(2, minmax(200px, 1fr));width:100%}}@media (max-width: 560px){.station-map__inner{gap:var(--spacing-lg)}.station-grid--top,.station-grid--bottom{grid-template-columns:1fr}.station-card__number{font-size:clamp(2.25rem, 10vw, 3.5rem)}}.permits-game{display:flex;flex-direction:column;gap:var(--spacing-sm);max-width:100%;height:100vh;padding:var(--spacing-sm);box-sizing:border-box}.scenario-card{background:var(--repsol-white);border:2px solid var(--repsol-light-blue);border-radius:var(--radius-md);padding:var(--spacing-md);box-shadow:var(--shadow-sm);flex-shrink:0}.scenario-title{color:var(--repsol-dark-blue);font-size:var(--font-size-md);margin-bottom:var(--spacing-xs)}.scenario-text{color:var(--repsol-dark-blue);font-size:var(--font-size-sm);line-height:1.4}.permits-workspace{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-md);flex:1;min-height:0}.permits-pool{background:var(--repsol-white);border:2px solid var(--repsol-light-gray);border-radius:var(--radius-md);padding:var(--spacing-sm);display:flex;flex-direction:column}.permits-pool h4{color:var(--repsol-dark-blue);font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm);text-align:center;flex-shrink:0}#permitsPool{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-xs)}.permit-item{background:linear-gradient(135deg, #4ECDC4, #44A08D);color:var(--repsol-white);border:none;border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);cursor:grab;font-size:12px;font-weight:600;text-align:center;transition:all var(--transition-base);user-select:none;flex-shrink:0;line-height:1.2}.permit-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.permit-item.dragging{opacity:0.5;cursor:grabbing}.permit-item.correct{background:linear-gradient(135deg, #56ab2f, #a8e6cf);border:2px solid #4CAF50}.permit-item.incorrect{background:linear-gradient(135deg, #ff6b6b, #ffa8a8);border:2px solid #f44336}.drop-zones{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.drop-zone{background:var(--repsol-white);border:3px dashed var(--repsol-light-gray);border-radius:var(--radius-md);padding:var(--spacing-sm);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;transition:all var(--transition-base);min-height:150px;overflow-y:auto}.drop-zone h5{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs);text-align:center;flex-shrink:0}.drop-zone p{color:var(--repsol-gray);font-size:11px;text-align:center;margin-bottom:var(--spacing-sm);flex-shrink:0}.drop-zone[data-zone="applies"]{border-color:#4CAF50}.drop-zone[data-zone="applies"] h5{color:#4CAF50}.drop-zone[data-zone="not-applies"]{border-color:#f44336}.drop-zone[data-zone="not-applies"] h5{color:#f44336}.drop-zone.drag-over{background:rgba(78,205,196,0.1);border-color:#4ECDC4;transform:scale(1.01)}.drop-zone .permit-item{margin-bottom:var(--spacing-xs);width:100%}.scenario-feedback{background:var(--repsol-white);border-radius:var(--radius-md);padding:var(--spacing-sm);margin-top:var(--spacing-sm);box-shadow:var(--shadow-sm);flex-shrink:0}.scenario-feedback.correct{border-left:4px solid #4CAF50}.scenario-feedback.incorrect{border-left:4px solid #ff6b35}.scenario-feedback h4{margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.scenario-feedback.correct h4{color:#4CAF50}.scenario-feedback.incorrect h4{color:#ff6b35}.scenario-feedback p{font-size:12px;margin-bottom:var(--spacing-xs)}.game-actions{display:flex;gap:var(--spacing-sm);justify-content:center;flex-shrink:0;padding:var(--spacing-sm) 0}.game-actions .btn{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-sm)}@media (max-width: 1200px){.permits-workspace{grid-template-columns:1fr;gap:var(--spacing-sm)}.drop-zones{grid-template-columns:1fr}.permits-game{padding:var(--spacing-xs)}}@media (max-height: 800px){.permits-game{gap:var(--spacing-xs)}.scenario-card{padding:var(--spacing-sm)}.drop-zone{min-height:120px;padding:var(--spacing-xs)}.permit-item{padding:4px var(--spacing-xs);font-size:11px}}.game-content{flex:1;padding:var(--spacing-2xl) var(--spacing-xl);max-width:1400px;margin:0 auto;width:100%}.welcome-screen{display:none;text-align:center;max-width:800px;margin:0 auto;padding:var(--spacing-2xl)}.welcome-screen.active{display:block;animation:fadeInUp 0.6s ease}.welcome-screen h2{font-size:var(--font-size-3xl);font-weight:700;color:var(--repsol-dark-blue);margin-bottom:var(--spacing-lg)}.subtitle{font-size:var(--font-size-lg);color:var(--repsol-gray);margin-bottom:var(--spacing-2xl);line-height:1.8}.team-setup{background:var(--repsol-white);border-radius:var(--radius-xl);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-md)}.team-setup h3{color:var(--repsol-dark-blue);margin-bottom:var(--spacing-lg);font-weight:600}#teamNameInput{margin-top:50px;width:100%;max-width:300px;padding:var(--spacing-md);border:2px solid #e9ecef;border-radius:var(--radius-lg);font-size:var(--font-size-base);margin-bottom:var(--spacing-lg);transition:border-color var(--transition-fast)}#teamNameInput:focus{outline:none;border-color:var(--repsol-orange)}.difficulty-selector{display:flex;align-items:center;gap:var(--spacing-md);justify-content:center;flex-wrap:wrap}.difficulty-selector select{padding:var(--spacing-sm) var(--spacing-md);border:2px solid #e9ecef;border-radius:var(--radius-md);font-size:var(--font-size-base);background:var(--repsol-white)}.game-rules{background:linear-gradient(135deg, #f8f9fa 0%, #fff 100%);border-radius:var(--radius-xl);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.game-rules h3{color:var(--repsol-dark-blue);margin-bottom:var(--spacing-lg);font-weight:600}.game-rules ul{list-style:none;text-align:left;max-width:500px;margin:0 auto}.game-rules li{padding:var(--spacing-sm) 0;border-bottom:1px solid #e9ecef;display:flex;align-items:center;gap:var(--spacing-md)}.game-rules li:last-child{border-bottom:none}.start-journey-btn{background:var(--gradient-primary);color:var(--repsol-white);border:none;padding:var(--spacing-lg) var(--spacing-2xl);border-radius:var(--radius-xl);font-size:var(--font-size-lg);font-weight:600;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;gap:var(--spacing-md);text-transform:uppercase;letter-spacing:0.5px;box-shadow:var(--shadow-lg)}.start-journey-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl)}.start-journey-btn:active{transform:translateY(0)}.app-footer{background:var(--repsol-white);color:var(--station-blue-ink);padding:clamp(1.25rem, 2vw, 1.75rem);margin-top:auto;margin-inline:calc(var(--app-gutter) * -1);display:flex;align-items:center;justify-content:center}.app-footer__text{margin:0;font-size:clamp(0.95rem, 1.5vw, 1.1rem);font-weight:500;text-align:center}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);opacity:0;visibility:hidden;transition:all var(--transition-base)}.modal-overlay.active{opacity:1;visibility:visible}.modal{background:var(--repsol-white);border-radius:var(--radius-xl);max-width:600px;width:min(90%, 540px);max-height:80vh;overflow:hidden;box-shadow:var(--shadow-xl);transform:translateY(16px);transition:transform var(--transition-base),opacity var(--transition-base);opacity:0}.modal-overlay.active .modal{transform:translateY(0);opacity:1}.modal-header{position:relative;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid rgba(0,30,55,0.08);display:flex;justify-content:center;align-items:center;text-align:center;gap:var(--spacing-sm)}.modal-header h3{color:var(--station-blue-ink);font-weight:700;letter-spacing:-0.01em;margin:0;padding:0 clamp(1.2rem, 4vw, 2.4rem)}.modal-close{position:absolute;top:50%;right:var(--spacing-lg);transform:translateY(-50%);background:rgba(0,30,55,0.05);border:none;font-size:var(--font-size-2xl);color:var(--station-blue-ink);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:all var(--transition-fast)}@media (max-width: 480px){.modal-header{padding:var(--spacing-md) var(--spacing-lg)}.modal-header h3{padding:0 clamp(1rem, 6vw, 1.6rem)}.modal-close{right:var(--spacing-md)}}.modal-close:hover{background:rgba(0,30,55,0.12);color:var(--station-blue-ink)}.modal-body{padding:clamp(1.6rem, 4vw, 2.2rem);overflow:visible;display:flex;flex-direction:column;gap:clamp(1rem, 2.4vw, 1.4rem);align-items:center;text-align:center}.modal-footer{padding:clamp(1.1rem, 3vw, 1.4rem) clamp(1.4rem, 4vw, 2rem);border-top:1px solid rgba(0,30,55,0.08);display:flex;justify-content:center;gap:var(--spacing-md);background:rgba(0,30,55,0.02)}.modal--narrow{max-width:420px}.modal-body__intro{margin:0;background:rgba(0,30,55,0.05);border-radius:var(--radius-lg);padding:clamp(1rem, 2.6vw, 1.4rem);color:var(--station-blue-ink);font-size:var(--font-size-sm);line-height:1.6;max-width:380px}.modal-form-group{display:flex;flex-direction:column;gap:var(--spacing-xs);width:100%;max-width:320px}.modal-form-group label{font-weight:600;color:var(--station-blue-ink);font-size:var(--font-size-sm);text-align:center;width:100%;display:block}.modal-form-group input{border:1.4px solid rgba(0,30,55,0.15);border-radius:var(--radius-md);padding:0.65rem 0.85rem;font-size:var(--font-size-sm);transition:all var(--transition-fast);background:var(--repsol-white);width:100%;padding-right:3rem}.modal-form-group input:focus{outline:none;border-color:var(--station-turquoise)}.modal-form-group__input-wrapper{position:relative;width:100%;display:flex;align-items:center}.modal-password-toggle{position:absolute;right:0.8rem;top:50%;transform:translateY(-50%);border:none;background:rgba(0,30,55,0.04);width:36px;height:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--station-blue-ink);cursor:pointer;transition:all var(--transition-fast)}.modal-password-toggle:hover,.modal-password-toggle:focus-visible{background:rgba(0,30,55,0.12);outline:none;box-shadow:0 0 0 3px rgba(0,190,212,0.2)}.modal-password-toggle svg{width:20px;height:20px}.modal-password-toggle::after{content:'';position:absolute;width:2px;height:20px;background:currentColor;transform:rotate(45deg);opacity:0;transition:opacity var(--transition-fast);border-radius:1px}.modal-password-toggle.is-revealed::after{opacity:0.65}.modal-error-message{margin-top:var(--spacing-sm);color:var(--error-red);font-size:var(--font-size-xs);min-height:1.2em;opacity:0;transition:opacity var(--transition-fast)}.modal-error-message.is-visible{opacity:1}.modal-action-btn{justify-content:center;min-width:150px;padding:var(--spacing-sm) clamp(1.4rem, 4vw, 1.8rem);border-radius:999px;border:1.4px solid transparent;background:var(--repsol-light-gray);color:var(--station-blue-ink);box-shadow:none;transition:all var(--transition-fast);font-weight:600}.modal-action-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.modal-action-btn--cancel{background:rgba(0,30,55,0.06);border-color:rgba(0,30,55,0.12)}.modal-action-btn--cancel:hover{background:rgba(0,30,55,0.1)}.modal-action-btn--confirm{background:#001E37;color:var(--repsol-white);border:none}.modal-action-btn--confirm:hover{box-shadow:0 16px 32px rgba(0,30,55,0.18)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%, 100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}@keyframes pulse{0%, 100%{transform:scale(1)}50%{transform:scale(1.05)}}@media (max-width: 768px){.app-header__inner{padding:var(--spacing-md);flex-direction:column;align-items:center;gap:var(--spacing-md);text-align:center}.app-header__brand{flex-direction:column;gap:var(--spacing-sm)}.app-header__title{font-size:var(--font-size-lg)}.app-header__actions{width:100%;justify-content:center;flex-wrap:wrap;gap:var(--spacing-sm)}.app-header__team{min-width:unset;width:100%;padding:0 var(--spacing-lg)}.stations-grid{grid-template-columns:1fr;gap:var(--spacing-lg)}.game-content{padding:var(--spacing-lg) var(--spacing-md)}.welcome-screen{padding:var(--spacing-lg)}.welcome-screen h2{font-size:var(--font-size-2xl)}.subtitle{font-size:var(--font-size-base)}.footer-content{flex-direction:column;text-align:center}}@media (max-width: 480px){.app-header__title{font-size:var(--font-size-lg)}.station-card__icon{width:50px;height:50px}.station-card__icon--double{width:auto}.station-card__icon--double .station-card__icon-img{width:50px;height:50px}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.hidden{display:none !important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);border:0}.ranking-modal{position:fixed;top:0;left:0;width:100%;height:100vh;background:rgba(0,0,0,0.8);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;z-index:var(--z-modal);opacity:0;transition:opacity var(--transition-base)}.ranking-modal.show{opacity:1}.ranking-modal-content{background:var(--repsol-white);border-radius:var(--radius-2xl);width:95%;max-width:1200px;height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-xl);transform:translateY(20px);transition:transform var(--transition-base)}.ranking-modal.show .ranking-modal-content{transform:translateY(0)}.ranking-modal-header{background:var(--gradient-primary);color:var(--repsol-white);padding:var(--spacing-xl);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap}.ranking-modal-title{font-size:var(--font-size-3xl);font-weight:700;margin:0;display:flex;align-items:center;gap:var(--spacing-md)}.ranking-close-btn{background:rgba(255,255,255,0.2);border:none;color:var(--repsol-white);width:40px;height:40px;border-radius:50%;font-size:var(--font-size-xl);cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;justify-content:center}.ranking-close-btn:hover{background:rgba(255,255,255,0.3);transform:scale(1.1)}.ranking-modal-body{flex:1;padding:var(--spacing-xl);overflow:hidden;display:flex;flex-direction:column}.ranking-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:2px solid #e9ecef;flex-shrink:0;overflow-x:auto;padding-bottom:var(--spacing-xs)}.ranking-tabs::-webkit-scrollbar{height:4px}.ranking-tabs::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.ranking-tabs::-webkit-scrollbar-thumb{background:var(--repsol-orange);border-radius:2px}.ranking-tabs::-webkit-scrollbar-thumb:hover{background:#e55a2b}.ranking-tab{background:none;border:none;padding:var(--spacing-sm) var(--spacing-md);color:var(--repsol-gray);font-weight:600;font-size:var(--font-size-sm);cursor:pointer;border-radius:var(--radius-md) var(--radius-md) 0 0;transition:all var(--transition-base);position:relative;white-space:nowrap;flex-shrink:0}.ranking-tab.active{color:var(--repsol-blue);background:var(--repsol-light-gray)}.ranking-tab.active::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--repsol-orange)}.ranking-tab:hover:not(.active){background:rgba(255,107,53,0.1);color:var(--repsol-blue)}.ranking-content{display:none;flex:1;overflow:hidden}.ranking-content.active{display:flex;flex-direction:column}.ranking-list{display:flex;flex-direction:column;gap:var(--spacing-md);overflow-y:auto;flex:1;padding-right:var(--spacing-sm)}.ranking-list::-webkit-scrollbar{width:8px}.ranking-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.ranking-list::-webkit-scrollbar-thumb{background:var(--repsol-orange);border-radius:4px}.ranking-list::-webkit-scrollbar-thumb:hover{background:#e55a2b}.ranking-item{background:var(--repsol-white);border:2px solid #e9ecef;border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-lg);transition:all var(--transition-base);flex-shrink:0;min-height:80px}.ranking-item:hover{border-color:var(--repsol-orange);box-shadow:var(--shadow-md)}.ranking-item.podium{background:linear-gradient(135deg, #fff9e6 0%, #fff 100%);border-color:var(--warning-yellow)}.ranking-item.first{background:linear-gradient(135deg, #fff5e6 0%, #fff 100%);border-color:#ffd700}.ranking-position{font-size:var(--font-size-2xl);font-weight:700;min-width:60px;text-align:center}.ranking-team{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.ranking-team-name{font-size:var(--font-size-lg);font-weight:600;color:var(--repsol-blue)}.ranking-team-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--repsol-gray)}.ranking-score{font-size:var(--font-size-2xl);font-weight:700;color:var(--repsol-orange);text-align:center;min-width:100px}.no-rankings{text-align:center;padding:var(--spacing-3xl);color:var(--repsol-gray);flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.no-rankings p{margin-bottom:var(--spacing-md);font-size:var(--font-size-lg)}.loading-rankings{display:flex;align-items:center;justify-content:center;padding:var(--spacing-3xl);color:var(--repsol-gray);font-size:var(--font-size-lg);flex:1}.loading-spinner{width:30px;height:30px;border:3px solid #e9ecef;border-top:3px solid var(--repsol-orange);border-radius:50%;animation:spin 1s linear infinite;margin-right:var(--spacing-md)}@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}.station-ranking-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg);background:var(--repsol-light-gray);border-radius:var(--radius-lg);flex-shrink:0}.station-icon-small{width:40px;height:40px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--repsol-white);font-size:var(--font-size-lg)}.station-ranking-title{font-size:var(--font-size-xl);font-weight:600;color:var(--repsol-blue);margin:0}@media (max-width: 768px){.ranking-modal-content{width:98%;height:95vh}.ranking-modal-header{padding:var(--spacing-lg);flex-direction:column;gap:var(--spacing-md);text-align:center}.ranking-modal-title{font-size:var(--font-size-2xl)}.ranking-modal-body{padding:var(--spacing-lg)}.ranking-tabs{gap:var(--spacing-xs);justify-content:flex-start}.ranking-tab{padding:var(--spacing-sm);font-size:var(--font-size-xs);min-width:fit-content}.ranking-item{flex-direction:column;text-align:center;gap:var(--spacing-md);padding:var(--spacing-md);min-height:auto}.ranking-team-stats{justify-content:center;flex-wrap:wrap}.ranking-position{font-size:var(--font-size-xl);min-width:auto}.ranking-score{font-size:var(--font-size-xl);min-width:auto}}@media (max-width: 480px){.ranking-modal-header{padding:var(--spacing-md)}.ranking-modal-title{font-size:var(--font-size-xl)}.ranking-modal-body{padding:var(--spacing-md)}.ranking-tab{padding:var(--spacing-xs) var(--spacing-sm);font-size:0.7rem}.station-ranking-header{flex-direction:column;text-align:center;gap:var(--spacing-sm);padding:var(--spacing-md)}.station-ranking-title{font-size:var(--font-size-lg)}.ranking-item{padding:var(--spacing-sm)}.ranking-position{font-size:var(--font-size-lg)}.ranking-score{font-size:var(--font-size-lg)}.ranking-team-name{font-size:var(--font-size-base)}.ranking-team-stats{font-size:var(--font-size-xs)}}.login-page{background:var(--gradient-orange-red);min-height:100vh;min-height:100dvh;min-height:-webkit-fill-available;display:grid;place-items:center;padding:clamp(12px, 3vw, 24px);padding-bottom:calc(env(safe-area-inset-bottom, 0px) + clamp(8px, 2vw, 16px));position:relative;overflow:hidden}.login-page::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 15% 40%, rgba(255,170,102,0.4) 0%, transparent 60%),radial-gradient(circle at 85% 70%, rgba(255,60,80,0.32) 0%, transparent 55%),radial-gradient(circle at 50% 85%, rgba(255,255,255,0.1) 0%, transparent 55%);pointer-events:none}.login-container{display:flex;align-items:center;justify-content:center;width:100%;height:100%;padding:0;opacity:1;visibility:visible;pointer-events:auto;transform:none;z-index:1}.login-card{background:var(--skin-peach);backdrop-filter:blur(20px);border-radius:var(--radius-xl);box-shadow:0 20px 40px rgba(0,0,0,0.1),0 10px 20px rgba(0,0,0,0.05),inset 0 1px 0 rgba(255,255,255,0.9);overflow:hidden;border:1px solid rgba(255,255,255,0.35);width:420px;max-width:100%;display:flex;flex-direction:column;max-height:calc(100dvh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 24px)}.login-header{text-align:center;padding:34px 28px 12px;background:transparent;border-bottom:0}.login-header .repsol-logo{display:inline-flex;align-items:center;justify-content:center;gap:12px;margin:12px auto 20px}.login-logo{display:block;height:28px;width:auto}.login-logo--wordmark,.login-logo--iso{height:28px}.login-header h1{font-size:clamp(1.125rem, 2.4vw, 1.25rem);font-weight:700;color:#0d2b4a;margin:18px auto;line-height:1.25;white-space:nowrap}.login-subtitle{font-size:0.875rem;color:#4b5e75;margin:0 auto 24px;line-height:1.4}.login-body{flex:1;padding:0 28px;display:flex;flex-direction:column;justify-content:center}.welcome-animation{display:flex;justify-content:center;margin-bottom:var(--spacing-md)}.team-setup{text-align:center;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;width:100%;max-width:100%;margin:24px 0 32px;padding:28px 24px;background:#ffffff;border-radius:24px;border:1px solid rgba(0,63,127,0.08);box-shadow:none}.team-setup__title{font-size:1.25rem;font-weight:800;color:#0d2b4a;margin:0 0 6px}.team-setup__description{font-size:0.875rem;color:#4b5e75;margin:0 0 20px;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md);max-width:100%;margin:0 auto;width:100%;padding:0}.input-group{text-align:center;width:100%}.input-group label{display:block;font-weight:500;color:var(--repsol-blue);margin-bottom:var(--spacing-sm);font-size:var(--font-size-base);text-align:center}.input-group input{width:100%;height:52px;padding:0 16px;border:1.5px solid var(--border-blue);border-radius:14px;font-size:0.9375rem;font-family:var(--font-family);transition:all 0.3s ease;background:#ffffff;box-sizing:border-box;text-align:center;margin:0 auto;color:#0d2b4a}.input-group input:focus{outline:none;border-color:var(--repsol-orange);box-shadow:0 6px 18px rgba(255,107,53,0.15);transform:translateY(-1px)}.input-group input::placeholder{color:#6a7b8f}.start-button-wrapper{width:100%;margin:0;padding:0 28px 40px;display:flex;justify-content:center;flex-shrink:0}.start-experience-btn{width:100%;height:56px;border:1px solid rgba(0,30,55,0.85);border-radius:14px;background:var(--navy-deep);color:var(--repsol-white);font-size:1rem;font-weight:700;letter-spacing:0.2px;cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base),filter var(--transition-base);box-shadow:none;text-transform:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm)}.start-experience-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 20px 40px rgba(0,30,55,0.3);filter:brightness(1.05)}.start-experience-btn:active:not(:disabled){transform:translateY(0)}.start-experience-btn:disabled{opacity:0.7;cursor:not-allowed}.start-experience-btn.loading::after{content:'';width:18px;height:18px;border-radius:50%;border:3px solid rgba(255,255,255,0.4);border-top-color:var(--repsol-white);margin-left:var(--spacing-sm);animation:spin 1s linear infinite;display:inline-block;vertical-align:middle}.login-form .btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg);font-weight:600;border:none;border-radius:var(--radius-md);background:var(--gradient-primary);color:white;cursor:pointer;transition:all 0.3s ease;text-decoration:none;min-height:54px;box-shadow:0 4px 12px rgba(255,107,53,0.2)}.login-form .btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,107,53,0.3)}.login-form .btn:active:not(:disabled){transform:translateY(0)}.login-form .btn:disabled{opacity:0.7;cursor:not-allowed;transform:none}.login-form .btn.loading{position:relative}.login-form .btn.loading .btn-icon{animation:spin 1s linear infinite}@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}.login-features{display:grid;grid-template-columns:repeat(2, 1fr);gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-md) var(--spacing-md) 0;border-top:1px solid rgba(0,0,0,0.05);justify-items:center}.feature-item{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--repsol-gray);padding:var(--spacing-xs);justify-content:center;text-align:center}.feature-icon{font-size:var(--font-size-base)}.login-footer{background:#ffffff;padding:16px 24px;border-top:0;text-align:center;flex-shrink:0}.login-footer p{margin:0;font-size:0.75rem;color:#6a7b8f;line-height:1.4}.error-modal{max-width:400px;border-radius:var(--radius-lg);background:white;box-shadow:0 20px 40px rgba(0,0,0,0.15)}.error-modal .modal-header{background:#ffeaa7;color:#d63031;border-bottom:1px solid #fdcb6e;padding:var(--spacing-lg)}.error-modal .modal-body{padding:var(--spacing-lg);text-align:center}.error-modal .modal-footer{padding:var(--spacing-lg);text-align:center;border-top:1px solid #e9ecef}@media (max-width: 1180px){.login-card{width:min(92vw, 360px);border-radius:32px}.login-header{padding:28px 24px 12px}.login-body{padding:0 24px}.login-body .team-setup{padding:24px 20px;border-radius:22px}.start-button-wrapper{padding:0 24px calc(28px + env(safe-area-inset-bottom, 0px))}.login-footer{padding:16px 24px calc(18px + env(safe-area-inset-bottom, 0px))}}@media (max-width: 900px){.login-card{width:min(88vw, 340px)}.login-header{padding:24px 22px 10px}.login-body{padding:0 22px}.login-body .team-setup{padding:20px 18px}.start-button-wrapper{padding:0 22px calc(24px + env(safe-area-inset-bottom, 0px))}}@media (max-width: 768px){.login-card{width:min(100%, 400px);border-radius:28px}.login-header{padding:1rem 1.5rem 0.75rem}.login-header h1{font-size:var(--font-size-lg)}.login-body{padding:1rem 1.5rem}.login-body .team-setup{padding:1.25rem 1rem;border-radius:28px}.login-features{grid-template-columns:1fr;gap:var(--spacing-xs)}}@media (max-width: 480px){.login-card{width:100%}.login-header h1{font-size:var(--font-size-base);line-height:1.3}.login-subtitle{font-size:var(--font-size-xs)}.login-logo{height:40px}.welcome-animation lottie-player{width:140px !important;height:80px !important}.team-setup h3{font-size:var(--font-size-base)}}@media (max-height: 820px){.login-header{padding:16px 18px 8px}.login-logo{height:28px}.login-header h1{font-size:18px;margin:6px 0 4px}.login-subtitle{font-size:12px;margin-bottom:14px}.login-body{padding:12px 18px}.login-body .team-setup{margin:12px 0 14px;padding:14px 12px;border-radius:18px}.team-setup__title{font-size:16px;margin-bottom:4px}.team-setup__description{font-size:12px;margin-bottom:10px}.login-form .input-group input{height:44px;padding:10px 12px;font-size:14px}.start-button-wrapper{padding:0 18px calc(14px + env(safe-area-inset-bottom, 0px))}.start-experience-btn{height:48px;font-size:15px;border-radius:12px}.login-footer{padding:10px 14px calc(12px + env(safe-area-inset-bottom, 0px))}.login-footer p{font-size:11px}}@media (max-height: 700px){.login-header{padding:12px 14px 6px}.login-header h1{font-size:16px}.login-subtitle{display:none}.login-body .team-setup{margin:8px 0 10px;padding:12px}.team-setup__title{font-size:15px}.team-setup__description{font-size:11.5px;margin-bottom:8px}.login-form .input-group input{height:42px}.start-experience-btn{height:46px}}@media (max-width: 768px){.app-header__inner{flex-direction:column;align-items:center;gap:var(--spacing-md);text-align:center}.app-header__brand{flex-direction:column;gap:var(--spacing-sm)}.app-header__title{font-size:var(--font-size-xl)}.app-header__actions{width:100%;flex-wrap:wrap;justify-content:center;gap:var(--spacing-sm)}.app-header__team{width:100%;min-width:unset;padding:0 var(--spacing-md);font-size:var(--font-size-xs)}.app-header__icon-button{width:44px;height:44px}}@media (max-width: 480px){.app-header__logo{height:32px}.app-header__logo--iso{height:24px}.app-header__title{font-size:var(--font-size-lg)}.app-header__team{padding:0 var(--spacing-md)}.app-header__icon-button{width:40px;height:40px;border-radius:14px}.app-header__icon{width:26px;height:26px}}
/*# sourceMappingURL=main.css.map */
