.tcl{border:1px solid #e5e7eb;border-radius:14px;padding:16px;margin:16px 0;background:#fff}
.tcl .tcl-title{margin:0 0 6px 0;font-size:18px}
.tcl .tcl-lead{margin:0 0 12px 0;color:#4b5563;font-size:14px}
.tcl-stage{display:flex;flex-direction:column;gap:12px;align-items:center}
.tcl-btn{background:#111827;color:#fff;border:0;border-radius:12px;padding:10px 14px;font-size:14px;cursor:pointer}
.tcl-btn:hover{opacity:.92}
.tcl-card-slot,.tcl-card-grid{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.tcl-card{width:180px;max-width:42vw;aspect-ratio:3/5;perspective:900px}
.tcl-card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .55s ease}
.tcl-card.is-open .tcl-card-inner{transform:rotateY(180deg)}
.tcl-card-back,.tcl-card-front{position:absolute;inset:0;border-radius:16px;backface-visibility:hidden;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.12)}
.tcl-card-back{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#111827,#374151);color:#fff;font-size:42px}
.tcl-card-front{transform:rotateY(180deg);background:#fff;display:flex;flex-direction:column}
.tcl-card-front img{width:100%;height:70%;object-fit:cover}
.tcl-card-front.is-rev img{transform:rotate(180deg)}
.tcl-placeholder{width:100%;height:70%;display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:#6b7280;font-weight:700;letter-spacing:.12em}
.tcl-card-caption{padding:10px 10px 12px 10px;border-top:1px solid #eee}
.tcl-pos{font-size:12px;color:#6b7280}
.tcl-name{font-size:14px;font-weight:700;margin-top:2px}
.tcl-orient{font-size:12px;color:#374151;margin-top:4px}
.tcl-result{margin-top:10px;width:100%}
.tcl-meta{font-weight:700}
.tcl-result-text p{margin:6px 0 0 0;line-height:1.65}
.tcl-result-list{display:flex;flex-direction:column;gap:10px}
.tcl-row{border:1px solid #e5e7eb;border-radius:12px;padding:12px;display:flex;gap:12px}
.tcl-row-head{min-width:72px;font-weight:800;color:#111827}
.tcl-row-title{font-weight:800;margin-bottom:4px}
.tcl-row-text{color:#374151;line-height:1.65}
.tcl-error{color:#b91c1c;margin:0}
@media (max-width:520px){
  .tcl-card{width:150px}
  .tcl-row{flex-direction:column}
  .tcl-row-head{min-width:auto}
}
