*{box-sizing:border-box;margin:0;padding:0}body{color:#1d1d1f;background:#f5f5f7;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Malgun Gothic,sans-serif}button{font-family:inherit}.app-header{z-index:10;background:#fff;border-bottom:1px solid #e5e5ea;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.app-header h1{font-size:20px;font-weight:600}.btn{color:#fff;cursor:pointer;background:#007aff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500}.btn:hover{background:#0062cc}.btn-secondary{color:#1d1d1f;background:#e5e5ea}.btn-secondary:hover{background:#d1d1d6}.btn-danger{color:#fff;background:#ff3b30}.btn-danger:hover{background:#d70015}.tabs{background:#fff;border-bottom:1px solid #e5e5ea;gap:8px;padding:16px 24px;display:flex;overflow-x:auto}.tab{cursor:pointer;white-space:nowrap;background:#f5f5f7;border:none;border-radius:16px;padding:6px 14px;font-size:14px}.tab.active{color:#fff;background:#1d1d1f}main{max-width:1200px;margin:0 auto;padding:24px}.grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.card{cursor:pointer;text-align:left;font:inherit;color:inherit;background:#fff;border:none;border-radius:12px;flex-direction:column;padding:0;transition:transform .15s,box-shadow .15s;display:flex;overflow:hidden}.card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.cover{aspect-ratio:2/3;color:#fff;background:linear-gradient(135deg,#b8c1d9,#6c7a99);justify-content:center;align-items:center;width:100%;font-size:32px;font-weight:700;display:flex;overflow:hidden}.cover img{object-fit:cover;width:100%;height:100%}.card-body{padding:12px}.card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:4px;font-size:14px;font-weight:600;display:-webkit-box;overflow:hidden}.card-author{color:#86868b;margin-bottom:8px;font-size:12px}.card-meta{justify-content:space-between;align-items:center;display:flex}.badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500}.badge-wishlist{color:#8a6d00;background:#fff4cc}.badge-reading{color:#003d8a;background:#cce5ff}.badge-done{color:#1e5631;background:#d4edda}.stars{color:orange;font-size:12px}.empty{text-align:center;color:#86868b;padding:80px 24px}.empty p{margin-bottom:16px;font-size:16px}.modal-backdrop{z-index:100;background:#0006;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:90vh;padding:24px;overflow-y:auto}.modal h2{margin-bottom:16px;font-size:18px}.field{margin-bottom:12px}.field label{color:#3c3c43;margin-bottom:4px;font-size:13px;font-weight:500;display:block}.field input,.field select,.field textarea{background:#fff;border:1px solid #d1d1d6;border-radius:8px;width:100%;padding:8px 12px;font-family:inherit;font-size:14px}.field input:focus,.field select:focus,.field textarea:focus{border-color:#007aff;outline:none}.field textarea{resize:vertical;min-height:60px}.rating-input{gap:4px;display:flex}.rating-input button{cursor:pointer;color:#d1d1d6;-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:0;font-size:24px;line-height:1}.rating-input button.active{color:orange}.modal-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}
