.icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1;vertical-align:middle}.icon-img{width:100%;height:100%;object-fit:contain;display:block;opacity:1}.icon-emoji{font-family:"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji",sans-serif;text-align:center}.icon-xs{width:14px;height:14px;font-size:12px}.icon-sm{width:18px;height:18px;font-size:14px}.icon-md{width:22px;height:22px;font-size:18px}.icon-lg{width:26px;height:26px;font-size:22px}.icon-xl{width:36px;height:36px;font-size:30px}.icon-img{filter:none}.btn-primary .icon-img,.nav-link.active .icon-img,.tab-btn.active .icon-img,.amount-btn-large .icon-img,.toggle-btn.on .icon-img{filter:brightness(0) invert(1)}.btn:hover .icon-img,.nav-link:hover .icon-img,.tab-btn:hover .icon-img{transition:filter var(--transition-fast),opacity var(--transition-fast)}.btn-icon .icon-img{opacity:.7}.btn-icon:hover .icon-img{opacity:1}@media(max-width:640px){.icon-sm{width:20px;height:20px;min-width:20px;min-height:20px}.icon-md{width:24px;height:24px;min-width:24px;min-height:24px}.icon-img{min-width:100%;min-height:100%}}.auth-page{min-height:100vh;display:flex;background:#fff}.auth-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.auth-loading p{color:var(--color-text-light);font-size:14px}.auth-left{flex:1;display:flex;align-items:center;justify-content:center;padding:48px;background:radial-gradient(ellipse 80% 50% at 20% 40%,rgba(34,197,94,.15) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 80% 60%,rgba(74,222,128,.1) 0%,transparent 50%),radial-gradient(ellipse 100% 80% at 50% 100%,rgba(22,101,52,.3) 0%,transparent 50%),linear-gradient(160deg,#052e16,#14532d,#166534 70%,#15803d);position:relative;overflow:hidden}.auth-left:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;pointer-events:none}.auth-left:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 30%,rgba(74,222,128,.08) 0%,transparent 40%);pointer-events:none}.auth-left-content{max-width:420px;position:relative;z-index:1}.auth-brand{display:flex;align-items:center;gap:14px;margin-bottom:8px}.brand-icon .icon-img{filter:brightness(0) invert(1)}.brand-name{font-size:36px;font-weight:700;color:#fff;letter-spacing:2px;margin:0}.brand-tagline{font-size:14px;font-weight:500;color:#ffffffb3;margin:0 0 32px}.brand-description{font-size:15px;line-height:1.7;color:#fffc;margin:0 0 40px}.auth-features{display:flex;flex-direction:column;gap:20px}.feature{display:flex;align-items:flex-start;gap:14px}.feature-icon-wrap{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:10px;flex-shrink:0}.feature-icon .icon-img{filter:brightness(0) invert(1)}.feature-text{display:flex;flex-direction:column;gap:2px}.feature-title{font-size:14px;font-weight:600;color:#fff}.feature-desc{font-size:13px;color:#ffffffa6}.auth-download{margin-top:24px;padding-top:24px;border-top:1px solid var(--color-border-light);text-align:center}.download-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 20px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;color:var(--color-text);font-size:14px;font-weight:500;text-decoration:none;transition:all .15s}.download-btn:hover{background:var(--color-border-light);border-color:var(--color-border-dark)}.auth-right{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;background:#fff}.auth-card{width:100%;max-width:380px}.auth-card h2{margin:0 0 8px;font-size:26px;font-weight:700;color:var(--color-text)}.auth-subtitle{margin:0 0 28px;font-size:14px;color:var(--color-text-light)}.auth-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.auth-btn{display:flex;align-items:center;justify-content:center;padding:14px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;width:100%}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-btn-outline{background:#fff;border:1px solid var(--color-border);color:var(--color-text)}.auth-btn-outline:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-border-dark)}.auth-btn-primary{background:#1e7a34;border:none;color:#fff;box-shadow:0 4px 14px #1e7a344d}.auth-btn-primary:hover:not(:disabled){background:#145523;transform:translateY(-1px);box-shadow:0 6px 20px #1e7a3459}.auth-divider{display:flex;align-items:center;gap:16px;margin-bottom:24px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider span{font-size:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.auth-form{display:flex;flex-direction:column;gap:14px}.form-field input{width:100%;padding:14px 16px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:10px;font-size:15px;color:var(--color-text);transition:all .15s}.form-field input:focus{outline:none;border-color:#1e7a34;background:#fff;box-shadow:0 0 0 3px #1e7a341a}.form-field input::placeholder{color:var(--color-text-muted)}.form-field input:disabled{opacity:.5;cursor:not-allowed}.auth-error{padding:12px 14px;background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:10px;font-size:13px;color:#dc2626}.auth-footer{margin-top:24px;padding-top:24px;border-top:1px solid var(--color-border-light);text-align:center}.auth-footer p{margin:0;font-size:14px;color:var(--color-text-light)}.auth-link{background:none;border:none;padding:0;font-size:14px;font-weight:600;color:#1e7a34;cursor:pointer;transition:color .15s}.auth-link:hover{color:#145523;text-decoration:underline}.auth-mobile-info{display:none;width:100%;max-width:380px}@media(max-width:1024px){.auth-left,.auth-right{padding:40px}.brand-name{font-size:32px}.auth-left-content{max-width:360px}.auth-card{max-width:340px}}@media(max-width:768px){.auth-page{flex-direction:column;min-height:100vh;height:auto;background:linear-gradient(160deg,#052e16,#14532d,#166534 70%,#15803d)}.auth-left{flex:none;padding:32px 24px 24px;background:transparent}.auth-left:before,.auth-left:after{display:none}.auth-left-content{max-width:100%;text-align:center}.auth-brand{justify-content:center;margin-bottom:4px}.brand-name{font-size:28px;letter-spacing:1px}.brand-tagline{text-align:center;margin-bottom:0}.brand-description,.auth-features{display:none}.auth-right{flex:none;padding:0 20px;background:transparent}.auth-card{max-width:100%;background:#fff;padding:28px 24px;border-radius:16px;box-shadow:0 8px 32px #0003}.auth-card h2{font-size:22px}.auth-subtitle{margin-bottom:24px}.auth-download{display:block;margin-top:20px;padding-top:20px}.auth-mobile-info{display:block;max-width:none;width:100%;padding:32px 24px 48px;background:transparent}.mobile-description{font-size:14px;line-height:1.6;color:#ffffffd9;text-align:center;margin:0 0 28px}.mobile-features{display:flex;flex-direction:column;gap:18px}.mobile-feature{display:flex;align-items:flex-start;gap:14px}.mobile-feature-icon-wrap{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff26;border-radius:10px;flex-shrink:0}.mobile-feature-icon .icon-img{filter:brightness(0) invert(1)}.mobile-feature-text{display:flex;flex-direction:column;gap:2px}.mobile-feature-title{font-size:14px;font-weight:600;color:#fff}.mobile-feature-desc{font-size:13px;color:#ffffffb3}}@media(max-width:400px){.auth-left{padding:24px 16px 20px}.brand-name{font-size:24px}.auth-right{padding:0 16px}.auth-card{padding:24px 20px}.auth-mobile-info{padding:28px 16px 40px}.auth-btn{padding:12px 20px}}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--space-md);z-index:1000;animation:fadeIn .2s ease}.modal-content{background-color:var(--color-bg-card);border-radius:var(--radius-xl);width:100%;max-width:460px;max-height:90vh;overflow-y:auto;animation:slideUp .25s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border-light)}.modal-header h2{margin:0;font-size:var(--font-size-lg)}.modal-close{background:none;border:none;font-size:var(--font-size-xl);color:var(--color-text-muted);cursor:pointer;padding:4px;line-height:1;transition:color var(--transition-fast);border-radius:var(--radius-sm)}.modal-close:hover{color:var(--color-text);background-color:var(--color-bg)}.modal-form{padding:var(--space-lg)}.modal-form textarea{resize:vertical;min-height:80px}.modal-actions{display:flex;gap:var(--space-md);justify-content:flex-end;margin-top:var(--space-lg)}@media(max-width:480px){.modal-content{max-width:100%;margin:var(--space-md);border-radius:var(--radius-lg)}.modal-header,.modal-form{padding:var(--space-md)}.modal-actions{flex-direction:column-reverse}.modal-actions .btn{width:100%}}.home-page{max-width:600px;margin:0 auto}.tournaments-list{display:flex;flex-direction:column;gap:8px}.tournament-card{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:16px 20px;background:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;box-shadow:0 1px 3px #00000014}.tournament-card:hover{background:#fff;box-shadow:0 4px 12px #0000001f;transform:translateY(-1px)}.tournament-card:active{transform:translateY(0);box-shadow:0 1px 3px #00000014}.card-main{flex:1;min-width:0}.card-main h3{margin:0;font-size:var(--font-size-md);font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-description{margin:4px 0 0;font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-info{display:flex;align-items:center;gap:12px;flex-shrink:0}.info-item{display:flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:500}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border)}.status-dot.public{background:var(--color-success);box-shadow:0 0 6px #22c55e80}.card-arrow{color:var(--color-text-muted);opacity:.5;transition:all var(--transition-fast)}.tournament-card:hover .card-arrow{opacity:1;transform:translate(2px)}.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);background:#fff;border-radius:var(--radius-xl);box-shadow:0 1px 3px #00000014}.empty-state .empty-icon{opacity:.3;margin-bottom:var(--space-md)}.empty-state h2{margin:0 0 var(--space-sm);color:var(--color-text)}.empty-state p{margin:0 0 var(--space-lg);color:var(--color-text-muted)}@media(max-width:640px){.tournament-card{padding:14px 16px}.card-main h3{font-size:var(--font-size-sm)}.card-description{display:none}}.confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--space-md);z-index:1000;animation:fadeIn .15s ease}.confirm-modal{background:#fff;border-radius:var(--radius-lg);padding:var(--space-lg);max-width:360px;width:100%;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.confirm-title{margin:0 0 var(--space-sm);font-size:var(--font-size-lg);font-weight:600;color:var(--color-text)}.confirm-message{margin:0 0 var(--space-lg);font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5;white-space:pre-wrap}.confirm-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.btn-cancel{padding:10px 16px;background:var(--color-bg);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:background var(--transition-fast)}.btn-cancel:hover{background:var(--color-border-light)}.btn-confirm{padding:10px 16px;background:var(--color-primary);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;color:#fff;cursor:pointer;transition:background var(--transition-fast)}.btn-confirm:hover{background:var(--color-primary-dark)}.btn-confirm.danger{background:var(--color-danger)}.btn-confirm.danger:hover{background:#dc2626}.team-manager{display:flex;flex-direction:column;gap:var(--space-sm);width:100%}.add-team-form{display:flex;gap:var(--space-sm);padding:var(--space-md);background:#fff;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;flex-wrap:wrap}.add-team-input{flex:1;min-width:30px;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.add-team-input:focus{outline:none;border-color:var(--color-primary)}.color-picker-dropdown{position:relative}.color-picker-trigger{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.color-picker-trigger:hover:not(:disabled){border-color:var(--color-primary)}.color-picker-trigger:disabled{opacity:.6;cursor:not-allowed}.color-swatch{width:20px;height:20px;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.dropdown-arrow{font-size:8px;color:var(--color-text-muted)}.color-picker-popup{position:absolute;top:calc(100% + 4px);left:0;display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px;background:#fff;border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;z-index:100}.color-option{width:28px;height:28px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--color-text);box-shadow:0 0 0 2px #fff,0 0 0 3px var(--color-text)}.teams-list{display:flex;flex-direction:column;gap:4px}.team-row{display:flex;align-items:center;gap:var(--space-sm);padding:10px var(--space-md);background:#fff;border-radius:var(--radius-md);box-shadow:0 1px 3px #0000000f;min-width:0}.team-name-btn{flex:1;padding:0;background:none;border:none;text-align:left;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);cursor:pointer}.team-name-btn:hover{color:var(--color-primary)}.team-name-input{flex:1;padding:6px 10px;border:1px solid var(--color-primary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500}.team-name-input:focus{outline:none}.team-row-right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.delete-team-btn{padding:6px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.delete-team-btn:hover{background:#ef44441a;color:var(--color-danger)}.empty-teams{text-align:center;padding:var(--space-xl);color:var(--color-text-muted);background:#fff;border-radius:var(--radius-lg)}.empty-teams p{margin:0;font-size:var(--font-size-sm)}@media(max-width:200px){.add-team-form{flex-wrap:wrap}.add-team-input{flex:1 1 100%}.team-row{flex-wrap:wrap}.team-name-btn,.team-name-input{flex:1 1 100%;margin-bottom:6px}.team-row-right{width:100%;justify-content:space-between;flex-shrink:1}}.score-manager{width:100%}.teams-scores-list{display:flex;flex-direction:column;gap:6px}.team-score-row{display:grid;grid-template-columns:40px auto 1fr 70px 60px;align-items:center;gap:12px;width:100%;padding:14px 16px;background:#fff;border:none;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;cursor:pointer;text-align:left;transition:all var(--transition-fast)}.team-score-row:hover:not(:disabled){box-shadow:0 2px 8px #3b82f626;transform:translateY(-1px)}.team-score-row:disabled{opacity:.7;cursor:not-allowed}.team-score-row.podium-1{background:linear-gradient(90deg,#ffd7001a,#fff)}.team-score-row.podium-2{background:linear-gradient(90deg,#c0c0c01a,#fff)}.team-score-row.podium-3{background:linear-gradient(90deg,#cd7f321a,#fff)}.team-rank{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-muted);text-align:center}.podium-1 .team-rank{color:#ca8a04}.podium-2 .team-rank{color:#6b7280}.podium-3 .team-rank{color:#b45309}.team-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.team-name{font-size:var(--font-size-md);font-weight:600;color:var(--color-primary)!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-undo-col{display:flex;justify-content:flex-end}.team-score{font-size:1.25rem;font-weight:700;color:var(--color-text);text-align:right}.undo-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#4ade8026;border:none;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;color:#16a34a;cursor:pointer;transition:all var(--transition-fast);animation:slideIn .3s ease}.undo-btn:hover{background:#ef444426;color:var(--color-danger)}@keyframes slideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.add-view{background:#fff;border-radius:var(--radius-lg);box-shadow:0 1px 3px #00000014;overflow:hidden}.add-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid var(--color-border)}.back-btn{padding:8px 14px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.back-btn:hover{background:#fff;border-color:var(--color-text-muted)}.selected-team-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.team-dot-lg{width:16px;height:16px;border-radius:50%;flex-shrink:0}.selected-team-name{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-team-score{font-size:var(--font-size-sm);color:var(--color-text-muted);flex-shrink:0}.amount-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:var(--space-lg)}.amount-btn-lg{padding:28px 16px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border:none;border-radius:var(--radius-lg);font-size:1.75rem;font-weight:800;color:#fff;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 4px #3b82f64d}.amount-btn-lg:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.amount-btn-lg:active:not(:disabled){transform:translateY(0)}.amount-btn-lg:disabled{opacity:.6;cursor:not-allowed}.custom-amount-form{display:grid;grid-template-columns:1fr auto;gap:12px;padding:0 var(--space-lg) var(--space-lg)}.custom-input{padding:14px 16px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);text-align:center}.custom-input:focus{outline:none;border-color:var(--color-primary);background:#fff}.custom-input::placeholder{color:var(--color-text-muted);font-weight:400}.custom-submit-btn{padding:14px 28px;background:var(--color-text);border:none;border-radius:var(--radius-lg);font-size:var(--font-size-md);font-weight:700;color:#fff;cursor:pointer;transition:all var(--transition-fast)}.custom-submit-btn:hover:not(:disabled){opacity:.85}.custom-submit-btn:disabled{opacity:.4;cursor:not-allowed}.score-manager-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-xl);background:#fff;border-radius:var(--radius-lg);text-align:center}.empty-icon{font-size:2.5rem;opacity:.5}.score-manager-empty p{margin:0;color:var(--color-text-muted);font-size:var(--font-size-sm)}@media(max-width:480px){.team-score-row{grid-template-columns:28px auto 1fr 55px 45px;gap:8px;padding:12px}.team-rank{font-size:var(--font-size-sm)}.team-dot{width:10px;height:10px}.team-name{font-size:var(--font-size-sm)}.team-score{font-size:1rem}.undo-btn{font-size:.6rem;padding:3px 6px}.add-header{flex-wrap:wrap;gap:var(--space-sm)}.back-btn{padding:6px 12px;font-size:var(--font-size-xs)}.selected-team-name{font-size:var(--font-size-md)}.amount-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:var(--space-md)}.amount-btn-lg{padding:20px 12px;font-size:1.4rem}.custom-amount-form{grid-template-columns:1fr;padding:0 var(--space-md) var(--space-md)}.custom-input{padding:12px 14px;font-size:var(--font-size-md)}.custom-submit-btn{width:100%;padding:14px}}.tournament-settings{display:flex;flex-direction:column;gap:var(--space-lg);width:100%}.settings-section{display:flex;flex-direction:column;gap:var(--space-sm)}.section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0;padding-left:2px}.settings-card{background:#fff;border-radius:var(--radius-lg);padding:var(--space-md);box-shadow:0 1px 3px #00000014}.settings-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}.settings-desc{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0 0 var(--space-sm)}.info-display{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;background:none;border:none;cursor:pointer;text-align:left}.info-display:hover{opacity:.8}.info-content{display:flex;flex-direction:column;gap:2px}.info-name{font-size:var(--font-size-md);font-weight:600;color:var(--color-text)}.info-desc{font-size:var(--font-size-sm);color:var(--color-text-muted)}.info-display .icon{color:var(--color-text-muted)}.edit-info-form{display:flex;flex-direction:column;gap:var(--space-sm)}.edit-name-input,.edit-desc-input{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.edit-name-input{font-weight:600}.edit-name-input:focus,.edit-desc-input:focus{outline:none;border-color:var(--color-primary)}.edit-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.btn-link{padding:8px 12px;background:none;border:none;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer}.btn-link:hover{color:var(--color-text)}.current-amounts{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:var(--space-sm)}.amount-tag{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:var(--color-primary);border:none;border-radius:var(--radius-full);color:#fff;font-weight:600;font-size:var(--font-size-sm);cursor:pointer;transition:opacity var(--transition-fast)}.amount-tag:hover{opacity:.85}.remove-x{font-size:14px;opacity:.7}.amount-tag:hover .remove-x{opacity:1}.custom-amount{display:flex;gap:var(--space-xs)}.custom-amount input{flex:1;max-width:140px;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.custom-amount input:focus{outline:none;border-color:var(--color-primary)}.toggle-row{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;background:none;border:none;cursor:pointer;text-align:left}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.toggle-desc{font-size:var(--font-size-xs);color:var(--color-text-muted)}.toggle-switch{width:44px;height:24px;background:var(--color-border);border-radius:12px;padding:2px;transition:background var(--transition-fast)}.toggle-switch.on{background:var(--color-primary)}.toggle-knob{width:20px;height:20px;background:#fff;border-radius:50%;transition:transform var(--transition-fast);box-shadow:0 1px 3px #0003}.toggle-switch.on .toggle-knob{transform:translate(20px)}.duration-grid{display:flex;flex-wrap:wrap;gap:6px}.duration-btn{padding:8px 14px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.duration-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.duration-btn.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.bg-color-grid{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.bg-option{width:40px;height:40px;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.bg-option:hover{transform:scale(1.1)}.bg-option.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px #fff,0 0 0 4px var(--color-primary)}.bg-custom{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--color-bg);border:1px dashed var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-xs);color:var(--color-text-muted);transition:all var(--transition-fast)}.bg-custom:hover{border-color:var(--color-primary);color:var(--color-primary)}.bg-custom input[type=color]{width:20px;height:20px;padding:0;border:none;border-radius:4px;cursor:pointer}.bg-custom input[type=color]::-webkit-color-swatch-wrapper{padding:0}.bg-custom input[type=color]::-webkit-color-swatch{border:1px solid rgba(0,0,0,.15);border-radius:4px}.danger-section{margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.danger-section .section-title{color:var(--color-danger)}.delete-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-md);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-lg);color:var(--color-danger);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.delete-btn:hover{background:#ef44441f;border-color:#ef44444d}.tournament-page{max-width:900px;margin:0 auto}.tab-nav{display:flex;gap:6px;margin-bottom:var(--space-lg);background-color:#fff;padding:6px;border-radius:var(--radius-xl);box-shadow:0 2px 8px #0000000f}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 16px;background:transparent;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast)}.tab-btn:hover{background-color:var(--color-bg);color:var(--color-text)}.tab-btn.active{background-color:var(--color-primary);color:#fff;box-shadow:0 2px 8px #1e7a344d}.tab-content{animation:fadeIn .2s ease}.section-card{background-color:#fff;border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:0 2px 8px #0000000f}.section-header{margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:2px solid var(--color-bg)}.section-header h3{margin:0;font-size:var(--font-size-lg);font-weight:700;color:var(--color-text)}.section-header p{margin:var(--space-xs) 0 0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.toggle-btn{padding:10px 24px;border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:600;border:none;cursor:pointer;transition:all var(--transition-fast);min-width:80px}.toggle-btn.on{background-color:var(--color-success);color:#fff;box-shadow:0 2px 8px #22c55e4d}.toggle-btn.off{background-color:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.toggle-btn:hover{transform:scale(1.02)}.share-tab{width:100%}.share-card{background-color:#fff;border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:0 2px 8px #0000000f}.share-header{margin-bottom:var(--space-md)}.share-header h3{margin:0;font-size:var(--font-size-xl);font-weight:700;color:var(--color-text)}.share-description{color:var(--color-text-muted);margin-bottom:var(--space-xl);line-height:1.6;font-size:var(--font-size-sm)}.share-toggle-section{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg);background-color:var(--color-bg);border-radius:var(--radius-lg);margin-bottom:var(--space-lg)}.share-toggle-info{display:flex;align-items:center;gap:var(--space-md)}.share-toggle-info strong{display:block;margin-bottom:2px;font-size:var(--font-size-md);font-weight:600}.share-toggle-info p{margin:0;font-size:var(--font-size-xs);color:var(--color-text-muted)}.share-link-section{padding-top:var(--space-lg);border-top:2px solid var(--color-bg)}.share-link-section label{display:block;font-weight:600;margin-bottom:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-text)}.share-link-row{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.share-link-input{flex:1;font-family:SF Mono,Monaco,Consolas,monospace;font-size:var(--font-size-sm);background-color:var(--color-bg);border:none}.share-link-input:focus{box-shadow:none;background-color:var(--color-bg)}.share-preview-btn{width:100%;justify-content:center;text-decoration:none}.share-private-notice{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background-color:var(--color-bg);border-radius:var(--radius-lg);color:var(--color-text-muted)}.share-private-notice p{margin:0;font-size:var(--font-size-sm)}@media(max-width:640px){.tab-nav{padding:4px;gap:4px}.tab-btn{padding:12px 8px;flex-direction:column;gap:4px;font-size:var(--font-size-xs)}.tab-btn .icon,.tab-btn .icon.icon-sm{width:22px!important;height:22px!important;min-width:22px;min-height:22px;display:inline-flex!important}.share-toggle-section{flex-direction:column;text-align:center;gap:var(--space-md)}.share-toggle-info{flex-direction:column;align-items:center}.share-link-row{flex-direction:column}.share-card{padding:var(--space-lg)}}.sb2-container{flex:1;display:flex;flex-direction:column;gap:2.2vh;padding:2vh 2.5vw;min-height:0;overflow:hidden;color:#fff}.sb2-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.sb2-empty span{font-size:4vw;opacity:.4}.sb2-empty p{font-size:1.1vw;color:#ffffff80}.sb2-podium{display:flex;justify-content:center;flex-shrink:0}.sb2-podium-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.4vw;width:100%;max-width:64vw}.sb2-podium-entry{min-width:0}.sb2-podium-card{position:relative;display:flex;flex-direction:column;align-items:center;gap:.9vh;padding:2.4vh 1.6vw 2.1vh;border-radius:1vw;background:linear-gradient(180deg,#0f172a99,#0f172a4d);border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 20px 40px #03071259;overflow:hidden}.sb2-podium-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#ffffff59,#fff0 60%);opacity:.6}.sb2-podium-card:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.12) 0%,transparent 45%);opacity:.6;pointer-events:none}.sb2-podium-rank{display:flex;align-items:baseline;gap:.2vw}.sb2-podium-rank-num{font-size:3vw;font-weight:800;line-height:1;letter-spacing:-.03em;color:#ffffff40}.sb2-podium-rank-suffix{font-size:1.1vw;font-weight:600;color:#fff3}.sb2-podium-dot{width:1.1vw;height:1.1vw;border-radius:50%;flex-shrink:0;box-shadow:0 0 .6vw currentColor}.sb2-podium-name{font-size:1.2vw;font-weight:600;color:#ffffffe6;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb2-podium-score-row{display:flex;align-items:baseline;justify-content:center;gap:.4vw}.sb2-podium-score{font-size:2vw;font-weight:700;color:#fff}.sb2-podium-pts-label{font-size:.9vw;font-weight:500;color:#fff6;text-transform:uppercase;letter-spacing:.05vw}.sb2-pos-1 .sb2-podium-card{background:linear-gradient(180deg,#fbbf2433,#0f172a66);border-color:#fbbf2466;box-shadow:0 0 3vw #fbbf2433}.sb2-pos-1 .sb2-podium-rank-num{color:#fbbf24;font-size:3.3vw}.sb2-pos-1 .sb2-podium-rank-suffix{color:#fbbf24b3}.sb2-pos-1 .sb2-podium-score{font-size:2.2vw}.sb2-pos-1 .sb2-podium-name{font-size:1.35vw}.sb2-pos-1 .sb2-podium-dot{width:1.4vw;height:1.4vw}.sb2-pos-2 .sb2-podium-card{background:linear-gradient(180deg,#94a3b824,#0f172a59);border-color:#94a3b859}.sb2-pos-2 .sb2-podium-rank-num{color:#9ca3af}.sb2-pos-2 .sb2-podium-rank-suffix{color:#9ca3af99}.sb2-pos-3 .sb2-podium-card{background:linear-gradient(180deg,#b453092e,#0f172a59);border-color:#d9770659}.sb2-pos-3 .sb2-podium-rank-num{color:#d97706}.sb2-pos-3 .sb2-podium-rank-suffix{color:#d9770699}.sb2-lists-wrapper{flex:1;min-height:0;display:flex;gap:1.5vw;justify-content:center;overflow:hidden}.sb2-list{flex:1;min-height:0;overflow:hidden;max-width:52vw;width:100%;display:flex;flex-direction:column;gap:.8vh}.sb2-desktop-only{justify-content:flex-start;padding-left:6vw;padding-right:6vw}.sb2-desktop-only .sb2-list{max-width:38vw}.sb2-mobile-only{display:none}.sb2-row{display:flex;align-items:center;gap:.5vw;padding:1.2vh 1vw;border-radius:.6vw;background:#0f172a80;border:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.sb2-row:hover{background:#0f172aa6;border-color:#ffffff1f}.sb2-has-podium .sb2-row.sb2-top3{display:none}.sb2-row-rank{width:2.5vw;font-size:1.1vw;font-weight:700;color:#ffffff80;text-align:center;flex-shrink:0}.sb2-row-rank.sb2-rank-1{color:#fbbf24}.sb2-row-rank.sb2-rank-2{color:#9ca3af}.sb2-row-rank.sb2-rank-3{color:#d97706}.sb2-row-change{width:.5vw;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sb2-row-dot{width:.9vw;height:.9vw;border-radius:50%;flex-shrink:0}.sb2-row-name{flex:1;font-size:1.1vw;font-weight:600;color:#fffffff2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb2-row-score{display:flex;align-items:center;gap:.6vw;flex-shrink:0;margin-left:auto}.sb2-row-pts{font-size:1.2vw;font-weight:700;color:#fffffff2}.sb2-score-change{font-size:.7vw;font-weight:700;color:#4ade80;padding:.25vh .5vw;background:#4ade8033;border-radius:999px;flex-shrink:0}.sb2-score-change.sb2-animate{animation:sb2ChangePopIn .4s ease-out}@keyframes sb2ChangePopIn{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.08)}to{opacity:1;transform:scale(1)}}.sb2-pos-change{font-size:.8vw;font-weight:700}.sb2-pos-change.sb2-up{color:#4ade80}.sb2-pos-change.sb2-down{color:#ef4444}@media(max-width:768px){.sb2-container{padding:12px;gap:0;overflow:hidden}.sb2-empty span{font-size:3rem}.sb2-empty p{font-size:1rem}.sb2-podium{display:none}.sb2-has-podium .sb2-row.sb2-top3{display:flex}.sb2-lists-wrapper{flex-direction:column;gap:0;overflow:visible}.sb2-mobile-only{display:flex}.sb2-desktop-only{display:none}.sb2-list{max-width:100%;gap:10px;overflow-y:auto;-webkit-overflow-scrolling:touch}.sb2-row{gap:12px;padding:14px 16px}.sb2-row-rank{width:32px;font-size:1.1rem}.sb2-row-change{width:16px}.sb2-row-dot{width:12px;height:12px}.sb2-row-name{font-size:1.05rem}.sb2-row-pts{font-size:1.2rem}.sb2-score-change{font-size:.8rem;padding:4px 8px}.sb2-pos-change{font-size:.9rem}}.live-page{height:100vh;max-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#0f172a,#1e293b);padding:16px;overflow:hidden}.live-header{display:flex;align-items:center;gap:20px;padding:16px 24px;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.1)}.live-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#ef4444;color:#fff;font-size:.875rem;font-weight:700;letter-spacing:1px;border-radius:8px}.pulse-dot{width:10px;height:10px;background:#fff;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.live-header h1{margin:0;font-size:2rem;font-weight:800;color:#fff;letter-spacing:-.5px;flex:1}.fullscreen-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#ffffffb3;cursor:pointer;transition:all .2s;flex-shrink:0}.fullscreen-btn:hover{background:#ffffff26;color:#fff}.fullscreen-btn svg{width:20px;height:20px}.live-badge.polling{background:#f59e0b}.live-badge.polling .pulse-dot{animation:pulse-slow 2.5s ease-in-out infinite}.live-badge.error{background:#6b7280}.live-badge.error .pulse-dot{animation:pulse-error 1s ease-in-out infinite}@keyframes pulse-slow{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}@keyframes pulse-error{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}.live-badge.unavailable{background:#64748b}.live-badge.unavailable .pulse-dot{animation:pulse-unavailable 3s ease-in-out infinite}@keyframes pulse-unavailable{0%,to{opacity:.3}50%{opacity:.8}}.live-main{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.live-footer{display:flex;align-items:center;padding:12px 20px;flex-shrink:0;background:transparent}.footer-info{display:flex;align-items:center;gap:10px;font-size:.75rem}.footer-brand{font-weight:700;font-size:.9rem;color:#fff6;letter-spacing:2px;text-transform:lowercase}.footer-divider{color:#fff3}.footer-link{color:#ffffff59;text-decoration:none;transition:color .2s}.footer-link:hover{color:#fff9}.footer-updated{color:#ffffff59}.qr-corner{position:absolute;bottom:2vh;right:2vw;display:flex;flex-direction:column;align-items:center;gap:.5vh;pointer-events:none}.qr-corner svg{width:8vw;height:8vw;max-width:150px;max-height:150px;min-width:80px;min-height:80px}.qr-corner .qr-label{font-size:.6vw;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.live-status-message{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;padding:32px}.live-status-message .status-icon{font-size:4rem;margin-bottom:16px;opacity:.9}.live-status-message h2{margin:0 0 8px;font-size:1.75rem;font-weight:700}.live-status-message p{margin:0;font-size:1rem;color:#fff9}.live-status-message .status-hint{display:block;margin-top:24px;padding:12px 20px;background:#ffffff1a;border-radius:8px;font-size:.875rem;color:#ffffff80}.live-status-message .loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:#4ade80;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.header-actions{display:flex;align-items:center;gap:8px}.qr-toggle-btn{display:none;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#ffffffb3;cursor:pointer;transition:all .2s}.qr-toggle-btn:hover{background:#ffffff26;color:#fff}.qr-toggle-btn svg{width:20px;height:20px}.qr-modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.qr-modal{position:relative;background:#fff;border-radius:16px;padding:32px;text-align:center;max-width:90%;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.qr-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;background:#f1f5f9;border:none;border-radius:50%;font-size:1.25rem;color:#64748b;cursor:pointer;transition:all .2s}.qr-modal-close:hover{background:#e2e8f0;color:#1e293b}.qr-modal h3{margin:0 0 20px;font-size:1.25rem;font-weight:700;color:#1e293b}.qr-modal-code{display:inline-block;padding:16px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.qr-modal-url{margin:16px 0 0;font-size:.75rem;color:#64748b;word-break:break-all}@media(min-width:1200px){.live-page{padding:20px 32px}.live-header h1{font-size:2rem}}@media(min-width:1600px){.live-page{padding:24px 40px}.live-header{padding:16px 24px}.live-header h1{font-size:2.5rem}.live-badge{font-size:.9rem;padding:8px 16px}}@media(max-width:768px){.live-page{padding:10px;gap:8px}.live-header{gap:10px;padding:10px 12px;border-radius:12px}.live-header h1{font-size:1.1rem}.live-badge{padding:5px 8px;font-size:.7rem;gap:6px}.pulse-dot{width:8px;height:8px}.fullscreen-btn{width:32px;height:32px;border-radius:8px}.fullscreen-btn svg{width:14px;height:14px}.live-main{overflow-y:auto;-webkit-overflow-scrolling:touch}.live-status-message{padding:24px 16px}.live-status-message .status-icon{font-size:3rem}.live-status-message h2{font-size:1.4rem}.live-status-message p{font-size:.9rem}.live-footer{padding:10px 12px}.footer-info{gap:8px;font-size:.65rem}.footer-brand{font-size:.8rem}.qr-corner{display:none}.qr-toggle-btn{display:flex;width:34px;height:34px;border-radius:8px}.qr-toggle-btn svg{width:16px;height:16px}}@media(max-width:380px){.live-page{padding:8px}.live-header{padding:8px 10px}.live-header h1{font-size:1rem}.live-badge{padding:4px 6px;font-size:.65rem}}.account-page{max-width:450px;margin:0 auto}.profile-info{display:flex;flex-direction:column}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--color-border-light)}.info-row:last-child{border-bottom:none}.info-row label{font-weight:500;color:var(--color-text-light);margin-bottom:0;font-size:var(--font-size-sm)}.info-row span{color:var(--color-text);font-weight:500}.user-id{font-family:SF Mono,Monaco,Consolas,monospace;font-size:var(--font-size-xs)!important;color:var(--color-text-muted)!important;font-weight:400!important}.profile-actions{margin-top:var(--space-lg);padding-top:var(--space-lg);border-top:1px solid var(--color-border-light)}@media(max-width:640px){.info-row{flex-direction:column;align-items:flex-start;gap:4px}.profile-actions .btn{width:100%;justify-content:center}}.app{min-height:100vh;display:flex;flex-direction:column}.app-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-lg);background-color:var(--color-bg-card);border-bottom:1px solid var(--color-border-light);position:sticky;top:0;z-index:100}.nav-brand{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;transition:opacity var(--transition-fast);min-width:0;flex:1;max-width:60%}.nav-brand:hover{opacity:.8}.brand-text{font-size:var(--font-size-lg);font-weight:700;color:var(--color-primary);letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-links{display:flex;gap:var(--space-xs)}.nav-link{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-light);cursor:pointer;transition:all var(--transition-fast)}.nav-link:hover{background-color:var(--color-bg);color:var(--color-text)}.nav-link.active{background-color:var(--color-primary);color:#fff}.app-main{flex:1;padding:var(--space-lg);max-width:1100px;width:100%;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap}.header-title{display:flex;align-items:center;gap:var(--space-sm)}.header-title h1{font-size:var(--font-size-2xl)}.page-content{animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center;color:var(--color-text-light)}.empty-icon{margin-bottom:var(--space-md);opacity:.4;color:var(--color-text-muted)}.empty-state h2{color:var(--color-text-light);margin-bottom:var(--space-sm);font-size:var(--font-size-xl)}.empty-state p{margin-bottom:var(--space-lg);color:var(--color-text-muted)}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center}.loading-state p{margin-top:var(--space-md);color:var(--color-text-muted)}.error-state .error-icon{font-size:3rem;margin-bottom:var(--space-md)}@media(max-width:768px){.app-nav{padding:var(--space-sm) var(--space-md)}.brand-text{font-size:var(--font-size-md)}.nav-link{padding:12px;background-color:var(--color-bg);border:1px solid var(--color-border-light)}.nav-link span{display:none}.nav-links .nav-link .icon,.nav-links .nav-link .icon.icon-sm,.nav-links .nav-link .icon.icon-md{width:24px!important;height:24px!important;display:inline-flex!important}.nav-link.active{background-color:var(--color-primary);border-color:var(--color-primary)}.app-main{padding:var(--space-md)}.page-header{flex-direction:row;align-items:center;gap:var(--space-md)}.header-title{flex:1}}:root{--color-primary: #1e7a34;--color-primary-light: #28a745;--color-primary-dark: #145523;--color-secondary: #f5a623;--color-secondary-light: #ffc857;--color-secondary-dark: #d4891a;--color-bg: #f5f6f8;--color-bg-card: #ffffff;--color-bg-dark: #1a1a2e;--color-text: #1a1a1a;--color-text-light: #5a5a5a;--color-text-muted: #9ca3af;--color-border: #e2e5e9;--color-border-light: #f0f1f3;--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .15);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--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: 2rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--color-text);background-color:var(--color-bg);line-height:1.5;min-height:100vh}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--color-text)}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)}p{color:var(--color-text-light)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 20px;font-size:var(--font-size-sm);font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff;box-shadow:0 2px 6px #1e7a344d}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #1e7a3466}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background-color:#fff;color:var(--color-text);border:2px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.btn-danger{background-color:var(--color-danger);color:#fff;box-shadow:0 2px 6px #ef44444d}.btn-danger:hover:not(:disabled){background-color:#dc2626;box-shadow:0 4px 12px #ef444466}.btn-success{background-color:var(--color-success);color:#fff;box-shadow:0 2px 6px #22c55e4d}.btn-success:hover:not(:disabled){background-color:#16a34a}.btn-icon{padding:10px;background:transparent;border:none;color:var(--color-text-muted);border-radius:var(--radius-lg)}.btn-icon:hover:not(:disabled){background-color:var(--color-bg);color:var(--color-text)}.btn-icon.btn-danger{background:transparent;color:var(--color-text-muted);box-shadow:none}.btn-icon.btn-danger:hover:not(:disabled){background-color:#ef44441a;color:var(--color-danger)}.btn-full{width:100%}.btn-sm{padding:8px 14px;font-size:var(--font-size-xs)}input,select,textarea{font-family:inherit;font-size:var(--font-size-md);padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:#fff;color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e7a341f}button:focus{outline:none}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}input:disabled,select:disabled,textarea:disabled{background-color:var(--color-bg);cursor:not-allowed}input::placeholder{color:var(--color-text-muted)}label{display:block;font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--space-xs);color:var(--color-text)}.form-group{margin-bottom:var(--space-md)}.card{background-color:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-lg);border:1px solid var(--color-border-light)}.card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border-light)}.card-header h2,.card-header h3{margin:0}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}.loading-spinner.large{width:52px;height:52px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.error-message{background-color:#ef444414;color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-md);border:1px solid rgba(239,68,68,.2)}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);background-color:#ef444414;color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md);border:1px solid rgba(239,68,68,.2)}.error-close{background:none;border:none;font-size:var(--font-size-lg);cursor:pointer;color:inherit;padding:4px}.link-button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:inherit;padding:0;text-decoration:underline;font-weight:500}.link-button:hover{color:var(--color-primary-light)}@media(max-width:768px){:root{--space-lg: 1rem;--space-xl: 1.5rem;--font-size-3xl: 1.5rem;--font-size-2xl: 1.25rem}}
