/* ── Hero ── */
.combo-hero { padding:4rem 0 2.5rem; text-align:center; position:relative; }
.combo-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 70% 60% at 50% 0%,rgba(124,58,237,.07) 0%,transparent 70%); pointer-events:none; }
.hero-tag { font-family:'Cinzel',serif; font-size:.72rem; letter-spacing:.25em; text-transform:uppercase; color:var(--purple); margin-bottom:1rem; display:block; }
.hero-title { font-family:'Cinzel Decorative',serif; font-size:clamp(1.8rem,4vw,2.8rem); font-weight:700; color:var(--text); margin-bottom:.75rem; }
.hero-title .accent { color:var(--purple); }
.hero-sub { color:var(--muted); font-size:1rem; font-weight:300; max-width:560px; margin:0 auto; line-height:1.7; }

/* ── Selected cards bar ── */
.selected-bar { background:var(--bg2); border:1px solid var(--border); border-radius:14px; padding:1.25rem 1.5rem; margin-bottom:1.5rem; }
.selected-bar-title { font-family:'Cinzel',serif; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-bottom:1rem; }
.selected-chips { display:flex; flex-wrap:wrap; gap:.6rem; min-height:44px; align-items:center; }
.chip { display:flex; align-items:center; gap:.5rem; background:#fff; border:1px solid rgba(124,58,237,.3); border-radius:8px; padding:.4rem .7rem .4rem .6rem; font-family:'Cinzel',serif; font-size:.72rem; color:var(--text); }
.chip-img { width:28px; height:42px; object-fit:cover; border-radius:4px; flex-shrink:0; transition:transform .25s ease; }
.chip-img.reversed { transform:rotate(180deg); }
.chip-state { display:flex; gap:.2rem; }
.chip-state label { cursor:pointer; font-size:.6rem; padding:.15rem .4rem; border-radius:4px; border:1px solid var(--border); color:var(--muted); transition:all .15s; }
.chip-state input[type=radio] { display:none; }
.chip-state input[type=radio]:checked + label { background:rgba(124,58,237,.12); border-color:rgba(124,58,237,.5); color:var(--purple); }
.chip-remove { cursor:pointer; color:var(--muted); font-size:.85rem; line-height:1; padding:.1rem .2rem; border-radius:3px; transition:color .15s; }
.chip-remove:hover { color:#dc3545; }
.chip-empty { color:var(--muted); font-size:.82rem; font-style:italic; }

.find-btn { font-family:'Cinzel',serif; font-size:.8rem; letter-spacing:.1em; padding:.65rem 2rem; background:linear-gradient(135deg,#7c3aed,#9d4fd4); border:none; color:#fff; border-radius:9px; cursor:pointer; transition:opacity .2s; margin-top:1rem; }
.find-btn:hover { opacity:.88; }
.find-btn:disabled { opacity:.35; cursor:not-allowed; }
.limit-note { font-size:.72rem; color:var(--muted); margin-top:.5rem; }

/* ── Card grid ── */
.section-label { font-family:'Cinzel',serif; font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--purple); margin-bottom:.6rem; }
.suit-divider { display:flex; align-items:center; gap:.8rem; margin:1.5rem 0 .8rem; }
.suit-divider::before, .suit-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.suit-label { font-family:'Cinzel',serif; font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--purple); white-space:nowrap; }
.cards-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:.6rem; margin-bottom:1rem; }
.card-pick { background:#fff; border:1.5px solid var(--border); border-radius:10px; padding:.8rem .6rem .7rem; text-align:center; cursor:pointer; transition:all .18s; user-select:none; box-shadow:0 1px 3px rgba(124,58,237,.06); }
.card-pick:hover { border-color:rgba(124,58,237,.4); transform:translateY(-2px); box-shadow:0 4px 14px rgba(124,58,237,.1); }
.card-pick.selected { border-color:rgba(124,58,237,.65); background:var(--bg3); box-shadow:0 0 0 3px rgba(124,58,237,.12); }
.card-pick.disabled { opacity:.35; cursor:not-allowed; }
.card-pick .cp-icon { font-size:1.2rem; display:block; margin-bottom:.3rem; }
.card-pick .cp-num { font-family:'Cinzel',serif; font-size:.58rem; color:var(--muted); letter-spacing:.08em; margin-bottom:.2rem; }
.card-pick .cp-title { font-family:'Cinzel',serif; font-size:.65rem; color:var(--text-soft); line-height:1.3; }
.card-pick.selected .cp-title { color:var(--purple); }
.card-pick .cp-img { width:100%; aspect-ratio:2/3; object-fit:cover; border-radius:6px; margin-bottom:.35rem; display:block; }
.card-pick.selected .cp-img { box-shadow:0 0 0 2px rgba(124,58,237,.6); }

/* ── Results ── */
.result-wrap { background:#fff; border:1px solid var(--border); border-radius:16px; overflow:hidden; margin-bottom:3rem; box-shadow:0 2px 16px rgba(124,58,237,.07); }
.result-header { padding:2rem 2rem 1.5rem; border-bottom:1px solid var(--border); background:var(--bg2); }
.result-tag { font-family:'Cinzel',serif; font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:var(--purple); margin-bottom:.75rem; display:block; }
.result-title { font-family:'Cinzel Decorative',serif; font-size:clamp(1.1rem,2.5vw,1.6rem); color:var(--text); line-height:1.3; }
/* Mini card images in result header */
.result-images-row { display:flex; gap:.85rem; flex-wrap:wrap; margin:1.1rem 0 .85rem; }
.result-img-item { display:flex; flex-direction:column; align-items:center; gap:.3rem; }
.result-card-img { width:62px; aspect-ratio:2/3; object-fit:cover; border-radius:7px; box-shadow:0 3px 14px rgba(0,0,0,.18); border:1.5px solid rgba(124,58,237,.22); display:block; transition:box-shadow .2s; }
.result-card-img.reversed { transform:rotate(180deg); }
.result-card-placeholder { width:62px; height:93px; border-radius:7px; background:linear-gradient(155deg,#1d1050,#0d0826); border:1.5px solid rgba(124,58,237,.22); display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:rgba(192,132,252,.45); }
.result-card-placeholder.reversed { transform:rotate(180deg); }
.result-img-name { font-family:'Cinzel',serif; font-size:.52rem; letter-spacing:.05em; color:var(--muted); text-align:center; max-width:68px; line-height:1.35; }

.result-cards-row { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1rem; }
.result-card-badge { display:inline-flex; align-items:center; gap:.4rem; font-family:'Cinzel',serif; font-size:.68rem; padding:.3rem .75rem; border-radius:50px; }
.state-a { background:rgba(124,58,237,.1); border:1px solid rgba(124,58,237,.25); color:var(--purple); }
.state-u { background:rgba(76,175,80,.1); border:1px solid rgba(76,175,80,.3); color:#2e7d32; }
.state-r { background:rgba(239,108,0,.08); border:1px solid rgba(239,108,0,.25); color:#e65100; }

.combo-list { padding:1.5rem 2rem 2rem; }
.combo-list-title { font-family:'Cinzel',serif; font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:var(--muted); margin-bottom:1.25rem; }
.combo-item { display:flex; align-items:baseline; gap:.75rem; padding:.55rem 0; border-bottom:1px solid var(--border); font-size:.92rem; color:var(--text); font-weight:300; line-height:1.6; }
.combo-item:last-child { border-bottom:none; }
.combo-num { font-family:'Cinzel',serif; font-size:.62rem; color:var(--muted); min-width:22px; }
.combo-text { color:var(--text-soft); }
.combo-empty { color:var(--muted); font-style:italic; font-size:.9rem; padding:1rem 0; }

.share-row { display:flex; align-items:center; gap:.75rem; flex-wrap:wrap; margin-top:1.5rem; padding-top:1.25rem; border-top:1px solid var(--border); }
.share-label { font-family:'Cinzel',serif; font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.share-url { font-family:monospace; font-size:.78rem; color:var(--purple); background:rgba(124,58,237,.06); border:1px solid var(--border); border-radius:6px; padding:.3rem .75rem; }
.copy-btn { font-family:'Cinzel',serif; font-size:.68rem; letter-spacing:.08em; padding:.3rem .75rem; background:rgba(124,58,237,.08); border:1px solid var(--border); color:var(--purple); border-radius:6px; cursor:pointer; transition:all .2s; }
.copy-btn:hover { background:rgba(124,58,237,.15); }

/* ── User notes ── */
.notes-section { border-top:1px solid var(--border); padding:1.75rem 2rem 2rem; }
.notes-section-title { font-family:'Cinzel',serif; font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:var(--muted); margin-bottom:1.25rem; }
.note-card { background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:1rem 1.25rem; margin-bottom:.85rem; }
.note-card-own { border-color:rgba(124,58,237,.35); background:var(--bg3); }
.note-meta { display:flex; align-items:center; gap:.6rem; margin-bottom:.5rem; flex-wrap:wrap; }
.note-author { font-family:'Cinzel',serif; font-size:.68rem; color:var(--purple); }
.note-own-badge { font-family:'Cinzel',serif; font-size:.58rem; letter-spacing:.08em; text-transform:uppercase; color:var(--purple); background:rgba(124,58,237,.1); border:1px solid rgba(124,58,237,.25); border-radius:4px; padding:.1rem .4rem; }
.note-date { font-size:.65rem; color:var(--muted); }
.note-content { font-size:.88rem; color:var(--text-soft); line-height:1.7; white-space:pre-wrap; }
.note-form textarea { width:100%; background:#fff; border:1px solid var(--border); border-radius:8px; color:var(--text); font-family:'Raleway',sans-serif; font-size:.88rem; padding:.75rem 1rem; resize:vertical; min-height:90px; outline:none; transition:border-color .2s; }
.note-form textarea:focus { border-color:rgba(124,58,237,.5); }
.note-form textarea::placeholder { color:var(--muted); }
.note-form-actions { display:flex; gap:.6rem; margin-top:.6rem; align-items:center; flex-wrap:wrap; }
.note-save-btn { font-family:'Cinzel',serif; font-size:.68rem; letter-spacing:.08em; padding:.4rem 1.1rem; background:var(--purple); border:none; color:#fff; border-radius:7px; cursor:pointer; transition:opacity .2s; }
.note-save-btn:hover { opacity:.88; }
.note-delete-btn { font-family:'Cinzel',serif; font-size:.65rem; padding:.4rem .9rem; background:transparent; border:1px solid rgba(220,53,69,.3); color:#dc3545; border-radius:7px; cursor:pointer; transition:all .2s; }
.note-delete-btn:hover { background:rgba(220,53,69,.06); }
.note-hint { font-size:.82rem; color:var(--muted); font-style:italic; }
.note-hint a { color:var(--purple); text-decoration:none; }
.note-hint a:hover { text-decoration:underline; }
.note-public-hint { font-size:.68rem; color:var(--muted); display:flex; align-items:center; gap:.3rem; }

/* ── Voting ── */
.vote-bar { display:flex; align-items:center; gap:.35rem; margin-left:auto; }
.vote-btn { display:flex; align-items:center; justify-content:center; width:26px; height:26px; background:#fff; border:1px solid var(--border); border-radius:6px; color:var(--muted); font-size:.75rem; cursor:pointer; transition:all .18s; line-height:1; padding:0; }
.vote-btn:hover:not(:disabled) { border-color:rgba(124,58,237,.4); color:var(--purple); }
.vote-btn.active-up { border-color:rgba(76,175,80,.5); color:#2e7d32; background:rgba(76,175,80,.08); }
.vote-btn.active-down { border-color:rgba(230,81,0,.4); color:#e65100; background:rgba(230,81,0,.06); }
.vote-btn:disabled { opacity:.32; cursor:default; }
.vote-sum { font-family:'Cinzel',serif; font-size:.72rem; min-width:22px; text-align:center; color:var(--text); }
.vote-sum.positive { color:#2e7d32; }
.vote-sum.negative { color:#e65100; }

/* ── Footer ── */
.combo-footer-spacer { margin-top:4rem; }

@media (max-width:576px) { .cards-grid { grid-template-columns:repeat(auto-fill,minmax(90px,1fr)); } }
