.ranking-page-wrapper{max-width:1200px;margin:0 auto;padding:2rem 1rem;color:#fff}.ranking-hero-section{text-align:center;margin-bottom:2rem}.ranking-page-title{font-size:2.2rem;background:linear-gradient(90deg,#00f0ff,#007bff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:1rem}.ranking-explanation-box{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:1rem;max-width:800px;margin:0 auto 1.5rem;font-size:.85rem;color:#ddd;line-height:1.6}.formula-hint{display:block;margin-top:.5rem;color:#888}.ranking-actions-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.sort-control{display:flex;align-items:center;gap:.5rem;color:#ccc;font-size:.9rem}.sort-select{background:#2a2a2a;color:#fff;border:1px solid #444;padding:.4rem .8rem;border-radius:6px;outline:none;cursor:pointer}.compact-movie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.compact-movie-card{background:#1a1a1a;border:1px solid #333;border-radius:10px;overflow:hidden;position:relative;display:flex;flex-direction:column;transition:transform .2s,border-color .2s}.compact-movie-card:hover{transform:translateY(-4px);border-color:#555;box-shadow:0 8px 20px #00000080}.rank-badge{position:absolute;top:0;left:0;padding:6px 12px;font-weight:700;font-size:1.1rem;z-index:2;border-bottom-right-radius:10px;box-shadow:2px 2px 5px #0000004d}.rank-badge.gold{background:linear-gradient(135deg,gold,#daa520);color:#000}.rank-badge.silver{background:linear-gradient(135deg,#e0e0e0,#999);color:#000}.rank-badge.bronze{background:linear-gradient(135deg,#cd7f32,#8b4513);color:#fff}.rank-badge.normal{background:#000000b3;color:#fff;font-size:.9rem}.poster-container{width:100%;aspect-ratio:2 / 3;background-color:#222;border-bottom:1px solid #333}.compact-movie-poster{width:100%;height:100%;object-fit:cover;display:block}.no-poster-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#666;font-size:.9rem}.compact-movie-info{padding:12px;display:flex;flex-direction:column;flex:1}.compact-movie-title{font-size:1rem;margin:0 0 8px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.movie-meta-tags{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.meta-year{font-size:.8rem;color:#aaa}.meta-score-label{font-size:.75rem;background:#00f0ff1a;color:#00f0ff;padding:2px 6px;border-radius:4px;border:1px solid rgba(0,240,255,.3)}.meta-score-value{font-size:.9rem;font-weight:700}.movie-stats-row{display:flex;justify-content:space-between;font-size:.8rem;color:#bbb;margin-bottom:10px}.compact-movie-overview{font-size:.8rem;color:#999;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}@media (max-width: 600px){.compact-movie-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}}.ranking-loading-screen{text-align:center;padding:4rem 0;color:#aaa}.ranking-spinner{width:50px;height:50px;border:4px solid #333;border-top-color:#00f0ff;border-radius:50%;animation:ranking-spin 1s linear infinite;margin:0 auto 1rem}@keyframes ranking-spin{to{transform:rotate(360deg)}}.diagnosis-container{max-width:800px;margin:0 auto;padding:2rem 1rem;color:#fff;background:#121212}.diagnosis-header{text-align:center;margin-bottom:2rem}.diagnosis-header h1{font-size:2.5rem;background:linear-gradient(90deg,#ff8a00,#e52e71);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.diagnosis-form-card{background:#1e1e1e;border-radius:12px;padding:2rem;box-shadow:0 8px 24px #0000004d}.step-indicator{color:#888;font-size:.9rem;margin-bottom:1rem}.question-title{font-size:1.5rem;margin-bottom:1.5rem}.options-container{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem}.option-btn{background:#2a2a2a;border:2px solid #333;color:#fff;padding:.8rem 1.5rem;border-radius:20px;cursor:pointer;transition:all .2s;font-size:1rem}.option-btn:hover{background:#333}.option-btn.selected{background:#e52e7133;border-color:#e52e71;color:#e52e71}.free-text-input{width:100%;background:#2a2a2a;border:1px solid #444;color:#fff;padding:1rem;border-radius:8px;resize:vertical}.form-actions{display:flex;justify-content:flex-end;gap:1rem}.btn-primary,.btn-secondary,.diagnosis-action-btn{padding:.8rem 2rem;border-radius:8px;font-weight:700;cursor:pointer;border:none;text-decoration:none;display:inline-block}.btn-primary,.diagnosis-action-btn{background:linear-gradient(90deg,#ff8a00,#e52e71);color:#fff}.btn-secondary{background:#333;color:#fff}.loading-screen{text-align:center;padding:4rem 0}.spinner{width:50px;height:50px;border:4px solid #333;border-top-color:#e52e71;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.diagnosis-movie-card{display:flex;background:#1e1e1e;border-radius:12px;margin-bottom:1.5rem;position:relative;overflow:hidden}.rank-badge{position:absolute;top:0;left:0;background:#e52e71;color:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;border-bottom-right-radius:12px}.movie-poster{width:150px;object-fit:cover}.movie-info{padding:1.5rem;flex:1}.movie-info h3{margin:0 0 .5rem}.rating{color:#ff8a00;font-weight:700;margin-bottom:1rem}.reasons-box{background:#ffffff0d;padding:1rem;border-radius:8px;margin-bottom:1rem}.reasons-box h4{margin:0 0 .5rem;font-size:.9rem;color:#aaa}.caution-box{color:#fa0;font-size:.9rem;margin-bottom:1rem}.tag-badge{display:inline-block;background:#333;color:#ccc;padding:.2rem .6rem;border-radius:4px;font-size:.8rem;margin-right:.5rem}@media (max-width: 600px){.diagnosis-movie-card{flex-direction:column}.movie-poster{width:100%;height:250px}}:root{--bg-color: #050510;--text-main: #ffffff;--text-muted: #a0a0b0;--accent-gold: #ffd700;--accent-cyan: #00f0ff;--card-bg: rgba(255, 255, 255, .05);--card-border: rgba(255, 255, 255, .1);--error-bg: rgba(255, 50, 50, .2);--error-border: rgba(255, 50, 50, .5);--rank-1: linear-gradient(135deg, #ffd700, #ff8c00);--rank-2: linear-gradient(135deg, #e0e0e0, #808080);--rank-3: linear-gradient(135deg, #cd7f32, #8b4513)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,sans-serif;background-color:var(--bg-color);background-image:radial-gradient(circle at 15% 50%,rgba(0,240,255,.05),transparent 25%),radial-gradient(circle at 85% 30%,rgba(255,215,0,.05),transparent 25%);color:var(--text-main);line-height:1.6;min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:2rem 1rem}.header{text-align:center;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:1px solid var(--card-border);position:relative}.header h1{font-size:3rem;font-weight:800;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem;letter-spacing:2px}.header p{color:var(--text-muted);font-size:1.1rem}.controls{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.info-text{font-size:.9rem;color:var(--text-muted);background:var(--card-bg);padding:.4rem 1rem;border-radius:20px;border:1px solid var(--card-border)}.refresh-btn{background:transparent;color:var(--accent-cyan);border:1px solid var(--accent-cyan);padding:.5rem 1.5rem;border-radius:20px;cursor:pointer;font-weight:700;transition:all .3s ease}.refresh-btn:hover:not(:disabled){background:var(--accent-cyan);color:var(--bg-color);box-shadow:0 0 10px #00f0ff80}.refresh-btn:disabled{opacity:.5;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted)}.update-indicator{position:fixed;top:0;left:0;width:100%;background:#00f0ff33;color:var(--accent-cyan);text-align:center;padding:.5rem;font-size:.9rem;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:pulse 1.5s infinite}@keyframes pulse{0%{opacity:.8}50%{opacity:.4}to{opacity:.8}}.error-banner{background:var(--error-bg);border:1px solid var(--error-border);color:#ff8080;padding:1rem;border-radius:8px;margin-bottom:2rem;text-align:center}.movie-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:2rem}@media (min-width: 768px){.movie-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1024px){.movie-grid{grid-template-columns:repeat(3,1fr)}}.movie-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:transform .3s ease,box-shadow .3s ease;position:relative;display:flex;flex-direction:column}.movie-card:hover{transform:translateY(-5px);box-shadow:0 10px 20px #00000080;border-color:#ffffff4d}.rank-badge{position:absolute;top:10px;left:10px;background:#000000b3;color:#fff;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:1.2rem;font-weight:700;z-index:2;border:2px solid var(--text-muted)}.rank-1 .rank-badge{background:var(--rank-1);border:none;color:#000;width:50px;height:50px;font-size:1.5rem}.rank-2 .rank-badge{background:var(--rank-2);border:none;color:#000}.rank-3 .rank-badge{background:var(--rank-3);border:none;color:#fff}.rank-1{transform:scale(1.02);border-color:#ffd7004d;box-shadow:0 0 15px #ffd7001a}.poster-wrapper{position:relative;width:100%;padding-top:150%;background:#2a2a35;overflow:hidden}.poster-img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.movie-card:hover .poster-img{transform:scale(1.05)}.placeholder-img{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-muted)}.card-content{padding:1.5rem;flex-grow:1;display:flex;flex-direction:column}.movie-title{font-size:1.2rem;font-weight:700;margin-bottom:.5rem;line-height:1.3}.movie-meta{display:flex;justify-content:space-between;color:var(--text-muted);font-size:.9rem;margin-bottom:1rem}.score{color:var(--accent-gold);font-weight:700}.movie-overview{font-size:.9rem;color:#ccc;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:1.5rem;flex-grow:1}.detail-btn{width:100%;padding:.8rem;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;transition:background .2s ease;font-weight:700}.detail-btn:hover{background:#fff3}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.modal-content{background:#1a1a24;border:1px solid var(--card-border);border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;padding:2rem;box-shadow:0 20px 40px #00000080}.close-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer}.close-btn:hover{color:#fff}.modal-header{margin-bottom:1.5rem}.modal-title{font-size:1.8rem;margin-bottom:.5rem;color:var(--accent-cyan)}.modal-stats{display:flex;gap:1rem;color:var(--text-muted);font-size:.9rem;background:var(--card-bg);padding:.5rem;border-radius:8px}.modal-body{line-height:1.8}.skeleton{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;height:450px;position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);animation:loading 1.5s infinite}@keyframes loading{to{left:100%}}
