@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;600&family=Outfit:wght@500;700&display=swap";:root{--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--mobile-header-height: 56px;--mobile-tab-height: 60px;--mobile-content-padding: 16px;--touch-target-min: 44px;--primitive-teal: #2A9D8F;--primitive-indigo: #264653;--primitive-orange: #F4A261;--primitive-gold: #E9C46A;--primitive-charcoal: #2B2D42;--primitive-white: #FAFAFA;--primitive-pure-white: #FFFFFF;--primitive-grey: #E5E5E5;--primitive-dark-bg: #1a1a1a;--primitive-dark-surface: #2d2d2d;--primitive-red: #f44336;--primitive-red-light: #fee;--primitive-yellow: #ffc107;--primitive-yellow-light: #fff8e1;--primitive-blue: #2196f3;--primitive-blue-light: #e3f2fd;--primitive-green: #4caf50;--primitive-green-light: #e8f5e9;--primitive-grey-light: #f5f5f5;--primitive-grey-dark: #999;--font-display: "Outfit", sans-serif;--font-copy: "Inter", sans-serif}:root,[data-theme=light]{--text-main: var(--primitive-charcoal);--text-heading: var(--primitive-indigo);--text-inverse: var(--primitive-pure-white);--text-muted: #64748b;--bg-page: var(--primitive-white);--bg-surface: var(--primitive-pure-white);--bg-gradient-start: var(--primitive-teal);--bg-gradient-end: var(--primitive-indigo);--border-subtle: var(--primitive-grey);--border-default: #ddd;--color-section-now: var(--primitive-green);--color-section-now-bg: var(--primitive-green-light);--color-section-next: var(--primitive-orange);--color-section-next-bg: var(--primitive-yellow-light);--color-section-today: var(--primitive-blue);--color-section-today-bg: var(--primitive-blue-light);--color-section-later: #757575;--color-section-later-bg: var(--primitive-grey-light);--color-section-done: var(--primitive-teal);--color-section-done-bg: rgba(42, 157, 143, .12);--color-button-primary: #667eea;--color-button-primary-hover: #5568d3;--color-button-danger: var(--primitive-red);--color-button-danger-hover: #d32f2f;--color-task-time-badge: var(--primitive-blue-light);--color-task-time-text: #1976d2}[data-theme=dark]{--text-main: var(--primitive-white);--text-heading: var(--primitive-teal);--text-inverse: var(--primitive-charcoal);--text-muted: #94a3b8;--bg-page: var(--primitive-dark-bg);--bg-surface: var(--primitive-dark-surface);--bg-gradient-start: var(--primitive-indigo);--bg-gradient-end: var(--primitive-charcoal);--border-subtle: #3f3f3f;--border-default: #555;--color-section-now: #66bb6a;--color-section-now-bg: rgba(102, 187, 106, .15);--color-section-next: var(--primitive-orange);--color-section-next-bg: rgba(244, 162, 97, .15);--color-section-today: var(--primitive-teal);--color-section-today-bg: rgba(42, 157, 143, .15);--color-section-later: #888;--color-section-later-bg: rgba(136, 136, 136, .15);--color-section-done: #4db8a8;--color-section-done-bg: rgba(77, 184, 168, .15);--color-button-primary: var(--primitive-teal);--color-button-primary-hover: #35b5a5;--color-button-danger: #ff6b6b;--color-button-danger-hover: #ff5252;--color-task-time-badge: rgba(42, 157, 143, .2);--color-task-time-text: var(--primitive-teal)}body{margin:0;padding:0;background-color:var(--bg-page);color:var(--text-main);font-family:var(--font-copy);line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-heading);margin-top:0}h1{font-size:clamp(1.75rem,4vw + 1rem,2.5rem)}h2{font-size:clamp(1.375rem,3vw + .75rem,2rem)}h3{font-size:clamp(1.125rem,2vw + .5rem,1.5rem)}html{font-size:clamp(15px,1vw + 14px,16px)}.action-trigger{background-color:var(--primitive-orange);color:var(--primitive-indigo);font-family:var(--font-display);font-weight:700;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;display:inline-block;text-decoration:none}.brand-identity{background-color:var(--primitive-teal);color:var(--primitive-pure-white)}.block-emphasis{background-color:var(--primitive-indigo);color:var(--primitive-pure-white)}.highlight-reward{background-color:var(--primitive-gold);color:var(--primitive-indigo)}.surface-card{background-color:var(--bg-surface);color:var(--text-main);border:1px solid var(--border-subtle);border-radius:12px;padding:24px}.action-trigger:hover{filter:brightness(1.1)}.action-trigger:active{transform:translateY(1px)}*{box-sizing:border-box}#root{min-height:100vh}.timer{font-size:4rem;font-weight:700;font-variant-numeric:tabular-nums;font-family:var(--font-display)}.landing-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);color:var(--text-inverse);padding:2rem;display:flex;justify-content:center;align-items:center}.landing-content{max-width:900px;width:100%}.landing-header{text-align:center;margin-bottom:3rem}.landing-title{font-size:3.5rem;font-weight:800;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3);font-family:var(--font-display)}.landing-tagline{font-size:1.25rem;margin-top:.5rem;opacity:.95}.landing-hero{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2.5rem;margin-bottom:2rem}.hero-text{text-align:center;margin-bottom:2.5rem}.hero-text h2{font-size:2rem;margin-bottom:1rem}.hero-text p{font-size:1.15rem;line-height:1.6;opacity:.95}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem}.feature{background:#ffffff26;padding:1.5rem;border-radius:15px;text-align:center;transition:transform .2s ease,background .2s ease}.feature:hover{transform:translateY(-5px);background:#fff3}.feature-icon{font-size:2.5rem;margin-bottom:.75rem;color:var(--primitive-indigo);display:flex;justify-content:center;align-items:center}.feature-icon img{width:64px;height:64px}.feature h3{font-size:1.15rem;margin:.5rem 0}.feature p{font-size:.95rem;opacity:.9;margin:0}.landing-cta{background:#fffffff2;color:#1e293b;border-radius:20px;padding:2.5rem;text-align:center;margin-bottom:2rem}.landing-cta h2{font-size:2rem;margin-bottom:.5rem;color:var(--clarity-teal);font-family:var(--font-display)}.landing-cta>p{font-size:1.1rem;color:#475569;margin-bottom:1.5rem}.google-sign-in-btn{background:#fff;color:#1e293b;border:2px solid #e2e8f0;padding:1rem 2.5rem;font-size:1.15rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0000001a}.google-sign-in-btn:hover:not(:disabled){background:#f8fafc;transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.google-sign-in-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee2e2;color:#991b1b;padding:1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid #dc2626}.privacy-note{font-size:.85rem;color:#64748b;margin-top:1rem;font-style:italic}.landing-footer{text-align:center;padding:2rem 0;opacity:.9}.landing-footer p{margin:.5rem 0}.landing-footer .subtitle{font-size:.9rem;opacity:.8}@media(max-width:768px){.landing-title{font-size:2.5rem}.landing-tagline{font-size:1.1rem}.hero-text h2{font-size:1.5rem}.features{grid-template-columns:1fr}.landing-hero,.landing-cta{padding:1.5rem}}.waitlist-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;display:flex;justify-content:center;align-items:center}.waitlist-content{max-width:600px;width:100%;background:#fffffff2;color:#1e293b;border-radius:20px;padding:3rem;text-align:center;box-shadow:0 20px 50px #0000004d}.waitlist-icon{font-size:4rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.waitlist-content h1{font-size:2.5rem;color:#667eea;margin-bottom:1rem}.waitlist-message{font-size:1.25rem;color:#475569;margin-bottom:2rem}.waitlist-info{background:#f1f5f9;padding:1.5rem;border-radius:12px;margin-bottom:2rem;text-align:left}.waitlist-info p{margin:.75rem 0;line-height:1.6;color:#334155}.waitlist-info strong{color:#667eea}.waitlist-cta{background:#ede9fe;padding:1.5rem;border-radius:12px;margin-bottom:2rem}.waitlist-cta h3{color:#5b21b6;margin-top:0;margin-bottom:1rem}.waitlist-cta ul{list-style:none;padding:0;text-align:left}.waitlist-cta li{padding:.5rem 0 .5rem 2rem;position:relative;color:#334155}.waitlist-cta li:before{content:"✓";position:absolute;left:0;color:#667eea;font-weight:700;font-size:1.25rem}.waitlist-footer{padding-top:1.5rem;border-top:1px solid #e2e8f0;color:#64748b;font-size:.95rem}.waitlist-footer a{color:#667eea;text-decoration:none;font-weight:600}.waitlist-footer a:hover{text-decoration:underline}@media(max-width:768px){.waitlist-content{padding:2rem 1.5rem}.waitlist-content h1{font-size:2rem}.waitlist-message{font-size:1.1rem}}.timer-container{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 4px 6px #0000001a;max-width:500px;margin:0 auto}.timer-header{text-align:center;margin-bottom:1.5rem}.timer-header h2{margin:0;color:#1e293b;font-size:1.75rem}.timer-subtitle{margin:.5rem 0 0;color:#64748b;font-size:1.1rem}.goal-input-section{text-align:center;margin-bottom:1.5rem}.goal-input-section label{display:block;margin-bottom:.75rem;color:#1e293b;font-weight:600;font-size:1.1rem}.goal-input{width:100%;padding:.875rem 1rem;font-size:1rem;border:2px solid #e2e8f0;border-radius:10px;transition:border-color .2s ease;background:#fff;color:#1e293b}.goal-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.goal-input::placeholder{color:#94a3b8}.goal-hint{margin:.5rem 0 0;color:#64748b;font-size:.9rem;font-style:italic}.active-goal{background:linear-gradient(135deg,#ede9fe,#ddd6fe);padding:1.25rem;border-radius:12px;margin-bottom:1.5rem;text-align:center}.goal-label{margin:0 0 .5rem;color:#5b21b6;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.goal-text{margin:0;color:#1e293b;font-size:1.15rem;font-weight:600;line-height:1.4}.duration-selector{text-align:center;margin-bottom:2rem}.duration-selector label{display:block;margin-bottom:.5rem;color:#475569;font-weight:600}.duration-select{padding:.75rem 1.5rem;font-size:1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#1e293b;cursor:pointer;transition:border-color .2s ease}.duration-select:hover{border-color:#667eea}.duration-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.task-selector-section{margin-bottom:1.5rem}.task-selector-section label{display:block;margin-bottom:.5rem;color:#475569;font-weight:600;font-size:.95rem}.task-select{width:100%;padding:.75rem 1rem;font-size:1rem;border:2px solid #e2e8f0;border-radius:8px;background:#fff;color:#1e293b;cursor:pointer;transition:border-color .2s ease}.task-select:hover{border-color:var(--primitive-teal)}.task-select:focus{outline:none;border-color:var(--primitive-teal);box-shadow:0 0 0 3px #2a9d8f1a}.new-task-input{width:100%;margin-top:.75rem;padding:.75rem 1rem;font-size:1rem;border:2px solid var(--primitive-orange);border-radius:8px;background:#fffbf5;color:#1e293b;transition:border-color .2s ease}.new-task-input:focus{outline:none;border-color:var(--primitive-orange);box-shadow:0 0 0 3px #f4a2611a}.timer-settings-row{display:flex;gap:1rem;margin-bottom:1.5rem;justify-content:center}.duration-mini,.voice-cue-mini{display:flex;align-items:center;gap:.5rem}.duration-mini label,.voice-cue-mini label{color:#64748b;font-size:.9rem;font-weight:600;white-space:nowrap}.duration-select-compact,.voice-cue-select-compact{padding:.5rem .75rem;font-size:.9rem;border:2px solid #e2e8f0;border-radius:6px;background:#fff;color:#1e293b;cursor:pointer;transition:border-color .2s ease}.duration-select-compact:hover,.voice-cue-select-compact:hover{border-color:var(--primitive-teal)}.duration-select-compact:focus,.voice-cue-select-compact:focus{outline:none;border-color:var(--primitive-teal);box-shadow:0 0 0 2px #2a9d8f1a}.timer-display{display:flex;justify-content:center;margin:2rem 0}.timer-circle{position:relative;width:250px;height:250px}.timer-svg{width:100%;height:100%;transform:rotate(0)}.progress-circle{transition:stroke-dashoffset .3s ease}.timer-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.time-remaining{font-size:3rem;font-weight:700;color:#1e293b;font-variant-numeric:tabular-nums}.time-elapsed{font-size:.95rem;color:#64748b;margin-top:.5rem}.timer-controls{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.btn{padding:.875rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.btn:active{transform:translateY(0)}.btn-start,.btn-resume,.btn-restart{background:#667eea;color:#fff}.btn-start:hover,.btn-resume:hover,.btn-restart:hover{background:#5568d3}.btn-pause{background:#f59e0b;color:#fff}.btn-pause:hover{background:#d97706}.btn-break{background:#0ea5e9;color:#fff}.btn-break:hover{background:#0284c7}.btn-stop{background:#ef4444;color:#fff}.btn-stop:hover{background:#dc2626}.timer-info{background:#ede9fe;padding:1rem;border-radius:8px;text-align:center;margin-top:1.5rem}.timer-info p{margin:0;color:#5b21b6;font-size:.95rem}.voice-cue-controls{display:flex;align-items:center;justify-content:space-between;gap:1rem}.voice-cue-label{color:#5b21b6;font-size:.95rem;flex:1}.voice-cue-actions{display:flex;align-items:center;gap:.5rem}.voice-toggle-btn{padding:.375rem .875rem;font-size:.85rem;font-weight:600;border:2px solid;border-radius:6px;cursor:pointer;transition:all .2s ease;min-width:50px}.voice-toggle-btn.on{background:var(--primitive-teal);border-color:var(--primitive-teal);color:#fff}.voice-toggle-btn.on:hover{background:#238276;border-color:#238276}.voice-toggle-btn.off{background:#fff;border-color:#cbd5e1;color:#64748b}.voice-toggle-btn.off:hover{border-color:#94a3b8;color:#475569}.voice-settings-btn{padding:.375rem .5rem;font-size:1rem;background:#fff;border:2px solid #cbd5e1;border-radius:6px;cursor:pointer;transition:all .2s ease}.voice-settings-btn:hover{border-color:#94a3b8;transform:scale(1.1)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.modal-content{background:#fff;border-radius:16px;max-width:500px;width:100%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:modalSlideIn .2s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;color:#1e293b;font-size:1.25rem}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#94a3b8;font-size:1.75rem;cursor:pointer;border-radius:6px;transition:all .2s ease;line-height:1}.modal-close:hover{background:#f1f5f9;color:#64748b}.modal-body{padding:1.5rem}.modal-body label{display:block;margin-bottom:1rem;color:#475569;font-size:.95rem}.voice-slider{width:100%;height:8px;border-radius:4px;background:#e2e8f0;outline:none;-webkit-appearance:none;appearance:none;cursor:pointer}.voice-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primitive-teal);cursor:pointer;transition:all .2s ease}.voice-slider::-webkit-slider-thumb:hover{background:#238276;transform:scale(1.2)}.voice-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primitive-teal);cursor:pointer;border:none;transition:all .2s ease}.voice-slider::-moz-range-thumb:hover{background:#238276;transform:scale(1.2)}.slider-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:#94a3b8}.timer-celebration{background:linear-gradient(135deg,#10b981,#059669);padding:1.5rem;border-radius:12px;text-align:center;margin-top:1.5rem;color:#fff}.timer-celebration p{margin:.5rem 0;font-size:1.1rem}.timer-celebration p:first-child{font-weight:600;font-size:1.25rem}@media(max-width:600px){.timer-container{max-width:none;margin:0;border-radius:0;padding:1.5rem}.timer-circle{width:200px;height:200px}.time-remaining{font-size:2.5rem}.timer-controls{flex-direction:column}.btn{width:100%}}.timer-circle.paused .time-remaining{color:#94a3b8}.timer-circle.paused svg{filter:grayscale(1);opacity:.6}.btn-pause.resuming{background:#10b981}.btn-pause.resuming:hover{background:#059669}@keyframes timer-pause-blink{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.timer-circle.paused .time-remaining{animation:timer-pause-blink 2s infinite ease-in-out}.timer-paused-overlay{position:absolute;inset:0;background:#fffbeb66;display:flex;align-items:center;justify-content:center;z-index:5;border-radius:50%;pointer-events:none}.timer-paused-overlay span{background:#f59e0b;color:#fff;padding:.5rem 1.5rem;border-radius:99px;font-weight:800;font-size:1.25rem;letter-spacing:2px;box-shadow:0 4px 12px #f59e0b66;animation:pause-overlay-pulse 1.5s infinite ease-in-out}.timer-container:has(.timer-circle.paused){background-color:#fffbeb!important;border:4px solid #fde68a!important;transition:all .5s ease}@keyframes pause-overlay-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}to{transform:scale(1);opacity:1}}.daily-plan{background:var(--bg-surface);border-radius:16px;padding:1.25rem;box-shadow:0 4px 6px #0000000f;margin:0 auto 1.25rem;max-width:600px}.daily-plan-accordion{padding:0}.daily-plan-summary{list-style:none;display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;cursor:pointer;padding:1.1rem 1.25rem}.daily-plan-summary::-webkit-details-marker{display:none}.daily-plan-summary-title{font-weight:800;color:var(--text-heading);font-size:1.05rem}.daily-plan-summary-text{flex:1;color:var(--text-muted);font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.daily-plan-summary-date{color:var(--text-muted);font-size:.85rem;white-space:nowrap}.daily-plan-body{padding:0 1.25rem 1.25rem}.daily-plan-header{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1rem}.daily-plan-title{margin:0;color:var(--text-heading);font-size:1.35rem}.daily-plan-date{font-size:.9rem;color:var(--text-muted)}.daily-plan-grid{display:grid;grid-template-columns:1fr;gap:1rem}.daily-plan-card{background:#fff;border:1px solid rgba(15,23,42,.08);border-radius:14px;padding:1rem}.daily-plan-card-title{margin:0;color:var(--text-heading);font-size:1.1rem}.daily-plan-hint{margin:.35rem 0 .75rem;color:var(--text-muted);font-size:.92rem;line-height:1.35}.intentions-input-row{display:flex;gap:.5rem}.intentions-input{flex:1;padding:.6rem .75rem;border-radius:10px;border:1px solid rgba(15,23,42,.15)}.intentions-add{padding:.6rem .9rem;border-radius:10px;border:none;background:var(--color-button-primary);color:var(--text-inverse);font-weight:700;cursor:pointer}.intentions-add:disabled{opacity:.5;cursor:not-allowed}.intentions-list{list-style:none;padding:0;margin:.75rem 0 0;display:grid;gap:.5rem}.intentions-item{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:start;padding:.6rem .75rem;border-radius:12px;background:#f1f5f9}.intentions-text{color:#0f172a;line-height:1.25}.intentions-remove{border:none;background:transparent;font-size:1.2rem;line-height:1;cursor:pointer;color:#334155}.intentions-empty{margin-top:.75rem;color:var(--text-muted)}.parking-input-row{display:flex;gap:.5rem}.parking-input{flex:1;padding:.6rem .75rem;border-radius:10px;border:1px solid rgba(15,23,42,.15)}.parking-add{padding:.6rem .9rem;border-radius:10px;border:none;background:var(--color-button-primary);color:var(--text-inverse);font-weight:700;cursor:pointer}.parking-add:disabled{opacity:.5;cursor:not-allowed}.parking-list{list-style:none;padding:0;margin:.75rem 0 0;display:grid;gap:.5rem}.parking-item{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:start;padding:.6rem .75rem;border-radius:12px;background:#f1f5f9}.parking-text{color:#0f172a;line-height:1.25}.parking-remove{border:none;background:transparent;font-size:1.2rem;line-height:1;cursor:pointer;color:#334155}.parking-empty{margin-top:.75rem;color:var(--text-muted)}@media(max-width:768px){.daily-plan{max-width:none;margin:0 0 1rem;border-radius:12px;padding:1rem;box-shadow:none;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.daily-plan-header{gap:.75rem;margin-bottom:.75rem}.daily-plan-title{font-size:1.15rem}.daily-plan-date{font-size:.8rem}.daily-plan-summary{padding:.875rem 1rem;min-height:var(--touch-target-min)}.daily-plan-summary-title{font-size:.95rem}.daily-plan-summary-text{font-size:.85rem}.daily-plan-summary-date{font-size:.75rem}.daily-plan-body{padding:0 1rem 1rem}.daily-plan-card{border-radius:12px;padding:.875rem}.daily-plan-card-title{font-size:1rem}.daily-plan-hint{font-size:.85rem;margin:.25rem 0 .625rem}.intentions-input-row{gap:.375rem}.intentions-input{font-size:16px;padding:.75rem;border-radius:10px;min-height:var(--touch-target-min)}.intentions-add{min-width:var(--touch-target-min);min-height:var(--touch-target-min);padding:.75rem;border-radius:10px;font-size:.9rem}.intentions-add:active{transform:scale(.96)}.intentions-list{margin-top:.5rem;gap:.375rem}.intentions-item{padding:.625rem .75rem;border-radius:10px;min-height:var(--touch-target-min);align-items:center}.intentions-text{font-size:.9rem;line-height:1.3}.intentions-remove{min-width:var(--touch-target-min);min-height:var(--touch-target-min);display:flex;align-items:center;justify-content:center;font-size:1.1rem;border-radius:8px;margin:-.25rem}.intentions-remove:active{background:#00000014}.intentions-empty{font-size:.85rem;padding:.5rem 0}.parking-input-row{gap:.375rem}.parking-input{font-size:16px;padding:.75rem;border-radius:10px;min-height:var(--touch-target-min)}.parking-add{min-width:var(--touch-target-min);min-height:var(--touch-target-min);padding:.75rem;border-radius:10px;font-size:.9rem}.parking-add:active{transform:scale(.96)}.parking-list{margin-top:.5rem;gap:.375rem}.parking-item{padding:.625rem .75rem;border-radius:10px;min-height:var(--touch-target-min);align-items:center}.parking-text{font-size:.9rem;line-height:1.3}.parking-remove{min-width:var(--touch-target-min);min-height:var(--touch-target-min);display:flex;align-items:center;justify-content:center;font-size:1.1rem;border-radius:8px;margin:-.25rem}.parking-remove:active{background:#00000014}.parking-empty{font-size:.85rem;padding:.5rem 0}}@media(max-width:480px){.daily-plan{padding:.875rem;border-radius:10px}.daily-plan-title{font-size:1.05rem}.daily-plan-card{padding:.75rem;border-radius:10px}.daily-plan-card-title{font-size:.95rem}.intentions-input,.parking-input{padding:.625rem .75rem}}.task-item{display:flex;align-items:center;gap:8px;padding:12px;margin-bottom:8px;background:var(--bg-surface);border-radius:8px;border:1px solid var(--border-default);transition:all .2s;cursor:default;min-width:0}.task-item:hover{box-shadow:0 2px 4px #0000001a;border-color:var(--color-button-primary)}.task-item.completed{opacity:.7;background:var(--bg-page)}.task-item.completed .task-text{text-decoration:line-through;color:var(--text-muted)}.drag-handle{cursor:grab;color:var(--text-muted);padding:4px;font-size:16px;-webkit-user-select:none;user-select:none;touch-action:none}.drag-handle:active{cursor:grabbing}.drag-handle:hover{color:var(--color-button-primary)}.task-checkbox{width:20px;height:20px;cursor:pointer;flex-shrink:0}.task-text{flex:1;font-size:15px;color:var(--text-main);cursor:pointer;word-break:break-word;min-width:0}.task-text-input{flex:1;font-size:15px;color:var(--text-main);background:var(--bg-surface);border:2px solid var(--color-button-primary);border-radius:4px;padding:4px 8px;outline:none;min-width:0}.task-actions-row{display:flex;align-items:center;gap:8px;flex:0 0 auto}.task-text-input:focus{border-color:var(--color-button-primary-hover);box-shadow:0 0 0 3px #667eea1a}.task-time{background:var(--color-task-time-badge);color:var(--color-task-time-text);padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap;flex-shrink:0}.timer-btn{background:var(--color-button-primary);color:var(--text-inverse);border:none;border-radius:6px;padding:6px 12px;font-size:14px;cursor:pointer;transition:background .2s;flex-shrink:0}.timer-btn:hover{background:var(--color-button-primary-hover)}.timer-btn:active{transform:scale(.95)}.delete-btn{background:var(--color-button-danger);color:var(--text-inverse);border:none;border-radius:6px;padding:4px 8px;font-size:18px;line-height:1;cursor:pointer;transition:background .2s;flex-shrink:0}.delete-btn:hover{background:var(--color-button-danger-hover)}.delete-btn:active{transform:scale(.95)}.task-item[data-is-dragging=true]{opacity:.5;cursor:grabbing}@media(max-width:768px){.task-item{display:grid;grid-template-columns:36px 28px 1fr;grid-template-rows:auto auto;grid-template-areas:"drag check text" "actions actions actions";align-items:center;padding:.75rem;gap:.5rem .625rem;border-radius:12px;margin-bottom:.5rem;border:1px solid rgba(0,0,0,.06);background:var(--bg-surface)}.task-item:hover{box-shadow:none;border-color:#0000001a}.task-item:active{background:#00000005}.drag-handle{grid-area:drag;width:36px;height:var(--touch-target-min);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-muted);border-radius:8px;transition:background .15s ease}.drag-handle:active{background:#0000000f}.task-checkbox{grid-area:check;width:24px;height:24px;min-width:24px;min-height:24px;position:relative}.task-checkbox:before{content:"";position:absolute;inset:-10px}.task-text,.task-text-input{grid-area:text}.task-text{font-size:15px;line-height:1.35;overflow-wrap:anywhere;word-break:break-word;padding:.25rem 0}.task-text-input{font-size:16px;padding:.5rem;border-radius:8px;min-height:var(--touch-target-min)}.task-actions-row{grid-area:actions;justify-content:flex-end;gap:.5rem;padding-top:.25rem}.task-time{padding:.375rem .625rem;font-size:.75rem;border-radius:8px;min-height:28px;display:inline-flex;align-items:center}.timer-btn{min-height:var(--touch-target-min);min-width:var(--touch-target-min);padding:.5rem .875rem;font-size:.85rem;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;gap:.25rem}.timer-btn:active{transform:scale(.96)}.delete-btn{min-height:var(--touch-target-min);min-width:var(--touch-target-min);padding:.5rem;font-size:1.1rem;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.delete-btn:active{transform:scale(.96)}.task-item.completed{opacity:.6}.task-item.completed .task-text{color:var(--text-muted)}}@media(max-width:480px){.task-item{grid-template-columns:32px 24px 1fr;padding:.625rem;gap:.375rem .5rem}.drag-handle{width:32px;font-size:16px}.task-text{font-size:14px}.timer-btn{padding:.5rem .75rem;font-size:.8rem}}.task-section{margin-bottom:24px;border-radius:12px;padding:16px;background:var(--bg-page);border:2px solid transparent;transition:border-color .2s}.task-section.section-now{background:var(--color-section-now-bg);border-color:var(--color-section-now)}.task-section.section-next{background:var(--color-section-next-bg);border-color:var(--color-section-next)}.task-section.section-today{background:var(--color-section-today-bg);border-color:var(--color-section-today)}.task-section.section-later{background:var(--color-section-later-bg);border-color:var(--color-section-later)}.task-section.section-done{background:var(--color-section-done-bg);border-color:var(--color-section-done)}.section-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-weight:600}.section-emoji{font-size:20px}.section-title{font-size:16px;margin:0;color:var(--text-heading)}.section-count{color:var(--text-muted);font-size:14px;font-weight:400}.section-limit-badge{background:var(--color-button-danger);color:var(--text-inverse);padding:2px 8px;border-radius:12px;font-size:11px;font-weight:700;margin-left:auto}.section-tasks{min-height:60px;border-radius:8px;padding:8px;background:#ffffff80}[data-theme=dark] .section-tasks{background:#0003}.section-empty{padding:24px;text-align:center;color:var(--text-muted);font-style:italic;font-size:14px}.task-section:hover{border-color:var(--color-button-primary);box-shadow:0 2px 8px #667eea1a}@media(max-width:768px){.task-section{margin-bottom:1rem;border-radius:14px;padding:.875rem;border-width:1.5px}.task-section:hover{border-color:inherit;box-shadow:none}.task-section.section-now:hover{border-color:var(--color-section-now)}.task-section.section-next:hover{border-color:var(--color-section-next)}.task-section.section-today:hover{border-color:var(--color-section-today)}.task-section.section-later:hover{border-color:var(--color-section-later)}.task-section.section-done:hover{border-color:var(--color-section-done)}.section-header{gap:.5rem;margin-bottom:.75rem;padding:.25rem 0;min-height:var(--touch-target-min);align-items:center}.section-emoji{font-size:1.25rem}.section-title{font-size:.95rem;font-weight:700}.section-count{font-size:.8rem}.section-limit-badge{padding:.25rem .5rem;font-size:.65rem;border-radius:8px}.section-tasks{min-height:48px;border-radius:10px;padding:.375rem}.section-empty{padding:1.25rem;font-size:.85rem;min-height:48px;display:flex;align-items:center;justify-content:center}}@media(max-width:480px){.task-section{margin-bottom:.75rem;padding:.75rem;border-radius:12px}.section-header{margin-bottom:.5rem}.section-emoji{font-size:1.1rem}.section-title{font-size:.9rem}.section-tasks{padding:.25rem;min-height:40px}.section-empty{padding:1rem;font-size:.8rem}}.task-list-container{background:var(--bg-surface);border-radius:16px;padding:2rem;box-shadow:0 4px 6px #0000001a;max-width:600px;margin:0 auto}.task-list-accordion{padding:0}.task-list-summary{list-style:none;display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;cursor:pointer;padding:1.1rem 1.25rem}.task-list-summary::-webkit-details-marker{display:none}.task-list-summary-title{font-weight:800;color:var(--text-heading);font-size:1.05rem}.task-list-summary-text{flex:1;color:var(--text-muted);font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-list-body{padding:0 1.25rem 1.25rem}.task-list-header{text-align:center;margin-bottom:1.5rem}.task-warnings{margin:0 0 1rem;display:grid;gap:.5rem}.task-warning{background:#f59e0b24;border:1px solid rgba(245,158,11,.28);color:#7c2d12;padding:.75rem .9rem;border-radius:12px;font-size:.92rem}.task-list-header h2{margin:0;color:var(--text-heading);font-size:1.75rem}.task-progress{margin:.5rem 0 0;color:var(--text-muted);font-size:1.1rem}.progress-emoji{font-size:1.25rem}.task-summary{display:flex;justify-content:center;gap:1rem;margin-top:1rem;flex-wrap:wrap}.task-summary>span{font-size:.95rem;font-weight:600;padding:.25rem .75rem;border-radius:12px;background:#f1f5f9;transition:all .2s}.task-summary>span:hover{transform:translateY(-2px);box-shadow:0 2px 4px #0000001a}.now-count{background:var(--color-section-now-bg)!important;color:var(--color-section-now)}.next-count{background:var(--color-section-next-bg)!important;color:var(--color-section-next)}.today-count{background:var(--color-section-today-bg)!important;color:var(--color-section-today)}.later-count{background:var(--color-section-later-bg)!important;color:var(--color-section-later)}.done-count{background:var(--color-section-done-bg)!important;color:var(--color-section-done)}.loading{text-align:center;padding:2rem;color:var(--text-muted)}.error-message{background:var(--color-section-now-bg);color:var(--color-section-now);padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;border-left:4px solid var(--color-button-danger);font-size:.95rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.dismiss-error{background:transparent;border:none;color:var(--color-button-danger);font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;flex-shrink:0}.dismiss-error:hover{background:var(--color-section-now-bg);opacity:.8}.add-task-form{display:flex;gap:.75rem;margin-bottom:1.5rem}.task-input{flex:1;padding:.875rem 1rem;font-size:1rem;border:2px solid var(--border-subtle);border-radius:10px;transition:border-color .2s ease;background:var(--bg-surface);color:var(--text-main)}.task-input:focus{outline:none;border-color:var(--color-button-primary);box-shadow:0 0 0 3px #667eea1a}.task-input::placeholder{color:var(--text-muted)}.add-task-btn{padding:.875rem 1.5rem;font-size:1rem;font-weight:600;background:var(--color-button-primary);color:var(--text-inverse);border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.add-task-btn:hover:not(:disabled){background:var(--color-button-primary-hover);transform:translateY(-2px)}.add-task-btn:disabled{background:var(--border-subtle);cursor:not-allowed;opacity:.6}.progress-bar-container{position:relative;height:8px;background:var(--border-subtle);border-radius:10px;overflow:hidden;margin-bottom:1.5rem}.progress-bar{height:100%;background:linear-gradient(90deg,var(--color-button-primary) 0%,var(--primitive-indigo) 100%);transition:width .5s ease;border-radius:10px}.progress-text{display:block;text-align:center;margin-top:.5rem;font-size:.875rem;color:var(--text-muted);font-weight:500}.motivation-message,.celebration-message{text-align:center;padding:1rem;border-radius:10px;margin-top:1rem}.motivation-message{background:var(--primitive-gold);color:var(--primitive-indigo)}.motivation-message p{margin:0;font-size:.95rem}.celebration-message{background:linear-gradient(135deg,var(--color-section-done),var(--primitive-teal));color:var(--text-inverse)}.celebration-message p{margin:0;font-size:1.1rem;font-weight:600}.switch-modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:1.25rem;z-index:9999}.switch-modal{width:min(520px,100%);background:var(--bg-surface);border-radius:14px;padding:1.25rem;box-shadow:0 18px 40px #00000040}.switch-modal-title{margin:0 0 .5rem;color:var(--text-heading);font-size:1.2rem}.switch-modal-body{margin:0 0 1rem;color:var(--text-muted);line-height:1.4}.switch-modal-actions{display:flex;gap:.75rem;justify-content:flex-end;flex-wrap:wrap}.switch-btn{border:0;border-radius:10px;padding:.75rem 1rem;font-weight:700;cursor:pointer}.switch-btn.primary{background:var(--color-button-primary);color:var(--text-inverse)}.switch-btn.secondary{background:#e2e8f0;color:#0f172a}@media(max-width:768px){.task-list-container{max-width:none;margin:0;border-radius:12px;padding:1rem;box-shadow:none;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.task-list-header{margin-bottom:1rem}.task-list-header h2{font-size:1.35rem}.task-progress{font-size:.95rem}.task-summary{gap:.5rem;margin-top:.75rem}.task-summary>span{font-size:.85rem;padding:.5rem .75rem;min-height:var(--touch-target-min);display:inline-flex;align-items:center;border-radius:10px}.add-task-form{flex-direction:column;gap:.5rem;margin-bottom:1rem}.task-input{font-size:16px;padding:.875rem 1rem;border-radius:12px;min-height:var(--touch-target-min)}.add-task-btn{width:100%;min-height:var(--touch-target-min);font-size:.95rem;border-radius:12px}.progress-bar-container{margin-bottom:1rem;height:6px;border-radius:6px}.progress-text{font-size:.8rem}.motivation-message,.celebration-message{padding:.875rem;border-radius:12px;margin-top:.75rem}.motivation-message p,.celebration-message p{font-size:.9rem}.error-message{padding:.75rem;border-radius:10px;font-size:.875rem}.dismiss-error{width:var(--touch-target-min);height:var(--touch-target-min);font-size:1.25rem;border-radius:8px}.task-warning{padding:.625rem .75rem;font-size:.85rem;border-radius:10px}.task-list-summary{padding:.875rem 1rem;min-height:var(--touch-target-min)}.task-list-summary-title{font-size:.95rem}.task-list-summary-text{font-size:.85rem}.task-list-body{padding:0 1rem 1rem}.switch-modal-overlay{padding:var(--mobile-content-padding);padding-bottom:calc(var(--mobile-tab-height) + var(--safe-area-bottom) + var(--mobile-content-padding))}.switch-modal{width:100%;max-width:none;border-radius:16px;padding:1.25rem}.switch-modal-title{font-size:1.1rem}.switch-modal-body{font-size:.9rem}.switch-modal-actions{gap:.5rem}.switch-btn{flex:1;min-height:var(--touch-target-min);padding:.875rem 1rem;font-size:.9rem;border-radius:12px}}@media(max-width:480px){.task-list-container{padding:.875rem;border-radius:10px}.task-list-header h2{font-size:1.2rem}.task-summary>span{font-size:.8rem;padding:.4rem .6rem}}.chat-sidebar{width:0;background-color:var(--surface-2, #f8fafc);border-right:1px solid var(--border-subtle, #e2e8f0);display:flex;flex-direction:column;z-index:20;transition:width .3s ease,transform .3s ease;height:100%;flex-shrink:0;overflow:hidden}.chat-sidebar.open{width:260px}.sidebar-header{padding:1rem;display:flex;gap:.5rem;align-items:center;border-bottom:1px solid var(--border-subtle, #e2e8f0)}.new-chat-btn{flex:1;background:var(--primary, #3b82f6);color:#fff;border:none;padding:.6rem;border-radius:8px;font-weight:500;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.new-chat-btn:hover{background:var(--primary-hover, #2563eb)}.close-sidebar-btn{background:transparent;border:none;color:var(--text-secondary, #64748b);font-size:1.5rem;cursor:pointer;padding:0 .5rem;line-height:1}.close-sidebar-btn:hover{color:var(--text-primary, #1e293b)}.threads-list{flex:1;overflow-y:auto;padding:1rem}.thread-group{margin-bottom:1.5rem}.group-title{font-size:.75rem;text-transform:uppercase;color:var(--text-tertiary, #94a3b8);margin-bottom:.5rem;font-weight:600;padding-left:.5rem;letter-spacing:.05em}.thread-item-wrapper{display:flex;flex-direction:column;align-items:flex-start;width:100%;background:transparent;border:none;padding:.75rem;border-radius:8px;cursor:pointer;text-align:left;color:var(--text-secondary, #475569);transition:all .2s;margin-bottom:.25rem;box-sizing:border-box}.thread-item-wrapper:hover{background:var(--surface-3, #f1f5f9);color:var(--text-primary, #1e293b)}.thread-item-wrapper.active{background:var(--surface-active, #e0f2fe);color:var(--primary, #0284c7)}.thread-content{display:flex;flex-direction:column;width:100%}.thread-title{font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;font-weight:500;-webkit-user-select:none;user-select:none}.thread-title-input{font-size:.9rem;font-weight:500;padding:0;margin:0;border:1px solid var(--primary, #3b82f6);border-radius:4px;width:100%;background:#fff;color:var(--text-primary, #1e293b);outline:none;font-family:inherit;box-shadow:0 0 0 2px #3b82f633}.thread-date{font-size:.7rem;color:var(--text-tertiary, #94a3b8);margin-top:.2rem}.empty-history{color:var(--text-tertiary, #94a3b8);font-size:.9rem;text-align:center;margin-top:2rem;font-style:italic}.threads-list::-webkit-scrollbar{width:4px}.threads-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}@media(min-width:1024px){.close-sidebar-btn{display:none}}@media(max-width:768px){.chat-sidebar{position:absolute;top:0;left:0;bottom:0;width:85%;max-width:300px;box-shadow:2px 0 10px #0000001a;transform:translate(-100%);transition:transform .3s ease}.chat-sidebar.open{transform:translate(0)}}.audio-recorder-container{display:flex;align-items:center;gap:.5rem}.visualizer-wrapper{background:var(--bg-surface-muted, #f8fafc);border:1px solid var(--border-subtle, #e2e8f0);border-radius:8px;padding:0 4px;display:flex;align-items:center;justify-content:center;height:40px;min-width:60px;animation:fadeIn .2s ease}.audio-recorder-btn{background:var(--bg-surface-muted, #f1f5f9);border:1px solid var(--border-subtle, #e2e8f0);border-radius:8px;padding:.5rem;cursor:pointer;font-size:1.2rem;transition:all .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #475569)}.audio-recorder-btn:hover{background:var(--surface-3, #f1f5f9);border-color:var(--accent, #667eea)}.audio-recorder-btn.recording{background:#f87171;border-color:#ef4444;color:#fff;box-shadow:0 0 0 2px #ef444433}.audio-recorder-btn.processing{cursor:not-allowed;opacity:.7}.mic-icon{display:inline-block}.loader-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.prefs-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.prefs-modal{background:#fff;width:90%;max-width:500px;border-radius:16px;box-shadow:0 10px 25px #0003;display:flex;flex-direction:column;max-height:85vh;overflow:hidden}.prefs-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-subtle, #e2e8f0);display:flex;justify-content:space-between;align-items:center}.prefs-header h2{margin:0;font-size:1.25rem;color:var(--text-primary, #1e293b)}.prefs-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary, #64748b);padding:.25rem;line-height:1}.prefs-content{padding:1.5rem;overflow-y:auto}.prefs-section{margin-bottom:2rem}.prefs-section h3{font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary, #94a3b8);margin-bottom:1rem}.prefs-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.prefs-label{font-weight:500;color:var(--text-primary, #334155)}.prefs-toggle{position:relative;width:44px;height:24px;background:#cbd5e1;border-radius:12px;cursor:pointer;transition:background .2s;border:none;padding:0}.prefs-toggle.active{background:var(--primary, #3b82f6)}.prefs-toggle-thumb{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s}.prefs-toggle.active .prefs-toggle-thumb{transform:translate(20px)}.voice-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.voice-card{border:2px solid var(--border-subtle, #e2e8f0);border-radius:10px;padding:.75rem;cursor:pointer;transition:all .2s;text-align:left;background:transparent;display:flex;justify-content:space-between;align-items:center}.voice-card:hover{border-color:var(--primary-light, #93c5fd);background:var(--surface-2, #f8fafc)}.voice-card.selected{border-color:var(--primary, #3b82f6);background:var(--surface-active, #eff6ff)}.voice-info{flex:1}.voice-preview-btn{background:#fff;border:1px solid var(--border-subtle, #cbd5e1);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-left:.5rem;font-size:.9rem;transition:all .2s;flex-shrink:0}.voice-preview-btn:hover:not(:disabled){background:var(--surface-3, #f1f5f9);border-color:var(--primary, #3b82f6);transform:scale(1.05)}.voice-preview-btn:disabled{opacity:.6;cursor:wait}.voice-name{display:block;font-weight:600;color:var(--text-primary, #1e293b);margin-bottom:.25rem}.voice-desc{display:block;font-size:.8rem;color:var(--text-secondary, #64748b)}#chat-buddy-container{background:var(--bg-surface, white);border-radius:16px;box-shadow:0 4px 6px #0000001a;max-width:1200px;margin:0 auto;display:flex;flex-direction:row;flex:1;min-height:0;width:100%;height:100%;overflow:hidden;position:relative}.chat-main-area{flex:1;display:flex;flex-direction:column;min-width:0;height:100%;background:#fff;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-subtle, #e2e8f0)}.menu-toggle-btn{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:.5rem;color:var(--text-secondary, #64748b);border-radius:8px;margin-right:.5rem;display:flex;align-items:center;justify-content:center}.menu-toggle-btn:hover{background:var(--bg-surface-muted, #f1f5f9);color:var(--text-primary, #1e293b)}.header-content h2{margin:0;color:var(--text-primary, #1e293b);font-size:1.25rem;display:flex;align-items:center;gap:.5rem}.admin-badge{font-size:.65rem;background:#3b82f6;color:#fff;padding:2px 6px;border-radius:4px;vertical-align:middle;text-transform:uppercase}.chat-subtitle{margin:.25rem 0 0;color:var(--text-secondary, #64748b);font-size:.85rem}.voice-toggle{width:40px;height:40px;border:1px solid var(--border-subtle, #e2e8f0);background:var(--bg-surface, white);border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.voice-toggle:hover{border-color:var(--accent, #667eea);background:var(--bg-surface-muted, #f8fafc)}.voice-toggle.active{background:var(--accent, #667eea);border-color:var(--accent, #667eea)}.stop-speaking-btn{background:#fee2e2;color:#991b1b;border:1px solid #fecaca;padding:.4rem .8rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:all .2s ease}.stop-speaking-btn:hover{background:#fecaca;border-color:#fca5a5}.bot-speech-controls{display:flex;gap:.5rem;align-items:center}.pause-resume-btn{background:var(--bg-surface-muted, #f1f5f9);color:var(--text-primary, #1e293b);border:1px solid var(--border-subtle, #e2e8f0);padding:.4rem .8rem;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.4rem;transition:all .2s ease}.pause-resume-btn:hover{background:var(--bg-surface, #e2e8f0);border-color:var(--border-subtle, #cbd5e1)}.pause-resume-btn.paused{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.pause-resume-btn.paused:hover{background:#dcfce7}.quick-actions{display:flex;gap:.5rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border-subtle, #e2e8f0);overflow-x:auto;flex-shrink:0}.quick-btn{padding:.4rem .8rem;background:var(--bg-surface-muted, #f1f5f9);color:var(--text-secondary, #475569);border:none;border-radius:16px;font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s ease}.quick-btn:hover{background:var(--bg-surface, #e2e8f0);color:var(--text-primary, #1e293b)}#messages-container{flex:1;min-height:0;overflow-y:auto!important;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.empty-state{margin:auto;color:var(--text-tertiary, #94a3b8);font-style:italic;text-align:center}#messages-container>:first-child{margin-top:auto}.message{display:flex;flex-direction:column;max-width:85%;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message.error{align-self:center;max-width:90%}.message-content{position:relative;padding:.75rem 1rem;border-radius:12px;box-shadow:0 1px 2px #0000000d}.message.user .message-content{background:linear-gradient(135deg,var(--accent, #667eea) 0%,var(--accent-strong, #764ba2) 100%);color:var(--text-inverse, white);border-bottom-right-radius:2px}.message.optimistic{opacity:.7}.optimistic-indicator{display:flex;align-items:center;gap:.5rem;font-size:.75rem;margin-top:.4rem;color:#fffc}.transcribing-state{display:flex;align-items:center;gap:.5rem;font-style:italic;color:var(--text-secondary, #64748b)}.message.placeholder .message-content{background:var(--bg-surface-muted, #f8fafc);border:1px dashed var(--border-subtle, #e2e8f0)}.message.assistant .message-content{background:var(--bg-surface-muted, #f1f5f9);color:var(--text-primary, #1e293b);border-bottom-left-radius:2px}.message.error .message-content{background:var(--bg-danger-subtle, #fee2e2);color:var(--text-danger, #991b1b);border:1px solid var(--border-danger, #dc2626)}.message-content p{margin:0;line-height:1.5;font-size:.95rem}.message-text{width:100%}.message-text p{margin:0 0 .5rem}.message-text p:last-child{margin-bottom:0}.message-text strong{font-weight:700}.message-text em{font-style:italic}.message-text ul,.message-text ol{margin:.5rem 0;padding-left:1.5rem}.message-text li{margin:.25rem 0}.message-text code{background:var(--code-bg, rgba(0, 0, 0, .1));padding:.125rem .25rem;border-radius:3px;font-family:Courier New,monospace;font-size:.9em}.message.user .message-text code{background:var(--code-bg-inverse, rgba(255, 255, 255, .2))}.speak-btn{position:absolute;top:.25rem;right:.25rem;width:24px;height:24px;border:none;background:transparent;border-radius:50%;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.5}.speak-btn:hover{background:#0000000d;opacity:1}.message-main{display:flex;align-items:flex-start;gap:.5rem}.assistant-controls-row{display:flex;align-items:center;gap:.75rem}.inline-speech-actions{display:flex;align-items:center;gap:.5rem}.inline-pause-btn{background:var(--bg-surface, white);border:1px solid var(--border-subtle, #e2e8f0);border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;padding:4px 10px;display:flex;align-items:center;gap:.4rem;transition:all .2s;color:var(--text-secondary, #64748b)}.inline-pause-btn:hover{background-color:var(--bg-surface-muted, #f1f5f9);color:var(--text-primary, #1e293b);border-color:var(--border-strong, #cbd5e1)}.inline-pause-btn.paused{background-color:var(--accent-subtle, #ebf4ff);border-color:var(--accent, #667eea);color:var(--accent, #667eea)}.loading-speech-controls{display:flex;gap:.75rem;margin-top:.5rem;align-items:center;padding:6px 10px;background:var(--bg-surface, white);border-radius:8px;border:1px solid var(--border-subtle, #e2e8f0);box-shadow:0 1px 2px #0000000d}.inline-stop-btn{background:none;border:1px solid var(--border-subtle, #e2e8f0);border-radius:6px;padding:4px 8px;cursor:pointer;color:var(--text-secondary, #64748b);transition:all .2s}.inline-stop-btn:hover{background-color:var(--bg-danger-subtle, #fee2e2);color:var(--text-danger, #991b1b);border-color:var(--border-danger, #dc2626)}.speaking-indicator{display:flex;align-items:center;gap:.5rem;font-size:.75rem;margin-top:.4rem;color:var(--accent, #667eea);font-weight:500}.speaking-indicator.mini{margin-top:0}.pulse-dot{width:8px;height:8px;background-color:var(--accent, #667eea);border-radius:50%;display:inline-block;animation:pulse 1.5s infinite ease-in-out}@keyframes pulse{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.2);opacity:1}to{transform:scale(.8);opacity:.5}}.message.speaking .message-content{border:1px solid var(--accent-subtle, #ebf4ff);box-shadow:0 0 8px #667eea33}.message-time{font-size:.7rem;color:var(--text-tertiary, #94a3b8);margin-top:.2rem;align-self:flex-end}.message.user .message-time{align-self:flex-end}.message.assistant .message-time{align-self:flex-start}.typing-indicator{display:flex;gap:4px;padding:.5rem 0}.typing-indicator span{width:6px;height:6px;background:var(--text-tertiary, #94a3b8);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-6px);opacity:1}}.loader-tiny{display:inline-block;width:12px;height:12px;border:2px solid rgba(0,0,0,.2);border-radius:50%;border-top-color:#667eea;animation:spin 1s ease-in-out infinite}.chat-error{background:var(--bg-danger-subtle, #fee2e2);color:var(--text-danger, #991b1b);padding:.5rem 1rem;border-top:1px solid var(--border-danger-subtle, #fecaca);font-size:.85rem;text-align:center}.response-buttons{display:flex;gap:.5rem;padding:.75rem 1.5rem 0;flex-wrap:wrap;border-top:1px solid var(--border-subtle, #e2e8f0);background:#fcfcfc;flex-shrink:0}.response-btn{padding:.5rem 1rem;font-size:.85rem;font-weight:500;border:1px solid;border-radius:16px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.response-btn.reply-btn{background:#fff;border-color:var(--primitive-teal, #0d9488);color:var(--primitive-teal, #0d9488)}.response-btn.reply-btn:hover:not(:disabled){background:var(--primitive-teal, #0d9488);color:#fff;transform:translateY(-1px)}.response-btn.action-btn{background:var(--primitive-orange, #f97316);border-color:var(--primitive-orange, #f97316);color:#fff}.response-btn.action-btn:hover:not(:disabled){background:#ea580c;transform:translateY(-1px)}.chat-input-row{display:flex;align-items:flex-end;gap:.75rem;padding:1rem 1.5rem;background:#fff;border-top:1px solid var(--border-subtle, #f1f5f9);flex-shrink:0;position:sticky;bottom:0;z-index:10}.chat-input-form{display:flex;gap:.75rem;flex:1;width:100%;box-sizing:border-box}.chat-input-textarea{flex:1;padding:.75rem 1rem;font-size:.95rem;border:1px solid var(--border-subtle, #cbd5e1);border-radius:8px;transition:border-color .2s ease;font-family:inherit;resize:none;height:48px;min-height:48px;max-height:150px;overflow-y:auto;line-height:1.4}.chat-input-textarea:focus{outline:none;border-color:var(--accent, #667eea);box-shadow:0 0 0 2px #667eea1a}.chat-input-textarea:disabled{background:var(--bg-surface-muted, #f8fafc);cursor:not-allowed}.send-btn{padding:0 1.25rem;height:48px;min-width:80px;font-size:.95rem;font-weight:600;background:var(--accent, #667eea);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin-bottom:0}.send-btn:hover:not(:disabled){background:var(--accent-strong, #5568d3)}.send-btn:disabled{background:var(--border-subtle, #cbd5e1);cursor:not-allowed}.context-panel{border-top:1px solid var(--border-subtle, #e2e8f0);background:var(--bg-surface-muted, #f8fafc);font-size:.85rem}.context-summary{padding:.5rem 1rem;cursor:pointer;display:flex;justify-content:space-between}.context-body{padding:0 1rem 1rem;display:flex;flex-direction:column;gap:.25rem}.context-row{display:flex;gap:.5rem}.context-key{font-weight:600;min-width:60px}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}@media(max-width:768px){#chat-buddy-container{border-radius:0;max-width:none;margin:0;height:100%}.chat-main-area{background:var(--bg-surface, white)}.chat-header{padding:.6rem 1rem;background:var(--bg-surface, white);position:sticky;top:0;z-index:5}.header-content h2{font-size:1.1rem}.chat-subtitle{display:none}.voice-toggle{width:44px;height:44px}.quick-actions{padding:.5rem 1rem;gap:.4rem;-webkit-overflow-scrolling:touch}.quick-btn{padding:.5rem .9rem;font-size:.85rem;min-height:36px}#messages-container{padding:1rem;gap:.75rem}.message{max-width:90%}.message-content{padding:.65rem .9rem;border-radius:16px}.message-content p{font-size:.92rem;line-height:1.45}.response-buttons{padding:.6rem 1rem;gap:.4rem;background:var(--bg-surface-muted, #f8fafc)}.response-btn{padding:.6rem 1rem;font-size:.85rem;min-height:40px}.chat-input-row{padding:.75rem 1rem;padding-bottom:calc(.75rem + var(--safe-area-bottom, 0px));gap:.5rem;background:var(--bg-surface, white);border-top:1px solid var(--border-subtle, #e2e8f0)}.chat-input-textarea{font-size:16px;padding:.7rem .9rem;height:44px;min-height:44px;border-radius:22px;background:var(--bg-surface-muted, #f8fafc);border-color:transparent}.chat-input-textarea:focus{border-color:var(--accent, #667eea);background:#fff}.send-btn{width:44px;height:44px;min-width:44px;padding:0;border-radius:22px}.send-label{display:none}.send-icon{display:inline-block;font-size:1.2rem}.llm-provider-selector{padding:.5rem 1rem;gap:.4rem}.provider-btn{padding:.35rem .7rem;min-height:32px}.typing-indicator{padding:.3rem 0}.bot-speech-controls{flex-wrap:wrap;gap:.4rem}.stop-speaking-btn,.pause-resume-btn{padding:.5rem .8rem;min-height:36px}}@media(max-width:360px){.quick-actions{padding:.4rem .75rem}.quick-btn{padding:.4rem .7rem;font-size:.8rem}#messages-container{padding:.75rem}.chat-input-row{padding:.5rem .75rem;padding-bottom:calc(.5rem + var(--safe-area-bottom, 0px))}}.llm-provider-selector{display:flex;align-items:center;gap:.5rem;padding:.5rem 1.5rem;background:var(--bg-surface-muted, #f8fafc);border-top:1px solid var(--border-subtle, #e2e8f0);flex-wrap:wrap}.provider-label{font-size:.75rem;font-weight:700;color:var(--text-tertiary, #94a3b8);text-transform:uppercase}.provider-btn{padding:.25rem .6rem;font-size:.75rem;font-weight:600;border:1px solid var(--border-subtle, #cbd5e1);background:#fff;border-radius:4px;cursor:pointer;transition:all .2s}.provider-btn:hover{border-color:var(--accent, #667eea);background:var(--bg-surface, #f1f5f9)}.provider-btn.active{background:var(--accent, #667eea);color:#fff;border-color:var(--accent, #667eea);box-shadow:0 2px 4px #667eea4d}.current-model-info{margin-left:auto;font-size:.7rem;color:var(--text-tertiary, #94a3b8);font-family:Courier New,monospace;background:#0000000d;padding:2px 6px;border-radius:4px}.floating-timer{position:fixed;z-index:9999;background:var(--bg-surface);border-radius:12px;box-shadow:0 4px 12px #00000026;border:2px solid var(--color-section-now);transition:box-shadow .2s,transform .1s;-webkit-user-select:none;user-select:none;cursor:grab;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.floating-timer:hover{box-shadow:0 6px 16px #0003}.floating-timer.dragging{cursor:grabbing;opacity:.9;box-shadow:0 8px 20px #0000004d;transform:scale(1.02);animation:none}.floating-timer.full{min-width:200px;max-width:280px}.floating-timer-content{padding:16px;position:relative;display:flex;flex-direction:column;gap:8px}.floating-timer-toggle{position:absolute;top:8px;right:8px;background:transparent;border:none;cursor:pointer;font-size:18px;color:var(--text-muted);padding:4px;border-radius:4px;transition:all .2s;line-height:1;width:24px;height:24px;display:flex;align-items:center;justify-content:center;z-index:1}.floating-timer-toggle:hover{background:var(--color-section-now-bg);color:var(--color-section-now)}.floating-timer-time{font-size:32px;font-weight:700;color:var(--color-section-now);text-align:center;font-family:var(--font-display);margin-bottom:4px;font-variant-numeric:tabular-nums}.floating-timer-goal{font-size:14px;color:var(--text-main);text-align:center;margin-bottom:8px;word-break:break-word;line-height:1.3}.floating-timer-progress{width:100%;height:6px;background:var(--border-subtle);border-radius:3px;overflow:hidden;margin-bottom:4px}.floating-timer-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-section-now),var(--primitive-indigo));transition:width .3s ease;border-radius:3px}.floating-timer-stats{font-size:12px;color:var(--text-muted);text-align:center;font-variant-numeric:tabular-nums}.floating-timer.mini{min-width:auto;max-width:260px}.floating-timer-mini{display:flex;align-items:center;gap:10px;padding:10px 14px;white-space:nowrap}.floating-timer-mini-goal{font-size:13px;color:var(--text-main);font-weight:500;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.floating-timer-mini-time{font-size:15px;font-weight:700;color:var(--color-section-now);font-family:var(--font-display);flex-shrink:0;font-variant-numeric:tabular-nums}.floating-timer.mini .floating-timer-toggle{position:static;flex-shrink:0;font-size:16px;margin:0;padding:2px;width:20px;height:20px}@media(max-width:768px){.floating-timer.full{max-width:240px}.floating-timer-time{font-size:28px}.floating-timer-goal{font-size:13px}.floating-timer.mini{max-width:220px}.floating-timer-mini-goal{font-size:12px}.floating-timer-mini-time{font-size:14px}}@media(hover:none)and (pointer:coarse){.floating-timer{cursor:default;touch-action:none}.floating-timer.dragging{cursor:default}.floating-timer-toggle{width:32px;height:32px;font-size:20px}.floating-timer.mini .floating-timer-toggle{width:28px;height:28px}}.floating-timer.paused{border-color:var(--text-muted);opacity:.9}.floating-timer.paused .floating-timer-time,.floating-timer.paused .floating-timer-mini-time{color:var(--text-muted);animation:none}.floating-timer.paused .floating-timer-progress-bar{background:var(--text-muted);opacity:.5}@keyframes pause-pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}.floating-timer.paused:before{content:"PAUSED";position:absolute;top:-10px;left:50%;transform:translate(-50%);background:var(--text-muted);color:#fff;font-size:10px;padding:2px 6px;border-radius:4px;font-weight:700;letter-spacing:.5px;animation:pause-pulse 2s infinite ease-in-out;z-index:10}.today-view{display:flex;flex-direction:column;gap:1rem;padding:1rem;max-width:600px;margin:0 auto;width:100%;animation:todayFadeIn .4s ease-out}@keyframes todayFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.day-progress{background:#ffffff1f;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:1rem 1.25rem;border:1px solid rgba(255,255,255,.15)}.day-progress__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.day-progress__date{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--text-inverse)}.day-progress__time{font-family:var(--font-display);font-size:.95rem;color:#fffc;font-variant-numeric:tabular-nums}.day-progress__bar{height:8px;background:#ffffff26;border-radius:4px;overflow:hidden;position:relative}.day-progress__fill{height:100%;background:linear-gradient(90deg,var(--primitive-teal),var(--primitive-gold));border-radius:4px;transition:width 1s ease-out;position:relative}.day-progress__fill:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:12px;height:12px;background:var(--primitive-pure-white);border-radius:50%;box-shadow:0 0 8px #fff9}.day-progress__flexible{margin-top:.5rem;font-size:.9rem;color:#ffffffbf;text-align:center}.day-progress__flexible strong{color:var(--primitive-gold);font-weight:600}.your-focus{background:var(--bg-surface);border-radius:20px;padding:1.5rem;box-shadow:0 4px 20px #0000001f,0 0 0 1px #2a9d8f33;position:relative;overflow:hidden}.your-focus:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primitive-teal),var(--color-section-now))}.your-focus__label{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--primitive-teal);margin-bottom:.75rem}.your-focus__icon{font-size:1.1rem}.your-focus__task{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--text-heading);line-height:1.3;margin-bottom:1.25rem}.your-focus__actions{display:flex;gap:.75rem;flex-wrap:wrap}.your-focus__btn{flex:1;min-width:100px;padding:.875rem 1rem;border-radius:12px;font-family:var(--font-display);font-weight:700;font-size:.95rem;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;justify-content:center;gap:.5rem}.your-focus__btn--start{background:var(--primitive-teal);color:var(--primitive-pure-white)}.your-focus__btn--start:hover{background:#35b5a5;transform:translateY(-2px);box-shadow:0 4px 12px #2a9d8f4d}.your-focus__btn--done{background:var(--color-section-now);color:var(--primitive-pure-white)}.your-focus__btn--done:hover{background:#5cb85c;transform:translateY(-2px)}.your-focus__btn--stuck{background:#f4a26126;color:var(--primitive-orange);border:2px solid var(--primitive-orange)}.your-focus__btn--stuck:hover{background:#f4a26140}.your-focus__timer{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;background:#2a9d8f14;border-radius:12px;margin-bottom:1rem}.your-focus__timer-display{font-family:var(--font-display);font-size:2rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--primitive-teal)}.your-focus__timer-label{font-size:.85rem;color:var(--text-muted)}.your-focus__btn--stop{background:var(--primitive-orange);color:var(--primitive-indigo);padding:.75rem 1.25rem}.your-focus__btn--stop:hover{filter:brightness(1.1)}.your-focus--empty{text-align:center;padding:2rem 1.5rem}.your-focus__empty-text{color:var(--text-muted);font-size:1rem;margin-bottom:1rem}.your-focus__btn--plan{background:linear-gradient(135deg,var(--primitive-teal),var(--primitive-indigo));color:var(--primitive-pure-white);padding:1rem 2rem}.your-focus__btn--plan:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2a9d8f59}.hard-landscape{background:#ffffff14;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:1rem 1.25rem;border:1px solid rgba(255,255,255,.12)}.hard-landscape__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.hard-landscape__icon{font-size:1rem}.hard-landscape__title{font-family:var(--font-display);font-size:.85rem;font-weight:700;flex:1}.hard-landscape__refresh-btn{background:transparent;border:1px solid rgba(255,255,255,.2);color:#fff9;padding:.25rem .5rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.hard-landscape__refresh-btn:hover:not(:disabled){background:#ffffff1a;color:#ffffffe6}.hard-landscape__refresh-btn:disabled{opacity:.5;cursor:not-allowed;text-transform:uppercase;letter-spacing:.04em;color:#ffffffb3}.hard-landscape__list{display:flex;flex-direction:column;gap:.5rem}.hard-landscape__event{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;background:#ffffff0f;border-radius:10px;transition:background .2s ease}.hard-landscape__event:hover{background:#ffffff1a}.hard-landscape__event--current{background:#2a9d8f33;border-left:3px solid var(--primitive-teal)}.hard-landscape__event-time{font-family:var(--font-display);font-size:.85rem;font-weight:600;font-variant-numeric:tabular-nums;color:#ffffffe6;min-width:70px}.hard-landscape__event-title{font-size:.9rem;color:var(--text-inverse);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hard-landscape__event-duration{font-size:.75rem;color:#ffffff80;background:#ffffff1a;padding:.2rem .5rem;border-radius:6px}.hard-landscape__empty{text-align:center;padding:1rem;color:#ffffff80;font-size:.9rem}.hard-landscape--disconnected{border:1px dashed rgba(255,255,255,.2)}.hard-landscape__connect{text-align:center;padding:.5rem}.hard-landscape__connect-text{font-size:.9rem;color:#fff9;margin-bottom:1rem}.hard-landscape__connect-btn{background:var(--primitive-teal);color:var(--primitive-pure-white);padding:.75rem 1.5rem;border-radius:10px;font-family:var(--font-display);font-weight:700;font-size:.9rem;border:none;cursor:pointer;transition:all .2s ease}.hard-landscape__connect-btn:hover:not(:disabled){background:#35b5a5;transform:translateY(-2px);box-shadow:0 4px 12px #2a9d8f4d}.hard-landscape__connect-btn:disabled{opacity:.6;cursor:not-allowed;font-size:.9rem}.up-next{background:#ffffff14;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:1rem 1.25rem;border:1px solid rgba(255,255,255,.12)}.up-next__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.up-next__icon{font-size:1rem}.up-next__title{font-family:var(--font-display);font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#ffffffb3}.up-next__list{display:flex;flex-direction:column;gap:.5rem}.up-next__task{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff0f;border-radius:10px;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.up-next__task:hover{background:#ffffff1f;border-color:#f4a26166;transform:translate(4px)}.up-next__task-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#f4a26133;color:var(--primitive-orange);border-radius:6px;font-family:var(--font-display);font-weight:700;font-size:.8rem}.up-next__task-text{flex:1;color:var(--text-inverse);font-size:.95rem}.up-next__task-arrow{color:#ffffff4d;transition:color .2s ease}.up-next__task:hover .up-next__task-arrow{color:var(--primitive-orange)}.up-next__empty{text-align:center;padding:1rem;color:#ffffff80;font-size:.9rem}.tomorrow-preview{background:#ffffff0d;border-radius:12px;padding:.875rem 1rem;display:flex;align-items:center;justify-content:space-between;border:1px solid rgba(255,255,255,.08)}.tomorrow-preview__label{font-size:.85rem;color:#fff9;display:flex;align-items:center;gap:.5rem}.tomorrow-preview__summary{font-size:.85rem;color:#fffc}@media(max-width:768px){.today-view{padding:var(--mobile-content-padding, 16px);padding-bottom:calc(var(--mobile-content-padding, 16px) + 80px);gap:1rem;max-width:100%}.day-progress,.hard-landscape,.up-next{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}}@media(max-width:480px){.today-view{padding:12px 12px 92px;gap:12px}.your-focus{padding:1.25rem;border-radius:18px;box-shadow:0 2px 12px #00000014,0 0 0 1px #2a9d8f26}.your-focus__label{font-size:.8rem;margin-bottom:.5rem}.your-focus__task{font-size:1.15rem;line-height:1.35;margin-bottom:1rem}.your-focus__actions{flex-direction:column;gap:.625rem}.your-focus__btn{width:100%;min-height:var(--touch-target-min, 44px);padding:.875rem 1rem;font-size:.9rem;border-radius:14px}.your-focus__timer{padding:.875rem;gap:.75rem;border-radius:14px}.your-focus__timer-display{font-size:1.6rem}.your-focus__timer-label{font-size:.8rem}.day-progress{padding:.875rem 1rem;border-radius:14px}.day-progress__date{font-size:1rem}.day-progress__time{font-size:.85rem}.day-progress__bar{height:6px}.day-progress__fill:after{width:10px;height:10px}.hard-landscape{padding:.875rem 1rem;border-radius:14px}.hard-landscape__event{padding:.625rem;border-radius:10px;min-height:var(--touch-target-min, 44px)}.hard-landscape__event-time{font-size:.8rem;min-width:60px}.hard-landscape__event-title{font-size:.85rem}.hard-landscape__connect-btn{min-height:var(--touch-target-min, 44px);padding:.75rem 1.25rem}.up-next{padding:.875rem 1rem;border-radius:14px}.up-next__task{padding:.75rem;border-radius:12px;min-height:var(--touch-target-min, 44px)}.up-next__task-text{font-size:.9rem}.up-next__task-number{width:22px;height:22px;font-size:.75rem}.tomorrow-preview{padding:.75rem;border-radius:12px}.tomorrow-preview__label,.tomorrow-preview__summary{font-size:.8rem}}@media(max-width:360px){.today-view{padding:10px}.your-focus__task{font-size:1.05rem}.your-focus__timer-display{font-size:1.4rem}}.today-view--loading{display:flex;align-items:center;justify-content:center;min-height:300px}.today-view__loader{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--primitive-teal);border-radius:50%;animation:spin 1s linear infinite}.focus-app{height:100vh;height:100svh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);overflow:hidden}.app-header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2);padding:1rem 2rem;flex-shrink:0}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.app-logo{margin:0;font-size:1.75rem;font-weight:800;color:var(--text-inverse);text-shadow:2px 2px 4px rgba(0,0,0,.2);font-family:var(--font-display);display:flex;align-items:center;gap:.75rem}.app-logo-icon{width:40px;height:40px;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.2))}.user-info{display:flex;align-items:center;gap:1.5rem}.mobile-menu-btn{display:none;padding:.5rem .75rem;background:#fff3;color:var(--text-inverse);border:1px solid rgba(255,255,255,.3);border-radius:10px;font-size:1.25rem;font-weight:700;cursor:pointer}.mobile-menu-btn:hover{background:#ffffff4d}.mobile-menu-overlay,.mobile-menu{display:none}.user-name{color:var(--text-inverse);font-weight:600;font-size:1.05rem}.sign-out-btn{padding:.5rem 1.25rem;background:#fff3;color:var(--text-inverse);border:1px solid rgba(255,255,255,.3);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.sign-out-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.tab-nav{display:flex;justify-content:center;gap:1rem;padding:1.5rem 2rem;max-width:1200px;margin:0 auto;width:100%;flex-shrink:0}.tab-btn{flex:1;max-width:200px;padding:1rem 1.5rem;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-inverse);border:2px solid rgba(255,255,255,.2);border-radius:12px;font-size:1.1rem;font-weight:600;font-family:var(--font-display);cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.tab-btn:hover{background:#ffffff40;transform:translateY(-2px)}.tab-btn.active{background:var(--bg-surface);color:var(--primitive-teal);border-color:var(--bg-surface);box-shadow:0 4px 12px #00000026}.app-main{flex:1;display:flex;flex-direction:column;padding:0;overflow:hidden;min-height:0}.content-container{flex:1;max-width:1100px;margin:0 auto;width:100%;height:100%;display:flex;flex-direction:column;padding:0 2rem;min-height:0}.tab-content{animation:fadeIn .3s ease;display:flex;flex-direction:column;min-height:0;height:100%;flex:1;overflow-y:auto}.chat-tab{flex:1;min-height:0;overflow:hidden!important;display:flex;flex-direction:column;height:100%}.chat-tab .chat-buddy-container{flex:1 1 auto;min-height:0;height:100%}.chat-tab .tab-info,.app-footer{flex-shrink:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tab-info{text-align:center;margin-top:1rem;padding:1rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;color:var(--text-inverse)}.tab-info p{margin:.25rem 0;font-size:1rem}.tab-info .hint{font-size:.9rem;opacity:.9;font-style:italic}.app-footer{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid rgba(255,255,255,.2);padding:1.5rem 2rem;text-align:center;color:var(--text-inverse)}.app-footer p{margin:0;font-size:.95rem;opacity:.9}@media(max-width:768px){.focus-app{padding-top:var(--safe-area-top);padding-bottom:calc(var(--mobile-tab-height) + var(--safe-area-bottom))}.app-header{padding:.5rem var(--mobile-content-padding);padding-top:calc(.5rem + var(--safe-area-top));background:#ffffff14;border-bottom:1px solid rgba(255,255,255,.1)}.header-content{flex-direction:row;gap:.5rem}.app-logo{font-size:1.25rem;gap:.5rem}.app-logo-icon{width:28px;height:28px}.user-info{display:none}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;min-width:var(--touch-target-min);min-height:var(--touch-target-min);padding:0;background:#ffffff26;border:none;border-radius:12px;font-size:1.1rem;transition:background .15s ease}.mobile-menu-btn:active{background:#ffffff40;transform:scale(.96)}.tab-nav{position:fixed;bottom:0;left:0;right:0;z-index:1000;padding:.5rem var(--mobile-content-padding);padding-bottom:calc(.5rem + var(--safe-area-bottom));gap:.25rem;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(0,0,0,.06);box-shadow:0 -4px 20px #00000014}.tab-btn{flex:1;flex-direction:column;padding:.5rem .25rem;min-height:var(--touch-target-min);background:transparent;border:none;border-radius:12px;color:var(--text-secondary, #64748b);font-size:.65rem;font-weight:600;gap:.25rem;transition:all .15s ease}.tab-btn:hover{transform:none;background:#0000000a}.tab-btn:active{transform:scale(.95);background:#00000014}.tab-btn.active{background:transparent;color:var(--primitive-teal);box-shadow:none}.tab-emoji{font-size:1.35rem;line-height:1}.tab-label{display:block;font-size:.65rem;letter-spacing:.02em}.app-main{padding:0;flex:1;min-height:0}.content-container{max-width:none;padding:0 var(--mobile-content-padding);padding-bottom:1rem}.tab-info,.app-footer{display:none}.mobile-menu-overlay{display:flex;align-items:flex-start;justify-content:flex-end;position:fixed;inset:0;background:#0006;z-index:10000;padding:calc(var(--safe-area-top) + 60px) var(--mobile-content-padding) var(--mobile-content-padding);animation:overlayFadeIn .2s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu{display:block;width:100%;max-width:280px;background:var(--bg-surface);color:var(--text-primary, #0f172a);border-radius:16px;box-shadow:0 10px 40px #0003;overflow:hidden;animation:menuSlideIn .25s ease}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid rgba(0,0,0,.06)}.mobile-menu-title{font-weight:700;font-size:.9rem;font-family:var(--font-display);color:var(--text-heading, #0f172a)}.mobile-menu-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:#0000000d;border-radius:8px;font-size:.9rem;cursor:pointer;color:var(--text-secondary, #475569);transition:background .15s ease}.mobile-menu-close:active{background:#0000001a}.mobile-menu-section{padding:1rem;display:flex;flex-direction:column;gap:.75rem}.mobile-menu-user{font-weight:600;font-size:.95rem;color:var(--text-heading, #0f172a);padding-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.06)}.mobile-menu-signout{padding:.75rem 1rem;border-radius:10px;border:none;cursor:pointer;font-weight:600;font-size:.9rem;background:var(--primitive-teal);color:#fff;min-height:var(--touch-target-min);transition:all .15s ease}.mobile-menu-signout:active{transform:scale(.98);opacity:.9}.mobile-menu-update{padding:.625rem 1rem;border-radius:10px;border:1px solid rgba(0,0,0,.1);cursor:pointer;font-weight:600;font-size:.9rem;background:#0000000a;color:var(--text-main);min-height:var(--touch-target-min);transition:all .15s ease}.mobile-menu-update:active{transform:scale(.98);background:#00000014}.mobile-menu-link{color:var(--text-secondary);font-weight:500;font-size:.9rem;text-decoration:none;padding:.5rem 0}.mobile-menu-version{display:block;font-size:.75rem;color:var(--text-muted);font-family:Courier New,monospace;padding-top:.75rem;margin-top:.5rem;border-top:1px solid rgba(0,0,0,.06)}}.app-main::-webkit-scrollbar{width:8px}.app-main::-webkit-scrollbar-track{background:#ffffff1a}.app-main::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:10px}.app-main::-webkit-scrollbar-thumb:hover{background:#fff6}.build-info{font-size:.75rem;color:#ffffff80;margin-top:.25rem;font-family:Courier New,monospace;cursor:help}.build-info:hover{color:#fffc}.admin-dashboard-container{display:flex;flex-direction:column;height:100vh;background-color:#f4f7f6;font-family:system-ui,-apple-system,sans-serif;color:#333}.admin-dashboard-container .app-header{background-color:#264653;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.admin-dashboard-container .app-header h1{font-size:1.5rem;margin:0;font-weight:600}.admin-nav{display:flex;gap:1rem}.admin-nav-item{color:#ffffffb3;text-decoration:none;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease}.admin-nav-item:hover,.admin-nav-item.active{color:#fff;background-color:#ffffff1a}.admin-dashboard-container .app-main{flex:1;padding:2rem;overflow-y:auto;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.admin-table-container{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #0000000d}.admin-table-container h2{margin-top:0;margin-bottom:1.5rem;color:#2a9d8f;font-size:1.5rem;border-bottom:2px solid #f0f0f0;padding-bottom:.5rem}.filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filters select{padding:.5rem 1rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;background-color:#fff;color:#333;cursor:pointer}.filters select:focus{border-color:#2a9d8f;outline:none}table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.9rem}table th,table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid #eee}table th{background-color:#f8f9fa;color:#666;font-weight:600;text-transform:uppercase;font-size:.75rem;letter-spacing:.05em}table tbody tr:hover{background-color:#fcfcfc}td .status-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:capitalize}.pagination-controls{display:flex;justify-content:flex-end;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #f0f0f0}.pagination-controls button{padding:.5rem 1rem;background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.9rem;color:#555;transition:all .2s}.pagination-controls button:hover:not(:disabled){border-color:#2a9d8f;color:#2a9d8f}.pagination-controls button:disabled{opacity:.5;cursor:not-allowed;background-color:#f5f5f5}.pagination-controls span{font-size:.9rem;color:#777}.loading-message{text-align:center;padding:2rem;color:#666;font-style:italic}.error-message{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:6px;margin-bottom:1rem;border-left:4px solid #c62828}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.admin-toolbar-actions{display:flex;gap:.5rem}.admin-toolbar button{padding:.5rem .9rem;border-radius:6px;border:1px solid #d5d5d5;background:#fff;cursor:pointer}.admin-toolbar .secondary{color:#264653}.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1rem}.filter-row label{display:flex;flex-direction:column;gap:.25rem;font-size:.9rem}.filter-row select{padding:.45rem .6rem;border:1px solid #ddd;border-radius:6px}.create-card{border:1px solid #ececec;border-radius:8px;padding:1rem;margin-bottom:1rem;background:#fafafa}.create-card h3{margin-top:0;margin-bottom:.75rem}.create-form .form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:.75rem}.create-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.create-form input,.create-form select,.create-form textarea{border:1px solid #ddd;border-radius:6px;padding:.45rem .6rem;font-size:.95rem}.actions-row{display:flex;gap:.5rem;justify-content:flex-end;margin-top:.5rem}.actions-row button{padding:.6rem 1rem;border-radius:6px;border:1px solid #2A9D8F;background:#2a9d8f;color:#fff;cursor:pointer}.table-wrapper{overflow-x:auto}.feedback-table select,.feedback-table input[type=number]{width:100%;box-sizing:border-box;padding:.35rem .45rem;border:1px solid #ddd;border-radius:6px}.feedback-table .row-actions{display:flex;gap:.4rem}.feedback-table .link-button{background:none;border:none;color:#264653;cursor:pointer;padding:0;text-align:left}.feedback-table .secondary{border:1px solid #d5d5d5;background:#fff}.feedback-table .danger{background:#ffecec;border:1px solid #f5c2c2;color:#c62828}.feedback-table tr.selected{background:#f0faf8}.detail-drawer{margin-top:1.25rem;border:1px solid #e4e4e4;border-radius:10px;padding:1rem;background:#fff}.drawer-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem}.drawer-label{margin:0;color:#6c6c6c;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.drawer-section{margin-bottom:1rem}.drawer-section .muted{margin:0 0 .25rem;color:#6c6c6c}.drawer-text{white-space:pre-wrap}.drawer-section select,.drawer-section input,.drawer-section textarea{width:100%;border:1px solid #ddd;border-radius:6px;padding:.45rem .6rem;box-sizing:border-box}.grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.app{min-height:100vh}.loading-screen{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.loading-spinner{text-align:center;color:var(--text-inverse)}.spinner{width:60px;height:60px;margin:0 auto 1.5rem;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner p{font-size:1.25rem;font-weight:600;margin:0;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}
