.biscuit-wrapper{display:inline-block;transform-origin:center bottom}.biscuit-sparkle{opacity:0;transition:opacity .3s}@keyframes idle-bounce{0%,to{transform:translateY(0) rotate(0)}30%{transform:translateY(-6px) rotate(1deg)}60%{transform:translateY(-3px) rotate(-.5deg)}}.biscuit-wrapper[data-state=idle]{animation:idle-bounce 3s ease-in-out infinite}@keyframes talking-wiggle{0%,to{transform:rotate(0)}20%{transform:rotate(-4deg)}40%{transform:rotate(4deg)}60%{transform:rotate(-3deg)}80%{transform:rotate(3deg)}}@keyframes mouth-talk{0%,to{d:path("M 92 107 Q 100 115 108 107")}50%{d:path("M 92 109 Q 100 118 108 109")}}.biscuit-wrapper[data-state=talking]{animation:talking-wiggle .4s ease-in-out infinite}.biscuit-wrapper[data-state=talking] .biscuit-mouth{animation:mouth-talk .3s ease-in-out infinite}@keyframes happy-jump{0%{transform:translateY(0) scale(1)}25%{transform:translateY(-20px) scale(1.05) rotate(-3deg)}50%{transform:translateY(-14px) scale(1.08) rotate(3deg)}70%{transform:translateY(-6px) scale(1.02) rotate(-1deg)}to{transform:translateY(0) scale(1)}}.biscuit-wrapper[data-state=happy]{animation:happy-jump .8s cubic-bezier(.36,.07,.19,.97) infinite}.biscuit-wrapper[data-state=happy] .biscuit-sparkle{opacity:1;animation:sparkle-fade 1.2s ease-in-out infinite}@keyframes sparkle-fade{0%,to{opacity:.4;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}:root{--color-bg: #FFF9F0;--color-pink: #FF8FAB;--color-pink-light: #FFD6E2;--color-teal: #A8DADC;--color-teal-light: #D4F0F0;--color-brown: #3D2B1F;--color-brown-light: #6B4C3B;--color-card: #FFFFFF;--color-success: #4CAF50;--radius: 20px;--radius-sm: 12px;--shadow: 0 4px 16px rgba(61, 43, 31, .1);--shadow-lg: 0 8px 32px rgba(61, 43, 31, .15);--font: "Nunito", "Segoe UI", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--color-bg);color:var(--color-brown);min-height:100dvh;overflow-x:hidden}.app{max-width:816px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}.app-nav{display:flex;gap:8px;padding:12px 16px;background:var(--color-card);border-bottom:2px solid var(--color-pink-light);position:sticky;top:0;z-index:10;box-shadow:var(--shadow);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.app-nav::-webkit-scrollbar{display:none}.nav-btn{flex:1;padding:10px 8px;border:2px solid transparent;border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-brown-light);font-family:var(--font);font-size:.85rem;font-weight:700;cursor:pointer;transition:all .2s ease;white-space:nowrap}.nav-btn:hover{background:var(--color-pink-light);border-color:var(--color-pink);color:var(--color-brown)}.nav-btn.active{background:var(--color-pink);border-color:var(--color-pink);color:#fff;box-shadow:0 2px 8px #ff8fab66}.app-main{flex:1;padding:16px;overflow-y:auto}.card{background:var(--color-card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);margin-bottom:16px}.card-teal{background:var(--color-teal-light);border:2px solid var(--color-teal)}.card-pink{background:var(--color-pink-light);border:2px solid var(--color-pink)}.card h2{font-size:1rem;font-weight:800;color:var(--color-brown-light);margin-bottom:12px;text-transform:uppercase;letter-spacing:.05em}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:50px;font-family:var(--font);font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--color-pink);color:#fff;box-shadow:0 4px 12px #ff8fab66}.btn-primary:hover{background:#ff6b8a;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-teal);color:var(--color-brown);box-shadow:0 4px 12px #a8dadc66}.btn-secondary:hover{background:#8ecfd1;transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.spinner{width:32px;height:32px;border:3px solid var(--color-pink-light);border-top-color:var(--color-pink);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-pink-light);border-radius:3px}.briefing-loading{display:flex;flex-direction:column;align-items:center;padding-top:40px;gap:8px}.loading-text{font-size:1rem;font-weight:600;color:var(--color-brown-light);margin-top:12px}.briefing-avatar{display:flex;justify-content:center;padding:8px 0 4px}.briefing-text-card{text-align:center}.briefing-name{font-weight:800;color:#c0486a;background:#ff8fab2e;border-radius:6px;padding:0 4px}.briefing-text-card .briefing-text{font-size:1.05rem;line-height:1.7;color:var(--color-brown);white-space:pre-wrap}.subject-pills{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;align-items:center;margin-top:14px}.subject-pills-label{width:100%;font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#c0486a;margin-bottom:2px}.subject-pills-comment{width:100%;font-size:.85rem;font-weight:600;color:#a0735a;margin-top:4px}.subject-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 12px 5px 6px;border-radius:999px;font-size:.8rem;font-weight:700;white-space:nowrap}.subject-pill-num{width:18px;height:18px;border-radius:50%;background:#0000001f;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:800;flex-shrink:0}.homework-today{margin:14px auto 0;width:60%;background:#ff8fab21;border:1.5px solid rgba(255,143,171,.4);border-radius:12px;padding:10px 14px;text-align:center}.homework-today-label{display:block;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#c0486a;margin-bottom:6px}.homework-today-list{list-style:none;display:flex;flex-direction:column;gap:4px}.homework-today-list li{font-size:.85rem;font-weight:600;color:var(--color-brown)}.homework-today-subject{font-weight:800;color:#c0486a;margin-right:4px}.school-time-badge{display:inline-flex;align-items:center;gap:8px;margin-top:14px;padding:8px 16px;background:#ff8fab26;border:1.5px solid rgba(255,143,171,.4);border-radius:999px;font-size:.9rem;color:var(--color-brown)}.school-time-icon{font-size:1rem}.school-time-label{font-weight:700;margin-right:5px;color:var(--color-brown)}.school-time-text strong{color:#c0486a;font-weight:800}.briefing-links{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:14px}.card-joke{background:linear-gradient(135deg,#fff9e6,#fff3cc);border:2px solid #FFD966}.joke-bubble{position:relative;background:#fff;border-radius:16px;padding:16px 20px;border:2px solid #FFE08A;box-shadow:0 2px 8px #ffd96633}.joke-text{font-size:1rem;line-height:1.6;color:var(--color-brown);margin:0}.joke-paw{position:absolute;bottom:-8px;right:16px;font-size:1.2rem}.weather-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:12px}.weather-item{display:flex;flex-direction:column;align-items:center;gap:4px}.weather-value{font-size:1.4rem;font-weight:800;color:var(--color-brown)}.weather-label{font-size:.75rem;font-weight:600;color:var(--color-brown-light);text-transform:uppercase;letter-spacing:.05em}.weather-desc{font-size:.9rem;font-weight:600;color:var(--color-brown-light);text-align:center;text-transform:capitalize}.tt-wrapper{overflow-x:auto;margin:0 -4px}.tt-table{width:100%;border-collapse:collapse;font-size:.82rem}.tt-th{padding:8px 6px 10px;text-align:center;font-weight:800;color:var(--color-brown);border-bottom:2px solid rgba(61,43,31,.1);white-space:nowrap}.tt-th-period{width:64px;min-width:64px}.tt-th.tt-today{color:var(--color-pink);border-bottom-color:var(--color-pink)}.tt-day-short{display:none}.tt-day-full{display:inline}.tt-row:nth-child(2n) td{background:#a8dadc14}.tt-period{text-align:right;padding:7px 6px 7px 2px;white-space:nowrap}.tt-period-num{display:block;font-size:.72rem;font-weight:800;color:#c4a882;line-height:1}.tt-period-time{display:block;font-size:.65rem;font-weight:500;color:#d4b896;line-height:1.3}.tt-cell{text-align:center;padding:6px 5px;font-weight:600;color:var(--color-brown);border-left:1px solid rgba(61,43,31,.06);line-height:1.2}.tt-cell.tt-today{background:#ff8fab1a;color:#c0486a;font-weight:700}.tt-cell.tt-empty{color:#3d2b1f33;font-weight:400}.tt-cell.tt-today.tt-empty{color:#c0486a40}@media (max-width: 400px){.tt-day-short{display:inline}.tt-day-full{display:none}.tt-cell,.tt-period{padding:6px 3px}.tt-table{font-size:.78rem}}.news-list{list-style:none;display:flex;flex-direction:column;gap:8px}.news-item{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:var(--color-bg);border-radius:var(--radius-sm);border-left:3px solid var(--color-teal)}.news-title{font-size:.9rem;font-weight:700;line-height:1.4;color:var(--color-brown)}.news-summary{font-size:.82rem;font-weight:600;line-height:1.5;color:var(--color-brown-light)}.chat-videos{display:flex;flex-direction:column;gap:12px;margin-top:12px;width:min(420px,72vw)}.chat-video-item{display:flex;flex-direction:column;gap:5px}.news-link{font-size:.8rem;font-weight:700;color:var(--color-teal);text-decoration:none;align-self:flex-start}.news-link:hover{text-decoration:underline;color:var(--color-brown)}.chat{display:flex;flex-direction:column;height:calc(100dvh - 80px)}.chat-avatar{display:flex;flex-direction:column;align-items:center;padding:8px 0;flex-shrink:0}.ollama-indicator{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;padding:4px 10px;border-radius:20px;margin-top:4px;transition:all .3s ease}.ollama-indicator.online{color:#2e7d32;background:#e8f5e9}.ollama-indicator.offline{color:#9e9e9e;background:#f5f5f5}.ollama-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ollama-indicator.online .ollama-dot{background:#4caf50;box-shadow:0 0 6px #4caf5099;animation:ollama-pulse 2s ease-in-out infinite}.ollama-indicator.offline .ollama-dot{background:#bdbdbd}@keyframes ollama-pulse{0%,to{opacity:1}50%{opacity:.4}}.source-badge{display:inline-block;font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:10px;margin-top:6px;opacity:.75}.source-ki{color:#6a1b9a;background:#f3e5f5}.source-biscuit{color:#5d4037;background:#efebe9}.chat-header{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--color-pink-light);flex-shrink:0}.chat-header-btn{background:none;border:1px solid var(--color-pink-light);border-radius:var(--radius-sm);padding:4px 10px;font-size:.8rem;font-family:var(--font);font-weight:600;color:var(--color-brown);cursor:pointer;transition:background .2s}.chat-header-btn:hover{background:var(--color-pink-light)}.chat-clear-btn{color:#c62828;border-color:#ffcdd2}.chat-clear-btn:hover{background:#ffcdd2}.chat-header-spacer{flex:1}.chat-viewing-badge{display:flex;align-items:center;gap:6px;font-size:.8rem;font-weight:700;color:var(--color-brown-light)}.chat-back-btn{background:var(--color-teal-light);border:none;border-radius:8px;padding:2px 8px;font-size:.75rem;font-family:var(--font);font-weight:700;cursor:pointer;color:var(--color-brown)}.chat-history-panel{display:flex;flex-wrap:wrap;gap:6px;padding:10px 12px;background:var(--color-teal-light);border-bottom:1px solid var(--color-teal);flex-shrink:0}.chat-history-empty{font-size:.8rem;color:var(--color-brown-light);margin:0}.chat-history-day{background:var(--color-card);border:1px solid var(--color-teal);border-radius:16px;padding:4px 12px;font-size:.75rem;font-family:var(--font);font-weight:600;cursor:pointer;transition:all .2s}.chat-history-day:hover{background:var(--color-teal);color:#fff}.chat-history-day.active{background:var(--color-teal);color:#fff;border-color:var(--color-teal)}.chat-readonly-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;font-size:.85rem;font-weight:600;color:var(--color-brown-light);background:var(--color-teal-light);border-radius:var(--radius-sm)}.tts-toggle{background:var(--color-card);border:2px solid var(--color-pink-light);border-radius:50%;width:36px;height:36px;font-size:1.1rem;cursor:pointer;margin-top:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.tts-toggle.active{border-color:var(--color-pink);background:var(--color-pink-light)}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:8px 4px}.chat-bubble{display:flex;align-items:flex-end;gap:8px;max-width:85%}.chat-bubble.user{align-self:flex-end;flex-direction:row-reverse}.chat-bubble.assistant{align-self:flex-start}.chat-avatar-label{font-size:1.2rem;flex-shrink:0;margin-bottom:4px}.chat-bubble-text{padding:12px 16px;border-radius:20px;font-size:.95rem;line-height:1.5;font-weight:600}.chat-bubble.assistant .chat-bubble-text{background:var(--color-card);color:var(--color-brown);border-bottom-left-radius:4px;box-shadow:var(--shadow)}.chat-bubble.user .chat-bubble-text{background:var(--color-pink);color:#fff;border-bottom-right-radius:4px;box-shadow:0 2px 8px #ff8fab4d}.chat-thinking{display:flex;align-items:center;gap:5px;padding:14px 18px}.chat-thinking span{width:8px;height:8px;border-radius:50%;background:var(--color-pink);animation:dot-bounce 1.2s ease-in-out infinite}.chat-thinking span:nth-child(2){animation-delay:.2s}.chat-thinking span:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{transform:translateY(0);opacity:.5}40%{transform:translateY(-8px);opacity:1}}.chat-input-wrapper{flex-shrink:0;position:relative}.autosuggest-list{list-style:none;position:absolute;bottom:calc(100% + 4px);left:0;right:0;background:var(--color-card);border:2px solid var(--color-pink-light);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;z-index:20}.autosuggest-item{padding:11px 16px;font-size:.92rem;font-weight:600;color:var(--color-brown);cursor:pointer;transition:background .15s;border-bottom:1px solid var(--color-pink-light)}.autosuggest-item:last-child{border-bottom:none}.autosuggest-item:hover,.autosuggest-item.active{background:var(--color-pink-light);color:var(--color-brown)}.chat-input-row{display:flex;gap:10px;padding:12px 0 8px}.chat-input{flex:1;padding:14px 18px;border:2px solid var(--color-pink-light);border-radius:50px;font-family:var(--font);font-size:1rem;font-weight:600;background:var(--color-card);color:var(--color-brown);outline:none;transition:border-color .2s}.chat-input:focus{border-color:var(--color-pink)}.chat-input::placeholder{color:#c4a882}.chat-input:disabled{opacity:.6}.chat-send-btn{padding:14px 18px;flex-shrink:0;font-size:1.1rem}.btn-sm{padding:8px 16px;font-size:.85rem}.question-slider{display:flex;flex-direction:column;gap:6px;margin-top:10px;width:100%;max-width:320px}.question-chip{padding:8px 14px;background:var(--color-card);border:2px dashed var(--color-pink);border-radius:50px;font-family:var(--font);font-size:.83rem;font-weight:700;color:var(--color-brown-light);cursor:pointer;opacity:0;transform:translateY(4px);transition:opacity .28s ease,transform .28s ease,background .15s,color .15s;text-align:center;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.question-chip.visible{opacity:1;transform:translateY(0)}.question-chip.fading{opacity:0;transform:translateY(-4px)}.question-chip:hover{background:var(--color-pink-light);color:var(--color-brown);border-style:solid}.import-export-card{margin-top:8px}.import-export-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.import-success{margin-top:10px;font-size:.88rem;font-weight:700;color:var(--color-success)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#3d2b1f59;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--color-card);border-radius:var(--radius);box-shadow:0 12px 40px #3d2b1f2e;padding:28px 24px;max-width:420px;width:100%;display:flex;flex-direction:column;gap:14px}.modal-title{font-size:1.15rem;font-weight:800;color:var(--color-brown)}.modal-body{font-size:.92rem;color:var(--color-brown);line-height:1.5}.modal-info{background:#a8dadc26;border-radius:var(--radius-sm);padding:10px 14px;display:flex;flex-direction:column;gap:6px}.modal-info-row{display:flex;justify-content:space-between;font-size:.85rem;font-weight:600;color:var(--color-brown)}.modal-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.modal-hint{font-size:.78rem;color:var(--color-brown-light);line-height:1.5;border-top:1px solid rgba(61,43,31,.08);padding-top:10px}.settings{padding-bottom:24px}.settings-title{font-size:1.4rem;font-weight:800;margin-bottom:16px;color:var(--color-brown)}.settings-input{width:100%;padding:12px 16px;border:2px solid var(--color-pink-light);border-radius:var(--radius-sm);font-family:var(--font);font-size:1rem;font-weight:600;background:var(--color-bg);color:var(--color-brown);outline:none;margin-bottom:8px;transition:border-color .2s}.settings-input:focus{border-color:var(--color-pink)}.settings-hint{font-size:.85rem;color:var(--color-brown-light);font-weight:600}.timetable{display:flex;flex-direction:column;gap:20px;margin-top:16px}.timetable-day-name{font-size:1rem;font-weight:800;color:var(--color-pink);margin-bottom:10px}.timetable-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.timetable-period{width:24px;font-size:.85rem;font-weight:700;color:var(--color-brown-light);flex-shrink:0;text-align:right}.timetable-input{flex:1;padding:8px 12px;border:1.5px solid var(--color-teal);border-radius:var(--radius-sm);font-family:var(--font);font-size:.9rem;font-weight:600;background:var(--color-bg);color:var(--color-brown);outline:none;transition:border-color .2s}.timetable-input:focus{border-color:var(--color-pink)}.timetable-input::placeholder{color:#c4a882}.settings-save{width:100%;justify-content:center;margin-top:8px;padding:16px;font-size:1.05rem}.btn-success{background:var(--color-success);color:#fff;box-shadow:0 4px 12px #4caf5059}.notes{padding-bottom:32px}.notes-title{font-size:1.4rem;font-weight:800;color:var(--color-brown);margin-bottom:24px}.notes-section{margin-bottom:32px}.notes-section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid rgba(255,143,171,.25)}.notes-section-label{font-size:1rem;font-weight:800;color:var(--color-brown)}.notes-section-count{font-size:.72rem;font-weight:800;background:#ff8fab33;color:#c0486a;border-radius:999px;padding:1px 8px;min-width:20px;text-align:center}.notes-empty{font-size:.85rem;color:#c4a882;font-style:italic;padding:4px 0}.notes-cards{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start}.note-card{background:var(--color-card);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px;flex:1 1 260px;min-width:220px;max-width:340px;display:flex;flex-direction:column;gap:10px;border:1.5px solid rgba(255,143,171,.18)}.note-card-homework{border-color:#a8dadc99;background:linear-gradient(135deg,var(--color-card) 80%,rgba(168,218,220,.12))}.note-card-header{display:flex;align-items:center;gap:8px}.note-title-input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:.95rem;font-weight:800;color:var(--color-brown);outline:none;padding:0}.note-title-input::placeholder{color:#d4b896}.note-remove-btn{background:none;border:none;cursor:pointer;font-size:.75rem;color:#d4b896;padding:2px 5px;border-radius:4px;transition:color .15s}.note-remove-btn:hover{color:var(--color-pink)}.note-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.note-meta-field{display:flex;align-items:center;gap:4px;cursor:pointer}.note-meta-icon{font-size:.8rem}.note-date-input{border:none;background:#ff8fab1a;border-radius:6px;font-family:var(--font);font-size:.75rem;font-weight:700;color:#c0486a;padding:3px 6px;outline:none;cursor:pointer}.note-date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6}.note-date-clear{background:none;border:none;cursor:pointer;font-size:.65rem;color:#d4b896;padding:0 2px;transition:color .15s}.note-date-clear:hover{color:var(--color-pink)}.note-homework-label{display:flex;align-items:center;gap:5px;font-size:.75rem;font-weight:700;color:var(--color-teal, #A8DADC);cursor:pointer;-webkit-user-select:none;user-select:none}.note-checkbox{accent-color:var(--color-pink);width:15px;height:15px;flex-shrink:0;cursor:pointer}.note-items{list-style:none;display:flex;flex-direction:column;gap:6px}.note-item{display:flex;align-items:center;gap:8px}.note-item-input{flex:1;border:none;border-bottom:1px solid rgba(61,43,31,.1);background:transparent;font-family:var(--font);font-size:.88rem;color:var(--color-brown);outline:none;padding:2px 0;transition:border-color .15s}.note-item-input:focus{border-bottom-color:var(--color-pink)}.note-item-input::placeholder{color:#d4b896}.note-item-done{text-decoration:line-through;color:#c4a882}.note-item-remove{background:none;border:none;cursor:pointer;font-size:.65rem;color:#d4b896;padding:0 2px;opacity:0;transition:opacity .15s,color .15s}.note-item:hover .note-item-remove{opacity:1}.note-item-remove:hover{color:var(--color-pink)}.note-add-item-btn{background:none;border:none;cursor:pointer;font-family:var(--font);font-size:.78rem;font-weight:700;color:#c4a882;padding:0;text-align:left;transition:color .15s}.note-add-item-btn:hover{color:var(--color-pink)}.note-add-card-btn{flex:1 1 260px;min-width:220px;max-width:340px;background:#ff8fab12;border:2px dashed rgba(255,143,171,.3);border-radius:var(--radius);padding:20px;cursor:pointer;font-family:var(--font);font-size:.88rem;font-weight:700;color:#c4a882;transition:all .2s}.note-add-card-btn:hover{background:#ff8fab24;border-color:var(--color-pink);color:var(--color-pink)}.calendar{padding:16px;display:flex;flex-direction:column;gap:16px}.cal-header{display:flex;align-items:center;justify-content:space-between}.cal-title{font-size:1.4rem;font-weight:800;color:var(--color-brown)}.cal-empty{text-align:center;color:var(--color-brown-light);font-size:.95rem;padding:32px 16px}.cal-filters{display:flex;gap:6px;flex-wrap:wrap}.cal-filter-chip{font-size:1.1rem;width:36px;height:36px;border:2px solid #E0D4C4;border-radius:50%;background:var(--color-card);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;opacity:.4}.cal-filter-chip.active{opacity:1}.cal-day-group{display:flex;flex-direction:column;gap:8px}.cal-day-label{font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#a0917f;padding-bottom:4px;border-bottom:1px solid #EEE}.cal-card{display:flex;background:var(--color-card);border-radius:var(--radius-sm);box-shadow:var(--shadow);overflow:hidden;transition:transform .15s}.cal-card:hover{transform:translateY(-1px)}.cal-card.cal-today{background:#fff0f5}.cal-card.cal-urgent{background:#fef2f2}.cal-card.cal-soon{background:#fffbeb}.cal-card.cal-past{opacity:.6}.cal-card-color{width:5px;flex-shrink:0}.cal-card-content{flex:1;padding:12px 14px;min-width:0}.cal-card-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}.cal-card-cat{font-size:1.1rem;flex-shrink:0}.cal-card-title{font-size:1rem;font-weight:800;color:var(--color-brown);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-card-recur{font-size:.8rem;opacity:.6}.cal-card-countdown{font-size:.78rem;font-weight:700;color:var(--color-brown-light);flex-shrink:0}.cal-card-details{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.cal-card-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--color-pink-light);color:#c0486a;padding:2px 8px;border-radius:20px}.cal-card-type{background:var(--color-teal-light);color:#457b7d}.cal-card-time{font-size:.8rem;font-weight:600;color:var(--color-brown-light)}.cal-card-date{font-size:.75rem;color:#a0917f}.cal-card-notes{font-size:.8rem;color:var(--color-brown-light);margin:4px 0 0;font-style:italic}.cal-card-actions{display:flex;flex-direction:column;gap:2px;padding:8px 6px}.cal-action-btn{background:none;border:none;cursor:pointer;font-size:.9rem;padding:4px;border-radius:6px;transition:background .15s}.cal-action-btn:hover{background:var(--color-pink-light)}.cal-delete-btn{font-size:.7rem;opacity:.5;margin-top:auto}.cal-delete-btn:hover{opacity:1;background:#ffcdd2!important}.cal-confirm-modal{max-width:340px;text-align:center}.cal-confirm-text{font-size:.9rem;color:var(--color-brown);margin:12px 0}.cal-confirm-hint{font-size:.82rem;color:#9e9e9e;margin-bottom:12px}.cal-delete-options{display:flex;flex-direction:column;gap:8px;margin-top:8px}.cal-delete-option{width:100%;justify-content:center;text-align:center}.cal-delete-series{background:#c62828;color:#fff;border:none}.cal-delete-series:hover{background:#b71c1c}.cal-progress-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.cal-progress-btn{font-family:var(--font);font-size:.72rem;font-weight:700;padding:3px 10px;border:2px solid #E0D4C4;border-radius:20px;background:var(--color-bg);cursor:pointer;color:var(--color-brown-light);transition:all .15s}.cal-progress-btn:hover{border-color:var(--color-pink);color:var(--color-pink)}.cal-progress-btn.active{font-weight:800}.cal-past-section{margin-top:8px}.cal-past-toggle{background:none;border:none;font-family:var(--font);font-size:.82rem;font-weight:700;color:#a0917f;cursor:pointer;padding:4px 0}.cal-cat-picker{display:flex;gap:6px;flex-wrap:wrap}.cal-cat-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 10px;border:2px solid #E0D4C4;border-radius:var(--radius-sm);background:var(--color-card);cursor:pointer;font-size:1.2rem;transition:all .15s}.cal-cat-btn.active{font-weight:800}.cal-cat-label{font-size:.6rem;font-weight:700;color:var(--color-brown-light)}.cal-form{display:flex;flex-direction:column;gap:12px}.cal-form-label{display:flex;flex-direction:column;gap:5px;font-size:.82rem;font-weight:700;color:var(--color-brown-light)}.cal-form-input{font-family:var(--font);font-size:.95rem;padding:9px 12px;border:2px solid #E0D4C4;border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-brown);outline:none;transition:border-color .15s;width:100%}.cal-form-input:focus{border-color:var(--color-pink)}.cal-form-textarea{resize:vertical}.cal-form-row{display:flex;gap:12px}.cal-form-flex{flex:1}.cal-recurrence{display:flex;gap:6px;flex-wrap:wrap}.cal-rec-btn{font-family:var(--font);font-size:.78rem;font-weight:600;padding:5px 12px;border:2px solid #E0D4C4;border-radius:20px;background:var(--color-bg);cursor:pointer;color:var(--color-brown-light);transition:all .15s}.cal-rec-btn.active{border-color:var(--color-teal);background:var(--color-teal-light);color:var(--color-brown);font-weight:700}.cal-rec-btn:hover{border-color:var(--color-teal)}.packlists{padding:16px;display:flex;flex-direction:column;gap:16px}.pl-tabs{display:flex;gap:8px;flex-wrap:wrap}.pl-tab{font-family:var(--font);font-size:.82rem;font-weight:700;padding:8px 14px;border:2px solid #E0D4C4;border-radius:20px;background:var(--color-bg);cursor:pointer;color:var(--color-brown-light);display:flex;align-items:center;gap:6px;transition:all .15s}.pl-tab:hover{border-color:var(--color-pink);color:var(--color-pink)}.pl-tab.active{background:var(--color-pink);border-color:var(--color-pink);color:#fff}.pl-tab-count{font-size:.7rem;background:#0000001f;padding:1px 6px;border-radius:10px}.pl-tab.active .pl-tab-count{background:#ffffff40}.pl-card{padding:16px;display:flex;flex-direction:column;gap:12px}.pl-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.pl-name-input{font-family:var(--font);font-size:1rem;font-weight:800;color:var(--color-brown);border:none;background:transparent;outline:none;border-bottom:2px solid transparent;padding-bottom:2px;transition:border-color .15s;flex:1}.pl-name-input:focus{border-bottom-color:var(--color-pink)}.pl-card-actions{display:flex;gap:4px}.pl-progress-bar-wrap{position:relative;background:#f0e8dc;border-radius:10px;height:14px;overflow:hidden}.pl-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-teal),#6EE7B7);border-radius:10px;transition:width .4s ease}.pl-progress-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:800;color:var(--color-brown);mix-blend-mode:multiply}.pl-items{list-style:none;display:flex;flex-direction:column;gap:6px}.pl-item{display:flex;align-items:center;gap:8px}.pl-item-input{flex:1;font-family:var(--font);font-size:.9rem;border:none;background:transparent;outline:none;border-bottom:1px solid #E8DDD0;padding:3px 0;color:var(--color-brown);transition:border-color .15s}.pl-item-input:focus{border-bottom-color:var(--color-pink)}.pl-item-input.pl-item-done{text-decoration:line-through;color:#b0a090}.pl-template-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.pl-template-btn{font-family:var(--font);font-size:.88rem;font-weight:700;padding:14px 12px;border:2px solid #E0D4C4;border-radius:var(--radius-sm);background:var(--color-bg);cursor:pointer;color:var(--color-brown);display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .15s}.pl-template-btn:hover{border-color:var(--color-pink);background:#fff0f5}.pl-template-count{font-size:.7rem;font-weight:600;color:#a0917f}.pl-template-blank{border-style:dashed}.horse-diary{padding:16px;display:flex;flex-direction:column;gap:16px}.horse-profile-card{background:linear-gradient(135deg,#fff5f0,#ffede4);border:2px solid #FBBF8C}.horse-profile-header{display:flex;align-items:center;gap:14px}.horse-photo-wrapper{flex-shrink:0}.horse-photo{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid rgba(251,191,140,.5);box-shadow:0 3px 10px #0000001a}.horse-photo-placeholder{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#fbbf8c,#f59e5e);display:flex;align-items:center;justify-content:center;font-size:2.2rem;border:3px solid rgba(251,191,140,.5)}.horse-profile-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.horse-profile-name{font-size:1.3rem;font-weight:800;color:var(--color-brown);margin:0}.horse-profile-subtitle{font-size:.85rem;font-weight:600;color:var(--color-brown-light)}.horse-profile-age{font-size:.78rem;font-weight:700;color:#c2410c}.horse-profile-edit{flex-shrink:0;align-self:flex-start}.horse-steckbrief{margin-top:14px;padding-top:12px;border-top:1px solid rgba(251,191,140,.3);display:flex;flex-direction:column;gap:6px}.horse-steckbrief-row{display:flex;gap:8px;font-size:.85rem}.horse-steckbrief-label{font-weight:700;color:var(--color-brown-light);min-width:80px;flex-shrink:0}.horse-steckbrief-value{font-weight:600;color:var(--color-brown)}.horse-photo-upload-area{display:flex;align-items:center;justify-content:center;width:120px;height:120px;border-radius:50%;border:3px dashed rgba(251,191,140,.5);cursor:pointer;overflow:hidden;margin:0 auto 8px;transition:border-color .2s}.horse-photo-upload-area:hover{border-color:#f59e5e}.horse-photo-upload-preview{width:100%;height:100%;object-fit:cover}.horse-photo-upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:2rem;color:var(--color-brown-light)}.horse-photo-upload-placeholder span{font-size:.72rem;font-weight:700}.horse-gender-btns{display:flex;gap:8px;flex-wrap:wrap}.horse-color-chips{display:flex;gap:7px;flex-wrap:wrap}.horse-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.horse-entries{display:flex;flex-direction:column;gap:10px}.horse-entry-card{background:var(--color-card);border-radius:var(--radius-sm);padding:14px 16px;box-shadow:var(--shadow);border-left:4px solid var(--color-teal);display:flex;flex-direction:column;gap:8px;transition:transform .15s}.horse-entry-card:hover{transform:translateY(-1px)}.horse-entry-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.horse-entry-date{font-size:.88rem;font-weight:700;color:var(--color-brown);display:block}.horse-entry-mood{font-size:.78rem;color:var(--color-brown-light);margin-top:2px;display:block}.horse-entry-types{display:flex;flex-wrap:wrap;gap:5px}.horse-type-pill{font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:20px;background:var(--color-teal-light);color:#2a8a8c}.horse-entry-notes{font-size:.85rem;color:var(--color-brown-light);line-height:1.5}.horse-modal{max-width:500px;max-height:90vh;overflow-y:auto}.horse-type-grid{display:flex;flex-wrap:wrap;gap:7px;margin-top:2px}.horse-type-select-btn{font-family:var(--font);font-size:.78rem;font-weight:700;padding:6px 12px;border:2px solid #E0D4C4;border-radius:20px;background:var(--color-bg);cursor:pointer;color:var(--color-brown-light);transition:all .15s}.horse-type-select-btn:hover{border-color:var(--color-teal);color:#2a8a8c}.horse-type-select-btn.selected{background:var(--color-teal);border-color:var(--color-teal);color:#fff}.horse-mood-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:2px}.horse-mood-btn{font-family:var(--font);font-size:.82rem;font-weight:700;padding:7px 14px;border:2px solid #E0D4C4;border-radius:20px;background:var(--color-bg);cursor:pointer;color:var(--color-brown-light);transition:all .15s}.horse-mood-btn:hover{border-color:var(--color-pink);color:var(--color-pink)}.horse-mood-btn.selected{background:var(--color-pink-light);border-color:var(--color-pink);color:#c0486a}.horse-notes-input{resize:vertical;min-height:72px}.briefing-exams{margin-top:12px;padding:12px 14px;background:#ffffff8c;border-radius:var(--radius-sm);border-left:3px solid #FCD34D}.briefing-exams-label{display:block;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:#92400e;margin-bottom:8px}.briefing-exams-list{list-style:none;display:flex;flex-direction:column;gap:5px}.briefing-exam-item{display:flex;align-items:center;gap:8px;font-size:.85rem}.briefing-exam-when{font-weight:800;min-width:72px;color:#92400e}.briefing-exam-item.today .briefing-exam-when{color:#c0486a}.briefing-exam-item.soon .briefing-exam-when{color:#c2410c}.briefing-exam-info{color:var(--color-brown)}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:24px;background:var(--color-bg)}.login-card{background:var(--color-card);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:48px 32px;text-align:center;max-width:360px;width:100%}.login-title{font-size:1.8rem;color:var(--color-brown);margin-top:16px}.login-subtitle{color:var(--color-brown-light);font-size:1rem;margin-top:4px;margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{padding:14px 16px;border:2px solid var(--color-pink-light);border-radius:var(--radius-sm);font-family:var(--font);font-size:1rem;background:var(--color-bg);color:var(--color-brown);outline:none;transition:border-color .2s}.login-input:focus{border-color:var(--color-pink)}.login-btn{padding:14px;border:none;border-radius:var(--radius-sm);background:var(--color-pink);color:#fff;font-family:var(--font);font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s,transform .1s}.login-btn:hover:not(:disabled){background:#ff6b8a}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{margin-top:16px;color:#dc2626;font-weight:700;font-size:.9rem}.mini-player{position:sticky;bottom:0;left:0;right:0;background:var(--color-card);border-top:2px solid var(--color-pink-light);box-shadow:0 -4px 16px #3d2b1f1a;display:flex;align-items:center;padding:8px 16px;gap:12px;z-index:50;min-height:56px}.mini-player-progress{position:absolute;top:0;left:0;height:3px;background:var(--color-pink);transition:width .3s linear;border-radius:0 2px 2px 0}.mini-player-cover{position:relative;width:40px;height:40px;border-radius:8px;flex-shrink:0;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#ffffffd9;box-shadow:0 2px 6px #0000001a}.mini-player-info{flex:1;min-width:0;cursor:pointer;display:flex;flex-direction:column;gap:2px}.mini-player-title{font-size:.88rem;font-weight:700;color:var(--color-brown);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-player-artist{font-size:.75rem;font-weight:600;color:var(--color-brown-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-player-controls{display:flex;gap:4px;flex-shrink:0}.mini-player-btn{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:4px 8px;border-radius:8px;transition:background .15s}.mini-player-btn:hover{background:var(--color-pink-light)}.app:has(.mini-player) .app-main{padding-bottom:64px}.music-player{padding:0 0 24px;display:flex;flex-direction:column;gap:12px}.music-loading,.music-unavailable{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 16px;gap:12px}.music-view-tabs{display:flex;gap:8px}.music-view-tab{flex:1;font-family:var(--font);font-size:.82rem;font-weight:700;padding:10px 14px;border:2px solid #E0D4C4;border-radius:20px;background:var(--color-bg);cursor:pointer;color:var(--color-brown-light);text-align:center;transition:all .15s}.music-view-tab:hover{border-color:var(--color-pink);color:var(--color-pink)}.music-view-tab.active{background:var(--color-pink);border-color:var(--color-pink);color:#fff}.music-search{width:100%;padding:12px 16px;border:2px solid var(--color-pink-light);border-radius:var(--radius-sm);font-family:var(--font);font-size:.95rem;font-weight:600;background:var(--color-card);color:var(--color-brown);outline:none;transition:border-color .2s}.music-search:focus{border-color:var(--color-pink)}.music-search::placeholder{color:#c4a882}.card-music{background:linear-gradient(135deg,#f3e8ff,#ede5ff);border:2px solid #C4B5FD}.now-playing-hero{display:flex;align-items:center;gap:16px;margin-bottom:16px}.now-playing-art{position:relative;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#ffffffd9;flex-shrink:0;box-shadow:0 4px 12px #00000026;overflow:hidden}.cover-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1}.now-playing-info{display:flex;flex-direction:column;gap:4px;min-width:0}.now-playing-title{font-size:1.1rem;font-weight:800;color:var(--color-brown);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.now-playing-artist{font-size:.88rem;font-weight:600;color:var(--color-brown-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.now-playing-album{font-size:.75rem;font-weight:600;color:#a78bfa;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slider{position:relative;width:100%;height:24px;cursor:pointer;display:flex;align-items:center;touch-action:none;-webkit-user-select:none;user-select:none}.slider-thin{height:18px}.slider-track{position:relative;width:100%;height:6px;background:#c4b5fd4d;border-radius:3px;overflow:visible}.slider-thin .slider-track{height:4px;border-radius:2px}.slider-fill{height:100%;background:#8b5cf6;border-radius:3px;transition:width .1s linear}.slider-knob{position:absolute;top:50%;width:16px;height:16px;background:#8b5cf6;border:3px solid white;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 6px #8b5cf659;transition:transform .1s}.slider:hover .slider-knob{transform:translate(-50%,-50%) scale(1.15)}.slider-progress{margin-bottom:2px}.slider-volume{flex:1}.progress-times{display:flex;justify-content:space-between;font-size:.72rem;font-weight:600;color:var(--color-brown-light);margin-bottom:8px}.player-controls{display:flex;align-items:center;justify-content:center;gap:6px}.player-btn{background:none;border:none;cursor:pointer;padding:8px;border-radius:10px;transition:background .15s,color .15s,transform .1s;color:var(--color-brown);display:flex;align-items:center;justify-content:center;opacity:.7}.player-btn:hover{background:#8b5cf61f;opacity:1}.player-btn:active{transform:scale(.92)}.player-btn.active{opacity:1;color:#8b5cf6;background:#8b5cf61f}.player-btn-sm{padding:6px}.player-btn-main{opacity:1;background:#8b5cf6;color:#fff;border-radius:50%;width:56px;height:56px;padding:0;box-shadow:0 4px 14px #8b5cf666}.player-btn-main:hover{background:#7c3aed;opacity:1;transform:scale(1.05)}.player-btn-main:active{transform:scale(.95)}.volume-row{display:flex;align-items:center;gap:6px;margin-top:8px;padding:0 4px}.volume-row .slider-fill{background:#a78bfa}.artist-list{display:flex;flex-direction:column;gap:6px}.artist-card{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--color-card);border:1.5px solid rgba(196,181,253,.2);border-radius:var(--radius-sm);box-shadow:var(--shadow);cursor:pointer;font-family:var(--font);transition:all .15s;text-align:left;width:100%}.artist-card:hover{border-color:#c4b5fd;transform:translateY(-1px)}.artist-name{font-size:.95rem;font-weight:700;color:var(--color-brown)}.artist-count{font-size:.78rem;font-weight:600;color:var(--color-brown-light);flex-shrink:0}.song-list-view{display:flex;flex-direction:column;gap:8px}.song-list-header{display:flex;align-items:center;gap:10px}.btn-back{font-family:var(--font);font-size:.82rem;font-weight:700;background:none;border:2px solid #E0D4C4;border-radius:20px;padding:6px 14px;cursor:pointer;color:var(--color-brown-light);transition:all .15s}.btn-back:hover{border-color:var(--color-pink);color:var(--color-pink)}.song-list-title{flex:1;font-size:1.1rem;font-weight:800;color:var(--color-brown);margin:0}.btn-play-all{font-family:var(--font);font-size:.82rem;font-weight:700;background:var(--color-pink);color:#fff;border:none;border-radius:20px;padding:6px 14px;cursor:pointer;transition:background .15s}.btn-play-all:hover{background:#ff6b8a}.song-list{display:flex;flex-direction:column}.song-row{display:flex;align-items:center;border-bottom:1px solid rgba(61,43,31,.06);transition:background .1s}.song-row:hover{background:#c4b5fd14}.song-row.active{background:#c4b5fd26}.song-row-info{flex:1;display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;min-width:0}.song-row-num{font-size:.78rem;font-weight:600;color:var(--color-brown-light);width:24px;text-align:right;flex-shrink:0}.song-row-title{font-size:.9rem;font-weight:600;color:var(--color-brown);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.song-row-artist{font-size:.78rem;font-weight:600;color:var(--color-brown-light);flex-shrink:0}.song-playing-indicator{color:#8b5cf6;font-weight:800}.format-badge{display:inline-block;font-size:.6rem;font-weight:800;letter-spacing:.04em;padding:1px 6px;border-radius:4px;margin-left:6px;vertical-align:middle;flex-shrink:0}.format-badge-sm{font-size:.55rem;padding:0 4px;margin-left:4px}.format-alac,.format-flac{background:#eab30826;color:#a16207}.format-aac{background:#8b5cf61f;color:#7c3aed}.format-mp3{background:#3b82f61f;color:#2563eb}.format-ogg{background:#22c55e1f;color:#16a34a}.format-wav{background:#f43f5e1f;color:#e11d48}.album-header{font-size:.78rem;font-weight:700;color:#a78bfa;padding:10px 12px 4px;text-transform:uppercase;letter-spacing:.04em;border-top:1px solid rgba(196,181,253,.2);margin-top:4px}.song-row-add,.song-row-remove{background:none;border:none;font-size:1rem;cursor:pointer;padding:8px 12px;color:var(--color-brown-light);transition:color .15s;flex-shrink:0}.song-row-add:hover{color:var(--color-teal)}.song-row-remove:hover{color:var(--color-pink)}.queue-empty{text-align:center;padding:32px 16px;color:var(--color-brown-light);font-size:.95rem}.queue-list{display:flex;flex-direction:column}.card-song-of-day{background:linear-gradient(135deg,#f3e8ff,#ede5ff);border:2px solid #C4B5FD}.song-of-day-content{display:flex;align-items:center;gap:12px}.song-of-day-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.song-of-day-title{font-size:1rem;font-weight:700;color:var(--color-brown);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-of-day-artist{font-size:.85rem;font-weight:600;color:var(--color-brown-light)}.song-of-day-actions{display:flex;gap:6px;flex-shrink:0}.song-of-day-play{padding:8px 16px;font-size:.88rem}.song-of-day-random{padding:8px 10px;font-size:.88rem}.chat-music-results{display:flex;flex-direction:column;gap:6px;margin-top:10px}.chat-music-card{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#8b5cf614;border:1.5px solid rgba(196,181,253,.3);border-radius:12px;cursor:pointer;font-family:var(--font);text-align:left;transition:all .15s}.chat-music-card:hover{background:#8b5cf626;border-color:#c4b5fd}.chat-music-art{position:relative;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#ffffffe6;flex-shrink:0;overflow:hidden}.chat-music-info{display:flex;flex-direction:column;gap:1px;min-width:0}.chat-music-title{font-size:.85rem;font-weight:700;color:var(--color-brown);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-music-artist{font-size:.72rem;font-weight:600;color:var(--color-brown-light)}.chat-bubble{position:relative}.chat-delete-btn{position:absolute;top:4px;right:4px;background:none;border:none;cursor:pointer;font-size:.7rem;color:var(--color-brown-light);opacity:0;padding:2px 5px;border-radius:4px;transition:opacity .15s,color .15s}.chat-bubble:hover .chat-delete-btn{opacity:.5}.chat-delete-btn:hover{opacity:1!important;color:var(--color-pink);background:#ff8fab1a}.chat-generated-image-wrap{margin-top:10px;border-radius:12px;overflow:hidden}.chat-generated-image{width:100%;max-width:400px;border-radius:12px;cursor:pointer;transition:transform .15s;display:block}.chat-generated-image:hover{transform:scale(1.02)}.gallery{padding:16px;display:flex;flex-direction:column;gap:16px;min-height:100vh}.gallery-title{font-size:1.4rem;font-weight:800;color:var(--color-brown)}.gallery-loading{display:flex;flex-direction:column;align-items:center;padding:48px 16px;gap:12px}.gallery-empty{text-align:center;padding:32px 16px}.gallery-hint{font-size:.9rem;color:var(--color-pink);font-weight:700;margin-top:8px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.gallery-item{display:flex;flex-direction:column;gap:6px;background:var(--color-card);border-radius:var(--radius-sm);box-shadow:var(--shadow);overflow:hidden}.gallery-thumb{width:100%;aspect-ratio:1;object-fit:cover;cursor:pointer;transition:transform .15s}.gallery-thumb:hover{transform:scale(1.03)}.gallery-item-info{display:flex;align-items:center;padding:6px 10px 8px;gap:6px}.gallery-prompt{flex:1;font-size:.72rem;font-weight:600;color:var(--color-brown-light);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-delete{background:none;border:none;cursor:pointer;font-size:.8rem;padding:2px;opacity:.4;transition:opacity .15s}.gallery-delete:hover{opacity:1}.gallery-fullscreen{background:var(--color-card);border-radius:var(--radius);box-shadow:0 12px 40px #0003;padding:16px;max-width:520px;width:90%;display:flex;flex-direction:column;gap:12px;align-items:center}.gallery-fullscreen-img{width:100%;border-radius:var(--radius-sm)}.gallery-fullscreen-prompt{font-size:.88rem;font-weight:600;color:var(--color-brown);text-align:center}.notes-view-toggle{display:flex;gap:8px;margin-bottom:8px}
