:root{font-family:Inter,Pretendard,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;background:#f8fafc;color:#0f172a;min-width:320px;min-height:100vh}#root{min-height:100vh}#root{background-color:#334155}.app-shell{max-width:840px;margin:0 auto;padding:40px 20px}.app-header{margin-bottom:20px}.app-header h1{margin:0;font-size:32px}.app-header p{margin-top:8px;color:#475569}.search-form{display:flex;gap:8px}.search-input{flex:1;border:1px solid #cbd5e1;border-radius:10px;padding:10px 12px;font-size:15px}.search-input:focus{outline:2px solid #93c5fd;border-color:#60a5fa}.search-button{border:0;border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600;background:#2563eb;color:#fff}.search-button:disabled{opacity:.6}.recent-searches{margin-top:12px}.recent-searches-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.recent-searches-header strong{font-size:14px;color:#475569}.recent-clear-button{border:0;background:transparent;color:#64748b;font-size:13px;cursor:pointer;padding:4px 0}.recent-clear-button:hover{color:#334155}.recent-searches-list{display:flex;flex-wrap:wrap;gap:8px}.recent-item-button{border:1px solid #cbd5e1;border-radius:999px;background:#fff;padding:6px 10px;font-size:13px;color:#0f172a}.recent-item-button:hover{border-color:#93c5fd}.favorite-section{margin-top:18px}.favorite-title{margin:0 0 10px;color:#334155;font-size:14px;font-weight:700}.result-empty{margin-top:16px;color:#64748b}.result-error{margin-top:16px;color:#dc2626;font-weight:500}.result-section{margin-top:16px}.result-count{margin:0 0 10px;color:#475569;font-size:14px}.character-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.character-card{border:1px solid #e2e8f0;border-radius:12px;padding:14px;background:#fff}.character-card.is-clickable{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.character-card.is-clickable:hover{transform:translateY(-2px);border-color:#93c5fd;box-shadow:0 8px 20px #0f172a14}.character-card.is-clickable:focus-visible{outline:2px solid #60a5fa;outline-offset:2px}.character-card-header{margin-bottom:10px}.character-card-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.character-card-header h3{margin:0;font-size:17px}.character-card-header span{display:inline-block;margin-top:4px;color:#475569;font-size:13px}.favorite-button{border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#64748b;width:32px;height:28px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.favorite-button.is-active{color:#d97706;border-color:#f59e0b;background:#fffbeb}.character-meta{margin:0;display:grid;gap:8px}.character-meta div{display:flex;justify-content:space-between;gap:8px}.character-meta dt{margin:0;color:#64748b;font-size:13px}.character-meta dd{margin:0;font-weight:600;font-size:14px}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:20}.modal-panel{width:min(860px,100%);max-height:85vh;overflow:auto;background:#fff;border-radius:14px;padding:16px}.modal-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.modal-header h2{margin:0;font-size:22px}.modal-header p{margin:6px 0 0;color:#64748b;font-size:14px}.modal-close{border:1px solid #cbd5e1;border-radius:8px;background:#fff;color:#0f172a;padding:8px 10px}.modal-tabs{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px}.modal-tab{border:1px solid #cbd5e1;border-radius:999px;background:#fff;color:#334155;padding:6px 12px;font-size:13px}.modal-tab.is-active{border-color:#2563eb;background:#eff6ff;color:#1d4ed8}.modal-content{margin-top:12px}.detail-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.detail-list-item{border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;display:flex;justify-content:space-between;align-items:baseline;gap:10px}.detail-list-item strong{color:#0f172a;font-size:14px}.detail-list-item span{color:#475569;font-size:13px;text-align:right}.detail-empty{margin-top:12px;color:#64748b}
