:root{--bg-primary:#0d0d0f;--bg-secondary:#16161a;--bg-tertiary:#1e1e24;--surface-raised:#1a1a20;--surface-border:#2a2a32;--text-primary:#f0f0f0;--text-secondary:#8a8a96;--text-muted:#555560;--accent-coral:#ff6b6b;--accent-coral-soft:#ff6b6b33;--accent-coral-dim:#ff6b6b1a;--accent-amber:#ffb347;--accent-amber-soft:#ffb34733;--accent-amber-dim:#ffb3471a;--status-green:#4ade80;--status-amber:#fbbf24;--status-red:#f87171;--emotion-excited:#ff6b6b;--emotion-calm:#60a5fa;--emotion-tired:#a78bfa;--emotion-focused:#ffb347;--emotion-confused:#fb923c;--emotion-playful:#f472b6;--emotion-serious:#94a3b8;--emotion-frustrated:#ef4444;--emotion-satisfied:#4ade80;--emotion-curious:#22d3ee;--font-sans:"Inter", "Pretendard", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:28px;--space-8:32px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 8px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-glow-coral:0 0 12px #ff6b6b4d;--shadow-glow-amber:0 0 12px #ffb3474d;--transition-fast:.12s ease;--transition-normal:.2s ease;--transition-slow:.35s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;color:inherit;background:0 0;border:none}ul,ol{list-style:none}img{max-width:100%;display:block}code,pre{font-family:var(--font-mono)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--surface-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--surface-border) var(--bg-secondary)}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--surface-border);z-index:100;flex-direction:column;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar__header{align-items:center;gap:var(--space-3);padding:var(--space-6);border-bottom:1px solid var(--surface-border);display:flex}.sidebar__logo{border-radius:var(--radius-md);background:var(--accent-coral);width:36px;height:36px;color:var(--bg-primary);font-family:var(--font-sans);transition:all var(--transition-normal);justify-content:center;align-items:center;font-size:18px;font-weight:800;display:flex}.sidebar__logo--dim{background:var(--text-muted);opacity:.5}.sidebar__title{font-family:var(--font-sans);color:var(--text-primary);letter-spacing:2px;font-size:18px;font-weight:700}.sidebar__nav{gap:var(--space-1);padding:var(--space-4) var(--space-3);flex-direction:column;flex:1;display:flex}.sidebar__link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-sans);transition:all var(--transition-normal);border-left:3px solid #0000;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar__link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.sidebar__link--active{color:var(--text-primary);background:var(--bg-tertiary);border-left-color:var(--accent-coral)}.sidebar__link-icon{text-align:center;width:20px;font-size:16px}.sidebar__link-label{white-space:nowrap}.sidebar__footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--surface-border)}.sidebar__status{align-items:center;gap:var(--space-2);display:flex}.sidebar__dot{border-radius:var(--radius-full);width:8px;height:8px;transition:all var(--transition-normal)}.sidebar__dot--awake{background:var(--status-green);box-shadow:0 0 6px var(--status-green);animation:2s ease-in-out infinite pulse-dot}.sidebar__dot--waking{background:var(--accent-amber);box-shadow:0 0 6px var(--accent-amber);animation:.6s ease-in-out infinite pulse-dot}.sidebar__dot--sleeping{background:var(--text-muted);opacity:.5}.sidebar__status-text{font-family:var(--font-sans);color:var(--text-muted);font-size:12px}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}@media (width<=768px){.sidebar{display:none}}.mobile-tabbar{display:none}@media (width<=768px){.mobile-tabbar{background:var(--bg-secondary);border-top:1px solid var(--surface-border);z-index:200;height:60px;padding-bottom:env(safe-area-inset-bottom);justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-tabbar__tab{padding:var(--space-2);color:var(--text-muted);font-family:var(--font-sans);transition:color var(--transition-fast);flex-direction:column;flex:1;align-items:center;gap:2px;text-decoration:none;display:flex}.mobile-tabbar__tab--active{color:var(--accent-coral)}.mobile-tabbar__icon{font-size:20px}.mobile-tabbar__label{font-size:10px;font-weight:500}.mobile-tabbar__status{border-radius:var(--radius-full);width:6px;height:6px;position:absolute;top:8px;right:12px}.mobile-tabbar__status--awake{background:var(--status-green);box-shadow:0 0 4px var(--status-green)}.mobile-tabbar__status--waking{background:var(--accent-amber);animation:.6s ease-in-out infinite pulse-dot}.mobile-tabbar__status--sleeping{background:var(--text-muted);opacity:.5}}.garasa-toast{top:var(--space-6);align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);border-radius:var(--radius-lg);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;z-index:1000;font-weight:600;animation:.3s ease-out toast-slide-in;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080}.garasa-toast--sleeping{background:var(--bg-tertiary);color:var(--text-muted);border:1px solid var(--surface-border)}.garasa-toast--awake,.garasa-toast--waking{background:linear-gradient(135deg, var(--accent-coral-dim), var(--bg-secondary));color:var(--accent-coral);border:1px solid var(--accent-coral)}.garasa-toast__icon{font-size:var(--text-lg)}.garasa-toast__text{white-space:nowrap}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%)translateY(-20px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.layout{min-height:100vh;display:flex}.layout__main{padding:var(--space-6);background:var(--bg-primary);flex:1;margin-left:240px;overflow-y:auto}@media (width<=768px){.layout__main{margin-left:0;padding:0 0 60px}}.chat-bubble{gap:var(--space-1);flex-direction:column;max-width:70%;display:flex}.chat-bubble--user{align-self:flex-end;align-items:flex-end}.chat-bubble--user .chat-bubble__content{background:var(--bubble-color,var(--accent-coral));color:var(--bg-primary);border-radius:var(--radius-lg) var(--radius-lg) var(--radius-sm) var(--radius-lg)}.chat-bubble--assistant{align-self:flex-start;align-items:flex-start}.chat-bubble--assistant .chat-bubble__content{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--surface-border);border-radius:var(--radius-lg) var(--radius-lg) var(--radius-lg) var(--radius-sm)}.chat-bubble__name{font-family:var(--font-sans);padding:0 var(--space-1);opacity:.8;font-size:11px;font-weight:600}.chat-bubble__content{padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal)}.chat-bubble__content:hover{box-shadow:var(--shadow-md)}.chat-bubble__text{font-family:var(--font-sans);word-break:break-word;margin:0;font-size:14px;line-height:1.6}.chat-bubble__time{font-family:var(--font-mono);color:var(--text-muted);padding:0 var(--space-1);font-size:11px}@media (width<=768px){.chat-bubble{max-width:85%}.chat-bubble__text{font-size:15px}}.typing-indicator{padding:var(--space-3) var(--space-4);align-items:center;gap:6px;min-width:60px;min-height:40px;display:flex}.typing-indicator__dot{border-radius:var(--radius-full);background:var(--text-muted);width:8px;height:8px;animation:1.4s ease-in-out infinite typing-bounce}.typing-indicator__dot:nth-child(2){animation-delay:.2s}.typing-indicator__dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.chat-list{flex-direction:column;height:100%;display:flex}.chat-list__scroll{max-height:600px;padding:var(--space-4);scrollbar-width:thin;scrollbar-color:var(--surface-border) transparent;flex:1;overflow-y:auto}.chat-list__scroll::-webkit-scrollbar{width:6px}.chat-list__scroll::-webkit-scrollbar-track{background:0 0}.chat-list__scroll::-webkit-scrollbar-thumb{background:var(--surface-border);border-radius:var(--radius-full)}.chat-list__messages{gap:var(--space-3);flex-direction:column;display:flex}.chat-list__load-more{padding-bottom:var(--space-4);justify-content:center;display:flex}.chat-list__load-btn{padding:var(--space-2) var(--space-5);border:1px solid var(--surface-border);border-radius:var(--radius-full);color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-normal);background:0 0;font-size:13px}.chat-list__load-btn:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent-coral)}@media (width<=768px){.chat-list__scroll{max-height:none;padding:var(--space-2);flex:1}.chat-list__messages{gap:var(--space-2)}}.chat-input{gap:var(--space-3);padding:var(--space-4);border-top:1px solid var(--surface-border);background:var(--bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg);display:flex}.chat-input__textarea{background:var(--bg-tertiary);border:1px solid var(--surface-border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);padding:var(--space-3) var(--space-4);resize:none;transition:border-color var(--transition-fast);outline:none;flex:1}.chat-input__textarea:focus{border-color:var(--accent-coral)}.chat-input__textarea::placeholder{color:var(--text-muted)}.chat-input__textarea:disabled{opacity:.5}.chat-input__send{background:var(--accent-coral);color:#fff;border-radius:var(--radius-md);padding:var(--space-3) var(--space-6);font-family:var(--font-sans);font-size:var(--text-sm);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap;border:none;font-weight:600}.chat-input__send:hover:not(:disabled){background:var(--accent-coral-soft)}.chat-input__send:disabled{opacity:.4;cursor:not-allowed}@media (width<=768px){.chat-input{padding:var(--space-2) var(--space-3);gap:var(--space-2);border-radius:0}.chat-input__textarea{padding:var(--space-2) var(--space-3);font-size:16px}.chat-input__send{padding:var(--space-2) var(--space-4)}}.chat-history-page{gap:var(--space-6);flex-direction:column;display:flex}.chat-history-page__card{background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md);flex-direction:column;min-height:0;display:flex}.chat-history-page__title{font-family:var(--font-sans);color:var(--text-primary);margin-bottom:var(--space-4);font-size:18px;font-weight:700}.chat-history-page__loading{text-align:center;color:var(--text-muted);padding:var(--space-8);font-size:14px}@media (width<=768px){.chat-history-page{gap:0;height:calc(100vh - 60px)}.chat-history-page__card{padding:var(--space-3);box-shadow:none;background:var(--bg-primary);border:none;border-radius:0;flex:1}.chat-history-page__title{margin-bottom:var(--space-2);padding:var(--space-2) var(--space-2);font-size:16px}}.emotion-line-chart{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-5);transition:box-shadow var(--transition-normal)}.emotion-line-chart:hover{box-shadow:var(--shadow-lg)}.emotion-line-chart .recharts-tooltip-wrapper{filter:drop-shadow(0 4px 8px #0006)}.emotion-legend{gap:var(--space-2);flex-wrap:wrap;display:flex}.emotion-legend__item{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border:1px solid var(--surface-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-normal);font-family:var(--font-sans);color:var(--text-primary);background:0 0;font-size:13px;display:flex}.emotion-legend__item:hover{background:var(--bg-tertiary)}.emotion-legend__item--inactive{opacity:.3}.emotion-legend__dot{border-radius:var(--radius-full);flex-shrink:0;width:10px;height:10px}.emotion-legend__label{white-space:nowrap}.dominant-badge{align-items:center;gap:var(--space-2);flex-direction:column;display:flex}.dominant-badge__circle{border-radius:var(--radius-full);width:80px;height:80px;transition:transform var(--transition-normal), box-shadow var(--transition-normal);border:2px solid;justify-content:center;align-items:center;display:flex}.dominant-badge__circle:hover{box-shadow:var(--shadow-md);transform:scale(1.05)}.dominant-badge__emotion{font-family:var(--font-sans);font-size:16px;font-weight:700;line-height:1}.dominant-badge__label{font-family:var(--font-sans);color:var(--text-muted);font-size:12px}.emotion-graph-page{gap:var(--space-6);flex-direction:column;display:flex}.emotion-graph-page__card{background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md)}.emotion-graph-page__header{justify-content:space-between;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);display:flex}.emotion-graph-page__date-input{font-family:var(--font-mono);padding:var(--space-2) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--surface-border);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-normal);outline:none;font-size:14px}.emotion-graph-page__date-input:focus{border-color:var(--accent-coral)}.emotion-graph-page__date-input::-webkit-calendar-picker-indicator{filter:invert(.8);cursor:pointer}.emotion-graph-page__chart{margin-bottom:var(--space-4)}.emotion-graph-page__legend{padding-top:var(--space-4);border-top:1px solid var(--surface-border)}.emotion-graph-page__loading{text-align:center;color:var(--text-muted);padding:var(--space-8);font-size:14px}.gauge-bar{gap:var(--space-2);flex-direction:column;display:flex}.gauge-bar__header{justify-content:space-between;align-items:center;display:flex}.gauge-bar__label{font-family:var(--font-sans);color:var(--text-secondary);font-size:13px;font-weight:500}.gauge-bar__value{font-family:var(--font-mono);color:var(--text-muted);font-size:12px}.gauge-bar__track{background:var(--surface-border);border-radius:var(--radius-full);height:8px;overflow:hidden}.gauge-bar__fill{border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.pattern-badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--surface-border);border-radius:var(--radius-full);transition:background var(--transition-normal);display:inline-flex}.pattern-badge:hover{background:var(--surface-raised)}.pattern-badge__icon{font-family:var(--font-mono);color:var(--accent-amber);font-size:12px;font-weight:700}.pattern-badge__text{font-family:var(--font-sans);color:var(--text-secondary);white-space:nowrap;font-size:13px}.emotion-heatmap{padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);flex-direction:column;gap:2px;display:flex;position:relative}.emotion-heatmap__header,.emotion-heatmap__row{grid-template-columns:56px repeat(7,1fr);align-items:center;gap:2px;display:grid}.emotion-heatmap__row-label{font-family:var(--font-sans);color:var(--text-secondary);text-align:right;padding-right:var(--space-2);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.emotion-heatmap__col-label{font-family:var(--font-sans);color:var(--text-muted);text-align:center;font-size:11px}.emotion-heatmap__cell{aspect-ratio:1;border-radius:var(--radius-sm);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast);min-height:24px}.emotion-heatmap__cell:hover{box-shadow:var(--shadow-sm);z-index:1;transform:scale(1.15)}.emotion-heatmap__tooltip{padding:var(--space-1) var(--space-3);background:var(--bg-tertiary);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-family:var(--font-mono);color:var(--text-primary);white-space:nowrap;pointer-events:none;box-shadow:var(--shadow-md);z-index:200;font-size:12px;position:fixed;transform:translate(-50%,-100%)}.emotion-summary-page{gap:var(--space-6);flex-direction:column;display:flex}.emotion-summary-page__card{background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md)}.emotion-summary-page__tabs{gap:var(--space-2);margin-bottom:var(--space-6);display:flex}.emotion-summary-page__tab{padding:var(--space-2) var(--space-4);font-family:var(--font-sans);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-normal);font-size:14px;font-weight:600}.emotion-summary-page__tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.emotion-summary-page__tab--active{color:var(--text-primary);background:var(--bg-tertiary);box-shadow:inset 0 -2px 0 var(--accent-coral)}.emotion-summary-page__daily{gap:var(--space-5);flex-direction:column;display:flex}.emotion-summary-page__badges{gap:var(--space-6);display:flex}.emotion-summary-page__metrics{gap:var(--space-4);display:flex}.emotion-summary-page__metric{align-items:baseline;gap:var(--space-2);display:flex}.emotion-summary-page__metric-label{font-family:var(--font-sans);color:var(--text-secondary);font-size:13px}.emotion-summary-page__metric-value{font-family:var(--font-mono);color:var(--emotion-frustrated);font-size:20px;font-weight:700}.emotion-summary-page__pattern{padding-top:var(--space-3)}.emotion-summary-page__weekly{padding-top:var(--space-2)}.emotion-summary-page__loading{text-align:center;color:var(--text-muted);padding:var(--space-8);font-size:14px}.status-card{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-5);gap:var(--space-3);transition:box-shadow var(--transition-normal), transform var(--transition-normal);flex-direction:column;display:flex}.status-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.status-card__header{align-items:center;gap:var(--space-2);display:flex}.status-card__dot{border-radius:var(--radius-full);flex-shrink:0;width:8px;height:8px}.status-card__dot--green{background:var(--status-green);box-shadow:0 0 8px #4ade8066}.status-card__dot--amber{background:var(--status-amber);box-shadow:0 0 8px #fbbf2466}.status-card__dot--red{background:var(--status-red);animation:1.5s ease-in-out infinite pulse-red;box-shadow:0 0 8px #f8717166}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.5}}.status-card__body{align-items:baseline;gap:var(--space-1);display:flex}.status-card__value{font-family:var(--font-mono);color:var(--text-primary);font-size:28px;font-weight:700;line-height:1}.status-card__unit{font-family:var(--font-sans);color:var(--text-muted);font-size:13px}.status-card__title{font-family:var(--font-sans);color:var(--text-secondary);font-size:13px;font-weight:500}.status-card__extra{padding-top:var(--space-2);border-top:1px solid var(--surface-border)}.donut-gauge{justify-content:center;align-items:center;display:inline-flex;position:relative}.donut-gauge__svg{transform:rotate(-90deg)}.donut-gauge__track{fill:none;stroke:var(--surface-border)}.donut-gauge__fill{fill:none;stroke-linecap:round;transition:stroke-dashoffset var(--transition-slow)}.donut-gauge__center{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.donut-gauge__pct{font-family:var(--font-mono);color:var(--text-primary);font-size:16px;font-weight:700;line-height:1}.donut-gauge__label{font-family:var(--font-sans);color:var(--text-muted);font-size:10px}.system-status-page{gap:var(--space-6);flex-direction:column;display:flex}.system-status-page__card{background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md)}.system-status-page__title{font-family:var(--font-sans);color:var(--text-primary);margin-bottom:var(--space-6);font-size:18px;font-weight:700}.system-status-page__grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.system-status-page__loading{text-align:center;color:var(--text-muted);padding:var(--space-8);font-size:14px}.tools-page{gap:var(--space-6);flex-direction:column;display:flex}.tools-page__card{background:var(--surface-raised);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md)}.tools-page__title{font-family:var(--font-sans);color:var(--text-primary);margin-bottom:var(--space-2);font-size:18px;font-weight:700}.tools-page__subtitle{color:var(--text-muted);margin-bottom:var(--space-6);font-size:13px}.tools-page__category{margin-bottom:var(--space-6)}.tools-page__category-title{font-family:var(--font-sans);color:var(--text-secondary);margin-bottom:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--surface-border);font-size:15px;font-weight:600}.tools-page__grid{gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.tools-page__tool{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-md);padding:var(--space-4);transition:border-color var(--transition-fast)}.tools-page__tool:hover{border-color:var(--accent-coral)}.tools-page__tool-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.tools-page__tool-icon{font-size:18px}.tools-page__tool-name{font-family:var(--font-mono);color:var(--accent-coral);font-size:13px;font-weight:600}.tools-page__tool-desc{color:var(--text-secondary);margin:0;font-size:13px;line-height:1.5}.tools-page__loading{text-align:center;color:var(--text-muted);padding:var(--space-8)}@media (width<=768px){.tools-page__card{padding:var(--space-4);box-shadow:none;background:var(--bg-primary);border:none;border-radius:0}.tools-page__grid{grid-template-columns:1fr}}
