@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&family=Roboto+Condensed:wght@400;700&family=Oswald:wght@500;700&display=swap);code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.add-couple-form{border:1px solid #e0e0e0;box-shadow:0 4px 15px #0000001a;padding:20px 25px}.add-couple-form h3{font-family:Poppins,sans-serif;font-weight:600;margin-bottom:25px}.form-row{display:flex;gap:15px;margin-bottom:18px}.form-input{border:1px solid #ccc;border-radius:6px;flex-grow:1;font-family:Montserrat,sans-serif;font-size:1em;padding:12px 15px;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{border-color:#ff8fab;box-shadow:0 0 0 3px #ff7eb933;outline:none}.submit-button{background-color:#ff8fab;border:none;border-radius:6px;color:#fff;cursor:pointer;display:block;font-family:Poppins,sans-serif;font-size:1.05em;font-weight:700;padding:12px 15px;transition:background-color .3s ease;width:100%}.submit-button:hover{background-color:#f06292}.submit-button:disabled{background-color:#e0e0e0;cursor:not-allowed}.anime-input-container{align-items:center;display:flex;position:relative}.anime-title-input{flex-grow:1}.anime-suggestions-dropdown{background-color:#fff;border:1px solid #ccc;border-radius:0 0 6px 6px;border-top:none;box-shadow:0 4px 8px #0000001a;left:0;list-style-type:none;margin:0;max-height:250px;overflow-y:auto;padding:0;position:absolute;right:0;top:100%;z-index:1000}.anime-suggestions-dropdown li{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;gap:10px;padding:8px 12px}.anime-suggestions-dropdown li:last-child{border-bottom:none}.anime-suggestions-dropdown li:hover{background-color:#f0f0f0}.anime-suggestions-dropdown li img{border-radius:3px;flex-shrink:0;height:auto;max-height:60px;object-fit:cover;width:40px}.anime-suggestions-dropdown .suggestion-text{display:flex;flex-direction:column;font-family:Montserrat,sans-serif}.anime-suggestions-dropdown .suggestion-title{color:#333;font-size:.95em;font-weight:500}.anime-suggestions-dropdown .suggestion-year{color:#777;font-size:.8em}.anime-suggestions-dropdown.no-results{color:#777;font-style:italic;padding:10px;text-align:center}.spinner{border:3px solid #f3f3f3;border-top-color:#ff8fab;height:20px;margin-left:-30px;margin-right:10px;width:20px;z-index:5}.character-input-container{align-items:center;display:flex;flex-grow:1;position:relative}.character-suggestions-dropdown{background-color:#fff;border:1px solid #ccc;border-radius:0 0 6px 6px;border-top:none;box-shadow:0 4px 8px #0000001a;left:0;list-style-type:none;margin:0;max-height:200px;overflow-y:auto;padding:0;position:absolute;right:0;top:100%;z-index:1000}.character-suggestions-dropdown li{align-items:center;border-bottom:1px solid #eee;color:#333;cursor:pointer;display:flex;font-family:Montserrat,sans-serif;font-size:.9em;gap:10px;padding:8px 12px}.character-suggestions-dropdown li:last-child{border-bottom:none}.character-suggestions-dropdown li:hover{background-color:#f0f0f0}.character-suggestions-dropdown li img{border-radius:50%;flex-shrink:0;height:30px;object-fit:cover;width:30px}.character-suggestions-dropdown.no-results{color:#777;font-style:italic;padding:10px;text-align:center}.couple-card{background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 2px 4px #0000000d;cursor:grab;justify-content:space-between;margin-bottom:10px;max-width:400px;min-height:60px;padding:10px;position:relative;touch-action:none;transition:box-shadow .2s ease,transform .2s ease;-webkit-user-select:none;user-select:none;width:100%}.card-content-wrapper,.couple-card{align-items:center;display:flex;gap:10px}.card-content-wrapper{flex-grow:1;min-width:0}.couple-card.ranked{background-color:#fff;border:1px solid #d1eaff}.couple-card.roster{background-color:#ffffe0;border:1px solid #fffacd}.couple-card.dragging{box-shadow:0 5px 15px #0003;cursor:grabbing;transform:scale(1.03)}.rank-indicator{color:#0277bd;flex-shrink:0;font-size:1.2em;font-weight:700;margin-right:5px;min-width:25px;text-align:right}.couple-images{align-items:center;display:flex;flex-shrink:0;gap:5px}.char-image{border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0000001a;height:45px;object-fit:cover;width:45px}.char-image.placeholder{align-items:center;background-color:#eee;color:#888;display:flex;font-size:.7em;justify-content:center}.couple-details{display:flex;flex-direction:column;flex-grow:1;justify-content:center;min-width:0}.couple-names{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#333;display:-webkit-box;font-size:.95em;line-height:1.3;margin:0;overflow:hidden;text-overflow:ellipsis}.anime-title-card{color:#555;font-size:.8em;font-style:italic;line-height:1.3;margin:3px 0 0;overflow-wrap:break-word;white-space:normal}.delete-couple-button{background:#ff7675;border:none;border-radius:50%;color:#fff;cursor:pointer;flex-shrink:0;font-size:12px;font-weight:700;height:22px;line-height:20px;margin-left:5px;padding:0;text-align:center;transition:background-color .2s ease;width:22px}.delete-couple-button:hover{background:#d63031}.delete-couple-button:focus{box-shadow:0 0 0 2px #d6303180;outline:none}.drag-handle-area{align-items:center;align-self:stretch;display:flex;padding-right:8px}.drag-handle{color:#777;cursor:grab;display:inline-block;font-size:1.2em;padding:5px;transition:color .2s ease}.drag-handle:hover{color:#333}.couple-card:hover{border-color:silver}.list-container{border-radius:8px;display:flex;flex-direction:column;min-height:500px;padding:15px;transition:background-color .2s ease}.list-container h2{color:#333;font-size:1.5em;margin-bottom:20px;margin-top:0;text-align:center}.droppable-area{border-radius:6px;flex-grow:1;min-height:400px;padding:10px}.placeholder-text{align-items:center;border:2px dashed #d1d1d1;border-radius:6px;color:#777;display:flex;font-style:italic;height:100%;justify-content:center;min-height:150px;padding:20px;text-align:center}.ranking-table .list-container{background-color:#e6f7ff;border:1px solid #b3e5fc}.ranking-table .list-container h2{color:#0277bd}.ranking-table .droppable-area.is-over-container{background-color:#b3e5fc;outline:2px dashed #0277bd}.ranking-table .placeholder-text.is-over-placeholder{color:#01579b;font-weight:700}.selection-roster .list-container{background-color:#fff9c4;border:1px solid #fff176}.selection-roster .list-container h2{color:#f57f17}.selection-roster .droppable-area.is-over-container{background-color:#fff176;outline:2px dashed #f57f17}.selection-roster .placeholder-text.is-over-placeholder{color:#e65100;font-weight:700}.export-container.export-compact-layout{background:linear-gradient(135deg,#232526,#414345);background:var(--bg-gradient,linear-gradient(135deg,#232526 0,#414345 100%));border:1px solid #ffffff1a;border:1px solid var(--border-color,#ffffff1a);box-shadow:0 5px 15px #0003;color:#e0e0e0;color:var(--text-color,#e0e0e0);font-family:Roboto Condensed,Montserrat,sans-serif;padding:15px 20px;width:780px}.export-compact-layout .export-header{background:none;border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--border-color,#ffffff0d);margin-bottom:15px;padding-bottom:10px;text-align:center}.export-compact-layout .export-header h1{background:none!important;color:#ff7eb9;color:var(--header-text-color,#ff7eb9);font-family:Oswald,Poppins,sans-serif;font-size:2em;font-weight:700;letter-spacing:.5px;margin:0 0 3px;text-transform:uppercase}.export-compact-layout .export-header .export-date{color:#b0b0b0;color:var(--secondary-text-color,#b0b0b0);font-size:.75em;margin-top:2px}.export-compact-layout .export-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:1fr}.export-compact-layout .export-couple-item{align-items:stretch;background-color:#28282db3;background-color:var(--card-bg-color,#28282db3);border:1px solid #5050504d;border:1px solid var(--card-border-color,#5050504d);border-radius:4px;box-shadow:0 1px 2px #0003;box-shadow:0 1px 2px var(--card-pseudo-shadow-color,#0003);display:flex;gap:0;height:70px;overflow:hidden;padding:0}.export-compact-layout .rank-display{align-items:center;background-color:#ff7eb9;background-color:var(--accent-color,#ff7eb9);border-right:1px solid #0003;border-right:1px solid var(--border-color,#0003);color:#fff;color:var(--rank-badge-text-color,#fff);display:flex;flex:0 0 55px;justify-content:center}.export-compact-layout .rank-display .rank-number{color:#fff;color:var(--rank-badge-text-color,#fff);font-family:Oswald,Poppins,sans-serif;font-size:2em;font-weight:700;line-height:1;text-shadow:1px 1px 2px #00000080}.export-compact-layout .couple-info-main{display:flex;flex-direction:column;flex-grow:1;justify-content:center;overflow:hidden;padding:5px 10px}.export-compact-layout .couple-info-main:has(+.couple-stats-column),.export-compact-layout .couple-info-main:has(+.movement-indicator){border-right:1px solid #0000001a;border-right:1px solid var(--border-color,#0000001a)}.export-compact-layout .character-names-inline{align-items:baseline;display:flex;gap:.2em;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.export-compact-layout .single-char-name-block{color:#d0d0d0;color:var(--text-color,#d0d0d0);font-size:1em;font-weight:500;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-compact-layout .char-given-name.highlighted{color:#fff;color:var(--highlighted-name-color,#fff);font-family:Poppins,sans-serif;font-size:1em;font-weight:600}.export-compact-layout .char-rest-of-name{color:#b0b0b0;color:var(--rest-of-name-color,#b0b0b0);font-size:.8em;margin-left:.15em}.export-compact-layout .ampersand-inline{color:#aaa;color:var(--secondary-text-color,#aaa);font-size:1em;font-weight:500}.export-compact-layout .anime-title-export{color:#a0a0a0;color:var(--secondary-text-color,#a0a0a0);font-size:.7em;font-style:italic;line-height:1.1;margin-top:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-compact-layout .anime-title-export p{margin:0}.export-compact-layout .couple-stats-column{align-items:flex-start;border-right:1px solid #0000001a;border-right:1px solid var(--border-color,#0000001a);flex:0 0 75px;flex-direction:column;justify-content:space-evenly;padding:3px 8px}.export-compact-layout .couple-stats-column,.export-compact-layout .export-stat-item{background:none!important;border-radius:0!important;box-shadow:none!important;display:flex;outline:none!important}.export-compact-layout .export-stat-item{align-items:center;border-left:none!important;border-right:none!important;border-top:none!important;color:#e0e0e0;color:var(--text-color,#e0e0e0);font-size:.65em;line-height:1.2;padding:2px 0;width:100%}.export-compact-layout .export-stat-item:not(:last-child){border-bottom:1px solid #ffffff12;border-bottom:1px solid var(--border-color,#ffffff12)}.export-compact-layout .export-stat-icon{color:#ff7eb9;color:var(--accent-color,#ff7eb9);font-weight:600;margin-right:4px;min-width:28px}.export-compact-layout .export-stat-icon,.export-compact-layout .export-stat-value{background:none!important;border:none!important;border-radius:0!important;box-shadow:none!important;outline:none!important}.export-compact-layout .export-stat-value{font-size:1.1em;font-weight:700}.export-compact-layout .movement-indicator{align-items:center;border-radius:0!important;border-right:1px solid #0000001a;border-right:1px solid var(--border-color,#0000001a);color:#fff;display:flex;flex:0 0 50px;flex-direction:column;font-size:.7em;font-weight:700;justify-content:center;text-align:center}.export-compact-layout .movement-indicator .arrow{font-size:1em;line-height:1;margin-bottom:1px;text-shadow:1px 1px 1px #000000b3}.export-compact-layout .movement-indicator .movement-text{font-size:.85em;line-height:1;text-shadow:1px 1px 1px #000000b3}.export-compact-layout .movement-indicator.up{background-color:#28a745}.export-compact-layout .movement-indicator.down{background-color:#dc3545}.export-compact-layout .movement-indicator.new-entry{background-color:#007bff}.export-compact-layout .movement-indicator.re-entry{background-color:#d47312}.export-compact-layout .movement-indicator.same{background-color:#6c757d}.export-compact-layout .movement-indicator.same .movement-text{font-size:1em}.export-compact-layout .character-image-pair-compact{align-items:center;background-color:#0000000d;background-color:var(--card-pseudo-shadow-color,#0000000d);display:flex;flex:0 0 130px;justify-content:center;overflow:visible;padding:0 5px}.export-compact-layout .char-image-frame{background-color:#ffffff1a;background-color:var(--image-border-color,#ffffff1a);border-radius:3px;box-shadow:inset 0 0 5px #0000004d;height:65px;padding:2px;position:relative;width:50px}.export-compact-layout .char-image-frame:before{border:2px solid #ff7eb9;border:2px solid var(--accent-color,#ff7eb9);border-radius:5px;bottom:-2px;content:"";left:-2px;opacity:.7;position:absolute;right:-2px;top:-2px;z-index:-1}.export-compact-layout .char-img{border-radius:2px;display:block;height:100%;object-fit:cover;width:100%}.export-compact-layout .image-x-separator{align-self:center;color:#ff7eb9;color:var(--separator-color,#ff7eb9);font-family:Poppins,sans-serif;font-size:1.4em;font-weight:600;line-height:1;margin:0 3px;padding:0 2px;text-shadow:1px 1px 1px #0003}.export-compact-layout .export-footer{border-top:1px solid #ffffff0d;border-top:1px solid var(--border-color,#ffffff0d);color:#999;color:var(--secondary-text-color,#999);font-size:.7em;margin-top:15px;padding-top:10px}.peak-rank-indicator,.rank-badge,.rank-movement.new-entry-badge,.rank-movement.reappear-badge{display:none!important}.modal-overlay{align-items:center;background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:10px;position:fixed;right:0;top:0;z-index:1050}.modal-content.preview-modal-content{background-color:#fff;border-radius:12px;box-shadow:0 8px 32px #0000004d;display:flex;flex-direction:column;height:90vh;max-height:90vh;max-width:1200px;overflow:hidden;position:relative;width:95%}.modal-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #e9ecef;flex-shrink:0;justify-content:space-between;padding:16px 24px}.header-left,.modal-header{align-items:center;display:flex}.header-left{gap:16px}.modal-header h4{color:#333;font-family:Poppins,sans-serif;font-size:1.3em;font-weight:600;margin:0}.zoom-level{background:#007bff;border-radius:12px;color:#fff;font-size:.85em;font-weight:500;min-width:50px;padding:4px 12px;text-align:center}.zoom-controls{align-items:center;display:flex;gap:8px}.zoom-slider-container{align-items:center;display:flex;margin:0 8px}.zoom-slider{-webkit-appearance:none;appearance:none;background:#dee2e6;border-radius:3px;cursor:pointer;height:6px;outline:none;width:120px}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#007bff;border-radius:50%;cursor:pointer;height:18px;-webkit-transition:all .2s ease;transition:all .2s ease;width:18px}.zoom-slider::-webkit-slider-thumb:hover{background:#0056b3;transform:scale(1.1)}.zoom-slider::-moz-range-thumb{background:#007bff;border:none;border-radius:50%;cursor:pointer;height:18px;-moz-transition:all .2s ease;transition:all .2s ease;width:18px}.zoom-slider::-moz-range-thumb:hover{background:#0056b3;transform:scale(1.1)}.zoom-btn{align-items:center;background:#f8f9fa;border:2px solid #dee2e6;border-radius:8px;cursor:pointer;display:flex;font-family:Poppins,sans-serif;height:36px;justify-content:center;transition:all .2s ease;width:36px}.zoom-btn:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.zoom-btn:active{background:#dee2e6;transform:translateY(0)}.zoom-btn.collapse-btn{background:#fff3cd;border-color:#ffeaa7}.zoom-btn.collapse-btn:hover{background:#fff3a0;border-color:#fdcb6e}.zoom-icon{color:#495057;font-size:1.1em}.close-button,.zoom-icon{font-weight:700;line-height:1}.close-button{background:none;border:none;border-radius:4px;color:#888;cursor:pointer;font-size:1.8em;padding:0 5px;transition:all .2s ease}.close-button:hover{background:#0000001a;color:#555}.modal-body.preview-body{align-items:center;background:#f8f9fa;cursor:grab;display:flex;flex-grow:1;justify-content:center;min-height:0;overflow:auto;position:relative}.modal-body.preview-body:active{cursor:grabbing}.preview-content-wrapper{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:inline-block;min-height:-webkit-fit-content;min-height:fit-content;min-width:-webkit-fit-content;min-width:fit-content;transform-origin:center center;-webkit-user-select:none;user-select:none}.modal-footer{align-items:center;background:#f8f9fa;border-top:2px solid #e9ecef;display:flex;flex-shrink:0;gap:12px;justify-content:space-between;padding:16px 24px}.footer-help{color:#6c757d;font-size:.85em}.footer-buttons{display:flex;gap:12px}.modal-footer .button{border:2px solid #0000;border-radius:8px;cursor:pointer;font-family:Poppins,sans-serif;font-size:.95em;font-weight:500;min-width:100px;padding:10px 24px;transition:all .2s ease}.button.secondary{background-color:#6c757d;color:#fff}.button.secondary:hover{background-color:#5a6268;transform:translateY(-1px)}.button.primary{background-color:#007bff;color:#fff}.button.primary:hover{background-color:#0056b3;transform:translateY(-1px)}.modal-customization-section{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#f8f9fafa;border:2px solid #e9ecef;border-radius:8px;box-shadow:0 4px 20px #0003;left:20px;margin:0 auto;max-width:600px;overflow:hidden;position:absolute;right:20px;top:80px;transform-origin:top center;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:20}.modal-customization-section.collapsed{opacity:0;pointer-events:none;transform:translateY(-100%) scale(.95);visibility:hidden}.modal-customization-section:not(.collapsed){opacity:1;pointer-events:all;transform:translateY(0) scale(1);visibility:visible}.customization-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:12px 24px}.customization-header h4{color:#333;font-family:Poppins,sans-serif;font-size:1.1em;font-weight:600;margin:0}.collapse-toggle-btn{align-items:center;background:#fff;border:2px solid #dee2e6;border-radius:8px;cursor:pointer;display:flex;font-family:Poppins,sans-serif;height:32px;justify-content:center;transition:all .2s ease;width:32px}.collapse-toggle-btn:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.collapse-toggle-btn:active{background:#dee2e6;transform:translateY(0)}.collapse-icon{color:#495057;font-size:.9em;font-weight:700;line-height:1}.customization-content{max-height:320px;overflow-y:auto;padding:16px 24px}.customization-content .customization-container{background:#fff;box-shadow:0 2px 8px #0000001a;margin-bottom:0}.customization-content .palette-grid{gap:8px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.customization-content .palette-option{padding:4px}.customization-content .palette-preview{height:40px}.customization-content .detailed-palette-preview{padding:10px}.customization-actions{border-top:1px solid #dee2e6;margin-top:16px;padding-top:16px;text-align:center}.apply-customization-btn{background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:Poppins,sans-serif;font-size:.9em;font-weight:500;min-width:140px;padding:10px 20px;transition:all .2s ease}.apply-customization-btn:hover{background:#0056b3;box-shadow:0 2px 8px #007bff4d;transform:translateY(-1px)}.apply-customization-btn:active{transform:translateY(0)}@media (max-width:768px){.modal-content.preview-modal-content{height:95vh;width:98%}.modal-header{flex-wrap:wrap;gap:8px;padding:12px 16px}.modal-header h4{font-size:1.1em}.zoom-controls{flex-wrap:wrap;gap:6px}.zoom-btn{height:32px;width:32px}.zoom-slider-container{margin:0 4px}.zoom-slider{width:80px}.modal-footer{flex-direction:column;gap:8px;padding:12px 16px}.footer-help{font-size:.8em;text-align:center}.footer-buttons{justify-content:center;width:100%}.modal-footer .button{flex:1 1;min-width:120px}.modal-customization-section{left:10px;right:10px;top:140px}}.modal-footer .button.primary{background-color:#ff7eb9;color:#fff}.modal-footer .button.primary:hover{background-color:#e062a4;box-shadow:0 2px 5px #0000001a}.modal-footer .button.secondary{background-color:#e9ecef;border:1px solid #ced4da;color:#333}.modal-footer .button.secondary:hover{background-color:#d3d9df}.preview-body[data-zoomed=true]:before{animation:fadeInOut 3s ease-in-out;background:#000c;border-radius:16px;color:#fff;content:"Scroll or drag to navigate • " attr(data-zoom-level);font-family:Poppins,sans-serif;font-size:.8em;font-weight:500;left:50%;opacity:0;padding:6px 16px;pointer-events:none;position:absolute;top:10px;transform:translateX(-50%);z-index:10}@keyframes fadeInOut{0%{opacity:0}15%{opacity:1}85%{opacity:1}to{opacity:0}}.modal-body.preview-body::-webkit-scrollbar{height:14px;width:14px}.modal-body.preview-body::-webkit-scrollbar-track{background:#e9ecef;border-radius:8px}.modal-body.preview-body::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#6c757d,#495057);border:2px solid #e9ecef;border-radius:8px;-webkit-transition:background .2s ease;transition:background .2s ease}.modal-body.preview-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#495057,#343a40)}.modal-body.preview-body::-webkit-scrollbar-corner{background:#e9ecef}.customization-container{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 15px #00000014;margin-bottom:30px;padding:20px 25px}.customization-container h3{color:#d6336c;font-family:Poppins,sans-serif;font-weight:600;margin-bottom:20px;margin-top:0;text-align:center}.control-group{display:flex;flex-direction:column;margin-bottom:15px}.control-group label{color:#333;font-family:Montserrat,sans-serif;font-size:.9em;font-weight:500;margin-bottom:5px}.control-group input[type=text],.control-group select{border:1px solid #ccc;border-radius:6px;box-sizing:border-box;font-family:Montserrat,sans-serif;font-size:1em;padding:10px 12px;width:100%}.control-group input[type=text]:focus,.control-group select:focus{border-color:#ff8fab;box-shadow:0 0 0 3px #ff7eb933;outline:none}.palette-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-top:10px}.palette-option{background:#f8f9fa;border:2px solid #0000;border-radius:8px;cursor:pointer;padding:8px;transition:all .2s ease}.palette-option:hover{border-color:#ff7eb9;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.palette-option.selected{background:#fff;border-color:#ff7eb9;box-shadow:0 0 0 3px #ff7eb933}.palette-preview{border-radius:6px;height:60px;margin-bottom:6px;overflow:hidden;position:relative}.palette-background{box-sizing:border-box;display:flex;flex-direction:column;height:100%;justify-content:space-between;padding:4px;width:100%}.palette-text-sample{display:flex;flex-direction:column;gap:2px}.sample-header{font-family:Poppins,sans-serif;font-size:10px;font-weight:700}.sample-text{font-family:Montserrat,sans-serif;font-size:8px}.palette-accent-bar{align-items:center;display:flex;gap:4px;height:12px}.accent-strip{border-radius:1px;flex-grow:1;height:2px}.badge-sample{align-items:center;border-radius:2px;color:#fff;display:flex;font-size:6px;font-weight:700;height:12px;justify-content:center;width:16px}.palette-name{color:#555;font-family:Montserrat,sans-serif;font-size:.8em;font-weight:500;text-align:center}.detailed-palette-preview{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:20px;padding:15px}.detailed-palette-preview h4{color:#333;font-family:Poppins,sans-serif;font-size:1em;font-weight:600;margin:0 0 12px}.color-swatches{display:flex;flex-direction:column;gap:8px}.swatch-row{display:flex;flex-wrap:wrap;gap:12px}.swatch-item{align-items:center;display:flex;flex-direction:column;gap:4px}.swatch{border:2px solid #0000001a;border-radius:6px;box-shadow:0 2px 4px #0000001a;height:30px;width:30px}.swatch-label{color:#666;font-family:Montserrat,sans-serif;font-size:.7em;font-weight:500;text-align:center}@media (max-width:768px){.palette-grid{gap:8px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.palette-option{padding:6px}.palette-preview{height:50px}.swatch-row{justify-content:center}.detailed-palette-preview{padding:12px}}.voting-card{background:linear-gradient(145deg,#fff,#fefefe);border:2px solid #f0f0f0;border-radius:16px;box-shadow:0 2px 8px #0000000f;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:220px;overflow:hidden;padding:16px;position:relative;transition:all .3s ease;-webkit-user-select:none;user-select:none}.voting-card:hover:not(.voted):not(.voting){border-color:#ff7eb9;box-shadow:0 8px 20px #e91e631f;transform:translateY(-4px)}.voting-card.voted{background:linear-gradient(145deg,#e8f5e8,#f0f8f0);border-color:#4caf50;cursor:default}.voting-card.voting{background:linear-gradient(145deg,#fff8e1,#fffbf0);border-color:#ff9800;cursor:wait}.voted-overlay{background:#4caf5026;border-radius:14px;bottom:0;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:2}.voted-checkmark,.voted-overlay{align-items:center;display:flex;justify-content:center}.voted-checkmark{animation:checkmarkPop .4s ease-out;background:#4caf50;border-radius:50%;box-shadow:0 2px 8px #4caf504d;color:#fff;font-size:1.2rem;font-weight:700;height:40px;width:40px}@keyframes checkmarkPop{0%{opacity:0;transform:scale(0)}80%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.couple-images-container{align-items:center;display:flex;flex:1 1;gap:12px;justify-content:space-between;margin-bottom:12px}.char-image-wrapper{align-items:center;background:none!important;border:0!important;border-radius:0!important;box-shadow:none!important;display:flex;flex:1 1;flex-direction:column;gap:8px;justify-content:center;max-width:100px;min-height:68px;min-width:68px;padding:4px}.char-image-compact{border:2px solid #e0e0e0;border-radius:50%;display:block;flex-shrink:0;height:60px;max-height:60px;max-width:60px;min-height:60px;min-width:60px;object-fit:cover;object-position:center;transition:all .3s ease;width:60px}.voting-card:hover:not(.voted) .char-image-compact{border-color:#ff7eb9;transform:scale(1.05)}.couple-pairing{background:linear-gradient(135deg,#e91e6314,#9c27b00f);border:2px solid #e91e6326;border-radius:12px;box-shadow:0 2px 8px #e91e631a;color:#2c2c2c;font-size:.9rem;font-weight:700;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;margin:0 4px;overflow-wrap:break-word;padding:12px 8px 8px;position:relative;text-align:center;transition:all .3s ease;word-break:break-word}.couple-pairing:before{background:#fff;content:"⭐";font-size:.8rem;left:50%;opacity:.8;padding:0 4px;position:absolute;top:-8px;transform:translateX(-50%)}.voting-card:hover:not(.voted) .couple-pairing{background:linear-gradient(135deg,#e91e631f,#9c27b014);border-color:#e91e6340;box-shadow:0 4px 12px #e91e6326;transform:translateY(-1px)}.couple-divider{font-size:1.2rem;font-weight:600;margin:0 8px;text-shadow:0 1px 3px #e91e634d;transition:all .3s ease}.voting-card:hover:not(.voted) .couple-divider{color:#ad1457;text-shadow:0 2px 6px #e91e6366;transform:scale(1.1)}.voted-indicator{align-items:center;display:flex;flex-direction:column;gap:8px}.cancel-vote-btn{background:linear-gradient(135deg,#ff7043,#f4511e);border:none;border-radius:12px;box-shadow:0 2px 6px #f4511e4d;color:#fff;cursor:pointer;font-size:.7rem;font-weight:600;padding:4px 12px;transition:all .3s ease}.cancel-vote-btn:hover{background:linear-gradient(135deg,#f4511e,#d84315);box-shadow:0 4px 12px #f4511e66;transform:translateY(-1px)}.cancel-vote-btn:active{box-shadow:0 2px 6px #f4511e4d;transform:translateY(0)}.vote-confirmation{align-items:center;display:flex;flex-direction:column;gap:8px;padding:8px}.confirm-text{color:#2c2c2c;font-size:.85rem;font-weight:600;margin:0;text-align:center}.confirmation-buttons{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.confirm-vote-btn{background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:12px;box-shadow:0 2px 6px #4caf504d;color:#fff;cursor:pointer;font-size:.7rem;font-weight:600;padding:6px 12px;transition:all .3s ease}.confirm-vote-btn:hover{background:linear-gradient(135deg,#45a049,#388e3c);box-shadow:0 4px 12px #4caf5066;transform:translateY(-1px)}.cancel-confirm-btn{background:linear-gradient(135deg,#757575,#616161);border:none;border-radius:12px;box-shadow:0 2px 6px #7575754d;color:#fff;cursor:pointer;font-size:.7rem;font-weight:600;padding:6px 12px;transition:all .3s ease}.cancel-confirm-btn:hover{background:linear-gradient(135deg,#616161,#424242);box-shadow:0 4px 12px #75757566;transform:translateY(-1px)}.cancel-confirm-btn:active,.confirm-vote-btn:active{transform:translateY(0)}.dark-mode .voting-card{background:linear-gradient(145deg,#2a2a2a,#1f1f1f);border-color:#444;color:#e0e0e0}.dark-mode .voting-card:hover:not(.voted):not(.voting){border-color:#ff7eb9;box-shadow:0 8px 20px #ff7eb933}.dark-mode .voting-card.voted{background:linear-gradient(145deg,#1a3a1a,#2a4a2a);border-color:#4caf50}.dark-mode .voting-card.voting{background:linear-gradient(145deg,#3a3a1a,#4a4a2a);border-color:#ff9800}.dark-mode .couple-pairing{color:#e0e0e0}.dark-mode .vote-confirmation{background:#282828f2;border-color:#555}.dark-mode .confirm-text{color:#e0e0e0}.dark-mode .confirm-vote-btn{background:linear-gradient(135deg,#4caf50,#66bb6a);border-color:#4caf50}.dark-mode .confirm-vote-btn:hover{background:linear-gradient(135deg,#388e3c,#4caf50)}.dark-mode .cancel-confirm-btn{background:linear-gradient(135deg,#666,#777);border-color:#666;color:#e0e0e0}.dark-mode .cancel-confirm-btn:hover{background:linear-gradient(135deg,#555,#666)}.dark-mode .cancel-vote-btn{background:#666;border-color:#555;color:#e0e0e0}.dark-mode .cancel-vote-btn:hover{background:#777}.dark-mode .vote-prompt,.dark-mode .voted-indicator,.dark-mode .voting-indicator{color:#e0e0e0}@media (max-width:768px){.voting-card{min-height:200px;padding:10px}.couple-images-container{gap:4px;margin-bottom:16px}.char-image-wrapper{flex:0 0 auto;max-width:59px;min-height:59px;min-width:59px;padding:2px}.char-image-compact{display:block;flex-shrink:0;height:55px;max-height:55px;max-width:55px;min-height:55px;min-width:55px;width:55px}.couple-pairing{font-size:.85rem;margin:0 2px;padding:10px 6px 6px}.couple-pairing:before{font-size:.75rem;top:-7px}.couple-divider{font-size:1.1rem;margin:0}.vote-status{padding:8px 0}.vote-prompt,.voted-indicator,.voting-indicator{font-size:.82rem}}@media (max-width:480px){.voting-card{min-height:180px;padding:8px}.couple-images-container{gap:2px;margin-bottom:14px}.char-image-wrapper{flex:0 0 auto;max-width:52px;min-height:52px;min-width:52px;padding:1px}.char-image-compact{display:block;flex-shrink:0;height:50px;max-height:50px;max-width:50px;min-height:50px;min-width:50px;width:50px}.couple-pairing{font-size:.8rem;margin:0 1px;padding:8px 5px 5px}.couple-pairing:before{font-size:.7rem;top:-6px}.couple-divider{font-size:1rem;margin:0}.vote-status{font-size:.8rem;padding:6px 0}.cancel-vote-btn{font-size:.65rem;padding:3px 8px}}@media (max-width:360px){.voting-card{min-height:160px;padding:6px}.couple-images-container{gap:1px;margin-bottom:12px}.char-image-wrapper{flex:0 0 auto;max-width:46px;min-height:46px;min-width:46px;padding:1px}.char-image-compact{display:block;flex-shrink:0;height:45px;max-height:45px;max-width:45px;min-height:45px;min-width:45px;width:45px}.couple-pairing{font-size:.75rem;margin:0;padding:6px 4px 4px}.couple-pairing:before{font-size:.65rem;top:-5px}.couple-divider{font-size:.9rem;margin:0 2px}.vote-status{font-size:.75rem;padding:4px 0}.cancel-vote-btn{font-size:.6rem;padding:2px 6px}}@media (max-width:320px){.voting-card{min-height:150px;padding:8px}.couple-images-container{gap:4px;margin-bottom:10px}.char-image-wrapper{flex:0 0 auto;max-width:48px;min-height:48px;min-width:48px;padding:4px}.char-image-compact{border-width:2px;display:block;flex-shrink:0;height:40px;max-height:40px;max-width:40px;min-height:40px;min-width:40px;width:40px}.couple-pairing{font-size:.7rem;line-height:1.2;margin:0;padding:4px 3px 3px}.couple-pairing:before{font-size:.6rem;top:-4px}.couple-divider{font-size:.8rem;margin:0 1px}.vote-status{font-size:.7rem;padding:3px 0}.cancel-vote-btn{font-size:.55rem;padding:2px 4px}.confirmation-buttons{gap:4px}.cancel-confirm-btn,.confirm-vote-btn{font-size:.55rem;padding:3px 6px}}.vote-page{background:linear-gradient(135deg,#ffeef8,#f8e8ff 50%,#e8f4fd);font-family:Poppins,sans-serif;min-height:100vh;padding:16px}.vote-page.dark-mode{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);color:#e0e0e0}.vote-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 6px 20px #e91e631f;margin-bottom:24px;padding:24px 20px;text-align:center}.vote-page.dark-mode .vote-header{background:#1e1e2de6;border:1px solid #ff6b9d33;box-shadow:0 8px 24px #0006}.vote-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e91e63,#9c27b0,#3f51b5);background-clip:text;-webkit-background-clip:text;font-size:2.5rem;font-weight:800;line-height:1.2;margin-bottom:16px}.vote-page.dark-mode .vote-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff6b9d,#c44569,#546de5);background-clip:text;-webkit-background-clip:text}.vote-instructions{background:linear-gradient(135deg,#fce4ec,#e1bee7);border-left:4px solid #e91e63;border-radius:12px;margin:16px 0;padding:16px}.vote-page.dark-mode .vote-instructions{background:linear-gradient(135deg,#ff6b9d26,#c4456926);border-left-color:#ff6b9d}.vote-instructions p{color:#4a148c;font-size:.95rem;font-weight:500;margin:6px 0}.vote-page.dark-mode .vote-instructions p{color:#e0e0e0}.vote-stats{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin:16px 0}.vote-stat-item{background:linear-gradient(135deg,#e91e63,#f06292);border-radius:16px;box-shadow:0 3px 10px #e91e6340;color:#fff;font-size:.9rem;padding:8px 16px}.vote-page.dark-mode .vote-stat-item{background:linear-gradient(135deg,#ff6b9d,#c44569);box-shadow:0 4px 12px #ff6b9d4d}.vote-stat-item strong{font-size:1.2em;font-weight:700}.back-link{background:linear-gradient(135deg,#2196f3,#42a5f5);border-radius:25px;box-shadow:0 4px 15px #2196f34d;color:#fff;display:inline-block;font-weight:600;margin:20px 10px;padding:15px 30px;text-decoration:none;transition:all .3s ease}.back-link:hover{background:linear-gradient(135deg,#1976d2,#2196f3);box-shadow:0 8px 25px #2196f366;transform:translateY(-3px)}.vote-page.dark-mode .back-link{background:linear-gradient(135deg,#546de5,#3f51b5);box-shadow:0 4px 15px #546de566}.vote-page.dark-mode .back-link:hover{background:linear-gradient(135deg,#4caf50,#2e7d32);box-shadow:0 6px 20px #4caf5066}.loading-container{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff6;border:2px solid #e91e631a;border-radius:20px;display:flex;flex-direction:column;gap:30px;justify-content:center;min-height:300px;overflow:hidden;padding:60px 40px;position:relative}.loading-container:before{animation:backgroundShimmer 4s ease-in-out infinite;background:linear-gradient(45deg,#0000,#e91e630d,#0000,#9c27b00d,#0000);content:"";height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;width:200%}.loading-animation{height:120px;position:relative;width:120px}.heart-loader,.loading-animation{align-items:center;display:flex;justify-content:center}.heart-loader{height:80px;position:absolute;width:80px;z-index:3}.heart{animation:heartFloat 3s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(233,30,99,.4));font-size:2rem;position:absolute}.heart-1{animation-delay:0s;animation-duration:2.5s}.heart-2{animation-delay:.8s;animation-duration:3s;transform:scale(.8)}.heart-3{animation-delay:1.6s;animation-duration:2.8s;transform:scale(1.2)}.loading-rings{height:100%;position:absolute;width:100%}.ring{animation:ringRotate 2s linear infinite;border-radius:50%;border-right:3px solid #0000;border-top:3px solid #0000;border-color:#e91e63 #e91e63 #0000 #0000;border-style:solid;border-width:3px;position:absolute}.loading-text{color:#666;font-size:1.1rem;font-weight:500}.ring-1{animation-duration:2s;border-right-color:#e91e63;border-top-color:#e91e63;height:120px;left:0;top:0;width:120px}.ring-2{animation-direction:reverse;animation-duration:1.5s;border-right-color:#9c27b0;border-top-color:#9c27b0;height:90px;left:15px;top:15px;width:90px}.ring-3{animation-duration:1s;border-right-color:#3f51b5;border-top-color:#3f51b5;height:60px;left:30px;top:30px;width:60px}.loading-dots{bottom:-40px;display:flex;gap:8px;left:50%;position:absolute;transform:translateX(-50%)}.dot{animation:dotBounce 1.4s ease-in-out infinite;background:linear-gradient(135deg,#e91e63,#9c27b0);border-radius:50%;height:8px;width:8px}.dot-1{animation-delay:0s}.dot-2{animation-delay:.2s}.dot-3{animation-delay:.4s}.loading-text-container{animation:fadeInUp 1s ease-out .5s forwards;opacity:0;text-align:center}.loading-text{-webkit-text-fill-color:#0000;animation:textShimmer 2s ease-in-out infinite;background:linear-gradient(135deg,#e91e63,#9c27b0);background-clip:text;-webkit-background-clip:text;font-size:1.4rem;font-weight:600;margin:0}.loading-subtext{color:#666;font-size:1rem;font-weight:400;margin:8px 0 0;opacity:.8}@keyframes heartFloat{0%,to{opacity:.6;transform:translateY(0) scale(1)}50%{opacity:1;transform:translateY(-15px) scale(1.1)}}@keyframes ringRotate{0%{opacity:1;transform:rotate(0deg)}50%{opacity:.6}to{opacity:1;transform:rotate(1turn)}}@keyframes dotBounce{0%,80%,to{opacity:.5;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popupSlideIn{0%{opacity:0;transform:scale(.8) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:.9;transform:translateY(0)}}@keyframes textShimmer{0%,to{background-position:0 50%}50%{background-position:100% 50%}}@keyframes backgroundShimmer{0%,to{transform:translateX(-100%) translateY(-100%) rotate(0deg)}50%{transform:translateX(0) translateY(0) rotate(180deg)}}.voting-closed-notice{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:3px solid #ff9800;border-radius:20px;margin:30px 0;padding:40px}.voting-closed-notice h2{color:#e65100;font-size:2rem;margin-bottom:15px}.voting-closed-notice p{color:#bf360c;font-size:1.2rem;font-weight:500;margin:10px 0}.vote-page.dark-mode .voting-closed-notice{background:linear-gradient(135deg,#ff980026,#ffc10726);border-color:#ff9800}.vote-page.dark-mode .voting-closed-notice h2{color:#ffb74d}.vote-page.dark-mode .voting-closed-notice p{color:#e0e0e0}.vote-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-radius:16px;margin-top:32px;padding:20px;text-align:center}.footer-content h3{color:#e91e63;font-size:1.4rem;font-weight:700;margin-bottom:10px}.footer-content p{color:#666;font-size:.95rem;line-height:1.5;margin:8px 0}.vote-page.dark-mode .vote-footer{background:#1e1e2de6;border:1px solid #ff6b9d33}.status-active{background:#4caf501a;border:1px solid #4caf50;border-radius:12px;color:#4caf50;font-weight:700;padding:3px 8px}.voting-sections{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.compact-anime-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:12px}.vote-page.dark-mode .anime-section{background:#1e1e2de6;border:2px solid #ff6b9d26;box-shadow:0 6px 20px #0000004d}.vote-page.dark-mode .compact-anime-row .anime-section{background:#1e1e2dd9;border:1px solid #ff6b9d33}.anime-section-header{align-items:center;background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:16px;box-shadow:0 8px 32px #00000026;display:flex;justify-content:center;margin-bottom:20px;min-height:120px;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.anime-section-header:hover{box-shadow:0 16px 48px #00000040;transform:translateY(-2px)}.anime-section-header:before{background:linear-gradient(135deg,#0009,#00000080 50%,#0009);bottom:0;content:"";left:0;position:absolute;right:0;top:0;transition:all .3s ease;z-index:1}.anime-section-header:hover:before{background:linear-gradient(135deg,#0006,#0000004d 50%,#0006)}.anime-section-header .anime-title{word-wrap:break-word;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0006;border:1px solid #fff3;border-radius:12px;box-shadow:0 6px 24px #0006,inset 0 1px 0 #ffffff26;color:#fff;font-size:1.6rem;font-weight:700;-webkit-hyphens:auto;hyphens:auto;letter-spacing:.3px;line-height:1.3;margin:0;max-width:85%;padding:16px 28px;position:relative;text-align:center;text-shadow:0 2px 8px #000000e6,0 0 16px #0009;transition:all .3s ease;z-index:2}.anime-section-header:hover .anime-title{background:#00000080;border-color:#ffffff4d;box-shadow:0 8px 32px #00000080,inset 0 1px 0 #fff3;transform:scale(1.02)}.vote-page.dark-mode .anime-section-header:before{background:linear-gradient(135deg,#000000bf,#000000a6 50%,#000000bf)}.vote-page.dark-mode .anime-section-header:hover:before{background:linear-gradient(135deg,#0009,#00000080 50%,#0009)}.vote-page.dark-mode .anime-section-header .anime-title{background:#0f0f19bf;border:1px solid #ff6b9d4d;box-shadow:0 6px 28px #0009,inset 0 1px 0 #ff6b9d26;color:#fff;text-shadow:0 2px 10px #000,0 0 20px #000c}.vote-page.dark-mode .anime-section-header:hover .anime-title{background:#0f0f19d9;border-color:#ff6b9d66;box-shadow:0 8px 36px #000000b3,inset 0 1px 0 #ff6b9d33}.anime-section-header:not([style*=background-image]){background:linear-gradient(135deg,#e91e63,#9c27b0 50%,#673ab7);position:relative}.anime-section-header:not([style*=background-image]):before{background:linear-gradient(135deg,#0000004d,#0003 50%,#0000004d)}.anime-section-header:not([style*=background-image]) .anime-title{background:#0006;border:1px solid #ffffff40;color:#fff}.vote-page.dark-mode .anime-section-header:not([style*=background-image]){background:linear-gradient(135deg,#2c2c54,#1e1e3f 50%,#4a148c)}.vote-page.dark-mode .anime-section-header:not([style*=background-image]):before{background:linear-gradient(135deg,#00000080,#0006 50%,#00000080)}.vote-page.dark-mode .anime-section-header:not([style*=background-image]) .anime-title{background:#0f0f19b3;border:1px solid #ff6b9d4d}.anime-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:2px solid #e91e6314;border-radius:16px;box-shadow:0 4px 16px #e91e6314;margin-bottom:12px;padding:16px 20px 20px;transition:all .3s ease}.anime-section.compact{min-height:auto;padding:12px 16px 16px}.anime-section.compact .anime-section-header{margin-bottom:16px}.voting-grid.single-couple{display:flex;gap:0;justify-content:center;max-width:none;padding:0}.voting-grid.single-couple .voting-card{flex-shrink:0;max-width:240px;width:240px}@media (max-width:768px){.voting-grid.single-couple .voting-card{max-width:220px;width:220px}}@media (max-width:480px){.voting-grid.single-couple{justify-content:stretch}.voting-grid.single-couple .voting-card{box-sizing:border-box;flex-grow:1;margin:0;max-width:100%;width:100%}.compact-anime-row .anime-section{box-sizing:border-box;min-width:0;overflow:hidden}.compact-anime-row .voting-grid.single-couple{box-sizing:border-box;margin:0;max-width:100%;padding:0;width:100%}.compact-anime-row .voting-grid.single-couple .voting-card{box-sizing:border-box;flex-shrink:1;max-width:100%;min-width:0;width:100%}}.voting-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin:0 auto;max-width:1400px;padding:16px 0}@media (max-width:768px){.voting-grid{gap:14px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}}@media (max-width:480px){.voting-grid{gap:12px;grid-template-columns:1fr 1fr}}@media (max-width:360px){.voting-grid{gap:10px;grid-template-columns:1fr 1fr}}.no-couples{background:#ffffffe6;border:3px dashed #e0e0e0;border-radius:25px;margin:40px 0;padding:80px 20px}.no-couples h3{color:#333;font-size:1.8rem;font-weight:700;margin-bottom:16px}.no-couples p{line-height:1.6;margin:12px 0}.no-couples-icon{font-size:4rem;margin-bottom:20px;opacity:.7}.message-popup-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0006;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.message-popup{animation:popupSlideIn .4s cubic-bezier(.34,1.56,.64,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e91e6333;border-radius:20px;box-shadow:0 10px 40px #0003;max-width:500px;min-width:300px;padding:25px 30px;position:relative}.message-popup.success{background:linear-gradient(135deg,#c8e6c9f2,#a5d6a7f2);border-color:#4caf50;box-shadow:0 10px 40px #4caf504d}.message-popup.error{background:linear-gradient(135deg,#ffcdd2f2,#ef9a9af2);border-color:#f44336;box-shadow:0 10px 40px #f443364d}.message-content{align-items:center;display:flex;gap:20px;justify-content:space-between}.message-text{color:#333;flex:1 1;font-size:1.1rem;font-weight:600;line-height:1.4}.message-popup.success .message-text{color:#1b5e20}.message-popup.error .message-text{color:#b71c1c}.message-close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;flex-shrink:0;font-size:1.8rem;font-weight:700;height:30px;justify-content:center;padding:0;transition:all .2s ease;width:30px}.message-close:hover{background:#0000001a;color:#333;transform:scale(1.1)}.message-popup.success .message-close:hover{background:#1b5e201a;color:#1b5e20}.message-popup.error .message-close:hover{background:#b71c1c1a;color:#b71c1c}.vote-page.dark-mode .loading-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff6b9d,#c44569,#546de5);background-clip:text;-webkit-background-clip:text}.vote-page.dark-mode .loading-subtext{color:#c8c8c8}.vote-page.dark-mode .heart{filter:drop-shadow(0 0 12px rgba(255,107,157,.6))}.vote-page.dark-mode .ring-1{border-right-color:#ff6b9d;border-top-color:#ff6b9d;box-shadow:0 0 20px #ff6b9d4d}.vote-page.dark-mode .ring-2{border-right:3px solid #c44569;border-top-color:#c44569;box-shadow:0 0 16px #c445694d}.vote-page.dark-mode .ring-3{border-right-color:#546de5;border-top-color:#546de5;box-shadow:0 0 12px #546de54d}.vote-page.dark-mode .dot{background:linear-gradient(135deg,#ff6b9d,#c44569);box-shadow:0 0 8px #ff6b9d66}.vote-page.dark-mode .loading-container{background:#28283299;border:2px solid #ff6b9d33;border-radius:20px}.scroll-to-top,.vote-page.dark-mode .loading-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.scroll-to-top{align-items:center;animation:fadeInUp .3s ease-out;background:linear-gradient(135deg,#e91e63,#9c27b0);border:none;border-radius:50%;bottom:30px;box-shadow:0 4px 20px #e91e6366,0 2px 8px #0003;color:#fff;cursor:pointer;display:flex;font-size:1.8rem;font-weight:700;height:56px;justify-content:center;line-height:1;opacity:.9;position:fixed;right:30px;transition:all .3s cubic-bezier(.4,0,.2,1);width:56px;z-index:1000}.scroll-to-top:hover{background:linear-gradient(135deg,#d81b60,#8e24aa);box-shadow:0 8px 28px #e91e6380,0 4px 12px #0000004d;opacity:1;transform:translateY(-3px) scale(1.05)}.scroll-to-top:active{transform:translateY(-1px) scale(1.02);transition:all .1s ease}.vote-page.dark-mode .scroll-to-top{background:linear-gradient(135deg,#ff6b9d,#9c27b0);box-shadow:0 4px 20px #ff6b9d66,0 2px 8px #0006}.vote-page.dark-mode .scroll-to-top:hover{background:linear-gradient(135deg,#ff5722,#7b1fa2);box-shadow:0 8px 28px #ff6b9d80,0 4px 12px #00000080}.header-top{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:16px}.header-top h1{flex:1 1;margin:0}.dark-mode-toggle{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#e91e63,#9c27b0);border:none;border-radius:50%;box-shadow:0 4px 15px #e91e634d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.5rem;height:50px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);width:50px}.dark-mode-toggle:hover{background:linear-gradient(135deg,#d81b60,#8e24aa);box-shadow:0 6px 20px #e91e6366;transform:translateY(-2px) scale(1.05)}.dark-mode-toggle:active{transform:translateY(0) scale(1);transition:all .1s ease}.vote-page.dark-mode .dark-mode-toggle{background:linear-gradient(135deg,#ff6b9d,#c44569);box-shadow:0 4px 15px #ff6b9d66}.vote-page.dark-mode .dark-mode-toggle:hover{background:linear-gradient(135deg,#ff5722,#b71c1c);box-shadow:0 6px 20px #ff6b9d80;transform:translateY(-2px) scale(1.05)}@media (max-width:768px){.header-top{flex-direction:column;gap:15px}.dark-mode-toggle{font-size:1.3rem;height:45px;width:45px}.compact-anime-row{gap:14px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:480px){.header-top{gap:10px}.dark-mode-toggle{font-size:1.1rem;height:40px;width:40px}.compact-anime-row{gap:12px;grid-template-columns:1fr}.compact-anime-row .voting-grid.single-couple{justify-content:stretch}.compact-anime-row .voting-grid.single-couple .voting-card{max-width:none;width:100%}}@media (max-width:768px){.anime-section-header{margin-bottom:16px;min-height:100px}.anime-section-header .anime-title{font-size:1.4rem;line-height:1.4;max-width:90%;padding:12px 20px}}@media (max-width:480px){.anime-section-header{border-radius:12px;margin-bottom:12px;min-height:70px}.anime-section-header .anime-title{font-size:1.1rem;font-weight:600;letter-spacing:0;line-height:1.3;max-width:95%;padding:8px 12px;white-space:normal;word-break:break-word}}@media (max-width:360px){.anime-section-header{min-height:60px}.anime-section-header .anime-title{font-size:1rem;font-weight:600;line-height:1.25;max-width:98%;padding:6px 10px}}@media (max-width:768px){.loading-container{gap:25px;min-height:250px;padding:40px 20px}.loading-animation{height:100px;width:100px}.heart-loader{height:70px;width:70px}.heart{font-size:1.6rem}.ring-1{height:100px;width:100px}.ring-2{height:75px;left:12.5px;top:12.5px;width:75px}.ring-3{height:50px;left:25px;top:25px;width:50px}.loading-text{font-size:1.2rem}.loading-subtext{font-size:.9rem}}@media (max-width:480px){.loading-container{gap:20px;min-height:200px;padding:30px 15px}.loading-animation{height:80px;width:80px}.heart-loader{height:60px;width:60px}.heart{font-size:1.4rem}.ring-1{height:80px;width:80px}.ring-2{height:60px;left:10px;top:10px;width:60px}.ring-3{height:40px;left:20px;top:20px;width:40px}.loading-text{font-size:1.1rem}.loading-subtext{font-size:.85rem}.loading-dots{bottom:-30px}.dot{height:6px;width:6px}}.vote-page.dark-mode .period-info{color:#e0e0e0}.vote-page.dark-mode .period-info strong{color:#ff6b9d}.vote-page.dark-mode .no-couples{background:#1e1e2de6;border:2px solid #ff6b9d33;color:#e0e0e0}.vote-page.dark-mode .no-couples h3{color:#ff6b9d}@media (max-width:480px){.anime-section{box-sizing:border-box;overflow-x:hidden;width:100%}.anime-section.compact{min-width:0;overflow-x:hidden;width:100%}.anime-section *,.voting-grid{box-sizing:border-box}.voting-grid{overflow-x:hidden;width:100%}}.voting-couples-manager{background:linear-gradient(135deg,#f8f9ff,#e8f5e8);border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:0 auto;max-width:1200px;padding:20px}.manager-header{background:#fffc}.manager-header h2{color:#e91e63;margin-bottom:10px}.manager-header p{color:#666;margin-bottom:15px}.manager-message{border-radius:8px;font-weight:500;margin:15px 0;padding:12px 20px;text-align:center}.manager-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.manager-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.manager-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:30px}.action-btn{align-items:center;border:none;border-radius:25px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.add-btn{background:linear-gradient(135deg,#4caf50,#66bb6a)}.add-btn:hover{background:linear-gradient(135deg,#388e3c,#4caf50);transform:translateY(-2px)}.import-btn{background:linear-gradient(135deg,#2196f3,#42a5f5)}.import-btn:hover:not(:disabled){background:linear-gradient(135deg,#1976d2,#2196f3)}.clear-btn{background:linear-gradient(135deg,#f44336,#ef5350)}.clear-btn:hover:not(:disabled){background:linear-gradient(135deg,#d32f2f,#f44336);transform:translateY(-2px)}.action-btn:disabled{background:#999;cursor:not-allowed;opacity:.6}.action-btn:disabled:hover{transform:none}.add-form-container{background:#ffffffe6;border:2px solid #e91e63;border-radius:12px;margin-bottom:30px;padding:20px}.couples-stats{background:#ffffffb3;border-radius:10px;margin-bottom:25px;padding:15px;text-align:center}.couples-stats p{color:#333;font-size:1.1rem;margin:0}.couples-stats strong{color:#e91e63}.couples-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:20px}.couple-item{background:#fff;border-radius:12px;box-shadow:0 4px 15px #0000001a;padding:15px;position:relative;transition:all .3s ease}.couple-item:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.imported-badge{background:linear-gradient(135deg,#ff9800,#ffb74d);border-radius:12px;box-shadow:0 2px 8px #ff98004d;color:#fff;font-size:.75rem;font-weight:600;padding:4px 8px;position:absolute;right:10px;top:10px}.added-date{color:#666;font-size:.85rem;font-style:italic;margin-top:10px;text-align:center}.no-couples{background:#fffc;border:2px dashed #ddd;border-radius:12px;grid-column:1/-1;padding:60px 20px;text-align:center}.no-couples p{color:#666;font-size:1.1rem;margin:15px 0}.voting-manager-loading{color:#666;font-size:1.2rem;padding:60px 20px;text-align:center}.roster-btn{background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff}.roster-btn:hover:not(:disabled){background:linear-gradient(135deg,#7b1fa2,#6a1b9a);box-shadow:0 4px 12px #9c27b066;transform:translateY(-2px)}.roster-manager-container{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:20px 0;padding:20px}.roster-manager-header{background:linear-gradient(135deg,#9c27b0,#7b1fa2);border-radius:8px;color:#fff;margin-bottom:20px;padding:15px;text-align:center}.roster-manager-header h3{font-size:1.4rem;margin:0 0 8px}.roster-manager-header p{font-size:1rem;margin:0;opacity:.9}.roster-manager-section{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:15px}.roster-manager-section h4{border-bottom:2px solid #9c27b0;color:#333;font-size:1.2rem;margin:0 0 15px;padding-bottom:5px}.roster-manager-section h5{color:#555;font-size:1rem;margin:15px 0 10px}.roster-actions{display:flex;flex-wrap:wrap;gap:10px;margin:10px 0}.roster-action-btn{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 18px;transition:all .3s ease}.auto-import-btn{background:linear-gradient(135deg,#ff9800,#f57c00)}.auto-import-btn:hover:not(:disabled){background:linear-gradient(135deg,#f57c00,#ef6c00);box-shadow:0 4px 12px #ff980066}.export-textarea,.import-textarea{background:#fff;border-radius:6px;font-size:.85rem;margin:10px 0;padding:12px}.export-textarea:focus,.import-textarea:focus{border-color:#9c27b0;box-shadow:0 0 0 3px #9c27b01a}.export-data-section{background:#fff;border-radius:6px;margin-top:15px;padding:10px}.import-note{background:#fff3cd;border:1px solid #ffeaa7;color:#856404;padding:12px}.roster-action-btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.6;transform:none!important}@media (max-width:768px){.voting-couples-manager{padding:15px}.manager-header h2{font-size:1.5rem}.manager-actions{align-items:center;flex-direction:column}.action-btn{justify-content:center;max-width:300px;width:100%}.couples-grid{gap:15px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.add-form-container{padding:15px}.roster-actions{flex-direction:column}.roster-action-btn{width:100%}.roster-manager-container{padding:15px}}.results-page{background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;font-family:Poppins,sans-serif;min-height:100vh;padding:20px}.results-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;padding:30px}.results-header h1{color:#ff7eb9;margin-bottom:20px}.admin-controls{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:20px}.back-link,.vote-link{background:#2196f3;border-radius:25px;color:#fff;display:inline-block;font-weight:500;padding:12px 24px;text-decoration:none;transition:all .3s ease}.back-link:hover,.vote-link:hover{background:#1976d2;transform:translateY(-2px)}.vote-link{background:#e91e63}.vote-link:hover{background:#c2185b}.voting-status-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:15px;margin-bottom:30px;padding:25px}.voting-status-panel h2{color:#ff7eb9;font-size:1.8rem;margin-bottom:20px}.status-info{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:25px}.status-info p{font-size:1.1rem;margin:10px 0}.status-info strong{color:#ff7eb9}.status.active{color:#4caf50;font-weight:700}.status.inactive{color:#f44336;font-weight:700}.admin-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.admin-actions button{border:none;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.refresh-btn{background:#2196f3}.refresh-btn:hover{background:#1976d2;transform:translateY(-2px)}.manage-couples-btn{background:#9c27b0}.manage-couples-btn:hover{background:#7b1fa2;transform:translateY(-2px)}.end-voting-btn{background:#f44336}.end-voting-btn:hover{background:#d32f2f;transform:translateY(-2px)}.start-voting-btn{background:#4caf50}.start-voting-btn:hover{background:#388e3c;transform:translateY(-2px)}.export-btn{background:#ff9800}.export-btn:hover:not(:disabled){background:#f57c00}.export-btn:disabled{background:#666;cursor:not-allowed;opacity:.6}.clear-votes-btn{background:#f44336}.clear-votes-btn:hover{background:#d32f2f;transform:translateY(-2px)}.couples-manager-section{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:15px;margin:30px 0;padding:20px}.results-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border-radius:15px;padding:25px}.results-content h2{color:#ff7eb9;font-size:1.8rem;margin-bottom:25px;text-align:center}.results-list{display:flex;flex-direction:column;gap:15px;margin:0 auto;max-width:1000px}.result-item{align-items:center;background:#ffffff1a;border:1px solid #ffffff1a;border-radius:12px;display:flex;gap:20px;padding:15px;transition:all .3s ease}.result-item:hover{background:#ffffff26;transform:translateX(5px)}.rank-position{background:#ff7eb933;border-radius:50%;color:#ff7eb9;font-size:1.5rem;font-weight:700;height:50px;min-width:60px;text-align:center;width:50px}.couple-display{flex:1 1}.vote-info{min-width:120px;text-align:right}.vote-count{color:#4caf50;font-size:1.3rem;font-weight:700;margin-bottom:5px}.vote-percentage{color:#b0b0b0;font-size:.9rem}.no-results{color:#b0b0b0}.message,.no-results p{margin:15px 0}.message.success{background:#4caf5033;border:1px solid #4caf504d;color:#4caf50}.message.error{background:#f4433633;border:1px solid #f443364d;color:#f44336}.export-customization{background:#ffffff1a;border-radius:10px;margin-bottom:20px;padding:20px}.customization-controls{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.customization-controls label{color:#fff;display:flex;flex-direction:column;font-weight:500;gap:8px}.header-input,.palette-select{border:1px solid #ccc;border-radius:5px;font-size:1rem;min-width:200px;padding:10px}@media (max-width:768px){.results-page{padding:10px}.results-header h1{font-size:2rem}.admin-actions,.admin-controls{align-items:center;flex-direction:column}.admin-actions button{max-width:300px;width:100%}.result-item{flex-direction:column;gap:15px}.result-item,.vote-info{text-align:center}.customization-controls{align-items:center;flex-direction:column}.status-info{grid-template-columns:1fr}}.public-announcement{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:20px}.announcement-container{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001a;margin:0 auto;max-width:1000px;overflow:hidden}.announcement-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px;text-align:center}.announcement-title{font-size:2.5rem;font-weight:800;line-height:1.2;margin:0 0 15px;text-shadow:0 2px 4px #0000004d}.announcement-date{font-size:1.1rem;font-weight:500;opacity:.9}.announcement-content{padding:40px 30px;text-align:center}.image-container{background:#f8f9fa;border:4px solid #667eea;border-radius:16px;box-shadow:0 8px 32px #0003;display:inline-block;max-width:100%;overflow:hidden}.announcement-image{display:block;max-width:100%;transition:transform .3s ease}.announcement-image:hover{transform:scale(1.02)}.announcement-footer{background:#f8f9fa;border-top:2px solid #e9ecef;padding:30px}.social-share{text-align:center}.social-share p{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 20px}.share-buttons{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.download-btn,.share-btn{align-items:center;border:none;border-radius:12px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;text-decoration:none;transition:all .3s ease}.share-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.share-btn:hover{box-shadow:0 6px 20px #667eea4d;transform:translateY(-2px)}.download-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.download-btn:hover{box-shadow:0 6px 20px #28a7454d;transform:translateY(-2px)}.announcement-loading{align-items:center;color:#667eea;display:flex;flex-direction:column;justify-content:center;min-height:400px}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#667eea;height:50px;width:50px}.announcement-loading p{font-size:1.2rem;font-weight:600;margin:0}.announcement-error{color:#dc3545;padding:50px 20px;text-align:center}.announcement-error p{font-size:1.2rem;margin:0 0 20px}.retry-btn{background:linear-gradient(135deg,#dc3545,#c82333);border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .3s ease}.retry-btn:hover{box-shadow:0 6px 20px #dc35454d;transform:translateY(-2px)}.no-announcement{align-items:center;display:flex;justify-content:center;min-height:400px;padding:40px 20px}.no-announcement-content{max-width:500px;text-align:center}.no-announcement-content h2{color:#667eea;font-size:2rem;font-weight:700;margin:0 0 20px}.no-announcement-content p{color:#666;font-size:1.1rem;line-height:1.6;margin:0 0 15px}.no-announcement-content p:last-child{color:#333;font-weight:600}@media (max-width:768px){.public-announcement{padding:15px}.announcement-header{padding:30px 20px}.announcement-title{font-size:2rem}.announcement-date{font-size:1rem}.announcement-content{padding:30px 20px}.announcement-footer{padding:25px 20px}.share-buttons{align-items:center;flex-direction:column}.download-btn,.share-btn{justify-content:center;width:200px}}@media (max-width:480px){.public-announcement{padding:10px}.announcement-header{padding:25px 15px}.announcement-title{font-size:1.6rem}.announcement-content{padding:25px 15px}.announcement-footer{padding:20px 15px}.image-container{border-width:2px}.no-announcement-content h2{font-size:1.6rem}.no-announcement-content p{font-size:1rem}}*,:after,:before{box-sizing:border-box}body,html{overflow-x:hidden}.public-results-page{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1200px;overflow-x:hidden;padding:20px;width:100%}.results-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;padding:20px;position:relative;text-align:center}.header-content{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.header-title{flex:1 1;text-align:center}.back-button{background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:10px 20px;transition:all .3s ease}.back-button:hover{background:#ffffff4d;transform:translateY(-2px)}.results-header h1{font-size:2.5rem;font-weight:700;margin:0 0 10px}.results-header p{font-size:1.1rem;margin:0 0 20px;opacity:.9}.refresh-button{background:#fff3;border:2px solid #ffffff4d;font-size:1rem;padding:10px 20px}.refresh-button:hover{background:#ffffff4d}.loading{padding:60px 20px;text-align:center}.loading h2{color:#667eea;margin-bottom:15px}.spinner{border-top-color:#667eea;height:40px;margin:0 auto;width:40px}.historical-results-section{overflow-x:hidden;width:100%}.no-historical-results{background:#f8f9fa;border:2px dashed #dee2e6;border-radius:12px;padding:60px 20px;text-align:center}.no-historical-results h3{color:#333;font-size:1.5rem;margin-bottom:15px}.historical-results-main{grid-gap:30px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:grid;gap:30px;grid-template-columns:300px 1fr;max-width:100%;min-height:600px;overflow:hidden;width:100%}.weeks-sidebar{background:#f8f9fa;border-right:1px solid #e9ecef;overflow-x:hidden;padding:25px;width:100%}.weeks-sidebar h3{color:#333;font-size:1.3rem;margin:0 0 20px;text-align:center}.week-list{gap:12px;width:100%}.week-button{background:#fff;border:2px solid #e9ecef;padding:16px;width:100%}.week-button:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.week-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 16px #667eea4d}.week-title{color:inherit;margin-bottom:6px}.week-subtitle{line-height:1.4;margin-bottom:6px}.week-stats{font-size:.8rem;opacity:.9}.first-week-badge{background:linear-gradient(135deg,#ff6b6b,#feca57);border-radius:20px;display:inline-block;margin-top:8px;padding:4px 8px}.results-display-area{min-width:0;overflow-x:hidden;padding:25px;width:100%}.week-results{max-width:100%;overflow-x:hidden;width:100%}.week-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:12px;padding:20px}.week-header h3{color:#333;margin:0 0 15px;text-align:center}.week-info{font-size:.95rem}.week-info span{align-items:center;display:flex;gap:5px}.first-week-indicator{background:linear-gradient(135deg,#ff6b6b,#feca57);border-radius:20px;color:#fff;font-size:.85rem;padding:6px 12px}.rankings-list{max-width:100%;overflow-x:hidden;width:100%}.ranking-item{background:linear-gradient(135deg,#fff,#fafbfc);border:1px solid #e1e8ed;grid-template-columns:120px 160px 1fr}.ranking-item:hover{border-color:#667eea;box-shadow:0 8px 25px #0000001a;transform:translateY(-3px)}.ranking-item.rank-1{background:linear-gradient(135deg,gold,#ffed4e);border:2px solid #f1c40f;box-shadow:0 4px 20px #f1c40f4d}.ranking-item.rank-1:hover{box-shadow:0 8px 30px #f1c40f66}.ranking-item.rank-1 .result-char-image-wrapper{border-color:#f39c12;box-shadow:0 6px 20px #f39c1266}.ranking-item.rank-2{background:linear-gradient(135deg,#e8e8e8,#d5d5d5);border:2px solid #95a5a6;box-shadow:0 4px 20px #95a5a64d}.ranking-item.rank-2:hover{box-shadow:0 8px 30px #95a5a666}.ranking-item.rank-2 .result-char-image-wrapper{border-color:#7f8c8d;box-shadow:0 6px 20px #7f8c8d66}.ranking-item.rank-3{background:linear-gradient(135deg,#cd7f32,#d4af37);border:2px solid #b7850f;box-shadow:0 4px 20px #b7850f4d}.ranking-item.rank-3:hover{box-shadow:0 8px 30px #b7850f66}.ranking-item.rank-3 .result-char-image-wrapper{border-color:#a0690f;box-shadow:0 6px 20px #a0690f66}.rank-medal{font-size:2.2rem;margin-bottom:5px}.movement-indicator{border-radius:12px;font-size:.8rem;font-weight:600;padding:4px 8px;white-space:nowrap}.movement-indicator.up{background:linear-gradient(135deg,#00c851,#00a041);color:#fff}.movement-indicator.down{background:linear-gradient(135deg,#f44,#c00);color:#fff}.movement-indicator.same{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff}.movement-indicator.new{animation:newItemPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#ff6b6b,#feca57);color:#fff}.movement-indicator.reappear{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}@keyframes newItemPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.top-10-separator{align-items:center;display:flex;gap:15px;margin:20px 0}.separator-line{background:linear-gradient(90deg,#0000,#667eea,#0000);flex:1 1;height:2px}.separator-text{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #667eea;border-radius:20px;box-shadow:0 2px 8px #667eea33;color:#667eea;font-size:.9rem;font-weight:700;letter-spacing:.5px;padding:8px 16px;text-transform:uppercase}.result-char-image-wrapper{align-items:center;background-color:#f5f5f5;border:3px solid #667eea;border-radius:50%;box-shadow:0 4px 12px #667eea40;display:flex;flex-shrink:0;height:55px;justify-content:center;overflow:hidden;transition:all .3s ease;width:55px}.char-image-ranking{height:100%;width:100%}.result-char-image-wrapper:hover{border-color:#5a67d8;box-shadow:0 6px 16px #667eea59;transform:scale(1.05)}.result-char-image-wrapper:hover .char-image-ranking{transform:scale(1.1)}.couple-divider{color:#667eea}.couple-info{display:flex;flex-direction:column;gap:12px}.couple-main-info{flex:1 1}.couple-stats{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.stat-item{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:8px;display:flex;flex-direction:column;gap:2px;min-width:50px;padding:6px 10px}.stat-icon{color:#6c757d;font-size:.7rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stat-value{color:#495057;font-size:.9rem;font-weight:700}.stat-item.peak-rank .stat-value{color:#e91e63}.stat-item.prev-rank .stat-value{color:#2196f3}.stat-item.weeks-on .stat-value{color:#4caf50}@keyframes rankingAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ranking-item{animation:rankingAppear .5s ease-out forwards}.ranking-item:first-child{animation-delay:.1s}.ranking-item:nth-child(2){animation-delay:.2s}.ranking-item:nth-child(3){animation-delay:.3s}@keyframes medalPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.ranking-item.rank-1 .rank-medal,.ranking-item.rank-2 .rank-medal,.ranking-item.rank-3 .rank-medal{animation:medalPulse 3s ease-in-out infinite}@media (min-width:641px){.ranking-item{display:grid!important;grid-template-columns:120px 160px 1fr!important}.rank-position{max-width:120px!important;min-width:120px!important;width:120px!important}.couple-images-section{max-width:160px!important;min-width:160px!important;width:160px!important}}@media (max-width:1024px) and (min-width:641px){.header-content{gap:16px}.back-button,.refresh-button{font-size:.95rem;padding:8px 16px}.header-title h1{font-size:2.2rem}}@media (max-width:1024px){.historical-results-main{gap:20px;grid-template-columns:250px 1fr}}@media (max-width:640px){.public-results-page{margin:0;max-width:100vw;padding:12px}.results-header{margin:0 0 20px;padding:18px 12px}.header-content{flex-direction:column;gap:15px}.back-button{align-self:flex-start;font-size:.9rem;padding:8px 16px}.header-title h1{font-size:1.8rem;margin-bottom:8px}.refresh-button{font-size:.9rem;padding:8px 16px}.historical-results-main{gap:0;grid-template-columns:1fr;width:100%}.weeks-sidebar{border-bottom:1px solid #e9ecef;border-right:none}.results-display-area,.weeks-sidebar{padding:18px 12px}.week-list{-webkit-overflow-scrolling:touch;flex-direction:row;gap:10px;overflow-x:auto;padding-bottom:10px}.week-button{flex-shrink:0;min-width:200px}.ranking-item{gap:12px;grid-template-columns:1fr;margin:0 auto;max-width:100%;padding:16px 12px;text-align:center}.rank-position{align-items:center;flex-direction:row;min-width:auto}.couple-images-section,.rank-position{justify-content:center;margin:0 auto;width:-webkit-fit-content;width:fit-content}.couple-images-section{gap:10px}.result-char-image-wrapper{border-width:2px;height:50px;width:50px}.char-image-ranking{height:50px;width:50px}.couple-divider{font-size:1.2rem}.couple-info{margin-left:0;text-align:center}.couple-title{font-size:1.2rem}.couple-names{font-size:1rem}.anime-title{font-size:.9rem}.week-header{padding:15px}.week-header h3{font-size:1.5rem;margin-bottom:12px}.week-info{flex-direction:column;gap:10px}.top-10-separator{gap:10px;margin:15px 0}.separator-text{font-size:.8rem;padding:6px 12px}.couple-stats{gap:8px;justify-content:center;margin-top:12px}.stat-item{min-width:45px;padding:4px 8px}.stat-icon{font-size:.65rem}.stat-value{font-size:.8rem}}@media (max-width:480px){.public-results-page{max-width:100vw;padding:10px}.results-header{border-radius:8px;margin:0 0 15px;padding:15px 10px}.header-content{gap:12px}.back-button{font-size:.85rem;padding:6px 12px}.header-title h1{font-size:1.6rem}.refresh-button{font-size:.85rem;padding:6px 12px}.results-display-area,.weeks-sidebar{padding:15px 10px}.week-list{flex-direction:column;gap:8px;overflow-x:visible}.week-button{min-width:100%;width:100%}.ranking-item{gap:10px;margin:0 auto;max-width:100%;padding:14px 10px}.couple-images-section,.rank-position{margin:0 auto;width:-webkit-fit-content;width:fit-content}.couple-images-section{gap:8px}.couple-title{font-size:1.1rem}.couple-names{font-size:.95rem}.anime-title{font-size:.85rem}.result-char-image-wrapper{border-width:2px;height:45px;width:45px}.char-image-ranking{height:45px;width:45px}.couple-divider{font-size:1rem}.week-header{padding:12px}.week-header h3{font-size:1.3rem}.top-10-separator{gap:8px;margin:12px 0}.separator-text{font-size:.75rem;padding:5px 10px}.couple-stats{gap:6px;margin-top:10px}.stat-item{min-width:40px;padding:3px 6px}.stat-icon{font-size:.6rem}.stat-value{font-size:.75rem}}@media (max-width:320px){.public-results-page{padding:8px}.ranking-item,.results-display-area,.results-header,.weeks-sidebar{padding:12px 8px}.ranking-item{margin:0 auto;max-width:100%}.couple-images-section,.rank-position{margin:0 auto;width:-webkit-fit-content;width:fit-content}.couple-images-section{gap:6px}.result-char-image-wrapper{border-width:2px;height:40px;width:40px}.char-image-ranking{height:40px;width:40px}.couple-title{font-size:1rem}.couple-names{font-size:.9rem}.anime-title{font-size:.8rem}}.tab-navigation{display:flex;gap:10px;justify-content:center;margin:20px 0;padding:0 20px}.tab-button{align-items:center;background:#fff;border:2px solid #667eea;border-radius:12px;color:#667eea;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.tab-button:hover{background:#667eea1a;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 6px 16px #667eea4d;color:#fff;transform:translateY(-2px)}.tab-content{min-height:400px}.admin-login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);bottom:0;display:flex;justify-content:center;left:0;min-height:100vh;padding:20px;position:fixed;right:0;top:0;z-index:1000}.admin-login-card{animation:slideIn .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:400px;padding:40px;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.admin-login-header{margin-bottom:32px;text-align:center}.admin-login-header h2{color:#333;font-size:28px;font-weight:600;margin:0 0 8px}.admin-login-header p{color:#666;font-size:14px;margin:0}.admin-login-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-size:14px;font-weight:500}.form-group input{background:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;padding:12px 16px;transition:all .2s ease}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{flex:1 1;padding-right:48px}.password-toggle{background:none;border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:4px;position:absolute;right:12px;transition:background-color .2s ease}.password-toggle:hover:not(:disabled){background:#f0f0f0}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:14px;padding:12px 16px}.error-message,.login-button{align-items:center;display:flex;gap:8px}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;justify-content:center;margin-top:8px;padding:14px 24px;transition:all .2s ease}.login-button:hover:not(:disabled){box-shadow:0 8px 16px #667eea4d;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.loading-spinner{border:2px solid #0000;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.admin-login-footer{border-top:1px solid #e5e7eb;margin-top:32px;padding-top:24px;text-align:center}.admin-login-footer p{color:#059669;font-size:14px;font-weight:500;margin:0 0 4px}.admin-login-footer small{color:#6b7280;font-size:12px}@media (max-width:480px){.admin-login-container{padding:16px}.admin-login-card{padding:24px}.admin-login-header h2{font-size:24px}}.admin-login-card:before{background:linear-gradient(90deg,#10b981,#059669);border-radius:16px 16px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.admin-login-card{position:relative}.admin-login-container:focus{outline:none}@media (prefers-contrast:high){.admin-login-card{border:2px solid #000}.form-group input{border-color:#000}.login-button{background:#000;border:2px solid #000}}@media (prefers-reduced-motion:reduce){.admin-login-card,.loading-spinner{animation:none}.login-button{transition:none}}.admin-roster-manager{font-family:Poppins,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.manager-header{background:linear-gradient(135deg,#e91e63,#9c27b0);border-radius:12px;box-shadow:0 4px 12px #e91e634d}.manager-section{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px}.manager-section h3{border-bottom:2px solid #e91e63;color:#333;font-size:1.3rem;font-weight:600;margin:0 0 15px;padding-bottom:8px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-top:15px}.action-buttons button{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;min-width:140px;padding:12px 20px;transition:all .3s ease}.export-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.export-btn:hover:not(:disabled){background:linear-gradient(135deg,#45a049,#3e8e41);box-shadow:0 4px 12px #4caf5066;transform:translateY(-2px)}.delete-btn{background:linear-gradient(135deg,#f44336,#d32f2f)}.delete-btn:hover:not(:disabled){background:linear-gradient(135deg,#d32f2f,#c62828);box-shadow:0 4px 12px #f4433666;transform:translateY(-2px)}.refresh-btn{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.refresh-btn:hover:not(:disabled){background:linear-gradient(135deg,#1976d2,#1565c0);box-shadow:0 4px 12px #2196f366;transform:translateY(-2px)}.import-btn{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.import-btn:hover:not(:disabled){background:linear-gradient(135deg,#f57c00,#ef6c00);box-shadow:0 4px 12px #ff980066;transform:translateY(-2px)}.auto-import-btn{background:linear-gradient(135deg,#9c27b0,#7b1fa2);color:#fff}.auto-import-btn:hover:not(:disabled){background:linear-gradient(135deg,#7b1fa2,#6a1b9a);box-shadow:0 4px 12px #9c27b066;transform:translateY(-2px)}button:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.6;transform:none!important}.export-textarea,.import-textarea{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:8px;font-family:Consolas,Monaco,monospace;font-size:.9rem;margin-top:10px;min-height:200px;padding:15px;resize:vertical;width:100%}.export-textarea:focus,.import-textarea:focus{border-color:#e91e63;box-shadow:0 0 0 3px #e91e631a;outline:none}.message{word-wrap:break-word;border-radius:8px;font-weight:500;padding:15px;white-space:pre-wrap}.message.success{background:linear-gradient(135deg,#e8f5e8,#d4edda);border:1px solid #c3e6cb}.message.error{background:linear-gradient(135deg,#ffeaea,#f8d7da);border:1px solid #f5c6cb}.import-note{background:#f0f0f0;border-left:4px solid #ff9800;border-radius:6px;color:#666;font-size:.9rem;margin-top:10px;padding:10px}.loading-overlay{align-items:center;background:#000000b3;bottom:0;color:#fff;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-spinner{animation:spin 1s linear infinite;font-size:3rem;margin-bottom:20px}.loading-overlay p{font-size:1.2rem;font-weight:600}.admin-dashboard h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e91e63,#9c27b0);background-clip:text;-webkit-background-clip:text;color:#e91e63;font-size:2.2rem;font-weight:700;margin-bottom:10px;text-align:center}.admin-dashboard>p{color:#666;font-size:1.1rem;margin-bottom:30px;text-align:center}.admin-nav{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:30px}.admin-nav-button{align-items:center;background:linear-gradient(135deg,#fafafa,#f5f5f5);border:2px solid #e0e0e0;border-radius:12px;color:#333;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.95rem;font-weight:600;gap:8px;justify-content:center;min-width:140px;padding:12px 20px;text-decoration:none;transition:all .3s ease}.admin-nav-button:hover{background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-color:#4caf50;box-shadow:0 4px 12px #4caf5033;transform:translateY(-2px)}.admin-nav-button.active{background:linear-gradient(135deg,#e91e63,#9c27b0);border-color:#e91e63;box-shadow:0 4px 16px #e91e634d;color:#fff}.admin-nav-button.active:hover{background:linear-gradient(135deg,#d81b60,#8e24aa);box-shadow:0 6px 20px #e91e6366;transform:translateY(-2px)}.admin-dashboard>div>p{background:#f0f0f0;border-radius:8px;color:#666;font-size:.9rem;font-style:italic;margin-bottom:20px;padding:10px}.admin-dashboard{font-family:Poppins,sans-serif;margin:0 auto;max-width:1200px;padding:20px}@media (max-width:768px){.admin-dashboard,.admin-roster-manager{padding:15px}.admin-dashboard h1{font-size:1.8rem}.admin-nav{flex-direction:column;gap:8px}.admin-nav-button{min-width:auto;width:100%}.manager-header h2{font-size:1.6rem}.manager-header p{font-size:1rem}.action-buttons{flex-direction:column}.action-buttons button{min-width:auto;width:100%}.manager-section{padding:15px}}@media (max-width:480px){.admin-dashboard h1{font-size:1.5rem}.admin-nav-button{font-size:.9rem;padding:10px 16px}.manager-header h2{font-size:1.4rem}.manager-header p{font-size:.9rem}.manager-section h3{font-size:1.1rem}}.voting-period-manager{font-family:Poppins,sans-serif;margin:0 auto;max-width:1000px;padding:20px}.voting-period-manager h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e91e63,#9c27b0);background-clip:text;-webkit-background-clip:text;color:#e91e63;font-size:2rem;font-weight:700;margin-bottom:30px;text-align:center}.voting-period-manager h3{border-bottom:2px solid #e91e63;color:#333;font-size:1.4rem;font-weight:600;margin-bottom:20px;padding-bottom:8px}.create-period-section,.current-period-section,.periods-history-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e91e631a;border-radius:16px;box-shadow:0 6px 20px #e91e631f;margin-bottom:30px;padding:24px}.period-card{background:linear-gradient(135deg,#fafafa,#f5f5f5);border:2px solid #e0e0e0;border-radius:12px;margin-bottom:16px;padding:20px;transition:all .3s ease}.period-card.active-period{background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-color:#4caf50;box-shadow:0 4px 16px #4caf5033}.period-card.inactive{background:linear-gradient(135deg,#fafafa,#f0f0f0);border-color:#bdbdbd;opacity:.8}.period-card h4{color:#333;font-size:1.3rem;font-weight:700;margin-bottom:8px}.period-description{color:#666;font-size:.95rem;font-style:italic;line-height:1.5;margin-bottom:16px}.period-dates{margin-bottom:16px}.period-dates p{color:#555;font-size:.9rem;margin:6px 0}.period-dates strong{color:#e91e63;font-weight:600}.status-badge{border-radius:20px;font-size:.8rem;font-weight:600;padding:4px 12px;position:absolute;right:16px;text-transform:uppercase;top:16px}.status-badge.active{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.status-badge.inactive{background:linear-gradient(135deg,#757575,#9e9e9e);color:#fff}.no-active-period{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:2px dashed #ff9800;border-radius:12px;padding:40px 20px;text-align:center}.no-active-period p{color:#e65100;font-size:1.1rem;font-weight:500;margin-bottom:20px}.period-form{background:#fafafa;border:2px solid #e0e0e0;border-radius:12px;padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.95rem;margin-bottom:8px}.form-group input,.form-group textarea{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:.95rem;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#e91e63;box-shadow:0 0 0 3px #e91e631a;outline:none}.form-group textarea{min-height:80px;resize:vertical}.datetime-row{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-bottom:20px}.datetime-group label{color:#333;display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.datetime-inputs{display:flex;gap:12px}.datetime-inputs input{background:#fff;border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-family:inherit;font-size:.95rem;padding:12px 16px;transition:all .3s ease}.datetime-inputs input:focus{border-color:#e91e63;box-shadow:0 0 0 3px #e91e631a;outline:none}.readonly-field{background:#f5f5f5!important;border-color:#ccc!important;color:#666!important;cursor:not-allowed!important}.readonly-field:focus{border-color:#ccc!important;box-shadow:none!important}.field-note{color:#666;display:block;font-size:.85rem;font-style:italic;margin-top:6px}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-family:inherit;font-size:.95rem;font-weight:600;padding:12px 24px;text-align:center;text-decoration:none;transition:all .3s ease}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:linear-gradient(135deg,#e91e63,#9c27b0);box-shadow:0 4px 16px #e91e634d;color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#d81b60,#8e24aa);box-shadow:0 6px 20px #e91e6366;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#757575,#9e9e9e);box-shadow:0 4px 16px #7575754d;color:#fff}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#616161,#757575);box-shadow:0 6px 20px #75757566;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#f44336,#e53935);box-shadow:0 4px 16px #f443364d;color:#fff}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#e53935,#d32f2f);box-shadow:0 6px 20px #f4433666;transform:translateY(-2px)}.form-actions{border-top:2px solid #e0e0e0;display:flex;gap:16px;justify-content:flex-end;margin-top:24px;padding-top:20px}.periods-list{display:flex;flex-direction:column;gap:16px}.voting-mode-select{background:#fff;border:2px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.voting-mode-select:focus{border-color:#e91e63;box-shadow:0 0 0 3px #e91e631a;outline:none}.voting-mode-explanation{border-radius:8px;font-size:.9rem;line-height:1.4;margin-top:12px;padding:12px 16px}.mode-info{display:block}.mode-info.oneoff{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-left:4px solid #ff9800;color:#e65100}.mode-info.seasonal{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border-left:4px solid #4caf50;color:#2e7d32}.period-mode{display:flex;flex-direction:column;gap:6px;margin:12px 0}.mode-badge{border-radius:20px;display:inline-block;font-size:.9rem;font-weight:600;padding:6px 12px;text-align:center;width:-webkit-fit-content;width:fit-content}.mode-badge.oneoff{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.mode-badge.seasonal{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.mode-description{color:#666;font-size:.85rem;font-style:italic}.period-card{position:relative}.period-card:before{border-radius:8px 0 0 8px;content:"";height:100%;left:0;position:absolute;top:0;width:5px}.period-card.active-period:before{background:linear-gradient(135deg,#e91e63,#9c27b0)}.first-week-group{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:2px solid #ff9800;border-radius:12px;margin:16px 0;padding:16px}.checkbox-label{align-items:center;color:#333;cursor:pointer;display:flex;font-weight:600;gap:12px;margin-bottom:8px}.first-week-checkbox{accent-color:#ff9800;cursor:pointer;height:20px;width:20px}.checkbox-text{font-size:1rem;-webkit-user-select:none;user-select:none}.first-week-explanation{margin-top:8px}.mode-info.first-week{background:linear-gradient(135deg,#ffebe3,#ffcc80);border-left:4px solid #ff9800;color:#e65100}@media (max-width:768px){.voting-period-manager{padding:16px}.voting-period-manager h2{font-size:1.6rem}.datetime-row{gap:16px;grid-template-columns:1fr}.datetime-inputs{gap:8px}.datetime-inputs,.form-actions{flex-direction:column}.btn{width:100%}.create-period-section,.current-period-section,.period-card,.periods-history-section{padding:16px}.status-badge{display:inline-block;margin-top:12px;position:static}.period-mode{align-items:flex-start;flex-direction:column}.mode-badge{text-align:center;width:100%}.voting-mode-explanation{padding:10px 12px}.mode-info{font-size:.85rem}}@media (max-width:480px){.voting-period-manager h2{font-size:1.4rem}.voting-period-manager h3{font-size:1.2rem}.period-card h4{font-size:1.1rem}.btn{font-size:.9rem;padding:10px 16px}}.announcement-manager{background:#f8f9fa;margin:0 auto;max-width:1200px;min-height:100vh;padding:20px}.manager-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 20px #667eea4d;color:#fff;margin-bottom:30px;padding:20px;text-align:center}.manager-header h2{font-size:2rem;font-weight:700;margin:0 0 10px}.manager-header p{font-size:1.1rem;margin:0;opacity:.9}.loading-spinner{color:#667eea;font-size:1.2rem;padding:50px;text-align:center}.message{margin-bottom:20px;padding:12px 20px}.message.success{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:2px solid #c3e6cb;color:#155724}.message.error{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:2px solid #f5c6cb;color:#721c24}.current-announcement-section{background:#fff;border:2px solid #e9ecef;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:30px;padding:25px}.current-announcement-section h3{color:#333;font-size:1.5rem;font-weight:700;margin:0 0 20px}.announcement-preview{grid-gap:25px;align-items:start;display:grid;gap:25px;grid-template-columns:300px 1fr}.announcement-image{border:3px solid #667eea;border-radius:12px;box-shadow:0 6px 20px #00000026;height:auto;max-width:300px;width:100%}.announcement-details{display:flex;flex-direction:column;gap:15px}.title-section label{color:#333;display:block;font-weight:600;margin-bottom:8px}.title-input-group{align-items:center;display:flex;gap:10px}.title-input{border:2px solid #e9ecef;border-radius:12px;flex:1 1;font-size:1rem;padding:12px 16px;transition:all .3s ease}.title-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.update-title-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:600;padding:12px 20px;transition:all .3s ease;white-space:nowrap}.update-title-btn:hover{box-shadow:0 6px 20px #667eea4d;transform:translateY(-2px)}.update-title-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.announcement-date{color:#666;font-size:.95rem;margin:0}.delete-btn{align-self:flex-start;background:linear-gradient(135deg,#dc3545,#c82333);border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:600;padding:12px 20px;transition:all .3s ease}.delete-btn:hover{box-shadow:0 6px 20px #dc35454d;transform:translateY(-2px)}.delete-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.upload-section{background:#fff;border:2px solid #e9ecef;border-radius:16px;box-shadow:0 4px 20px #00000014;margin-bottom:30px;padding:25px}.upload-section h3{color:#333;font-size:1.5rem;font-weight:700;margin:0 0 20px}.upload-form{gap:20px}.form-group,.upload-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#333;font-size:1rem;font-weight:600}.file-input{background:#667eea0d;border:2px dashed #667eea;border-radius:12px;cursor:pointer;font-size:1rem;padding:12px 16px;transition:all .3s ease}.file-input:hover{background:#667eea1a;border-color:#5a67d8}.file-help{color:#666;font-size:.9rem;font-style:italic;margin:0}.preview-section{margin-top:15px}.preview-section h4{color:#333;font-size:1.2rem;margin:0 0 15px}.preview-image{border:3px solid #667eea;border-radius:12px;box-shadow:0 6px 20px #00000026;height:auto;max-width:400px;width:100%}.upload-btn{align-self:flex-start;background:linear-gradient(135deg,#28a745,#20c997);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:16px 24px;transition:all .3s ease}.upload-btn:hover{box-shadow:0 6px 20px #28a7454d;transform:translateY(-2px)}.upload-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.instructions{background:#fff;border:2px solid #e9ecef;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:25px}.instructions h4{color:#333;font-size:1.3rem;font-weight:700;margin:0 0 15px}.instructions ul{margin:0;padding-left:20px}.instructions li{color:#555;line-height:1.6;margin-bottom:8px}@media (max-width:768px){.announcement-manager{padding:15px}.manager-header h2{font-size:1.6rem}.manager-header p{font-size:1rem}.announcement-preview{gap:20px;grid-template-columns:1fr}.announcement-image{justify-self:center;max-width:100%}.title-input-group{align-items:stretch;flex-direction:column}.current-announcement-section,.instructions,.upload-section{padding:20px}}@media (max-width:480px){.announcement-manager{padding:10px}.manager-header{padding:15px}.manager-header h2{font-size:1.4rem}.current-announcement-section,.instructions,.upload-section{padding:15px}.announcement-details{gap:12px}.upload-form{gap:15px}}.weekly-results-container{font-family:Poppins,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.weekly-results-container h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e91e63,#9c27b0);background-clip:text;-webkit-background-clip:text;color:#e91e63;font-size:2rem;font-weight:700;margin-bottom:30px;text-align:center}.message{animation:messageSlideIn .3s ease-out;border-radius:12px;font-weight:600;margin-bottom:24px;padding:16px 20px;text-align:center}.message.success{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border:2px solid #4caf50;color:#2e7d32}.message.error{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #f44336;color:#c62828}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.loading-spinner{align-items:center;display:flex;flex-direction:column;gap:20px;padding:60px 20px}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#e91e63;height:50px;width:50px}@keyframes spin{to{transform:rotate(1turn)}}.no-results{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:3px dashed #ff9800;border-radius:20px;padding:60px 20px;text-align:center}.no-results h3{color:#e65100;font-size:1.8rem;font-weight:700;margin-bottom:15px}.no-results p{color:#bf360c;font-size:1.1rem;font-weight:500}.weekly-results-main{display:flex;flex-direction:column;gap:24px}.main-controls{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e91e631a;border-radius:16px;box-shadow:0 6px 20px #e91e631f;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:20px}.view-mode-controls{flex-wrap:wrap}.action-controls{display:flex;flex-wrap:wrap;gap:12px}.mode-button{background:linear-gradient(135deg,#fafafa,#f5f5f5);border:2px solid #e0e0e0;border-radius:12px;font-family:inherit;padding:12px 20px}.mode-button:hover{background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-color:#4caf50;transform:translateY(-1px)}.mode-button.active{background:linear-gradient(135deg,#e91e63,#9c27b0);border-color:#e91e63;box-shadow:0 4px 12px #e91e634d}.action-button{background:linear-gradient(135deg,#2196f3,#21cbf3);border:none;border-radius:8px;box-shadow:0 3px 10px #2196f34d;color:#fff;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;padding:10px 16px;transition:all .3s ease}.action-button:hover{box-shadow:0 5px 15px #2196f366;transform:translateY(-2px)}.delete-button{background:linear-gradient(135deg,#f44336,#e91e63);box-shadow:0 3px 10px #f443364d}.delete-button:hover{box-shadow:0 5px 15px #f4433666}.content-layout{grid-gap:30px;align-items:start;display:grid;gap:30px;grid-template-columns:320px 1fr}.week-selector-sidebar{position:-webkit-sticky;position:sticky;top:20px}.week-selector{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e91e631a;border-radius:16px;box-shadow:0 6px 20px #e91e631f;padding:20px}.week-selector h3{border-bottom:2px solid #e91e63;color:#333;font-size:1.2rem;font-weight:600;margin-bottom:16px;padding-bottom:8px;text-align:center}.week-list{display:flex;flex-direction:column;gap:8px}.week-button{background:linear-gradient(135deg,#fafafa,#f5f5f5);border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;font-family:inherit;padding:12px 16px;text-align:left;transition:all .3s ease}.week-button:hover{background:linear-gradient(135deg,#e8f5e8,#f1f8e9);border-color:#4caf50;transform:translateY(-1px)}.week-button.active{background:linear-gradient(135deg,#e91e63,#9c27b0);border-color:#e91e63;box-shadow:0 4px 12px #e91e634d;color:#fff}.week-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.week-title{font-size:1rem}.week-subtitle{font-size:.85rem;opacity:.8}.week-stats{font-weight:500;opacity:.7}.first-week-badge{background:linear-gradient(135deg,#ff9800,#f57c00);border-radius:12px;color:#fff;font-size:.7rem;font-weight:600;margin-top:4px;padding:2px 8px;text-align:center}.results-display-area{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e91e631a;border-radius:16px;box-shadow:0 6px 20px #e91e631f;min-height:400px;padding:24px}.empty-results-state{color:#666;padding:60px 20px;text-align:center}.empty-results-state h3{color:#333;font-size:1.5rem;margin-bottom:12px}.empty-results-state p{font-size:1rem;opacity:.8}.week-results.single-view{height:100%}.week-header{border-bottom:2px solid #e91e63;margin-bottom:24px;padding-bottom:16px}.week-header h4{color:#666;font-weight:500}.week-info{color:#666;font-size:.9rem}.first-week-indicator{color:#ff9800;font-weight:600}.ranking-item{grid-gap:24px;background:linear-gradient(135deg,#fafafa,#f8f9fa);border:2px solid #e9ecef;border-radius:16px;box-shadow:0 2px 8px #0000000a;gap:24px;grid-template-columns:120px 160px 1fr 120px;min-width:0;overflow:hidden;padding:24px;width:100%}.ranking-item:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.rank-position{max-width:120px;min-width:120px;width:120px}.rank-movement{text-align:center}.rank-movement.up{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.rank-movement.down{background:linear-gradient(135deg,#f44336,#ef5350);color:#fff}.rank-movement.same{background:linear-gradient(135deg,#9e9e9e,#bdbdbd);color:#fff}.rank-movement.new{background:linear-gradient(135deg,#2196f3,#42a5f5);color:#fff}.rank-movement.reappear{background:linear-gradient(135deg,#ff9800,#ffa726);color:#fff}.couple-images-section{max-width:160px;min-width:160px;width:160px}.couple-info{min-width:0;overflow:hidden}.couple-title{word-wrap:break-word;color:#2c3e50;font-size:1.4rem;-webkit-hyphens:auto;hyphens:auto;line-height:1.3;margin-bottom:8px;overflow-wrap:break-word}.couple-names{color:#667eea;font-size:1.1rem;margin-bottom:6px}.anime-title,.couple-names{word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;line-height:1.4;overflow-wrap:break-word}.anime-title{color:#7f8c8d;font-size:.95rem}.vote-count{justify-content:center;max-width:120px;min-width:120px;width:120px}.comparison-selectors{align-items:flex-start;display:flex;gap:16px}.comparison-column{flex:1 1}.comparison-column h4{color:#333;font-size:1rem;font-weight:600}.comparison-vs{color:#e91e63;margin-top:32px;min-width:40px}.comparison-results{height:100%}.comparison-header{border-bottom:2px solid #e91e63;padding-bottom:16px}.comparison-header h3{font-size:1.8rem;font-weight:700}.comparison-weeks{flex-wrap:wrap}.week-label{background:linear-gradient(135deg,#e91e63,#9c27b0);color:#fff;font-size:.9rem}.vs-text{color:#666}.comparison-rankings-list{display:flex;flex-direction:column;gap:16px}.comparison-ranking-item{background:linear-gradient(135deg,#fafafa,#f8f9fa);border:2px solid #e9ecef;padding:20px}.comparison-ranking-item:hover{border-color:#e91e63;box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.comparison-data{grid-gap:20px;gap:20px;margin-top:16px}.week-name{font-size:.9rem}.rank-info{align-items:center}.rank{font-size:1.5rem}.change-indicators{gap:8px;padding:0 16px}.rank-change,.vote-change{white-space:nowrap}.rank-up,.votes-up{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.rank-down,.votes-down{background:linear-gradient(135deg,#f44336,#ef5350);color:#fff}.rank-same,.votes-same{background:linear-gradient(135deg,#9e9e9e,#bdbdbd);color:#fff}.no-comparison-data{color:#666;font-style:italic;padding:40px 20px;text-align:center}.admin-tab-navigation{display:flex;gap:10px;justify-content:center;margin:20px 0;padding:0 20px}.admin-tab-button{align-items:center;background:#fff;border:2px solid #667eea;border-radius:12px;color:#667eea;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:8px;padding:12px 24px;transition:all .3s ease}.admin-tab-button:hover{background:#667eea1a;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.admin-tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 6px 16px #667eea4d;color:#fff;transform:translateY(-2px)}.admin-tab-content{min-height:400px}@media (min-width:769px){.ranking-item{display:grid!important;grid-template-columns:120px 160px 1fr 120px!important}.rank-position{max-width:120px!important;min-width:120px!important;width:120px!important}.couple-images-section{max-width:160px!important;min-width:160px!important;width:160px!important}.vote-count{max-width:120px!important;min-width:120px!important;width:120px!important}}@media (max-width:768px){.results-header{align-items:stretch;flex-direction:column;gap:20px}.results-header h2{min-width:auto;text-align:center}.refresh-button{align-self:center;width:-webkit-fit-content;width:fit-content}.content-layout{gap:20px;grid-template-columns:1fr}.main-controls{align-items:stretch;flex-direction:column}.action-controls,.view-mode-controls{justify-content:center}.comparison-selectors{flex-direction:column;gap:20px}.comparison-vs{margin-top:0;transform:rotate(90deg)}.comparison-data{gap:16px;grid-template-columns:1fr;text-align:center}.change-indicators{flex-direction:row;justify-content:center;padding:16px 0}}.ranking-item{gap:12px;grid-template-columns:1fr;margin:0 auto;max-width:100%;text-align:center}.rank-position{flex-direction:row}.couple-images-section,.rank-position{justify-content:center;margin:0 auto;width:-webkit-fit-content;width:fit-content}.couple-images-section{gap:10px}.week-char-image-wrapper{border-width:2px;height:50px;width:50px}.char-image-ranking{height:50px;width:50px}.week-button.active{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border-color:#4caf50;box-shadow:0 4px 16px #4caf504d}.week-title{color:#333;font-size:.95rem;font-weight:700;margin-bottom:4px}.week-subtitle{color:#666;font-size:.8rem;line-height:1.3;margin-bottom:4px}.week-stats{color:#e91e63;font-size:.75rem;font-weight:600}.week-results{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #e91e631a;border-radius:16px;box-shadow:0 6px 20px #e91e631f;padding:24px}.week-header{border-bottom:2px solid #e0e0e0;margin-bottom:30px;padding-bottom:20px;text-align:center}.week-header h3{color:#e91e63;font-size:1.8rem;font-weight:700;margin-bottom:8px}.week-header h4{color:#333;font-size:1.2rem;font-weight:600;margin-bottom:12px}.week-info{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.week-info span{background:linear-gradient(135deg,#fce4ec,#e1bee7);border-radius:16px;color:#4a148c;font-size:.85rem;font-weight:500;padding:6px 12px}.rankings-list{display:flex;flex-direction:column;gap:12px}.ranking-item{grid-gap:16px;align-items:center;background:linear-gradient(135deg,#fafafa,#f5f5f5);border:2px solid #e0e0e0;border-radius:12px;display:grid;gap:16px;grid-template-columns:120px 1fr auto;padding:16px 20px;transition:all .3s ease}.ranking-item:hover{background:linear-gradient(135deg,#fff,#fafafa);border-color:#e91e63;box-shadow:0 4px 16px #e91e6326;transform:translateY(-1px)}.ranking-item.rank-1{background:linear-gradient(135deg,#fff9c4,#fff59d);border-color:#ffa000}.ranking-item.rank-2{background:linear-gradient(135deg,#e8eaf6,#c5cae9);border-color:#5c6bc0}.ranking-item.rank-3{background:linear-gradient(135deg,#fce4ec,#f8bbd9);border-color:#f06292}.rank-position{align-items:center;display:flex;flex-direction:column;gap:8px}.rank-medal{color:#333;font-size:1.5rem;font-weight:700}.rank-movement{border-radius:8px;font-size:.75rem;font-weight:600;padding:2px 6px;white-space:nowrap}.rank-movement.up{background:linear-gradient(135deg,#e8f5e8,#c8e6c9);border:1px solid #4caf50;color:#2e7d32}.rank-movement.down{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:1px solid #f44336;color:#c62828}.rank-movement.same{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:1px solid #2196f3;color:#1565c0}.rank-movement.new{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:1px solid #ff9800;color:#e65100}.couple-info{text-align:left}.couple-title{line-height:1.2}.couple-names{color:#e91e63;font-size:.9rem;font-weight:600}.anime-title{color:#666}.vote-count{text-align:center}.votes{line-height:1}.votes-label{color:#666;font-size:.8rem;font-weight:500}.no-rankings{color:#666;font-style:italic;padding:40px 20px;text-align:center}.results-explanation{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;border-radius:12px;font-size:.95rem;line-height:1.5;margin-bottom:24px;padding:16px 20px}.results-explanation p{color:#1565c0;margin:8px 0}.results-explanation strong{color:#0d47a1;font-weight:600}.results-controls{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #dee2e6;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:24px;padding:16px 20px}.view-mode-controls{display:flex;gap:12px}.mode-button{background:#fff;border:2px solid #e91e63;border-radius:8px;color:#e91e63;cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 20px;transition:all .3s ease}.mode-button:hover{background:#fce4ec;transform:translateY(-2px)}.mode-button.active{background:#e91e63;color:#fff}.mode-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.export-button{background:linear-gradient(135deg,#4caf50,#388e3c);font-size:.9rem;font-weight:600;padding:10px 20px;transition:all .3s ease}.export-button:hover{box-shadow:0 4px 12px #4caf504d}.clear-all-button{align-items:center;background:linear-gradient(135deg,#dc3545,#c62828)!important;border:2px solid #dc3545!important;border-radius:8px;box-shadow:0 4px 12px #dc35454d;color:#fff!important;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;margin-left:10px!important;padding:12px 20px;transition:all .3s ease}.clear-all-button:hover{background:linear-gradient(135deg,#e53e3e,#d32f2f)!important;border-color:#e53e3e!important;box-shadow:0 6px 20px #dc354580;transform:translateY(-2px)}.clear-all-button:active{box-shadow:0 2px 8px #dc35454d;transform:translateY(0)}.clear-all-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.clear-all-button:disabled:hover{background:linear-gradient(135deg,#dc3545,#c62828)!important;box-shadow:0 4px 12px #dc35454d;transform:none}.comparison-selectors{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:1fr auto 1fr}.comparison-column h4{color:#e91e63;font-size:1.1rem;margin-bottom:12px;text-align:center}.comparison-vs{align-items:center;background:linear-gradient(135deg,#e91e63,#9c27b0);border-radius:50%;color:#fff;display:flex;font-size:1.2rem;font-weight:700;justify-content:center;margin-top:40px;min-height:60px;min-width:60px;padding:12px 20px}.comparison-results{background:#fff;border:2px solid #f0f0f0;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:24px}.comparison-header{margin-bottom:24px;text-align:center}.comparison-header h3{color:#e91e63;font-size:1.6rem;margin-bottom:12px}.comparison-weeks{align-items:center;display:flex;font-size:1.1rem;gap:16px;justify-content:center}.week-label{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:20px;color:#1565c0;font-weight:600;padding:8px 16px}.vs-text{color:#e91e63;font-size:1.2rem;font-weight:700}.comparison-ranking-item{grid-gap:20px;align-items:center;background:linear-gradient(135deg,#fafafa,#f5f5f5);border-left:4px solid #e91e63;border-radius:12px;display:grid;gap:20px;grid-template-columns:1fr 2fr;margin-bottom:12px;padding:16px 20px;transition:all .3s ease}.comparison-ranking-item:hover{box-shadow:0 4px 12px #e91e6326;transform:translateX(4px)}.comparison-data{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:1fr auto 1fr}.week-data{text-align:center}.week-name{color:#666;font-size:.85rem;font-weight:600;margin-bottom:8px}.rank-info{display:flex;flex-direction:column;gap:4px}.rank{font-size:1.2rem;font-weight:700}.votes{color:#666;font-size:.9rem}.not-ranked{color:#999;font-size:.9rem;font-style:italic}.change-indicators{align-items:center;display:flex;flex-direction:column;gap:6px;min-width:120px}.rank-change,.vote-change{border-radius:12px;font-size:.8rem;font-weight:600;padding:4px 8px;text-align:center}.rank-up{background:#e8f5e8;color:#2e7d32}.rank-down{background:#ffebee;color:#c62828}.rank-same{background:#f5f5f5;color:#666}.votes-up{background:#e8f5e8;color:#2e7d32}.votes-down{background:#ffebee;color:#c62828}.votes-same{background:#f5f5f5;color:#666}.mode-button.refresh-button{background:linear-gradient(135deg,#2196f3,#1976d2);border:none;color:#fff}.mode-button.refresh-button:hover{background:linear-gradient(135deg,#1976d2,#1565c0);transform:translateY(-2px)}.results-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:30px}.results-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e91e63,#9c27b0);background-clip:text;-webkit-background-clip:text;color:#e91e63;flex:1 1;font-size:2rem;font-weight:700;margin:0;min-width:250px}.header-controls{align-items:center;display:flex;gap:12px}.toggle-button{align-items:center;background:linear-gradient(135deg,#9e9e9e,#757575);border:none;border-radius:8px;box-shadow:0 4px 12px #9e9e9e4d;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s ease}.toggle-button.active{background:linear-gradient(135deg,#4caf50,#66bb6a);box-shadow:0 4px 12px #4caf504d}.toggle-button:hover{box-shadow:0 6px 20px #9e9e9e66;transform:translateY(-2px)}.toggle-button.active:hover{box-shadow:0 6px 20px #4caf5066}.refresh-button{align-items:center;background:linear-gradient(135deg,#e91e63,#9c27b0);border:none;border-radius:8px;box-shadow:0 4px 12px #e91e634d;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s ease}.refresh-button:hover{background:linear-gradient(135deg,#f50057,#8e24aa);box-shadow:0 6px 20px #e91e6366;transform:translateY(-2px)}.refresh-button:active{box-shadow:0 2px 8px #e91e634d;transform:translateY(0)}.refresh-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.refresh-button:disabled:hover{background:linear-gradient(135deg,#e91e63,#9c27b0);box-shadow:0 4px 12px #e91e634d;transform:none}.force-refresh-button{align-items:center;background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:8px;box-shadow:0 4px 12px #ff98004d;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;padding:12px 20px;transition:all .3s ease}.force-refresh-button:hover{background:linear-gradient(135deg,#fb8c00,#ef6c00);box-shadow:0 6px 20px #ff980066;transform:translateY(-2px)}.force-refresh-button:active{box-shadow:0 2px 8px #ff98004d;transform:translateY(0)}.force-refresh-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.force-refresh-button:disabled:hover{background:linear-gradient(135deg,#ff9800,#f57c00);box-shadow:0 4px 12px #ff98004d;transform:none}@media (max-width:1024px){.results-layout{gap:20px;grid-template-columns:1fr}.week-selector{position:static}.week-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.weekly-results-container{padding:16px}.weekly-results-container h2{font-size:1.6rem}.ranking-item{gap:12px;grid-template-columns:1fr;margin:0 auto;max-width:100%;text-align:center}.rank-position{flex-direction:row}.couple-images-section,.rank-position{justify-content:center;margin:0 auto;width:-webkit-fit-content;width:fit-content}.couple-images-section{gap:10px}.week-char-image-wrapper{border-width:2px;height:50px;width:50px}.char-image-ranking{height:50px;width:50px}.results-header{align-items:stretch;flex-direction:column;gap:20px}.results-header h2{min-width:auto;text-align:center}.refresh-button{align-self:center;width:-webkit-fit-content;width:fit-content}}@media (max-width:480px){.week-list{grid-template-columns:1fr}.ranking-item{margin:0 auto;max-width:100%;padding:12px 16px}.couple-images-section,.rank-position{margin:0 auto;width:-webkit-fit-content;width:fit-content}.couple-images-section{gap:8px}.week-char-image-wrapper{border-width:2px;height:45px;width:45px}.char-image-ranking{height:45px;width:45px}.couple-title{font-size:1rem}.votes{font-size:1.2rem}}.couple-images-section{align-items:center;display:flex;gap:12px}.week-char-image-wrapper{background-color:#f5f5f5;border:3px solid #e91e63;border-radius:50%;box-shadow:0 4px 12px #e91e6340;flex-shrink:0;height:55px;overflow:hidden;transition:all .3s ease;width:55px}.char-image-ranking{border-radius:50%;display:block;height:55px;object-fit:cover;object-position:center;transition:transform .3s ease;width:55px}.week-char-image-wrapper:hover{border-color:#ad1457;box-shadow:0 6px 16px #e91e6359;transform:scale(1.05)}.week-char-image-wrapper:hover .char-image-ranking{transform:scale(1.1)}.couple-divider{color:#e91e63;font-size:1.4rem;font-weight:700;margin:0 6px;text-shadow:0 1px 2px #0000001a}.couple-info{flex:1 1;min-width:200px}.couple-title{color:#333;font-size:1.1rem;font-weight:700;margin-bottom:4px}.couple-names{color:#666;font-size:.95rem;font-weight:500;margin-bottom:4px}.anime-title{color:#999;font-size:.85rem;font-style:italic;margin:0}.vote-count{align-items:center;display:flex;flex-direction:column;gap:2px;min-width:60px}.votes{color:#e91e63;font-size:1.4rem;font-weight:700}.votes-label{color:#999;font-size:.75rem;text-transform:uppercase}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f4f7f6;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;margin:0}.app-container{margin:0 auto;max-width:1200px;padding:20px}.app-header{border-bottom:2px solid #e0e0e0;margin-bottom:30px;padding-bottom:20px;text-align:center}.app-header h1{color:#d6336c;font-size:2.8em;margin-bottom:5px;text-shadow:1px 1px 2px #0000001a}.app-header p{color:#555;font-size:1.1em}.nav-links{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:20px}.nav-link{border:2px solid #0000;border-radius:25px;display:inline-block;font-size:1rem;font-weight:600;padding:12px 24px;text-decoration:none;transition:all .3s ease}.vote-nav{background:linear-gradient(135deg,#e91e63,#f06292);color:#fff}.vote-nav:hover{background:linear-gradient(135deg,#c2185b,#e91e63);box-shadow:0 4px 15px #e91e634d;transform:translateY(-2px)}.results-nav{background:linear-gradient(135deg,#ff9800,#ffb74d);color:#fff}.results-nav:hover{background:linear-gradient(135deg,#f57c00,#ff9800);box-shadow:0 4px 15px #ff98004d;transform:translateY(-2px)}.admin-nav{background:linear-gradient(135deg,#2196f3,#42a5f5);color:#fff}.admin-nav:hover{background:linear-gradient(135deg,#1976d2,#2196f3);box-shadow:0 4px 15px #2196f34d;transform:translateY(-2px)}@media (max-width:768px){.nav-links{align-items:center;flex-direction:column}.nav-link{text-align:center;width:200px}}.content-wrapper{display:flex;flex-wrap:wrap;gap:30px;justify-content:space-around;margin-bottom:5px}.export-button-container{margin-top:30px;text-align:center}.export-button{background-color:#4caf50;border:none;border-radius:8px;box-shadow:0 4px 6px #0000001a;color:#fff;cursor:pointer;font-size:1.1em;font-weight:700;padding:12px 25px;transition:background-color .3s ease,transform .2s ease}.export-button:hover{background-color:#45a049;transform:translateY(-2px)}.export-button:disabled{background-color:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.add-couple-form{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #00000014;margin-bottom:30px;padding:20px}.add-couple-form h3{color:#d6336c;margin-bottom:20px;margin-top:0;text-align:center}.add-couple-form div{display:flex;gap:10px;margin-bottom:15px}.add-couple-form input[type=text]{border:1px solid #ddd;border-radius:4px;flex-grow:1;font-size:1em;padding:10px}.add-couple-form input[type=text]:focus{border-color:#ff8fab;box-shadow:0 0 0 2px #d6336c33;outline:none}.add-couple-form button[type=submit]{background-color:#ff8fab;border:none;border-radius:4px;color:#fff;cursor:pointer;display:block;font-size:1em;font-weight:700;padding:10px 15px;transition:background-color .3s ease;width:100%}.add-couple-form button[type=submit]:hover{background-color:#f06292}.add-couple-form button[type=submit]:disabled{background-color:#e0e0e0;cursor:not-allowed}.error-message{background-color:#ffd2d2;border:1px solid #d8000c;border-radius:4px;color:#d8000c;margin-bottom:15px;padding:10px;text-align:center}.customization-section{background-color:#f9f9f9;border:1px solid #ddd;border-radius:8px;margin-bottom:30px;padding:20px}.apply-customization-button{background-color:#2dd454;border:none;border-radius:6px;color:#fff;cursor:pointer;display:block;font-family:Poppins,sans-serif;font-size:1em;font-weight:700;margin:20px auto 0;padding:10px 20px;transition:background-color .3s ease;width:auto}.apply-customization-button:hover{background-color:#218838}.clear-roster-button{background-color:#f23434;border:none;border-radius:6px;color:#fff;cursor:pointer;display:block;font-family:Poppins,sans-serif;font-size:1em;font-weight:700;margin:10px auto 40px;padding:10px;transition:background-color .3s ease;width:auto}.clear-roster-button:hover{background-color:#bc1518}.roster-actions-container{align-items:center;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;flex-direction:column;gap:15px;margin-bottom:30px;margin-top:20px;padding:20px}.roster-actions-container .clear-current-ranking-button,.roster-actions-container .clear-roster-button,.roster-actions-container .save-week-button{font-size:.95em;margin:0;min-width:220px;padding:10px 15px;width:auto}.roster-actions-container .save-week-button{background-color:#007bff;border:none;color:#fff}.roster-actions-container .save-week-button:hover{background-color:#0056b3}.roster-actions-container .save-week-button:disabled{background-color:#cce5ff;color:#004085;cursor:not-allowed}.roster-actions-container .clear-current-ranking-button{background-color:#dc3545;border:none;color:#fff}.roster-actions-container .clear-current-ranking-button:hover{background-color:#c82333}.roster-actions-container .clear-current-ranking-button:disabled{background-color:#f8d7da;color:#721c24;cursor:not-allowed}.generate-recap-button-container{border-top:1px solid #d0d8dd;margin-top:20px;padding-top:20px;text-align:center}.generate-recap-button-container .generate-recap-button{background-color:#ffc107;border:none;border-radius:6px;color:#212529;cursor:pointer;font-size:1.05em;font-weight:700;padding:12px 25px;transition:background-color .3s ease,transform .2s ease}.generate-recap-button-container .generate-recap-button:hover{background-color:#e0a800;transform:translateY(-1px)}.generate-recap-button-container .generate-recap-button:disabled{background-color:#fff3cd;color:#856404;cursor:not-allowed;transform:none}@media (max-width:600px){.app-header h1{font-size:2em}.add-couple-form div{flex-direction:column}}.save-recap-button:hover{background-color:#138496;transform:translateY(-1px)}.recap-couples-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:20px}.recap-couple-item{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;padding:15px}.recap-rank-badge{align-self:flex-start;color:#d6336c;font-size:1.2em;font-weight:700;margin-bottom:10px}.recap-couple-item .couple-card{margin-bottom:10px;width:100%}.recap-couple-details{color:#495057;font-size:.9em;text-align:center}.recap-couple-details p{margin:3px 0}.load-recap-to-main-button{background-color:#fd7e14;border:none;border-radius:6px;box-shadow:0 2px 4px #00000014;color:#fff;cursor:pointer;font-size:.95em;font-weight:700;margin-left:10px;padding:10px 18px;transition:background-color .3s ease,transform .2s ease}.load-recap-to-main-button:hover{background-color:#e66900;transform:translateY(-1px)}.mode-controls{border-bottom:1px solid #e0e0e0;margin-bottom:25px;padding-bottom:15px;text-align:center}.mode-controls button{background-color:#f0f0f0;border:2px solid #0000;border-radius:6px;color:#555;cursor:pointer;font-size:1.05em;font-weight:500;margin:0 8px;padding:10px 20px;transition:background-color .3s,border-color .3s,color .3s}.mode-controls button:hover{background-color:#e6e6e6;border-color:#ccc}.mode-controls button.active{background-color:#d6336c;border-color:#c0205a;color:#fff;font-weight:700}.seasonal-mode-container{background-color:#f0f3f5;border:1px solid #dde4e8;border-radius:8px;margin-top:20px;padding:20px}.seasonal-selectors{align-items:center;border-bottom:1px solid #d0d8dd;display:flex;gap:15px;margin-bottom:25px;padding-bottom:20px}.seasonal-selectors label{font-weight:500}.seasonal-selectors select{background-color:#fff;border:1px solid #c0c9d0;border-radius:5px;padding:8px 12px}.selected-season-label{color:#2a7a7a;font-weight:700;margin-left:10px}.contextual-export-view,.seasonal-normal-operation{border-radius:6px;margin-bottom:25px;padding:15px}.contextual-export-view{background-color:#e9ecef;border:1px solid #ced4da}.contextual-export-title{border-bottom:1px solid #adb5bd;color:#343a40;font-size:1.5em;margin-bottom:20px;margin-top:0;padding-bottom:15px;text-align:center}.minimal-customization .customization-controls-container{background-color:#f8f9fa;border-radius:6px;box-shadow:0 1px 3px #0000000d;padding:15px}.apply-palette-button{background-color:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;display:block;font-size:1em;margin:15px auto 10px;padding:10px 20px;transition:background-color .2s ease;width:auto}.apply-palette-button:hover{background-color:#0056b3}.ranking-table-container.fixed-ranking-for-export{background-color:#fff;border-radius:4px;margin-bottom:20px;margin-top:20px;padding:10px}.export-actions-contextual{border-top:1px solid #adb5bd;display:flex;gap:20px;justify-content:center;margin-top:25px;padding-top:20px}.exit-export-view-button{background-color:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1em;padding:10px 20px;transition:background-color .2s ease}.exit-export-view-button:hover{background-color:#545b62}.seasonal-normal-operation .seasonal-actions{border-bottom:1px solid #d0d8dd;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:25px;padding-bottom:20px}.seasonal-normal-operation .seasonal-actions button{border:none;border-radius:5px;cursor:pointer;font-size:.95em;font-weight:500;padding:10px 18px;transition:background-color .2s ease,transform .1s ease}.clear-current-ranking-button{background-color:#dc3545;color:#fff}.clear-current-ranking-button:hover{background-color:#c82333}.clear-current-ranking-button:disabled{background-color:#e9ecef;color:#6c757d;cursor:not-allowed}.past-weekly-rankings,.season-recap-display{border-top:1px solid #d0d8dd;margin-top:30px;padding-top:20px}.past-weekly-rankings h4,.season-recap-display h3{color:#495057;margin-bottom:15px}.past-weekly-rankings ul{list-style:none;padding-left:0}.past-weekly-rankings li{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:5px;box-shadow:0 1px 3px #0000000a;display:flex;justify-content:space-between;margin-bottom:10px;padding:12px 10px}.past-weekly-rankings li span{font-weight:500}.past-weekly-rankings li div button{border:1px solid #0000;border-radius:4px;cursor:pointer;font-size:.85em;margin-left:8px;min-width:100px;padding:5px 10px;text-align:center;transition:background-color .2s ease,transform .1s ease}.load-week-to-table-button{background-color:#5bc0de;border-color:#46b8da;color:#fff}.load-week-to-table-button:hover{background-color:#31b0d5;border-color:#269abc;transform:translateY(-1px)}.load-week-to-table-button:disabled{background-color:#a1d9e9;border-color:#89cddd;color:#777;cursor:not-allowed;transform:none}.load-week-button{background-color:#5cb85c;border-color:#4cae4c;color:#fff}.load-week-button:hover{background-color:#449d44;border-color:#398439;transform:translateY(-1px)}.load-week-button:disabled{background-color:#a3d9a3;border-color:#90d090;color:#777;cursor:not-allowed;transform:none}.delete-week-button{background-color:#d9534f;border-color:#d43f3a;color:#fff}.delete-week-button:hover{background-color:#c9302c;border-color:#ac2925;transform:translateY(-1px)}.delete-week-button:disabled{background-color:#eba8a6;border-color:#e59592;color:#777;cursor:not-allowed;transform:none}.season-recap-display .load-recap-to-main-button,.season-recap-display .save-recap-button{border:1px solid #0000;border-radius:5px;color:#fff;cursor:pointer;font-size:.9em;margin-top:10px;padding:8px 15px;transition:background-color .2s ease,transform .1s ease}.season-recap-display .save-recap-button{background-color:#007bff;border-color:#007bff}.season-recap-display .save-recap-button:hover{background-color:#0056b3;transform:translateY(-1px)}.season-recap-display .save-recap-button:disabled{background-color:#cce5ff;color:#004085;cursor:not-allowed;transform:none}.season-recap-display .load-recap-to-main-button{background-color:#fd7e14;border-color:#fd7e14;margin-left:10px}.season-recap-display .load-recap-to-main-button:hover{background-color:#e66900;transform:translateY(-1px)}.season-recap-display .load-recap-to-main-button:disabled{background-color:#ffc999;color:#8c4d00;cursor:not-allowed;transform:none}.developer-reset-button{background-color:#6f42c1;border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:700;padding:10px 20px;transition:background-color .2s ease}.developer-reset-button:hover{background-color:#5a32a3}.clear-generated-recap-button{background-color:#ffc107;border:1px solid #e0a800;border-radius:5px;color:#212529;cursor:pointer;font-size:.9em;margin-left:10px;margin-top:10px;padding:8px 15px;transition:background-color .2s ease,transform .1s ease}.clear-generated-recap-button:hover{background-color:#e0a800;border-color:#c69500;transform:translateY(-1px)}@media (max-width:900px){.content-wrapper{align-items:center;flex-direction:column}.ranking-table-container,.selection-roster-container{max-width:500px;width:90%}}
/*# sourceMappingURL=main.0a82b0f6.css.map*/