/* ============================================ IMMERSE - Obsidian Plugin Styles Inspired by https://www.blitzit.app/ ============================================ */ /* ============ CSS Variables ============ */ .immerse-container { --ft-primary: #6366f1; --ft-primary-light: #818cf8; --ft-primary-dark: #4f46e5; --ft-success: #22c55e; --ft-warning: #f59e0b; --ft-danger: #ef4444; --ft-break: #06b6d4; --ft-bg: var(--background-primary); --ft-bg-secondary: var(--background-secondary); --ft-bg-tertiary: var(--background-modifier-hover); --ft-text: var(--text-normal); --ft-text-muted: var(--text-muted); --ft-border: var(--background-modifier-border); --ft-radius: 12px; --ft-radius-sm: 8px; --ft-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06); --ft-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); } /* ============ Container ============ */ .immerse-container { padding: 16px; font-family: var(--font-interface); overflow-y: auto; height: 100%; } /* ============ Header ============ */ .immerse-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--ft-border); } .immerse-title-section { display: flex; flex-direction: column; gap: 4px; } .immerse-title { margin: 0; font-size: 24px; font-weight: 700; background: linear-gradient(135deg, var(--ft-primary) 0%, var(--ft-primary-light) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; } .immerse-date { color: var(--ft-text-muted); font-size: 13px; } .immerse-header-actions { display: flex; gap: 8px; } /* ============ Buttons ============ */ .immerse-btn { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 8px 16px; border-radius: var(--ft-radius-sm); font-size: 14px; font-weight: 500; cursor: pointer; transition: all 0.2s ease; border: none; background: var(--ft-bg-tertiary); color: var(--ft-text); } .immerse-btn:hover { background: var(--ft-border); transform: translateY(-1px); } .immerse-btn-primary { background: linear-gradient(135deg, var(--ft-primary) 0%, var(--ft-primary-dark) 100%); color: white; } .immerse-btn-primary:hover { background: linear-gradient(135deg, var(--ft-primary-light) 0%, var(--ft-primary) 100%); box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4); } .immerse-btn-success { background: var(--ft-success); color: white; } .immerse-btn-success:hover { background: #16a34a; } .immerse-btn-secondary { background: var(--ft-bg-secondary); border: 1px solid var(--ft-border); } .immerse-btn-danger { background: transparent; color: var(--ft-danger); border: 1px solid var(--ft-danger); } .immerse-btn-danger:hover { background: var(--ft-danger); color: white; } /* ============ Stats Bar ============ */ .immerse-stats-bar { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 20px; } @media (max-width: 600px) { .immerse-stats-bar { grid-template-columns: repeat(2, 1fr); } } .immerse-stat-item { background: var(--ft-bg-secondary); border-radius: var(--ft-radius); padding: 12px; text-align: center; transition: all 0.2s ease; } .immerse-stat-item:hover { transform: translateY(-2px); box-shadow: var(--ft-shadow); } .immerse-stat-icon { font-size: 20px; margin-bottom: 4px; } .immerse-stat-value { font-size: 18px; font-weight: 700; color: var(--ft-primary); } .immerse-stat-label { font-size: 11px; color: var(--ft-text-muted); text-transform: uppercase; letter-spacing: 0.5px; } /* ============ Active Task Section ============ */ .immerse-active-section { margin-bottom: 24px; } .immerse-start-prompt { background: linear-gradient(135deg, var(--ft-bg-secondary) 0%, var(--ft-bg-tertiary) 100%); border: 2px dashed var(--ft-border); border-radius: var(--ft-radius); padding: 32px; text-align: center; } .immerse-prompt-icon { font-size: 48px; margin-bottom: 12px; animation: ft-pulse 2s ease-in-out infinite; } @keyframes ft-pulse { 0%, 100% { transform: scale(1); opacity: 1; } 50% { transform: scale(1.1); opacity: 0.8; } } .immerse-prompt-text { font-size: 18px; font-weight: 600; color: var(--ft-text); margin-bottom: 4px; } .immerse-prompt-hint { font-size: 14px; color: var(--ft-text-muted); } /* ============ Active Task Card ============ */ .immerse-active-card { background: linear-gradient(135deg, var(--ft-primary) 0%, var(--ft-primary-dark) 100%); border-radius: var(--ft-radius); padding: 24px; color: white; box-shadow: var(--ft-shadow-lg); } .immerse-break-card { background: linear-gradient(135deg, var(--ft-break) 0%, #0891b2 100%); } .immerse-active-label { font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 1px; opacity: 0.9; margin-bottom: 8px; } .immerse-active-task-name { font-size: 20px; font-weight: 700; margin-bottom: 16px; word-break: break-word; } .immerse-timer-display { text-align: center; margin-bottom: 16px; } .immerse-timer-time { font-size: 48px; font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: 2px; } .immerse-timer-time.immerse-overtime { color: var(--ft-warning); } /* Progress Bar */ .immerse-progress-wrap { background: rgba(255, 255, 255, 0.2); border-radius: 999px; height: 8px; overflow: hidden; margin-bottom: 12px; } .immerse-progress-bar { height: 100%; background: rgba(255, 255, 255, 0.9); border-radius: 999px; transition: width 0.3s ease; } .immerse-progress-bar.immerse-overtime { background: var(--ft-warning); } .immerse-time-info { display: flex; justify-content: space-between; font-size: 13px; opacity: 0.9; margin-bottom: 16px; } .immerse-active-controls { display: flex; gap: 8px; flex-wrap: wrap; } .immerse-active-controls .immerse-btn { flex: 1 1 auto; min-width: 100px; max-width: 100%; background: rgba(255, 255, 255, 0.2); color: white; border: none; white-space: normal; word-wrap: break-word; line-height: 1.3; padding: 8px 12px; } .immerse-active-controls .immerse-btn:hover { background: rgba(255, 255, 255, 0.3); } .immerse-active-controls .immerse-btn-success { background: var(--ft-success); } .immerse-active-controls .immerse-btn-danger { background: transparent; border: 1px solid rgba(255, 255, 255, 0.4); } /* ============ Task List Section ============ */ .immerse-list-section { flex: 1; } /* Filters */ .immerse-filters { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; } .immerse-filter-btn { padding: 6px 12px; border-radius: 999px; font-size: 13px; background: var(--ft-bg-secondary); border: 1px solid var(--ft-border); color: var(--ft-text-muted); cursor: pointer; transition: all 0.2s ease; } .immerse-filter-btn:hover { background: var(--ft-bg-tertiary); color: var(--ft-text); } .immerse-filter-btn.active { background: var(--ft-primary); border-color: var(--ft-primary); color: white; } /* Task List */ .immerse-task-list { display: flex; flex-direction: column; gap: 8px; } /* Empty State */ .immerse-empty-state { text-align: center; padding: 40px 20px; color: var(--ft-text-muted); } .immerse-empty-icon { font-size: 48px; margin-bottom: 12px; opacity: 0.5; } .immerse-empty-text { font-size: 16px; font-weight: 500; margin-bottom: 4px; } .immerse-empty-hint { font-size: 14px; } /* ============ Task Item ============ */ .immerse-task-item { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--ft-bg-secondary); border-radius: var(--ft-radius-sm); border: 1px solid transparent; transition: all 0.2s ease; } .immerse-task-item:hover { border-color: var(--ft-primary); box-shadow: var(--ft-shadow); transform: translateX(4px); } .immerse-task-item.active { border-color: var(--ft-primary); background: linear-gradient(90deg, rgba(99, 102, 241, 0.1) 0%, var(--ft-bg-secondary) 100%); } .immerse-task-item.completed { opacity: 0.6; } .immerse-task-item.completed .immerse-task-text { text-decoration: line-through; } /* Checkbox */ .immerse-checkbox { width: 24px; height: 24px; min-width: 24px; border: 2px solid var(--ft-primary); border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; cursor: pointer; transition: all 0.2s ease; } .immerse-checkbox:hover { transform: scale(1.1); box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2); } /* Task Content */ .immerse-task-content { flex: 1; min-width: 0; } .immerse-task-header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; } .immerse-task-text { font-size: 14px; font-weight: 500; color: var(--ft-text); word-break: break-word; } .immerse-list-badge { font-size: 11px; padding: 2px 8px; border-radius: 999px; font-weight: 500; } .immerse-task-meta { display: flex; gap: 12px; font-size: 12px; color: var(--ft-text-muted); } .immerse-overtime-text { color: var(--ft-warning); } .immerse-schedule-badge { padding: 2px 8px; background: var(--ft-primary); color: white; border-radius: 4px; font-size: 11px; font-weight: 500; } .immerse-schedule-badge.overdue { background: var(--ft-danger); animation: pulse-overdue 2s ease-in-out infinite; } @keyframes pulse-overdue { 0%, 100% { opacity: 1; } 50% { opacity: 0.7; } } .immerse-task-item.overdue { border-left: 3px solid var(--ft-danger); } /* Task Actions */ .immerse-task-actions { display: flex; gap: 4px; opacity: 0; transition: opacity 0.2s ease; } .immerse-task-item:hover .immerse-task-actions { opacity: 1; } .immerse-task-btn { width: 32px; height: 32px; border-radius: 6px; display: flex; align-items: center; justify-content: center; background: var(--ft-bg-tertiary); border: none; cursor: pointer; font-size: 14px; transition: all 0.2s ease; } .immerse-task-btn:hover { background: var(--ft-primary); color: white; transform: scale(1.1); } .immerse-delete-btn:hover { background: var(--ft-danger); } /* ============ Status Bar Timer ============ */ .immerse-status-bar { cursor: pointer; padding: 0 8px; display: flex; align-items: center; gap: 4px; font-size: 12px; transition: all 0.2s ease; } .immerse-status-bar:hover { color: var(--text-accent); } .immerse-status-bar.immerse-status-active { color: var(--text-accent); font-weight: 500; } /* ============ Modal Styles ============ */ .immerse-modal { padding: 20px; } .immerse-modal h2 { margin-top: 0; margin-bottom: 20px; } .immerse-modal-buttons { display: flex; justify-content: flex-end; gap: 8px; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--ft-border); } /* About section in settings */ .immerse-about { background: var(--ft-bg-secondary); border-radius: var(--ft-radius); padding: 16px; margin-top: 8px; } .immerse-about p { margin: 0 0 12px 0; line-height: 1.6; } .immerse-about p:last-child { margin-bottom: 0; } .immerse-about a { color: var(--ft-primary); } /* ============ Scrollbar Styling ============ */ .immerse-container::-webkit-scrollbar { width: 8px; } .immerse-container::-webkit-scrollbar-track { background: transparent; } .immerse-container::-webkit-scrollbar-thumb { background: var(--ft-border); border-radius: 4px; } .immerse-container::-webkit-scrollbar-thumb:hover { background: var(--ft-text-muted); } /* ============ Animations ============ */ @keyframes ft-checkComplete { 0% { transform: scale(1); } 50% { transform: scale(1.3); } 100% { transform: scale(1); } } .immerse-checkbox.completing { animation: ft-checkComplete 0.3s ease; } /* ============ Dark mode adjustments ============ */ .theme-dark .immerse-status-bar { background: var(--background-secondary); } /* ============ Mobile Responsive ============ */ @media (max-width: 400px) { .immerse-header { flex-direction: column; align-items: flex-start; gap: 12px; } .immerse-active-controls { flex-direction: column; } .immerse-active-controls .immerse-btn { flex: none; width: 100%; } .immerse-task-item { flex-wrap: wrap; } .immerse-task-actions { opacity: 1; width: 100%; justify-content: flex-end; margin-top: 8px; } } /* ============ Report View ============ */ .immerse-report-view { padding: 20px; overflow-y: auto; height: 100%; } .immerse-report-header { margin-bottom: 20px; padding-bottom: 10px; border-bottom: 2px solid var(--ft-border); } .immerse-report-title { font-size: 28px; font-weight: 700; margin: 0 0 10px 0; color: var(--ft-text); } .immerse-report-filters { background: var(--ft-bg-secondary); padding: 12px; border-radius: var(--ft-radius); margin-bottom: 16px; } .immerse-report-filter-row { display: flex; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; align-items: center; } .immerse-report-filter-row .setting-item { flex: 1; min-width: 200px; margin: 0 !important; padding: 0 !important; border: none !important; display: flex !important; flex-direction: row !important; align-items: center !important; gap: 12px; } .immerse-report-filter-row .setting-item > * { margin: 0 !important; padding: 0 !important; } .immerse-report-filter-row .setting-item-info { flex-shrink: 0 !important; width: auto !important; min-width: 80px !important; max-width: 100px !important; padding: 0 !important; margin: 0 !important; } .immerse-report-filter-row .setting-item-control { flex-grow: 1 !important; padding: 0 !important; margin: 0 !important; } .immerse-report-filter-row .setting-item-name { margin: 0 !important; padding: 0 !important; line-height: 1.4 !important; } .immerse-report-filter-row .setting-item-description { display: none !important; } .immerse-report-filter-row input[type="date"] { width: 100% !important; margin: 0 !important; } .immerse-report-quick-filters { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; } .immerse-filter-label { font-weight: 500; color: var(--ft-text); font-size: 14px; } .immerse-quick-filter-btn { padding: 6px 12px; border-radius: 6px; background: var(--ft-bg); border: 1px solid var(--ft-border); color: var(--ft-text); cursor: pointer; transition: all 0.3s ease; font-size: 13px; white-space: nowrap; position: relative; } .immerse-quick-filter-btn:hover { background: var(--ft-primary); color: white; border-color: var(--ft-primary); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3); } .immerse-quick-filter-btn.active { background: var(--ft-primary); color: white; border-color: var(--ft-primary); box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2), 0 0 20px rgba(99, 102, 241, 0.4); animation: pulse-glow 2s ease-in-out infinite; } @keyframes pulse-glow { 0%, 100% { box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2), 0 0 20px rgba(99, 102, 241, 0.4); } 50% { box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.3), 0 0 25px rgba(99, 102, 241, 0.6); } } .immerse-report-generate-btn { width: 100%; margin-bottom: 20px; } .immerse-report-content { margin-top: 20px; } .immerse-no-data-message { text-align: center; padding: 60px 20px; color: var(--ft-text-muted); font-size: 16px; } /* Stats Grid */ .immerse-stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 16px; margin-bottom: 30px; } .immerse-stat-card { background: var(--ft-bg-secondary); padding: 16px; border-radius: var(--ft-radius); text-align: center; border: 1px solid var(--ft-border); } .immerse-stat-label { font-size: 11px; font-weight: 600; color: var(--ft-text-muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 10px; } .immerse-stat-value-row { display: flex; align-items: center; justify-content: center; gap: 8px; } .immerse-stat-icon { font-size: 24px; } .immerse-stat-value { font-size: 28px; font-weight: 700; color: var(--ft-text); } /* Report Sections */ .immerse-report-section { margin-bottom: 40px; } .immerse-report-section-title { font-size: 20px; font-weight: 700; margin-bottom: 20px; color: var(--ft-text); padding-bottom: 10px; border-bottom: 2px solid var(--ft-border); position: relative; } .immerse-report-section-title::after { content: ''; position: absolute; bottom: -2px; left: 0; width: 60px; height: 2px; background: linear-gradient(90deg, var(--ft-primary), var(--ft-success)); } /* Time by List */ .immerse-time-by-list { display: flex; flex-direction: column; gap: 16px; } .immerse-list-stat-item { background: var(--ft-bg-secondary); padding: 16px; border-radius: 10px; border: 1px solid var(--ft-border); transition: all 0.2s ease; } .immerse-list-stat-item:hover { transform: translateX(4px); box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); } .immerse-list-info { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; } .immerse-list-icon { font-size: 22px; filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.1)); } .immerse-list-name { font-weight: 600; color: var(--ft-text); font-size: 16px; } .immerse-list-progress { width: 100%; height: 10px; background: var(--ft-bg); border-radius: 5px; overflow: hidden; margin-bottom: 10px; box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1); } .immerse-list-progress-fill { height: 100%; transition: width 0.6s ease; border-radius: 5px; } .immerse-list-stats { display: flex; justify-content: space-between; font-size: 13px; gap: 8px; flex-wrap: wrap; } .immerse-list-stat-text { color: var(--ft-text-muted); } .immerse-list-stat-percentage { font-weight: 600; color: var(--ft-text); } /* Insights */ .immerse-insights-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; } .immerse-insight-card { background: var(--ft-bg-secondary); padding: 28px; border-radius: 16px; text-align: center; border: 2px solid var(--ft-border); position: relative; overflow: visible; transition: all 0.3s ease; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05); } .immerse-insight-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--ft-primary); border-radius: 16px 16px 0 0; } .immerse-insight-card:hover { transform: translateY(-4px); box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12); border-color: var(--ft-primary); } .immerse-insight-icon { font-size: 48px; margin-bottom: 12px; display: block; filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.1)); } .immerse-insight-label { font-size: 10px; font-weight: 700; color: var(--ft-text-muted); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 16px; display: block; } .immerse-insight-value { font-size: 32px; font-weight: 800; color: var(--ft-primary); text-shadow: 0 2px 4px rgba(0, 0, 0, 0.08); line-height: 1.2; display: block; } /* Daily Breakdown - Enhanced Visual Chart Style */ .immerse-daily-breakdown-container { display: flex; flex-direction: column; gap: 16px; } .immerse-daily-row { display: grid; grid-template-columns: 110px 1fr; gap: 20px; align-items: center; padding: 20px; background: linear-gradient(135deg, var(--ft-bg-secondary) 0%, var(--ft-bg) 100%); border-radius: 12px; border: 2px solid var(--ft-border); transition: all 0.3s ease; position: relative; overflow: hidden; } .immerse-daily-row::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: linear-gradient(180deg, var(--ft-primary), var(--ft-success)); opacity: 0; transition: opacity 0.3s ease; } .immerse-daily-row:hover::before { opacity: 1; } .immerse-daily-row:hover { transform: translateX(6px); box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12); border-color: var(--ft-primary); } .immerse-daily-date { font-weight: 800; color: var(--ft-text); font-size: 14px; text-align: center; display: flex; flex-direction: column; gap: 4px; } .immerse-daily-date-day { font-size: 11px; color: var(--ft-text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 1px; } .immerse-daily-date-num { font-size: 16px; color: var(--ft-primary); } .immerse-daily-bars { display: flex; flex-direction: column; gap: 12px; flex: 1; } .immerse-daily-bar-row { display: flex; align-items: center; gap: 12px; } .immerse-daily-bar-label { min-width: 90px; font-size: 12px; color: var(--ft-text-muted); font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; display: flex; align-items: center; gap: 6px; } .immerse-daily-bar-icon { font-size: 16px; } .immerse-daily-bar-track { flex: 1; height: 12px; background: var(--ft-bg); border-radius: 6px; overflow: hidden; position: relative; box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1); } .immerse-daily-bar-fill { height: 100%; border-radius: 6px; transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1); position: relative; overflow: hidden; } /* Pie chart for daily breakdown */ .immerse-daily-pie-container { display: flex; align-items: center; justify-content: center; gap: 40px; margin-top: 30px; } .immerse-daily-pie-chart { position: relative; width: 280px; height: 280px; border-radius: 50%; display: flex; align-items: center; justify-content: center; /* Background set via inline style for proper gradient rendering */ box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15); transition: transform 0.3s ease; } .immerse-daily-pie-chart:hover { transform: scale(1.05); } .immerse-daily-pie-center { position: absolute; width: 160px; height: 160px; background: var(--ft-bg); border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; box-shadow: 0 0 20px rgba(0, 0, 0, 0.1); } .immerse-daily-pie-center-value { font-size: 36px; font-weight: 800; color: var(--ft-text-primary); line-height: 1; } .immerse-daily-pie-center-label { font-size: 12px; font-weight: 500; color: var(--ft-text-secondary); text-transform: uppercase; letter-spacing: 1px; margin-top: 4px; } .immerse-daily-pie-legend { display: flex; flex-direction: column; gap: 20px; } .immerse-daily-pie-legend-item { display: flex; align-items: center; gap: 12px; } .immerse-daily-pie-legend-color { width: 24px; height: 24px; border-radius: 6px; flex-shrink: 0; } .immerse-daily-pie-legend-info { display: flex; flex-direction: column; gap: 2px; } .immerse-daily-pie-legend-label { font-size: 13px; font-weight: 600; color: var(--ft-text-primary); display: flex; align-items: center; gap: 6px; } .immerse-daily-pie-legend-value { font-size: 20px; font-weight: 700; color: var(--ft-text-primary); } .immerse-daily-pie-legend-percentage { font-size: 12px; color: var(--ft-text-secondary); font-weight: 500; } .immerse-daily-bar-fill.tasks { background: linear-gradient(90deg, var(--ft-primary), #7c3aed); } .immerse-daily-bar-fill.hours { background: linear-gradient(90deg, var(--ft-success), #059669); } .immerse-daily-bar-fill.pomodoros { background: linear-gradient(90deg, var(--ft-warning), #dc2626); } .immerse-daily-bar-value { min-width: 50px; text-align: right; font-weight: 800; font-size: 14px; color: var(--ft-text); font-feature-settings: 'tnum'; font-variant-numeric: tabular-nums; } /* Responsive adjustments for smaller screens */ @media (max-width: 768px) { .immerse-report-view { padding: 15px; } .immerse-stats-grid { grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 12px; } .immerse-insights-grid { grid-template-columns: 1fr; } .immerse-report-filter-row { flex-direction: column; } .immerse-report-filter-row .setting-item { min-width: 100%; } /* Pie chart mobile optimization */ .immerse-daily-pie-container { flex-direction: column; gap: 30px; } .immerse-daily-pie-chart { width: 220px; height: 220px; } .immerse-daily-pie-center { width: 130px; height: 130px; } .immerse-daily-pie-center-value { font-size: 28px; } /* Daily breakdown mobile optimization */ .immerse-daily-row { flex-direction: column; gap: 12px; } .immerse-daily-date { flex-direction: row; gap: 8px; align-items: center; margin-bottom: 8px; } .immerse-daily-bars { width: 100%; } .immerse-daily-bar-label { min-width: 70px; font-size: 11px; } .immerse-daily-bar-track { flex: 1; } .immerse-daily-bar-value { min-width: 40px; font-size: 12px; } /* Task list mobile optimization */ .immerse-task-item { padding: 10px 12px; font-size: 14px; } .immerse-task-actions { opacity: 1; } .immerse-task-btn { width: 36px; height: 36px; font-size: 16px; } /* Active card mobile optimization */ .immerse-active-card { padding: 20px 16px; } .immerse-timer-time { font-size: 40px; } /* Stats bar mobile optimization */ .immerse-stats-bar { grid-template-columns: repeat(2, 1fr); gap: 10px; } .immerse-stat-item { padding: 10px; } .immerse-stat-value { font-size: 16px; } .immerse-stat-label { font-size: 10px; } /* Modal optimization for mobile */ .immerse-modal { padding: 16px; max-height: 80vh; overflow-y: auto; } .immerse-modal-buttons { flex-direction: column; gap: 10px; } .immerse-modal-buttons .immerse-btn { width: 100%; padding: 12px 16px; font-size: 14px; min-height: 44px; } /* Increase touch target sizes */ .immerse-checkbox { width: 28px; height: 28px; min-width: 28px; } .immerse-filter-btn { padding: 8px 14px; font-size: 14px; min-height: 40px; } /* Better spacing for buttons */ .immerse-header-actions { width: 100%; justify-content: stretch; } .immerse-header-actions .immerse-btn { flex: 1; min-height: 44px; } } /* Extra small screens (phones in portrait) */ @media (max-width: 480px) { .immerse-container { padding: 12px; } .immerse-report-view { padding: 12px; } /* Make pie chart smaller on very small screens */ .immerse-daily-pie-chart { width: 180px; height: 180px; } .immerse-daily-pie-center { width: 110px; height: 110px; } .immerse-daily-pie-center-value { font-size: 24px; } .immerse-daily-pie-center-label { font-size: 10px; } .immerse-daily-pie-legend-value { font-size: 18px; } /* Stack stats grid in single column on very small screens */ .immerse-stats-grid { grid-template-columns: 1fr; } /* Smaller buttons and text */ .immerse-btn { padding: 6px 12px; font-size: 13px; } .immerse-timer-time { font-size: 36px; } .immerse-active-task-name { font-size: 18px; } /* Quick filters wrap better */ .immerse-quick-filter-btn { padding: 5px 10px; font-size: 12px; } /* Report title smaller */ .immerse-report-title { font-size: 24px; } .immerse-report-section-title { font-size: 18px; } } /* ============ Emoji Picker ============ */ .immerse-emoji-picker { width: 85vw; max-width: 400px; max-height: 80vh; display: flex; flex-direction: column; box-sizing: border-box; } .immerse-emoji-picker .modal-content { display: flex; flex-direction: column; height: 100%; overflow: hidden; box-sizing: border-box; max-width: 100%; } .immerse-emoji-current { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; padding: 10px; background: var(--ft-bg-secondary); border-radius: var(--ft-radius-sm); flex-shrink: 0; } .immerse-emoji-current-icon { font-size: 20px; } .immerse-emoji-search { margin-bottom: 12px; flex-shrink: 0; } .immerse-emoji-search-input { width: 100%; padding: 8px 12px; border-radius: var(--ft-radius-sm); border: 1px solid var(--ft-border); background: var(--ft-bg); color: var(--ft-text); font-size: 14px; } .immerse-emoji-categories { flex: 1; overflow-y: auto; margin-bottom: 12px; min-height: 0; } .immerse-emoji-category { margin-bottom: 20px; } .immerse-emoji-category-title { font-size: 14px; font-weight: 600; color: var(--ft-text-muted); margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.5px; } .immerse-emoji-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(32px, 1fr)); gap: 4px; max-width: 100%; box-sizing: border-box; } .immerse-emoji-button { width: 32px; height: 32px; border: 1px solid var(--ft-border); background: var(--ft-bg); border-radius: 6px; font-size: 18px; cursor: pointer; transition: all 0.2s ease; display: flex; align-items: center; justify-content: center; padding: 0; box-sizing: border-box; } .immerse-emoji-button:hover { background: var(--ft-bg-tertiary); transform: scale(1.1); border-color: var(--ft-primary); } .immerse-emoji-button.immerse-emoji-selected { background: var(--ft-primary); border-color: var(--ft-primary); box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.3); } .immerse-emoji-custom { display: flex; align-items: center; gap: 8px; padding-top: 12px; border-top: 1px solid var(--ft-border); flex-shrink: 0; } .immerse-emoji-custom-input { flex: 1; padding: 8px 12px; border-radius: var(--ft-radius-sm); border: 1px solid var(--ft-border); background: var(--ft-bg); color: var(--ft-text); font-size: 18px; text-align: center; }