*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=light]{--accent: #6366f1;--accent-dark: #4f46e5;--accent-soft: #e0e7ff;--bg: #f8fafc;--surface: #ffffff;--sidebar: #1e293b;--sidebar-txt: #94a3b8;--sidebar-act: #f1f5f9;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--danger: #ef4444;--success: #22c55e;--warn: #f59e0b;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 10px 25px rgba(0,0,0,.12);font-size:15px}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--sidebar: #0f172a;--text: #f1f5f9;--text-muted: #94a3b8;--border: #334155;--accent-soft: #312e81;--sidebar-act: #334155}[data-theme=sepia]{--accent: #7c6d3a;--accent-dark: #5c4f25;--accent-soft: #f5ecd7;--bg: #f5f0e8;--surface: #fdf8f0;--sidebar: #3b3020;--sidebar-txt: #a89070;--sidebar-act: #ede8dc;--text: #3b2f1a;--text-muted: #7a6545;--border: #ddd0b8;--danger: #c0392b;--success: #27ae60;--warn: #d68910;--shadow: 0 1px 3px rgba(60,40,10,.1), 0 1px 2px rgba(60,40,10,.06);--shadow-lg: 0 10px 25px rgba(60,40,10,.12)}@media (prefers-color-scheme: dark){:root:not([data-theme]){--bg: #0f172a;--surface: #1e293b;--sidebar: #0f172a;--text: #f1f5f9;--text-muted: #94a3b8;--border: #334155;--accent-soft: #312e81;--sidebar-act: #334155}}.theme-switcher{display:flex;gap:.5rem}.theme-btn{width:36px;height:36px;border-radius:50%;border:2.5px solid transparent;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .15s;background:var(--bg);box-shadow:var(--shadow)}.theme-btn:hover{transform:scale(1.15)}.theme-btn.active{border-color:var(--accent);box-shadow:0 0 0 3px #6366f140}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}.splash{height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;background:var(--sidebar)}.splash-icon{font-size:3rem}.splash-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-wrap{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e293b,#0f172a);padding:1.5rem}.auth-card{background:var(--surface);border-radius:20px;padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-logo{font-size:2.5rem;text-align:center;margin-bottom:.5rem}.auth-title{text-align:center;font-size:1.4rem;font-weight:700;margin-bottom:.25rem}.auth-subtitle{text-align:center;color:var(--text-muted);font-size:.875rem;margin-bottom:2rem}.auth-tabs{display:flex;border-radius:var(--radius);overflow:hidden;background:var(--bg);margin-bottom:1.5rem}.auth-tab{flex:1;padding:.6rem;border:none;background:none;cursor:pointer;font-size:.875rem;color:var(--text-muted);transition:all .2s}.auth-tab.active{background:var(--accent);color:#fff;font-weight:600;border-radius:var(--radius)}.auth-step-title{font-weight:600;margin-bottom:.25rem}.auth-step-hint{font-size:.8rem;color:var(--text-muted);margin-bottom:1.5rem;line-height:1.5}.field{margin-bottom:1rem}.field label{display:block;font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.05em}.field input,.field textarea,.field select{width:100%;padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:.95rem;transition:border-color .2s;outline:none}.field input:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f126}.field textarea{resize:vertical;min-height:80px}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.4rem;border:none;border-radius:var(--radius);cursor:pointer;font-size:.9rem;font-weight:600;transition:all .15s;text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 4px 12px #6366f166}.btn-secondary{background:var(--bg);color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--bg);color:var(--text)}.btn-biometric{background:var(--bg);color:var(--text);border:1.5px solid var(--accent);display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:1rem}.btn-biometric:hover{background:var(--accent);color:#fff}.bio-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0;color:var(--text-muted);font-size:.8rem}.bio-divider:before,.bio-divider:after{content:"";flex:1;height:1px;background:var(--border)}.bio-offer{text-align:center;padding:.5rem 0}.bio-offer-icon{font-size:3rem;margin-bottom:.75rem}.btn-full{width:100%;justify-content:center}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-sm{padding:.45rem .9rem;font-size:.8rem}.btn-icon{padding:.5rem;border-radius:50%;aspect-ratio:1}.alert{padding:.8rem 1rem;border-radius:var(--radius);font-size:.875rem;margin-bottom:1rem}.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.alert-success{background:#dcfce7;color:#166534;border:1px solid #86efac}.alert-info{background:var(--accent-soft);color:var(--accent-dark);border:1px solid #a5b4fc}.layout{display:flex;height:100dvh;overflow:hidden}.sidebar{width:260px;background:var(--sidebar);display:flex;flex-direction:column;padding:1.5rem 0;flex-shrink:0;transition:transform .3s}.sidebar-logo{padding:0 1.5rem 1.5rem;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-icon{font-size:1.5rem}.sidebar-logo-text{font-weight:700;font-size:1rem;color:#f1f5f9}.sidebar-logo-sub{font-size:.7rem;color:var(--sidebar-txt)}.sidebar-nav{flex:1;padding:1rem 0}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;color:var(--sidebar-txt);cursor:pointer;transition:all .15s;font-size:.9rem;border:none;background:none;width:100%;text-align:left}.nav-item:hover{color:#f1f5f9;background:#ffffff0d}.nav-item.active{color:#f1f5f9;background:#6366f140;border-right:3px solid var(--accent)}.nav-item svg,.nav-item span:first-child{width:18px;flex-shrink:0}.sidebar-bottom{padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{font-size:.8rem;color:var(--sidebar-txt);margin-bottom:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.topbar{padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.topbar-title{font-weight:700;font-size:1.1rem;flex:1}.content-area{flex:1;overflow-y:auto;padding:1.5rem}.menu-btn{display:none;background:none;border:none;cursor:pointer;color:var(--text);padding:.25rem}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:40}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:50;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.open{display:block}.menu-btn{display:flex}.content-area{padding:1rem}}.calendar-wrap{max-width:680px;margin:0 auto}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.calendar-month{font-size:1.2rem;font-weight:700}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-weekday{text-align:center;font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;padding:.5rem 0}.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px;cursor:pointer;border:none;background:none;color:var(--text);font-size:.9rem;transition:all .15s;position:relative;gap:2px}.cal-day:hover{background:var(--accent-soft);color:var(--accent)}.cal-day.other-month{color:var(--text-muted);opacity:.4}.cal-day.today{font-weight:700;color:var(--accent)}.cal-day.selected{background:var(--accent)!important;color:#fff!important}.cal-day.has-entry:after{content:"";width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.7}.cal-day.selected.has-entry:after{background:#fffc}.cal-dot-row{display:flex;gap:2px}.cal-mood-dot{width:5px;height:5px;border-radius:50%;display:block}.entry-list{margin-top:1.5rem}.entry-list-title{font-size:.8rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.entry-card{background:var(--surface);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:.5rem;display:flex;align-items:center;gap:1rem;cursor:pointer;border:1.5px solid transparent;transition:all .15s;box-shadow:var(--shadow)}.entry-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.entry-card-date{font-weight:700;font-size:.875rem;color:var(--accent);min-width:80px}.entry-card-preview{font-size:.85rem;color:var(--text-muted);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex:1}.entry-card-icons{display:flex;gap:.35rem;font-size:.85rem}.editor-wrap{max-width:780px;margin:0 auto}.editor-date{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.editor-date input[type=date]{border:1.5px solid var(--border);border-radius:8px;padding:.35rem .65rem;background:var(--bg);color:var(--text);font-size:.85rem;outline:none}.editor-date input[type=date]:focus{border-color:var(--accent)}.mood-row{display:flex;gap:.5rem;margin-bottom:1rem;align-items:center}.mood-label{font-size:.8rem;color:var(--text-muted);margin-right:.25rem}.mood-btn{border:none;border-radius:50%;width:32px;height:32px;cursor:pointer;font-size:1.1rem;transition:transform .15s;background:var(--bg);display:flex;align-items:center;justify-content:center}.mood-btn:hover{transform:scale(1.2)}.mood-btn.active{box-shadow:0 0 0 3px var(--accent)}.editor-textarea{width:100%;min-height:300px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.25rem;font-size:1rem;line-height:1.8;color:var(--text);resize:vertical;outline:none;font-family:inherit;transition:border-color .2s}.editor-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f11f}.char-count{font-size:.75rem;color:var(--text-muted);text-align:right;margin-top:.25rem}.editor-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.photo-section{margin-top:1.5rem}.photo-section-title{font-size:.875rem;font-weight:600;color:var(--text-muted);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.75rem}.photo-thumb{aspect-ratio:1;border-radius:10px;overflow:hidden;position:relative;background:var(--bg);border:1.5px solid var(--border);cursor:pointer}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-delete{position:absolute;top:4px;right:4px;background:#0009;color:#fff;border:none;border-radius:50%;width:22px;height:22px;font-size:.75rem;cursor:pointer;display:none;align-items:center;justify-content:center}.photo-thumb:hover .photo-delete{display:flex}.photo-upload-btn{aspect-ratio:1;border-radius:10px;border:2px dashed var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;font-size:.8rem;transition:all .15s}.photo-upload-btn:hover{border-color:var(--accent);color:var(--accent)}.photo-upload-input{display:none}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:100;cursor:pointer}.lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;object-fit:contain}.lightbox-close{position:absolute;top:1rem;right:1rem;background:#ffffff26;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:1.2rem;cursor:pointer}.settings-wrap{max-width:560px;margin:0 auto}.settings-section{background:var(--surface);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.25rem;box-shadow:var(--shadow)}.settings-section-title{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:1rem}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border)}.settings-row:last-child{border-bottom:none;padding-bottom:0}.settings-row-label{font-size:.9rem;font-weight:500}.settings-row-sub{font-size:.8rem;color:var(--text-muted);margin-top:.15rem}.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:.5rem}.stat-card{background:var(--bg);border-radius:10px;padding:.75rem;text-align:center}.stat-num{font-size:1.5rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.7rem;color:var(--text-muted)}.loading-inline{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.875rem}.spinner-sm{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.7rem;font-weight:700}.badge-purple{background:var(--accent-soft);color:var(--accent)}.badge-green{background:#dcfce7;color:#166534}.divider{border:none;border-top:1px solid var(--border);margin:1rem 0}.text-muted{color:var(--text-muted)}.text-sm{font-size:.875rem}
