@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&family=Outfit:wght@400;500;600;700;800&display=swap";
:root{--color-primary:#1b5e3b;--color-primary-light:#2d8f5e;--color-primary-dark:#0e3d25;--color-primary-50:#e8f5ee;--color-primary-100:#c6e7d3;--color-primary-200:#9dd6b5;--color-primary-500:#1b5e3b;--color-primary-600:#155030;--color-primary-700:#0e3d25;--color-accent:#c8a04a;--color-accent-light:#e0c06a;--color-accent-dark:#a07f2e;--color-saddle:#6d4c2a;--color-saddle-light:#8b6742;--color-saddle-dark:#4a3218;--color-bg:#f8f6f1;--color-bg-secondary:#f0ede5;--color-bg-card:#fff;--color-bg-elevated:#ffffffd9;--color-text:#1a1a1a;--color-text-secondary:#5a5a52;--color-text-muted:#8c8c80;--color-text-inverse:#fff;--color-border:#e0ddd4;--color-border-light:#ece9e0;--color-success:#2ecc71;--color-warning:#f39c12;--color-error:#e74c3c;--color-info:#3498db;--color-gold:gold;--color-silver:silver;--color-bronze:#cd7f32;--color-xp:#9b59b6;--color-star-filled:#f1c40f;--color-star-empty:#ddd;--glass-bg:#ffffffa6;--glass-border:#ffffff4d;--glass-shadow:0 8px 32px #00000014;--glass-blur:blur(16px);--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-display:"Outfit","Inter",sans-serif;--font-mono:"SF Mono","Fira Code",monospace;--text-xs:.75rem;--text-sm:.8125rem;--text-base:.9375rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-base:.25s cubic-bezier(.4,0,.2,1);--transition-slow:.4s cubic-bezier(.4,0,.2,1);--transition-spring:.5s cubic-bezier(.175,.885,.32,1.275);--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014,0 2px 4px #0000000a;--shadow-lg:0 10px 30px #0000001a,0 4px 8px #0000000a;--shadow-xl:0 20px 60px #0000001f,0 8px 16px #0000000f;--shadow-glow-primary:0 0 20px #1b5e3b4d;--shadow-glow-accent:0 0 20px #c8a04a4d;--shadow-glow-success:0 0 20px #2ecc7166;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px}[data-theme=dark]{--color-primary:#3aaa6e;--color-primary-light:#4cc88a;--color-primary-dark:#2d8f5e;--color-primary-50:#0c261a;--color-primary-100:#143d2b;--color-bg:#0f1210;--color-bg-secondary:#181d1a;--color-bg-card:#1e2520;--color-bg-elevated:#1e2520e6;--color-text:#e8e6e1;--color-text-secondary:#a0a098;--color-text-muted:#6a6a62;--color-border:#2a322c;--color-border-light:#222a24;--glass-bg:#1e2520b3;--glass-border:#ffffff14;--glass-shadow:0 8px 32px #0000004d;--shadow-sm:0 1px 3px #0003;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 10px 30px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--color-text);font-weight:700;line-height:1.2}h1{font-size:var(--text-4xl);letter-spacing:-.02em}h2{font-size:var(--text-3xl);letter-spacing:-.01em}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}p{margin-bottom:var(--space-md)}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-light)}.app-layout{min-height:100vh;display:flex}.app-sidebar{width:var(--sidebar-width);background:var(--color-bg-card);border-right:1px solid var(--color-border);z-index:100;transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.app-sidebar .sidebar-brand{padding:var(--space-lg);border-bottom:1px solid var(--color-border-light);align-items:center;gap:var(--space-md);display:flex}.app-sidebar .sidebar-brand .brand-icon{border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;width:40px;height:40px;font-size:var(--text-xl);box-shadow:var(--shadow-glow-primary);justify-content:center;align-items:center;display:flex}.app-sidebar .sidebar-brand h2{font-size:var(--text-base);font-weight:700;line-height:1.3}.app-sidebar .sidebar-brand h2 span{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:400;display:block}.sidebar-nav{padding:var(--space-md);gap:var(--space-xs);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar-section-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-md)var(--space-sm)var(--space-xs);font-weight:600}.sidebar-link{align-items:center;gap:var(--space-md);padding:var(--space-sm)var(--space-md);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--color-text-secondary);transition:all var(--transition-fast);cursor:pointer;text-align:left;background:0 0;border:none;width:100%;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--color-bg-secondary);color:var(--color-text)}.sidebar-link.active{background:var(--color-primary-50);color:var(--color-primary);font-weight:600}.sidebar-link .link-icon{flex-shrink:0;width:20px;height:20px}.sidebar-user{padding:var(--space-md)var(--space-lg);border-top:1px solid var(--color-border-light);align-items:center;gap:var(--space-md);display:flex}.sidebar-user .user-avatar{border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));color:#fff;width:36px;height:36px;font-weight:700;font-size:var(--text-sm);justify-content:center;align-items:center;display:flex}.sidebar-user .user-info{flex:1;min-width:0}.sidebar-user .user-name{font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user .user-role{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:capitalize}.app-main{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.app-header{height:var(--header-height);border-bottom:1px solid var(--color-border-light);padding:0 var(--space-xl);background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.app-header .page-title{font-size:var(--text-xl);font-weight:700;font-family:var(--font-display)}.app-content{padding:var(--space-xl);max-width:1400px}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--glass-shadow)}.card-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-lg);font-weight:700;font-family:var(--font-display)}.stat-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.stat-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";background:linear-gradient(90deg,var(--color-primary),var(--color-accent));opacity:0;height:3px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card .stat-icon{border-radius:var(--radius-md);width:44px;height:44px;margin-bottom:var(--space-md);font-size:var(--text-xl);justify-content:center;align-items:center;display:flex}.stat-card .stat-icon.green{background:var(--color-primary-50);color:var(--color-primary)}.stat-card .stat-icon.gold{color:var(--color-accent-dark);background:#fdf6e3}.stat-card .stat-icon.blue{color:var(--color-info);background:#eef6ff}.stat-card .stat-icon.purple{color:var(--color-xp);background:#f5f0ff}.stat-card .stat-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-xs)}.stat-card .stat-value{font-size:var(--text-3xl);font-weight:800;font-family:var(--font-display);line-height:1}.stat-card .stat-change{font-size:var(--text-xs);margin-top:var(--space-sm);border-radius:var(--radius-full);align-items:center;gap:4px;padding:2px 8px;font-weight:600;display:inline-flex}.stat-card .stat-change.positive{color:var(--color-success);background:#2ecc711a}.stat-card .stat-change.negative{color:var(--color-error);background:#e74c3c1a}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-lg);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;font-weight:600;line-height:1.5;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{box-shadow:var(--shadow-glow-primary);transform:translateY(-1px)}.btn-accent{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark));color:#fff;box-shadow:var(--shadow-sm)}.btn-accent:hover{box-shadow:var(--shadow-glow-accent);transform:translateY(-1px)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover{background:var(--color-bg-secondary);color:var(--color-text)}.btn-success{background:linear-gradient(135deg,var(--color-success),#27ae60);color:#fff}.btn-success:hover{box-shadow:var(--shadow-glow-success)}.btn-danger{background:var(--color-error);color:#fff}.btn-lg{padding:var(--space-md)var(--space-xl);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-sm{padding:var(--space-xs)var(--space-md);font-size:var(--text-xs)}.btn-icon{border-radius:var(--radius-md);width:40px;height:40px;padding:0}.form-group{margin-bottom:var(--space-lg)}.form-label{font-size:var(--text-sm);color:var(--color-text);margin-bottom:var(--space-xs);font-weight:600;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-sm)var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-sm);color:var(--color-text);background:var(--color-bg-card);transition:all var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-50)}.form-textarea{resize:vertical;min-height:100px}.badge{border-radius:var(--radius-full);font-size:var(--text-xs);align-items:center;gap:4px;padding:2px 10px;font-weight:600;line-height:1.6;display:inline-flex}.badge-primary{background:var(--color-primary-50);color:var(--color-primary)}.badge-accent{color:var(--color-accent-dark);background:#fdf6e3}.badge-success{color:#1a9c52;background:#2ecc711f}.badge-warning{color:#c77e10;background:#f39c121f}.badge-error{color:#c0392b;background:#e74c3c1f}.badge-info{color:#2980b9;background:#3498db1f}.table-container{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;padding:var(--space-md)var(--space-lg);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);font-weight:600}.data-table td{padding:var(--space-md)var(--space-lg);font-size:var(--text-sm);border-bottom:1px solid var(--color-border-light)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--color-bg-secondary)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;animation:fadeIn var(--transition-fast)ease-out;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--color-bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:90%;max-width:560px;max-height:90vh;animation:slideUp var(--transition-spring)ease-out;overflow-y:auto}.modal-header{padding:var(--space-lg)var(--space-xl);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:var(--space-xl)}.modal-footer{padding:var(--space-md)var(--space-xl)var(--space-xl);gap:var(--space-md);justify-content:flex-end;display:flex}.stars-rating{gap:4px;display:flex}.stars-rating .star{font-size:var(--text-2xl);color:var(--color-star-empty);cursor:pointer;transition:all var(--transition-fast)}.stars-rating .star.filled{color:var(--color-star-filled);filter:drop-shadow(0 0 4px #f1c40f66)}.stars-rating .star:hover{transform:scale(1.2)}.leaderboard-podium{justify-content:center;align-items:flex-end;gap:var(--space-md);padding:var(--space-2xl)var(--space-lg);display:flex}.podium-item{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.podium-item .podium-avatar{border-radius:var(--radius-full);width:56px;height:56px;font-weight:800;font-size:var(--text-xl);color:#fff;justify-content:center;align-items:center;display:flex;position:relative}.podium-item.gold .podium-avatar{background:linear-gradient(135deg,gold,#fa0);box-shadow:0 0 24px #ffd70080}.podium-item.silver .podium-avatar{background:linear-gradient(135deg,silver,#a0a0a0);box-shadow:0 0 16px #c0c0c066}.podium-item.bronze .podium-avatar{background:linear-gradient(135deg,#cd7f32,#a06020);box-shadow:0 0 16px #cd7f3266}.podium-item .podium-medal{font-size:var(--text-lg);filter:drop-shadow(0 2px 4px #0003);position:absolute;bottom:-4px;right:-4px}.podium-item .podium-name{font-weight:700;font-size:var(--text-sm);text-align:center}.podium-item .podium-stat{font-size:var(--text-xs);color:var(--color-text-muted)}.podium-block{border-radius:var(--radius-md)var(--radius-md)0 0;font-size:var(--text-2xl);color:#fff;justify-content:center;align-items:center;min-width:80px;font-weight:800;display:flex}.podium-item.gold .podium-block{height:100px;color:var(--color-gold);background:linear-gradient(#ffd7004d,#ffd7001a)}.podium-item.silver .podium-block{height:70px;color:var(--color-silver);background:linear-gradient(#c0c0c04d,#c0c0c01a)}.podium-item.bronze .podium-block{height:50px;color:var(--color-bronze);background:linear-gradient(#cd7f324d,#cd7f321a)}.clock-button{border-radius:var(--radius-full);justify-content:center;align-items:center;gap:var(--space-sm);width:200px;height:200px;font-family:var(--font-display);font-size:var(--text-2xl);cursor:pointer;transition:all var(--transition-base);border:4px solid;flex-direction:column;font-weight:800;display:flex;position:relative}.clock-button.clock-in{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border-color:var(--color-primary-light);color:#fff;box-shadow:var(--shadow-glow-primary)}.clock-button.clock-in:hover{transform:scale(1.05);box-shadow:0 0 40px #1b5e3b80}.clock-button.clock-out{background:linear-gradient(135deg,var(--color-error),#c0392b);color:#fff;border-color:#e74c3c;box-shadow:0 0 20px #e74c3c4d}.clock-button.clock-out:hover{transform:scale(1.05);box-shadow:0 0 40px #e74c3c80}.clock-button .clock-label{font-size:var(--text-xs);opacity:.8;text-transform:uppercase;letter-spacing:.1em;font-weight:500}.stall-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(140px,1fr));display:grid}.stall-card{aspect-ratio:1;border-radius:var(--radius-lg);border:2px solid var(--color-border);justify-content:center;align-items:center;gap:var(--space-xs);cursor:pointer;transition:all var(--transition-base);background:var(--color-bg-card);flex-direction:column;display:flex;position:relative;overflow:hidden}.stall-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary);transform:translateY(-2px)}.stall-card .stall-number{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-text);font-weight:800}.stall-card .stall-horse{font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;padding:0 var(--space-sm);white-space:nowrap;text-overflow:ellipsis;max-width:100%;overflow:hidden}.stall-card.available{border-color:var(--color-primary);background:var(--color-primary-50)}.stall-card.in-progress{border-color:var(--color-warning);background:#f39c120f;animation:2s ease-in-out infinite pulse-border}.stall-card.completed{border-color:var(--color-success);background:#2ecc710f}.stall-card.rated{border-color:var(--color-accent);background:#c8a04a0f}.stall-card .stall-status-dot{border-radius:var(--radius-full);width:10px;height:10px;position:absolute;top:8px;right:8px}.stall-card.available .stall-status-dot{background:var(--color-primary)}.stall-card.in-progress .stall-status-dot{background:var(--color-warning)}.stall-card.completed .stall-status-dot{background:var(--color-success)}.stall-card.rated .stall-status-dot{background:var(--color-accent)}.timer-display{font-family:var(--font-mono);font-size:var(--text-5xl);letter-spacing:.05em;text-align:center;background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.timer-display.active{animation:1s ease-in-out infinite timer-pulse}.photo-capture-area{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);justify-content:center;align-items:center;gap:var(--space-md);cursor:pointer;transition:all var(--transition-base);background:var(--color-bg-secondary);flex-direction:column;min-height:200px;display:flex}.photo-capture-area:hover{border-color:var(--color-primary);background:var(--color-primary-50)}.photo-capture-area .capture-icon{font-size:var(--text-4xl);color:var(--color-text-muted)}.photo-capture-area .capture-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500}.photo-preview{border-radius:var(--radius-lg);width:100%;position:relative;overflow:hidden}.photo-preview img{width:100%;height:auto;display:block}.tabs{gap:var(--space-xs);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-xl);display:flex}.tab{padding:var(--space-sm)var(--space-lg);font-size:var(--text-sm);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-weight:500;position:relative}.tab:after{content:"";background:var(--color-primary);height:2px;transition:transform var(--transition-base);position:absolute;bottom:-1px;left:0;right:0;transform:scaleX(0)}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-primary);font-weight:600}.tab.active:after{transform:scaleX(1)}.progress-bar{background:var(--color-bg-secondary);border-radius:var(--radius-full);height:8px;overflow:hidden}.progress-bar .progress-fill{border-radius:var(--radius-full);background:linear-gradient(90deg,var(--color-primary),var(--color-accent));height:100%;transition:width var(--transition-slow)}.map-canvas{border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);cursor:crosshair;min-height:500px;position:relative;overflow:hidden}.map-canvas .map-bg-image{object-fit:contain;pointer-events:none;width:100%;height:100%}.map-stall-marker{border-radius:var(--radius-sm);border:2px solid var(--color-primary);cursor:grab;transition:box-shadow var(--transition-fast);font-size:var(--text-sm);color:var(--color-primary);-webkit-user-select:none;user-select:none;background:#1b5e3b26;justify-content:center;align-items:center;font-weight:700;display:flex;position:absolute}.map-stall-marker:hover{box-shadow:var(--shadow-glow-primary);z-index:10}.map-stall-marker.selected{border-color:var(--color-accent);box-shadow:var(--shadow-glow-accent);z-index:11}.map-paddock-marker{border-radius:var(--radius-md);border:2px dashed var(--color-saddle);cursor:grab;padding:var(--space-sm);font-size:var(--text-xs);color:var(--color-saddle);-webkit-user-select:none;user-select:none;background:#6d4c2a14;font-weight:600;position:absolute}.map-paddock-marker:hover{background:#6d4c2a26}.map-toolbar{gap:var(--space-sm);padding:var(--space-md);background:var(--color-bg-card);border-bottom:1px solid var(--color-border);border-radius:var(--radius-lg)var(--radius-lg)0 0;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse-border{0%,to{border-color:var(--color-warning)}50%{border-color:#f39c124d}}@keyframes timer-pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}to{opacity:0;transform:translateY(100vh)rotate(720deg)}}@keyframes celebrate-pop{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.3)}to{opacity:1;transform:scale(1)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 20px #2ecc7133}50%{box-shadow:0 0 40px #2ecc7180}}@keyframes rank-up{0%{opacity:0;transform:translateY(10px)}50%{transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes shine{0%{background-position:-200%}to{background-position:200%}}.animate-fade-in{animation:fadeIn var(--transition-base)ease-out}.animate-slide-up{animation:slideUp var(--transition-spring)ease-out}.animate-slide-down{animation:slideDown var(--transition-base)ease-out}.animate-scale-in{animation:scaleIn var(--transition-spring)ease-out}.animate-celebrate{animation:.6s cubic-bezier(.175,.885,.32,1.275) celebrate-pop}.celebration-overlay{z-index:2000;pointer-events:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.celebration-content{text-align:center;animation:.6s cubic-bezier(.175,.885,.32,1.275) celebrate-pop}.celebration-content .celebration-emoji{margin-bottom:var(--space-md);font-size:80px}.celebration-content .celebration-text{font-family:var(--font-display);font-size:var(--text-4xl);background:linear-gradient(135deg,var(--color-gold),var(--color-accent));-webkit-text-fill-color:transparent;margin-bottom:var(--space-sm);-webkit-background-clip:text;background-clip:text;font-weight:900}.celebration-content .celebration-subtext{font-size:var(--text-lg);color:var(--color-text-secondary);font-weight:500}.celebration-content .celebration-badge{align-items:center;gap:var(--space-sm);margin-top:var(--space-lg);padding:var(--space-sm)var(--space-lg);background:linear-gradient(135deg,var(--color-success),#27ae60);color:#fff;border-radius:var(--radius-full);font-weight:700;font-size:var(--text-base);box-shadow:var(--shadow-glow-success);animation:2s ease-in-out infinite glow-pulse;display:inline-flex}.confetti-piece{width:10px;height:10px;animation:confetti-fall var(--confetti-duration,3s)linear forwards;animation-delay:var(--confetti-delay,0s);position:absolute}.mobile-bottom-bar{z-index:200;background:var(--color-bg-card);border-top:1px solid var(--color-border);padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 20px #0000000f}.bottom-tab{font-size:var(--text-xs);color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:54px;padding:8px 4px 6px;text-decoration:none;display:flex}.bottom-tab.active{color:var(--color-primary)}.bottom-tab-icon{font-size:22px;line-height:1}.bottom-tab-label{letter-spacing:.01em;font-size:10px;font-weight:600}.more-sheet-backdrop{z-index:300;animation:fadeIn var(--transition-fast)ease-out;-webkit-tap-highlight-color:transparent;background:#0006;position:fixed;inset:0}.more-sheet{z-index:301;background:var(--color-bg-card);border-radius:var(--radius-xl)var(--radius-xl)0 0;padding:var(--space-sm)var(--space-lg);padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom,0px));max-height:80vh;animation:slideUp var(--transition-spring)ease-out;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -8px 40px #00000026}.more-sheet-handle{background:var(--color-border);border-radius:var(--radius-full);width:40px;height:4px;margin:0 auto var(--space-lg)}.more-sheet-header{padding:var(--space-md)0;border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-md)}.more-sheet-links{gap:var(--space-xs);flex-direction:column;display:flex}.more-sheet-link{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--color-text);-webkit-tap-highlight-color:transparent;min-height:48px;font-weight:500;text-decoration:none;display:flex}.more-sheet-link:hover,.more-sheet-link.active{background:var(--color-primary-50);color:var(--color-primary)}.more-sheet-logout{justify-content:center;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-md);margin-top:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-sm);cursor:pointer;background:0 0;min-height:48px;font-weight:600;display:flex}.desktop-only{display:flex}.mobile-only{display:none}@media (max-width:768px){.desktop-only{display:none!important}.mobile-only{display:flex!important}.app-main{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px));margin-left:0}.app-content{padding:var(--space-md)}h1{font-size:var(--text-xl)}h2{font-size:var(--text-lg)}h3{font-size:var(--text-base)}.page-title{font-size:var(--text-xl)!important}.stat-grid{gap:var(--space-sm);scroll-snap-type:x mandatory;padding-bottom:var(--space-sm);margin-bottom:var(--space-md);-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.stat-grid::-webkit-scrollbar{display:none}.stat-card{scroll-snap-align:start;min-width:140px;padding:var(--space-md);flex-shrink:0}.stat-card .stat-icon{width:36px;height:36px;margin-bottom:var(--space-sm);font-size:var(--text-base)}.stat-card .stat-value{font-size:var(--text-xl)}.stat-card .stat-label{font-size:11px}.stat-card:hover{box-shadow:none;transform:none}.card{padding:var(--space-md);border-radius:var(--radius-md)}.card:hover{box-shadow:none;transform:none}.btn{min-height:48px;font-size:var(--text-sm);-webkit-tap-highlight-color:transparent}.btn-lg{min-height:56px;font-size:var(--text-base);border-radius:var(--radius-lg)}.btn:active{transform:scale(.97)}.btn:hover,.btn-primary:hover,.btn-accent:hover{box-shadow:none;transform:none}.mobile-cta{gap:var(--space-sm);flex-direction:column;display:flex}.mobile-cta .btn{width:100%}.stall-grid{gap:var(--space-sm);grid-template-columns:repeat(4,1fr)}.stall-card{aspect-ratio:1;border-radius:var(--radius-md);border-width:2px}.stall-card .stall-number{font-size:var(--text-xl)}.stall-card .stall-horse{font-size:9px}.stall-card:hover{box-shadow:none;transform:none}.clock-button{width:100%;max-width:260px;height:200px;font-size:var(--text-xl)}.timer-display{font-size:var(--text-4xl)}.photo-capture-area{padding:var(--space-xl);min-height:160px}.photo-capture-area .capture-icon{font-size:var(--text-3xl)}.leaderboard-podium{padding:var(--space-lg)var(--space-xs);gap:var(--space-sm)}.podium-item .podium-avatar{width:44px;height:44px;font-size:var(--text-base)}.podium-item .podium-name{font-size:var(--text-xs)}.podium-block{min-width:60px;font-size:var(--text-lg)}.podium-item.gold .podium-block{height:70px}.podium-item.silver .podium-block{height:50px}.podium-item.bronze .podium-block{height:35px}.data-table th,.data-table td{padding:var(--space-sm)var(--space-md);font-size:var(--text-xs)}.table-container{border-radius:var(--radius-md)}.tabs{scrollbar-width:none;-webkit-overflow-scrolling:touch;gap:0;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{padding:var(--space-sm)var(--space-md);font-size:var(--text-xs);white-space:nowrap;text-align:center;flex:1;min-height:44px}.map-canvas{min-height:350px}.map-toolbar{flex-wrap:wrap}.form-input,.form-select,.form-textarea{padding:var(--space-md);font-size:var(--text-base);border-radius:var(--radius-md);min-height:48px}.celebration-overlay{background:#0000001a}.badge{padding:4px 10px;font-size:11px}.empty-state{padding:var(--space-xl)var(--space-md)}.empty-state .empty-icon{margin-bottom:var(--space-md);font-size:48px}.empty-state .empty-title{font-size:var(--text-lg)}}@media (max-width:390px){.stat-card{min-width:120px;padding:var(--space-sm)var(--space-md)}.stat-card .stat-value{font-size:var(--text-lg)}.stall-grid{grid-template-columns:repeat(3,1fr)}.bottom-tab-icon{font-size:20px}.bottom-tab-label{font-size:9px}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-muted)}.text-primary{color:var(--color-primary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-lg{font-size:var(--text-lg)}.font-bold{font-weight:700}.font-display{font-family:var(--font-display)}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.w-full{width:100%}.grid{display:grid}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.hidden{display:none}.relative{position:relative}.overflow-hidden{overflow:hidden}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@media (max-width:768px){.grid-2,.grid-3{grid-template-columns:1fr}}.empty-state{text-align:center;padding:var(--space-3xl)var(--space-xl)}.empty-state .empty-icon{margin-bottom:var(--space-lg);opacity:.5;font-size:64px}.empty-state .empty-title{font-size:var(--text-xl);margin-bottom:var(--space-sm);font-weight:700}.empty-state .empty-description{font-size:var(--text-sm);color:var(--color-text-muted);max-width:400px;margin:0 auto var(--space-lg)}.skeleton{background:linear-gradient(90deg,var(--color-bg-secondary),var(--color-border-light),var(--color-bg-secondary));border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shine}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-title{width:60%;height:24px;margin-bottom:12px}.skeleton-avatar{border-radius:var(--radius-full);width:40px;height:40px}.skeleton-card{height:120px}
