.layout{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.layout-main{flex:1;padding:var(--space-md);padding-bottom:var(--space-lg)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--space-sm) 0 calc(var(--space-sm) + var(--safe-area-bottom));z-index:100;box-shadow:0 -2px 10px #0000000d}.nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);color:var(--color-text-muted);text-decoration:none;font-size:.75rem;transition:color .2s}.nav-item.active{color:var(--color-primary-dark)}.nav-icon{font-size:1.25rem}.nav-label{white-space:nowrap}@media (max-width: 480px){.layout-main{padding:var(--space-sm)}.nav-label{font-size:.7rem}}.heatmap-calendar{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:var(--shadow-sm)}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.nav-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--color-text);border-radius:var(--radius-sm);transition:background .2s}.nav-btn:hover{background:var(--color-primary-bg)}.nav-btn:active{background:var(--color-primary-light)}.month-title{font-size:1rem;font-weight:600;color:var(--color-text)}.weekday-labels{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:var(--space-xs)}.weekday{font-size:.7rem;color:var(--color-text-muted);text-align:center}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.day-cell{aspect-ratio:1;min-height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.06);transition:transform .15s,box-shadow .15s}.day-cell:not(.pad){cursor:pointer}.day-cell:not(.pad):hover{transform:scale(1.05);box-shadow:var(--shadow-sm)}.day-cell.today{border:2px solid var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-bg);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.9}}.day-cell.has-record .day-num{font-weight:600}.day-num{font-size:.85rem;color:var(--color-text)}.heat-legend{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);margin-top:var(--space-md);font-size:.7rem;color:var(--color-text-muted)}.legend-dot{width:12px;height:12px;border-radius:3px}@media (max-width: 480px){.heatmap-calendar{padding:var(--space-sm)}.day-cell{min-height:28px}.day-num{font-size:.75rem}}.quote-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-lg);border-left:4px solid var(--color-primary);box-shadow:var(--shadow-sm)}.quote-card.compact{padding:var(--space-md)}.quote-text{font-size:1rem;line-height:1.7;color:var(--color-text);margin-bottom:var(--space-sm)}.quote-meta{display:flex;align-items:baseline;gap:var(--space-sm);font-size:.85rem;color:var(--color-text-secondary)}.quote-author{font-style:italic}.quote-source{color:var(--color-text-muted)}.quote-tag{display:inline-block;margin-top:var(--space-sm);padding:2px 8px;font-size:.7rem;background:var(--color-primary-bg);color:var(--color-primary-dark);border-radius:var(--radius-full)}.collect-btn{margin-top:var(--space-md);padding:var(--space-xs) var(--space-md);font-size:.8rem;color:var(--color-primary-dark);background:var(--color-primary-bg);border-radius:var(--radius-sm);transition:background .2s}.collect-btn:hover{background:var(--color-primary-light)}@media (max-width: 480px){.quote-card{padding:var(--space-md)}.quote-text{font-size:.95rem}}.home{max-width:480px;margin:0 auto}.home-header{text-align:center;margin-bottom:var(--space-lg)}.home-header h1{font-size:1.75rem;color:var(--color-primary-dark);font-weight:600}.slogan{font-size:.85rem;color:var(--color-text-secondary);margin-top:var(--space-xs)}.today-section{margin-top:var(--space-lg)}.today-section h3{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.day-summary{background:var(--color-primary-bg);padding:var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-size:.9rem}.day-summary p{margin:var(--space-xs) 0}.empty-hint{font-size:.85rem;color:var(--color-text-muted);margin-bottom:var(--space-md)}.feed-section{margin-top:var(--space-lg)}.feed-section h3{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.feed-time{font-size:.8rem;color:var(--color-text-muted);min-width:3rem}.record-fab{position:fixed;right:var(--space-lg);bottom:calc(80px + var(--safe-area-bottom));padding:var(--space-sm) var(--space-md);background:var(--color-primary);color:#fff;border-radius:var(--radius-full);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-md);transition:transform .2s,box-shadow .2s}.record-fab:hover{transform:scale(1.05);box-shadow:var(--shadow-lg)}.record-fab:active{transform:scale(.98)}.record-page{max-width:480px;margin:0 auto}.record-date{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.form-section{margin-bottom:var(--space-lg)}.form-section label{display:block;font-size:.85rem;color:var(--color-text);margin-bottom:var(--space-sm)}.form-input,.form-textarea{width:100%;padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem}.form-textarea{resize:vertical;min-height:80px}.duration-chips,.completion-row{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.chip{padding:var(--space-xs) var(--space-sm);font-size:.85rem;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);transition:all .2s}.chip.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.mood-row{display:flex;gap:var(--space-sm)}.mood-btn{width:44px;height:44px;font-size:1.5rem;border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--color-surface);transition:all .2s}.mood-btn.active{border-color:var(--color-primary);background:var(--color-primary-bg)}.submit-btn{width:100%;padding:var(--space-md);margin-top:var(--space-lg);background:var(--color-primary);color:#fff;font-size:1rem;font-weight:500;border-radius:var(--radius-md);transition:opacity .2s}.submit-btn:hover{opacity:.9}.stats-page{max-width:480px;margin:0 auto}.page-title{font-size:1.25rem;color:var(--color-text);margin-bottom:var(--space-lg)}.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.stat-card{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;box-shadow:var(--shadow-sm)}.stat-card.highlight{background:var(--color-primary-bg);border:1px solid var(--color-primary-light)}.stat-value{display:block;font-size:1.5rem;font-weight:600;color:var(--color-primary-dark)}.stat-label{font-size:.75rem;color:var(--color-text-secondary);margin-top:var(--space-xs);display:block}.content-breakdown h3{font-size:.95rem;color:var(--color-text);margin-bottom:var(--space-md)}.content-chart{display:flex;align-items:center;gap:var(--space-lg)}.pie-wrapper{position:relative;width:140px;height:140px;flex-shrink:0}.pie-chart{width:100%;height:100%;border-radius:50%;background:conic-gradient(#e8f5e9,#4caf50 360deg);box-shadow:var(--shadow-md)}.pie-center{position:absolute;top:18%;right:18%;bottom:18%;left:18%;border-radius:50%;background:var(--color-surface);display:flex;flex-direction:column;align-items:center;justify-content:center}.pie-total{font-size:1.2rem;font-weight:600;color:var(--color-primary-dark)}.pie-label{font-size:.75rem;color:var(--color-text-secondary);margin-top:2px}.breakdown-list{list-style:none}.breakdown-list li{display:flex;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--color-surface);border-radius:var(--radius-sm);margin-bottom:var(--space-xs)}.breakdown-item{cursor:pointer;transition:background .2s}.breakdown-item:hover{background:var(--color-primary-bg)}.breakdown-item.selected{background:var(--color-primary-bg);border:1px solid var(--color-primary-light)}.legend-left{display:flex;align-items:center;gap:var(--space-xs)}.legend-color{width:10px;height:10px;border-radius:2px}.breakdown-list .name{color:var(--color-text)}.breakdown-list .mins{color:var(--color-text-secondary);font-size:.9rem}.empty-hint{color:var(--color-text-muted);font-size:.9rem}.field-feed-section{margin-top:var(--space-xl)}.field-feed-section h3{font-size:.95rem;color:var(--color-text);margin-bottom:var(--space-md)}.feed-list{list-style:none}.feed-item{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);box-shadow:var(--shadow-sm);margin-bottom:var(--space-xs)}.feed-main{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:2px}.feed-time{font-size:.8rem;color:var(--color-text-muted);min-width:4.5rem}.feed-content{font-size:.9rem;color:var(--color-text)}.feed-meta{font-size:.8rem;color:var(--color-text-secondary)}.feed-note{margin-top:var(--space-xs);font-size:.85rem;color:var(--color-text-secondary);line-height:1.4;white-space:pre-wrap;padding-top:var(--space-xs);border-top:1px solid var(--color-border)}@media (max-width: 480px){.stat-cards{grid-template-columns:1fr}.stat-value{font-size:1.25rem}.content-chart{flex-direction:column;align-items:stretch}.pie-wrapper{margin:0 auto}}.collection-page{max-width:480px;margin:0 auto}.subtitle{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:var(--space-lg)}.empty-state{text-align:center;padding:var(--space-xl);color:var(--color-text-muted)}.empty-state .hint{font-size:.85rem;margin-top:var(--space-sm)}.collection-list{list-style:none}.collection-list li{margin-bottom:var(--space-lg)}.item-meta{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-sm);font-size:.8rem;color:var(--color-text-muted)}.remove-btn{color:var(--color-error);font-size:.8rem}.remove-btn:hover{text-decoration:underline}.settings-page{max-width:480px;margin:0 auto}.settings-section{background:var(--color-surface);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg);box-shadow:var(--shadow-sm)}.settings-section h3{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:var(--space-md);padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0}.setting-row.full{justify-content:flex-start}.permission-btn{padding:var(--space-xs) var(--space-md);font-size:.85rem;color:var(--color-primary-dark);background:var(--color-primary-bg);border-radius:var(--radius-sm)}.permission-btn:hover{background:var(--color-primary-light)}.export-btn{padding:var(--space-xs) var(--space-md);font-size:.85rem;color:var(--color-primary-dark);background:var(--color-surface);border-radius:var(--radius-sm);border:1px solid var(--color-primary-light)}.export-btn:hover{background:var(--color-primary-bg)}.setting-row span{color:var(--color-text)}.setting-row input[type=time]{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--color-border);border-radius:24px;transition:.3s}.slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:var(--shadow-sm)}input:checked+.slider{background:var(--color-primary)}input:checked+.slider:before{transform:translate(20px)}.about-text{font-size:.9rem;color:var(--color-text)}.about-slogan{font-size:.8rem;color:var(--color-text-muted);margin-top:var(--space-xs)}:root{--color-primary: #8BC34A;--color-primary-light: #C5E1A5;--color-primary-dark: #558B2F;--color-primary-bg: #F1F8E9;--heat-0: #E8F5E9;--heat-1: #C8E6C9;--heat-2: #A5D6A7;--heat-3: #81C784;--heat-4: #4CAF50;--heat-5: #2E7D32;--color-text: #37474F;--color-text-secondary: #78909C;--color-text-muted: #B0BEC5;--color-bg: #FAFBFA;--color-surface: #FFFFFF;--color-border: #E0E0E0;--color-success: #4CAF50;--color-warning: #FF9800;--color-error: #F44336;--color-info: #2196F3;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--safe-area-bottom: env(safe-area-inset-bottom, 0)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;color:var(--color-text);background:var(--color-bg);min-height:100vh;min-height:100dvh;line-height:1.5}#root{min-height:100vh;min-height:100dvh;padding-bottom:calc(64px + var(--safe-area-bottom))}@media (max-width: 768px){html{font-size:15px}}button{cursor:pointer;font-family:inherit;border:none;background:none}input,textarea,select{font-family:inherit}
