/* ---------- COLOURS ---------- */
:root{
    --pink:#ffd8e8;
    --lav:#e7d8ff;
    --mint:#ffffff;
    --border:#a6a6a6;
    --correct-bg:#c6ffcf;
    --correct-border:#46b34a;
}

/* ---------- PAGE ---------- */
html,body{margin:0;padding:0}
body{
    font-family:'Fredoka',system-ui,sans-serif;
    background:linear-gradient(135deg,var(--pink),var(--lav));
    min-height:100vh;
    display:flex;
    justify-content:center;
    padding:4rem 1rem 2rem;
    box-sizing:border-box;
}

/* ---------- SIDE IMAGE COLUMNS ---------- */
.side-col{
    position:absolute;        /* scrolls with page */
    top:0;
    width:180px;
    display:flex;
    flex-direction:column;
    gap:1.2rem;
    pointer-events:none;
    z-index:0;
}
.side-col.left  {left:1rem;}
.side-col.right {right:1rem;}

.side-col img{
    width:100%;
    height:160px;
    object-fit:cover;
    border-radius:12px;
    box-shadow:0 4px 10px rgba(0,0,0,.25);
    transform-origin:center;
}
/* alternating  +30°, –30° tilt */
.side-col img:nth-child(odd)  {transform:rotate(10deg);}
.side-col img:nth-child(even) {transform:rotate(-10deg);}

/* hide on narrow screens */
@media(max-width:900px){
    .side-col{display:none}
}

/* ---------- CARD ---------- */
.wrapper{
    width:100%;
    max-width:720px;
    background:#fff;
    border-radius:18px;
    padding:2rem 1.5rem;
    box-shadow:0 4px 12px rgba(0,0,0,.2);
    position:relative;
    z-index:1;
}

/* ---------- HEADINGS ---------- */
h1{
    margin:0 0 1rem;
    font-size:2rem;
    color:#5b2673;
    text-align:center;
}
h2{
    margin:1.8rem 0 .8rem;
    font-size:1.25rem;
    color:#5b2673;
}

/* ---------- CLUE LINE ---------- */
.clue{
    display:grid;
    grid-template-columns:1fr auto;
    gap:.6rem;
    align-items:center;
    margin:.4rem 0;
}
.clue label{font-size:1rem;color:#333}
.clue input{
    font-size:1rem;
    padding:.4rem .6rem;
    border:2px solid var(--border);
    border-radius:8px;
    background:var(--mint);
    min-width:130px;
    transition:background .2s,border-color .2s;
}
.clue input:focus{outline:none;border-color:#5b2673}
.clue input.correct{background:var(--correct-bg);border-color:var(--correct-border)}
.prefill{font-weight:600;font-size:1rem;white-space:nowrap}

/* ---------- FOOTER ---------- */
footer{
    margin-top:2.5rem;
    text-align:center;
    font-style:italic;
    font-size:1.1rem;
    color:#5b2673;
}

/* ---------- MOBILE STACK ---------- */
@media(max-width:500px){
    .clue{grid-template-columns:1fr}
    .clue input{width:100%}
}