:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.habit-ai-sidebar{position:fixed;right:0;top:0;width:280px;height:100vh;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);padding:var(--spacing-lg);overflow-y:auto;z-index:10}.ai-sidebar-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.ai-icon{font-size:var(--font-size-xl)}.ai-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.ai-empty-state{text-align:center;padding:var(--spacing-xl) 0;color:var(--color-text-muted)}.ai-empty-state p{margin:var(--spacing-xs) 0}.ai-loading{text-align:center;padding:var(--spacing-xl) 0;color:var(--color-text-muted)}.loading-spinner{width:32px;height:32px;border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-primary);border-radius:50%;margin:0 auto var(--spacing-md);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ai-content{display:flex;flex-direction:column;gap:var(--spacing-md)}.ai-section{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-md)}.selected-habit{background:linear-gradient(135deg,#00d4ff1a,#ff00801a);border:1px solid var(--color-primary)}.habit-tag{color:var(--color-primary);font-weight:var(--font-weight-semibold);text-align:center}.section-header{display:flex;align-items:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.section-icon{font-size:var(--font-size-md)}.section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.section-content{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5}.time-content{color:var(--color-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-md)}.benefit-content{color:var(--color-success)}.analysis-section{flex:1}.analysis-content{white-space:pre-line}.exam-modal{width:500px;max-width:90vw;background:#1a1a2e;color:#fff;border:1px solid #333;border-radius:12px;padding:24px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.exam-list{max-height:300px;overflow-y:auto;margin-bottom:24px;display:flex;flex-direction:column;gap:8px}.exam-item{display:flex;justify-content:space-between;align-items:center;background:#ffffff0d;padding:12px;border-radius:8px;border:1px solid transparent}.exam-item.pinned{border-color:#52efdb;background:#52efdb1a}.exam-info{display:flex;flex-direction:column}.exam-title{font-weight:700}.exam-date{font-size:.85em;color:#aaa}.exam-actions{display:flex;gap:8px}.pin-btn,.delete-btn{background:none;border:none;cursor:pointer;font-size:1.2rem;opacity:.6;transition:opacity .2s}.pin-btn:hover,.delete-btn:hover{opacity:1}.pin-btn.active{opacity:1;text-shadow:0 0 10px #52efdb}.add-exam-form{border-top:1px solid #333;padding-top:16px}.add-exam-form h4{margin-bottom:12px;color:#ccc}.form-row{display:flex;gap:12px;margin-bottom:12px}.form-row input{flex:1;background:#0000004d;border:1px solid #444;padding:8px;border-radius:4px;color:#fff}.add-btn{width:100%;background:linear-gradient(90deg,#52efdb,#bc13fe);border:none;padding:10px;border-radius:6px;color:#fff;font-weight:700;cursor:pointer}.add-btn:hover{filter:brightness(1.1)}.countdown-widget-card{cursor:pointer;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.countdown-widget-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #52efdb33}.countdown-widget-card.danger{border-color:#ff4757;background:linear-gradient(135deg,#ff47571a,#1a1a2ee6)}.countdown-widget-card.danger .cw-days{color:#ff4757;text-shadow:0 0 20px rgba(255,71,87,.5);background:none;-webkit-text-fill-color:initial}.countdown-widget-card.warning{border-color:#ffa502;background:linear-gradient(135deg,#ffa5021a,#1a1a2ee6)}.countdown-widget-card.warning .cw-days{color:#ffa502;text-shadow:0 0 20px rgba(255,165,2,.5);background:none;-webkit-text-fill-color:initial}.cw-item{display:flex;flex-direction:column;align-items:center;padding:10px 0}.cw-days{font-size:3.5rem;font-weight:800;line-height:1;color:#52efdb;margin-bottom:8px;font-family:Outfit,sans-serif}.cw-label{font-size:1.1rem;color:#fff;font-weight:500}.cw-date{font-size:.8rem;color:#888;margin-top:4px}.cw-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100px;color:#aaa}.cw-empty .plus-icon{font-size:2rem;margin-bottom:8px;color:#52efdb}.setup-icon{font-size:.9rem;opacity:.5}.countdown-widget-card:hover .setup-icon{opacity:1}[data-theme=light] .countdown-widget-card{background:linear-gradient(135deg,#ffffffe6,#e8e4ddf2);border-color:var(--color-border)}[data-theme=light] .countdown-widget-card:hover{box-shadow:0 4px 12px #0099cc26}[data-theme=light] .countdown-widget-card.danger{background:linear-gradient(135deg,#cc334414,#fffffff2);border-color:#c34}[data-theme=light] .countdown-widget-card.warning{background:linear-gradient(135deg,#cc990014,#fffffff2);border-color:#c90}[data-theme=light] .cw-days{color:#09c}[data-theme=light] .countdown-widget-card.danger .cw-days{color:#c34;text-shadow:none}[data-theme=light] .countdown-widget-card.warning .cw-days{color:#c90;text-shadow:none}[data-theme=light] .cw-label{color:var(--color-text-primary)}[data-theme=light] .cw-date,[data-theme=light] .cw-empty{color:var(--color-text-muted)}[data-theme=light] .cw-empty .plus-icon{color:#09c}.student-layout{display:flex;min-height:100vh;background-color:var(--color-bg-primary);width:100vw;max-width:100vw;overflow-x:hidden}.sidebar{width:200px!important;min-width:200px!important;max-width:200px!important;background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:var(--z-fixed)}.sidebar-logo{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-md);border-bottom:1px solid var(--color-border);height:60px}.logo-image{width:32px;height:32px;object-fit:contain;border-radius:var(--radius-sm)}.logo-text{font-size:var(--font-size-md);font-weight:var(--font-weight-bold);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:var(--transition-fast);text-decoration:none;font-size:var(--font-size-sm)}.nav-item:hover{background-color:var(--color-primary-light);color:var(--color-text-primary)}.nav-item.active{background-color:var(--color-primary-light);color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.nav-icon{font-size:var(--font-size-md);width:20px;text-align:center}.nav-label{font-weight:var(--font-weight-medium)}.sidebar-footer{padding:var(--spacing-sm);border-top:1px solid var(--color-border)}.family-badge{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);text-align:center}.user-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);background-color:var(--glass-bg);margin-bottom:var(--spacing-sm)}.user-avatar{width:32px;height:32px;border-radius:var(--radius-full);background-color:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-md)}.user-details{flex:1;min-width:0}.user-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-points{font-size:10px;color:var(--color-warning)}.logout-btn-small{width:100%;padding:var(--spacing-xs);background:transparent;border:1px solid var(--color-danger);color:var(--color-danger);border-radius:var(--radius-md);font-size:var(--font-size-xs);cursor:pointer;transition:var(--transition-fast)}.logout-btn-small:hover{background:var(--color-danger);color:#fff}.main-content{margin-left:200px!important;min-height:100vh;display:flex;flex-direction:column;transition:margin-right .3s;flex:1;width:auto!important;max-width:none!important}.student-layout.has-right-panel .main-content{margin-right:280px}.student-layout.no-right-panel .main-content{margin-right:0}.top-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);height:50px;position:sticky;top:0;z-index:10}.page-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0}.header-actions{display:flex;gap:var(--spacing-sm)}.action-btn{padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-fast)}.action-btn.primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-bg-primary)}.action-btn.primary:hover{box-shadow:var(--glow-primary);transform:translateY(-1px)}.content-wrapper{flex:1;display:flex;flex-direction:column}.content-area{flex:1;width:100%;padding:var(--spacing-lg);overflow-y:auto;display:flex;flex-direction:column}.content-area.reduced-padding{padding:0!important}.content-area.full-width-content{padding:0}.content-area.fixed-height-content{overflow-y:hidden}.content-area.compact-content{padding:1rem}.content-area>*{width:100%!important;flex:1}.right-panel{position:fixed;top:0;right:0;width:280px;height:100vh;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);padding:var(--spacing-md);padding-top:calc(60px + var(--spacing-md));overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-md);z-index:var(--z-fixed)}.panel-card{background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md)}.panel-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.panel-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.countdown-card{background:linear-gradient(135deg,#00d4ff1a,#a855f71a);border-color:var(--color-primary)}.countdown-item{text-align:center;padding:var(--spacing-sm)}.countdown-days{font-size:48px;font-weight:var(--font-weight-bold);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.countdown-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-xs)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.stat-item{text-align:center;padding:var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.stat-value{display:block;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.stat-label{display:block;font-size:10px;color:var(--color-text-muted);margin-top:2px}.family-members-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.member-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.member-avatar{font-size:var(--font-size-md)}.member-name{flex:1;font-size:var(--font-size-sm)}.member-role{font-size:10px;color:var(--color-text-muted);padding:2px 6px;background:var(--color-bg-secondary);border-radius:var(--radius-sm)}.quick-btns{display:flex;flex-direction:column;gap:var(--spacing-xs)}.quick-btn{width:100%;padding:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast);text-align:left}.quick-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light)}@media(max-width:1200px){.right-panel{display:none}.student-layout.has-right-panel .main-content{margin-right:0}}@media(max-width:768px){.sidebar{width:60px;min-width:60px}.sidebar-logo .logo-text,.nav-label,.user-details,.family-badge{display:none}.sidebar-logo{justify-content:center}.nav-item{justify-content:center;padding:var(--spacing-md)}.nav-icon{width:auto}.user-info{justify-content:center}.main-content{margin-left:60px}.logout-btn-small{font-size:0;padding:var(--spacing-sm)}.logout-btn-small:before{content:"🚪";font-size:var(--font-size-md)}}.home-page{width:100%;height:100%;display:flex;flex-direction:column}.home-page .toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.today-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.btn{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:var(--transition-fast);cursor:pointer}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-bg-primary);border:none}.btn-primary:hover{box-shadow:var(--glow-primary-sm)}.countdown-banner{background:linear-gradient(135deg,var(--color-bg-secondary),var(--color-bg-tertiary));border:1px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);box-shadow:var(--glow-primary-sm);width:100%!important;box-sizing:border-box;margin-bottom:var(--spacing-md)}.countdown-content{display:flex;align-items:baseline;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.countdown-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.countdown-days{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary);text-shadow:0 0 20px var(--color-primary)}.countdown-unit{font-size:var(--font-size-md);color:var(--color-text-secondary)}.countdown-progress{height:4px;background:var(--color-bg-primary);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-success));border-radius:var(--radius-full);transition:width .5s ease}.home-grid{flex:1;display:grid!important;grid-template-columns:1fr 1fr!important;gap:var(--spacing-md);width:100%!important;min-width:100%!important;align-content:start}.home-page .card{background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);width:100%!important;min-width:0;box-sizing:border-box}.section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.timeline{display:flex;flex-direction:column;gap:var(--spacing-sm)}.timeline-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);background:var(--color-bg-secondary);transition:var(--transition-fast)}.timeline-item:hover{background:var(--color-bg-tertiary)}.timeline-item.completed{opacity:.6}.timeline-item.current{border-left:3px solid var(--color-primary);background:var(--color-primary-light)}.timeline-time{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-muted);min-width:40px}.timeline-content{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.timeline-tag{font-size:10px;padding:2px 6px;border-radius:var(--radius-full)}.tag-class{background:var(--color-subject-math);color:#fff}.tag-task{background:var(--color-secondary);color:#fff}.tag-habit{background:var(--color-success);color:var(--color-bg-primary)}.habits-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.habit-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);background:var(--color-bg-secondary)}.habit-item.completed{opacity:.7}.habit-icon{font-size:var(--font-size-md)}.habit-name{flex:1;font-size:var(--font-size-sm)}.habit-check{color:var(--color-success);font-weight:var(--font-weight-bold)}.habit-btn{padding:2px 10px;background:var(--color-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-sm);font-size:var(--font-size-xs);cursor:pointer;transition:var(--transition-fast)}.habit-btn:hover{box-shadow:var(--glow-primary-sm)}.streak-info{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);text-align:center;color:var(--color-warning);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.tag-focus{background:#ff9500;color:#fff}.q1-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.q1-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);background:var(--color-bg-secondary);border-left:3px solid #ff3b30}.q1-task-title{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.q1-due-date{font-size:var(--font-size-xs);color:#ff3b30;font-weight:var(--font-weight-medium)}.moments-list{display:flex;flex-direction:column;gap:var(--spacing-sm);max-height:200px;overflow-y:auto}.moment-item{padding:var(--spacing-sm);border-radius:var(--radius-md);background:var(--color-bg-secondary)}.moment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.moment-author{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary)}.moment-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.moment-content{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.clickable-card{transition:all .2s ease}.clickable-card:hover{border-color:var(--color-primary);box-shadow:var(--glow-primary-sm);transform:translateY(-2px)}.loading-text,.empty-text{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted);font-size:var(--font-size-sm)}@media(max-width:900px){.home-grid{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-primary),var(--color-bg-secondary));padding:var(--spacing-xl)}.login-container{width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:var(--spacing-xl)}.login-logo .logo-image{width:120px;height:120px;object-fit:contain;margin-bottom:var(--spacing-md);border-radius:var(--radius-lg)}.logo-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm)}.logo-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted)}.login-card{background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.form-tabs{display:flex;margin-bottom:var(--spacing-xl);background:var(--color-bg-primary);border-radius:var(--radius-lg);padding:4px}.tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;color:var(--color-text-secondary);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-fast)}.tab.active{background:var(--color-primary);color:var(--color-bg-primary)}.role-selector{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.role-btn{flex:1;padding:var(--spacing-md);background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-fast);text-align:center}.role-btn:hover{border-color:var(--color-primary)}.role-btn.active{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--glow-primary)}.role-icon{display:block;font-size:var(--font-size-2xl);margin-bottom:var(--spacing-sm)}.role-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.role-btn.active .role-label{color:var(--color-primary)}.form-group{margin-bottom:var(--spacing-lg)}.form-group label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.form-group input{width:100%;padding:var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-md);transition:var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary)}.form-group input::placeholder{color:var(--color-text-muted)}.submit-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.submit-btn:hover{box-shadow:var(--glow-primary);transform:translateY(-2px)}.login-footer{text-align:center;margin-top:var(--spacing-xl);font-size:var(--font-size-xs);color:var(--color-text-muted)}.login-footer a{color:var(--color-primary)}.error-message{background:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm)}.invite-code-group .invite-code-input{text-align:center;font-size:var(--font-size-lg);letter-spacing:3px;font-family:var(--font-family-mono);text-transform:uppercase}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.register-link{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.register-link p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.register-link a{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium)}.register-link a:hover{text-decoration:underline}.role-select{width:100%;padding:var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-md);transition:var(--transition-fast);cursor:pointer}.role-select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary)}.role-select:hover{border-color:var(--color-primary)}.setup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-primary),var(--color-bg-secondary));padding:var(--spacing-xl)}.setup-container{width:100%;max-width:450px}.setup-header{text-align:center;margin-bottom:var(--spacing-xl)}.setup-icon{font-size:64px;display:block;margin-bottom:var(--spacing-md)}.setup-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-sm)}.setup-header p{color:var(--color-text-secondary);font-size:var(--font-size-md)}.setup-card{background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-xl);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.setup-card .form-group{margin-bottom:var(--spacing-lg)}.setup-card .form-group label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.setup-card .form-group input{width:100%;padding:var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-md);transition:var(--transition-fast)}.setup-card .form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary)}.invite-input{text-align:center;font-size:var(--font-size-xl)!important;letter-spacing:4px;font-family:var(--font-family-mono)}.setup-card .submit-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.setup-card .submit-btn:hover{box-shadow:var(--glow-primary);transform:translateY(-2px)}.setup-card .submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.setup-card .error-message{background:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm)}.mode-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.mode-btn{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg);background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-fast);color:var(--color-text-secondary)}.mode-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-light)}.mode-btn.active{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--glow-primary);color:var(--color-primary)}.mode-btn:disabled{opacity:.5;cursor:not-allowed}.mode-icon{font-size:var(--font-size-3xl)}.mode-label{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold)}.mode-desc{font-size:var(--font-size-xs);text-align:center}.success-content{text-align:center}.success-icon{font-size:64px;margin-bottom:var(--spacing-md)}.success-content h2{font-size:var(--font-size-xl);margin-bottom:var(--spacing-md)}.success-content p{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.success-hint{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xl)}.invite-code-box{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin:var(--spacing-xl) 0;padding:var(--spacing-lg);background:var(--color-bg-primary);border:2px dashed var(--color-primary);border-radius:var(--radius-lg)}.invite-code{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);font-family:var(--font-family-mono);letter-spacing:4px;color:var(--color-primary)}.copy-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast)}.copy-btn:hover{box-shadow:var(--glow-primary)}.parent-store-section{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-header h3{font-size:var(--font-size-lg);color:var(--color-text-primary);margin:0}.add-btn{padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.add-btn:hover{box-shadow:var(--glow-primary)}.store-tabs{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.tab-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast);display:flex;align-items:center;gap:var(--spacing-xs)}.tab-btn:hover{border-color:var(--color-primary)}.badge{background:var(--color-danger);color:#fff;padding:2px 6px;border-radius:var(--radius-full);font-size:var(--font-size-xs)}.store-content{min-height:200px}.loading,.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.empty-state button{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);cursor:pointer}.rewards-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.reward-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md)}.reward-item.inactive{opacity:.5}.reward-info{flex:1}.reward-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.reward-meta{display:flex;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-muted)}.reward-price{color:var(--color-warning)}.reward-actions{display:flex;gap:var(--spacing-sm)}.edit-btn,.delete-btn{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);transition:var(--transition-fast)}.edit-btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg-primary)}.delete-btn:hover{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.pending-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.pending-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:var(--radius-md)}.pending-info{flex:1}.pending-student{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.pending-reward{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.pending-time{color:var(--color-text-muted);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.fulfill-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-success);border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.fulfill-btn:hover{box-shadow:var(--glow-success)}.add-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:500px}.modal-header h4{margin:0;color:var(--color-text-primary)}.close-btn{width:32px;height:32px;background:var(--color-bg-tertiary);border:none;border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:20px;cursor:pointer}.add-modal form{padding:var(--spacing-lg)}.form-group textarea{min-height:80px;resize:vertical}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-md);border-top:1px solid var(--color-border)}.cancel-btn,.submit-btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.cancel-btn{background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary)}.submit-btn{background:linear-gradient(135deg,var(--color-primary),var(--color-success));border:none;color:var(--color-bg-primary)}.submit-btn:hover{box-shadow:var(--glow-primary)}.subject-selector{position:relative;width:100%}.subject-input{width:100%;padding:4px 8px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:12px!important;font-weight:500;height:32px;transition:var(--transition-fast)}.subject-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.subject-input::placeholder{color:var(--color-text-muted);font-size:12px}.subject-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:200px;overflow-y:auto;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000004d;z-index:100}.subject-dropdown::-webkit-scrollbar{width:6px}.subject-dropdown::-webkit-scrollbar-track{background:var(--color-bg-primary)}.subject-dropdown::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.subject-dropdown::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.subject-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:4px 8px;cursor:pointer;transition:var(--transition-fast);color:var(--color-text-primary);font-size:12px!important;font-weight:500}.subject-item:hover{background:var(--color-bg-tertiary)}.subject-item.loading,.subject-item.empty{color:var(--color-text-muted);cursor:default;padding:8px;font-size:12px}.subject-item.loading:hover,.subject-item.empty:hover{background:transparent}.subject-color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.subject-name{flex:1;font-size:12px!important;font-weight:500}.subject-count{font-size:11px;color:var(--color-text-muted)}.subject-item.create-new{border-top:1px dashed var(--color-border);color:var(--color-primary)}.subject-item.create-new:hover{background:#00d4ff1a}.create-icon{font-size:14px;font-weight:700;margin-right:4px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-sm)}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);max-width:800px;width:95%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.create-task-content{max-width:800px!important}.modal-content form{padding:var(--spacing-sm)}.create-task-content .form-row{display:flex!important;align-items:flex-start;gap:var(--spacing-sm)}.create-task-content .form-row>.form-group{flex:1;min-width:0}.create-task-content .form-row.priority-row>.form-group:first-child{flex:0 0 160px!important}.error-msg{background:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm)}.modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-sm);margin-top:4px}.cancel-btn{padding:4px 16px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;font-size:13px}.submit-btn{padding:4px 16px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;white-space:nowrap;transition:var(--transition-fast);font-size:13px}.ai-input-section{background:linear-gradient(135deg,#00d4ff1a,#8a2be21a);border:1px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.ai-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary);margin-bottom:var(--spacing-xs)}.ai-input{flex:1;padding:4px 8px;font-size:13px}.ai-parse-btn{padding:4px 12px;font-size:13px;white-space:nowrap}.ai-error{color:var(--color-danger);font-size:12px;margin-top:2px}.modal-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border);padding-bottom:4px;padding-left:var(--spacing-sm);padding-right:var(--spacing-sm);margin-top:var(--spacing-sm)}.modal-tab{flex:1;padding:6px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:13px;cursor:pointer;text-align:center}.modal-tab:hover:not(.active){background:var(--color-bg-tertiary)}.priority-selector-row{display:grid;grid-template-columns:1fr 1fr;gap:4px;align-items:center;width:100%}.p-select-btn{width:100%;min-width:0;padding:4px 2px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:transparent;cursor:pointer;text-align:center;font-size:12px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px;font-weight:500;height:28px}.p-select-btn:hover{background:var(--color-bg-tertiary)}.ai-tasks-section{margin-top:var(--spacing-sm)}.ai-tasks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.ai-tasks-list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.ai-task-item{display:flex;align-items:center;gap:8px;padding:4px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:13px}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.tasks-page{height:100%;display:flex;flex-direction:column}.toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.toolbar-left{display:flex;align-items:center;gap:var(--spacing-md)}.toolbar-right{display:flex;align-items:center;gap:var(--spacing-sm)}.task-count{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.filters{display:flex;gap:2px;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:2px}.filters button{padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:none;color:var(--color-text-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast)}.filters button:hover{color:var(--color-text-primary)}.filters button.active{background:var(--color-bg-secondary);color:var(--color-text-primary)}.view-toggle{display:flex;background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:2px}.view-toggle button{padding:8px 20px;min-width:90px;background:transparent;border:none;color:var(--color-text-secondary);font-size:14px;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition-fast);white-space:nowrap}.add-btn{padding:var(--spacing-xs) var(--spacing-md);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-fast)}.add-btn:hover{box-shadow:var(--glow-primary-sm)}.loading{text-align:center;padding:var(--spacing-3xl);color:var(--color-text-secondary)}.empty-state{text-align:center;padding:var(--spacing-3xl);background:var(--glass-bg);border:1px dashed var(--color-border);border-radius:var(--radius-xl)}.empty-icon{font-size:64px;display:block;margin-bottom:var(--spacing-md)}.empty-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.empty-state button{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);cursor:pointer}.task-list{flex:1;display:flex;flex-direction:column;gap:var(--spacing-md)}.task-card{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:var(--transition-fast);width:100%}.task-card:hover{border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.task-card.completed{opacity:.6}.task-card.completed .task-title{text-decoration:line-through;color:var(--color-text-muted)}.task-card.compact{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.check-btn{width:24px;height:24px;min-width:24px;border:2px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-primary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.check-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary);color:#fff}.check-btn.checked{background:var(--color-success);border-color:var(--color-success);color:#fff}.task-main-section{display:flex;align-items:center;gap:var(--spacing-md);flex:1;min-width:0}.task-title{font-weight:var(--font-weight-medium);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--font-size-sm)}.task-meta-row{display:flex;align-items:center;gap:var(--spacing-sm);margin:0 var(--spacing-md)}.task-tag{padding:2px 8px;border-radius:var(--radius-sm);font-size:11px;background:var(--color-bg-tertiary);color:var(--color-text-secondary);display:flex;align-items:center;gap:4px;white-space:nowrap}.priority-tag.q1{background:#ff3b3026;color:#ff3b30;border:1px solid rgba(255,59,48,.2)}.priority-tag.q2{background:#00d4ff26;color:#00d4ff;border:1px solid rgba(0,212,255,.2)}.priority-tag.q3{background:#ffcc0026;color:#fc0;border:1px solid rgba(255,204,0,.2)}.priority-tag.q4{background:#4cd96426;color:#4cd964;border:1px solid rgba(76,217,100,.2)}.task-actions-section{display:flex;align-items:center;gap:var(--spacing-md)}.task-points{padding:var(--spacing-xs) var(--spacing-sm);background:linear-gradient(135deg,var(--color-warning),var(--color-warning-dark));color:var(--color-bg-primary);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.delete-btn{background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;opacity:0;transition:var(--transition-fast)}.task-card:hover .delete-btn{opacity:1}.delete-btn:hover{color:var(--color-danger)}.matrix-view{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:var(--spacing-md);min-height:70vh}.matrix-quadrant{background:var(--glass-bg);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-md);display:flex;flex-direction:column}.task-group{margin-bottom:var(--spacing-lg)}.group-title{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm);padding-left:var(--spacing-xs);border-left:3px solid var(--color-primary)}.class-group .group-title{border-color:#fc0}.group-list{gap:var(--spacing-sm)}.complete-btn-text{background:linear-gradient(135deg,#4cd964,#2ed573);color:#fff;border:none;padding:6px 12px;border-radius:var(--radius-full);font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 2px 5px #2ed5734d;transition:transform .2s;margin-right:8px}.complete-btn-text:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2ed57366}.completed-tag{color:#4cd964;font-size:13px;margin-right:8px;font-weight:600}.confirm-modal{max-width:400px;padding:24px;text-align:center}.confirm-modal h3{margin-top:0;color:var(--color-text-primary)}.confirm-modal p{color:var(--color-text-secondary);margin:16px 0 24px}.celebration-overlay{background:#000000d9}.celebration-modal{background:linear-gradient(135deg,#1e1e24,#2a2a35);border:2px solid #ffd700;text-align:center;padding:32px;max-width:400px;border-radius:20px;box-shadow:0 0 50px #ffd7004d;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.celebration-icon{font-size:64px;margin-bottom:16px;animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.celebration-modal h2{color:gold;font-size:28px;margin:0 0 8px;text-shadow:0 2px 4px rgba(0,0,0,.5)}.celebration-task{color:#fff;font-size:16px;margin-bottom:24px;opacity:.9}.celebration-points{background:#ffd7001a;border:1px solid #ffd700;display:inline-block;padding:12px 24px;border-radius:50px;margin-bottom:32px}.points-value{font-size:32px;font-weight:800;color:gold;margin-right:4px}.celebration-btn{background:linear-gradient(to right,gold,orange);border:none;color:#000;font-weight:700;font-size:16px;padding:12px 48px;border-radius:50px;cursor:pointer;box-shadow:0 4px 15px #ffa50066;transition:transform .2s}.celebration-btn:hover{transform:scale(1.05)}.matrix-quadrant.q1{border-color:var(--color-danger);background:#ef44440d}.matrix-quadrant.q2{border-color:var(--color-primary);background:#00d4ff0d}.matrix-quadrant.q3{border-color:var(--color-warning);background:#f59e0b0d}.matrix-quadrant.q4{border-color:var(--color-text-muted);background:#94a3b80d}.quadrant-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-sm)}.quadrant-name{font-weight:var(--font-weight-semibold)}.quadrant-hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.quadrant-tasks{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-xs)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header h2{margin:0;font-size:var(--font-size-lg)}.close-btn{width:32px;height:32px;border:none;background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-content form{padding:var(--spacing-lg)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-md)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md)}.error-msg{background:var(--color-danger-light);border:1px solid var(--color-danger);color:var(--color-danger);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm)}.modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-md)}.cancel-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer}.cancel-btn:hover{border-color:var(--color-text-secondary)}.submit-btn{padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.submit-btn:hover:not(:disabled){box-shadow:var(--glow-primary)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.ai-input-section{background:linear-gradient(135deg,#00d4ff1a,#8a2be21a);border:1px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.ai-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary);margin-bottom:var(--spacing-sm)}.ai-input-row{display:flex;gap:var(--spacing-sm)}.ai-input{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-md)}.ai-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.ai-parse-btn{padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;transition:var(--transition-fast)}.ai-parse-btn:hover:not(:disabled){box-shadow:var(--glow-primary);transform:translateY(-1px)}.ai-parse-btn:disabled{opacity:.5;cursor:not-allowed}.ai-error{color:var(--color-danger);font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.ai-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:var(--spacing-xs)}.form-divider{height:1px;background:var(--color-border);margin:var(--spacing-md) 0}.modal-large{max-width:600px;width:90%}.modal-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-sm)}.modal-tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast)}.modal-tab:hover{background:var(--color-bg-tertiary)}.modal-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg-primary)}.modal-tab.ai-tab{position:relative}.new-badge{background:linear-gradient(135deg,#ff6b6b,orange);color:#fff;font-size:10px;padding:2px 6px;border-radius:var(--radius-full);margin-left:var(--spacing-xs);font-weight:var(--font-weight-bold);animation:pulse 2s infinite}.tab-content{min-height:200px}.ai-tasks-section{margin-top:var(--spacing-md)}.ai-tasks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.ai-tasks-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.add-task-btn{padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:1px dashed var(--color-primary);border-radius:var(--radius-md);color:var(--color-primary);font-size:var(--font-size-xs);cursor:pointer;transition:var(--transition-fast)}.add-task-btn:hover{background:#00d4ff1a}.ai-tasks-list{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:250px;overflow-y:auto}.ai-task-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);opacity:.6;transition:var(--transition-fast)}.ai-task-item.selected{opacity:1;border-color:var(--color-primary)}.ai-task-item input[type=checkbox]{width:18px;height:18px;cursor:pointer}.task-title-input{flex:1;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm)}.task-title-input:focus{outline:none;border-color:var(--color-primary)}.task-time{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.remove-task-btn{padding:var(--spacing-xs);background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;transition:var(--transition-fast)}.remove-task-btn:hover{color:var(--color-danger)}.priority-selector-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.p-select-btn{flex:1;min-width:70px;padding:8px 4px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:transparent;cursor:pointer;text-align:center;font-size:12px;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px;font-weight:500}.p-select-btn:hover{background:var(--color-bg-tertiary);opacity:.9}.p-select-btn.active{font-weight:700;box-shadow:0 0 0 1px currentColor}@media(max-width:768px){.matrix-view{grid-template-columns:1fr;grid-template-rows:auto}.form-row{grid-template-columns:1fr}}.calendar-page{display:flex;flex-direction:column;height:100%;background:var(--color-bg-secondary)}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-primary);border-bottom:1px solid var(--color-border)}.toolbar-left{flex:1}.month-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.toolbar-center{display:flex;align-items:center;gap:var(--spacing-sm)}.nav-btn{width:36px;height:36px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:20px;cursor:pointer;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center;padding:0}.nav-btn:hover{background:var(--color-bg-tertiary)}.today-btn{padding:var(--spacing-xs) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast)}.today-btn:hover{background:var(--color-primary);color:var(--color-bg-primary);border-color:var(--color-primary)}.toolbar-right{flex:1;display:flex;justify-content:flex-end}.view-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.view-toggle button{padding:var(--spacing-xs) var(--spacing-md);border:none;background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast)}.view-toggle button:not(:last-child){border-right:1px solid var(--color-border)}.view-toggle button.active{background:var(--color-primary);color:var(--color-bg-primary)}.view-toggle button:hover:not(.active){background:var(--color-bg-tertiary)}.calendar-main{flex:1;display:flex;overflow:hidden}.task-panel{width:280px;flex-shrink:0;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.task-panel-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.task-panel-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary)}.task-count{background:var(--color-primary);color:var(--color-bg-primary);font-size:11px;padding:2px 8px;border-radius:10px}.task-panel-hint{padding:var(--spacing-xs) var(--spacing-md);font-size:11px;color:var(--color-text-muted);background:#00d4ff0d;border-bottom:1px solid var(--color-border)}.task-panel-body{flex:1;overflow-y:auto;padding:var(--spacing-sm)}.task-group{margin-bottom:var(--spacing-md)}.task-group-title{font-size:11px;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);padding-left:var(--spacing-xs)}.task-card{padding:var(--spacing-sm);background:var(--color-bg-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-xs);border-left:3px solid;cursor:grab;transition:var(--transition-fast)}.task-card:active{cursor:grabbing}.task-card:hover{transform:translate(4px);box-shadow:var(--shadow-md)}.task-card.urgent{border-left-color:var(--color-danger);background:#ff6b6b1a}.task-card.important{border-left-color:#00d4ff;background:#00d4ff1a}.task-card.quick{border-left-color:#fc0;background:#ffcc001a}.task-card.normal{border-left-color:#4cd964;background:#4cd9641a}.task-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-card-due{font-size:11px;color:var(--color-text-muted)}.task-card.urgent .task-card-due{color:var(--color-danger)}.no-tasks{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted);font-size:var(--font-size-sm)}.calendar-body{flex:1;overflow:hidden;display:flex;flex-direction:column;padding:0;min-width:0}.loading{display:flex;justify-content:center;align-items:center;height:100%;color:var(--color-text-muted)}.month-view{height:100%;display:flex;flex-direction:column;padding:var(--spacing-md);min-width:0}.month-header{display:grid;grid-template-columns:repeat(7,1fr);background:var(--color-bg-tertiary);border-radius:var(--radius-md) var(--radius-md) 0 0}.weekday-cell{padding:var(--spacing-sm);text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,1fr);flex:1;border:1px solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md)}.day-cell{padding:var(--spacing-xs);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);background:var(--color-bg-primary);min-height:80px;position:relative;z-index:1;overflow:hidden}.day-cell:hover{z-index:100!important;overflow:visible}.day-cell:nth-child(7n){border-right:none}.day-cell.other-month{background:var(--color-bg-secondary)}.day-cell.other-month .day-number{color:var(--color-text-muted)}.day-cell.today{background:#00d4ff1a}.day-cell.today .day-number{background:var(--color-primary);color:var(--color-bg-primary);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.day-number{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.day-events{display:flex;flex-direction:column;gap:2px}.event-pill{padding:2px 6px;border-radius:var(--radius-sm);font-size:11px;color:#fff;position:relative;cursor:pointer}.event-title-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.event-tooltip{display:none;position:absolute;left:100%;top:0;margin-left:8px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;min-width:180px;white-space:normal}.day-cell:nth-child(7n) .event-tooltip,.day-cell:nth-child(7n-1) .event-tooltip{left:auto;right:100%;margin-left:0;margin-right:8px}.event-pill:hover .event-tooltip{display:block}.tooltip-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.tooltip-time{font-size:11px;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.tooltip-desc{font-size:11px;color:var(--color-text-secondary);line-height:1.4}.more-events{font-size:10px;color:var(--color-text-muted);padding:2px}.day-tooltip{display:none;position:absolute;left:50%;top:100%;transform:translate(-50%);margin-top:4px;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:99;min-width:200px;max-width:280px;white-space:normal}.day-cell:hover .day-tooltip{display:block}.day-cell:has(.event-pill:hover) .day-tooltip{display:none}.day-cell:nth-child(7n+1) .day-tooltip{left:0;transform:none}.day-cell:nth-child(7n) .day-tooltip{left:auto;right:0;transform:none}.day-cell:nth-last-child(-n+14) .day-tooltip{top:auto;bottom:100%;margin-top:0;margin-bottom:4px}.day-tooltip-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--color-border)}.day-tooltip-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.day-tooltip-item{display:flex;align-items:center;gap:var(--spacing-xs);font-size:11px}.day-tooltip-item .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.day-tooltip-item .time{color:var(--color-text-muted);flex-shrink:0}.day-tooltip-item .title{color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis}.week-view{height:100%;display:flex;flex-direction:column}.week-header{display:flex;border-bottom:1px solid var(--color-border)}.time-column-header{width:60px;flex-shrink:0}.week-day-header{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm);border-left:1px solid var(--color-border)}.week-day-header.today .week-day-number{background:var(--color-primary);color:var(--color-bg-primary);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.week-day-name{font-size:var(--font-size-xs);color:var(--color-text-muted)}.week-day-number{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.week-body{flex:1;display:flex;overflow-y:auto;min-height:0}.time-column{width:60px;flex-shrink:0;display:flex;flex-direction:column;min-height:max-content}.time-slot{height:60px;flex-shrink:0;font-size:11px;color:var(--color-text-muted);text-align:right;padding-right:var(--spacing-xs);display:flex;align-items:flex-start;transform:translateY(-8px)}.week-grid{flex:1;display:flex;min-width:0;min-height:max-content}.week-day-column{flex:1;border-left:1px solid var(--color-border);position:relative;display:flex;flex-direction:column}.hour-cell{height:60px;flex-shrink:0;border-bottom:1px solid var(--color-border);box-sizing:border-box}.hour-cell.drag-over{background:#00d4ff33}.week-event{position:absolute;left:2px;right:2px;border-radius:var(--radius-sm);padding:var(--spacing-xs);color:#fff;font-size:11px;overflow:hidden;z-index:10;cursor:pointer}.week-event .event-time{font-size:10px;opacity:.9}.week-event .event-title{font-weight:var(--font-weight-medium)}.day-view{height:100%;display:flex;flex-direction:column}.day-header{display:flex;align-items:baseline;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-bg-primary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.day-date{font-size:var(--font-size-xxl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.day-weekday{font-size:var(--font-size-md);color:var(--color-text-secondary)}.day-body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.day-hour-row{flex:1;display:flex;align-items:flex-start;min-height:28px;padding:2px 0;border-bottom:1px solid var(--color-border)}.hour-label{width:50px;flex-shrink:0;font-size:11px;color:var(--color-text-muted);text-align:right;padding-right:var(--spacing-sm)}.hour-marker{width:10px;height:10px;border-radius:50%;border:2px solid var(--color-border);background:var(--color-bg-primary);margin-right:var(--spacing-md)}.hour-events{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.day-event{background:var(--color-bg-primary);border-left:4px solid var(--color-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:0 var(--radius-md) var(--radius-md) 0}.event-time-range{font-size:var(--font-size-sm);color:var(--color-primary);margin-bottom:var(--spacing-xs)}.day-event .event-title{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.day-cell.drag-over{background:#00d4ff33!important;box-shadow:inset 0 0 10px #00d4ff4d}.event-modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);max-width:800px!important;width:95%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;padding:var(--spacing-sm);box-shadow:var(--shadow-lg);position:relative;z-index:10000}.modal-header h3{margin:0;font-size:20px;font-weight:600;color:var(--color-text-primary)}.modal-close{width:32px;height:32px;border:none;background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.event-modal-content form{padding:var(--spacing-sm)}.calendar-event.virtual{border:1px dashed #ffcc00;color:#bfa100;pointer-events:auto}.calendar-event.virtual:hover{background:#ffcc0040!important;transform:scale(1.02)}.calendar-event.virtual .event-title{font-weight:700}width: 100%; padding: 4px 8px; background: var(--color-bg-primary); border: 1px solid var(--color-border); border-radius: var(--radius-md); color: var(--color-text-primary); font-size: 13px !important; height: 32px; transition: var(--transition-fast); font-family: inherit; } .form-group textarea{height:auto;min-height:60px;padding:8px}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.form-row{display:flex;gap:var(--spacing-sm)}.form-row .form-group{flex:1}.linked-task-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:4px 8px;background:#00d4ff1a;border-radius:var(--radius-md);margin-bottom:8px;font-size:12px;color:var(--color-primary)}.link-icon{font-size:14px}.color-option{width:24px;height:24px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:var(--transition-fast)}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--color-text-primary);box-shadow:0 0 8px currentColor}.reminder-options{display:flex;flex-wrap:wrap;gap:4px}.reminder-btn{padding:4px 8px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:11px;cursor:pointer;transition:var(--transition-fast)}.reminder-btn:hover{border-color:var(--color-primary)}.reminder-btn.active{background:#00d4ff33;border-color:var(--color-primary);color:var(--color-primary)}.modal-actions{display:flex;justify-content:flex-end;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.modal-actions .btn-delete{margin-right:auto;padding:4px 16px;background:transparent;border:1px solid var(--color-danger);border-radius:var(--radius-lg);color:var(--color-danger);font-size:13px;cursor:pointer}.action-right{display:flex;gap:var(--spacing-sm)}.btn-cancel{padding:4px 16px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);font-size:13px;cursor:pointer}.btn-submit{padding:4px 16px;background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);font-size:13px;cursor:pointer}.btn-delete:hover{background:#ff6b6b1a}.event-pill,.week-event,.day-event{cursor:pointer;transition:var(--transition-fast)}.event-pill:hover{opacity:.8;transform:scale(1.02)}.week-event:hover,.day-event:hover{opacity:.9;box-shadow:var(--shadow-md)}.task-priority-tag{font-size:10px;padding:2px 6px;border-radius:4px;margin-right:4px;font-weight:600}.task-priority-tag.q1{background:#ff3b3026;color:#ff3b30;border:1px solid rgba(255,59,48,.3)}.task-priority-tag.q2{background:#00d4ff26;color:#00d4ff;border:1px solid rgba(0,212,255,.3)}.task-priority-tag.q3{background:#ffcc0026;color:#fc0;border:1px solid rgba(255,204,0,.3)}.task-priority-tag.q4{background:#4cd96426;color:#4cd964;border:1px solid rgba(76,217,100,.3)}.btn-focus{padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),#00b4d8);border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.btn-focus:hover:not(:disabled){box-shadow:var(--glow-primary-sm);transform:translateY(-1px)}.btn-focus.disabled,.btn-focus:disabled{background:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:not-allowed;opacity:.6}.task-card.mobile{cursor:pointer;touch-action:manipulation}.task-card.mobile:hover{transform:none;box-shadow:none}.task-card.mobile:active{transform:scale(.98);background:var(--color-bg-secondary)}.task-card-action{margin-top:var(--spacing-xs);padding-top:var(--spacing-xs);border-top:1px dashed var(--color-border)}.task-card-action .schedule-hint{font-size:var(--font-size-xs);color:var(--color-primary);display:flex;align-items:center;gap:var(--spacing-xs)}.task-card-action .schedule-hint:before{content:"📅"}@media(hover:none)and (pointer:coarse){.day-cell{min-height:60px;touch-action:manipulation}.day-cell:active{background:var(--color-bg-secondary)}.event-pill{touch-action:manipulation}.event-pill:active{opacity:.8}}@media(max-width:768px){.calendar-toolbar{flex-wrap:wrap;gap:var(--spacing-sm)}.toolbar-left,.toolbar-right{flex:1 1 100%;justify-content:center}.toolbar-center{order:-1;flex:1 1 100%;margin-bottom:var(--spacing-sm)}}.day-cell{-webkit-tap-highlight-color:transparent}.day-cell .day-number{pointer-events:none}@media(max-width:768px){.task-panel{font-size:14px}.task-card{padding:var(--spacing-md);min-height:44px}}.touch-drag-preview{animation:dragPulse .3s ease-out}@keyframes dragPulse{0%{transform:scale(.8);opacity:.7}to{transform:scale(1);opacity:.95}}@media(hover:none)and (pointer:coarse){.task-card{user-select:none;-webkit-user-select:none;touch-action:none}.task-card:active{transform:scale(.98);transition:transform .1s ease}}.drag-over-touch{background:#00d4ff26!important;box-shadow:inset 0 0 0 2px #00d4ff80;transition:all .15s ease}.task-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-sm)}.task-modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);max-width:800px!important;width:95%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;padding:0!important}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;font-size:var(--font-size-lg);color:var(--color-text-primary)}.modal-close{width:32px;height:32px;border:none;background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--color-danger);color:#fff}.task-modal-content form{padding:var(--spacing-sm)}.form-group{margin-bottom:4px}.form-group label{display:block;font-size:12px;color:var(--color-text-secondary);margin-bottom:2px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:4px 8px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:13px;height:32px}.form-group textarea{height:auto;min-height:60px;padding:8px}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.form-row{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.form-row>.form-group{flex:1;min-width:0}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-sm);margin-top:4px}.btn-cancel{padding:4px 16px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;font-size:13px}.btn-submit{padding:4px 16px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;white-space:nowrap;transition:var(--transition-fast);font-size:13px}.btn-submit:hover:not(:disabled){box-shadow:var(--glow-primary)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}input[type=date]{font-size:12px!important}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer;opacity:.8}.matrix-page{display:flex;height:100%;background-color:#0b0c15;color:#e0e0e0;overflow:hidden}.matrix-grid{flex:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:16px;padding:24px;height:100%}.quadrant{background:#ffffff08;border-radius:16px;padding:16px;display:flex;flex-direction:column;transition:all .3s ease;border:1px solid transparent;position:relative;overflow:hidden}.quadrant:hover{background:#ffffff0d}.q1-area{border-color:#ff3b304d;background:linear-gradient(145deg,#ff3b300d,#14141e80)}.q1-area .quadrant-header h3{color:#ff3b30}.q2-area{border-color:#00d4ff4d;background:linear-gradient(145deg,#00d4ff0d,#14141e80)}.q2-area .quadrant-header h3{color:#00d4ff}.q3-area{border-color:#ffcc004d;background:linear-gradient(145deg,#ffcc000d,#14141e80)}.q3-area .quadrant-header h3{color:#fc0}.q4-area{border-color:#4cd9644d;background:linear-gradient(145deg,#4cd9640d,#14141e80)}.q4-area .quadrant-header h3{color:#4cd964}.quadrant-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.quadrant-header h3{margin:0;font-size:1.2rem;font-weight:700}.quadrant-subtitle{font-size:.8rem;color:#ffffff80;display:block;margin-top:4px}.btn-add-mini{background:none;border:1px solid rgba(255,255,255,.2);color:#fff9;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center}.btn-add-mini:hover{background:#ffffff1a;color:#fff;border-color:#fff}.quadrant-body{flex:1;overflow-y:auto;padding-right:4px}.matrix-task-card{background:#ffffff14;border-radius:8px;padding:12px;margin-bottom:10px;cursor:grab;transition:transform .2s,box-shadow .2s;display:flex;justify-content:space-between;align-items:center;border:1px solid transparent}.matrix-task-card:hover{transform:translateY(-2px);background:#ffffff1f;box-shadow:0 4px 10px #0000004d}.task-content{flex:1;min-width:0}.task-title{font-size:.95rem;color:#fff;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-meta{display:flex;gap:8px;font-size:.75rem}.tag-subject{background:#00d4ff33;color:#00d4ff;padding:2px 6px;border-radius:4px}.tag-date{color:#aaa;display:flex;align-items:center}.btn-complete-mini{background:none;border:1px solid rgba(76,217,100,.3);color:#4cd964;width:24px;height:24px;border-radius:50%;margin-left:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}.matrix-task-card:hover .btn-complete-mini{opacity:1}.btn-complete-mini:hover{background:#4cd964;color:#fff}.matrix-sidebar{width:280px;background:#0003;border-left:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;padding:20px}.sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sidebar-header h3{margin:0;font-size:1rem;color:#aaa}.btn-add-main{background:#00d4ff;color:#1a1a2e;border:none;border-radius:6px;padding:6px 12px;font-weight:600;cursor:pointer;font-size:.85rem}.sidebar-list{flex:1;overflow-y:auto}.unsorted-card{border-left:3px solid #8e8e93}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-track{background:transparent}.loading-overlay{position:absolute;inset:0;background:#0b0c15cc;display:flex;justify-content:center;align-items:center;z-index:100;font-size:1.5rem;color:#00d4ff;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}[data-theme=light] .matrix-page{background-color:var(--color-bg-primary);color:var(--color-text-primary)}[data-theme=light] .quadrant{background:#ffffffb3;border:1px solid var(--color-border)}[data-theme=light] .quadrant:hover{background:#ffffffd9}[data-theme=light] .q1-area{border-color:#c346;background:linear-gradient(145deg,#cc334414,#ffffffe6)}[data-theme=light] .q1-area .quadrant-header h3{color:#c34}[data-theme=light] .q2-area{border-color:#09c6;background:linear-gradient(145deg,#0099cc14,#ffffffe6)}[data-theme=light] .q2-area .quadrant-header h3{color:#09c}[data-theme=light] .q3-area{border-color:#c906;background:linear-gradient(145deg,#cc990014,#ffffffe6)}[data-theme=light] .q3-area .quadrant-header h3{color:#c90}[data-theme=light] .q4-area{border-color:#00b36666;background:linear-gradient(145deg,#00b36614,#ffffffe6)}[data-theme=light] .q4-area .quadrant-header h3{color:#00b366}[data-theme=light] .quadrant-header{border-bottom-color:var(--color-border)}[data-theme=light] .quadrant-subtitle{color:var(--color-text-muted)}[data-theme=light] .btn-add-mini{border-color:var(--color-border);color:var(--color-text-muted)}[data-theme=light] .btn-add-mini:hover{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary)}[data-theme=light] .matrix-task-card{background:#fffc;border:1px solid var(--color-border)}[data-theme=light] .matrix-task-card:hover{background:#fffffff2;box-shadow:var(--shadow-md)}[data-theme=light] .task-title{color:var(--color-text-primary)}[data-theme=light] .tag-subject{background:#0099cc26;color:#09c}[data-theme=light] .tag-date{color:var(--color-text-muted)}[data-theme=light] .matrix-sidebar{background:#ffffff80;border-left-color:var(--color-border)}[data-theme=light] .sidebar-header h3{color:var(--color-text-secondary)}[data-theme=light] .btn-add-main{background:var(--color-primary);color:#fff}[data-theme=light] .unsorted-card{border-left-color:var(--color-text-muted)}[data-theme=light] .loading-overlay{background:#f5f3efe6;color:var(--color-primary)}.settings-page{display:flex;height:100%;gap:var(--spacing-lg)}.settings-sidebar{width:200px;display:flex;flex-direction:column;gap:var(--spacing-xs)}.settings-nav-item{padding:var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);text-align:left;cursor:pointer;transition:var(--transition-fast);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.settings-nav-item:hover:not(.disabled){background:var(--color-bg-tertiary);border-color:var(--color-primary)}.settings-nav-item.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold)}.settings-nav-item.disabled{opacity:.5;cursor:not-allowed}.coming-soon{font-size:var(--font-size-xs);color:var(--color-text-muted)}.settings-content{flex:1;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);overflow-y:auto}.subjects-section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.section-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.section-header h2{margin:0;font-size:var(--font-size-xl);color:var(--color-text-primary)}.btn-new{padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.btn-new:hover{box-shadow:var(--glow-primary);transform:translateY(-1px)}.subjects-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.subject-card{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:var(--transition-fast)}.subject-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #00d4ff1a}.subject-info{display:flex;align-items:center;gap:var(--spacing-md);flex:1}.subject-color-badge{width:12px;height:12px;border-radius:50%;flex-shrink:0}.subject-name{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.subject-usage{font-size:var(--font-size-sm);color:var(--color-text-muted)}.subject-actions{display:flex;gap:var(--spacing-sm)}.btn-edit,.btn-delete{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast);font-size:var(--font-size-sm)}.btn-edit:hover{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg-primary)}.btn-delete:hover{background:var(--color-danger);border-color:var(--color-danger);color:#fff}.empty-state button{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);cursor:pointer}.loading{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.edit-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header h3{margin:0;font-size:var(--font-size-lg)}.close-btn{width:32px;height:32px;border:none;background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:20px;cursor:pointer}.edit-modal form{padding:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.form-group input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-md)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.color-picker{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.color-btn{width:100%;aspect-ratio:1;border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);color:#fff;transition:var(--transition-fast)}.color-btn:hover{transform:scale(1.1)}.color-btn.selected{border-color:#fff;box-shadow:0 0 0 2px var(--color-primary)}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding-top:var(--spacing-md)}.btn-cancel,.btn-save{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-fast)}.btn-save{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;color:var(--color-bg-primary);font-weight:var(--font-weight-semibold)}.btn-save:hover{box-shadow:var(--glow-primary)}.system-section{display:flex;flex-direction:column;gap:var(--spacing-lg)}.settings-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.setting-item{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg)}.setting-info h3{margin:0 0 var(--spacing-xs) 0;font-size:var(--font-size-md);color:var(--color-text-primary)}.setting-info p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.theme-switcher{display:flex;gap:var(--spacing-sm)}.theme-option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-fast);min-width:100px}.theme-option:hover{border-color:var(--color-primary);background:var(--color-bg-tertiary)}.theme-option.active{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--glow-primary)}.theme-icon{font-size:24px}.theme-label{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.theme-option.active .theme-label{color:var(--color-primary)}.setting-value{display:flex;align-items:center}.coming-soon-badge{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-muted)}.focus-page{height:100%;display:flex;flex-direction:row;background:var(--color-bg-primary);position:relative;overflow:hidden}.task-sidebar{width:280px;height:100%;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);padding:var(--spacing-lg);display:flex;flex-direction:column;z-index:2}.sidebar-title{font-size:var(--font-size-md);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.sidebar-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.task-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-sm)}.task-item{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:grab;transition:var(--transition-fast)}.task-item:hover{border-color:var(--color-primary);transform:translate(4px)}.task-item:active{cursor:grabbing}.task-item.priority-Q1{border-left:3px solid var(--color-danger)}.task-item.priority-Q2{border-left:3px solid var(--color-warning)}.task-item.priority-Q3{border-left:3px solid var(--color-primary)}.task-item.priority-Q4{border-left:3px solid var(--color-text-muted)}.task-item .task-title{display:block;font-size:var(--font-size-sm);color:var(--color-text-primary);margin-bottom:2px}.task-item .task-subject{font-size:var(--font-size-xs);color:var(--color-text-muted)}.no-tasks{text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-xl) 0}.focus-main{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;overflow-y:auto}.focus-page:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(0,212,255,.1) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(255,0,128,.05) 0%,transparent 40%);pointer-events:none}.setup-panel{width:100%;max-width:600px;padding:var(--spacing-lg);z-index:1;transition:var(--transition-fast);margin:auto 0}.setup-panel.drag-over{background:#00d4ff0d;border-radius:var(--radius-xl)}.drop-zone{padding:var(--spacing-md);margin-bottom:var(--spacing-md);border:2px dashed var(--color-border);border-radius:var(--radius-md);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm);transition:var(--transition-fast)}.setup-panel.drag-over .drop-zone{border-color:var(--color-primary);background:#00d4ff1a;color:var(--color-primary)}.linked-task{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);margin-bottom:var(--spacing-md);background:#00d4ff1a;border:1px solid var(--color-primary);border-radius:var(--radius-md)}.linked-icon{font-size:var(--font-size-lg)}.linked-title{flex:1;color:var(--color-primary);font-weight:var(--font-weight-semibold)}.unlink-btn{width:24px;height:24px;background:transparent;border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-muted);cursor:pointer;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs)}.unlink-btn:hover{border-color:var(--color-danger);color:var(--color-danger)}.stats-bar{display:flex;justify-content:center;gap:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.stats-bar .stat-item{text-align:center}.stats-bar .stat-value{display:block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary)}.stats-bar .stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.setup-title{text-align:center;font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.setup-panel .form-group{margin-bottom:var(--spacing-md)}.setup-panel label{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.setup-panel input[type=text]{width:100%;padding:var(--spacing-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm)}.setup-panel input[type=text]:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.duration-options{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.duration-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast);font-size:var(--font-size-sm)}.duration-btn:hover{border-color:var(--color-primary)}.duration-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold)}.sound-options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.sound-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast);font-size:var(--font-size-sm)}.sound-btn:hover{border-color:var(--color-primary)}.sound-btn.active{background:#00d4ff33;border-color:var(--color-primary);color:var(--color-primary)}.hardcore-toggle label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer}.hardcore-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-warning)}.toggle-label{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.toggle-desc{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-left:auto}.start-btn{width:100%;padding:var(--spacing-md) var(--spacing-lg);margin-top:var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-bold);cursor:pointer;transition:var(--transition-fast)}.start-btn:hover{box-shadow:var(--glow-primary);transform:translateY(-2px)}.focus-hud{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}.hardcore-warning{position:absolute;top:0;left:0;right:0;padding:var(--spacing-md);background:var(--color-danger);color:#fff;text-align:center;font-weight:var(--font-weight-semibold);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.task-banner{position:absolute;top:var(--spacing-xl);padding:var(--spacing-sm) var(--spacing-lg);background:#00d4ff1a;border:1px solid var(--color-primary);border-radius:var(--radius-lg);color:var(--color-primary);font-size:var(--font-size-sm)}.timer-container{position:relative;width:280px;height:280px}.progress-ring{width:100%;height:100%;transform:rotate(-90deg)}.progress-ring-bg{stroke:var(--color-border)}.progress-ring-fill{stroke:var(--color-primary);stroke-linecap:round;transition:stroke-dashoffset 1s linear}.timer-display{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.timer-time{display:block;font-size:4rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);font-family:Courier New,monospace;letter-spacing:2px}.timer-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.control-bar{position:absolute;bottom:var(--spacing-xl);left:0;right:0;padding:0 var(--spacing-xl);display:flex;justify-content:space-between;align-items:center}.elapsed-info{color:var(--color-text-muted);font-size:var(--font-size-sm)}.control-buttons{display:flex;gap:var(--spacing-md)}.complete-btn,.abandon-btn{padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-fast);font-size:var(--font-size-sm)}.complete-btn{background:var(--color-success);border:none;color:#fff}.complete-btn:hover{box-shadow:0 0 12px #4cd96480}.abandon-btn{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted)}.abandon-btn:hover{border-color:var(--color-danger);color:var(--color-danger)}.result-panel{text-align:center;z-index:1}.result-icon{font-size:5rem;margin-bottom:var(--spacing-lg);animation:bounce .5s ease}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.result-panel h2{font-size:var(--font-size-2xl);color:var(--color-text-primary);margin-bottom:var(--spacing-xl)}.result-stats{display:flex;justify-content:center;gap:var(--spacing-2xl);margin-bottom:var(--spacing-2xl)}.result-item{text-align:center}.result-item .result-value{display:block;font-size:3rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.result-item.highlight .result-value{color:var(--color-primary);text-shadow:0 0 20px var(--color-primary)}.result-item .result-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.continue-btn{padding:var(--spacing-md) var(--spacing-2xl);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-xl);color:var(--color-bg-primary);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.continue-btn:hover{box-shadow:var(--glow-primary);transform:translateY(-2px)}.habit-page{padding:var(--spacing-lg);max-width:800px;margin:0 auto;position:relative}.habit-page.loading{display:flex;align-items:center;justify-content:center;height:60vh;color:var(--color-text-muted)}.encouragement-toast{position:fixed;top:80px;left:50%;transform:translate(-50%);padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--color-bg-primary);border-radius:var(--radius-lg);font-weight:var(--font-weight-semibold);box-shadow:var(--shadow-lg);z-index:1000;animation:slideDown .3s ease,fadeOut .3s ease 2.7s forwards}@keyframes slideDown{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes fadeOut{to{opacity:0;transform:translate(-50%) translateY(-10px)}}.habit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.habit-header h2{color:var(--color-text-primary);margin:0}.btn-add{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.btn-add:hover{box-shadow:var(--glow-primary-sm);transform:translateY(-1px)}.habit-list{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.habit-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-card);border-left:4px solid var(--color-primary);border-radius:var(--radius-md);transition:var(--transition-fast);box-shadow:var(--shadow-sm)}.habit-card:hover{background:var(--color-bg-card);transform:translateY(-2px);box-shadow:var(--shadow-md)}.habit-card.checked{opacity:.7}.habit-icon{font-size:var(--font-size-2xl);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.habit-info{flex:1}.habit-name{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:4px}.habit-streak{font-size:var(--font-size-sm);color:var(--color-text-muted)}.record-badge{display:inline-block;margin-left:var(--spacing-sm);padding:2px 6px;background:var(--color-warning-light);color:var(--color-warning-hover);font-size:10px;border-radius:4px;font-weight:var(--font-weight-medium);border:1px solid var(--color-warning-light)}.habit-mini-heatmap{display:flex;gap:var(--spacing-sm);padding:0 var(--spacing-md)}.mini-day-wrapper{display:flex;flex-direction:column;align-items:center;gap:2px}.mini-day-wrapper.today .mini-day{border:2px solid var(--color-primary)}.mini-day{width:24px;height:24px;border-radius:4px;background:var(--color-bg-tertiary);border:1px solid var(--color-border-hover);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--color-bg-primary);transition:var(--transition-fast)}.mini-day.checked{background:var(--color-primary)}.mini-day.clickable{cursor:pointer}.mini-day.clickable:hover{background:#00d4ff4d;transform:scale(1.1)}.mini-day-label{font-size:10px;color:var(--color-text-muted)}.habit-card.selected{border:1px solid var(--color-primary);box-shadow:var(--glow-primary-sm)}.check-btn{padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast);min-width:70px;white-space:nowrap}.check-btn:hover:not(:disabled){box-shadow:var(--glow-primary-sm);transform:translateY(-1px)}.check-btn:disabled{opacity:.7;cursor:wait}.check-btn.unchecked{background:var(--color-bg-tertiary);color:var(--color-text-muted)}.check-btn.unchecked:hover{background:var(--color-danger);color:#fff;box-shadow:none}.heatmap-section{padding:var(--spacing-lg);background:var(--color-bg-secondary);border-radius:var(--radius-lg)}.heatmap-section h3{color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0;font-size:var(--font-size-md)}.heatmap-grid{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:var(--spacing-md)}.heatmap-day{width:20px;height:20px;border-radius:4px;background:var(--color-bg-tertiary)}.heatmap-day.level-1{background:#00d4ff4d}.heatmap-day.level-2{background:#00d4ff80}.heatmap-day.level-3{background:#00d4ffb3}.heatmap-day.level-4{background:var(--color-primary)}.heatmap-legend{display:flex;align-items:center;gap:4px;justify-content:flex-end;font-size:var(--font-size-xs);color:var(--color-text-muted)}.heatmap-legend .heatmap-day{width:12px;height:12px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999}.create-habit-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);max-width:800px!important;width:95%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;padding:var(--spacing-sm)}.create-habit-modal h3{margin:0 0 var(--spacing-sm) 0;color:var(--color-text-primary);font-size:var(--font-size-lg);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-sm)}.create-habit-modal .form-group{margin-bottom:4px}.create-habit-modal label{display:block;font-size:12px;color:var(--color-text-secondary);margin-bottom:2px}.create-habit-modal input[type=text],.create-habit-modal input[type=number],.create-habit-modal textarea{width:100%;padding:4px 8px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:13px;height:32px;font-family:inherit}.create-habit-modal input:focus,.create-habit-modal textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary-sm)}.modal-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border);padding-bottom:4px}.tab-btn{flex:1;padding:6px;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:13px;cursor:pointer;text-align:center;transition:var(--transition-fast)}.tab-btn:hover{background:var(--color-bg-tertiary)}.tab-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-bg-primary)}.icon-picker{display:flex;gap:4px;flex-wrap:wrap;background:var(--color-bg-tertiary);padding:8px;border-radius:var(--radius-md);border:1px solid var(--color-border)}.icon-picker button{width:32px;height:32px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:16px;cursor:pointer;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center;padding:0}.icon-picker button:hover{border-color:var(--color-primary);background:var(--color-bg-primary)}.icon-picker button.selected{border-color:var(--color-primary);background:#00d4ff33;box-shadow:0 0 0 1px var(--color-primary)}.color-picker{display:flex;gap:8px;padding:4px 0}.color-picker button{width:24px;height:24px;border:2px solid transparent;border-radius:50%;cursor:pointer;transition:var(--transition-fast)}.color-picker button:hover{transform:scale(1.1)}.color-picker button.selected{border-color:var(--color-text-primary);box-shadow:0 0 8px currentColor}.modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-md);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.btn-cancel{padding:4px 16px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;font-size:13px}.btn-submit{padding:4px 16px;background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;font-size:13px}.btn-submit:hover{box-shadow:var(--glow-primary-sm)}.ai-recommend-section{display:flex;flex-direction:column;gap:var(--spacing-sm)}.btn-ai-recommend{width:100%;padding:8px;background:linear-gradient(135deg,var(--color-secondary),var(--color-primary));border:none;border-radius:var(--radius-md);color:var(--color-bg-primary);font-weight:var(--font-weight-semibold);cursor:pointer;font-size:13px}.recommendations-list{margin-top:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:8px;background:var(--color-bg-tertiary)}.recommendation-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px;background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:4px;cursor:pointer;border:2px solid transparent;transition:all .2s ease}.recommendation-item:hover{border-color:var(--color-primary);background:var(--color-bg-tertiary)}.recommendation-item.selected{border-color:var(--color-primary);background:#00d4ff1a;box-shadow:0 0 0 1px var(--color-primary)}.rec-checkbox{width:20px;height:20px;border:2px solid var(--color-border);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--color-bg-primary);background:var(--color-bg-tertiary);flex-shrink:0}.recommendation-item.selected .rec-checkbox{background:var(--color-primary);border-color:var(--color-primary)}.selected-summary{padding:8px;background:#00d4ff1a;border:1px solid var(--color-primary);border-radius:var(--radius-md);text-align:center;font-size:13px;color:var(--color-primary)}.rec-icon{font-size:20px}.rec-info{flex:1;display:flex;flex-direction:column;gap:2px}.rec-name{font-weight:500;font-size:13px}.rec-benefit{font-size:11px;color:var(--color-text-muted)}.encouragement-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000d9;color:#fff;padding:20px 40px;border-radius:12px;z-index:1000;font-size:1.2rem;font-weight:700;text-align:center;box-shadow:0 10px 30px #0000004d;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeInOut 3s ease-in-out forwards;pointer-events:none;border:1px solid rgba(255,255,255,.1)}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-40%)}10%{opacity:1;transform:translate(-50%,-50%)}90%{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-60%)}}.habit-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.habit-card{transition:transform .4s ease,opacity .3s ease,box-shadow .2s ease;position:relative}.delete-btn{position:absolute;top:8px;right:8px;background:transparent;border:none;font-size:14px;cursor:pointer;opacity:0;transition:opacity .2s ease,transform .2s ease;padding:4px;border-radius:4px;z-index:10}.habit-card:hover .delete-btn{opacity:.5}.delete-btn:hover{opacity:1!important;transform:scale(1.2);background:#ff646433}.delete-modal{max-width:380px;text-align:center}.delete-modal h3{color:var(--color-danger, #ff6b6b);margin-bottom:var(--spacing-lg)}.delete-warning{background:var(--color-bg-tertiary);padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.delete-warning p{margin:var(--spacing-sm) 0;color:var(--color-text-secondary)}.delete-warning strong{color:var(--color-primary)}.warning-text{color:var(--color-danger, #ff6b6b)!important;font-size:var(--font-size-sm);margin-top:var(--spacing-md)!important}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:center}.btn-cancel{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;font-weight:var(--font-weight-medium);transition:var(--transition-fast)}.btn-cancel:hover{background:var(--color-primary);border-color:var(--color-primary)}.btn-danger{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-danger, #ff6b6b);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-weight:var(--font-weight-medium);transition:var(--transition-fast)}.btn-danger:hover{background:#ff4757;transform:translateY(-1px)}.gamified-dashboard{padding:10px}.gamified-loading,.gamified-error{text-align:center;padding:40px;color:#888}.gamified-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:12px;max-height:calc(100vh - 160px)}@media(max-width:768px){.gamified-grid{grid-template-columns:1fr}}.gamified-card{background:linear-gradient(145deg,#1e1e32e6,#141423f2);border-radius:12px;padding:12px;border:1px solid rgba(255,255,255,.1);transition:transform .3s ease,box-shadow .3s ease;overflow:hidden}.gamified-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000004d}.card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.card-icon{font-size:18px}.card-header h3{margin:0;font-size:14px;color:#fff}.card-content{color:#ccc}.flow-savings-card{border-color:#10b98166}.flow-savings-card .card-content{display:flex;flex-direction:row;flex:1;gap:20px}.flow-left{flex:1;display:flex;align-items:center;justify-content:center}.flow-right{flex:1;display:flex;flex-direction:column;justify-content:center;gap:12px}.flow-main-row{display:flex;flex-direction:row;flex:1;gap:16px}.flow-left-section{flex:1;display:flex;align-items:center;justify-content:center;position:relative}.bottle-svg{width:100px;height:160px}.bottle-percent{position:absolute;font-size:22px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.flow-right-section{flex:1;display:flex;flex-direction:column;justify-content:center;gap:12px}.today-row{display:flex;flex-direction:column}.today-value{font-size:36px;font-weight:700;color:#10b981}.today-label{font-size:14px;color:#888}.badge-info{display:flex;flex-direction:column}.badge-text{font-size:14px;color:#aaa}.remaining-text{font-size:15px;color:#10b981;font-weight:600}.enc-emoji{font-size:20px}.enc-text{font-size:14px;color:#10b981;font-weight:500}.total-text{font-size:13px;color:#888}.energy-bottle{position:relative;width:100px;height:160px;border:3px solid #10b981;border-radius:12px 12px 20px 20px;overflow:hidden;background:#10b9811a}.energy-bottle:before{content:"";position:absolute;top:-12px;left:50%;transform:translate(-50%);width:35px;height:14px;background:#10b981;border-radius:8px 8px 0 0}.energy-fill{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,#10b981,#34d399);transition:height .5s ease;animation:bubbles 2s infinite}@keyframes bubbles{0%,to{opacity:.8}50%{opacity:1}}.energy-percent{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:18px;font-weight:700;color:#fff;text-shadow:0 0 10px rgba(0,0,0,.5)}.today-focus{margin-bottom:0}.today-focus .value{font-size:32px;font-weight:700;color:#10b981}.today-focus .label{display:block;font-size:13px;color:#888}.badge-progress{font-size:13px}.badge-name{color:#aaa}.badge-remain{display:block;color:#10b981;font-weight:600}.encouragement-box{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#10b98126;border-radius:10px}.encouragement-emoji{font-size:18px}.encouragement-text{font-size:13px;color:#10b981;font-weight:500}.total-focus{font-size:13px;color:#888}.willpower-card{border-color:#ff6b354d}.willpower-left{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.willpower-right{flex:1;display:flex;flex-direction:column;justify-content:center;padding-left:16px;border-left:1px solid rgba(255,255,255,.1)}.willpower-content{display:flex;flex-direction:column;flex:1}.willpower-main-row{display:flex;flex-direction:row;flex:1}.willpower-left-section{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.flame-display{font-size:32px;margin-bottom:4px;line-height:1}.streak-row{display:flex;align-items:baseline;gap:6px}.flame-desc{font-size:16px;color:#f97316;margin-top:4px;text-align:center}.willpower-right-section{flex:1;display:flex;flex-direction:column;justify-content:center;padding-left:16px;border-left:1px solid rgba(255,255,255,.1);gap:10px}.habit-row{display:flex;align-items:center;justify-content:space-between}.habit-name{font-size:14px;color:#8b5cf6;font-weight:500}.habit-right{display:flex;align-items:center;gap:6px}.habit-days{font-size:14px;color:#f97316;font-weight:600}.habit-dot{font-size:8px;color:#f97316}.habit-bar{width:60px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.habit-fill{height:100%;background:#f97316;border-radius:3px}.daily-row{display:flex;align-items:center;justify-content:center;gap:10px;background:#ffffff14;padding:10px 16px;border-radius:10px;margin-top:8px;flex-wrap:nowrap;white-space:nowrap}.daily-label{font-size:14px;color:#888;white-space:nowrap}.daily-rate{font-size:18px;font-weight:700;color:#fff}.daily-badge{font-size:13px;color:#fff;font-weight:600;padding:4px 12px;border-radius:12px;background:#ffffff26}.daily-badge.perfect{background:#f97316}.daily-badge.excellent{background:#10b981}.streak-display{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:4px}.flame{font-size:28px;animation:flicker .5s infinite alternate}.flame-level-4,.flame-level-5{animation:flicker .3s infinite alternate,glow 1s infinite}@keyframes flicker{0%{transform:scale(1)}to{transform:scale(1.1)}}@keyframes glow{0%,to{filter:drop-shadow(0 0 5px #ff6b35)}50%{filter:drop-shadow(0 0 15px #ff6b35)}}.streak-number{font-size:52px;font-weight:700;color:#f97316}.streak-unit{font-size:20px;color:#888;margin-left:6px}.flame-description{text-align:center;font-size:12px;color:#ff6b35;margin-bottom:8px}.daily-effectiveness{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;background:#ffffff0d;border-radius:8px}.daily-label{font-size:12px;color:#888}.daily-rate{font-size:16px;font-weight:700;color:#fff}.daily-level{font-size:12px;padding:3px 10px;border-radius:12px;background:#ffffff1a}.daily-level.perfect{background:linear-gradient(135deg,gold,#ff6b35);color:#000}.daily-level.excellent{background:#52efdb;color:#000}.individual-streaks{display:flex;flex-direction:column;gap:8px}.habit-streak{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px;font-size:12px}.habit-name{color:#8b5cf6;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.habit-days{color:#ff6b35;font-weight:600}.habit-progress-bar{width:60px;height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden}.habit-progress-fill{height:100%;background:linear-gradient(90deg,#ff6b35,orange);border-radius:3px;transition:width .3s ease}.trust-index-card{border-color:#bc13fe4d}.trust-score-display{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:8px}.trust-score{font-size:64px;font-weight:700;color:#8b5cf6}.trust-trend{font-size:28px;font-weight:700;margin-left:10px}.trust-trend.up{color:#52efdb}.trust-trend.down{color:#ff4757}.trust-trend.stable{color:#888}.trust-level{text-align:center;font-size:18px;font-weight:700;padding:8px 20px;border-radius:16px;margin:0 auto 16px;width:fit-content}.trust-level.level-outstanding{background:linear-gradient(135deg,#52efdb,#2dd4bf);color:#000}.trust-level.level-excellent{background:#bc13fe;color:#fff}.trust-level.level-good{background:#7c3aed;color:#fff}.trust-level.level-fair{background:orange;color:#000}.trust-level.level-poor{background:#ff4757;color:#fff}.trust-components{display:flex;flex-direction:column;gap:6px}.component{display:grid;grid-template-columns:90px 1fr 50px;align-items:center;gap:12px}.comp-label{font-size:14px;color:#888}.comp-bar{height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.comp-fill{height:100%;background:linear-gradient(90deg,#bc13fe,#7c3aed);border-radius:3px;transition:width .3s ease}.comp-value{font-size:16px;color:#8b5cf6;text-align:right;font-weight:600}.life-balance-card{border-color:#7c3aed4d}.life-balance-card .card-content{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:0}.radar-container{height:170px;display:flex;align-items:flex-start;justify-content:center;width:100%;margin-top:-10px}.balance-footer{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;flex-shrink:0;padding:8px 0}.balance-label{font-size:14px;color:#888}.balance-value{font-size:24px;font-weight:700;color:#8b5cf6}.balance-suggestion{font-size:13px;color:#aaa;margin-left:8px}[data-theme=light] .gamified-card{background:linear-gradient(145deg,#fffffff2,#f8f8fcfa);border-color:#0000001a;box-shadow:0 2px 8px #00000014}[data-theme=light] .gamified-card:hover{box-shadow:0 4px 16px #0000001f}[data-theme=light] .card-header h3{color:#1a1a2e}[data-theme=light] .card-content{color:#444}[data-theme=light] .flow-savings-card{border-color:#10b9814d}[data-theme=light] .energy-bottle{border-color:#10b981;background:#0000000d}[data-theme=light] .energy-bottle:before{background:#10b981}[data-theme=light] .energy-fill{background:linear-gradient(to top,#10b981,#34d399)}[data-theme=light] .today-focus .value{color:#10b981}[data-theme=light] .today-focus .label,[data-theme=light] .total-focus,[data-theme=light] .badge-name{color:#666}[data-theme=light] .badge-remain{color:#10b981}[data-theme=light] .willpower-card{border-color:#f973164d}[data-theme=light] .streak-number{color:#f97316}[data-theme=light] .streak-unit{color:#666}[data-theme=light] .flame-description{color:#f97316}[data-theme=light] .daily-effectiveness{background:#0000000a}[data-theme=light] .daily-label{color:#666}[data-theme=light] .daily-rate{color:#1a1a2e}[data-theme=light] .daily-level{background:#0000000f;color:#666}[data-theme=light] .habit-name{color:#666}[data-theme=light] .habit-days{color:#f97316}[data-theme=light] .habit-progress-bar{background:#00000014}[data-theme=light] .trust-index-card{border-color:#8b5cf64d}[data-theme=light] .trust-score{background:linear-gradient(135deg,#8b5cf6,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}[data-theme=light] .trust-level.level-outstanding{background:linear-gradient(135deg,#10b981,#34d399)}[data-theme=light] .trust-level.level-excellent{background:#8b5cf6}[data-theme=light] .trust-level.level-good{background:#a78bfa}[data-theme=light] .comp-label{color:#666}[data-theme=light] .comp-bar{background:#00000014}[data-theme=light] .comp-fill{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}[data-theme=light] .comp-value{color:#8b5cf6}[data-theme=light] .life-balance-card{border-color:#8b5cf64d}[data-theme=light] .balance-score{color:#666}[data-theme=light] .score-value{color:#8b5cf6}[data-theme=light] .suggested-action{background:#8b5cf614;color:#666;border-color:#8b5cf64d}.stats-page{padding:24px;max-width:1200px;margin:0 auto}.stats-header{margin-bottom:32px}.stats-header h1{font-size:2rem;color:var(--text-primary);margin-bottom:8px}.stats-header p{color:var(--text-secondary)}.stats-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px}.stats-section{background:var(--bg-card);border-radius:16px;padding:24px;border:1px solid var(--border-color)}.stats-section h2{font-size:1.2rem;margin-bottom:16px;display:flex;align-items:center;gap:8px}.placeholder-chart{height:300px;display:flex;align-items:center;justify-content:center;background:#0003;border-radius:8px;color:var(--text-secondary)}.ai-insights{grid-column:1 / -1;background:linear-gradient(135deg,#52efdb1a,#bc13fe1a);border:1px solid rgba(82,239,219,.3);display:flex;flex-direction:column;gap:20px}.ai-message{display:flex;gap:16px;align-items:flex-start}.ai-avatar{font-size:2rem;background:#ffffff1a;padding:8px;border-radius:50%}.ai-text p{margin:4px 0;line-height:1.5}.ai-summary{color:var(--text-primary);font-weight:500}.ai-suggestion{color:gold;font-size:.9em}.ai-chat-container{background:#0003;border-radius:12px;padding:16px;margin-top:8px}.chat-history{max-height:200px;overflow-y:auto;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}.chat-bubble{max-width:80%;padding:8px 12px;border-radius:12px;font-size:.9rem;line-height:1.4}.chat-bubble.user{align-self:flex-end;background:var(--primary-color);color:#fff;border-bottom-right-radius:2px}.chat-bubble.assistant{align-self:flex-start;background:#ffffff1a;color:var(--text-primary);border-bottom-left-radius:2px}.chat-input-area{display:flex;gap:8px}.chat-input-area input{flex:1;background:#0000004d;border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;color:#fff}.chat-input-area button{background:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:0 16px;cursor:pointer;transition:all .2s}.chat-input-area button:hover{filter:brightness(1.1)}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed}.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;grid-column:1 / -1}@media(max-width:768px){.stats-row{grid-template-columns:1fr}}.task-stats-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 0}.task-stat-number{font-size:3rem;font-weight:700;margin-bottom:16px}.task-stat-number .completed{color:#52efdb}.task-stat-number .separator{color:#666;margin:0 8px}.task-stat-number .total{color:#888}.task-progress-bar{width:80%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden;margin-bottom:12px}.task-progress-fill{height:100%;background:linear-gradient(90deg,#52efdb,#bc13fe);border-radius:4px;transition:width .5s ease}.task-rate{font-size:1rem;color:#aaa}.empty-state{display:flex;align-items:center;justify-content:center;height:200px;color:#888;font-size:.9rem}.heatmap-container{padding:10px 0}.heatmap-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:4px;margin-bottom:12px}.heatmap-cell{aspect-ratio:1;border-radius:3px;min-width:12px;min-height:12px}.heatmap-cell.level-0{background:#ffffff1a}.heatmap-cell.level-1{background:#52efdb4d}.heatmap-cell.level-2{background:#52efdb80}.heatmap-cell.level-3{background:#52efdbb3}.heatmap-cell.level-4{background:#52efdb}.heatmap-legend{display:flex;align-items:center;justify-content:center;gap:4px;font-size:.75rem;color:#888}.heatmap-legend .heatmap-cell{width:12px;height:12px}.points-section{background:linear-gradient(135deg,#ffd7001a,#bc13fe1a);border:1px solid rgba(255,215,0,.3)}.points-overview{display:flex;flex-direction:column;gap:20px;padding:10px 0}.points-main{display:flex;align-items:center;justify-content:space-between}.points-balance{display:flex;align-items:baseline;gap:8px}.points-value{font-size:3rem;font-weight:700;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px rgba(255,215,0,.3)}.points-label{font-size:1rem;color:#888}.level-badge{background:linear-gradient(135deg,#bc13fe,#7c3aed);color:#fff;font-weight:700;font-size:1.2rem;padding:8px 16px;border-radius:20px;box-shadow:0 0 20px #bc13fe66}.level-progress-container{display:flex;flex-direction:column;gap:8px}.level-progress-bar{width:100%;height:10px;background:#ffffff1a;border-radius:5px;overflow:hidden}.level-progress-fill{height:100%;background:linear-gradient(90deg,#bc13fe,#52efdb);border-radius:5px;transition:width .8s ease;box-shadow:0 0 10px #52efdb80}.level-progress-text{font-size:.85rem;color:#aaa;text-align:right}.next-level-points{margin-left:6px;color:#666}.points-trend{display:flex;align-items:flex-end;gap:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1)}.trend-label{font-size:.85rem;color:#888;white-space:nowrap}.trend-bars{flex:1;display:flex;align-items:flex-end;gap:4px;height:40px}.trend-bar{flex:1;min-width:12px;border-radius:2px 2px 0 0;transition:height .3s ease}.trend-bar.positive{background:linear-gradient(to top,#52efdb80,#52efdb)}.trend-bar.negative{background:linear-gradient(to top,#ff475780,#ff4757)}.store-page{display:flex;flex-direction:column;height:100%;gap:var(--spacing-lg)}.store-header{display:flex;justify-content:center;padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-bg-secondary),var(--color-bg-tertiary));border:1px solid var(--color-border);border-radius:var(--radius-xl)}.points-balance{display:flex;align-items:center;gap:var(--spacing-sm)}.points-icon{font-size:32px}.points-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-primary);text-shadow:var(--glow-primary)}.points-label{font-size:var(--font-size-md);color:var(--color-text-secondary)}.store-tabs{display:flex;gap:var(--spacing-sm);padding:var(--spacing-xs);background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.store-tab{flex:1;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:var(--transition-fast)}.store-tab:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.store-tab.active{background:var(--color-primary);color:var(--color-bg-primary)}.store-content{flex:1;overflow-y:auto}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);color:var(--color-text-muted)}.empty-icon{font-size:64px;margin-bottom:var(--spacing-md)}.empty-hint{font-size:var(--font-size-sm);margin-top:var(--spacing-xs)}.rewards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.reward-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:var(--transition-fast)}.reward-card:hover:not(.disabled){border-color:var(--color-primary);box-shadow:var(--glow-primary);transform:translateY(-2px)}.reward-card.disabled{opacity:.7;cursor:not-allowed}.reward-image{position:relative;height:140px;background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center}.reward-image img{width:100%;height:100%;object-fit:cover}.reward-placeholder{font-size:48px}.reward-placeholder.large{font-size:64px}.reward-category{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background:#000000b3;border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-primary)}.reward-info{padding:var(--spacing-md)}.reward-name{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reward-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.reward-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.reward-price{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-warning)}.reward-stock{font-size:var(--font-size-xs);color:var(--color-text-muted)}.progress-bar{height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-success));border-radius:var(--radius-full);transition:width .3s ease}.can-redeem{color:var(--color-success);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.sold-out{color:var(--color-danger);font-size:var(--font-size-sm)}.points-needed{color:var(--color-text-muted);font-size:var(--font-size-sm)}.redemptions-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.redemption-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.redemption-image{width:60px;height:60px;background:var(--color-bg-tertiary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.redemption-image img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md)}.redemption-info{flex:1;min-width:0}.redemption-info h4{font-size:var(--font-size-md);color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.redemption-points{font-size:var(--font-size-sm);color:var(--color-warning);margin-bottom:var(--spacing-xs)}.redemption-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.redemption-status{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.status-pending{background:var(--color-warning-light);color:var(--color-warning)}.status-fulfilled{background:var(--color-success-light);color:var(--color-success)}.status-cancelled{background:var(--color-danger-light);color:var(--color-danger)}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-md)}.redeem-modal{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:400px;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-border)}.modal-header h3{font-size:var(--font-size-lg);color:var(--color-text-primary)}.close-btn{width:32px;height:32px;background:var(--color-bg-tertiary);border:none;border-radius:var(--radius-full);color:var(--color-text-secondary);font-size:20px;cursor:pointer;transition:var(--transition-fast)}.close-btn:hover{background:var(--color-danger);color:#fff}.modal-body{padding:var(--spacing-lg)}.redeem-preview{text-align:center;margin-bottom:var(--spacing-lg)}.redeem-image{width:100px;height:100px;margin:0 auto var(--spacing-md);background:var(--color-bg-tertiary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;overflow:hidden}.redeem-image img{width:100%;height:100%;object-fit:cover}.redeem-preview h4{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.redeem-price{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-warning)}.redeem-summary{background:var(--color-bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-md)}.summary-row{display:flex;justify-content:space-between;padding:var(--spacing-sm) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.summary-row:not(:last-child){border-bottom:1px solid var(--color-border)}.summary-row .deduct{color:var(--color-danger)}.summary-row.total{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-actions{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border)}.btn-cancel,.btn-confirm{flex:1;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);font-weight:var(--font-weight-semibold);cursor:pointer;transition:var(--transition-fast)}.btn-cancel{background:var(--color-bg-tertiary);border:1px solid var(--color-border);color:var(--color-text-secondary)}.btn-cancel:hover{border-color:var(--color-text-secondary)}.btn-confirm{background:linear-gradient(135deg,var(--color-primary),var(--color-success));border:none;color:var(--color-bg-primary)}.btn-confirm:hover{box-shadow:var(--glow-primary)}.btn-confirm:disabled{opacity:.6;cursor:not-allowed}.family-circle-layout{display:flex;flex-direction:column;gap:.75rem;width:100%!important;max-width:100%!important;height:100%;color:var(--color-text-primary);box-sizing:border-box;margin:0;padding:0}@media(max-width:768px){.family-circle-layout{padding:1rem}}.mood-weather-bar{background:var(--color-bg-card);padding:.75rem;border-radius:8px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:1rem;align-items:center;width:100%!important;max-width:100%!important;box-sizing:border-box}.my-mood-section{flex-shrink:0;padding-right:2rem;border-right:1px solid var(--color-border);min-width:fit-content}@media(max-width:600px){.mood-weather-bar{flex-direction:column;gap:1.5rem}.my-mood-section{border-right:none;padding-right:0;border-bottom:1px solid var(--color-border);padding-bottom:1.5rem;width:100%}}.my-mood-section h4,.family-moods-section h4{margin:0 0 1rem;font-size:.9rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.mood-selector{display:flex;gap:.8rem;flex-wrap:wrap}.mood-btn{font-size:1.5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.mood-btn:hover{transform:translateY(-2px);background:var(--color-bg-tertiary)}.mood-btn.active{background:var(--color-primary-light);border-color:var(--color-primary);transform:scale(1.1);box-shadow:0 0 0 2px var(--color-primary-light)}.family-moods-section{flex:1;overflow:hidden;min-width:0}.family-mood-list{display:flex;gap:1.5rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:none}.family-mood-list::-webkit-scrollbar{display:none}.member-mood-item{display:flex;flex-direction:column;align-items:center;gap:.5rem;flex-shrink:0}.member-avatar{position:relative;width:48px;height:48px}.member-avatar img,.avatar-placeholder{width:100%;height:100%;border-radius:50%;object-fit:cover;border:2px solid var(--color-border)}.avatar-placeholder{background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.mood-badge{position:absolute;bottom:-4px;right:-4px;background:var(--color-bg-card);border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.member-name{font-size:.8rem;color:var(--color-text-secondary);white-space:nowrap}.create-post-card{background:var(--color-bg-card);padding:.75rem;border-radius:8px;border:1px solid var(--color-border);position:relative;width:100%!important;max-width:100%!important;box-sizing:border-box}.post-input{width:100%;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;padding:1rem;min-height:80px;resize:vertical;color:var(--color-text-primary);font-family:inherit;margin-bottom:1rem;transition:border-color .2s;box-sizing:border-box}.post-input:focus{outline:none;border-color:var(--color-primary)}.image-preview-area{margin-bottom:1rem;position:relative;display:inline-block}.upload-preview{max-height:200px;max-width:100%;width:auto;height:auto;object-fit:contain;display:block;border-radius:8px;border:1px solid var(--color-border)}.remove-image-btn{position:absolute;top:-8px;right:-8px;background:#e74c3c;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 2px 4px #0003}.post-actions{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.action-tools{display:flex;gap:.5rem;flex-wrap:wrap}.tool-btn{background:transparent;border:none;color:var(--color-text-secondary);padding:.5rem .8rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.4rem;font-size:.9rem;transition:background .2s;white-space:nowrap}.tool-btn:hover{background:var(--color-bg-secondary);color:var(--color-primary)}.tool-btn.active{background:var(--color-primary-light);color:var(--color-primary)}.post-submit-btn{background:var(--color-primary);color:#fff;border:none;padding:.6rem 1.5rem;border-radius:20px;font-weight:500;cursor:pointer;transition:opacity .2s;white-space:nowrap}.post-submit-btn:disabled{opacity:.6;cursor:not-allowed}.praise-selector-panel{margin-top:1rem;background:var(--color-bg-secondary);border-radius:12px;padding:1rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.8rem;animation:slideDown .2s ease-out}.praise-option{display:flex;align-items:center;gap:.6rem;padding:.8rem;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s}.praise-option:hover{border-color:var(--color-primary);transform:translateY(-2px)}.selected-praise-preview{background:var(--color-primary-light);padding:.8rem 1rem;border-radius:8px;display:flex;align-items:center;gap:.8rem;margin-bottom:1rem;color:var(--color-primary-dark)}.close-btn{margin-left:auto;background:none;border:none;font-size:1.2rem;cursor:pointer;color:currentColor}.moments-feed{display:flex;flex-direction:column;gap:.75rem;width:100%!important;max-width:100%!important}.moment-card{background:var(--color-bg-card);border-radius:8px;padding:.75rem;border:1px solid var(--color-border);width:100%!important;max-width:100%!important;box-sizing:border-box}.moment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.author-info{display:flex;gap:1rem;align-items:center}.author-avatar,.author-avatar-placeholder{width:40px;height:40px;border-radius:50%;object-fit:cover}.author-avatar-placeholder{background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.author-meta{display:flex;flex-direction:column}.author-name{font-weight:600;color:var(--color-text-primary)}.post-time{font-size:.8rem;color:var(--color-text-secondary)}.moment-content{margin-bottom:1rem;font-size:1rem;line-height:1.6}.moment-images{display:flex;gap:.5rem;margin-top:.8rem;flex-wrap:wrap}.moment-image{max-height:300px;max-width:100%;width:auto;height:auto;border-radius:8px;cursor:pointer;border:1px solid var(--color-border);object-fit:contain;display:block}.moment-image-error{width:200px;height:150px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-bg-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--color-text-secondary)}.moment-image-error .error-icon{font-size:2rem}.moment-image-error .error-text{font-size:.85rem}.praise-badge{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,gold,orange);color:#fff;padding:.4rem 1rem;border-radius:20px;margin-bottom:.8rem;font-weight:700;box-shadow:0 2px 4px #ffa5004d}.interaction-bar{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid var(--color-border)}.action-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;gap:.4rem;font-size:.9rem;padding:.4rem .8rem;border-radius:6px;transition:background .2s}.action-btn:hover{background:var(--color-bg-secondary)}.action-btn.liked{color:#e74c3c}.sidebar-widget{background:var(--color-bg-card);border-radius:16px;padding:1.5rem;border:1px solid var(--color-border);margin-bottom:1.5rem}.widget-header{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}.widget-header h3{margin:0;font-size:1.1rem;color:var(--color-text-primary)}.widget-icon{font-size:1.5rem}.ai-widget{background:linear-gradient(135deg,var(--color-bg-card) 0%,rgba(var(--color-primary-rgb),.1) 100%);border:1px solid var(--color-primary-light)}.ai-question-content p{font-size:1rem;font-weight:500;margin-bottom:1rem;line-height:1.5}.answer-btn{display:block;text-align:center;background:var(--color-primary);color:#fff;padding:.6rem;border-radius:8px;text-decoration:none;font-weight:500;transition:opacity .2s}.answer-btn:hover{opacity:.9}.ai-card{border-left:4px solid var(--color-primary);background:linear-gradient(to right,rgba(var(--color-primary-rgb),.05),transparent)}.ai-header{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem;color:var(--color-primary);font-weight:600}.ai-body h3{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary)}.comments-section{margin-top:1rem;background:var(--color-bg-secondary);padding:1rem;border-radius:8px}.comment-item{font-size:.9rem;margin-bottom:.5rem}.comment-author{font-weight:600;margin-right:.5rem;color:var(--color-text-primary)}.comment-input-box{display:flex;gap:.5rem;margin-top:.8rem}.comment-input-box input{flex:1;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;font-size:.9rem}.comment-input-box button{background:var(--color-primary);color:#fff;border:none;padding:0 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}:root,[data-theme=dark]{--color-bg-primary: #0f0f1a;--color-bg-secondary: #1a1a2e;--color-bg-tertiary: #16213e;--color-bg-card: rgba(26, 26, 46, .8);--color-primary: #00d4ff;--color-primary-hover: #00b8e6;--color-primary-light: rgba(0, 212, 255, .1);--color-primary-glow: 0 0 20px rgba(0, 212, 255, .4);--color-secondary: #7b2cbf;--color-secondary-hover: #6a24a8;--color-secondary-light: rgba(123, 44, 191, .1);--color-success: #00ff88;--color-success-hover: #00e67a;--color-success-light: rgba(0, 255, 136, .1);--color-warning: #ffd700;--color-warning-hover: #e6c200;--color-warning-light: rgba(255, 215, 0, .1);--color-danger: #ff4757;--color-danger-hover: #e63e4d;--color-danger-light: rgba(255, 71, 87, .1);--color-text-primary: #ffffff;--color-text-secondary: rgba(255, 255, 255, .7);--color-text-muted: rgba(255, 255, 255, .5);--color-text-disabled: rgba(255, 255, 255, .3);--color-border: rgba(255, 255, 255, .1);--color-border-hover: rgba(255, 255, 255, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .3);--glow-primary: 0 0 10px rgba(0, 212, 255, .3), 0 0 20px rgba(0, 212, 255, .2);--glow-success: 0 0 10px rgba(0, 255, 136, .3), 0 0 20px rgba(0, 255, 136, .2);--glow-warning: 0 0 10px rgba(255, 215, 0, .3), 0 0 20px rgba(255, 215, 0, .2);--glow-danger: 0 0 10px rgba(255, 71, 87, .3), 0 0 20px rgba(255, 71, 87, .2);--glass-bg: rgba(26, 26, 46, .6);--glass-border: rgba(255, 255, 255, .1);--glass-blur: blur(10px)}[data-theme=light]{--color-bg-primary: #f5f3ef;--color-bg-secondary: #e8e4dd;--color-bg-tertiary: #ddd8d0;--color-bg-card: rgba(255, 255, 255, .9);--color-primary: #0099cc;--color-primary-hover: #007aa3;--color-primary-light: rgba(0, 153, 204, .1);--color-primary-glow: 0 0 15px rgba(0, 153, 204, .25);--color-secondary: #6a24a8;--color-secondary-hover: #5a1d90;--color-secondary-light: rgba(106, 36, 168, .1);--color-success: #00b366;--color-success-hover: #009955;--color-success-light: rgba(0, 179, 102, .1);--color-warning: #cc9900;--color-warning-hover: #b38600;--color-warning-light: rgba(204, 153, 0, .1);--color-danger: #cc3344;--color-danger-hover: #b32d3c;--color-danger-light: rgba(204, 51, 68, .1);--color-text-primary: #1a1a2e;--color-text-secondary: rgba(26, 26, 46, .75);--color-text-muted: rgba(26, 26, 46, .55);--color-text-disabled: rgba(26, 26, 46, .35);--color-border: rgba(26, 26, 46, .12);--color-border-hover: rgba(26, 26, 46, .25);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .12);--shadow-xl: 0 20px 30px rgba(0, 0, 0, .15);--glow-primary: 0 0 8px rgba(0, 153, 204, .2);--glow-success: 0 0 8px rgba(0, 179, 102, .2);--glow-warning: 0 0 8px rgba(204, 153, 0, .2);--glow-danger: 0 0 8px rgba(204, 51, 68, .2);--glass-bg: rgba(255, 255, 255, .7);--glass-border: rgba(26, 26, 46, .1);--glass-blur: blur(10px)}:root{--color-q1: #ff4757;--color-q2: #00ff88;--color-q3: #ffa502;--color-q4: #636e72;--color-subject-math: #3498db;--color-subject-chinese: #e74c3c;--color-subject-english: #2ecc71;--color-subject-physics: #9b59b6;--color-subject-chemistry: #f39c12;--color-subject-biology: #1abc9c;--color-subject-history: #e67e22;--color-subject-geography: #16a085;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", monospace;--font-size-xs: 12px;--font-size-sm: 14px;--font-size-md: 16px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 32px;--font-size-3xl: 48px;--font-size-4xl: 64px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .5s;--transition-fast: all .15s ease;--transition-normal: all .3s ease;--transition-slow: all .5s ease;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh}a{color:var(--color-primary);text-decoration:none;transition:var(--transition-fast)}a:hover{color:var(--color-primary-hover)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;background:none}input,textarea,select{font-family:inherit;font-size:inherit;color:var(--color-text-primary);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition-fast)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--glow-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}::selection{background:var(--color-primary);color:var(--color-bg-primary)}#root{min-height:100vh}.website-layout{display:flex;flex-direction:column;min-height:100vh;background-color:var(--bg-primary, #1a1a1a);color:var(--text-primary, #ffffff);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.website-main{flex:1}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.website-header{position:sticky;top:0;z-index:1000;background-color:#1a1a1af2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color, #333);padding:1rem 0}.website-header .container{display:flex;justify-content:space-between;align-items:center}.website-header .logo{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:var(--text-primary, #fff);text-decoration:none}.website-header .logo-img{width:32px;height:32px;object-fit:contain;border-radius:6px}.website-header .main-nav{display:flex;gap:1.5rem}.website-header .main-nav a{color:var(--text-secondary, #aaa);text-decoration:none;font-weight:500;transition:color .2s}.website-header .main-nav a:hover{color:var(--primary, #00d4ff)}.website-header .actions{display:flex;align-items:center;gap:1rem}.btn{padding:.5rem 1rem;border-radius:.5rem;text-decoration:none;font-weight:500;transition:all .2s}.btn-ghost{color:var(--text-primary, #fff)}.btn-ghost:hover{background-color:#ffffff1a}.btn-primary{background-color:var(--primary, #00d4ff);color:#000}.btn-primary:hover{filter:brightness(1.1)}.website-footer{background-color:#111;padding:3rem 0;margin-top:auto;border-top:1px solid #333}.footer-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem}.footer-cols h4{margin-bottom:1rem;color:var(--text-primary, #fff)}.footer-cols a{display:block;margin-bottom:.5rem;color:var(--text-secondary, #888);text-decoration:none}.footer-cols a:hover{color:var(--primary, #00d4ff)}.footer-bottom{border-top:1px solid #333;padding-top:2rem;text-align:center;color:#666;font-size:.9rem}.data-processing{margin-top:.5rem;font-size:.8rem;opacity:.7}.hero-section{padding:6rem 0;text-align:center;background:radial-gradient(circle at center,rgba(0,212,255,.1) 0%,transparent 70%)}.hero-title{font-size:3.5rem;font-weight:800;margin-bottom:1.5rem;background:linear-gradient(135deg,#fff,#00d4ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{font-size:1.25rem;color:var(--text-secondary, #aaa);margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto}.hero-cta{display:inline-block;padding:1rem 2rem;font-size:1.1rem}.legal-info{font-size:.75rem;color:#888;margin-bottom:.25rem}@media(max-width:768px){.website-header .main-nav{display:none}.hero-title{font-size:2.5rem}}
