*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary:#f5f5f5;--bg-secondary:#fff;--text-primary:#333;--text-secondary:#666;--border-color:#e0e0e0;--navbar-gradient:linear-gradient(135deg,#667eea,#764ba2);--accent-color:#667eea;--accent-dark:#764ba2}@media (prefers-color-scheme:dark){:root:not([data-theme]){--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--text-primary:#e8e8e8;--text-secondary:#b0b0b0;--border-color:#444;--navbar-gradient:linear-gradient(135deg,#667eea,#764ba2);--accent-color:#667eea;--accent-dark:#764ba2}}:root[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--text-primary:#e8e8e8;--text-secondary:#b0b0b0;--border-color:#444;--navbar-gradient:linear-gradient(135deg,#667eea,#764ba2);--accent-color:#667eea;--accent-dark:#764ba2}:root[data-theme=light]{--bg-primary:#f5f5f5;--bg-secondary:#fff;--text-primary:#333;--text-secondary:#666;--border-color:#e0e0e0;--navbar-gradient:linear-gradient(135deg,#667eea,#764ba2);--accent-color:#667eea;--accent-dark:#764ba2}body,html{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary)}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px rgba(0,0,0,.1)}.navbar-container{max-width:1200px;margin:0 auto;padding:0 20px;justify-content:space-between}.navbar-container,.navbar-logo{display:flex;align-items:center}.navbar-logo{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.navbar-logo:hover{opacity:.9}.navbar-right{display:flex;align-items:center;gap:1.5rem;margin-left:auto}.nav-item{position:relative}.nav-link{color:#fff;text-decoration:none;font-weight:500;padding:12px 20px;display:block;transition:opacity .3s ease;border-bottom:none}.nav-link:hover{opacity:.8;background-color:hsla(0,0%,100%,.1)}.nav-link.active{background-color:hsla(0,0%,100%,.15)}.theme-toggle-item{width:100%;padding:12px 20px;border-top:1px solid hsla(0,0%,100%,.1)}.theme-toggle-container{display:flex;align-items:center;gap:12px}.theme-label{color:#fff;font-weight:500;font-size:.9rem;white-space:nowrap}.theme-toggle-switch{display:flex;gap:0;background:hsla(0,0%,100%,.15);border-radius:20px;padding:2px}.toggle-btn{background:transparent;border:none;color:#fff;padding:6px 14px;font-size:.95rem;cursor:pointer;border-radius:18px;transition:all .3s ease;font-weight:500}.toggle-btn:not(.active){opacity:.6}.toggle-btn.active{background:hsla(0,0%,100%,.25);opacity:1}.toggle-btn:hover:not(.active){opacity:.8}.hamburger{display:flex;flex-direction:column;background:none;border:none;cursor:pointer;padding:0;gap:5px;flex-shrink:0}.hamburger-line{width:25px;height:3px;background-color:#fff;transition:all .3s ease;border-radius:2px}.hamburger.active .hamburger-line:first-child{transform:rotate(45deg) translate(8px,8px)}.hamburger.active .hamburger-line:nth-child(2){opacity:0}.hamburger.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}.nav-menu{position:absolute;top:100%;left:auto;right:0;background:linear-gradient(135deg,#667eea,#764ba2);flex-direction:column;gap:0;max-height:0;overflow:hidden;transition:max-height .3s ease;width:auto;min-width:250px}.nav-menu.active{max-height:80vh;box-shadow:0 8px 16px rgba(0,0,0,.2);overflow-y:auto}.logout-menu-item{width:100%;border-top:1px solid hsla(0,0%,100%,.15)}.logout-bottom-btn{width:100%;background:none;border:none;color:#fff;text-align:left;padding:12px 20px;font-size:16px;font-family:inherit;font-weight:500;cursor:pointer}.logout-bottom-btn:hover{background-color:hsla(0,0%,100%,.1)}@media (max-width:768px){.navbar-right{flex-direction:column;gap:0;position:absolute;top:100%;left:0;right:0;padding:0;background:none;max-height:none;overflow:visible;transition:none}.navbar-right.active{max-height:none;box-shadow:none}.nav-menu{width:100%;position:static;background:none;flex-direction:column;gap:0;max-height:none;overflow:visible;transition:none}.nav-menu.active{max-height:none;box-shadow:none}.logout-bottom-btn{display:block;padding:1rem 20px;border-bottom:1px solid hsla(0,0%,100%,.1)}.nav-item{width:100%}.nav-link{display:block;padding:1rem 20px}.nav-link,.nav-link:hover{border-bottom:1px solid hsla(0,0%,100%,.1)}.nav-link:hover{background-color:hsla(0,0%,100%,.1)}.nav-link.active{background-color:hsla(0,0%,100%,.2);border-bottom:1px solid hsla(0,0%,100%,.1)}}body{line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:20px}h1,h2,h3,h4{margin-top:1.5rem;margin-bottom:.5rem;font-weight:600}h1{font-size:2.5rem}h2{font-size:1.8rem}h3{font-size:1.3rem}a{color:var(--accent-color);text-decoration:none}a:hover{text-decoration:underline}button{background-color:var(--accent-color);color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background-color .2s}button:hover{background-color:var(--accent-dark)}.landing-page{text-align:center;padding:60px 20px}.landing-page h1{font-size:3.5rem;margin-bottom:1rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-page>p{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2rem}.cta-section{margin:2rem 0}.cta-section button{padding:16px 32px;font-size:1.1rem;background:linear-gradient(135deg,#667eea,#764ba2)}.cta-section button:hover{transform:translateY(-2px);box-shadow:0 10px 20px rgba(102,126,234,.3)}.features{margin-top:3rem;text-align:left;max-width:600px;margin-left:auto;margin-right:auto}.features ul{list-style:none;padding:0}.features li{padding:10px 0 10px 30px;position:relative;font-size:1.1rem}.features li:before{content:"✓";position:absolute;left:0;color:var(--accent-color);font-weight:700}.dashboard{background:var(--bg-secondary);border-radius:8px;padding:30px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.dashboard-header{border-bottom:2px solid var(--border-color);padding-bottom:20px;margin-bottom:30px}.dashboard-header h1{margin-bottom:.5rem}.dashboard-header p{color:var(--text-secondary);font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:20px;gap:20px;margin:20px 0}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:8px;text-align:center}.stat-card h3{margin-top:0;font-size:.95rem;opacity:.9;text-transform:uppercase;letter-spacing:1px}.stat-number{font-size:2.5rem;font-weight:700;margin:10px 0 0}.tag-list{display:flex;flex-direction:column;gap:20px;margin:20px 0}.tag-item{background:var(--bg-primary);padding:15px;border-radius:8px;border-left:4px solid var(--accent-color)}.tag-header{display:flex;justify-content:space-between;margin-bottom:8px}.tag-name{font-weight:600;font-size:1.05rem}.tag-count{color:var(--text-secondary);font-size:.9rem}.tag-bar{width:100%;height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden;margin:8px 0}.tag-bar-fill{height:100%;background:var(--navbar-gradient);border-radius:4px;transition:width .3s ease}.tag-percentage{font-size:.85rem;color:var(--text-secondary);font-weight:500}.insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:20px;gap:20px;margin:20px 0}.insight-card{background:var(--bg-primary);padding:20px;border-radius:8px;border:1px solid var(--border-color)}.insight-card h4{margin-top:0;color:var(--accent-color);margin-bottom:10px}.insight-card p{font-size:1.5rem;font-weight:700;margin:10px 0;color:var(--text-primary)}.insight-card small{color:var(--text-secondary);display:block;margin-top:5px}.dashboard-nav{margin-top:30px;padding-top:20px;border-top:2px solid var(--border-color)}.dashboard-nav a{display:inline-block;padding:10px 20px;background-color:var(--border-color);color:var(--text-primary);border-radius:6px;transition:background-color .2s}.dashboard-nav a:hover{background-color:color-mix(in srgb,var(--accent-color) 10%,var(--border-color));text-decoration:none}@media (max-width:768px){.dashboard{padding:20px}}.dashboard-tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid var(--border-color);padding-bottom:0}.tab-button{background:none;border:none;border-bottom:3px solid transparent;color:var(--text-secondary);font-size:1rem;font-weight:500;padding:12px 20px;cursor:pointer;transition:all .3s ease}.tab-button:hover{color:var(--accent-color);background-color:var(--bg-primary)}.tab-button.active{color:var(--accent-color);border-bottom-color:var(--accent-color)}.tab-content{padding-top:20px}.calendar-container{padding:60px 0 20px;flex-direction:column;align-items:center}.calendar-container,.calendar-controls{display:flex;width:100%;overflow:visible}.calendar-controls{gap:30px;margin-bottom:30px;max-width:1400px}.family-legend{background:var(--bg-primary);padding:16px 20px;border-radius:8px;margin-bottom:20px;width:100%;max-width:1400px;border:1px solid var(--border-color)}.family-legend h4{margin:0 0 12px;font-size:.95rem;font-weight:600;color:var(--text-primary)}.legend-members{display:flex;gap:24px;flex-wrap:wrap}.legend-member{display:flex;align-items:center;gap:8px}.legend-order{font-weight:700;color:var(--accent-color);font-size:.9rem}.legend-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;border:1px solid var(--accent-color)}.legend-avatar-fallback{width:24px;height:24px;border-radius:50%;border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff;background:var(--accent-color)}.legend-name{font-size:.9rem;color:var(--text-primary)}.calendar-filter{flex:1 1}.calendar-filter,.calendar-zoom{background:var(--bg-primary);padding:20px;border-radius:8px}.calendar-zoom{display:flex;flex-direction:column;justify-content:flex-start}.calendar-filter h3,.calendar-zoom h3{margin-top:0;margin-bottom:20px;font-size:1.1rem}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.filter-header h3{margin:0;font-size:1.1rem}.deselect-all-btn{background:none;border:1px solid var(--border-color);color:var(--accent-color);padding:6px 12px;font-size:.85rem;font-weight:500;border-radius:4px;cursor:pointer;transition:all .2s ease}.deselect-all-btn:hover{background-color:color-mix(in srgb,var(--accent-color) 5%,var(--bg-secondary));border-color:var(--accent-color)}.deselect-all-btn:active{transform:scale(.98)}.zoom-controls{gap:12px}.zoom-btn,.zoom-controls{display:flex;align-items:center}.zoom-btn{width:36px;height:36px;border:1px solid var(--border-color);background:var(--bg-secondary);border-radius:4px;cursor:pointer;font-size:1.2rem;justify-content:center;transition:all .2s ease;font-weight:700;color:var(--accent-color)}.zoom-btn:hover:not(:disabled){background-color:color-mix(in srgb,var(--accent-color) 5%,var(--bg-secondary));border-color:var(--accent-color)}.zoom-btn:disabled{opacity:.5;cursor:not-allowed}.zoom-level{font-weight:600;color:var(--text-primary);min-width:50px;text-align:center}.tag-filter-list{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.tag-filter-item{display:flex;align-items:center;gap:6px;cursor:pointer;padding:8px 12px;border-radius:4px;border:1px solid var(--border-color);transition:all .2s ease;background-color:var(--bg-secondary);color:var(--text-primary);white-space:nowrap}.tag-filter-item:hover{background-color:var(--accent-color);background-color:color-mix(in srgb,var(--accent-color) 10%,var(--bg-secondary));border-color:var(--accent-color);color:var(--text-primary)}.tag-filter-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin:0}.tag-filter-label{cursor:pointer;font-size:.9rem;margin:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--text-primary)}.member-tags-container{display:flex;flex-direction:column;gap:20px}.member-tag-section{padding:16px;border-radius:8px;background-color:var(--bg-primary);border:1px solid var(--border-color)}.member-tag-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.member-tag-avatar{width:32px;height:32px;border-radius:50%;border:2px solid var(--accent-color)}.member-tag-avatar-fallback{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;background:var(--accent-color)}.member-tag-header h4{margin:0;font-size:1rem;color:var(--text-primary)}.no-tags-message{color:var(--text-secondary);font-style:italic;font-size:.9rem;margin:0;padding:8px 0}.score-options{display:flex;flex-direction:column;gap:8px}.score-parent{font-weight:500}.score-children{display:flex;flex-direction:column;gap:6px;margin-left:12px;padding-left:8px;border-left:2px solid var(--border-color)}.score-child{padding:6px 8px!important;background-color:var(--bg-primary)!important;font-size:.85rem}.score-child:hover{background-color:color-mix(in srgb,var(--accent-color) 8%,var(--bg-primary))!important}.score-toggle-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;border-radius:4px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;transition:all .2s ease;border:1px solid transparent}.score-toggle-item:hover{background-color:color-mix(in srgb,var(--accent-color) 10%,var(--bg-secondary));border-color:var(--accent-color)}.score-toggle-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin:0}.calendar-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px;margin-top:20px;transition:transform .2s ease;max-width:1400px;width:100%;padding:0 20px;box-sizing:border-box;overflow:visible}@media (max-width:1200px){.calendar-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.calendar-grid{grid-template-columns:1fr}}.month-calendar{background:var(--bg-secondary);border-radius:8px;padding:40px 12px 12px;border:1px solid var(--border-color);overflow:visible;position:relative}.month-title{position:absolute;top:12px;left:0;right:0;text-align:center;font-size:.95rem;margin:0;color:var(--accent-color);font-weight:600;z-index:0}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px;overflow:visible}.weekday-header{font-weight:600;text-align:center;color:var(--accent-color);font-size:.75rem;padding:6px 2px;text-transform:uppercase;letter-spacing:.5px}.day-cell{aspect-ratio:1;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2px;font-size:.75rem;transition:all .2s ease;cursor:default;min-height:80px;max-height:120px;color:var(--text-primary);overflow:visible;position:relative;z-index:1}.day-cell:hover{box-shadow:0 2px 6px rgba(102,126,234,.2);border-color:var(--accent-color);background-color:color-mix(in srgb,var(--accent-color) 5%,var(--bg-secondary));z-index:100}.day-content,.day-empty{width:100%;height:100%}.day-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;position:relative;overflow:visible;z-index:1}.day-content:hover{z-index:101}.keyword-tooltip{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--accent-color);padding:16px 20px;border-radius:8px;font-size:1.1rem;white-space:pre-wrap;max-width:600px;min-width:300px;word-wrap:break-word;z-index:9999;pointer-events:none;line-height:1.5;box-shadow:0 8px 32px rgba(0,0,0,.3)}.calendar-tooltip-content{display:flex;flex-direction:column;gap:8px}.calendar-tooltip-title{font-weight:700;color:var(--accent-color);font-size:1rem}.calendar-tooltip-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.calendar-tooltip-subrow{padding-left:6px}.calendar-tooltip-tags{display:flex;flex-wrap:wrap;gap:6px}.calendar-tooltip-tag{border:1px solid transparent;border-radius:999px;padding:2px 8px;font-size:.85rem;font-weight:600}.calendar-tooltip-member{border-top:1px solid color-mix(in srgb,var(--accent-color) 25%,transparent);padding-top:8px;margin-top:4px}.calendar-tooltip-member:first-of-type{border-top:none;padding-top:0;margin-top:0}.calendar-tooltip-member-name{font-weight:700;margin-bottom:6px}.day-number{font-weight:600;color:var(--text-primary);font-size:.8rem}.day-tags{display:flex;flex-wrap:wrap;gap:1px;justify-content:center;width:100%}.day-tag{background:var(--accent-color);color:#fff;padding:1px 3px;border-radius:2px;font-size:.5rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.day-tag-more{background:var(--text-secondary);color:#fff}.day-score{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:2px;font-size:.65rem;font-weight:600;color:var(--text-primary);background:rgba(102,126,234,.1);padding:2px 4px;border-radius:2px}.score-label{color:var(--text-secondary);font-size:.6rem}.score-value{color:var(--accent-color)}.day-content-family{flex-direction:column;align-items:stretch;gap:1px;padding:2px;overflow-y:auto;overflow-x:visible;width:100%;height:100%;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent;position:relative;z-index:1}.day-content-family:hover{z-index:101}.day-content-family::-webkit-scrollbar{width:4px}.day-content-family::-webkit-scrollbar-track{background:transparent}.day-content-family::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.day-content-family::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.day-content-family .day-number{font-size:.65rem;line-height:1;margin-bottom:1px;flex-shrink:0;position:-webkit-sticky;position:sticky;top:0;background:var(--bg-secondary);z-index:1;padding:2px 0}.entry-divider{width:100%;height:1px;background-color:var(--border-color);margin:0;opacity:.6;flex-shrink:0}.single-entry{display:flex;flex-direction:column;gap:1px;position:relative;padding:1px;z-index:1}.single-entry:hover{z-index:101}.single-entry-empty{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:.7rem;opacity:.5;min-height:20px;padding:2px}.entry-user{font-size:.5rem;font-weight:600;color:var(--accent-color);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1}.day-tag-small{font-size:.45rem;padding:1px 2px}.day-score-small{font-size:.55rem;padding:1px 3px;margin-top:1px}.day-score-small .score-value{font-size:.55rem}@media (max-width:900px){.tag-filter-list{flex-direction:column;align-items:stretch}.tag-filter-item{flex:1 1}.day-cell{min-height:70px;max-height:100px}.day-tag{font-size:.5rem}}@media (max-width:600px){.month-calendar{padding:10px}.day-cell{min-height:60px;max-height:90px}.month-title{font-size:.85rem;margin-bottom:10px}.calendar-controls{flex-direction:column;gap:15px}}@media (max-width:480px){.calendar-filter{padding:15px}.tag-filter-item{padding:6px 10px;font-size:.85rem}.month-calendar{padding:8px}.day-number{font-size:.7rem}}@media (max-width:768px){.landing-page h1{font-size:2.5rem}.insights-grid,.stats-grid{grid-template-columns:1fr}.dashboard-tabs,.tag-header{flex-direction:column}.tab-button{width:100%;text-align:left;border-bottom:1px solid var(--border-color)}.tab-button.active{border-bottom-color:var(--accent-color)}}.score-heatmap{margin:2rem 0;padding:1.5rem;background-color:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.score-heatmap h3{margin:0 0 1rem;color:var(--text-primary);font-size:14px;font-weight:600}.heatmap-legend{display:flex;align-items:center;gap:8px;margin-bottom:1.5rem;font-size:.85rem;color:var(--text-secondary)}.legend-label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.legend-colors{display:flex;flex-direction:row;gap:3px}.legend-box{width:12px;height:12px;border-radius:2px}.heatmap-container{display:flex;gap:8px;overflow-x:auto;padding-bottom:10px;align-items:flex-start}.heatmap-months-and-grid{display:flex;flex-direction:column;gap:4px}.heatmap-months{display:flex;gap:4px;padding-left:0;font-size:11px;color:var(--text-secondary);font-weight:500}.month-label{text-align:center;min-width:30px}.heatmap-days-label{display:flex;flex-direction:column;gap:4px;justify-content:flex-start;padding-top:0;min-width:40px}.day-label{width:40px;height:14px;display:flex;align-items:center;font-size:11px;color:var(--text-secondary);font-weight:500}.heatmap-grid{display:flex;flex-direction:row;gap:4px;align-items:flex-start}.heatmap-week{display:flex;flex-direction:column;gap:4px;flex-wrap:nowrap}.heatmap-day{width:14px;height:14px;border-radius:2px;background-color:#ebedf0;transition:all .2s ease;cursor:pointer;flex-shrink:0}.heatmap-day:empty,.heatmap-day[style*=transparent]{cursor:default}.heatmap-day:hover:not([style*=transparent]){transform:scale(1.2);box-shadow:0 0 10px rgba(0,0,0,.3);z-index:10}.heatmap-tooltip{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:12px;box-shadow:0 4px 12px rgba(0,0,0,.15);max-width:300px;font-size:.85rem;z-index:1000;pointer-events:none;word-wrap:break-word}.tooltip-date{font-weight:600;color:var(--accent-color);margin-bottom:8px}.tooltip-score,.tooltip-tags{margin-bottom:6px;color:var(--text-primary)}.tooltip-keywords,.tooltip-tags{word-break:break-word}.tooltip-keywords{color:var(--text-secondary);font-style:italic;margin-top:6px;padding-top:6px;border-top:1px solid var(--border-color)}