@keyframes subtle-pulse{0%,to{opacity:.9}50%{opacity:1}}@keyframes rotate-hint{0%,50%,to{transform:rotate(0deg)}25%,75%{transform:rotate(-15deg)}}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}:root{--primary-blue:#00618c;--secondary-blue:#3DFAFF;--light-blue:#e2e8f0;--dark-blue:#3D7068;--page-background:#e7dfc7;--white:#ffffff;--light-gray:#f8fafc;--gray:#64748b;--dark-gray:#334155;--green:#43C59E;--light-green:#43C59E;--shadow:var(--primary-blue-10);--error:#8C2A00;--error-hover:#b91c1c;--error-dark:#991b1b;--warning:#fbbf24;--field-green:#5a6b01;--field-green-mid:#14453d;--brown:#8b4513;--brown-dark:#654321;--brown-light:#a0522d;--opponent-red:#8C2A00;--opponent-red-secondary:#F75270;--primary-blue-05:rgba(0, 97, 140, 0.05);--primary-blue-08:rgba(0, 97, 140, 0.08);--primary-blue-10:rgba(0, 97, 140, 0.1);--primary-blue-12:rgba(0, 97, 140, 0.12);--primary-blue-15:rgba(0, 97, 140, 0.15);--primary-blue-20:rgba(0, 97, 140, 0.2);--primary-blue-25:rgba(0, 97, 140, 0.25);--primary-blue-30:rgba(0, 97, 140, 0.3);--primary-blue-35:rgba(0, 97, 140, 0.35);--primary-blue-40:rgba(0, 97, 140, 0.4);--white-05:rgba(255, 255, 255, 0.05);--white-10:rgba(255, 255, 255, 0.1);--white-15:rgba(255, 255, 255, 0.15);--white-20:rgba(255, 255, 255, 0.2);--white-25:rgba(255, 255, 255, 0.25);--white-30:rgba(255, 255, 255, 0.3);--white-40:rgba(255, 255, 255, 0.4);--white-50:rgba(255, 255, 255, 0.5);--white-60:rgba(255, 255, 255, 0.6);--white-70:rgba(255, 255, 255, 0.7);--white-80:rgba(255, 255, 255, 0.8);--white-90:rgba(255, 255, 255, 0.9);--white-95:rgba(255, 255, 255, 0.95);--black-05:rgba(0, 0, 0, 0.05);--black-10:rgba(0, 0, 0, 0.1);--black-15:rgba(0, 0, 0, 0.15);--black-25:rgba(0, 0, 0, 0.25);--black-40:rgba(0, 0, 0, 0.4);--error-20:rgba(140, 42, 0, 0.2);--error-25:rgba(140, 42, 0, 0.25);--error-30:rgba(140, 42, 0, 0.3);--error-35:rgba(140, 42, 0, 0.35);--bg-card:var(--white-90);--bg-card-hover:rgba(219, 234, 254, 0.8);--bg-card-selected:rgba(219, 234, 254, 0.9);--bg-form:rgba(248, 250, 252, 0.8);--bg-green-light:rgba(220, 252, 231, 0.8);--bg-nav:var(--white-15);--bg-modal:rgba(0, 0, 0, 0.4);--bg-instructions:rgba(219, 234, 254, 0.8);--border-white:var(--white-30);--border-white-light:var(--white-40);--border-white-dark:var(--white-10);--border-gray:rgba(100, 116, 139, 0.1);--border-gray-15:rgba(100, 116, 139, 0.15);--font-display:"Inter", "SF Pro Display", -apple-system, BlinkMacSystemFont, sans-serif;--font-body:"Inter", "SF Pro Text", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", Consolas, monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-body);background:var(--page-background);min-height:100vh;color:var(--dark-gray);font-size:var(--text-base);line-height:var(--leading-normal);font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;position:relative}body::before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 60% 30%,var(--white-10) 0%,transparent 40%),radial-gradient(circle at 30% 70%,var(--white-05) 0%,transparent 40%);pointer-events:none;z-index:-1}.page{display:block}.hidden,.page.hidden{display:none}.danger-button:active,.login-button:active,.primary-button:active,.secondary-button:active{transform:translateY(0) scale(.98);transition:all .1s ease}.control-button:active{transform:scale(1.02);transition:all .1s ease}.nav-button:active,.nav-step-button:active,.tool-button:active{transform:translateY(0) scale(.98);transition:all .1s ease}.danger-button:focus,.login-button:focus,.primary-button:focus,.secondary-button:focus{outline:2px solid var(--primary-blue);outline-offset:2px}.logout-button:focus,.nav-button:focus{outline:2px solid var(--white-50);outline-offset:2px}.control-button:focus,.nav-step-button:focus,.tool-button:focus{outline:2px solid var(--primary-blue);outline-offset:2px}button:disabled{cursor:not-allowed;opacity:.6}button:disabled,button:disabled:hover{transform:none!important;box-shadow:none!important}.content-page{display:block}.content-page.hidden{display:none}.create-play-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.create-play-header h2{font-size:var(--text-3xl);font-family:var(--font-display);font-weight:600;line-height:var(--leading-tight);letter-spacing:-.025em}.header-actions{display:flex;gap:1rem}.primary-button{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue) 100%);color:var(--white);border:0;box-shadow:0 4px 14px 0 var(--primary-blue-25)}.primary-button:hover{background:linear-gradient(135deg,var(--dark-blue) 0%,var(--primary-blue) 100%);transform:translateY(-2px);box-shadow:0 8px 25px 0 var(--primary-blue-35)}.primary-button::before{background:linear-gradient(90deg,transparent,var(--white-20),transparent)}.danger-button:hover::before,.primary-button:hover::before,.secondary-button:hover::before,.tool-button:hover::before{left:100%}.danger-button,.primary-button,.secondary-button{padding:.875rem 2rem;border-radius:.75rem;font-size:var(--text-sm);font-weight:600;font-family:var(--font-display);letter-spacing:.025em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;backdrop-filter:blur(10px)}.secondary-button{background:var(--primary-blue-08);color:var(--primary-blue);border:1px solid var(--primary-blue-20)}.secondary-button:hover{background:var(--primary-blue);color:var(--white);border-color:var(--primary-blue);transform:translateY(-2px);box-shadow:0 8px 25px 0 var(--primary-blue-25)}.danger-button::before,.primary-button::before,.secondary-button::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;transition:left .6s}.secondary-button::before{background:linear-gradient(90deg,transparent,var(--primary-blue-10),transparent)}.danger-button{background:linear-gradient(135deg,var(--error) 0%,var(--error) 100%);color:var(--white);border:0;box-shadow:0 4px 14px 0 var(--error-25)}.danger-button:hover{background:linear-gradient(135deg,var(--error-hover) 0%,var(--error-dark) 100%);transform:translateY(-2px);box-shadow:0 8px 25px 0 var(--error-35)}.danger-button::before{background:linear-gradient(90deg,transparent,var(--white-20),transparent)}.play-form-container{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.play-form-container::before,.step-editor-container::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.step-editor-container{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.step-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.create-play-header h2,.field-editor-header h3,.step-editor-header h3{color:var(--primary-blue)}.step-controls{display:flex;align-items:center;gap:1rem}.current-step-info{color:var(--gray);font-size:.875rem}.step-navigation{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--bg-form);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;border:1px solid var(--white-40);position:relative;overflow:hidden}.step-navigation::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-50),transparent)}.nav-step-button{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue) 100%);color:var(--white);border:0;padding:.75rem 1.25rem;border-radius:.5rem;font-size:var(--text-sm);font-family:var(--font-display);font-weight:500;letter-spacing:.025em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 8px var(--primary-blue-20)}.nav-step-button:hover:not(:disabled){background:linear-gradient(135deg,var(--dark-blue) 0%,var(--primary-blue) 100%);transform:translateY(-1px);box-shadow:0 4px 16px var(--primary-blue-30)}.nav-step-button::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--white-20),transparent);transition:left .6s}.nav-step-button:hover:not(:disabled)::before{left:100%}.nav-step-button:disabled{opacity:.5;cursor:not-allowed;background:var(--gray);box-shadow:none;transform:none}.step-timeline{flex:1;display:flex;flex-direction:column;gap:.5rem}.step-timeline input{width:100%;height:6px;background:var(--light-blue);border-radius:3px;outline:0;cursor:pointer;-webkit-appearance:none}.step-timeline input::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary-blue);cursor:pointer}.step-time-display{text-align:center;font-size:.875rem;color:var(--dark-blue);font-weight:500}.field-editor-container{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.field-editor-container::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.field-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.editor-tools,.tool-group{display:flex;gap:2rem;align-items:center}.tool-group{gap:.5rem}.tool-group label{color:var(--dark-blue);font-size:.875rem;font-weight:500}.tool-button{background:var(--primary-blue-08);color:var(--primary-blue);border:1px solid var(--primary-blue-20);padding:.75rem 1.25rem;border-radius:.5rem;font-size:var(--text-sm);font-family:var(--font-display);font-weight:500;letter-spacing:.025em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);position:relative;overflow:hidden}.tool-button:hover:not(.active){background:var(--primary-blue-12);border-color:var(--primary-blue-30);transform:translateY(-1px)}.tool-button.active{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue) 100%);color:var(--white);border-color:var(--primary-blue);box-shadow:0 4px 14px 0 var(--primary-blue-25);transform:translateY(-1px)}.tool-button::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--primary-blue-10),transparent);transition:left .6s}.editor-field{position:relative;margin-bottom:1rem}.field-instructions{background:var(--bg-card-hover);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);padding:1rem;border-radius:12px;border:1px solid var(--white-40);position:relative;overflow:hidden}.field-instructions::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-60),transparent)}.field-instructions p{color:var(--primary-blue);font-weight:500;margin-bottom:.5rem}.field-instructions ul{list-style:none;padding:0}.field-instructions li{color:var(--dark-blue);font-size:.875rem;margin-bottom:.25rem;padding-left:1rem;position:relative}.field-instructions li::before{content:"→";position:absolute;left:0;color:var(--primary-blue)}.player-editor-panel{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.player-editor-panel::before,.removed-players-panel::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.player-editor-panel h4,.removed-players-panel h4{color:var(--primary-blue);margin-bottom:1rem}.player-form{display:flex;flex-direction:column;gap:1rem}.player-form button{height:fit-content;margin-top:.5rem}.removed-players-panel{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.main-content{padding:2rem;max-width:1400px;margin:0 auto}.play-selector-container{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 8px 32px var(--primary-blue-10),0 2px 16px var(--primary-blue-05),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.play-selector-container::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-60),transparent)}.play-selector{display:flex;align-items:center;gap:1rem}.play-selector label{color:var(--dark-blue);font-weight:500;white-space:nowrap}.play-selector select{flex:1;padding:.75rem 1rem;border:2px solid var(--light-blue);border-radius:8px;font-size:1rem;color:var(--dark-blue);background:var(--white);cursor:pointer;transition:border-color .2s ease}.input-group input:focus,.play-selector select:focus{outline:0;border-color:var(--primary-blue);box-shadow:0 0 0 3px var(--primary-blue-10)}.play-info{text-align:center;margin-bottom:2rem}.play-info h2,.timeline-header h3{color:var(--primary-blue);font-family:var(--font-display);font-weight:600}.play-info h2{font-size:var(--text-3xl);margin-bottom:.5rem;line-height:var(--leading-tight);letter-spacing:-.025em}.login-header p,.play-info p{color:var(--gray);font-size:var(--text-lg);font-weight:400;line-height:var(--leading-relaxed)}.field-container{background:var(--white-95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;padding:2rem;margin-bottom:2rem;box-shadow:0 16px 64px var(--primary-blue-12),0 4px 32px var(--primary-blue-08),inset 0 1px 0 var(--white-50);border:1px solid var(--white-30);position:relative;overflow:hidden;max-width:1200px;margin-left:auto;margin-right:auto}.field-container-inner{position:relative;width:100%;padding-bottom:50%;overflow:hidden}.field-container::before,.rugby-field::before{content:"";position:absolute;top:0;left:0;right:0}.field-container::before{height:2px;background:linear-gradient(90deg,transparent,var(--white-80),transparent)}.rugby-field{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:12px;box-shadow:0 8px 32px rgba(90,107,1,.2),0 2px 16px rgba(90,107,1,.1),inset 0 2px 4px var(--black-05);background:var(--field-green);overflow:visible}.rugby-field::before{bottom:0;background:radial-gradient(circle at 30% 40%,var(--white-05) 0%,transparent 50%),radial-gradient(circle at 70% 60%,var(--white-05) 0%,transparent 50%);pointer-events:none}.timeline-container{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.timeline-container::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.timeline-header h3{font-size:var(--text-xl);line-height:var(--leading-snug)}.play-controls{display:flex;align-items:center;gap:1rem}.control-button,.control-button::after{border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1)}.control-button{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue) 100%);color:var(--white);border:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;box-shadow:0 4px 14px 0 var(--primary-blue-25);backdrop-filter:blur(10px)}.control-button:hover{background:linear-gradient(135deg,var(--dark-blue) 0%,var(--primary-blue) 100%);transform:scale(1.08) translateY(-2px);box-shadow:0 8px 25px 0 var(--primary-blue-35)}.control-button::after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:var(--white-30);transform:translate(-50%,-50%)}.control-button:hover::after{width:100%;height:100%}.speed-control{display:flex;align-items:center;gap:.5rem;color:var(--dark-blue);font-size:.875rem}.speed-control select{padding:.25rem .5rem;border:1px solid var(--light-blue);border-radius:4px;color:var(--dark-blue);background:var(--white)}.timeline-slider-container,.timeline-track{position:relative}.timeline-track{margin-bottom:1rem}.timeline-slider{width:100%;height:8px;border-radius:4px;background:var(--light-blue);outline:0;cursor:pointer;-webkit-appearance:none}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-blue);cursor:pointer;box-shadow:0 2px 6px var(--primary-blue-30);transition:all .2s ease}.timeline-slider:hover::-webkit-slider-thumb{transform:scale(1.1);box-shadow:0 4px 12px var(--primary-blue-40)}.timeline-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-blue);cursor:pointer;border:0;box-shadow:0 2px 6px var(--primary-blue-30)}.step-marker,.step-markers{position:absolute;height:12px}.step-markers{top:-2px;left:0;right:0;pointer-events:none}.step-marker{width:3px;background:var(--primary-blue);border-radius:2px;cursor:pointer;pointer-events:auto;transition:all .2s ease}.step-marker:hover{background:var(--dark-blue);transform:scaleY(1.2)}.timeline-labels{display:flex;justify-content:space-between;color:var(--gray);font-size:.875rem}.player-legend{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.player-item::before,.player-legend::before{content:"";position:absolute;top:0;left:0;right:0;height:1px}.player-legend::before{background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.player-legend h4{color:var(--primary-blue);margin-bottom:1rem;font-size:var(--text-lg);font-family:var(--font-display);font-weight:600;line-height:var(--leading-snug)}.player-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.player-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:12px;background:rgba(248,250,252,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--white-40);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.player-item::before{background:linear-gradient(90deg,transparent,var(--white-50),transparent)}.player-item:hover{background:var(--bg-card-hover);transform:translateX(6px) translateY(-1px);box-shadow:0 4px 16px var(--primary-blue-10),0 1px 8px var(--primary-blue-05),inset 0 1px 0 var(--white-50);border-color:var(--primary-blue-20)}.player-circle,.rotate-hint svg{width:24px;height:24px;flex-shrink:0}.player-circle{border-radius:50%;background:var(--primary-blue);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.player-info{flex:1}.player-position{font-weight:600;color:var(--dark-blue);font-size:var(--text-sm);font-family:var(--font-display);line-height:var(--leading-snug)}.player-action{color:var(--gray);font-size:var(--text-xs);font-weight:400;line-height:var(--leading-normal)}.field-player{transition:all .8s cubic-bezier(.4,0,.2,1)}.field-player circle{fill:var(--primary-blue);stroke:var(--white);stroke-width:2}.field-player text{fill:var(--white);font-weight:700;font-size:12px;font-family:var(--font-display);text-anchor:middle;dominant-baseline:central}.field-player:hover circle{fill:var(--dark-blue)}.control-button.scribble-active{background:linear-gradient(135deg,#f59e0b 0,#d97706 100%);box-shadow:0 4px 14px 0 rgba(245,158,11,.4)}.control-button.scribble-active:hover{background:linear-gradient(135deg,#d97706 0,#b45309 100%);box-shadow:0 8px 25px 0 rgba(245,158,11,.5)}.scribble-path{fill:none;stroke:#f59e0b;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;pointer-events:none;opacity:.8}.rugby-field.scribble-mode{cursor:crosshair}.rotate-hint{position:absolute;bottom:16px;right:16px;display:none;align-items:center;gap:8px;background:rgba(0,0,0,.75);padding:10px 14px;border-radius:8px;border:0;cursor:pointer;z-index:100;animation:subtle-pulse 2s ease-in-out infinite;transition:background .2s ease;-webkit-tap-highlight-color:transparent}.rotate-hint:active{background:rgba(0,0,0,.85)}.rotate-hint svg{color:#fff}.rotate-hint .rotate-arrow{width:20px;height:20px;animation:rotate-hint 1.5s ease-in-out infinite}@media (max-width:1024px) and (orientation:portrait){.rotate-hint{display:flex}}@media (orientation:landscape){.rotate-hint{display:none!important}}:-moz-full-screen .rotate-hint,:-ms-fullscreen .rotate-hint,:-webkit-full-screen .rotate-hint,:fullscreen .rotate-hint{display:none!important}.fundamentals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:1.5rem;border-radius:20px;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.fundamentals-header::before,.login-form::before{content:"";position:absolute;top:0;left:0;right:0;height:1px}.fundamentals-header::before{background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.fundamentals-header h2,.login-header h1{font-size:var(--text-3xl);font-family:var(--font-display);font-weight:600;line-height:var(--leading-tight);letter-spacing:-.025em}.admin-only,.coach-only{display:none}.user-role-admin .admin-only,.user-role-coach .coach-only{display:flex}.user-role-admin .nav-button.admin-only,.user-role-coach .nav-button.coach-only{display:inline-flex}.logo-image{width:80px;height:80px;object-fit:contain;border-radius:12px;box-shadow:0 4px 12px var(--shadow)}.logo-image.header-logo{width:50px;height:50px;margin-right:.5rem}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{color:var(--primary-blue);font-size:var(--text-4xl);margin:1rem 0 .5rem;font-weight:700}.login-form{background:var(--white-95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:2rem;border-radius:20px;box-shadow:0 8px 32px var(--primary-blue-12),0 2px 16px var(--primary-blue-08),inset 0 1px 0 var(--white-50);width:100%;max-width:400px;border:1px solid var(--white-30);position:relative;overflow:hidden}.login-form::before{background:linear-gradient(90deg,transparent,var(--white-80),transparent)}.input-group{margin-bottom:1.5rem}.input-group label{display:block;margin-bottom:.5rem;color:var(--dark-blue);font-family:var(--font-display);line-height:var(--leading-snug);letter-spacing:.025em}.input-group input,.login-button{width:100%;font-size:var(--text-base)}.input-group input{padding:.75rem 1rem;border:2px solid var(--light-blue);border-radius:8px;font-family:var(--font-body);line-height:var(--leading-normal);transition:all .2s ease}.login-button{background:linear-gradient(135deg,var(--primary-blue) 0%,var(--primary-blue) 100%);color:var(--white);border:0;padding:.875rem 2rem;border-radius:.75rem;font-weight:600;font-family:var(--font-display);letter-spacing:.025em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 14px 0 var(--primary-blue-25);backdrop-filter:blur(10px)}.login-button:hover{background:linear-gradient(135deg,var(--dark-blue) 0%,var(--primary-blue) 100%);transform:translateY(-2px);box-shadow:0 8px 25px 0 var(--primary-blue-35)}.login-button::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--white-20),transparent);transition:left .6s}.close-button:hover::before,.icon-button:hover::before,.login-button:hover::before,.logout-button:hover::before,.nav-button:hover::before,.remove-button:hover::before{left:100%}.login-button:active{transform:translateY(0)}.error-message,.input-group label{font-size:var(--text-sm);font-weight:500}.error-message{color:var(--error);text-align:center;margin-top:1rem;line-height:var(--leading-normal)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-modal);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal.hidden{display:none!important}.modal-content{background:var(--white-95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 32px 80px rgba(0,0,0,.25),0 16px 40px rgba(0,0,0,.15),inset 0 2px 0 var(--white-60);border:1px solid var(--white-30);position:relative;overflow:hidden}.modal-content::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--white-80),transparent)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--light-blue)}.fundamental-card-header h3,.fundamentals-header h2,.modal-header h3,.section-header h4{color:var(--primary-blue);margin:0}.close-button{background:var(--border-gray);border:0;font-size:1.25rem;cursor:pointer;color:var(--gray);padding:.5rem;border-radius:.375rem;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.close-button:hover{background:var(--border-gray-15);color:var(--dark-gray);transform:scale(1.1)}.close-button::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--border-gray),transparent);transition:left .6s}.modal-body{padding:1.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid var(--light-blue)}.section{margin-bottom:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.principles-container,.roles-container{display:flex;flex-direction:column;gap:1rem}.principle-form,.role-form{padding:1rem;background:var(--bg-form);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;border:1px solid var(--white-40);position:relative;overflow:hidden}.principle-form::before,.role-form::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-50),transparent)}.principle-form-header,.role-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.remove-button,.shortcut-item kbd{font-family:var(--font-display);font-weight:600}.remove-button{background:linear-gradient(135deg,var(--error) 0%,var(--error) 100%);color:var(--white);border:0;padding:.5rem .75rem;border-radius:.375rem;font-size:var(--text-xs);letter-spacing:.025em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 2px 8px var(--error-20)}.remove-button:hover{background:linear-gradient(135deg,var(--error-hover) 0%,var(--error-dark) 100%);transform:translateY(-1px);box-shadow:0 4px 16px var(--error-30)}.remove-button::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--white-20),transparent);transition:left .6s}.form-row-2{display:grid;grid-template-columns:1fr 2fr;gap:1rem}@media (max-width:768px){.fundamental-card-header,.fundamentals-header{flex-direction:column;gap:1rem;align-items:stretch}.fundamental-card-header{align-items:flex-start}.fundamental-actions{align-self:flex-end}.modal-content{width:95%;margin:1rem}.modal-actions,.section-header{flex-direction:column}.section-header{align-items:flex-start;gap:1rem}.form-row-2,.roles-grid{grid-template-columns:1fr}}.shortcuts-list{display:flex;flex-direction:column;gap:1rem}.shortcut-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg-form);border-radius:8px;border:1px solid var(--white-40)}.shortcut-item kbd{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;height:2rem;padding:.25rem .75rem;background:linear-gradient(135deg,var(--white-95),var(--white-80));border:1px solid var(--border-gray);border-radius:6px;font-size:var(--text-sm);color:var(--dark-gray);box-shadow:0 2px 4px var(--shadow-light),inset 0 1px 0 var(--white)}.scribble-hint-content p,.shortcut-item span{color:var(--dark-gray);font-size:var(--text-base)}.shortcut-item span{flex:1}.info-button{background:0 0!important;box-shadow:none!important;color:var(--gray);border:0;opacity:.6}.info-button:hover{background:var(--white-20)!important;opacity:1;box-shadow:none!important}.info-button .info-icon{font-size:1.25rem}@media (max-width:768px){.shortcut-item{gap:.75rem;padding:.625rem .75rem}.shortcut-item kbd{min-width:2rem;height:1.75rem;font-size:var(--text-xs)}.shortcut-item span{font-size:var(--text-sm)}.info-button{display:none}}.scribble-hint{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1001;background:var(--white-95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:16px;padding:1.5rem;box-shadow:0 20px 60px rgba(0,0,0,.3),0 10px 30px rgba(0,0,0,.2),inset 0 2px 0 var(--white-60);border:1px solid var(--white-30);min-width:280px;text-align:center;animation:fadeInScale .3s cubic-bezier(.4,0,.2,1)}.scribble-hint.hidden{display:none}.scribble-hint-content p{margin:.5rem 0}.scribble-hint-content p:first-child{font-weight:600;color:var(--primary-blue)}.header-left h1,.hint-dismiss{font-weight:600;font-family:var(--font-display)}.hint-dismiss{margin-top:1rem;background:linear-gradient(135deg,var(--primary-blue) 0%,var(--secondary-blue) 100%);color:var(--white);border:0;padding:.75rem 1.5rem;border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px var(--primary-shadow)}.hint-dismiss:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--primary-shadow)}.app-header,.header-left{display:flex;align-items:center}.app-header{background:var(--primary-blue);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);color:var(--white);padding:1rem 2rem;justify-content:space-between;box-shadow:0 8px 32px var(--primary-blue-20),0 2px 16px var(--primary-blue-10),inset 0 1px 0 var(--white-20);border-bottom:1px solid var(--white-10);position:sticky;top:0;z-index:100;position:relative;overflow:hidden}.app-header::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--white-40),transparent);pointer-events:none}.header-left{gap:1rem}.mobile-menu-button{display:none;background:var(--white-15);border:1px solid var(--white-20);width:44px;height:44px;border-radius:.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);position:relative;overflow:hidden;flex-shrink:0}.mobile-menu-button:hover{background:var(--white-25);transform:translateY(-1px)}.hamburger-icon,.hamburger-icon::after,.hamburger-icon::before{display:block;width:20px;height:2px;background:var(--white);transition:all .3s ease}.hamburger-icon{position:relative;margin:0 auto}.hamburger-icon::after,.hamburger-icon::before{content:"";position:absolute;left:0}.hamburger-icon::before{top:-6px}.hamburger-icon::after{top:6px}.mobile-menu-button.active .hamburger-icon{background:0 0}.mobile-menu-button.active .hamburger-icon::before{top:0;transform:rotate(45deg)}.mobile-menu-button.active .hamburger-icon::after{top:0;transform:rotate(-45deg)}.mobile-menu,.mobile-menu-overlay{position:fixed;top:0;left:0;height:100%}.mobile-menu-overlay{width:100%;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.mobile-menu-overlay.active{opacity:1;visibility:visible}.mobile-menu{width:280px;max-width:80vw;background:var(--white-95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:2px 0 24px rgba(0,0,0,.2);transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1000;display:flex;flex-direction:column}.mobile-menu-overlay.active .mobile-menu{transform:translateX(0)}.close-menu-button,.mobile-menu-header{color:var(--white);display:flex;align-items:center}.mobile-menu-header{justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--light-blue);background:var(--primary-blue)}.mobile-menu-header h2{margin:0;font-size:var(--text-xl);font-weight:600;color:var(--white)}.close-menu-button{background:var(--white-15);border:1px solid var(--white-20);width:36px;height:36px;border-radius:.375rem;font-size:1.5rem;cursor:pointer;transition:all .3s ease;justify-content:center;line-height:1}.close-menu-button:hover{background:var(--white-25)}.mobile-menu-items{padding:1rem 0;overflow-y:auto;flex:1}.mobile-menu-item{width:100%;padding:1rem 1.5rem;background:0 0;border:0;text-align:left;font-size:var(--text-base);font-weight:500;color:var(--primary-blue);cursor:pointer;transition:all .2s ease;position:relative;border-left:3px solid transparent}.mobile-menu-item:hover{background:var(--primary-blue-08);border-left-color:var(--primary-blue)}.mobile-menu-item.active{background:var(--primary-blue-12);border-left-color:var(--primary-blue);font-weight:600}.header-left h1{font-size:var(--text-2xl);line-height:var(--leading-tight);letter-spacing:-.025em}.header-center{flex:1;display:flex;justify-content:center}.main-nav{display:flex;gap:.25rem;background:var(--white-15);padding:.375rem;border-radius:.75rem;backdrop-filter:blur(10px);border:1px solid var(--white-10)}.nav-button{background:0 0;color:var(--white-80);border:0;padding:.75rem 1.25rem;border-radius:.5rem;font-size:var(--text-sm);font-family:var(--font-display);font-weight:500;letter-spacing:.025em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.nav-button:hover:not(.active){background:var(--white-15);color:#fff;transform:translateY(-1px)}.nav-button.active{background:var(--white-25);color:#fff;font-weight:600;box-shadow:0 2px 8px var(--black-10)}.icon-button::before,.logout-button::before,.nav-button::before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--white-10),transparent);transition:left .6s}.header-right,.icon-button{display:flex;align-items:center}.header-right{gap:1rem}.icon-button{background:var(--white-15);color:var(--white);border:1px solid var(--white-20);width:44px;height:44px;border-radius:.5rem;font-size:1.25rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);position:relative;overflow:hidden;justify-content:center}.icon-button:hover,.logout-button:hover{background:var(--white-25);transform:translateY(-1px);box-shadow:0 4px 12px var(--black-10)}.user-info{font-size:.875rem;opacity:.9}.logout-button{background:var(--white-15);color:var(--white);border:1px solid var(--white-20);padding:.75rem 1.25rem;border-radius:.5rem;font-size:var(--text-sm);font-family:var(--font-display);font-weight:500;letter-spacing:.025em;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(10px);position:relative;overflow:hidden}.field-player.draggable{cursor:move}.field-player.dragging{opacity:.7}.field-player.selected circle{stroke:var(--warning);stroke-width:3}.field-player.multi-selected circle{stroke:var(--secondary-blue);stroke-width:3;filter:drop-shadow(0 0 4px var(--secondary-blue))}.field-player.opponent circle{fill:var(--opponent-red);stroke:var(--opponent-red-secondary)}.field-player.opponent.selected circle,.rugby-ball.selected{stroke:var(--warning);stroke-width:4}.field-player.opponent.multi-selected circle{stroke:var(--secondary-blue);stroke-width:3;filter:drop-shadow(0 0 4px var(--secondary-blue))}.rugby-ball{fill:var(--brown);stroke:var(--brown-dark);stroke-width:2;cursor:move}.rugby-ball.selected{stroke-width:3;animation:pulse 1s infinite}.rugby-ball:hover{fill:var(--brown-light)}.manage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.manage-header h2{color:var(--primary-blue);font-size:var(--text-3xl);font-family:var(--font-display);font-weight:600;line-height:var(--leading-tight);letter-spacing:-.025em}.plays-grid{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);position:relative;overflow:hidden}.play-card::before,.plays-grid::before{content:"";position:absolute;top:0;left:0;right:0;height:1px}.plays-grid::before{background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.plays-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr));gap:1rem}.play-card{background:var(--bg-form);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--white-40);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.play-card::before{background:linear-gradient(90deg,transparent,var(--white-60),transparent)}.play-card:hover{background:var(--bg-card-selected);transform:translateY(-4px);box-shadow:0 12px 40px var(--primary-blue-15),0 4px 16px var(--primary-blue-10),inset 0 1px 0 var(--white-60);border-color:var(--primary-blue-20)}.play-card.selected{border-color:var(--primary-blue-40);background:var(--bg-card-selected);box-shadow:0 8px 32px var(--primary-blue-20),0 2px 16px var(--primary-blue-10),inset 0 1px 0 var(--white-60)}.play-card h5,.play-card p{color:var(--primary-blue);margin-bottom:.5rem}.play-card p{color:var(--gray);font-size:.875rem}.play-card .play-meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--gray)}.play-actions{display:flex;justify-content:center;gap:1rem;padding:1rem}.search-filter-bar{display:flex;gap:1rem;margin:1.5rem 0;flex-wrap:wrap}.search-input{flex:1;min-width:min(250px,100%);padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--card-bg);color:var(--text-color);transition:border-color .2s}.filter-select:focus,.search-input:focus{outline:0;border-color:var(--primary-color)}.filter-select{min-width:150px;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--card-bg);color:var(--text-color);cursor:pointer;transition:border-color .2s}.users-grid{margin-top:2rem}.users-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(350px,100%),1fr));gap:1.5rem}.user-card{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px rgba(0,0,0,.1);border:1px solid var(--border-color);transition:transform .2s,box-shadow .2s}.user-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.user-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.user-info{flex:1}.user-name{font-size:1.125rem;font-weight:600;color:var(--primary-color);margin-bottom:.25rem}.user-email{font-size:.875rem;color:var(--text-secondary)}.user-card-actions{display:flex;gap:.5rem;flex-wrap:wrap}.user-card-actions button{flex:1;min-width:100px}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500;text-transform:capitalize}.role-badge.role-admin{background:#ef4444;color:#fff}.role-badge.role-editor{background:#3b82f6;color:#fff}.role-badge.role-player{background:#10b981;color:#fff}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:1.5rem;margin-top:2rem;padding:1.5rem}.pagination-button{min-width:100px}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.page-info{font-size:.95rem;color:var(--text-secondary);font-weight:500}.delete-user-btn,.edit-user-btn{padding:.5rem 1rem;margin-right:.5rem;font-size:.875rem}.fundamentals-list{display:grid;gap:1.5rem}.fundamental-card{background:var(--white-90);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;box-shadow:0 12px 48px var(--primary-blue-10),0 4px 24px rgba(37,99,235,.06),inset 0 1px 0 var(--white-40);border:1px solid var(--white-30);transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.fundamental-card::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--white-70),transparent)}.fundamental-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px var(--primary-blue-15),0 8px 32px var(--primary-blue-10),inset 0 1px 0 var(--white-60);border-color:var(--primary-blue-20)}.fundamental-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.fundamental-actions{display:flex;gap:.5rem}.fundamental-actions button{padding:.25rem .75rem;font-size:.875rem}.principles-section{margin-bottom:1.5rem}.principles-section h4,.roles-section h4{color:var(--dark-gray);margin-bottom:.75rem;font-size:1rem}.principle-item{margin-bottom:1rem;padding:1rem;background:var(--bg-form);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;border:1px solid var(--white-40);position:relative;overflow:hidden}.principle-item::before,.role-item::before{content:"";position:absolute;top:0;right:0;bottom:0;left:4px;background:linear-gradient(135deg,var(--white-10),transparent);pointer-events:none}.principle-title{font-weight:600;color:var(--primary-blue);margin-bottom:.25rem}.principle-description{color:var(--gray);font-size:.9rem}.roles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.role-item{padding:.75rem;background:var(--bg-green-light);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;border:1px solid var(--white-40);position:relative;overflow:hidden}.role-name{font-weight:600;color:var(--green);margin-bottom:.25rem}.role-responsibility{color:var(--dark-gray);font-size:.9rem}h1,h2,h3,h4,h5{font-family:var(--font-display)}h1{font-size:clamp(var(--text-2xl),4vw,var(--text-4xl));font-weight:700}h2,h3,h4,h5{font-weight:600}h1,h2{line-height:var(--leading-tight);letter-spacing:-.025em}h2{font-size:clamp(var(--text-xl),3.5vw,var(--text-3xl))}h3,h4,h5{font-size:clamp(var(--text-lg),3vw,var(--text-2xl));line-height:var(--leading-snug)}h4,h5{font-size:clamp(var(--text-base),2.5vw,var(--text-xl))}h5{font-size:clamp(var(--text-sm),2vw,var(--text-lg))}p{font-size:var(--text-base);line-height:var(--leading-normal);font-weight:400}@media (max-width:768px){.main-content{padding:1rem}.app-header{padding:.5rem 1rem;flex-direction:row;gap:.5rem;position:relative;justify-content:space-between;align-items:center}.mobile-menu-button{display:flex;align-items:center;justify-content:center}.header-center{display:none}.header-left{justify-content:flex-start;gap:.75rem;flex:0 1 auto}.header-left .logo-image{width:40px;height:40px}.header-left h1{font-size:var(--text-lg);white-space:nowrap}.header-right{gap:.5rem;flex-shrink:0;margin-left:auto}.header-right .icon-button,.user-info{display:none}.logout-button{padding:.5rem .875rem;font-size:.875rem;white-space:nowrap}.timeline-header{flex-direction:column;align-items:stretch;gap:1rem}.timeline-header h3{text-align:center;margin-bottom:.5rem}.play-controls{justify-content:center;flex-wrap:wrap;gap:1rem}.speed-control{flex-direction:column;align-items:center;gap:.25rem}.speed-control select{min-height:44px;padding:.75rem;font-size:16px;min-width:80px}.timeline-slider{height:12px}.timeline-slider::-webkit-slider-thumb{width:28px;height:28px}.timeline-slider::-moz-range-thumb{width:28px;height:28px}.step-timeline input{height:10px}.step-timeline input::-webkit-slider-thumb{width:24px;height:24px}.player-list{grid-template-columns:1fr}.login-container{padding:1rem}.login-header h1{font-size:var(--text-3xl)}.form-row{grid-template-columns:1fr;gap:1rem}.input-group input,.input-group select,.input-group textarea{font-size:16px;padding:1rem;min-height:44px}.danger-button,.primary-button,.secondary-button{min-height:48px;padding:1rem 2rem;font-size:var(--text-base);border-radius:.75rem}.control-button{width:52px;height:52px;font-size:1.25rem}.nav-step-button{min-height:44px;padding:.75rem 1rem}.step-navigation{flex-direction:column;gap:1rem;padding:1.5rem}.step-nav-buttons{display:flex;gap:1rem;justify-content:space-between}.step-nav-buttons .nav-step-button{flex:1}.editor-tools,.field-editor-header{flex-direction:column;gap:1rem;align-items:stretch}.tool-group{flex-wrap:wrap;justify-content:center}.tool-button{min-height:44px;padding:.75rem 1rem;flex:1 1 auto;min-width:min(120px,45%)}.player-form{grid-template-columns:1fr;gap:1rem}.header-actions{flex-direction:column;gap:.75rem}.plays-list{grid-template-columns:1fr}.play-card{padding:1.5rem;margin-bottom:1rem}.play-actions{flex-wrap:wrap;gap:.75rem}.play-actions button{flex:1;min-width:120px}}@media (max-width:480px){.field-container{padding:.75rem}.field-editor-container,.player-editor-panel,.player-legend,.step-editor-container,.timeline-container{padding:1rem;margin-bottom:1rem}.play-actions{flex-direction:column;gap:.75rem;padding:1rem .5rem}.play-actions button{width:100%;min-height:50px;padding:1rem;font-size:1rem;border-radius:8px;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.editor-tools{flex-direction:column;align-items:stretch;gap:1rem}.tool-group{justify-content:center}.app-header{padding:.5rem}.header-left .logo-image,.icon-button{width:36px;height:36px}.header-left h1{font-size:var(--text-base)}.login-header h1{font-size:var(--text-2xl)}.icon-button{font-size:1rem}.mobile-menu-button{width:40px;height:40px}.logout-button{padding:.5rem .75rem;font-size:.813rem}.step-nav-buttons{gap:.5rem}.control-button{width:44px;height:44px}.field-instructions{padding:.75rem}.field-instructions ul{font-size:.8rem}}@media (max-width:1024px) and (orientation:landscape){#mainApp .app-header,body:has(#viewPlayPage:not(.hidden)) .app-header{display:none!important}#mainApp .main-content{padding:0;height:100vh;overflow:hidden}#viewPlayPage{display:flex;flex-direction:column;height:100vh;padding:0;background:var(--field-green)}#viewPlayPage .play-info,#viewPlayPage .play-selector-container,#viewPlayPage .player-legend{display:none!important}#viewPlayPage .field-container{flex:1;padding:0;margin:0;height:100%;display:flex;align-items:center;justify-content:center}#viewPlayPage .field-container-inner{width:100%;height:100%;max-width:none;max-height:none;padding:1rem}#viewPlayPage .timeline-container{position:fixed;bottom:0;left:0;right:0;margin:0;padding:.75rem 1rem;background:linear-gradient(to top,rgba(0,0,0,.8),rgba(0,0,0,.4),transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;transition:transform .3s ease-in-out,opacity .3s ease-in-out}}@media (max-width:1024px){body.is-landscape-mobile .app-header{display:none!important}body.is-landscape-mobile .main-content{padding:0;height:100vh;overflow:hidden}body.is-landscape-mobile #viewPlayPage{display:flex;flex-direction:column;height:100vh;padding:0;background:var(--field-green)}body.is-landscape-mobile .play-info,body.is-landscape-mobile .play-selector-container,body.is-landscape-mobile .player-legend{display:none!important}body.is-landscape-mobile .field-container{flex:1;padding:0;margin:0;height:100%;display:flex;align-items:center;justify-content:center}body.is-landscape-mobile .field-container-inner{width:100%;height:100%;max-width:none;max-height:none;padding:1rem}body.is-landscape-mobile .timeline-container{position:fixed;bottom:0;left:0;right:0;margin:0;padding:.75rem 1rem;background:linear-gradient(to top,rgba(0,0,0,.8),rgba(0,0,0,.4),transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;transition:transform .3s ease-in-out,opacity .3s ease-in-out}body.is-landscape-mobile .timeline-container.landscape-hidden{transform:translateY(100%);opacity:0;pointer-events:none}body.is-landscape-mobile .timeline-header{flex-direction:row;align-items:center;gap:.5rem;padding:0;margin-bottom:.5rem}body.is-landscape-mobile .timeline-header h3{display:none}body.is-landscape-mobile .play-controls{gap:.5rem;flex-wrap:nowrap}body.is-landscape-mobile .control-button{width:44px;height:44px}body.is-landscape-mobile .speed-control{flex-direction:row;gap:.5rem}body.is-landscape-mobile .speed-control label{font-size:.875rem;color:var(--white)}body.is-landscape-mobile .speed-control select{min-height:36px;padding:.5rem;font-size:14px;background:rgba(255,255,255,.15);color:var(--white);border:1px solid rgba(255,255,255,.3)}body.is-landscape-mobile .speed-control select option{background:var(--dark-gray);color:var(--white)}body.is-landscape-mobile .timeline-slider-container{padding:0}body.is-landscape-mobile .timeline-labels{display:none}body.is-landscape-mobile .timeline-slider{height:8px}body.is-landscape-mobile .timeline-slider::-webkit-slider-thumb{width:20px;height:20px}body.is-landscape-mobile .timeline-slider::-moz-range-thumb{width:20px;height:20px}body.is-landscape-mobile .info-button{display:none!important}}