:root{--color-bg:oklch(95.5% .012 82);--color-surface:oklch(98% .008 80);--color-surface-alt:oklch(91.5% .02 78);--color-text:oklch(28% .025 55);--color-text-muted:oklch(55% .02 65);--color-accent:oklch(50% .09 155);--color-accent-soft:oklch(90% .045 155);--color-border:oklch(87% .018 78);--color-shadow:#64462814;--color-sidebar:oklch(22% .022 55);--color-sidebar-border:#ffffff0f;--color-sidebar-text:oklch(88% .01 80);--color-sidebar-muted:oklch(58% .015 75);--color-sidebar-accent:oklch(72% .09 75);--color-error:oklch(50% .15 25);--color-error-bg:oklch(95% .04 25)}*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:DM Sans,system-ui,sans-serif}#root{width:100%;min-height:100vh}input{font-family:inherit}.cassette{border-radius:4px;flex-shrink:0;display:block}.auth-shell{background:var(--color-sidebar);min-height:100vh;font-family:DM Sans,sans-serif;display:flex}.auth-shell__panel{background:var(--color-surface);flex-direction:column;flex-shrink:0;justify-content:center;width:520px;min-height:100vh;padding:60px 56px;display:flex}.auth-shell__brand{margin-bottom:48px}.auth-shell__brand-name{color:var(--color-text);margin-bottom:2px;font-family:Lora\, serif;font-size:22px;font-weight:600}.auth-shell__brand-line{background:var(--color-accent);border-radius:1px;width:32px;height:2px}.cassette-wall{z-index:1;flex-direction:column;align-items:center;display:flex}.cassette-wall__grid{opacity:.85;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:40px;display:grid}.cassette-wall__quote{text-align:center;max-width:340px}.cassette-wall__quote-text{color:#ffffffd1;margin-bottom:12px;font-family:Lora\, serif;font-size:17px;font-style:italic;font-weight:400;line-height:1.65}.cassette-wall__quote-author{color:#fff6;letter-spacing:.07em;text-transform:uppercase;font-family:DM Sans,sans-serif;font-size:12px}.auth-shell__decor{flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:100vh;padding:48px;display:flex;position:relative;overflow:hidden}.auth-shell__ring{pointer-events:none;border:1px solid #ffffff0d;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.auth-input{margin-bottom:18px}.auth-input__label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:7px;font-size:11px;font-weight:600}.auth-input__field{border:1.5px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);border-radius:12px;outline:none;padding:13px 16px;font-family:DM Sans,sans-serif;font-size:15px;transition:border-color .15s,box-shadow .15s}.auth-input__field:focus{border:2px solid var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.auth-input__field--error{border-color:var(--color-error)}.auth-input__error{color:var(--color-error);margin-top:4px;font-size:12px}.auth-btn{border:1.5px solid var(--color-border);width:100%;color:var(--color-text);cursor:pointer;text-align:center;background:0 0;border-radius:13px;margin-bottom:12px;padding:14px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;transition:opacity .15s}.auth-btn--primary{background:var(--color-accent);color:#fff;border:none}.auth-btn:disabled{cursor:not-allowed;opacity:.6}.landing__heading{color:var(--color-text);margin-top:0;margin-bottom:10px;font-family:Lora\, serif;font-size:30px;font-weight:600;line-height:1.25}.landing__subtitle{color:var(--color-text-muted);margin-bottom:36px;font-size:14px;line-height:1.7}.login__title{color:var(--color-text);margin-top:0;margin-bottom:6px;font-family:Lora\, serif;font-size:26px;font-weight:600}.login__alt-text{color:var(--color-text-muted);margin-bottom:32px;font-size:13px}.login__alt-link{color:var(--color-accent);font-weight:500;text-decoration:none}.login__forgot{justify-content:flex-end;margin-top:-10px;margin-bottom:24px;display:flex}.login__forgot-text{color:var(--color-accent);cursor:pointer;font-family:DM Sans,sans-serif;font-size:12px}.login__error{color:var(--color-error);background:var(--color-error-bg);border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:13px}.register__title{color:var(--color-text);margin-top:0;margin-bottom:6px;font-family:Lora\, serif;font-size:26px;font-weight:600}.register__alt-text{color:var(--color-text-muted);margin-bottom:28px;font-size:13px}.register__alt-link{color:var(--color-accent);font-weight:500;text-decoration:none}.register__error{color:var(--color-error);background:var(--color-error-bg);border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:13px}.sidebar{background:var(--color-sidebar);border-right:1px solid var(--color-sidebar-border);flex-direction:column;flex-shrink:0;width:220px;height:100vh;padding:24px 12px;display:flex}.sidebar__header{padding:0 6px 28px}.sidebar__title{color:var(--color-sidebar-text);margin-bottom:3px;font-family:Lora\, serif;font-size:16px;font-weight:600}.sidebar__count{color:var(--color-sidebar-muted);font-family:DM Sans,sans-serif;font-size:11px}.sidebar__nav{flex-direction:column;gap:2px;display:flex}.sidebar__nav-item{color:var(--color-sidebar-muted);cursor:pointer;background:0 0;border-radius:8px;align-items:center;gap:10px;padding:9px 10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:400;display:flex}.sidebar__nav-item--active{color:var(--color-sidebar-accent);background:#ffffff17;font-weight:600}.sidebar__nav-item--disabled{cursor:default;opacity:.5}.sidebar__nav-icon{flex-shrink:0}.sidebar__divider{background:#ffffff12;height:1px;margin:20px 0}.sidebar__log-btn{background:var(--color-sidebar-accent);color:#fff;cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;width:100%;padding:10px 12px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;display:flex}.sidebar__log-btn-plus{font-size:18px;font-weight:300;line-height:1}.sidebar__moods{margin-top:auto;padding:16px 4px 0}.sidebar__moods-label{color:var(--color-sidebar-muted);letter-spacing:.07em;text-transform:uppercase;margin-bottom:8px;font-family:DM Sans,sans-serif;font-size:10px}.sidebar__moods-list{flex-wrap:wrap;gap:5px;display:flex}.sidebar__mood-tag{color:var(--color-sidebar-accent);background:#ffffff14;border-radius:20px;padding:3px 8px;font-family:DM Sans,sans-serif;font-size:10px}.stars{gap:2px;display:flex}.stars__star{cursor:default;flex-shrink:0}.stars__star--interactive{cursor:pointer}.pill{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border);cursor:default;-webkit-user-select:none;user-select:none;border-radius:20px;flex-shrink:0;padding:5px 13px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500;transition:background .12s,color .12s}.pill--sm{padding:3px 8px;font-size:10px}.pill--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.pill--interactive{cursor:pointer}.entry-card{background:var(--color-surface);cursor:pointer;border:1.5px solid #0000;border-radius:12px;align-items:center;gap:12px;margin-bottom:8px;padding:12px 14px;transition:background .12s,border-color .12s;display:flex}.entry-card--selected{background:var(--color-accent-soft);border-color:var(--color-accent)}.entry-card__body{flex:1;min-width:0}.entry-card__title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-family:Lora\, serif;font-size:14px;font-weight:600;overflow:hidden}.entry-card__artist{color:var(--color-text-muted);white-space:nowrap;text-overflow:ellipsis;margin-bottom:5px;font-size:12px;overflow:hidden}.entry-detail{background:var(--color-surface);flex-direction:column;flex:1;height:100vh;display:flex;overflow:hidden}.entry-detail__header{border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:10px;padding:28px 28px 18px;display:flex}.entry-detail__header-label{color:var(--color-text-muted);letter-spacing:.07em;text-transform:uppercase;font-family:DM Sans,sans-serif;font-size:10px}.entry-detail__header-badge{background:var(--color-accent-soft);color:var(--color-accent);border-radius:20px;margin-left:auto;padding:3px 9px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:500}.entry-detail__content{flex:1;padding:28px 32px;overflow-y:auto}.entry-detail__cassette-wrap{justify-content:center;margin-bottom:24px;display:flex}.entry-detail__title{color:var(--color-text);margin-top:0;margin-bottom:6px;font-family:Lora\, serif;font-size:28px;font-weight:600}.entry-detail__artist{color:var(--color-text-muted);margin-bottom:3px;font-size:15px}.entry-detail__album{color:var(--color-text-muted);margin-bottom:18px;font-size:13px;font-style:italic}.entry-detail__meta{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:22px;display:flex}.entry-detail__date{color:var(--color-text-muted);margin-left:auto;font-family:DM Sans,sans-serif;font-size:12px}.entry-detail__tags{margin-bottom:22px}.entry-detail__tags-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;font-family:DM Sans,sans-serif;font-size:11px}.entry-detail__tags-list{flex-wrap:wrap;gap:6px;display:flex}.entry-detail__notes-wrap{margin-bottom:26px}.entry-detail__notes{background:var(--color-surface-alt);border-left:3px solid var(--color-accent);cursor:pointer;border-radius:12px;padding:16px 18px;transition:background .15s}.entry-detail__notes:hover{background:var(--color-border)}.entry-detail__notes--empty{cursor:pointer;border-left-style:dashed}.entry-detail__notes-text{color:var(--color-text);margin:0;font-family:Lora\, serif;font-size:15px;font-style:italic;line-height:1.7}.entry-detail__notes-placeholder{color:var(--color-text-muted);opacity:.6;font-family:Lora\, serif;font-size:15px;font-style:italic}.entry-detail__notes-textarea{background:var(--color-surface-alt);border:2px solid var(--color-accent);border-left:3px solid var(--color-accent);width:100%;color:var(--color-text);resize:none;box-sizing:border-box;border-radius:12px;outline:none;padding:16px 18px;font-family:Lora\, serif;font-size:15px;font-style:italic;line-height:1.7;overflow:hidden}.entry-detail-empty{background:var(--color-surface);height:100vh;color:var(--color-text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;font-family:DM Sans,sans-serif;display:flex}.entry-detail-empty__text{opacity:.6;font-size:13px}.log-modal{z-index:1000;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.log-modal__backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#140e088c;position:absolute;inset:0}.log-modal__dialog{background:var(--color-surface);z-index:1;border-radius:20px;width:540px;position:relative;overflow:hidden;box-shadow:0 32px 80px #00000059}.log-modal__steps{align-items:center;gap:6px;padding:20px 24px 0;display:flex}.log-modal__step{align-items:center;gap:6px;display:flex}.log-modal__step--stretch{flex:1}.log-modal__step-circle{border:1.5px solid var(--color-border);width:22px;height:22px;color:var(--color-text-muted);background:0 0;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:700;transition:all .2s;display:flex}.log-modal__step-circle--active,.log-modal__step-circle--done{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.log-modal__step-label{color:var(--color-text-muted);font-family:DM Sans,sans-serif;font-size:12px;font-weight:400}.log-modal__step-label--active{color:var(--color-text);font-weight:600}.log-modal__step-line{background:var(--color-border);width:28px;height:1px;margin-left:2px}.log-modal__error{background:var(--color-error-bg);color:var(--color-error);border-radius:10px;margin:12px 24px 0;padding:10px 14px;font-size:13px}.log-modal__form{padding:20px 24px 28px}.log-modal__form-title{color:var(--color-text);margin-top:0;margin-bottom:4px;font-family:Lora\, serif;font-size:20px;font-weight:600}.log-modal__form-subtitle{color:var(--color-text-muted);margin-top:0;margin-bottom:20px;font-size:13px}.log-modal__form-title--rate{margin-bottom:18px}.log-modal__section-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600}.log-modal__input-group{margin-bottom:14px}.log-modal__input{border:1.5px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);border-radius:10px;outline:none;padding:11px 14px;font-family:DM Sans,sans-serif;font-size:14px;transition:border-color .15s,box-shadow .15s}.log-modal__input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.log-modal__textarea{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);resize:none;border-radius:12px;outline:none;padding:12px 16px;font-family:Lora\, serif;font-size:14px;line-height:1.55;transition:border-color .15s}.log-modal__textarea:focus{border-color:var(--color-accent)}.log-modal__btn-primary{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:13px 32px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600}.log-modal__btn-cancel{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-family:DM Sans,sans-serif;font-size:13px;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}.log-modal__btn-primary:disabled{opacity:.6}.log-modal__btn-secondary{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:12px;padding:13px 32px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600}.log-modal__form-footer{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.log-modal__form-footer--right{align-items:center;gap:10px;display:flex}.log-modal__form-footer-spacer{flex:1}.log-modal__track-summary{background:var(--color-accent-soft);border:1.5px solid var(--color-accent);border-radius:12px;align-items:center;gap:14px;margin-bottom:22px;padding:12px 16px;display:flex}.log-modal__track-summary-body{flex:1;min-width:0}.log-modal__track-summary-title{color:var(--color-text);font-family:Lora\, serif;font-size:16px;font-weight:600}.log-modal__track-summary-artist{color:var(--color-text-muted);font-size:13px}.log-modal__track-summary-album{color:var(--color-text-muted);font-size:12px;font-style:italic}.log-modal__moods-grid{flex-wrap:wrap;gap:7px;display:flex}.log-modal__done{text-align:center;padding:20px 24px 36px}.log-modal__done-cassette{justify-content:center;margin-top:8px;margin-bottom:20px;display:flex}.log-modal__done-check{background:var(--color-accent-soft);border:2px solid var(--color-accent);width:52px;height:52px;color:var(--color-accent);border-radius:26px;justify-content:center;align-items:center;margin:0 auto 16px;font-size:22px;display:flex}.log-modal__done-title{color:var(--color-text);margin-top:0;margin-bottom:6px;font-family:Lora\, serif;font-size:22px;font-weight:600}.log-modal__done-text{color:var(--color-text-muted);margin-bottom:24px;font-size:14px;line-height:1.6}.log-modal__done-text strong{color:var(--color-text)}.log-modal__done-actions{justify-content:center;gap:10px;display:flex}.log-modal__validation-error{color:var(--color-error);margin-bottom:16px;font-size:13px}.journal{height:100vh;font-family:DM Sans,sans-serif;display:flex;overflow:hidden}.journal__feed{border-right:1px solid var(--color-border);background:var(--color-bg);flex-direction:column;flex-shrink:0;width:460px;height:100vh;display:flex}.journal__feed-header{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;padding:28px 24px 18px}.journal__feed-date{color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px;font-size:10px}.journal__feed-title{color:var(--color-text);margin:0;font-family:Lora\, serif;font-size:22px;font-weight:600}.journal__feed-list{flex:1;padding:16px;overflow-y:auto}.journal__feed-loading{color:var(--color-text-muted);padding:20px 4px;font-size:13px}.journal__feed-error{color:var(--color-error);padding:20px 4px;font-size:13px}.journal__date-group-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.09em;margin-bottom:10px;font-size:10px;font-weight:700}.journal__empty{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:32px;display:flex}.journal__empty-text{color:var(--color-text-muted);text-align:center;font-family:DM Sans,sans-serif;font-size:13px;line-height:1.6}.journal__empty-btn{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600}.profile{height:100vh;font-family:DM Sans,sans-serif;display:flex;overflow:hidden}.profile__content{background:var(--color-bg);flex-direction:column;flex:1;height:100vh;display:flex}.profile__header{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;padding:28px 24px 18px}.profile__header-title{color:var(--color-text);margin:0;font-family:Lora\, serif;font-size:22px;font-weight:600}.profile__body{flex:1;padding:24px;overflow-y:auto}.profile__loading{flex:1;justify-content:center;align-items:center;display:flex}.profile__loading-text{color:var(--color-text-muted);font-size:13px}.profile__error{color:var(--color-error);background:var(--color-error-bg);border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:13px}.profile__email-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;margin-bottom:20px;padding:28px 24px}.profile__email-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.09em;margin-bottom:8px;font-size:10px}.profile__email-value{color:var(--color-text);font-size:15px}.profile__logout-btn{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:10px;padding:10px 20px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;transition:opacity .15s}.profile__logout-btn:disabled{cursor:default;opacity:.6}.protected-route-loading{background:var(--color-sidebar);justify-content:center;align-items:center;height:100vh;display:flex}.protected-route-loading__text{color:var(--color-sidebar-muted);font-family:DM Sans,sans-serif;font-size:13px}
