:root{--fox: #F72585;--fox-deep: #B5179E;--purple: #7209B7;--purple-deep: #560BAD;--purple-dark: #480CA8;--violet: #3A0CA3;--alex: #4361EE;--alex-light: #4895EF;--alex-bright: #4CC9F0;--blue-violet: #3F37C9;--bg: #0a0a12;--surface: #160a24;--surface-alt: #0f0c1f;--border: #480CA8;--border-muted: #2a233b;--text: #f0f0ff;--text-muted: #9090b8;--accent: #7209B7;--accent-glow: #4CC9F0;--good: #4CC9F0;--caution: #B5179E;--warning: #F72585;--pillar-self-mgmt: #4895EF;--pillar-self-aware: #7209B7;--pillar-social: #4CC9F0;--pillar-relationship: #F72585;--flare-green: #55ffaa;--flare-yellow: #f2c14f;--flare-orange: #ff9500;--flare-red: #ff5555}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh;background:var(--bg);color:var(--text);font-family:Courier New,Consolas,monospace;line-height:1.5}body{display:flex;flex-direction:column}#root{display:flex;flex-direction:column;width:100%}h1,h2,h3,h4,h5,h6{margin:0 0 .5em;color:var(--accent);font-weight:600}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1rem;text-transform:uppercase;letter-spacing:1px}p{margin:0 0 1em}a{color:var(--alex-light);text-decoration:none}a:hover{color:var(--alex-bright)}input,select,textarea{width:100%;background:var(--surface-alt);color:var(--text);border:1px solid var(--border-muted);border-radius:10px;padding:10px;font-family:inherit;font-size:.9rem;outline:none;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--purple)}textarea{min-height:92px;resize:vertical}button{background:var(--surface);border:1px solid var(--border-muted);color:var(--purple);padding:10px 16px;border-radius:10px;cursor:pointer;font-family:inherit;font-size:.9rem;transition:all .18s}button:hover{background:var(--purple-deep);border-color:var(--purple);color:var(--text);box-shadow:0 0 12px #7209b74d;transform:translateY(-1px)}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button.primary{background:var(--purple);color:var(--text);border-color:var(--purple)}button.primary:hover{background:var(--fox-deep);box-shadow:0 0 15px #f7258566}button.fox{border-color:var(--fox);color:var(--fox)}button.fox:hover{background:#f7258533}button.alex{border-color:var(--alex);color:var(--alex)}button.alex:hover{background:#4361ee33}.card,.panel{background:linear-gradient(180deg,#ffffff05,#fff0);border:1px solid var(--border-muted);border-radius:16px;padding:16px}.card.fox{border-color:var(--fox)}.card.alex{border-color:var(--alex)}.card h3{color:var(--purple);margin-bottom:12px}.pill,.chip{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;background:var(--surface-alt);border:1px solid var(--border-muted);font-size:.8rem;color:var(--text-muted)}.chip.selected{background:var(--purple);border-color:var(--purple);color:var(--text)}.chip.fox{border-color:var(--fox);color:var(--fox)}.chip.alex{border-color:var(--alex);color:var(--alex)}input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:8px;background:var(--surface-alt);border-radius:4px;outline:none;border:1px solid var(--border-muted);padding:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:var(--purple);border-radius:50%;cursor:pointer;border:2px solid var(--alex-bright)}input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--purple);border-radius:50%;cursor:pointer;border:2px solid var(--alex-bright)}input[type=checkbox]{width:auto;accent-color:var(--purple);cursor:pointer}.text-muted{color:var(--text-muted)}.text-fox{color:var(--fox)}.text-alex{color:var(--alex)}.text-small{font-size:.8rem}.flex{display:flex}.flex-col{flex-direction:column}.gap-sm{gap:8px}.gap-md{gap:16px}.gap-lg{gap:24px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--surface);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--purple-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--purple)}@media(max-width:768px){html{font-size:14px}}.love-meter{text-align:center}.love-meter h3{margin-bottom:4px}.love-meter small{display:block;margin-bottom:16px}.meter-container{display:flex;align-items:center;gap:12px;margin-bottom:16px}.meter-side{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:50px}.meter-name{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px}.meter-score{font-size:1.5rem;font-weight:700;color:var(--text)}.meter-track{flex:1;height:32px;background:linear-gradient(90deg,var(--alex) 0%,var(--purple) 50%,var(--fox) 100%);border-radius:16px;position:relative;border:2px solid var(--border-muted)}.meter-heart{position:absolute;top:50%;transform:translate(-50%,-50%);transition:left .5s ease-out}.heart-emoji{font-size:2.5rem;filter:drop-shadow(0 0 8px var(--purple)) drop-shadow(0 0 16px rgba(114,9,183,.5))}.meter-buttons{display:flex;gap:12px;justify-content:center;margin-bottom:16px}.meter-buttons button{flex:1;max-width:200px}.emotion-row{display:flex;justify-content:space-between;gap:16px}.emotion-display{flex:1;padding:8px 12px;border-radius:8px;background:var(--surface-alt);border:1px solid var(--border-muted);text-align:left}.emotion-display.alex{border-color:var(--alex)}.emotion-display.fox{border-color:var(--fox)}.emotion-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}.emotion-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--border-muted);color:var(--text);font-size:.9rem;padding:4px 0;outline:none;border-radius:0}.emotion-input:focus{border-bottom-color:var(--purple)}.emotion-display.alex .emotion-input:focus{border-bottom-color:var(--alex)}.emotion-display.fox .emotion-input:focus{border-bottom-color:var(--fox)}.fox-state{display:flex;flex-direction:column;gap:12px}.fox-state h3{color:var(--fox);margin-bottom:0}.no-data{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;color:var(--text-muted)}.fox-spoons{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px;background:var(--surface-alt);border-radius:8px}.spoons-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.spoons-visual{display:flex;gap:4px;font-size:1.5rem}.spoon.filled{opacity:1}.spoon.empty{opacity:.2;filter:grayscale(1)}.spoons-count{font-size:.85rem;color:var(--text-muted)}.fox-stats-row{display:flex;gap:8px;flex-wrap:wrap}.stat-chip{display:flex;flex-direction:column;align-items:center;padding:8px 12px;background:var(--surface-alt);border-radius:6px;border-left:3px solid var(--text-muted);flex:1;min-width:60px}.stat-chip.pain{border-left-color:var(--flare-red)}.stat-chip.fog{border-left-color:var(--flare-yellow)}.stat-chip.fatigue{border-left-color:var(--flare-orange)}.stat-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase}.stat-value{font-size:1rem;font-weight:700;color:var(--text)}.fox-mood{padding:10px 12px;background:var(--surface-alt);border-radius:8px;border-left:3px solid var(--fox)}.mood-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}.mood-value{font-size:1rem;color:var(--fox);font-weight:500}.fox-need{padding:10px 12px;background:var(--surface-alt);border-radius:8px;border-left:3px solid var(--purple)}.need-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}.need-value{font-size:.9rem;color:var(--text);font-style:italic}.fox-heart-rate{display:flex;flex-direction:column}.hr-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.hr-value{font-size:1.75rem;font-weight:700;color:var(--fox)}.hr-unit{font-size:.9rem;font-weight:400;color:var(--text-muted)}.fox-status{padding:12px;background:var(--surface-alt);border-radius:8px;border-left:4px solid var(--flare-green)}.status-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}.status-value{font-size:1.25rem;font-weight:700}.fox-tags{display:flex;flex-wrap:wrap;gap:8px}.tag-chip{padding:6px 12px;background:var(--surface-alt);border:1px solid var(--border-muted);border-radius:6px;font-size:.8rem;color:var(--text)}.fox-note{padding:12px;background:var(--surface-alt);border-radius:8px;border-left:3px solid var(--fox)}.note-label{display:block;font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.note-text{font-style:italic;color:var(--text);font-size:.9rem;line-height:1.4}.fox-timestamp{font-size:.75rem;color:var(--text-muted);text-align:right;margin-top:auto}.alex-state h3{color:var(--alex)}.mbti-display{text-align:center;margin-bottom:16px}.mbti-type{font-size:2rem;font-weight:700;color:var(--alex);letter-spacing:4px}.mbti-confidence{display:block;font-size:.8rem;color:var(--text-muted);margin-top:4px}.axes-section{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.axis-bar{display:flex;flex-direction:column;gap:4px}.axis-labels{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-muted);text-transform:uppercase}.axis-left{color:var(--alex)}.axis-right{color:var(--purple)}.axis-track{height:8px;background:var(--surface-alt);border-radius:4px;border:1px solid var(--border-muted);position:relative}.axis-center{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--border-muted);transform:translate(-50%)}.axis-fill{position:absolute;top:0;bottom:0;background:linear-gradient(90deg,var(--alex),var(--purple));border-radius:4px}.axis-marker{position:absolute;top:-2px;width:12px;height:12px;background:var(--accent-glow);border-radius:50%;transform:translate(-50%);border:2px solid var(--bg)}.pillars-section{margin-bottom:16px}.pillars-section h4{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}.pillar-bars{display:flex;flex-direction:column;gap:6px}.pillar-row{display:flex;align-items:center;gap:8px}.pillar-name{font-size:.7rem;color:var(--text-muted);min-width:80px;text-transform:capitalize}.pillar-bar{flex:1;height:6px;background:var(--surface-alt);border-radius:3px;overflow:hidden;display:flex;justify-content:flex-end}.pillar-fill{height:100%;border-radius:3px;transition:width .3s ease}.pillar-fill[data-pillar=self-management]{background:var(--pillar-self-mgmt)}.pillar-fill[data-pillar=self-awareness]{background:var(--pillar-self-aware)}.pillar-fill[data-pillar=social-awareness]{background:var(--pillar-social)}.pillar-fill[data-pillar=relationship-management]{background:var(--pillar-relationship)}.pillar-count{font-size:.75rem;color:var(--text-muted);min-width:24px;text-align:right}.emotions-section{margin-bottom:12px}.emotions-section h4{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}.emotion-chips{display:flex;flex-wrap:wrap;gap:6px}.alex-stats{font-size:.8rem;color:var(--text-muted);text-align:right}.alex-stats strong{color:var(--alex)}.notes-between-stars h3{background:linear-gradient(90deg,var(--alex),var(--fox));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.note-form{margin-bottom:12px}.note-input-row{display:flex;gap:8px}.from-select{width:auto;min-width:100px}.note-input{flex:1}.notes-list{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.no-notes{padding:20px;text-align:center;color:var(--text-muted)}.note-item{padding:10px 12px;background:var(--surface-alt);border-radius:8px;border-left:3px solid var(--border-muted)}.note-item.alex{border-left-color:var(--alex)}.note-item.fox{border-left-color:var(--fox)}.note-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.note-from{font-size:.75rem;font-weight:600;text-transform:uppercase}.note-item.alex .note-from{color:var(--alex)}.note-item.fox .note-from{color:var(--fox)}.note-time{font-size:.7rem;color:var(--text-muted)}.note-text{font-size:.9rem;color:var(--text)}.recent-observations{margin-top:0}.recent-observations h3{color:var(--text);margin-bottom:12px}.no-observations{padding:20px;text-align:center;color:var(--text-muted)}.observations-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.observation-item{padding:12px;background:var(--surface-alt);border-radius:10px;border-left:3px solid var(--accent-glow)}.observation-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.observation-emotion{font-weight:600;font-size:.9rem}.observation-pillar{font-size:.75rem;opacity:.8}.observation-time{font-size:.75rem;color:var(--text-muted);margin-left:auto}.observation-content{font-size:.9rem;color:var(--text);line-height:1.5}.home{width:100%}.home-grid{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:20px}.home-column{display:flex;flex-direction:column;gap:16px}.home-loading,.home-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px;color:var(--text-muted)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-muted);border-top-color:var(--purple);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.home-error{color:var(--warning)}.home-full-width{margin-top:20px}@media(max-width:900px){.home-grid{grid-template-columns:1fr}.home-column{order:0}.center-column{order:-1}}.uplink{max-width:1000px;margin:0 auto}.uplink-header{text-align:center;margin-bottom:16px}.uplink-header h2{color:var(--purple);text-transform:uppercase;letter-spacing:2px}.current-time{font-size:1.5rem;color:var(--accent-glow);margin-top:8px}.flare-presets{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.flare-btn{padding:12px;font-weight:700;text-transform:uppercase;letter-spacing:1px}.flare-btn.green{border-color:var(--flare-green);color:var(--flare-green)}.flare-btn.green:hover{background:#5fa3}.flare-btn.yellow{border-color:var(--flare-yellow);color:var(--flare-yellow)}.flare-btn.yellow:hover{background:#f2c14f33}.flare-btn.orange{border-color:var(--flare-orange);color:var(--flare-orange)}.flare-btn.orange:hover{background:#ff950033}.flare-btn.red{border-color:var(--flare-red);color:var(--flare-red)}.flare-btn.red:hover{background:#f553}.uplink-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px}.form-row{margin-bottom:12px}.form-row label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:4px}.slider-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.slider-row label{min-width:100px;font-size:.8rem;color:var(--text-muted)}.slider-row input[type=range]{flex:1}.slider-value{min-width:32px;text-align:center;padding:4px 8px;background:var(--surface-alt);border:1px solid var(--border-muted);border-radius:8px;font-weight:700;color:var(--accent-glow)}.tags-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:12px}.tag-btn{padding:8px;font-size:.8rem}.tag-btn.selected{background:var(--purple);border-color:var(--purple);color:var(--text)}.selected-tags{font-size:.8rem;color:var(--text-muted)}.meds-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.med-check{display:flex;align-items:center;gap:8px;font-size:.85rem;cursor:pointer}.med-check input[type=checkbox]{margin:0}.orgasm-check{color:var(--fox);margin-top:8px}.packet-preview{margin-bottom:16px}.packet-text{background:#000;border:1px solid #333;color:var(--flare-green);padding:14px;border-radius:10px;font-size:.85rem;white-space:pre-wrap;margin:0;max-height:200px;overflow-y:auto}.uplink-actions{display:flex;gap:12px;flex-wrap:wrap}.uplink-actions button{flex:1;min-width:150px}@media(max-width:768px){.flare-presets{grid-template-columns:repeat(2,1fr)}.uplink-grid{grid-template-columns:1fr}.slider-row{flex-wrap:wrap}.slider-row label{width:100%;margin-bottom:4px}}.journal{max-width:700px;margin:0 auto}.journal-header{text-align:center;margin-bottom:20px}.journal-header h2{color:var(--fox);margin-bottom:4px}.view-toggle{display:flex;justify-content:center;gap:8px;margin-top:16px}.view-toggle button{padding:8px 20px;background:transparent;border:1px solid var(--border-muted);color:var(--text-muted)}.view-toggle button.active{background:var(--purple);border-color:var(--purple);color:var(--text)}.view-toggle button:hover:not(.active){background:var(--surface-alt);transform:none;box-shadow:none}.primary-emotions{margin-bottom:16px}.emotion-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.emotion-btn{padding:16px;font-size:1rem;background:var(--surface-alt);border:2px solid var(--border-muted);transition:all .2s}.emotion-btn:hover{border-color:var(--fox);background:#f725851a}.emotion-btn.selected{background:var(--fox);border-color:var(--fox);color:var(--text)}.sub-emotions{margin-bottom:16px}.sub-emotions h4{font-size:.9rem;color:var(--text-muted);margin-bottom:12px}.sub-emotion-chips{display:flex;flex-wrap:wrap;gap:8px}.sub-emotion-chips .chip{cursor:pointer;transition:all .2s}.sub-emotion-chips .chip:hover{border-color:var(--fox-deep);color:var(--fox)}.sub-emotion-chips .chip.selected{background:var(--fox-deep);border-color:var(--fox-deep);color:var(--text)}.feeling-display{text-align:center;padding:12px;background:var(--surface);border:1px solid var(--border-muted);border-radius:8px;margin-bottom:16px;font-size:.9rem;color:var(--text-muted)}.feeling-text{color:var(--fox);font-weight:700}.writing-section h4{font-size:.9rem;color:var(--text-muted);margin-bottom:12px}.prompts{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.prompt-btn{padding:8px 12px;font-size:.8rem;background:var(--surface-alt);border:1px solid var(--border-muted)}.prompt-btn:hover{border-color:var(--purple);background:#7209b71a;transform:none;box-shadow:none}.writing-section textarea{width:100%;margin-bottom:16px}.journal-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.private-toggle{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-muted);cursor:pointer}.journal-actions{display:flex;gap:8px}.journal-history{margin-top:16px}.no-entries{text-align:center;padding:40px;color:var(--text-muted)}.no-entries button{margin-top:16px}.entries-list{display:flex;flex-direction:column;gap:12px}.entry{border-left:3px solid var(--fox)}.entry.private{border-left-color:var(--purple)}.entry-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.entry-mood{background:var(--fox);border-color:var(--fox);color:var(--text)}.private-badge{font-size:.7rem;padding:2px 8px;background:var(--purple);border-radius:4px;color:var(--text)}.entry-date{font-size:.75rem;color:var(--text-muted);margin-left:auto}.entry-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.entry-tags .chip.small{font-size:.7rem;padding:2px 8px}.entry-content{font-size:.9rem;color:var(--text);line-height:1.5;white-space:pre-wrap}@media(max-width:600px){.emotion-grid{grid-template-columns:1fr}.journal-footer{flex-direction:column;align-items:stretch}.journal-actions{flex-direction:column}.journal-actions button{width:100%}}.app{display:flex;flex-direction:column;min-height:100vh;width:100%}.app-header{background:linear-gradient(135deg,var(--surface) 0%,var(--bg) 100%);border-bottom:1px solid var(--border-muted);padding:16px 20px;text-align:center}.header-content{max-width:1200px;margin:0 auto}.app-title{margin:0;font-size:1.5rem;background:linear-gradient(90deg,var(--fox),var(--purple),var(--alex));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-subtitle{color:var(--text-muted);font-size:.85rem}.tab-bar{display:flex;justify-content:center;gap:4px;background:var(--surface);border-bottom:1px solid var(--border-muted);padding:8px 16px;position:sticky;top:0;z-index:100}.tab-button{display:flex;align-items:center;gap:6px;padding:10px 20px;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-muted);font-size:.9rem;transition:all .2s}.tab-button:hover{background:var(--surface-alt);color:var(--text);transform:none;box-shadow:none}.tab-button.active{background:var(--purple);border-color:var(--purple);color:var(--text)}.tab-icon{font-size:1.1rem}.app-content{flex:1;padding:20px;max-width:1200px;width:100%;margin:0 auto}.app-footer{display:flex;justify-content:center;align-items:center;gap:20px;padding:16px 20px;background:var(--surface);border-top:1px solid var(--border-muted);color:var(--text-muted);font-size:.8rem}.embers{color:var(--purple);font-style:italic}@media(max-width:600px){.app-header{padding:12px 16px}.app-title{font-size:1.25rem}.tab-bar{padding:6px 8px}.tab-button{padding:8px 12px;flex-direction:column;gap:2px}.tab-label{font-size:.75rem}.app-content{padding:12px}.app-footer{flex-direction:column;gap:4px;padding:12px}}
