*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
    --bg:#0f0f1a;
    --surface:#1a1a2e;
    --border:#2a2a44;
    --text:#e8e8f0;
    --text-dim:#8888aa;
    --accent:#f0c040;
    --good-good:#4ecca3;
    --good-bad:#f0c040;
    --bad-good:#7b68ee;
    --bad-bad:#e94560;
    --radius:10px;
}

html{font-size:16px}
body{
    background:var(--bg);
    color:var(--text);
    font-family:'Inter',system-ui,sans-serif;
    min-height:100vh;
    display:flex;
    flex-direction:column;
    align-items:center;
}

header{
    text-align:center;
    padding:1.5rem 1rem 0.5rem;
}
header h1{
    font-family:'Space Grotesk',sans-serif;
    font-size:2.4rem;
    letter-spacing:0.15em;
    font-weight:700;
}
.accent{color:var(--accent)}
.tagline{color:var(--text-dim);font-size:0.85rem;margin-top:0.2rem}
.quad-key{color:var(--text);font-size:0.8rem;margin-top:0.35rem;letter-spacing:0.12em;text-transform:uppercase;opacity:0.7}

/* ---- LEGEND ---- */
#legend{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:0.6rem;
    padding:0.6rem 1rem;
    max-width:520px;
    margin:0 auto;
}
.legend-axis{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:0.1rem;
}
.legend-axis.horiz{
    flex-direction:row;
    gap:0.3rem;
}
.legend-label{
    font-family:'Space Grotesk',sans-serif;
    font-size:0.55rem;
    letter-spacing:0.15em;
    color:var(--text-dim);
    opacity:0.7;
}
.legend-arrow{
    font-size:0.7rem;
    color:var(--text-dim);
    opacity:0.5;
}
.legend-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:3px;
    flex:1;
    max-width:360px;
}
.legend-cell{
    padding:0.35rem 0.5rem;
    border-radius:4px;
    text-align:center;
    line-height:1.3;
}
.lg-name{
    display:block;
    font-family:'Space Grotesk',sans-serif;
    font-size:0.65rem;
    font-weight:600;
    letter-spacing:0.05em;
}
.lg-desc{
    display:block;
    font-size:0.55rem;
    opacity:0.7;
}
.lg-gg{background:rgba(78,204,163,0.12);color:var(--good-good)}
.lg-gb{background:rgba(233,69,96,0.12);color:var(--good-bad)}
.lg-bg{background:rgba(245,166,35,0.12);color:var(--bad-good)}
.lg-bb{background:rgba(123,104,238,0.12);color:var(--bad-bad)}

/* ---- SEARCH ---- */
#search-wrap{
    position:relative;
    margin-bottom:0.8rem;
}
#movie-search{
    width:100%;
    padding:0.6rem 0.8rem;
    border:1px solid var(--border);
    border-radius:var(--radius);
    background:var(--surface);
    color:var(--text);
    font-size:0.9rem;
    font-family:inherit;
}
#movie-search:focus{
    outline:none;
    border-color:var(--accent);
}
#movie-search::placeholder{color:var(--text-dim)}
#search-results{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    z-index:50;
    max-height:260px;
    overflow-y:auto;
    background:var(--surface);
    border:1px solid var(--border);
    border-top:none;
    border-radius:0 0 var(--radius) var(--radius);
    box-shadow:0 8px 24px rgba(0,0,0,0.4);
}
#search-results.hidden{display:none}
.search-item{
    display:flex;
    align-items:center;
    gap:0.6rem;
    padding:0.5rem 0.8rem;
    cursor:pointer;
    border-bottom:1px solid var(--border);
    transition:background 0.12s;
}
.search-item:last-child{border-bottom:none}
.search-item:hover{background:rgba(240,192,64,0.08)}
.search-item .si-poster{
    width:28px;
    height:42px;
    border-radius:3px;
    object-fit:cover;
    flex-shrink:0;
}
.search-item .si-placeholder{
    width:28px;
    height:42px;
    border-radius:3px;
    flex-shrink:0;
    background:var(--bg);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:0.65rem;
    font-weight:600;
    color:var(--text-dim);
}
.search-item .si-info{flex:1;min-width:0}
.search-item .si-title{
    font-size:0.85rem;
    font-weight:500;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    display:block;
}
.search-item .si-meta{
    font-size:0.7rem;
    color:var(--text-dim);
}
.search-item .si-dot{
    width:8px;
    height:8px;
    border-radius:50%;
    flex-shrink:0;
}
.search-empty{
    padding:0.8rem;
    text-align:center;
    font-size:0.8rem;
    color:var(--text-dim);
}
.sr-section-label{
    padding:0.4rem 0.8rem 0.2rem;
    font-size:0.65rem;
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:0.08em;
    color:var(--text-dim);
    opacity:0.7;
}
.sr-action{
    flex-shrink:0;
    font-size:0.7rem;
    font-weight:600;
    padding:0.25rem 0.6rem;
    border-radius:4px;
    text-transform:uppercase;
    letter-spacing:0.04em;
}
.sr-vote{
    border:1px solid;
    color:var(--text);
    background:transparent;
}
.sr-add{
    background:var(--accent);
    color:var(--bg);
    border:none;
}

main{
    width:100%;
    max-width:1100px;
    display:flex;
    flex-wrap:wrap;
    gap:1.5rem;
    padding:1rem;
    justify-content:center;
    align-items:flex-start;
}

/* ---- GRID ---- */
#grid-wrap{
    position:relative;
    width:min(600px, 92vw);
    aspect-ratio:1;
    flex-shrink:0;
}
#quad-grid{
    width:100%;
    height:100%;
    border-radius:var(--radius);
    cursor:crosshair;
}

.quadrant-label{
    position:absolute;
    font-family:'Space Grotesk',sans-serif;
    font-size:0.7rem;
    font-weight:600;
    letter-spacing:0.08em;
    text-transform:uppercase;
    pointer-events:none;
    opacity:0.55;
    line-height:1.4;
}
.quadrant-label span{
    display:block;
    font-family:'Inter',sans-serif;
    font-weight:400;
    font-size:0.6rem;
    letter-spacing:0.02em;
    text-transform:none;
    opacity:0.7;
}
.ql-tl{top:8px;left:12px;color:var(--good-bad)}
.ql-tr{top:8px;right:12px;text-align:right;color:var(--good-good)}
.ql-bl{bottom:8px;left:12px;color:var(--bad-bad)}
.ql-br{bottom:8px;right:12px;text-align:right;color:var(--bad-good)}

.axis-label{
    position:absolute;
    font-family:'Space Grotesk',sans-serif;
    font-size:0.55rem;
    letter-spacing:0.35em;
    text-transform:uppercase;
    color:var(--text-dim);
    pointer-events:none;
    opacity:0.5;
}
.axis-quality{
    left:-1.2rem;
    top:50%;
    transform:rotate(-90deg) translateX(-50%);
    transform-origin:0 0;
}
.axis-enjoy{
    bottom:-1.1rem;
    left:50%;
    transform:translateX(-50%);
}

/* ---- MOVIE PANEL ---- */
#movie-panel{
    flex:1;
    min-width:280px;
    max-width:380px;
    display:flex;
    flex-direction:column;
    gap:1rem;
}

#movie-card{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:1.2rem;
}
#movie-card-inner{
    display:flex;
    gap:1rem;
    align-items:flex-start;
}
#poster-wrap{
    flex-shrink:0;
    width:90px;
    height:135px;
    border-radius:6px;
    overflow:hidden;
    position:relative;
    background:var(--bg);
}
#movie-poster{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}
#movie-poster.hidden{display:none}
#poster-placeholder{
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    background:linear-gradient(135deg, #2a2a44 0%, #1a1a2e 100%);
}
#poster-placeholder.hidden{display:none}
#poster-letter{
    font-family:'Space Grotesk',sans-serif;
    font-size:2.2rem;
    font-weight:700;
    color:var(--accent);
    opacity:0.5;
}
#movie-info{flex:1;min-width:0}
#movie-title{
    font-family:'Space Grotesk',sans-serif;
    font-size:1.4rem;
    font-weight:700;
    line-height:1.2;
}
#movie-year{
    color:var(--text-dim);
    font-size:0.85rem;
    margin-top:0.2rem;
}
#movie-scores{
    display:flex;
    gap:0.6rem;
    margin-top:0.8rem;
    flex-wrap:wrap;
}
.score-badge{
    font-size:0.75rem;
    padding:0.3rem 0.6rem;
    border-radius:6px;
    background:rgba(255,255,255,0.06);
}
.score-badge strong{font-weight:600}
.quality-badge strong{color:var(--accent)}
.enjoy-badge strong{color:var(--good-good)}
#vote-count-text{
    font-size:0.75rem;
    color:var(--text-dim);
    margin-top:0.5rem;
}

/* ---- VOTE CONTROLS ---- */
#vote-section{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:1.2rem;
    text-align:center;
}
#vote-prompt{
    font-size:0.9rem;
    margin-bottom:1rem;
    color:var(--text-dim);
}
#vote-controls{
    display:flex;
    justify-content:center;
    gap:2rem;
    margin-bottom:1rem;
}
.vote-group{text-align:center}
.vote-group label{
    display:block;
    font-size:0.7rem;
    text-transform:uppercase;
    letter-spacing:0.1em;
    color:var(--text-dim);
    margin-bottom:0.4rem;
}
.arrow-pair{display:flex;gap:0.4rem}
.arrow-pair.vertical{flex-direction:column}

.arrow-btn{
    width:52px;
    height:52px;
    border:2px solid var(--border);
    border-radius:var(--radius);
    background:transparent;
    color:var(--text);
    font-size:1.3rem;
    cursor:pointer;
    transition:all 0.15s;
    display:flex;
    align-items:center;
    justify-content:center;
}
.arrow-btn:hover{
    border-color:var(--accent);
    background:rgba(240,192,64,0.08);
}
.arrow-btn.selected{
    border-color:var(--accent);
    background:rgba(240,192,64,0.2);
    color:var(--accent);
    box-shadow:0 0 12px rgba(240,192,64,0.15);
}

#submit-vote{
    width:100%;
    padding:0.75rem;
    border:none;
    border-radius:var(--radius);
    background:var(--accent);
    color:#111;
    font-family:'Space Grotesk',sans-serif;
    font-size:0.95rem;
    font-weight:700;
    letter-spacing:0.05em;
    cursor:pointer;
    transition:all 0.2s;
}
#submit-vote:disabled{
    opacity:0.3;
    cursor:not-allowed;
}
#submit-vote:not(:disabled):hover{
    background:#ffd966;
    transform:translateY(-1px);
}

#skip-btn{
    margin-top:0.5rem;
    background:none;
    border:none;
    color:var(--text-dim);
    font-size:0.8rem;
    cursor:pointer;
    text-decoration:underline;
    text-underline-offset:2px;
}
#skip-btn:hover{color:var(--text)}

#already-voted{
    color:var(--accent);
    font-size:0.8rem;
    margin-top:0.5rem;
}

#add-movie-btn{
    width:100%;
    padding:0.7rem;
    border:2px dashed var(--border);
    border-radius:var(--radius);
    background:transparent;
    color:var(--text-dim);
    font-family:'Space Grotesk',sans-serif;
    font-size:0.9rem;
    font-weight:600;
    cursor:pointer;
    transition:all 0.2s;
}
#add-movie-btn:hover{
    border-color:var(--accent);
    color:var(--accent);
}

/* ---- MODAL ---- */
.modal{
    position:fixed;
    inset:0;
    z-index:100;
    display:flex;
    align-items:center;
    justify-content:center;
    background:rgba(0,0,0,0.7);
    backdrop-filter:blur(4px);
}
.modal.hidden{display:none}
.modal-content{
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:var(--radius);
    padding:1.5rem;
    width:min(440px,92vw);
    max-height:90vh;
    overflow-y:auto;
    position:relative;
}
.modal-close{
    position:absolute;
    top:0.8rem;right:0.8rem;
    background:none;border:none;
    color:var(--text-dim);font-size:1.5rem;
    cursor:pointer;
}
.modal-close:hover{color:var(--text)}
.modal-content h2{
    font-family:'Space Grotesk',sans-serif;
    font-size:1.3rem;
    margin-bottom:1rem;
}
.form-group{margin-bottom:1rem}
.form-group>label{
    display:block;
    font-size:0.8rem;
    color:var(--text-dim);
    margin-bottom:0.3rem;
}
.form-group input[type="text"],
.form-group input[type="number"]{
    width:100%;
    padding:0.6rem 0.8rem;
    border:1px solid var(--border);
    border-radius:6px;
    background:var(--bg);
    color:var(--text);
    font-size:0.95rem;
    font-family:inherit;
}
.form-group input:focus{
    outline:none;
    border-color:var(--accent);
}

#mini-grid-wrap{
    width:100%;
    max-width:280px;
    aspect-ratio:1;
    margin:0.8rem auto;
}
#mini-grid{
    width:100%;
    height:100%;
    border-radius:6px;
    cursor:crosshair;
}

.slider-row{
    display:flex;
    align-items:center;
    gap:0.6rem;
    margin-top:0.5rem;
    font-size:0.8rem;
}
.slider-row label{
    min-width:130px;
    color:var(--text-dim);
}
.slider-row label strong{color:var(--accent)}
.slider-row input[type="range"]{
    flex:1;
    accent-color:var(--accent);
}

/* TMDb search */
#tmdb-results{
    max-height:220px;
    overflow-y:auto;
    border:1px solid var(--border);
    border-radius:6px;
    margin-top:0.4rem;
    background:var(--bg);
}
.tmdb-item{
    display:flex;
    align-items:center;
    gap:0.6rem;
    padding:0.5rem 0.6rem;
    cursor:pointer;
    border-bottom:1px solid var(--border);
    transition:background 0.12s;
}
.tmdb-item:last-child{border-bottom:none}
.tmdb-item:hover{background:rgba(255,255,255,0.04)}
.tmdb-thumb{
    width:34px;
    height:50px;
    border-radius:3px;
    object-fit:cover;
    flex-shrink:0;
    background:var(--surface);
}
.tmdb-no-thumb{
    width:34px;
    height:50px;
    border-radius:3px;
    flex-shrink:0;
    background:var(--surface);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:0.7rem;
    color:var(--text-dim);
}
.tmdb-meta{flex:1;min-width:0}
.tmdb-meta strong{
    display:block;
    font-size:0.85rem;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.tmdb-meta span{font-size:0.7rem;color:var(--text-dim)}

#selected-movie-preview{
    display:flex;
    align-items:center;
    gap:0.8rem;
    padding:0.7rem;
    background:rgba(240,192,64,0.08);
    border:1px solid rgba(240,192,64,0.25);
    border-radius:6px;
    margin-bottom:1rem;
}
#selected-movie-preview.hidden{display:none}
#sel-poster{
    width:40px;
    height:60px;
    border-radius:3px;
    object-fit:cover;
    flex-shrink:0;
}
#sel-info{flex:1;min-width:0}
#sel-info strong{
    display:block;
    font-size:0.9rem;
}
#sel-info span{font-size:0.75rem;color:var(--text-dim)}
#sel-clear{
    background:none;
    border:none;
    color:var(--text-dim);
    font-size:1.2rem;
    cursor:pointer;
    padding:0 0.3rem;
}
#sel-clear:hover{color:var(--text)}

.link-btn{
    background:none;
    border:none;
    color:var(--text-dim);
    font-size:0.8rem;
    cursor:pointer;
    text-decoration:underline;
    text-underline-offset:2px;
    margin-bottom:1rem;
    display:block;
}
.link-btn:hover{color:var(--text)}
.manual-note{
    font-size:0.75rem;
    color:var(--text-dim);
    margin-bottom:0.5rem;
}

#add-submit{
    width:100%;
    padding:0.7rem;
    border:none;
    border-radius:var(--radius);
    background:var(--accent);
    color:#111;
    font-family:'Space Grotesk',sans-serif;
    font-size:0.95rem;
    font-weight:700;
    cursor:pointer;
    transition:all 0.2s;
}
#add-submit:hover{background:#ffd966}
.error-text{color:var(--good-bad);font-size:0.8rem;margin-top:0.5rem}
.error-text.hidden{display:none}

/* ---- TOOLTIP ---- */
#tooltip{
    position:fixed;
    z-index:90;
    background:var(--surface);
    border:1px solid var(--border);
    border-radius:6px;
    padding:0.5rem 0.7rem;
    font-size:0.8rem;
    pointer-events:none;
    white-space:nowrap;
    box-shadow:0 4px 16px rgba(0,0,0,0.4);
    line-height:1.4;
}
#tooltip.hidden{display:none}
#tooltip .tip-title{font-weight:600}
#tooltip .tip-year{color:var(--text-dim);font-size:0.7rem}
#tooltip .tip-scores{font-size:0.7rem;color:var(--text-dim);margin-top:2px}

/* ---- FOOTER ---- */
footer{
    text-align:center;
    padding:2rem 1rem;
    font-size:0.75rem;
    color:var(--text-dim);
}
footer em{color:var(--accent);font-style:normal}
footer a{color:var(--accent);text-decoration:none}
footer a:hover{text-decoration:underline}

/* ---- DOT ANIMATIONS ---- */
.movie-dot{transition:cx 0.5s ease, cy 0.5s ease}
.movie-dot.highlight{filter:drop-shadow(0 0 8px var(--accent))}

.hidden{display:none!important}

/* ---- RESPONSIVE ---- */
@media(max-width:740px){
    main{flex-direction:column;align-items:center}
    #movie-panel{max-width:100%;min-width:0;width:min(600px,92vw)}
    header h1{font-size:1.8rem}
    .arrow-btn{width:46px;height:46px;font-size:1.1rem}
}
