@font-face{font-family:Inter;src:url(/fonts/Inter-Variable.woff2)format("woff2-variations");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:GeistMono;src:url(/fonts/GeistMono-Regular.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}:root{--bg:#0a0a0a;--surface:#111;--surface-2:#1a1a1a;--surface-3:#222;--border:#252525;--border-2:#333;--text:#e8e8e8;--text-muted:#666;--text-faint:#444;--accent:#ff2d78;--accent-h:#ff5a95;--accent-2:#bf00ff;--accent-3:#00e5ff;--success:#39ff14;--error:#ff3c3c;--warning:#ff9500;--glow-accent:0 0 20px #ff2d7866, 0 0 40px #ff2d7826;--glow-accent-2:0 0 20px #bf00ff66, 0 0 40px #bf00ff26;--glow-accent-3:0 0 20px #00e5ff66, 0 0 40px #00e5ff26;--glow-success:0 0 20px #39ff1466, 0 0 40px #39ff1426;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"GeistMono", "Cascadia Code", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-md:1.125rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:2rem;--text-3xl:2.5rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.35s ease;--shadow-sm:0 1px 4px #0009;--shadow-md:0 4px 16px #000000b3;--shadow-lg:0 8px 32px #000c;--nav-height:64px;--page-padding:var(--space-4);--max-width:480px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font);font-size:var(--text-base);color:var(--text);background-color:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-weight:400;line-height:1.5;overflow-x:hidden}#root{flex-direction:column;min-height:100dvh;display:flex}button,input,select,textarea{font-family:inherit;font-size:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}img,svg{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{color:var(--text);background:#ff2d784d}*{-webkit-tap-highlight-color:transparent}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);white-space:nowrap;transition:all var(--transition-fast);cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #0000;min-height:40px;font-weight:500;line-height:1;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}.btn-primary:hover:not(:disabled){background:var(--accent-h);border-color:var(--accent-h);box-shadow:var(--glow-accent);transform:translateY(-1px)}.btn-primary:active:not(:disabled){box-shadow:none;transform:translateY(0)}.btn-secondary{color:var(--text);border-color:var(--border-2);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--surface-2);border-color:var(--text-muted)}.btn-secondary:active:not(:disabled){background:var(--surface-3)}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){color:var(--text);background:var(--surface-2)}.btn-danger{color:var(--error);background:0 0;border-color:#ff3c3c4d}.btn-danger:hover:not(:disabled){border-color:var(--error);background:#ff3c3c1a}.btn-full{width:100%}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);transition:border-color var(--transition-base)}.card:hover{border-color:var(--border-2)}.card-interactive{cursor:pointer}.card-interactive:hover{background:var(--surface-2);border-color:#ff2d784d}.card-interactive:active{background:var(--surface-3)}.input,.textarea,.select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);font-family:var(--font);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;line-height:1.5}.input::placeholder,.textarea::placeholder{color:var(--text-faint)}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #ff2d7826}.input:disabled,.textarea:disabled,.select:disabled{opacity:.5;cursor:not-allowed}.textarea{resize:vertical;min-height:80px}.select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8);cursor:pointer}.select option{background:var(--surface-2);color:var(--text)}.field{gap:var(--space-2);flex-direction:column;display:flex}.field-label{font-size:var(--text-sm);color:var(--text-muted);font-weight:500}.field-error{font-size:var(--text-xs);color:var(--error)}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-xs);background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border);white-space:nowrap;font-weight:500;line-height:1.6;display:inline-flex}.badge-penetrative{color:#ff2d78;background:#ff2d7814;border-color:#ff2d784d}.badge-anal{color:#bf00ff;background:#bf00ff14;border-color:#bf00ff4d}.badge-oral{color:#00e5ff;background:#00e5ff14;border-color:#00e5ff4d}.badge-manual{color:#39ff14;background:#39ff1414;border-color:#39ff144d}.badge-solo{color:#ff9500;background:#ff950014;border-color:#ff95004d}.badge-kink{color:#e040fb;background:#e040fb14;border-color:#e040fb4d}.badge-other{color:#666;border-color:var(--border)}.badge-new{background:var(--accent);width:8px;height:8px;box-shadow:0 0 8px var(--accent);border-radius:50%;flex-shrink:0;display:inline-block}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:100;padding:var(--space-4);animation:overlay-in var(--transition-base) ease;background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal{z-index:101;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90dvh;animation:modal-in var(--transition-base) cubic-bezier(.34, 1.56, .64, 1);position:relative;overflow-y:auto}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{padding:var(--space-5) var(--space-5) 0;justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--text-lg);font-weight:600}.modal-body{padding:var(--space-5)}.modal-footer{gap:var(--space-3);padding:0 var(--space-5) var(--space-5);flex-direction:column;display:flex}.bottom-sheet{background:var(--surface);border-top:1px solid var(--border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:100;max-height:90dvh;animation:sheet-in var(--transition-base) cubic-bezier(.25, .46, .45, .94);padding-bottom:calc(var(--nav-height) + var(--space-4));position:fixed;bottom:0;left:0;right:0;overflow-y:auto}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-handle{background:var(--border-2);border-radius:var(--radius-full);width:36px;height:4px;margin:var(--space-3) auto}.bottom-sheet-header{padding:0 var(--space-5) var(--space-4);justify-content:space-between;align-items:center;display:flex}.bottom-sheet-title{font-size:var(--text-md);font-weight:600}.bottom-sheet-body{padding:0 var(--space-5) var(--space-4)}.nav-bar{height:var(--nav-height);background:var(--surface);border-top:1px solid var(--border);z-index:90;padding-bottom:env(safe-area-inset-bottom,0);align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-muted);letter-spacing:.02em;transition:color var(--transition-fast);padding:var(--space-2) 0;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;font-size:10px;font-weight:500;display:flex}.nav-item:hover{color:var(--text)}.nav-item.active{color:var(--accent)}.nav-item.active svg{filter:drop-shadow(0 0 6px #ff2d7899)}.tag-chip{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);color:var(--accent-h);font-size:var(--text-xs);cursor:default;transition:all var(--transition-fast);background:#ff2d781a;border:1px solid #ff2d784d;font-weight:500;display:inline-flex}.tag-chip-remove{width:14px;height:14px;color:var(--accent);cursor:pointer;transition:background var(--transition-fast);background:#ff2d7833;border-radius:50%;justify-content:center;align-items:center;font-size:10px;line-height:1;display:flex}.tag-chip-remove:hover{background:var(--accent);color:#fff}.tag-list{gap:var(--space-2);flex-wrap:wrap;display:flex}.dropdown{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:200;max-height:240px;animation:.12s dropdown-in;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-group-label{padding:var(--space-2) var(--space-3);font-size:var(--text-xs);color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em;font-weight:600}.dropdown-item{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text);cursor:pointer;transition:background var(--transition-fast);display:flex}.dropdown-item:hover{background:var(--surface-2)}.dropdown-item-create{color:var(--accent);font-style:italic}.dropdown-separator{background:var(--border);height:1px;margin:var(--space-1) 0}.dropdown-wrapper{position:relative}.calendar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.calendar-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.calendar-title{font-size:var(--text-md);cursor:pointer;color:var(--accent);transition:color var(--transition-fast), text-shadow var(--transition-fast);font-weight:600}.calendar-title:hover{color:#f59;text-shadow:0 0 12px #ff2d7880}.calendar-nav-btn{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;display:flex}.calendar-nav-btn:hover{color:var(--text);background:var(--surface-2);border-color:var(--border)}.calendar-weekdays{padding:var(--space-3) var(--space-4) var(--space-2);grid-template-columns:repeat(7,1fr);display:grid}.calendar-weekday{text-align:center;font-size:var(--text-xs);color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.calendar-days{padding:0 var(--space-2) var(--space-3);grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.calendar-day{aspect-ratio:1;border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);color:var(--text);justify-content:center;align-items:center;font-weight:400;display:flex;position:relative}.calendar-day:hover:not(.calendar-day--empty){background:var(--surface-2)}.calendar-day--empty{pointer-events:none}.calendar-day--other-month{color:var(--text-faint);pointer-events:none}.calendar-day--today{color:var(--accent-3);font-weight:700}.calendar-day--has-activity{font-weight:600}.calendar-day--activity-1{color:var(--accent-h);background:#ff2d781f}.calendar-day--activity-2{color:var(--accent-h);background:#ff2d7838}.calendar-day--activity-3{color:#fff;background:#ff2d7852}.calendar-day--activity-many{color:#fff;background:#ff2d7873}.calendar-day--selected{box-shadow:var(--glow-accent);font-weight:700;background:var(--accent)!important;color:#fff!important}.calendar-day:after{content:none}.calendar-day--has-activity:after{content:"";opacity:.8;background:currentColor;border-radius:50%;width:4px;height:4px;position:absolute;bottom:3px;left:50%;transform:translate(-50%)}.calendar-day--selected:after{background:#fffc}.mood-selector{gap:var(--space-2);display:flex}.mood-btn{aspect-ratio:1;border-radius:var(--radius-md);min-width:36px;max-width:48px;font-size:var(--text-lg);border:1px solid var(--border);background:var(--surface-2);cursor:pointer;transition:all var(--transition-fast);font-variant-emoji:emoji;flex:1;justify-content:center;align-items:center;display:flex}.mood-btn:hover{border-color:var(--accent);background:#ff2d781a;transform:scale(1.1)}.mood-btn.active{border-color:var(--accent);background:#ff2d7833;box-shadow:0 0 10px #ff2d784d}.page{padding:var(--space-4) var(--page-padding);padding-bottom:calc(var(--nav-height) + var(--space-8));max-width:var(--max-width);flex:1;width:100%;margin:0 auto}.page--standalone{padding-bottom:var(--space-8);flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;display:flex}.page-title{font-size:var(--text-xl);margin-bottom:var(--space-5);font-weight:700}.spinner{border:2px solid var(--border-2);border-top-color:var(--accent);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin;display:inline-block}.spinner--lg{border-width:3px;width:40px;height:40px}.spinner--sm{width:16px;height:16px}@keyframes spin{to{transform:rotate(360deg)}}.spinner-center{justify-content:center;align-items:center;gap:var(--space-4);flex-direction:column;min-height:100dvh;display:flex}.error-msg{border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--error);font-size:var(--text-sm);align-items:flex-start;gap:var(--space-2);background:#ff3c3c1a;border:1px solid #ff3c3c4d;display:flex}.toggle-wrapper{padding:var(--space-3) 0;cursor:pointer;justify-content:space-between;align-items:center;display:flex}.toggle-label{font-size:var(--text-sm);color:var(--text)}.toggle{flex-shrink:0;width:44px;height:24px;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-track{background:var(--surface-3);border-radius:var(--radius-full);border:1px solid var(--border);transition:all var(--transition-fast);position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--accent);border-color:var(--accent);box-shadow:0 0 8px #ff2d7866}.toggle-thumb{background:var(--text-muted);width:16px;height:16px;transition:all var(--transition-fast);border-radius:50%;position:absolute;top:3px;left:3px}.toggle input:checked~.toggle-thumb{background:#fff;transform:translate(20px)}.section{gap:var(--space-3);flex-direction:column;display:flex}.section-title{font-size:var(--text-xs);color:var(--text-faint);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.divider{background:var(--border);height:1px;margin:var(--space-4) 0}.empty-state{justify-content:center;align-items:center;gap:var(--space-3);padding:var(--space-10) var(--space-6);text-align:center;flex-direction:column;display:flex}.empty-state-icon{color:var(--text-faint);opacity:.4}.empty-state-text{color:var(--text-muted);font-size:var(--text-sm)}.activity-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:all var(--transition-fast);gap:var(--space-2);flex-direction:column;display:flex}.activity-card:hover{background:var(--surface-2);border-color:#ff2d784d}.activity-card-header{justify-content:space-between;align-items:center;display:flex}.activity-card-time{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.activity-card-duration{font-size:var(--text-xs);color:var(--accent);font-family:var(--font-mono)}.activity-card-tags{gap:var(--space-1);flex-wrap:wrap;display:flex}.activity-card-note{font-size:var(--text-xs);color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;display:-webkit-box;overflow:hidden}.partner-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:all var(--transition-fast)}.partner-card:hover{background:var(--surface-2);border-color:#ff2d784d}.partner-card-header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.partner-card-avatar{background:linear-gradient(135deg, var(--accent), var(--accent-2));width:40px;height:40px;font-size:var(--text-md);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.partner-card-name{font-size:var(--text-md);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.partner-card-stats{gap:var(--space-4);font-size:var(--text-xs);color:var(--text-muted);display:flex}.stat-big{text-align:center;padding:var(--space-6)}.stat-big-number{font-size:var(--text-3xl);font-variant-numeric:tabular-nums;color:var(--accent);filter:drop-shadow(0 0 10px #ff2d7880);font-weight:800;line-height:1}.stat-big-label{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-2)}.period-selector{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);gap:2px;padding:3px;display:flex}.period-btn{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-muted);transition:all var(--transition-fast);text-align:center;cursor:pointer;background:0 0;border:none;flex:1;font-weight:500}.period-btn:hover{color:var(--text)}.period-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.settings-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.settings-item{align-items:center;gap:var(--space-4);padding:var(--space-4);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition-fast);display:flex}.settings-item:last-child{border-bottom:none}.settings-item:hover{background:var(--surface-2)}.settings-item-icon{border-radius:var(--radius-md);background:var(--surface-2);width:36px;height:36px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;display:flex}.settings-item-icon--accent{color:var(--accent);background:#ff2d781a}.settings-item-icon--danger{color:var(--error);background:#ff3c3c1a}.settings-item-content{flex:1;min-width:0}.settings-item-title{font-size:var(--text-sm);font-weight:500}.settings-item-subtitle{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.tab-bar{border-bottom:1px solid var(--border);margin-bottom:var(--space-5);gap:0;display:flex}.tab-btn{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);color:var(--text-muted);transition:all var(--transition-fast);text-align:center;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;font-weight:500}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.sort-controls{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.sort-btn{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;transition:all var(--transition-fast);background:0 0;font-weight:500}.sort-btn:hover{color:var(--text);border-color:var(--border-2)}.sort-btn.active{color:var(--accent);background:#ff2d7814;border-color:#ff2d7866}.onboarding-logo{margin-bottom:var(--space-8)}.onboarding-title{font-size:var(--text-2xl);text-align:center;margin-bottom:var(--space-2);font-weight:800}.onboarding-subtitle{font-size:var(--text-sm);color:var(--text-muted);text-align:center;max-width:280px;line-height:1.6}@media (width>=640px){.nav-bar{max-width:var(--max-width);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-left:1px solid var(--border);border-right:1px solid var(--border);left:50%;transform:translate(-50%)}.bottom-sheet{border-radius:var(--radius-xl);border:1px solid var(--border);border-top:1px solid var(--border);width:90%;max-width:480px;padding-bottom:var(--space-5);animation:modal-in var(--transition-base) cubic-bezier(.34, 1.56, .64, 1);inset:50% auto auto 50%;transform:translate(-50%,-50%)}}@media (width>=1024px){:root{--max-width:600px}}[data-theme=light]{--bg:#f5f5f5;--surface:#fff;--surface-2:#f0f0f0;--surface-3:#e8e8e8;--border:#e0e0e0;--border-2:#ccc;--text:#111;--text-muted:#888;--text-faint:#bbb;--glow-accent:0 0 15px #ff2d7840, 0 0 30px #ff2d781a}
