:root{--color-primary: #667eea;--color-primary-hover: #5a6fd6;--color-primary-dark: #4a5bc7;--color-primary-light: #8b9df0;--color-primary-bg: rgba(102, 126, 234, .1);--color-success: #4caf50;--color-success-hover: #43a047;--color-success-dark: #388e3c;--color-success-light: #81c784;--color-success-bg: rgba(76, 175, 80, .1);--color-danger: #e74c3c;--color-danger-hover: #d32f2f;--color-danger-dark: #c62828;--color-danger-light: #ef5350;--color-danger-bg: rgba(231, 76, 60, .1);--color-warning: #f39c12;--color-warning-hover: #e67e22;--color-warning-dark: #d35400;--color-warning-light: #f5b041;--color-warning-bg: rgba(243, 156, 18, .1);--color-info: #2196f3;--color-info-hover: #1976d2;--color-info-dark: #1565c0;--color-info-light: #64b5f6;--color-info-bg: rgba(33, 150, 243, .1);--color-kata: #9c27b0;--color-kata-hover: #7b1fa2;--color-kata-bg: rgba(156, 39, 176, .1);--color-kumite: #ff5722;--color-kumite-hover: #e64a19;--color-kumite-bg: rgba(255, 87, 34, .1);--color-aka: #e74c3c;--color-aka-light: #ffebee;--color-aka-dark: #c62828;--color-ao: #2196f3;--color-ao-light: #e3f2fd;--color-ao-dark: #1565c0;--color-gold: #ffd700;--color-gold-bg: linear-gradient(135deg, #fff9e6 0%, #fff3cc 100%);--color-silver: #c0c0c0;--color-silver-bg: linear-gradient(135deg, #f8f8f8 0%, #e8e8e8 100%);--color-bronze: #cd7f32;--color-bronze-bg: linear-gradient(135deg, #fdf5eb 0%, #f5e6d3 100%);--color-text-primary: #333333;--color-text-secondary: #666666;--color-text-muted: #999999;--color-text-light: #cccccc;--color-text-inverse: #ffffff;--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f5;--color-bg-tertiary: #eeeeee;--color-bg-hover: #f0f0f0;--color-bg-dark: #333333;--color-bg-darker: #1a1a1a;--color-border: #e0e0e0;--color-border-light: #eeeeee;--color-border-dark: #cccccc;--color-border-focus: var(--color-primary);--color-pending: #ff9800;--color-pending-bg: rgba(255, 152, 0, .1);--color-active: #4caf50;--color-active-bg: rgba(76, 175, 80, .1);--color-completed: #9e9e9e;--color-completed-bg: rgba(158, 158, 158, .1);--color-kyu-9: #ffffff;--color-kyu-8: #ffeb3b;--color-kyu-7: #ff9800;--color-kyu-6: #4caf50;--color-kyu-5: #2196f3;--color-kyu-4: #9c27b0;--color-kyu-3: #795548;--color-kyu-2: #795548;--color-kyu-1: #795548;--color-dan: #000000;--color-info-bg-solid: #e3f2fd;--color-warning-bg-solid: #fff3e0;--color-success-bg-solid: #e8f5e9;--color-danger-bg-solid: #ffebee;--color-bg-light: #f8f9fa;--color-gray-500: #555555;--color-gray-400: #888888;--color-border-medium: #dddddd;--space-2xs: .125rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-xs: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .06);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 900;--z-modal: 1000;--z-popover: 1100;--z-tooltip: 1200;--z-toast: 1300;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: "SF Mono", "Monaco", "Inconsolata", "Fira Mono", "Droid Sans Mono", monospace;--font-size-2xs: .625rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}@media(prefers-color-scheme:dark)and (min-width:1025px){:root{--color-text-primary: #e0e0e0;--color-text-secondary: #b0b0b0;--color-text-muted: #888888;--color-text-light: #666666;--color-text-inverse: #1a1a1a;--color-bg-primary: #1a1a2e;--color-bg-secondary: #242440;--color-bg-tertiary: #2d2d4a;--color-bg-hover: #353555;--color-bg-dark: #e0e0e0;--color-bg-darker: #f0f0f0;--color-bg-light: #2a2a45;--color-border: #3a3a5c;--color-border-light: #2d2d4a;--color-border-dark: #4a4a6a;--color-border-medium: #3a3a5c;--color-gray-500: #aaaaaa;--color-gray-400: #888888;--color-primary: #7b93f5;--color-primary-hover: #6a82e8;--color-primary-dark: #5a72d8;--color-primary-light: #99aef7;--color-primary-bg: rgba(123, 147, 245, .15);--color-success: #66bb6a;--color-success-hover: #57a85c;--color-success-dark: #4caf50;--color-success-light: #81c784;--color-success-bg: rgba(76, 175, 80, .15);--color-danger: #ef5350;--color-danger-hover: #e53935;--color-danger-dark: #e74c3c;--color-danger-light: #ef9a9a;--color-danger-bg: rgba(231, 76, 60, .15);--color-warning: #ffa726;--color-warning-hover: #fb8c00;--color-warning-dark: #f39c12;--color-warning-light: #ffcc80;--color-warning-bg: rgba(243, 156, 18, .15);--color-info: #42a5f5;--color-info-hover: #2196f3;--color-info-dark: #1e88e5;--color-info-light: #90caf9;--color-info-bg: rgba(33, 150, 243, .15);--color-info-bg-solid: #1a2a3e;--color-warning-bg-solid: #2e2a1a;--color-success-bg-solid: #1a2e1a;--color-danger-bg-solid: #2e1a1a;--color-kata: #ba68c8;--color-kata-hover: #ab47bc;--color-kata-bg: rgba(186, 104, 200, .15);--color-kumite: #ff7043;--color-kumite-hover: #ff5722;--color-kumite-bg: rgba(255, 112, 67, .15);--color-aka: #ef5350;--color-aka-light: #2e1a1a;--color-aka-dark: #e53935;--color-ao: #42a5f5;--color-ao-light: #1a2a3e;--color-ao-dark: #1e88e5;--color-pending: #ffa726;--color-pending-bg: rgba(255, 167, 38, .15);--color-active: #66bb6a;--color-active-bg: rgba(102, 187, 106, .15);--color-completed: #bdbdbd;--color-completed-bg: rgba(189, 189, 189, .1);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 8px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 30px rgba(0, 0, 0, .5);--shadow-inner: inset 0 2px 4px rgba(0, 0, 0, .2)}}@media(max-width:1024px){:root{--space-2xl: 2.5rem;--space-3xl: 3rem}}@media(max-width:768px){:root{--space-lg: 1.25rem;--space-xl: 1.75rem;--space-2xl: 2rem;--space-3xl: 2.5rem}}@media(max-width:600px){:root{--space-lg: 1rem;--space-xl: 1.5rem;--space-2xl: 1.75rem;--space-3xl: 2rem}}@media(max-width:480px){:root{--space-md: .875rem;--space-lg: 1rem;--space-xl: 1.25rem;--space-2xl: 1.5rem;--space-3xl: 1.75rem}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);line-height:1;text-decoration:none;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary,.btn-secondary,.btn-success,.btn-danger,.btn-warning{border-radius:var(--radius-full)}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-text-secondary);color:var(--color-text-inverse)}.btn-secondary:hover:not(:disabled){background:var(--color-text-primary)}.btn-success{background:var(--color-success);color:var(--color-text-inverse)}.btn-success:hover:not(:disabled){background:var(--color-success-hover)}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-warning{background:var(--color-warning);color:var(--color-text-inverse)}.btn-warning:hover:not(:disabled){background:var(--color-warning-hover)}.btn-info{background:var(--color-info);color:var(--color-text-inverse)}.btn-info:hover:not(:disabled){background:var(--color-info-hover)}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-outline:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-border-dark)}.btn-outline-primary{background:transparent;border:1px solid var(--color-primary);color:var(--color-primary)}.btn-outline-primary:hover:not(:disabled){background:var(--color-primary);color:var(--color-text-inverse)}.btn-outline-danger{background:transparent;border:1px solid var(--color-danger);color:var(--color-danger)}.btn-outline-danger:hover:not(:disabled){background:var(--color-danger);color:var(--color-text-inverse)}.btn-xs{padding:var(--space-2xs) var(--space-xs);font-size:var(--font-size-xs)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs)}.btn-lg{padding:var(--space-md) var(--space-lg);font-size:var(--font-size-md)}.btn-xl{padding:var(--space-lg) var(--space-xl);font-size:var(--font-size-lg)}.btn-block{display:flex;width:100%}.btn-icon{padding:var(--space-sm);aspect-ratio:1}.badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2xs) var(--space-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1;border-radius:var(--radius-full);white-space:nowrap}.badge-primary{background:var(--color-primary-bg);color:var(--color-primary)}.badge-success{background:var(--color-success-bg);color:var(--color-success-dark)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger-dark)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning-dark)}.badge-info{background:var(--color-info-bg);color:var(--color-info-dark)}.badge-solid-primary{background:var(--color-primary);color:var(--color-text-inverse)}.badge-solid-success{background:var(--color-success);color:var(--color-text-inverse)}.badge-solid-danger{background:var(--color-danger);color:var(--color-text-inverse)}.badge-solid-warning{background:var(--color-warning);color:var(--color-text-inverse)}.badge-kata{background:var(--color-kata-bg);color:var(--color-kata)}.badge-kumite{background:var(--color-kumite-bg);color:var(--color-kumite)}.badge-solid-kata{background:var(--color-kata);color:var(--color-text-inverse)}.badge-solid-kumite{background:var(--color-kumite);color:var(--color-text-inverse)}.badge-sm{padding:var(--space-2xs) var(--space-xs);font-size:var(--font-size-2xs)}.badge-lg{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;margin-bottom:var(--space-xs);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-label-required:after{content:" *";color:var(--color-danger)}.form-input{display:block;width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-input:disabled{background:var(--color-bg-secondary);cursor:not-allowed}.form-input::placeholder{color:var(--color-text-muted)}.form-input-error{border-color:var(--color-danger)}.form-input-error:focus{box-shadow:0 0 0 3px var(--color-danger-bg)}.form-select{display:block;width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast)}.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-textarea{display:block;width:100%;min-height:100px;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);resize:vertical;transition:border-color var(--transition-fast)}.form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-bg)}.form-helper{margin-top:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}.form-error{margin-top:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-danger)}.card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.card-body{padding:var(--space-lg)}.card-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.flex{display:flex}.flex-inline{display:inline-flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.flex-1{flex:1}.flex-auto{flex:auto}.flex-none{flex:none}.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)}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.m-0{margin:0}.m-xs{margin:var(--space-xs)}.m-sm{margin:var(--space-sm)}.m-md{margin:var(--space-md)}.m-lg{margin:var(--space-lg)}.mt-0{margin-top:0}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mb-0{margin-bottom:0}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.p-0{padding:0}.p-xs{padding:var(--space-xs)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.px-sm{padding-left:var(--space-sm);padding-right:var(--space-sm)}.px-md{padding-left:var(--space-md);padding-right:var(--space-md)}.py-sm{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-md{padding-top:var(--space-md);padding-bottom:var(--space-md)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hidden{display:none}.visible{visibility:visible}.invisible{visibility:hidden}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.w-full{width:100%}.h-full{height:100%}.status-dot{display:inline-block;width:8px;height:8px;border-radius:var(--radius-full)}.status-dot-success{background:var(--color-success)}.status-dot-warning{background:var(--color-warning)}.status-dot-danger{background:var(--color-danger)}.status-dot-info{background:var(--color-info)}.loading{position:relative;pointer-events:none}.loading:after{content:"";position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center}.spinner{width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .8s linear infinite}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-lg{width:40px;height:40px;border-width:4px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-md)}.modal-content{background:var(--color-bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-height:90vh;overflow-y:auto;width:100%;max-width:600px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-header h2,.modal-header h3{margin:0;font-size:var(--font-size-lg);color:var(--color-text-primary)}.modal-body{padding:var(--space-lg)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.modal-close-btn{background:none;border:none;font-size:var(--font-size-xl);color:var(--color-text-muted);cursor:pointer;padding:var(--space-xs);line-height:1}.modal-close-btn:hover{color:var(--color-text-primary)}.error-message{background:var(--color-danger-bg);color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);margin-bottom:var(--space-md)}.form-row{display:flex;gap:var(--space-md)}.form-row>.form-group{flex:1}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg)}.show-mobile{display:none!important}@media(max-width:768px){.hide-mobile{display:none!important}.show-mobile{display:block!important}.show-mobile-flex{display:flex!important}.show-mobile-inline{display:inline!important}.show-mobile-inline-flex{display:inline-flex!important}.mobile-stack{flex-direction:column!important}.mobile-full-width{width:100%!important;min-width:0!important}.mobile-text-sm{font-size:var(--font-size-sm)!important}.mobile-text-xs{font-size:var(--font-size-xs)!important}.mobile-gap-sm{gap:var(--space-sm)!important}.mobile-p-sm{padding:var(--space-sm)!important}}@media(max-width:600px){.hide-phone{display:none!important}.show-phone{display:block!important}.show-phone-flex{display:flex!important}}@media(max-width:1024px){.form-input,.form-select,.form-textarea{min-height:44px}}@media(max-width:768px){.btn{min-height:40px;min-width:40px}.btn-sm{min-height:36px;min-width:36px}.btn-xs{min-height:32px;min-width:32px}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}@media(max-width:600px){.btn{min-height:44px}.btn-sm{min-height:40px}.card-body{padding:var(--space-md)}.card-header,.card-footer{padding:var(--space-sm) var(--space-md)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInBottom{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes blink{0%,50%,to{opacity:1}25%,75%{opacity:0}}@keyframes urgentPulse{0%,to{box-shadow:0 0 #e74c3cb3}50%{box-shadow:0 0 0 10px #e74c3c00}}@keyframes glow{0%,to{box-shadow:0 0 5px #667eea80}50%{box-shadow:0 0 20px #667eeacc}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-spin{animation:spin 1s linear infinite}.animate-spin-slow{animation:spin 2s linear infinite}.animate-spin-fast{animation:spin .5s linear infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-pulse-fast{animation:pulse 1s ease-in-out infinite}.animate-bounce-in{animation:bounceIn .5s ease-out}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-fade-out{animation:fadeOut .3s ease-out}.animate-slide-in-top{animation:slideInTop .3s ease-out}.animate-slide-in-bottom{animation:slideInBottom .3s ease-out}.animate-slide-in-left{animation:slideInLeft .3s ease-out}.animate-slide-in-right{animation:slideInRight .3s ease-out}.animate-scale-in{animation:scaleIn .2s ease-out}.animate-shake{animation:shake .5s ease-in-out}.animate-blink{animation:blink 1s step-end infinite}.animate-urgent{animation:urgentPulse 1.5s ease-in-out infinite}.animate-glow{animation:glow 2s ease-in-out infinite}.animate-shimmer{background:linear-gradient(90deg,var(--color-bg-secondary) 25%,var(--color-bg-tertiary) 50%,var(--color-bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.transition-none{transition:none}.transition-all{transition:all var(--transition-normal)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.transition-opacity{transition:opacity var(--transition-normal)}.transition-transform{transition:transform var(--transition-normal)}.transition-colors{transition:color var(--transition-normal),background-color var(--transition-normal),border-color var(--transition-normal)}.hover-scale:hover{transform:scale(1.05)}.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.hover-glow:hover{box-shadow:0 0 15px #667eea66}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:var(--font-size-md);-webkit-text-size-adjust:100%}body{font-family:var(--font-family-base);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-sm)}p{margin-bottom:var(--space-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}button,input,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit}button{cursor:pointer;border:none;background:none}button:disabled{cursor:not-allowed}input:focus,select:focus,textarea:focus,button:focus{outline:none}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0;width:100%}th{text-align:left;font-weight:var(--font-weight-semibold)}img,video{max-width:100%;height:auto;display:block}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--color-border-dark) var(--color-bg-secondary)}::selection{background:var(--color-primary-bg);color:var(--color-primary-dark)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media print{body{background:#fff;color:#000}.no-print{display:none!important}}@media(max-width:768px){html{font-size:15px}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}}@media(max-width:600px){html{font-size:14.5px}h1{font-size:var(--font-size-xl)}h2{font-size:var(--font-size-lg)}h3{font-size:var(--font-size-md)}body{min-width:0}}@media(max-width:480px){html{font-size:var(--font-size-sm)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.language-switcher{position:relative;display:inline-block;margin-left:10px}.lang-btn-current{display:flex;align-items:center;gap:4px;padding:.3rem .75rem;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);background:#ffffff1a;cursor:pointer;font-size:var(--font-size-sm);color:#fff;transition:background-color .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease}.lang-btn-current:hover{background:#fff3;border-color:#ffffff80}.lang-flag{font-size:var(--font-size-md);display:inline-flex;align-items:center;line-height:1}.lang-code{font-weight:500}.lang-arrow{font-size:var(--font-size-2xs);margin-left:2px;opacity:.8}.lang-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid var(--color-border-medium);border-radius:var(--radius-sm);box-shadow:0 4px 12px #00000026;z-index:var(--z-modal);min-width:100px;overflow:hidden}.lang-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:#fff;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-primary);transition:background .15s ease;text-align:left}.lang-option:hover{background:var(--color-bg-secondary)}.lang-option.active{background:#e8f4ff;color:#007bff;font-weight:500}.lang-option .lang-flag{font-size:var(--font-size-lg)}.login-language-switcher .lang-btn-current{background:var(--color-bg-hover);border-color:var(--color-border-medium);color:var(--color-text-primary)}.login-language-switcher .lang-btn-current:hover{background:var(--color-border);border-color:#bbb}.spectator-lang-switcher .lang-btn-current{background:var(--color-bg-hover);border-color:var(--color-border-medium);color:var(--color-text-primary)}.spectator-lang-switcher .lang-btn-current:hover{background:var(--color-border);border-color:#bbb}@media(max-width:768px){.navbar-top-right .language-switcher{margin-left:0}.navbar-top-right .lang-btn-current{padding:.2rem .35rem;gap:0;border:none;background:transparent;min-width:28px;min-height:28px;justify-content:center}.navbar-top-right .lang-btn-current:hover{background:#fff3;border-radius:50%}.navbar-top-right .lang-code,.navbar-top-right .lang-arrow{display:none}.navbar-top-right .lang-flag{font-size:1.15rem}.navbar-top-right .lang-dropdown{display:flex;flex-direction:row;min-width:auto;padding:.25rem;gap:0;right:-.5rem}.navbar-top-right .lang-option{padding:.4rem .5rem;justify-content:center;gap:0;border-radius:6px}.navbar-top-right .lang-option .lang-code{display:none}.navbar-top-right .lang-option .lang-flag{font-size:1.25rem}}@media(max-width:768px){.navbar-top-right .lang-btn-current{min-width:36px;min-height:36px}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%;position:fixed;top:0;left:0;background:#fff;box-sizing:border-box}.login-card{background:#fff;padding:2rem;border-radius:var(--radius-md);box-shadow:0 8px 24px #00000026;border:1px solid var(--color-border);width:100%;max-width:400px;margin:1rem;box-sizing:border-box}.login-card h1{font-size:var(--font-size-2xl);margin-bottom:.5rem;color:var(--color-text-primary);text-align:center}.login-card h2{font-size:var(--font-size-xl);margin-bottom:1.5rem;color:var(--color-text-secondary);text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--color-text-primary);font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid var(--color-border-medium);border-radius:var(--radius-sm);font-size:var(--font-size-md);transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--color-primary)}.form-group input:disabled{background-color:var(--color-bg-secondary);cursor:not-allowed}.login-language-switcher{display:flex;justify-content:flex-end;margin-bottom:1rem}.forgot-password-link{text-align:right;margin-top:-.5rem;margin-bottom:1rem}.forgot-password-link a{color:var(--color-primary);text-decoration:none;font-size:var(--font-size-sm)}.forgot-password-link a:hover{text-decoration:underline}@media(max-width:600px){.login-card{padding:1.5rem;margin:.75rem;box-shadow:0 4px 12px #0000001a}.login-card h1{font-size:var(--font-size-xl)}.login-card h2{font-size:var(--font-size-md);margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group input{padding:.75rem;font-size:var(--font-size-md);min-height:44px}.btn-primary{padding:.75rem;min-height:44px}}@media(max-width:480px){.login-card{padding:1.25rem;margin:.5rem;border-radius:var(--radius-md)}}.login-card .btn-primary{padding:.75rem 2rem;font-size:var(--font-size-md);margin-left:auto;display:block}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{flex:1;padding-right:2.5rem}.password-toggle-btn{position:absolute;right:10px;background:none;border:none;cursor:pointer;font-size:1.25rem;padding:4px;color:var(--color-text-secondary);opacity:.7;transition:opacity .2s;line-height:1;display:flex;align-items:center}.password-toggle-btn:hover{opacity:1}.ai-chat-container{display:flex;flex-direction:column;height:100%}.ai-chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.ai-message{max-width:85%;padding:10px 14px;border-radius:var(--radius-lg);font-size:var(--font-size-sm);line-height:1.4}.ai-message.user{align-self:flex-end;background:#3498db;color:#fff;border-bottom-right-radius:4px}.ai-message.assistant{align-self:flex-start;background:#f1f3f4;color:var(--color-text-primary);border-bottom-left-radius:4px}.ai-message-content.typing{display:flex;gap:4px;padding:4px 0}.ai-message-content.typing span{width:8px;height:8px;background:var(--color-text-muted);border-radius:var(--radius-full);animation:typing 1.4s infinite}.ai-message-content.typing span:nth-child(2){animation-delay:.2s}.ai-message-content.typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-4px)}}.ai-chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--color-border-light)}.ai-chat-input input{flex:1;padding:10px 14px;border:1px solid var(--color-border-medium);border-radius:var(--radius-xl);font-size:var(--font-size-sm);outline:none}.ai-chat-input input:focus{border-color:#3498db}.ai-chat-input button{padding:10px 18px;background:#3498db;color:#fff;border:none;border-radius:var(--radius-xl);font-size:var(--font-size-sm);cursor:pointer;transition:background .2s}.ai-chat-input button:hover:not(:disabled){background:#2980b9}.ai-chat-input button:disabled{background:#bdc3c7;cursor:not-allowed}.ai-message-content{white-space:pre-wrap;word-wrap:break-word}.ai-message.status-message{max-width:95%}.ai-message-content.ai-status{display:flex;align-items:center;gap:8px;font-size:var(--font-size-xs);color:var(--color-text-secondary);font-style:italic;padding:6px 12px;background:var(--color-bg-light);border:1px dashed var(--color-border-light, #dee2e6)}.status-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--color-border-medium, #ced4da);border-top-color:#3498db;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.status-icon{flex-shrink:0}.ai-assistant-modal{position:fixed;bottom:20px;right:20px;width:380px;height:520px;background:#fff;border-radius:var(--radius-lg);box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;z-index:var(--z-modal);transition:box-shadow .2s ease;overflow:hidden}.ai-assistant-modal:hover{box-shadow:0 12px 48px #0003}.ai-assistant-modal.resizing{transition:none;box-shadow:0 12px 48px #00000040}.ai-assistant-modal.minimized{height:auto;width:250px}.resize-handle-tl{position:absolute;top:0;left:0;width:20px;height:20px;cursor:nw-resize;z-index:var(--z-dropdown);background:transparent}.resize-handle-tl:before{content:"";position:absolute;top:4px;left:4px;width:10px;height:10px;border-left:2px solid rgba(255,255,255,.6);border-top:2px solid rgba(255,255,255,.6);border-radius:2px 0 0}.resize-handle-tl:hover:before{border-color:#ffffffe6}.ai-assistant-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;border-radius:12px 12px 0 0;flex-shrink:0}.minimized .ai-assistant-header{border-radius:var(--radius-lg)}.ai-assistant-title{font-weight:600;font-size:var(--font-size-sm)}.ai-assistant-controls{display:flex;gap:8px}.ai-assistant-btn{background:none;border:none;color:#fff;font-size:var(--font-size-lg);cursor:pointer;padding:0 4px;opacity:.8;transition:opacity .2s}.ai-assistant-btn:hover{opacity:1}.ai-assistant-body{flex:1;display:flex;flex-direction:column;overflow:hidden}.ai-usage-stats{padding:8px 12px;background:var(--color-bg-light);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-xs);flex-shrink:0}.usage-total{font-weight:600;color:#2c3e50}.usage-details{color:var(--color-text-secondary);margin-top:2px}.usage-personal{display:flex;justify-content:space-between;color:#2c3e50}.usage-personal span{color:var(--color-gray-400)}.usage-tournament{display:flex;justify-content:space-between;font-size:.7rem;font-style:italic;color:var(--color-text-secondary);margin-top:2px}.usage-tournament span{color:var(--color-gray-400)}
