:root{--accent: #0b63d8;--accent-dark: #0b3f95;--accent-light: #e0edff;--silver: #5f6b7a;--silver-light: #e8edf5;--bg: #f8f9fb;--surface: #ffffff;--text: #1a1d23;--text-secondary: #5f6b7a;--border: #e2e5ea;--radius: 10px;--radius-sm: 6px;--radius-lg: 14px;--green: #0e8a6e;--amber: #c47f17;--red: #c4342d;--font-heading: "Plus Jakarta Sans", system-ui, sans-serif;--font-body: "DM Sans", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4{font-family:var(--font-heading);font-weight:600;line-height:1.3}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:16px 8px;position:sticky;top:0;z-index:100}.app-main{flex:1;width:100%;max-width:720px;margin:0 auto;padding:24px 20px 48px}@media (min-width: 768px){.app-main{padding:32px 24px 64px}}@media (min-width: 1024px){.app-main{max-width:800px}}.app-footer{border-top:1px solid var(--border);padding:16px 20px;text-align:center;font-size:.8rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;gap:8px}.app-footer a{color:var(--text-secondary)}.app-footer a:hover{color:var(--accent)}.app-footer .dot{opacity:.4}.brand-logo{display:inline-flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0;font-family:var(--font-heading)}.brand-logo-img{height:64px;width:auto;display:block}@media (min-width: 768px){.brand-logo-img{height:80px}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius);border:1px solid transparent;font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-dark)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:var(--border)}.btn-ghost:hover{background:var(--silver-light)}.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}.btn-danger:hover{opacity:.9}.btn-sm{padding:6px 14px;font-size:.8rem}.btn-full{width:100%}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.82rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.9rem;color:var(--text);background:var(--surface);transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-textarea{resize:vertical}.form-textarea--sm{font-size:.82rem}.form-error{color:var(--red);font-size:.85rem;margin:8px 0}.search-page{display:flex;flex-direction:column;align-items:center;padding-top:48px}.search-hero{text-align:center;max-width:520px;width:100%}.search-hero__title{font-size:1.6rem;color:var(--text);margin-bottom:8px}@media (min-width: 768px){.search-hero__title{font-size:2rem}}.search-hero__sub{color:var(--text-secondary);font-size:.95rem;margin-bottom:24px}.search-box{display:flex;align-items:center;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:4px 4px 4px 14px;transition:border-color .15s;width:100%}.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.search-box__icon{flex-shrink:0;color:var(--silver);margin-right:10px}.search-box__input{flex:1;border:none;outline:none;font-family:var(--font-body);font-size:1rem;color:var(--text);background:transparent;padding:8px 0}.search-box__btn{flex-shrink:0;padding:10px 20px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;font-weight:500;cursor:pointer}.search-box__btn:hover{background:var(--accent-dark)}.search-box__btn:disabled{opacity:.4;cursor:not-allowed}.search-recents{margin-top:32px;width:100%;max-width:520px}.search-recents__title{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:10px}.search-recents__list{display:flex;flex-wrap:wrap;gap:8px}.search-recents__item{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--surface);font-size:.85rem;color:var(--text);cursor:pointer;font-family:var(--font-body)}.search-recents__item:hover{border-color:var(--accent);color:var(--accent)}.results-page{max-width:100%}.results-search{margin-bottom:20px}.results-loading,.results-empty{text-align:center;padding:48px 0;color:var(--text-secondary)}.results-empty__sub{font-size:.85rem;margin-top:6px}.results-empty__requested{margin-top:16px;padding:16px;background:#e6f4ea;border-radius:var(--radius);color:var(--green);font-size:.9rem}.results-count{font-size:.8rem;color:var(--text-secondary);margin-bottom:12px}.result-row{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;cursor:pointer;text-align:left;font-family:var(--font-body);transition:border-color .15s,box-shadow .15s}.result-row:hover{border-color:var(--accent);box-shadow:0 2px 8px #0b63d814}.result-row__icon{font-size:1.4rem;flex-shrink:0}.result-row__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.result-row__name{font-weight:600;font-family:var(--font-heading);font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-row__meta{font-size:.8rem;color:var(--text-secondary)}.result-row__status{font-size:.72rem;color:var(--silver)}.result-row__score{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;flex-shrink:0}.result-row__class{display:none;padding:3px 10px;border-radius:20px;color:#fff;font-size:.7rem;font-weight:500;white-space:nowrap;flex-shrink:0}@media (min-width: 600px){.result-row__class{display:inline-block}}.quick-view__header{margin-bottom:24px}.quick-view__type{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:4px}.quick-view__name{font-size:1.5rem;margin-bottom:2px}.quick-view__artist{color:var(--accent);font-weight:500;font-size:.95rem}.quick-view__subtitle{color:var(--text-secondary);font-size:.85rem;margin-bottom:8px}.quick-view__bio{color:var(--text);font-size:.9rem;margin-bottom:12px;line-height:1.6}.quick-view__badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.quick-view__status{font-size:.75rem;color:var(--text-secondary)}.quick-view__scores{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px}.quick-view__overall{display:flex;align-items:baseline;gap:10px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border)}.quick-view__overall-label{font-family:var(--font-heading);font-size:.9rem;font-weight:600;color:var(--text)}.quick-view__overall-value{font-family:var(--font-heading);font-size:1.8rem;font-weight:700}.quick-view__category-scores{display:flex;flex-direction:column;gap:10px}.quick-view__contains{margin-bottom:20px}.quick-view__contains h3{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.quick-view__contains-list{display:flex;flex-wrap:wrap;gap:8px}.quick-view__summary{background:var(--accent-light);border-radius:var(--radius);padding:14px 18px;margin-bottom:20px;font-size:.9rem;color:var(--accent-dark)}.quick-view__suggestions{margin-bottom:24px}.quick-view__suggestions h3{font-size:.85rem;color:var(--text-secondary);margin-bottom:10px}.quick-view__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.suggestion-cards{display:flex;flex-direction:column;gap:8px}@media (min-width: 600px){.suggestion-cards{flex-direction:row;flex-wrap:wrap}.suggestion-card{flex:1;min-width:180px}}.suggestion-card{display:flex;flex-direction:column;gap:4px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;font-family:var(--font-body);transition:border-color .15s}.suggestion-card:hover{border-color:var(--accent)}.suggestion-card__name{font-family:var(--font-heading);font-weight:600;font-size:.9rem}.suggestion-card__genre{font-size:.75rem;color:var(--text-secondary)}.suggestion-card__reason{font-size:.8rem;color:var(--silver)}.back-link{display:inline-block;background:none;border:none;color:var(--accent);font-size:.85rem;cursor:pointer;padding:0;margin-bottom:16px;font-family:var(--font-body)}.back-link:hover{text-decoration:underline}.detailed-view__header{margin-bottom:24px}.detailed-view__type{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:4px}.detailed-view__name{font-size:1.5rem;margin-bottom:2px}.detailed-view__artist{color:var(--accent);font-weight:500;font-size:.95rem}.detailed-view__subtitle{color:var(--text-secondary);font-size:.85rem;margin-bottom:8px}.detailed-view__badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.detailed-view__status{font-size:.75rem;color:var(--text-secondary)}.detailed-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}.detailed-section h2{font-size:.95rem;margin-bottom:12px;color:var(--text)}.detailed-section p{font-size:.9rem;color:var(--text);line-height:1.65}.detailed-view__overall{display:flex;align-items:baseline;gap:10px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--border)}.detailed-view__overall-label{font-family:var(--font-heading);font-weight:600;font-size:.9rem}.detailed-view__overall-value{font-family:var(--font-heading);font-size:1.8rem;font-weight:700}.detailed-view__scores{display:flex;flex-direction:column;gap:16px}.detailed-view__contains,.detailed-view__tags{display:flex;flex-wrap:wrap;gap:8px}.detailed-view__confidence-level{font-family:var(--font-heading);font-weight:600;margin-bottom:4px}.detailed-view__confidence-note{font-size:.85rem;color:var(--text-secondary)}.score-bar{margin-bottom:4px}.score-bar__header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.score-bar__label{font-size:.82rem;color:var(--text);font-weight:500}.score-bar__value{font-family:var(--font-heading);font-weight:700;font-size:.9rem}.score-bar__track{height:6px;background:var(--silver-light);border-radius:3px;overflow:hidden}.score-bar__fill{height:100%;border-radius:3px;transition:width .3s ease}.score-bar__explanation{font-size:.82rem;color:var(--text-secondary);margin-top:6px;line-height:1.5}.score-bar--compact .score-bar__label{font-size:.78rem}.score-bar--compact .score-bar__value{font-size:.82rem}.score-bar--compact .score-bar__track{height:4px}.classification-badge{display:inline-block;padding:4px 12px;border-radius:20px;color:#fff;font-size:.78rem;font-weight:500;white-space:nowrap}.tag-badge{display:inline-block;padding:4px 12px;border-radius:20px;background:var(--silver-light);color:var(--text);font-size:.78rem;font-weight:500}.contains-badge{display:inline-block;padding:4px 12px;border-radius:20px;background:#fef2e0;color:var(--amber);font-size:.78rem;font-weight:500}.suggest-edit-btn{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:none;border:none;color:var(--silver);font-size:.78rem;font-family:var(--font-body);cursor:pointer;border-radius:var(--radius-sm);margin-top:8px}.suggest-edit-btn:hover{color:var(--accent);background:var(--accent-light)}.auth-page{display:flex;justify-content:center;padding-top:48px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;max-width:400px;width:100%}.auth-card h1{font-size:1.3rem;margin-bottom:8px}.auth-card p{font-size:.9rem;color:var(--text-secondary);margin-bottom:20px}.suggest-page{max-width:520px}.suggest-page h1{font-size:1.3rem;margin-bottom:8px}.suggest-page__item{color:var(--text-secondary);margin-bottom:20px;font-size:.9rem}.suggest-page__actions{display:flex;gap:10px;margin-top:8px}.suggest-done{text-align:center;padding:32px 0}.suggest-done h2{margin-bottom:8px}.suggest-done p{color:var(--text-secondary);margin-bottom:16px;font-size:.9rem}.terms-page,.about-page{max-width:600px}.terms-page h1,.about-page h1{font-size:1.4rem;margin-bottom:16px}.terms-page h2,.about-page h2{font-size:1.05rem;margin-top:24px;margin-bottom:8px}.terms-page p,.about-page p{font-size:.9rem;color:var(--text);line-height:1.7;margin-bottom:12px}.terms-page__copyright,.about-page__footer{margin-top:32px;font-size:.8rem;color:var(--text-secondary)}.about-page__closing{margin-top:32px;font-family:var(--font-heading);font-weight:600;font-style:italic;color:var(--accent-dark);font-size:.95rem}.page-loading,.page-empty{text-align:center;padding:48px 0;color:var(--text-secondary);font-size:.95rem}.admin-shell{display:flex;min-height:100vh}.admin-sidebar{width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 0;flex-shrink:0}.admin-sidebar__logo{padding:0 20px 20px;border-bottom:1px solid var(--border);margin-bottom:12px}.admin-nav{display:flex;flex-direction:column;padding:0 12px;flex:1}.admin-nav__link{display:block;padding:10px 14px;border-radius:var(--radius-sm);font-size:.9rem;color:var(--text);font-weight:500;text-decoration:none;margin-bottom:2px}.admin-nav__link:hover{background:var(--silver-light);text-decoration:none}.admin-nav__link--active{background:var(--accent-light);color:var(--accent)}.admin-sidebar__footer{padding:12px 20px 0;border-top:1px solid var(--border);margin-top:auto}.admin-main{flex:1;padding:32px;overflow-y:auto;max-width:960px}.admin-loading,.admin-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:12px;text-align:center;padding:24px}.admin-denied h2{font-size:1.3rem}.admin-denied p{color:var(--text-secondary);margin-bottom:12px}.admin-page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.admin-page-header h1{font-size:1.4rem}.admin-badge{background:var(--accent);color:#fff;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.admin-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border)}.admin-tab{padding:10px 18px;background:none;border:none;border-bottom:2px solid transparent;font-family:var(--font-body);font-size:.9rem;font-weight:500;color:var(--text-secondary);cursor:pointer}.admin-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.admin-search{margin-bottom:16px}.admin-loading-inline{text-align:center;padding:32px 0;color:var(--text-secondary)}.admin-empty{text-align:center;padding:32px 0;color:var(--text-secondary);font-size:.9rem}.admin-list{display:flex;flex-direction:column;gap:8px}.admin-list-item{display:block;width:100%;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:left;font-family:var(--font-body);cursor:pointer;transition:border-color .15s;position:relative}.admin-list-item:hover{border-color:var(--accent)}.admin-list-item--static{cursor:default}.admin-list-item--static:hover{border-color:var(--border)}.admin-list-item__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}.admin-list-item__name{font-family:var(--font-heading);font-weight:600;font-size:.95rem}.admin-list-item__status{padding:2px 10px;border-radius:20px;font-size:.72rem;font-weight:500;background:var(--silver-light);color:var(--silver)}.admin-list-item__status--submitted{background:#fff3e0;color:var(--amber)}.admin-list-item__status--in_review{background:var(--accent-light);color:var(--accent)}.admin-list-item__status--approved{background:#e6f4ea;color:var(--green)}.admin-list-item__status--rejected{background:#fdecea;color:var(--red)}.admin-list-item__type{font-size:.72rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.06em}.admin-list-item__role{padding:2px 10px;border-radius:20px;font-size:.72rem;font-weight:500}.admin-list-item__role--admin{background:var(--accent-light);color:var(--accent)}.admin-list-item__role--user{background:var(--silver-light);color:var(--silver)}.admin-list-item__meta{font-size:.8rem;color:var(--text-secondary);margin-bottom:2px}.admin-list-item__message{font-size:.82rem;color:var(--text);margin-top:4px}.admin-list-item__delete{position:absolute;top:14px;right:14px}.admin-add-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px}.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}.admin-section h2{font-size:.95rem;margin-bottom:14px}.admin-section h4{font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:8px;margin-top:12px}.admin-meta-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.85rem;border-bottom:1px solid var(--silver-light)}.admin-meta-row:last-child{border-bottom:none}.admin-meta-row span{color:var(--text-secondary)}.admin-record__header{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:20px}.admin-record__header h1{font-size:1.4rem}.admin-record__type{font-size:.72rem;text-transform:uppercase;color:var(--text-secondary);letter-spacing:.06em}.admin-record__artist{color:var(--accent);font-size:.9rem}.admin-record__grid{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 768px){.admin-record__grid{grid-template-columns:1.2fr .8fr}}.admin-record__overall{font-size:.9rem;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.admin-record__class-preview{font-size:.82rem;color:var(--text-secondary)}.admin-score-row{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--silver-light)}.admin-score-row:last-child{border-bottom:none}.admin-score-row__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.admin-score-row__header label{font-size:.85rem;font-weight:500}.admin-slider{width:100%;margin-bottom:8px;accent-color:var(--accent)}.admin-record__actions{display:flex;align-items:center;gap:8px;padding-top:16px;border-top:1px solid var(--border);margin-top:8px;flex-wrap:wrap}.admin-save-confirm{font-size:.85rem;color:var(--green);font-weight:500}.admin-tag-group{margin-bottom:12px}.admin-tag-list,.admin-tag-grid{display:flex;flex-wrap:wrap;gap:6px}.admin-tag-btn{padding:5px 12px;border:1px solid var(--border);border-radius:20px;background:var(--surface);font-size:.78rem;font-family:var(--font-body);cursor:pointer;color:var(--text)}.admin-tag-btn:hover{border-color:var(--accent)}.admin-tag-btn--active{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-tag-item{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--border);border-radius:20px;background:var(--surface);font-size:.82rem}.admin-tag-item__delete{background:none;border:none;color:var(--silver);font-size:1rem;cursor:pointer;line-height:1;padding:0 2px}.admin-tag-item__delete:hover{color:var(--red)}.admin-request h1{font-size:1.3rem;margin-bottom:16px}.admin-request__details,.admin-request__message{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}.admin-request__message h3{font-size:.85rem;color:var(--text-secondary);margin-bottom:8px}.admin-request__actions{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.admin-request__buttons{display:flex;gap:10px;margin-top:12px}.admin-settings__help{color:var(--text-secondary);font-size:.9rem;margin-bottom:20px;line-height:1.6}.admin-settings__weight{margin-bottom:14px}.admin-settings__weight-header{display:flex;justify-content:space-between;font-size:.85rem;margin-bottom:4px}.admin-settings__normalized{background:var(--silver-light);border-radius:var(--radius);padding:14px;margin-top:16px}.admin-settings__normalized h3{font-size:.82rem;margin-bottom:8px}.admin-settings__actions{display:flex;align-items:center;gap:10px;margin-top:8px;flex-wrap:wrap}@media (max-width: 768px){.admin-shell{flex-direction:column}.admin-sidebar{width:100%;flex-direction:row;align-items:center;padding:12px;border-right:none;border-bottom:1px solid var(--border);overflow-x:auto;gap:8px}.admin-sidebar__logo{padding:0;border:none;margin:0}.admin-nav{flex-direction:row;padding:0;gap:4px}.admin-nav__link{white-space:nowrap;padding:8px 12px;font-size:.82rem}.admin-sidebar__footer{display:none}.admin-main{padding:20px}}
