:root{--primary:#1b3a2d;--accent:#4caf7d;--gold:#d4a843;--sand:#f5f0e8;--white:#fff;--success:#4caf7d;--warning:#d4a843;--error:#ef4444;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-title:"Georgia", "Merriweather", serif;--font-numbers:"Bebas Neue", "Oswald", sans-serif;--text-primary:#1b3a2d;--text-secondary:#2d2d2d;--text-muted:#1b3a2d;--bg-primary:#f5f0e8;--bg-card:#fff;--bg-sidebar:#1b3a2d;--text-sidebar:#fff;--border-color:#d4a843;--accent-gold:#d4a843;--input-bg:#fff;--input-text:#2d2d2d;--input-border:#d4a843;--title-color:var(--text-primary);--body-color:var(--text-secondary);--secondary-color:var(--text-secondary);--card-text:var(--text-secondary);--label-color:var(--text-primary)}.dark,html.dark{--text-primary:#f5f0e8;--text-secondary:#fff;--text-muted:#d4a843;--bg-primary:#0d0d0d;--bg-card:#1e1e1e;--bg-sidebar:#0d0d0d;--text-sidebar:#fff;--border-color:#4caf7d;--input-bg:#1e1e1e;--input-text:#fff;--input-border:#4caf7d;--accent-gold:#d4a843}*{box-sizing:border-box;scroll-behavior:smooth;margin:0;padding:0}.pizarra-sidebar-content,.materials-list,.timeline-scroll-wrapper,.topbar-scroll-wrapper,.main-wrapper{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;will-change:transform}main,.page-container{padding:16px 0}.pizarra-container main,.pizarra-container .page-container{max-width:none;padding:0}@media screen and (orientation:landscape){body{overflow-y:auto}}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);color:var(--title-color);margin-bottom:1rem}button{font-family:var(--font-body);cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}.app-container{width:100vw;height:100vh;display:flex;overflow:hidden}.sidebar{background-color:var(--bg-sidebar);color:#fff;border-right:1px solid #ffffff1a;flex-direction:column;width:260px;min-width:260px;height:100vh;padding:20px 0;display:flex}.logo-container{border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;margin-bottom:20px;padding:0 20px 30px;display:flex}.logo-img{object-fit:contain;width:44px;height:44px}.logo-icon{width:40px;height:40px}.logo-text{font-family:var(--font-title);color:var(--text-sidebar);letter-spacing:.5px;font-size:1.6rem;font-weight:700;line-height:1}.logo-text span{font-family:var(--font-numbers);color:var(--accent);font-size:1.4rem}.nav-menu{flex-direction:column;flex:1;gap:4px;display:flex}.nav-item{color:#aaa;border-left:3px solid #0000;align-items:center;gap:15px;padding:12px 20px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{color:#fff;background-color:#4caf7d1a}.nav-item.active{border-left-color:var(--accent);color:var(--accent);background-color:#4caf7d33}.user-profile{border-top:1px solid #ffffff1a;align-items:center;gap:15px;padding:20px;display:flex}.user-avatar{background-color:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:700;display:flex}.user-info{flex-direction:column;display:flex}.user-name{color:var(--text-sidebar);font-size:.9rem;font-weight:700}.user-role{color:#ccc;font-size:.8rem}.main-content{background-color:var(--bg-primary);flex-direction:column;flex:1;height:100vh;display:flex;overflow:hidden}.main-wrapper{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;flex:1;width:100%;display:flex;overflow:hidden auto}.header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;height:70px;padding:0 30px;display:flex;background-color:#1b3a2d!important}.header h1{margin:0;font-size:1.5rem;color:#fff!important;font-weight:700!important}.header-actions{align-items:center;gap:20px;display:flex}.icon-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;padding:8px;transition:background .2s;color:#d4a843!important}.icon-btn:hover{background-color:#0000000d}.page-content,.admin-container,.sesiones-page,.planificacion-page,.ia-page,.tests-content,.partidos-page,.mi-equipo-page,.players-grid,.tests-grid,.editor-content,.ia-form-body,.ia-result-panel{flex:1;padding:30px}.btn-primary{cursor:pointer;text-transform:uppercase;border:none;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:12px 24px;font-weight:700;transition:opacity .2s;display:inline-flex;color:#fff!important;background-color:#4caf7d!important;border-radius:8px!important}.btn-primary:hover{opacity:.9}.btn-secondary{text-transform:uppercase;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:12px 24px;font-weight:700;transition:all .2s;display:inline-flex;color:#2d2d2d!important;background-color:#d4a843!important}.btn-secondary:hover{background:#4caf7d1a}.btn-danger{text-transform:uppercase;background-color:#ef4444;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:10px 24px;font-weight:700;display:inline-flex;color:#fff!important}.btn-success{background-color:var(--success);text-transform:uppercase;letter-spacing:.5px;border-radius:8px;align-items:center;gap:8px;min-height:48px;padding:10px 24px;font-weight:700;display:inline-flex;color:var(--white)!important}.card{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000000d}.protocolo-card{color:#1b3a2d;background-color:#f5f0e8;border-left:4px solid #d4a843;border-radius:8px;margin:16px 0;padding:16px;font-weight:500}html.dark .protocolo-card{color:#f5f0e8;background-color:#2d2d2d;border-left:4px solid #d4a843}label{color:var(--label-color);margin-bottom:6px;font-weight:500;display:block}.text-secondary{color:var(--secondary-color)}input,select,textarea{background-color:var(--input-bg);color:var(--input-text);border:1.5px solid var(--input-border);font-family:var(--font-body);border-radius:8px;outline:none;padding:12px;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--accent)}input::placeholder,textarea::placeholder{color:var(--text-muted);opacity:.8}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--sand)}::-webkit-scrollbar-thumb{background:#1b3a2d33;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.team-switcher-header{background:#ffffff1a;border:1px solid #fff3;border-radius:20px;align-items:center;gap:10px;padding:5px 12px;display:flex;position:relative}.team-indicator{border-radius:50%;flex-shrink:0;width:10px;height:10px}.team-switcher-header select{font-family:var(--font-body);color:#fff;cursor:pointer;appearance:none;background:0 0;border:none;outline:none;padding-right:20px;font-size:.85rem;font-weight:700}.team-switcher-header select option{color:#1b3a2d;background-color:#fff;padding:12px 16px;font-weight:600}.team-switcher-header select option:checked,.team-switcher-header select option:hover{background-color:#f5f5f5}.switcher-arrow{pointer-events:none;color:#fff;position:absolute;right:10px}.hamburger-btn{color:#fff;z-index:1000;cursor:pointer;background:#1b3a2d;border:none;border-radius:0 0 8px;justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:fixed;top:0;left:0}.sidebar-overlay{z-index:1000;opacity:0;background:#00000080;width:100vw;height:100vh;transition:opacity .3s;display:none;position:fixed;top:0;left:0}.sidebar-overlay.open{opacity:1;display:block}.sidebar{border-right:none;flex-direction:column;margin:0;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%);z-index:1001!important;-webkit-overflow-scrolling:touch!important;background-color:#1a2e1a!important;width:280px!important;min-width:0!important;max-width:85%!important;height:100vh!important;display:flex!important;overflow-y:auto!important}.sidebar.open{transform:translate(0)}.sidebar-close-btn{justify-content:center;align-items:center;display:flex!important}.header{transition:all .2s;height:60px!important;padding-left:54px!important}.header h1{white-space:nowrap;text-overflow:ellipsis;max-width:200px;overflow:hidden;font-size:1.1rem!important}.main-content{width:100vw!important;margin-left:0!important}.main-wrapper{overscroll-behavior-y:contain;height:calc(100vh - 60px);-webkit-overflow-scrolling:touch!important;padding:0!important;overflow-y:auto!important}.app-container,.main-content{background-color:#1a2e1a!important}.page-content,.admin-container,.sesiones-page,.planificacion-page,.tests-content,.partidos-page,.mi-equipo-page,.players-grid,.tests-grid{min-height:auto;padding:16px;height:auto!important}button,.nav-item,input,select,.icon-btn,.topbar-btn,.tool-icon-btn{min-width:44px;min-height:44px}@media (orientation:landscape) and (height<=500px){.header h1{display:none!important}.header{height:44px!important}}.spinner{border:3px solid #2d5a27;border-top-color:#4caf7d;border-radius:50%;flex-shrink:0;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner-center{justify-content:center;align-items:center;width:100%;height:200px;display:flex}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-state-icon{opacity:.4;font-size:48px;line-height:1}.empty-state h3{color:var(--text-primary);margin:0;font-size:1.1rem}.empty-state p{max-width:280px;font-size:14px;line-height:1.5}.player-card,.frame-chip,.material-item,.test-card,.session-item-dash,.action-btn-dash,.player-select-item,.test-select-item{cursor:pointer}.notifications-overlay{z-index:1000;background:#0003;justify-content:flex-end;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.notifications-panel{background:var(--bg-card);flex-direction:column;width:350px;height:100%;animation:.3s ease-out slideIn;display:flex;box-shadow:-5px 0 15px #0000001a}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.notifications-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:20px;display:flex}.notifications-header h2{color:var(--text-primary);margin:0;font-size:1.2rem}.close-btn{cursor:pointer;color:#666;background:0 0;border:none}.notifications-list{flex:1;padding:10px;overflow-y:auto}.notification-item{border-bottom:1px solid var(--border-color);gap:15px;padding:15px;transition:background .2s;display:flex}.notification-item:hover{background:var(--bg-primary)}.notif-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.notification-item.info .notif-icon{color:#1976d2;background:#e3f2fd}.notification-item.warning .notif-icon{color:#f57c00;background:#fff3e0}.notification-item.success .notif-icon{color:#388e3c;background:#e8f5e9}.notif-content p{color:var(--text-secondary);margin:0;font-size:.9rem}.notif-content span{color:#888;font-size:.75rem}.empty-msg{text-align:center;color:#888;padding:40px 20px}.dark .notifications-panel{box-shadow:-5px 0 25px #0006}.dark .notification-item.info .notif-icon{color:#42a5f5;background:#0d2a3a}.dark .notification-item.warning .notif-icon{color:#ffb74d;background:#3a2a0d}.dark .notification-item.success .notif-icon{color:#66bb6a;background:#0d2a1a}.dark .close-btn{color:#a0ada9}.dashboard-page{background-color:var(--bg-primary);min-height:100%;padding:30px}.dashboard-header{justify-content:space-between;align-items:center;margin-bottom:40px;display:flex}.welcome h1{font-family:var(--font-title);color:var(--text-primary);margin:0;font-size:2.2rem}.welcome p{color:var(--text-muted);margin:5px 0 0}.current-date{text-align:right;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:10px 20px;box-shadow:0 4px 12px #1b3a2d0d}.current-date span{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:12px;display:block}.current-date strong{color:var(--text-primary);font-size:1.2rem}.stats-grid-dash{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px;display:grid}.stat-card-dash{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;border-radius:16px;align-items:center;gap:15px;padding:24px;transition:all .2s;display:flex;position:relative;box-shadow:0 4px 15px #1b3a2d0a}.stat-card-dash:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:0 8px 20px #1b3a2d1a}.stat-card-dash:active{transform:translateY(-2px)}.stat-icon-dash{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;display:flex}.stat-content-dash{flex-direction:column;display:flex}.stat-label-dash{color:var(--text-muted);font-size:13px;font-weight:500}.stat-value-dash{color:var(--text-primary);font-size:1.5rem;font-weight:800;font-family:var(--font-numbers);letter-spacing:1px}.stat-value-dash.no-rival{font-family:var(--font-body);text-transform:uppercase;font-size:1.1rem;color:var(--text-primary)!important}.stat-trend-dash{color:var(--accent);font-size:11px;font-weight:700;position:absolute;top:15px;right:15px}.dashboard-content{grid-template-columns:1.5fr 1fr;gap:25px;margin-bottom:30px;display:grid}.dash-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:0 4px 15px #1b3a2d0a}.section-header{justify-content:space-between;align-items:center;margin-bottom:25px;display:flex}.section-header h2{font-family:var(--font-title);color:var(--text-primary);margin:0;font-size:1.2rem}.chart-section{background:var(--bg-card)!important;border-radius:8px!important}.chart-section .section-header h2{color:var(--text-primary)}.chart-section .section-header .btn-text{color:var(--accent)}.bar-chart{background-image:linear-gradient(var(--border-color) 1px, transparent 1px);-webkit-overflow-scrolling:touch;background-size:100% 40px;justify-content:space-between;align-items:flex-end;width:100%;height:200px;padding:0 10px;display:flex;position:relative;overflow-x:auto}.bar-wrapper{flex-direction:column;flex:1;align-items:center;gap:10px;display:flex}.bar-container{flex-direction:column;justify-content:flex-end;width:24px;height:160px;display:flex;position:relative;overflow:visible;background:var(--bg-primary)!important;border:1px solid var(--border-color)!important;border-radius:6px!important}.bar-fill{border-radius:4px;width:100%;transition:height .6s cubic-bezier(.175,.885,.32,1.275);position:relative}.bar-fill.low{background:#4caf7d}.bar-fill.medium{background:#d4a843}.bar-fill.high{background:#ef4444}.bar-tooltip{color:var(--text-primary);opacity:1;pointer-events:none;background:var(--bg-card);border:1px solid var(--border-color);border-radius:4px;padding:2px 4px;font-weight:800;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.bar-fill:hover .bar-tooltip{opacity:1}.bar-label{color:var(--text-secondary);font-size:12px;font-weight:700}.sessions-list-dash{flex-direction:column;gap:12px;display:flex}.session-item-dash{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;align-items:center;gap:15px;padding:12px;transition:all .2s;display:flex}.session-item-dash:hover{border-color:var(--accent);background:var(--bg-card)}.session-indicator{border-radius:3px;width:6px;height:36px}.session-indicator.técnica{background:var(--gold)}.session-indicator.táctica{background:#3b82f6}.session-indicator.física{background:#ec4899}.session-info-dash{flex-direction:column;flex:1;display:flex}.session-info-dash strong{color:var(--text-secondary);font-size:14px}.session-info-dash span{color:var(--text-muted);font-size:12px}.session-badges{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.badge-dash{background:var(--bg-primary);color:var(--accent);border:1px solid var(--border-color);text-transform:uppercase;border-radius:4px;padding:2px 8px;font-size:10px;font-weight:700}.badge-dash.intensity{background:var(--bg-card);color:var(--text-muted)}.badge-dash.intensity.alta{color:#ef4444;background:#fee2e2}.quick-actions-dash h2{font-family:var(--font-title);color:var(--text-primary);margin:0 0 20px;font-size:1.2rem}.actions-grid-dash{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;display:grid}.action-btn-dash{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;color:var(--text-primary);border-radius:16px;flex-direction:column;align-items:center;gap:10px;padding:20px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.action-btn-dash:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 4px 12px #d4a8431a}.action-btn-dash span{font-size:24px}.btn-text{color:var(--accent);cursor:pointer;background:0 0;border:none;font-weight:700}.dash-select{font-size:13px;font-family:var(--font-body);cursor:pointer;border-radius:8px;outline:none;padding:8px 12px;font-weight:700;border:1px solid var(--border-color)!important;background-color:var(--bg-card)!important;color:var(--text-primary)!important}@media (width<=1024px){.dashboard-content{grid-template-columns:1fr}}.dark .current-date{box-shadow:0 4px 15px #0006}.dark .bar-container{background:#ffffff0d}.dark .session-item-dash:hover{background:#ffffff14}.dark .action-btn-dash:hover{background:#ffffff0d}.pizarra-container{background:var(--bg-primary);width:100%;height:100vh;font-family:var(--font-body);flex-direction:column;display:flex;overflow:hidden}.pizarra-topbar{background:var(--bg-card);border-bottom:1px solid var(--border-color);flex-shrink:0;align-items:center;height:46px;display:flex;overflow:hidden}.topbar-scroll-wrapper{scrollbar-width:none;align-items:center;gap:0;height:100%;padding:0 8px;display:flex;overflow:auto hidden}.topbar-scroll-wrapper::-webkit-scrollbar{display:none}.topbar-group{align-items:center;gap:4px;padding:0 6px;display:flex}.topbar-divider{background:var(--border-color);opacity:.3;width:1px;height:24px;margin:0 6px}.tool-icon-btn,.topbar-btn-nav{width:48px;height:48px;color:var(--text-primary);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.tool-icon-btn svg{width:18px;height:18px}.tool-icon-btn:hover{background:var(--bg-primary);color:var(--accent)}.tool-icon-btn.active{background:var(--accent);color:var(--white);border-color:var(--accent)}.topbar-select{background:var(--bg-primary);height:36px;color:var(--text-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:6px;min-width:160px;padding:0 10px;font-size:13px;font-weight:600}.topbar-btn{height:36px;color:var(--text-muted);border:1px solid var(--border-color);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:0 12px;font-size:12px;font-weight:700;transition:all .2s}.topbar-btn:hover{background:var(--bg-primary);color:var(--accent)}.topbar-btn.active{background:var(--accent);color:var(--white);border-color:var(--accent)}.topbar-btn.primary{background:var(--accent-gold);height:36px;color:var(--primary);border:none;padding:0 16px;font-weight:800}.topbar-btn.primary:hover{opacity:.9}.topbar-btn.outline{height:34px;color:var(--text-muted);border:2px solid var(--border-color);background:0 0}.color-swatch-top{cursor:pointer;border:2px solid #0000;border-radius:50%;width:18px;height:18px}.color-swatch-top.active{border-color:var(--white);box-shadow:0 0 0 2px var(--accent)}.pizarra-main{flex:1;min-height:0;display:flex;overflow:hidden}.panel-izq{background:var(--bg-card);border-right:1px solid var(--border-color);flex-shrink:0;width:176px;padding:10px;overflow-y:auto}.panel-title{letter-spacing:.12em;color:var(--accent-gold);text-transform:uppercase;margin-bottom:8px;font-size:10px;font-weight:700}.team-card-pizarra{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;margin-bottom:8px;padding:8px 10px}.team-header-pizarra{align-items:center;gap:8px;display:flex}.team-name-pizarra{color:var(--text-primary);flex:1;font-size:14px;font-weight:800}.btn-add-player-pizarra{border:1px solid var(--accent);width:48px;height:48px;color:var(--accent);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:16px;line-height:1;display:flex}.formation-select-pizarra{background:var(--bg-primary);width:100%;height:36px;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;margin-top:10px;padding:0 10px;font-size:13px;font-weight:700}.acciones-panel-container-grid{border-top:1px solid var(--border-color);grid-template-columns:1fr 1fr;gap:8px;margin-top:8px;padding-top:8px;display:grid}.toggle-rival,.btn-delete-pizarra{cursor:pointer;text-transform:uppercase;letter-spacing:.5px;justify-content:center;align-items:center;font-weight:700;transition:all .2s;display:flex;border-radius:4px!important;width:100%!important;height:28px!important;padding:0 4px!important;font-size:10px!important}.toggle-rival{border:1px solid var(--border-color)!important;color:var(--text-muted)!important;background:0 0!important}.toggle-rival:hover{background:var(--bg-hover)!important}.toggle-rival.active{background:var(--accent)!important;color:var(--white)!important;border-color:var(--accent)!important}.btn-delete-pizarra{color:#ef4444!important;background:0 0!important;border:1px solid #ef4444!important}.btn-delete-pizarra:hover{background:#ef44441a!important}.canvas-area{background:#2d5a27;flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}#canvas-container,.canvas-container,[id*=canvas][class*=container]{min-height:300px;position:relative;flex:1!important;width:100%!important;height:100%!important}canvas#fabric-canvas,canvas.upper-canvas,canvas.lower-canvas{touch-action:none}.field-renderer-canvas{z-index:1!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.fabric-canvas-elem{z-index:999!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.panel-der{background:var(--bg-card);border-left:1px solid var(--border-color);flex-shrink:0;width:168px;padding:8px;overflow-y:auto}.material-category{margin-bottom:4px}.collapsible-header{cursor:pointer;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:6px;padding:4px 0;font-size:10px;font-weight:700;display:flex}.collapsible-arrow{min-width:10px;font-size:8px}.material-items{grid-template-columns:1fr 1fr;gap:6px;padding:6px 0;display:grid}.material-item{background:var(--bg-card);border:1px solid var(--border-color);text-align:center;cursor:pointer;border-radius:6px;flex-direction:column;align-items:center;padding:6px 4px;transition:all .2s;display:flex}.material-item:hover{border-color:var(--accent);background:var(--bg-primary)}.material-item.active{border-color:var(--accent-gold);background:var(--bg-primary)}.material-item svg{width:28px!important;height:28px!important}.material-item span{color:var(--text-muted);margin-top:4px;font-size:10px;font-weight:700;line-height:1.1;display:block}.pizarra-timeline{background:var(--bg-card);border-top:1px solid var(--border-color);flex-shrink:0;align-items:center;height:44px;display:flex}.timeline-scroll-wrapper{scrollbar-width:none;align-items:center;gap:6px;height:100%;padding:0 10px;display:flex;overflow:auto hidden}.timeline-scroll-wrapper::-webkit-scrollbar{display:none}.timeline-btn-nav{background:var(--bg-card);border:1px solid var(--border-color);width:48px;height:48px;color:var(--text-primary);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;font-size:13px;display:flex}.timeline-btn-nav:hover{background:#1e3a2e}.timeline-btn-nav.play{color:#fff;background:#4caf7d;border-color:#4caf7d;font-weight:600}.frame-counter{color:var(--text-primary);min-width:auto;padding:0 12px;font-size:14px;font-weight:800}.timeline-chips{gap:4px;display:flex}.frame-chip{background:var(--bg-primary);border:1px solid var(--border-color);width:48px;height:48px;color:var(--text-muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:12px;font-weight:800;display:flex}.frame-chip.active{background:var(--accent);color:var(--white);border-color:var(--accent)}.btn-add-frame{color:#4caf7d;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #4caf7d;border-radius:4px;height:28px;padding:0 10px;font-size:11px}.btn-trash-frame{width:48px;height:48px;color:var(--error);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.pizarra-container.mobile .panel-izq,.pizarra-container.mobile .panel-der{display:none}.pizarra-container.mobile .canvas-area{background:var(--bg-card)}.floating-actions{z-index:100;gap:12px;display:none;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.pizarra-container.mobile .floating-actions{display:flex}.btn-floating-left,.btn-floating-right{color:#1b3a2d;background:#d4a843;border:none;border-radius:20px;padding:8px 16px;font-size:12px;font-weight:700;box-shadow:0 4px 12px #0006}.bottom-drawer-overlay{z-index:1000;background:#0009;align-items:flex-end;display:flex;position:fixed;inset:0}.bottom-drawer{background:var(--bg-card);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-height:75vh;padding:0 0 24px;display:flex;overflow-y:auto}.drawer-handle{background:#c9a84c66;border-radius:2px;width:40px;height:4px;margin:12px auto}.reduced-controls{border:1px solid var(--border-color);background:#ffffff0d;border-radius:6px;align-items:center;gap:10px;padding:4px 10px;display:flex}.slider-box{flex-direction:column;gap:1px;min-width:75px;display:flex}.slider-box span{color:#d4a843;text-transform:uppercase;white-space:nowrap;font-size:9px;font-weight:700}.slider-box input[type=range]{cursor:pointer;accent-color:#4caf7d;width:100%;height:3px}@media (width<=1024px){.reduced-controls{background:var(--bg-card);z-index:100;justify-content:space-around;position:absolute;top:55px;left:10px;right:10px;box-shadow:0 4px 10px #00000080}}.upgrade-modal{text-align:center;max-width:400px!important}.crown-icon{margin-bottom:10px;font-size:48px}.upgrade-message{color:var(--text-primary);margin-bottom:20px;font-size:1.1rem}.benefits-list{text-align:left;margin:20px 0;padding:0;list-style:none}.benefits-list li{color:var(--text-secondary);border-bottom:1px solid #0000000d;padding:8px 0}.benefits-list li:last-child{border-bottom:none}.equipo-page{background-color:var(--bg-primary);padding:24px;position:relative;overflow-x:hidden}.equipo-header{flex-direction:column;gap:20px;margin-bottom:30px;display:flex}.header-info h1{font-family:var(--font-title);color:var(--text-primary);margin:0;font-size:2rem}.header-info p{color:var(--text-secondary);margin:4px 0 0}.filter-chips{-ms-overflow-style:none;scrollbar-width:none;gap:10px;padding-bottom:5px;display:flex;overflow-x:auto}.filter-chips::-webkit-scrollbar{display:none}.chip{background:var(--bg-card);border:1px solid var(--accent);color:var(--accent);cursor:pointer;white-space:nowrap;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.chip.active{background:var(--accent)!important;color:var(--white)!important;border-color:var(--accent)!important}.players-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;padding-bottom:80px;display:grid}.player-card{background:var(--bg-card);text-align:center;cursor:pointer;border:1px solid var(--border-color);border-radius:12px;flex-direction:column;align-items:center;padding:20px;transition:transform .2s,box-shadow .2s;display:flex;position:relative;box-shadow:0 4px 12px #1b3a2d0d}.player-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #1b3a2d1a}.player-avatar{background:var(--primary);color:#fff;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:15px;font-size:24px;font-weight:700;display:flex;position:relative;box-shadow:0 2px 8px #0000001a}.player-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.player-number{background:var(--gold);color:var(--primary);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;display:flex;position:absolute;bottom:-5px;right:-5px}.player-info h3{color:var(--text-primary);margin:0;font-size:1.1rem}.player-meta{justify-content:center;align-items:center;gap:10px;margin-top:8px;display:flex}.pos-badge{background:var(--accent);color:var(--white);letter-spacing:.5px;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:800}.age-info{color:var(--text-muted);font-size:12px}.injury-indicator{font-size:18px;position:absolute;top:10px;right:10px}.empty-team-state h2{color:var(--text-primary);margin-bottom:10px}.empty-team-state p{color:var(--text-secondary);margin-bottom:20px}.fab-add{background:var(--accent);color:#fff;cursor:pointer;z-index:100;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s;display:flex;position:fixed;bottom:30px;right:30px;box-shadow:0 4px 15px #4caf7d66}.fab-add:hover{transform:scale(1.1)}.modal-overlay{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;width:90%;max-width:90vw;max-height:85vh;display:flex;overflow-y:auto;box-shadow:0 20px 40px #0003}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:var(--text-primary);margin:0;font-size:1.2rem}.modal-body{flex-direction:column;gap:16px;padding:24px;display:flex;overflow-y:auto}.form-row-team{gap:16px;display:flex}.form-group-team{flex-direction:column;flex:1;gap:6px;display:flex}.form-group-team.full{flex:none;width:100%}.form-group-team label{margin-bottom:4px;font-size:12px;font-weight:700;color:var(--accent-gold)!important}.form-group-team input,.form-group-team select{font-family:var(--font-body);border-radius:8px;width:100%;padding:10px;font-size:14px;border:1px solid var(--border-color)!important;background:var(--bg-primary)!important;color:var(--text-primary)!important}.modal-footer{border-top:1px solid var(--border-color);background:var(--bg-primary);border-radius:0 0 16px 16px;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.footer-actions{gap:10px;margin-left:auto;display:flex}.btn-outline-team{border:2px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-weight:700}.btn-primary-team{background:var(--accent);color:var(--white);cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-weight:700}.player-sidebar{background:var(--bg-card);z-index:200;border-left:1px solid var(--border-color);flex-direction:column;width:400px;height:100vh;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:-400px;box-shadow:-5px 0 25px #00000026}.player-sidebar.open{right:0}.sidebar-header{background:var(--primary);color:#fff;text-align:center;padding:30px;position:relative}.btn-close{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;font-size:20px;position:absolute;top:15px;left:15px}.header-actions-right{position:absolute;top:15px;right:15px}.btn-edit-icon{cursor:pointer;opacity:.8;background:0 0;border:none;font-size:16px;transition:opacity .2s}.btn-edit-icon:hover{opacity:1;transform:scale(1.1)}.large-avatar{border:4px solid var(--accent);background:#ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto 15px;font-size:32px;font-weight:700;display:flex}.sidebar-header h2{text-transform:uppercase;letter-spacing:1px;margin:0;font-family:Georgia,serif;font-weight:800;color:#fff!important}.sidebar-header p{opacity:1;color:#fff;margin:5px 0 0;font-size:14px;font-weight:500}.sidebar-tabs{background:var(--bg-primary);border-bottom:1px solid var(--border-color);display:flex}.sidebar-tabs button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:12px 5px;font-size:11px;font-weight:700;transition:all .2s}.sidebar-tabs button.active{color:var(--accent);border-bottom:3px solid var(--accent)}.sidebar-body{flex:1;padding:24px;overflow-y:auto}.info-row{border-bottom:1px solid #f5f5f5;justify-content:space-between;padding:12px 0;display:flex}.info-row label{color:var(--text-muted);font-size:13px}.info-row span{color:var(--text-secondary);font-weight:600}.badge-pos{background:var(--accent);text-transform:uppercase;letter-spacing:.5px;border-radius:20px;padding:4px 14px;font-size:12px;font-weight:800;display:inline-block;box-shadow:0 2px 4px #0000001a;color:#fff!important}.physical-stats{grid-template-columns:repeat(3,1fr);gap:15px;margin-top:10px;display:grid}.stat-item{background:var(--bg-primary);text-align:center;border:1px solid var(--border-color);border-radius:12px;padding:15px}.stat-val{color:var(--text-primary);font-size:1.5rem;font-weight:700}.stat-val span{margin-left:2px;font-size:12px}.stat-item label{color:var(--text-muted);margin-top:4px;font-size:11px;display:block}.medical-toggle{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.injury-box{background:#ef44441a;border:1.5px solid #ef4444;border-radius:8px;margin-bottom:20px;padding:15px}.injury-box label{color:#ef4444;font-size:12px;font-weight:700}.injury-box p{color:var(--text-primary);margin:5px 0 0;font-weight:500}.stats-grid{grid-template-columns:1fr 1fr;gap:15px;display:grid}.stat-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;padding:20px;display:flex}.stat-card span{color:var(--text-secondary);font-size:12px;font-weight:700}.stat-card strong{color:var(--text-primary);margin-top:5px;font-size:1.8rem}.empty-text{text-align:center;color:var(--text-muted);margin-top:40px;font-size:13px}.btn-outline-gold{border:2px solid var(--accent);width:100%;color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;padding:12px;font-weight:700;transition:all .2s}@media (width<=768px){.player-sidebar{width:100%;right:-100%}}@media (width>=768px){.modal-content{min-width:700px}}.dark .sidebar-header{background:#0a0f0e}.dark .sidebar-tabs{border-bottom-color:var(--border-color);background:#0003}.sesiones-page{background-color:var(--bg-primary);flex-direction:column;height:100%;padding:24px;display:flex;overflow:hidden}.sesiones-header{flex-shrink:0;margin-bottom:24px}.edit-mode-header{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;margin-bottom:24px;padding:20px;box-shadow:0 4px 12px #1b3a2d0d}.title-group{flex-direction:column;gap:8px;display:flex}.title-group h1{margin:0}.btn-icon-back{color:var(--text-primary);text-align:left;font-size:13px;font-weight:700;transition:opacity .2s}.btn-icon-back:hover{opacity:.8}.btn-primary{background:var(--accent);color:#fff;border-radius:12px;padding:10px 24px;font-size:14px;font-weight:700;transition:transform .2s;box-shadow:0 4px 12px #4caf7d4d}.btn-primary:hover{background:#3d9c6c;transform:translateY(-2px)}.btn-outline{color:var(--accent);border:2px solid var(--accent);cursor:pointer;background:0 0;border-radius:12px;padding:10px 24px;font-size:14px;font-weight:700;transition:all .2s}.btn-outline:hover{background:#4caf7d1a}.btn-primary-small{background:var(--accent);color:#fff;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:700}.calendar-strip{gap:12px;margin-top:24px;margin-bottom:24px;padding-bottom:5px;display:flex;overflow-x:auto}.day-chip{cursor:pointer;border:1px solid var(--border-color);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;min-width:60px;height:80px;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000000a;background:var(--bg-card)!important;color:var(--text-primary)!important}.day-chip.active.today{background:var(--accent)!important;color:var(--white)!important;border-color:var(--accent)!important}.day-name{text-transform:uppercase;color:inherit;opacity:.8;font-size:11px;font-weight:700}.day-num{font-size:1.4rem;font-weight:800;font-family:var(--font-numbers);color:inherit}.day-chip.active .day-name{opacity:.9}.filters-row{gap:8px;display:flex}.filter-tab{color:#4caf7d;cursor:pointer;background:0 0;border:1px solid #4caf7d;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.filter-tab.active{color:#fff!important;background:#4caf7d!important;border-color:#4caf7d!important}.sessions-content{flex:1;grid-template-columns:1.2fr .8fr;gap:24px;display:grid;overflow:hidden}.sessions-list{flex-direction:column;gap:16px;padding-right:10px;display:flex;overflow-y:auto}.session-card{background:var(--bg-card);cursor:pointer;border:1px solid var(--border-color);border-radius:16px;transition:transform .2s,box-shadow .2s;display:flex;overflow:hidden;box-shadow:0 4px 12px #00000008}.session-card.selected,.session-card:hover{border-color:var(--accent);transform:translate(5px);box-shadow:0 6px 16px #0000000f}.session-strip{width:6px}.session-strip.técnica{background:var(--gold)}.session-strip.táctica{background:#3b82f6}.session-strip.física{background:#ec4899}.session-strip.mixta{background:#8b5cf6}.session-main{flex:1;align-items:center;gap:20px;padding:20px;display:flex}.session-date-box{border-right:1px solid var(--border-color);flex-direction:column;min-width:70px;display:flex}.session-date-box .time{color:var(--text-primary);font-size:1.1rem;font-weight:800}.session-date-box .duration{color:var(--text-muted);font-size:11px}.session-details{flex:1}.session-details h3{color:var(--text-primary);margin:0 0 8px;font-size:1.1rem}.session-badges{gap:8px;display:flex}.badge{text-transform:uppercase;border:1.5px solid var(--border-color);border-radius:4px;padding:3px 10px;font-size:10px;font-weight:700}.badge.category{background:var(--accent);color:var(--white)}.badge.intensity.alta,.badge.intensity.máxima{color:#ef4444;background:#ef44441a;border-color:#ef4444}.badge.intensity.media{color:#f97316;background:#f973161a;border-color:#f97316}.badge.intensity.baja{color:#0ea5e9;background:#0ea5e91a;border-color:#0ea5e9}.badge.blocks{background:var(--bg-primary);color:var(--text-muted)}.session-arrow{color:var(--text-primary);font-size:14px}.empty-state-list{text-align:center;padding:40px;color:var(--text-muted)!important}.session-preview-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;flex-direction:column;display:flex;overflow-y:auto;box-shadow:0 10px 30px #1b3a2d0d}.preview-content{flex-direction:column;height:100%;padding:30px;display:flex}.preview-header h2{color:var(--text-primary);margin:0 0 5px;font-size:1.5rem}.date-full{color:var(--text-muted);font-size:14px}.preview-stats{gap:15px;margin:24px 0;display:flex}.p-stat{background:var(--bg-primary);text-align:center;border:1px solid var(--border-color);border-radius:12px;flex:1;padding:15px}.p-stat strong{color:var(--text-primary);font-size:1.4rem;font-family:var(--font-numbers);display:block}.p-stat span{color:var(--text-muted);text-transform:uppercase;font-size:10px;font-weight:700}.preview-files{margin-bottom:20px}.files-indicator{background:var(--bg-primary);color:var(--accent);border:1px solid var(--border-color);border-radius:8px;padding:10px;font-size:13px;font-weight:700}.preview-blocks{flex:1}.preview-blocks h4{text-transform:uppercase;color:var(--text-muted);margin-bottom:15px;font-size:13px}.block-item-mini{gap:12px;margin-bottom:12px;display:flex}.b-num{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.b-info strong{color:var(--text-secondary);font-size:13px;display:block}.b-info span{color:var(--text-secondary);font-size:11px}.empty-blocks-text{color:var(--text-muted);font-size:13px;font-style:italic}.preview-actions{border-top:1px solid var(--border-color);flex-direction:column;gap:10px;margin-top:auto;padding-top:20px;display:flex}.preview-empty{text-align:center;height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.empty-icon{margin-bottom:15px;font-size:3rem}.full-width{width:100%}.btn-outline-gold{border:2px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:12px;padding:12px;font-weight:700;transition:all .2s}.btn-outline-gold:hover{background:#4caf7d1a}.btn-text-error{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:10px;font-size:13px;font-weight:700;transition:opacity .2s}.btn-text-error:hover{opacity:.8}.editor-content{flex:1;grid-template-columns:1fr 1fr;gap:24px;display:grid;overflow:hidden}.editor-left,.editor-right{flex-direction:column;gap:24px;padding-right:10px;display:flex;overflow-y:auto}.edit-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:24px;box-shadow:0 4px 12px #1b3a2d08}.edit-section h3{color:var(--text-primary);border-bottom:1px solid var(--border-color);margin:0 0 20px;padding-bottom:10px;font-size:1.1rem}.section-header-flex{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;display:flex}.section-header-flex h3{border:none;margin:0;padding:0}.btn-small-outline{border:2px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:700;transition:all .2s}.btn-small-outline:hover{background:#4caf7d1a}.btn-text{color:var(--accent);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:700}.form-row{gap:16px;margin-bottom:16px;display:flex}.form-group{flex-direction:column;flex:1;gap:6px;display:flex}.form-group.mini{flex:unset;width:120px}.form-group.full{margin-bottom:16px}.form-group label{color:var(--text-secondary);font-size:12px;font-weight:700}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);font-family:var(--font-body);color:var(--text-secondary);background:var(--bg-primary);border-radius:8px;padding:12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);background:var(--bg-card);outline:none}.form-group textarea{resize:vertical;min-height:80px}.empty-files{text-align:center;color:var(--text-muted);background:var(--bg-primary);border:1px dashed var(--border-color);border-radius:8px;padding:20px}.files-list{flex-direction:column;gap:10px;display:flex}.file-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;align-items:center;gap:15px;padding:12px;display:flex}.file-icon{font-size:24px}.file-info{flex-direction:column;flex:1;display:flex}.file-name{color:var(--text-secondary);font-size:13px;font-weight:700}.file-size{color:var(--text-muted);font-size:11px}.btn-del-icon{color:#ef4444;cursor:pointer;background:0 0;border:none;padding:5px;font-size:14px;font-weight:700}.player-check-item{background:var(--bg-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px;transition:all .2s;display:flex}.player-check-item input{display:none}.p-num{font-family:var(--font-numbers);color:var(--gold);text-align:center;width:20px;font-size:1.2rem;font-weight:700}.blocks-header{background:var(--primary);color:#fff;border-radius:16px;justify-content:space-between;align-items:center;padding:20px;display:flex;box-shadow:0 4px 12px #1b3a2d1a}.blocks-header h3{color:#fff;border:none;margin:0;padding:0}.blocks-builder-list{flex-direction:column;gap:16px;display:flex}.empty-blocks{text-align:center;color:var(--text-muted);background:var(--bg-card);border:2px dashed var(--border-color);border-radius:16px;padding:40px}.block-editor-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #00000008}.block-editor-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);align-items:center;gap:15px;padding:15px 20px;display:flex}.block-number{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-weight:700;display:flex}.block-title-input{color:var(--text-primary);background:0 0;border:none;border-bottom:1px solid #0000;outline:none;flex:1;padding:5px;font-size:15px;font-weight:700;transition:border-color .2s}.block-title-input:focus{border-bottom-color:var(--accent)}.block-editor-body{flex-direction:column;gap:16px;padding:20px;display:flex}.block-editor-actions{border-top:1px solid #f0f0f0;justify-content:flex-end;padding-top:10px;display:flex}.btn-outline-accent{border:1px solid var(--accent);color:var(--accent);cursor:pointer;background:0 0;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:700;transition:all .2s}.btn-outline-accent:hover{background:#4caf7d1a}.modal-overlay-pdf{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content-pdf{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;width:90%;max-width:90vw;max-height:85vh;display:flex;overflow:hidden}.modal-header-pdf{background:var(--primary);color:#fff;justify-content:space-between;align-items:center;padding:15px 24px;display:flex}.modal-header-pdf h3{color:#fff;margin:0;font-size:1.2rem}.btn-close-pdf{color:#fff;cursor:pointer;background:0 0;border:none;font-size:20px}.modal-body-pdf{background:#e0e0e0;flex:1}.btn-text-small{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-left:10px;font-weight:700;text-decoration:underline}@media (width<=1024px){.sessions-content,.editor-content{grid-template-columns:1fr}.session-preview-panel{display:none}}@media (width>=768px){.modal-content-pdf{min-width:700px}}.planificacion-page{background-color:var(--bg-primary);flex-direction:column;height:100%;padding:24px;display:flex;overflow:hidden}.plan-toast{background:var(--accent);color:#fff;z-index:9999;white-space:nowrap;border-radius:30px;padding:12px 28px;font-size:14px;font-weight:800;animation:.3s toast-in;position:fixed;bottom:28px;left:50%;transform:translate(-50%);box-shadow:0 6px 24px #4caf7d73}.plan-toast--error{background:#ef4444;box-shadow:0 6px 24px #ef444466}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.plan-header{flex-shrink:0;margin-bottom:24px}.header-top{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.plan-tabs{border-bottom:2px solid #0000000d;gap:15px;padding-bottom:10px;display:flex;overflow-x:auto}.plan-tab{font-family:var(--font-body);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:8px 16px;font-size:14px;font-weight:800;transition:color .2s;position:relative}.plan-tab:hover,.plan-tab.active{color:var(--primary)}.plan-tab.active:after{content:"";background-color:var(--accent);border-radius:3px 3px 0 0;width:100%;height:3px;position:absolute;bottom:-12px;left:0}.plan-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;flex:1;padding:20px;display:flex;overflow-y:auto;box-shadow:0 4px 15px #1b3a2d0d}.macro-general-info{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:20px;padding:20px}.info-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:15px;display:grid}.form-group-macro{flex-direction:column;gap:5px;display:flex}.form-group-macro label{text-transform:uppercase;color:#d4a843!important;font-size:11px!important;font-weight:600!important}.form-group-macro input,.form-group-macro textarea{border:1px solid var(--border-color);font-family:var(--font-body);background:var(--input-bg);width:100%;color:var(--input-text);border-radius:8px;padding:10px;font-size:14px;transition:all .2s}.form-group-macro input::placeholder,.form-group-macro textarea::placeholder{color:var(--text-muted);opacity:.7}.full-width-macro textarea{resize:vertical;min-height:60px}.macro-legend{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:8px;flex-wrap:wrap;align-items:center;gap:15px;margin-bottom:20px;padding:10px 15px;font-size:12px;font-weight:600;display:flex}.macro-legend strong{color:var(--primary)}.macro-spreadsheet-container{border:1px solid var(--border-color);background:var(--bg-card);border-radius:12px;flex:1;overflow:auto}.macro-spreadsheet{min-width:max-content;display:flex}.row-headers{background:var(--bg-sidebar);color:var(--text-sidebar);z-index:10;border-right:2px solid var(--border-color);flex-direction:column;display:flex;position:sticky;left:0;box-shadow:2px 0 5px #0000001a}.r-head{border-bottom:1px solid var(--border-color);white-space:nowrap;align-items:center;height:40px;padding:0 15px;font-size:11px;font-weight:700;display:flex}.section-head{background:#0000001a}.sub-head{color:var(--text-muted);font-size:10px}.highlight-vol{color:var(--gold)}.data-columns{display:flex}.data-col{flex-direction:column;width:60px;display:flex;border-right:1px solid #2d5a27!important}.cell{border-bottom:1px solid var(--border-color);height:40px;color:var(--text-secondary);justify-content:center;align-items:center;font-size:12px;display:flex;position:relative}.cell input,.cell select{text-align:center;width:100%;height:100%;font-size:12px;font-family:var(--font-body);color:var(--text-secondary);background:0 0;border:none;outline:none}.cell input:focus,.cell select:focus{background:var(--bg-primary)}.month-cell{background:#142e22!important}.month-cell input{color:#d4a843!important;font-weight:600!important}.period-cell input{color:#4caf7d!important;font-weight:600!important}.cell.fw-bold{color:var(--text-primary);background:0 0;font-weight:700}.cell.sub-cell input{color:var(--text-muted)}.cell.highlight-vol input{color:var(--accent-gold);font-weight:800!important}.cell select{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px}.period-cell.preparatorio input{color:var(--gold);font-weight:700}.period-cell.competitivo input{color:var(--accent);font-weight:700}.period-cell.transitorio input{color:#3b82f6;font-weight:700}.macro-summary{background:var(--sand);border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:20px;padding:16px 20px;display:flex}.msv-label{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);font-size:10px;font-weight:700}.msv-formula{color:var(--text-muted);margin-top:1px;font-size:11px}.micro-view{flex-direction:column;gap:20px;display:flex}.micro-header{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:20px}.dark .micro-header{background:var(--bg-card)}.micro-title h3{color:var(--gold);margin:0 0 5px}.week-grid{grid-template-columns:repeat(7,1fr);gap:15px;display:grid}.day-col{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;display:flex;overflow:hidden}.day-header{text-align:center;background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:15px}.d-name{color:var(--primary);font-weight:700}.dark .d-name{color:#f1f5f9}.day-type-select{border-bottom:1px solid #eee;padding:10px}.day-type-select select{border:1px solid #ccc;border-radius:6px;width:100%;padding:8px;font-size:12px}.day-session{flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.btn-assign{color:#888;cursor:pointer;background:0 0;border:1px dashed #ccc;border-radius:8px;width:100%;padding:10px;font-size:12px}.btn-assign:hover{border-color:var(--accent);color:var(--accent);background:#fff}.assigned-session{background:var(--bg-primary);border:1.5px solid var(--accent);border-radius:8px;flex-direction:column;align-items:center;gap:5px;width:100%;padding:10px;display:flex;position:relative}.assigned-session .s-icon{font-size:20px}.assigned-session .s-name{color:var(--primary);text-align:center;word-break:break-word;font-size:11px;font-weight:700}.btn-remove-session{background:var(--error);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-5px;right:-5px}.btn-remove-session:hover{transform:scale(1.1)}.day-load-input{background:#fff;border-top:1px solid #eee;padding:15px}.day-load-input label{color:var(--text-muted);margin-bottom:5px;font-size:11px;font-weight:700;display:block}.day-load-input input{border:1px solid var(--border-color);text-align:center;background:var(--input-bg);width:100%;color:var(--input-text);font-family:var(--font-body);border-radius:6px;padding:8px}.day-load-input input::placeholder{color:var(--text-muted);opacity:.5}.obj-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.obj-card{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);border-radius:16px;flex-direction:column;padding:24px;transition:all .3s;display:flex}.dark .obj-card{background:var(--bg-primary);box-shadow:0 4px 20px #0003}.obj-card h3{color:var(--gold);border-bottom:2px solid var(--accent);margin:0 0 15px;padding-bottom:5px;transition:color .3s;display:inline-block}.dark .obj-card h3{color:#10b981;border-bottom-color:#10b981}.editable-list{border:1px solid var(--border-color);width:100%;font-family:var(--font-body);resize:vertical;background:var(--input-bg);color:var(--input-text);border-radius:8px;padding:15px;font-size:14px;line-height:1.5}.editable-list::placeholder{color:var(--text-muted);opacity:.6}.editable-list:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #4caf7d26}@media (width<=1024px){.week-grid,.obj-grid{grid-template-columns:1fr}}.training-schedule-config{border-top:1px solid var(--border-color);flex-direction:column;gap:12px;margin-top:16px;padding-top:16px;display:flex}.schedule-row{flex-wrap:wrap;align-items:flex-end;gap:20px;display:flex}.duration-input{border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-primary);border-radius:8px;padding:8px 12px;font-size:14px;font-weight:600;width:120px!important}.weekly-volume-badge{background:#4caf7d1f;border:1px solid #4caf7d66;border-radius:10px;flex-direction:column;align-items:center;min-width:130px;padding:8px 18px;display:flex}.wv-label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:10px;font-weight:700}.wv-value{color:#4caf7d;font-size:1.4rem;font-weight:800;font-family:var(--font-numbers,monospace)}.days-selector{flex-wrap:wrap;gap:8px;margin-top:4px;display:flex}.day-pill{border:2px solid var(--border-color);background:var(--bg-card);min-width:48px;height:48px;color:var(--text-muted);cursor:pointer;border-radius:10px;font-size:13px;font-weight:700;transition:all .2s}.day-pill:hover{color:#4caf7d;border-color:#4caf7d}.day-pill.active{color:#fff;background:#4caf7d;border-color:#4caf7d;box-shadow:0 2px 8px #4caf7d66}.meso-en-curso{background:linear-gradient(135deg,#142e22 0%,#1b3a2d 100%);border:1px solid #4caf7d40;border-radius:14px;margin-bottom:16px;padding:20px;box-shadow:0 4px 20px #00000026}.meso-header-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.meso-badge{color:#0d1f0d;letter-spacing:.5px;background:#d4a843;border-radius:20px;margin-right:8px;padding:4px 12px;font-size:12px;font-weight:800}.meso-period-tag{color:#4caf7d;background:#4caf7d33;border:1px solid #4caf7d4d;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.meso-countdown{flex-direction:column;align-items:center;display:flex}.countdown-num{color:#d4a843;font-size:2rem;font-weight:800;font-family:var(--font-numbers,monospace);line-height:1}.countdown-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-size:10px;font-weight:700}.meso-info-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;display:grid}.meso-stat{background:#ffffff0d;border-radius:8px;flex-direction:column;gap:2px;padding:10px;display:flex}.ms-label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;font-size:10px;font-weight:700}.ms-value{color:#fff;font-size:13px;font-weight:700}.meso-loads{flex-direction:column;gap:8px;display:flex}.load-bar-item{align-items:center;gap:10px;display:flex}.lb-label{color:#aaa;flex-shrink:0;width:55px;font-size:11px}.lb-track{background:#ffffff1a;border-radius:4px;flex:1;height:8px;overflow:hidden}.lb-fill{border-radius:4px;height:100%;transition:width .6s}.lb-fill.physical{background:linear-gradient(90deg,#ef4444,#f97316)}.lb-fill.technical{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.lb-fill.tactical{background:linear-gradient(90deg,#4caf7d,#22c55e)}.lb-pct{color:var(--text-muted);text-align:right;width:32px;font-size:12px;font-weight:700;transition:color .2s}.dark .lb-pct{color:#10b981;text-shadow:0 0 10px #10b98133}.planning-guide{border:1px solid #ffffff0f;border-radius:8px;margin-bottom:16px;overflow:hidden}.guide-toggle{cursor:pointer;color:#d4a843;background:#142e22;border:none;justify-content:space-between;align-items:center;width:100%;padding:12px 16px;font-size:13px;font-weight:600;transition:background .2s;display:flex}.guide-toggle:hover{background:#1b3a2d}.guide-arrow{color:#aaa;font-size:10px}.guide-content{background:#142e22;flex-direction:column;gap:16px;padding:16px;display:flex}.guide-section{flex-direction:column;gap:8px;display:flex}.guide-section-title{text-transform:uppercase;letter-spacing:1px;color:#d4a843;border-bottom:1px solid #d4a84333;margin:0 0 4px;padding-bottom:6px;font-size:11px;font-weight:700}.guide-items{flex-direction:column;gap:5px;display:flex}.guide-item{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.gi-code{color:#4caf7d;background:#4caf7d1f;border:1px solid #4caf7d4d;border-radius:4px;flex-shrink:0;padding:1px 6px;font-family:monospace;font-size:11px;font-weight:800}.gi-name{color:#4caf7d;flex-shrink:0;font-size:12px;font-weight:600}.gi-desc{color:#ccc;font-size:12px;line-height:1.4}@media (width<=768px){.meso-info-grid{grid-template-columns:repeat(2,1fr)}.schedule-row{flex-direction:column;align-items:flex-start}}.macro-summary-vol{flex-direction:column;gap:4px;display:flex}.msv-label{text-transform:uppercase;color:var(--gold);letter-spacing:.5px;font-size:11px;font-weight:700}.msv-value{color:#1a1a1a;font-size:1.8rem;font-weight:800;font-family:var(--font-numbers)}.dark .msv-value{color:#fff!important}.msv-formula{color:var(--text-muted);font-size:11px;font-style:italic}.tests-page{background-color:var(--bg-primary);flex-direction:column;height:100%;padding:24px;display:flex;overflow:hidden}.tests-header{flex-shrink:0;margin-bottom:24px}.tests-tabs{-webkit-overflow-scrolling:touch;white-space:nowrap;border-bottom:2px solid var(--border-color);scrollbar-width:none;flex-wrap:nowrap;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.tests-tabs::-webkit-scrollbar{display:none}.tests-tab{font-family:var(--font-body);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;flex-shrink:0;min-width:44px;min-height:44px;padding:8px 14px;font-weight:700;transition:color .2s;position:relative}.tests-tab:hover,.tests-tab.active{color:var(--primary)}.tests-tab.active:after{content:"";background-color:var(--accent);border-radius:3px 3px 0 0;width:100%;height:3px;position:absolute;bottom:-6px;left:0}.tests-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;flex:1;padding:20px;display:flex;overflow-y:auto;box-shadow:0 4px 15px #1b3a2d0d}.bateria-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.bateria-header h3{color:var(--text-primary);margin:0}.tests-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;display:grid}.test-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;padding:20px;transition:transform .2s,box-shadow .2s;display:flex}.test-card.clickable{cursor:pointer}.test-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 5px 15px #1b3a2d1a}.t-head{justify-content:space-between;margin-bottom:15px;display:flex}.t-cat{text-transform:uppercase;border-radius:4px;padding:4px 8px;font-size:11px;font-weight:700;color:var(--accent)!important;border:1px solid var(--accent)!important}.t-unit{border-radius:4px;padding:4px 8px;font-size:11px;font-weight:700;color:var(--accent-gold)!important;border:1px solid var(--accent-gold)!important;background:0 0!important}.test-card h4{margin:0 0 10px;font-size:1.1rem;font-weight:700;color:var(--text-primary)!important}.test-card p{flex:1;margin:0;font-size:13px;line-height:1.4;color:var(--text-secondary)!important}.view-detail-hint{color:var(--accent);text-transform:uppercase;opacity:0;margin-top:15px;font-size:11px;font-weight:700;transition:opacity .2s;display:block}.test-card:hover .view-detail-hint{opacity:1}.tab-registro,.tab-historial{gap:20px;height:100%;display:flex}.reg-sidebar,.hist-sidebar{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;flex-shrink:0;width:250px;padding:15px;display:flex;overflow-y:auto}.reg-sidebar h3,.hist-sidebar h3{color:var(--text-primary);text-transform:uppercase;margin:0 0 15px;font-size:14px}.test-selector,.player-selector{flex-direction:column;gap:8px;display:flex}.test-select-item,.player-select-item{background:var(--bg-card);cursor:pointer;border:1px solid var(--border-color);border-radius:8px;flex-direction:column;padding:12px;transition:all .2s;display:flex}.test-select-item:hover,.player-select-item:hover{border-color:var(--accent);background:var(--bg-primary)}.test-select-item.active,.player-select-item.active{border-color:var(--accent);background:#4caf7d0d}.test-select-item strong{color:var(--text-secondary);font-size:13px}.test-select-item span{color:var(--text-muted);margin-top:4px;font-size:11px}.player-select-item{flex-direction:row;align-items:center;gap:10px}.p-num{background:var(--gold);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.p-name{color:var(--text-secondary);font-size:13px;font-weight:700}.reg-main,.hist-main{flex-direction:column;flex:1;display:flex;overflow-y:auto}.reg-main-header{background:var(--primary);color:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:15px 20px;display:flex}.reg-main-header h3{margin:0}.reg-main-header h3 span{color:var(--accent-gold);margin-left:10px;font-weight:700}.unit-badge{border:1px solid var(--accent-gold);color:var(--accent-gold);background:#ffffff1a;border-radius:6px;padding:5px 10px;font-size:12px;font-weight:700}.reg-players-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;margin-bottom:20px;display:grid}.reg-player-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;justify-content:space-between;align-items:center;padding:15px;display:flex}.rp-info{align-items:center;gap:10px;display:flex}.rp-num{color:var(--gold);font-weight:700}.rp-name{color:var(--text-secondary);font-size:13px;font-weight:700}.reg-player-card input{text-align:center;border:1px solid var(--border-color);width:70px;color:var(--text-primary);background:var(--bg-card);border-radius:6px;outline:none;padding:8px;font-weight:700}.reg-player-card input:focus{border-color:var(--accent)}.reg-actions{border-top:1px solid var(--border-color);justify-content:flex-end;margin-top:auto;padding-top:20px;display:flex}.hist-main-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.hist-main-header h3{color:var(--text-primary);margin:0;font-size:1.5rem}.hist-charts-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.hist-chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;box-shadow:0 2px 10px #00000008}.hc-header{justify-content:space-between;align-items:center;margin-bottom:15px;display:flex}.hc-header h4{color:var(--text-primary);margin:0;font-size:14px}.hc-header .unit{color:var(--text-muted);font-size:11px;font-weight:400}.trend-arrow{border-radius:4px;padding:4px 8px;font-size:12px;font-weight:700}.trend-arrow.good{color:#4caf7d;background:#4caf7d1a;border:1px solid #4caf7d}.trend-arrow.bad{color:#ef4444;background:#ef44441a;border:1px solid #ef4444}.trend-badge{border-radius:4px;padding:4px 8px;font-size:11px;font-weight:700}.trend-badge.good{color:#4caf7d;background:#4caf7d1a;border:1px solid #4caf7d}.trend-badge.bad{color:#ef4444;background:#ef44441a;border:1px solid #ef4444}.svg-chart{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;width:100%;height:80px;margin-bottom:10px}.hc-labels{justify-content:space-between;margin-top:10px;display:flex}.hc-point{flex-direction:column;align-items:center;display:flex}.hc-point strong{color:var(--text-secondary);font-size:14px}.hc-point span{color:var(--text-muted);font-size:10px}.comp-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.comp-select{align-items:center;gap:15px;display:flex}.comp-select label{color:var(--text-muted);font-size:13px;font-weight:700}.comp-select select{border:1px solid var(--border-color);font-family:var(--font-body);color:var(--text-primary);background:var(--bg-card);border-radius:8px;outline:none;padding:10px;font-weight:700}.heatmap-container{border:1px solid var(--border-color);border-radius:12px;overflow-x:auto}.heatmap-table{border-collapse:collapse;width:100%}.heatmap-table th{background:var(--primary);color:#fff;text-align:left;text-transform:uppercase;white-space:nowrap;padding:15px;font-size:12px}.heatmap-table td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:12px 15px;font-size:13px}.heatmap-table td.center,.heatmap-table th.center{text-align:center}.heatmap-table tr:hover{background:var(--bg-primary)}.heat-cell{color:#1b3a2d!important;font-weight:800!important}.dark .heat-cell{color:#0d1f0d!important}.modal-content.large{max-width:700px}.test-detail-body{flex-direction:column;gap:20px;padding:0;display:flex}.test-image-placeholder{background:var(--bg-primary);border-bottom:1px solid var(--border-color);width:100%;height:250px}.test-image-placeholder img{object-fit:cover;width:100%;height:100%}.test-info-block{padding:0 24px 24px}.test-info-block h3{color:var(--text-primary);text-transform:uppercase;margin:0 0 8px;font-size:1rem}.test-info-block p{color:var(--text-secondary);margin:0 0 20px;font-size:14px;line-height:1.6}.test-meta{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:10px 15px;display:inline-block}.test-meta span{color:var(--text-primary);font-size:13px}@media (width<=768px){.tab-registro,.tab-historial{flex-direction:column}.reg-sidebar,.hist-sidebar{flex-shrink:0;width:100%;height:150px}}.dark .test-select-item.active,.dark .player-select-item.active{background:#4caf7d26}.dark .reg-main-header,.dark .heatmap-table th{background:var(--bg-sidebar)}.dark .heatmap-table tr:hover{background:#ffffff0d}.partidos-page{background-color:var(--bg-primary);flex-direction:column;height:100%;padding:24px;display:flex;overflow:hidden}.partidos-header{flex-shrink:0;margin-bottom:24px}.header-top{justify-content:space-between;align-items:center;display:flex}.header-top h1{font-family:var(--font-title);color:var(--text-primary);margin:0;font-size:1.8rem}.header-actions{gap:10px;display:flex}.partidos-list-container{flex-direction:column;flex:1;display:flex;overflow-y:auto}.list-filters{gap:10px;margin-bottom:20px;display:flex}.filter-tab{background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:700}.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.matches-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.match-card{background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;color:var(--text-secondary);border-radius:12px;padding:20px;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 10px #00000008}.match-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 8px 20px #0000000f}.mc-header{justify-content:space-between;align-items:center;margin-bottom:15px;display:flex}.status-badge{text-transform:uppercase;border-radius:4px;padding:4px 8px;font-size:11px;font-weight:700}.status-badge.terminado{background:var(--accent);color:#fff;border:1px solid var(--accent)}.status-badge.pendiente{background:var(--accent-gold);color:var(--primario-oscuro);border:1px solid var(--accent-gold)}.mc-date{color:var(--text-muted);font-size:12px;font-weight:800}.mc-body{border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:15px;padding:15px 0;display:flex}.t-name{color:var(--text-secondary);text-align:center;flex:1;font-size:14px;font-weight:700}.mc-score{color:var(--text-primary);padding:0 15px;font-size:24px;font-weight:700}.mc-score .vs{color:var(--text-muted);font-size:16px}.mc-footer{color:var(--text-muted);justify-content:space-between;font-size:12px;display:flex}.partidos-editor-container{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;flex:1;display:flex;overflow:hidden;box-shadow:0 4px 15px #1b3a2d0d}.editor-tabs{background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:15px 20px 0;display:flex}.e-tab{font-family:var(--font-body);color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:12px 20px;font-weight:700;position:relative}.e-tab.active{color:var(--text-primary)}.e-tab.active:after{content:"";background:var(--accent);border-radius:3px 3px 0 0;width:100%;height:3px;position:absolute;bottom:0;left:0}.editor-content{flex:1;padding:30px;overflow-y:auto}.tab-pane h3{color:var(--text-primary);border-bottom:2px solid var(--accent);margin:0 0 20px;padding-bottom:5px;font-size:1.3rem;display:inline-block}.form-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;display:grid}.form-group.full{grid-column:1/-1}.form-group label{color:var(--text-primary);text-transform:uppercase;margin-bottom:8px;font-size:12px;font-weight:700;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);width:100%;font-family:var(--font-body);background:var(--bg-primary);color:var(--text-secondary);border-radius:8px;padding:12px;font-size:14px}.form-group input:focus,.form-group select:focus{border-color:var(--accent);background:var(--bg-card);outline:none}.conv-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.conv-count{color:var(--accent);background:var(--bg-primary);border:2px solid var(--accent);border-radius:20px;padding:5px 15px;font-size:14px;font-weight:800;transition:all .2s}.conv-count.error{background:var(--bg-primary);color:var(--error);border-color:var(--error)}.players-checklist{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px;display:grid}.player-check-item{border:2px solid var(--border-color);background:var(--bg-primary);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;align-items:center;gap:15px;padding:15px;transition:all .2s;display:flex}.player-check-item:hover{border-color:var(--accent);background:var(--bg-card)}.player-check-item.selected{border-color:var(--accent);background:#4caf7d0d}.p-info{color:var(--text-secondary);flex-direction:column;flex:1;display:flex}.p-pos{color:var(--text-muted);font-size:11px}.check-indicator{border:2px solid var(--border-color);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.player-check-item.selected .check-indicator{background:var(--accent);border-color:var(--accent)}.alineacion{gap:30px;height:100%;display:flex}.alin-sidebar{flex-direction:column;flex-shrink:0;width:250px;display:flex}.form-select{border:1px solid var(--border-color);background:var(--bg-primary);width:100%;color:var(--text-primary);border-radius:8px;padding:10px;font-weight:700}.titulares-list h4{color:var(--text-primary);border-bottom:1px solid var(--border-color);margin:20px 0 10px;padding-bottom:5px}.hint{color:var(--text-muted);margin-top:-5px;font-size:11px;font-style:italic}.alin-player-list-item{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;align-items:center;gap:10px;margin-bottom:5px;padding:8px;font-size:13px;display:flex}.alin-player-list-item span{color:var(--gold);font-weight:700}.alin-player-list-item.sub{opacity:.7}.alin-main{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;flex:1;justify-content:center;align-items:center;padding:20px;display:flex}.mini-pitch-container{aspect-ratio:2/3;background:#2e5a3c;border:4px solid #fff;border-radius:8px;width:100%;max-width:400px;position:relative;overflow:hidden;box-shadow:0 10px 30px #0003}.pitch-line{background:#fffc;position:absolute}.center-line{width:100%;height:2px;top:50%;left:0;transform:translateY(-50%)}.pitch-circle{border:2px solid #fffc;border-radius:50%;position:absolute}.center-circle{aspect-ratio:1;width:30%;top:50%;left:50%;transform:translate(-50%,-50%)}.pitch-box{border:2px solid #fffc;width:50%;height:15%;position:absolute;left:50%;transform:translate(-50%)}.penalty-box.top{border-top:none;top:0}.penalty-box.bottom{border-bottom:none;bottom:0}.pitch-player{z-index:10;flex-direction:column;align-items:center;gap:4px;transition:all .3s;display:flex;position:absolute}.pp-circle{background:var(--white);border:2px solid var(--primary);width:28px;height:28px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex;box-shadow:0 2px 5px #0000004d}.pp-name{background:var(--primario-oscuro);color:#fff;white-space:nowrap;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.empty-state-post{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:50px 20px;display:flex}.empty-state-post .icon{opacity:.5;margin-bottom:20px;font-size:48px}.post-grid{grid-template-columns:1fr 1fr;gap:30px;display:grid}.analysis-panel.full{grid-column:1/-1}.resultado-panel,.events-panel,.analysis-panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;padding:20px}.score-inputs{justify-content:center;align-items:center;gap:20px;margin-top:20px;display:flex}.score-team{flex-direction:column;align-items:center;gap:10px;display:flex}.score-team span{color:var(--text-primary);font-size:16px;font-weight:700}.score-team input{text-align:center;border:1px solid var(--border-color);width:80px;height:80px;color:var(--text-primary);background:var(--bg-card);border-radius:12px;font-size:36px;font-weight:700}.score-team input:focus{border-color:var(--accent);outline:none}.score-inputs .vs{color:var(--text-muted);font-size:24px;font-weight:700}.analysis-panel textarea{border:1px solid var(--border-color);width:100%;font-family:var(--font-body);resize:vertical;background:var(--bg-card);color:var(--text-secondary);border-radius:8px;padding:15px}@media (width<=1024px){.alineacion{flex-direction:column}.alin-sidebar{width:100%}.post-grid{grid-template-columns:1fr}}.ia-page{background:var(--bg-primary);height:100%;display:flex;overflow:hidden}.ia-form-panel{background:var(--bg-card);border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;width:380px;display:flex;overflow:hidden}.ia-form-header{background:var(--primary);color:#fff;flex-shrink:0;padding:24px 24px 16px}.ia-form-header h1{font-family:var(--font-title);color:#fff;margin:0 0 8px;font-size:1.5rem}.ia-form-header p{color:#ffffffe6;margin:0;font-size:13px;line-height:1.4}.ia-form-body{flex-direction:column;flex:1;gap:20px;padding:20px 24px 24px;display:flex;overflow-y:auto}.ia-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11px;font-weight:800;display:block}.ia-field select,.ia-field textarea{border:1.5px solid var(--border-color);width:100%;font-family:var(--font-body);color:var(--input-text);background:var(--input-bg);border-radius:8px;padding:10px 12px;font-size:14px;transition:all .2s}.ia-field select::placeholder,.ia-field textarea::placeholder{color:var(--text-muted);opacity:.6}.ia-field select:focus,.ia-field textarea:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 2px #4caf7d1a}.ia-slider{-webkit-appearance:none;background:linear-gradient(to right, var(--accent) 0%, var(--border-color) 0%);cursor:pointer;border-radius:3px;outline:none;width:100%;height:6px}.ia-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);border:2px solid var(--bg-card);cursor:pointer;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 5px #0003}.slider-labels{color:var(--text-muted);justify-content:space-between;margin-top:4px;font-size:11px;display:flex}.chip-group{flex-wrap:wrap;gap:8px;display:flex}.chip{background:var(--bg-card);border:1.5px solid var(--border-color);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:7px 14px;font-size:13px;font-weight:600;transition:all .15s}.chip:hover{border-color:var(--accent);color:var(--primary)}.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.ia-error{color:#ef4444;background:#ef44441a;border:1px solid #ef4444;border-radius:8px;padding:12px 16px;font-size:13px}.btn-generate{background:var(--accent);color:#fff;width:100%;font-family:var(--font-title);letter-spacing:.05em;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-top:5px;padding:16px;font-size:1rem;font-weight:700;transition:all .2s;display:flex;box-shadow:0 4px 15px #4caf7d4d}.btn-generate:hover:not(:disabled){opacity:.95;transform:translateY(-1px)}.btn-generate:active:not(:disabled){transform:translateY(0)}.btn-generate:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-generate.loading{opacity:.7;cursor:not-allowed;animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%{opacity:.6;width:60%}50%{opacity:1;width:70%}to{opacity:.6;width:60%}}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}.ia-result-panel{flex-direction:column;flex:1;gap:24px;padding:30px;display:flex;overflow-y:auto}.ia-empty-state{text-align:center;color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:60px 40px;display:flex}.empty-icon{opacity:.6;margin-bottom:20px;font-size:64px}.ia-empty-state h2{color:var(--text-primary);margin:0 0 10px;font-size:1.5rem}.ia-empty-state p{max-width:400px;color:var(--text-muted);font-size:14px;line-height:1.6}.ia-loading-animation{gap:10px;margin-bottom:24px;display:flex}.ai-dot{background:var(--accent);border-radius:50%;width:14px;height:14px;animation:1.2s ease-in-out infinite bounce}.ai-dot:nth-child(2){animation-delay:.2s}.ai-dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.5;transform:scale(.6)}40%{opacity:1;transform:scale(1.2)}}.ia-result-content{background:var(--bg-card);border:1px solid var(--border-color);-webkit-overflow-scrolling:touch;border-radius:16px;max-height:calc(100vh - 120px);overflow-y:auto;box-shadow:0 4px 15px #0000000d}.result-actions{z-index:10;background:var(--bg-primary);border-bottom:1px solid var(--border-color);gap:10px;padding:16px 24px;display:flex;position:sticky;top:0}.ia-markdown-container{background:var(--bg-card);border:1px solid var(--border-color);white-space:pre-wrap;word-break:break-word;min-height:320px;max-height:60vh;color:var(--text-secondary);border-radius:12px;flex:1;margin-top:12px;padding:16px 20px;font-size:14px;line-height:1.7;overflow-y:auto}.ia-markdown{padding:8px}.ia-empty-text{color:var(--text-muted);font-style:italic;font-weight:500}.ia-markdown h1,.ia-markdown h2,.ia-markdown h3,.ia-markdown h4{color:var(--text-primary);font-weight:800;font-family:var(--font-title,inherit);margin-top:1.2em;margin-bottom:.6em}.ia-markdown h2{border-bottom:3px solid var(--accent,#10b981);padding-bottom:10px;font-size:1.6rem}.ia-markdown h3{text-transform:uppercase;letter-spacing:.05em;font-size:1rem}.ia-markdown p,.ia-markdown li{color:var(--text-secondary);margin:6px 0;font-weight:500;line-height:1.6}.ia-markdown strong{color:var(--text-primary);font-weight:800}.ia-markdown code{color:#c7254e;background:#e8e8e8;border-radius:4px;padding:.2em .4em}.ia-markdown li{padding-left:16px;position:relative}.ia-markdown li:before{content:"→";color:var(--accent,#10b981);font-weight:700;position:absolute;left:0}.dark .ia-markdown-container{color:#e0e0e0;background:#0f1a0f;border-color:#2d4a2d}.dark .ia-markdown h1,.dark .ia-markdown h2,.dark .ia-markdown h3,.dark .ia-markdown h4{color:#d4a843}.dark .ia-markdown p,.dark .ia-markdown li{color:#f5f0e8}.dark .ia-markdown strong{color:#fff}.dark .ia-markdown code{color:#f5f0e8;background:#333}.ia-modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;width:100vw;height:100vh;padding:20px;display:flex;position:fixed;top:0;left:0}.ia-modal-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;flex-direction:column;width:100%;max-width:800px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 10px 40px #0000004d}.ia-modal-header{background:var(--primary);color:#fff;justify-content:space-between;align-items:center;padding:20px 30px;display:flex}.ia-modal-header h2{color:#fff;margin:0;font-size:1.4rem}.btn-close-modal{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;transition:background .2s;display:flex}.btn-close-modal:hover{background:#ffffff4d}.ia-modal-body{-webkit-overflow-scrolling:touch;padding:30px;overflow-y:auto}.preview-text{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:250px;margin-top:4px;font-size:12px;display:block;overflow:hidden}.saved-exercises{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:20px 24px;box-shadow:0 4px 15px #0000000d}.saved-exercises h3{color:var(--text-primary);margin:0 0 16px;font-size:1.1rem}.saved-list{flex-direction:column;gap:8px;display:flex}.saved-item{background:var(--bg-primary);cursor:pointer;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;font-size:14px;transition:background .15s;display:flex}.saved-item:hover{border-color:var(--accent);background:#4caf7d1a}.saved-hint{color:var(--accent);font-size:12px;font-weight:700}@media (width<=900px){.ia-page{flex-direction:column}.ia-form-panel{width:100%;max-height:50vh}.ia-result-content{max-height:none}}.dark .ia-form-panel,.dark .ia-result-content,.dark .ia-modal-container,.dark .saved-exercises{background:var(--bg-card);border-color:var(--border-color)}.dark .result-actions{background:var(--bg-primary);border-color:var(--border-color)}.dark .saved-item{background:#ffffff08}.exercise-diagram{background:#1a2e1a;border:1px solid #4caf7d40;border-radius:14px;margin-top:24px;overflow:hidden}.diagram-header{background:#00000040;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.diagram-title{color:#d4a843;margin-bottom:2px;font-size:13px;font-weight:700;display:block}.diagram-sub{color:var(--accent-gold);font-size:11px;font-weight:700;display:block}.diagram-legend{background:#00000026;flex-wrap:wrap;gap:16px;padding:8px 16px;display:flex}.legend-item{color:#fff;align-items:center;gap:5px;font-size:11px;display:flex}.legend-dot{border:1.5px solid #ffffff80;border-radius:50%;flex-shrink:0;width:12px;height:12px;display:inline-block}.legend-arrow-icon{color:#ffffffb3;font-size:16px;line-height:1}.diagram-canvas{cursor:default;width:100%;height:300px;display:block}.diagram-actions{background:#0003;border-top:1px solid #ffffff0f;gap:10px;padding:12px 16px;display:flex}.diagram-actions .btn-outline{color:#4caf7d;border-color:#4caf7d66;padding:8px 16px;font-size:12px}.diagram-actions .btn-outline:hover{background:#4caf7d26}.admin-container{background:var(--bg-primary);height:calc(100vh - 100px);color:var(--text-secondary);margin:-20px;display:flex;overflow:hidden}.admin-sidebar{background:var(--bg-card);border-right:1px solid var(--border-color);flex-direction:column;gap:5px;width:240px;padding:10px;display:flex}.dark .admin-sidebar{background:var(--bg-sidebar);border-right-color:var(--border-color)}.admin-nav-item{color:var(--text-muted);cursor:pointer;text-align:left;font-family:var(--font-body);background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;padding:12px 15px;font-size:.95rem;transition:all .2s;display:flex}.admin-nav-item:hover{background:var(--bg-primary);color:var(--text-primary)}.admin-nav-item.active{background:var(--accent);color:var(--white);font-weight:700}.admin-content{flex:1;padding:30px;overflow-y:auto}.section-header{margin-bottom:30px}.section-header h2{color:var(--text-primary);margin-bottom:5px;font-size:1.8rem}.dark .section-header h2{color:var(--text-primary)}.section-header p{color:var(--text-muted)}.add-team-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;margin-bottom:30px;padding:20px}.dark .add-team-card{background:var(--bg-card);border-color:var(--border-color)}.add-team-card h3{margin-bottom:15px;font-size:1rem}.form-row{gap:10px;display:flex}.form-row input{background:var(--input-bg);border:1px solid var(--border-color);color:var(--input-text);font-family:var(--font-body);border-radius:6px;outline:none;flex:1;padding:10px 15px;transition:all .2s}.form-row input::placeholder{color:var(--text-muted);opacity:.6}.form-row input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #4caf7d1a}.teams-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.team-admin-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:12px;align-items:center;gap:15px;padding:15px;transition:all .2s;display:flex;box-shadow:0 2px 8px #00000005}.dark .team-admin-card{background:var(--bg-card)}.team-admin-card.active{border-color:var(--accent);background:var(--bg-primary)}.team-badge{color:#fff;border-radius:12px;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.5rem;font-weight:700;display:flex}.team-info{flex:1}.team-info h4{color:var(--text-primary);margin:0;font-size:1rem}.team-info span{color:var(--text-muted);font-size:.8rem}.team-actions{flex-direction:column;gap:5px;display:flex}.btn-select{background:var(--accent);color:var(--white);cursor:pointer;border:none;border-radius:4px;padding:5px 12px;font-size:.75rem;font-weight:700}.team-admin-card.active .btn-select{background:var(--primary);color:var(--white)}.btn-delete-icon{color:#555;cursor:pointer;background:0 0;border:none;padding:5px}.btn-delete-icon:hover{color:#ef4444}.export-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px;display:grid}.export-card{background:var(--bg-card);text-align:center;border:1px solid var(--border-color);border-radius:16px;flex-direction:column;align-items:center;gap:15px;padding:30px;display:flex;box-shadow:0 4px 12px #0000000d}.dark .export-card{background:var(--bg-card);border-color:var(--border-color)}.export-icon{color:var(--accent);background:#4caf7d1a;border-radius:50%;padding:15px}.export-card h3{margin:0}.export-card p{color:var(--text-muted);font-size:.9rem;line-height:1.4}.admin-select-export{background:var(--bg-primary);width:100%;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;outline:none;padding:10px}.dark .admin-select-export{background:var(--bg-primary);color:var(--text-secondary);border-color:var(--border-color)}.btn-export{background:var(--accent);width:100%;color:var(--white);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:12px;font-weight:700;transition:opacity .2s;display:flex}.btn-export.outline{border:2px solid var(--accent);color:var(--accent);background:0 0}.btn-export:hover{opacity:.9}.exercise-list-admin{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.dark .exercise-list-admin{background:var(--bg-card);border-color:var(--border-color)}.exercise-row:hover{border-left:4px solid var(--gold);background:#d4a8430d;padding-left:16px;transition:all .2s}.exercise-row{border-bottom:1px solid #ffffff0d;align-items:center;padding:15px 20px;display:flex}.exercise-row:last-child{border-bottom:none}.ex-info{flex-direction:column;flex:1;display:flex}.ex-info strong{color:var(--text-primary);font-size:1rem}.ex-info span{color:var(--text-muted);font-size:.8rem}.settings-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px;display:grid}.settings-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;gap:20px;padding:25px;display:flex}.card-header-icon{color:var(--accent);align-items:center;gap:12px;display:flex}.card-header-icon h3{color:var(--text-primary);margin:0;font-size:1.1rem}.dark .card-header-icon h3{color:var(--text-primary)}.settings-form{flex-direction:column;gap:15px;padding-bottom:24px;display:flex}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem}.form-group input[type=text],.admin-select-input{background:var(--input-bg);border:1px solid var(--border-color);color:var(--input-text);border-radius:8px;outline:none;padding:12px;font-family:inherit;transition:all .2s}.form-group input[type=text]::placeholder{color:var(--text-muted);opacity:.6}.form-group input[type=text]:focus,.admin-select-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #4caf7d1a}.form-row-dual{grid-template-columns:1fr 1fr;gap:15px;display:grid}.form-group input[type=color]{background:var(--bg-primary);border:1px solid var(--border-color);cursor:pointer;border-radius:8px;width:100%;height:40px;padding:2px}.upload-placeholder{color:var(--secondary-color);cursor:pointer;border:2px dashed #0003;border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:20px;transition:all .2s;display:flex}.dark .upload-placeholder{border-color:var(--border-color)}.upload-placeholder:hover{border-color:var(--accent);color:var(--accent);background:#4caf7d0d}.btn-save-settings{background:var(--accent);color:var(--white);cursor:pointer;border:none;border-radius:8px;margin-bottom:40px;padding:12px;font-weight:700;transition:all .1s}.btn-save-settings:active{transform:scale(.98)}.toggle-group{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.toggle-switch{background:var(--border-color);cursor:pointer;border-radius:12px;width:44px;height:24px;position:relative}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:all .2s;position:absolute;top:3px;left:3px}.toggle-switch.active{background:var(--accent)}.toggle-switch.active:after{left:23px}.login-page{background-color:var(--bg-primary);background:radial-gradient(ellipse at 20% 50%, var(--bg-gradient-start) 0%, var(--bg-gradient-mid) 50%, var(--bg-gradient-end) 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-container{flex-direction:column;align-items:center;width:100%;max-width:400px;padding:20px;display:flex}.login-logo h1{font-family:var(--font-title);color:var(--text-primary);text-shadow:0 4px 10px #00000080;letter-spacing:2px;margin:0 0 30px;font-size:3rem}.login-logo span{color:var(--gold)}.login-card{background:var(--bg-card);width:100%;box-shadow:0 10px 30px var(--shadow-color);text-align:center;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:16px;padding:40px 30px}.login-card h2{font-family:var(--font-title);color:var(--text-primary);margin:0 0 10px;font-size:1.5rem}.login-subtitle{color:var(--text-secondary);margin:0 0 30px;font-size:14px;line-height:1.5}.login-error{background:var(--bg-primary);color:var(--error-color);border:1px solid var(--border-color);border-radius:8px;margin-bottom:20px;padding:15px;font-size:13px}.btn-google{background:var(--white);width:100%;font-family:var(--font-body);color:var(--body-color);cursor:pointer;border:1px solid #0000001a;border-radius:8px;justify-content:center;align-items:center;gap:12px;padding:12px;font-size:15px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 2px 4px #0000000d}.btn-google:hover{background:#f9f9f9;transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.btn-google:disabled{opacity:.7;cursor:not-allowed;transform:none}.google-icon{width:20px;height:20px}.login-footer{border-top:1px solid var(--border-color);margin-top:30px;padding-top:20px}.login-footer p{color:var(--text-muted);margin:0;font-size:11px;font-weight:600}.dark .login-page{background:radial-gradient(at 20%,#0d1f0d 0%,#050505 50%,#000 100%)}.dark .btn-google{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}.dark .btn-google:hover{background:#ffffff0d}.placeholder-page{background-color:var(--bg-primary);text-align:center;justify-content:center;align-items:center;min-height:100%;padding:40px;display:flex}.placeholder-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:24px;max-width:500px;padding:50px;box-shadow:0 10px 30px #1b3a2d14}.placeholder-icon{color:var(--gold);margin-bottom:24px;animation:10s linear infinite rotate}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.placeholder-content h1{color:var(--primary);margin:0 0 16px;font-family:Georgia,serif;font-size:2rem}.placeholder-content p{color:var(--text-secondary);margin-bottom:30px;font-weight:600;line-height:1.6}.loading-bar{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;width:100%;height:8px;margin-bottom:40px;overflow:hidden}.loading-fill{background:var(--accent);border-radius:3px;width:65%;height:100%;animation:2s ease-in-out infinite pulse}.btn-back{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:12px 24px;font-weight:700;transition:transform .2s}.btn-back:hover{background:#0d2018;transform:scale(1.05)}.global-loader{background-color:var(--primary);z-index:9999;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.loader-content{color:var(--white);flex-direction:column;align-items:center;gap:20px;display:flex}.loader-logo{font-family:var(--font-title);letter-spacing:3px;text-transform:uppercase;font-size:3rem;font-weight:900}.loader-logo span{color:var(--accent);font-family:var(--font-numbers)}.spinner{border:4px solid #ffffff1a;border-top:4px solid var(--accent);border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}.loader-content p{letter-spacing:1px;text-transform:uppercase;opacity:.7;font-size:.9rem;font-weight:500}
