:root{--bg:#fff;--accent:#0b5cff;--muted:#666}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial;margin:0;padding:0;background:var(--bg);color:#111}.app{max-width:720px;margin:0 auto;padding:16px;min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:12px}.menu{display:flex;flex-direction:column;gap:12px}.card{padding:14px;border-radius:8px;background:#f7f9ff;border:1px solid #eee}.big{text-align:center;font-weight:600;font-size:18px}.button{padding:10px 12px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer}.button.secondary{background:#eef3ff;color:#0b3a99}.small{padding:8px}.menu-btn{width:100%;padding:18px;border-radius:12px;border:none;background:#0b5cff;color:#fff;font-size:18px;font-weight:600}.menu-btn.secondary{background:#eef3ff;color:#0b3a99}.menu-btn:disabled{opacity:.6}.auth-card{background:#fff;border:1px solid #e0e5ff;padding:24px;border-radius:12px;max-width:420px;margin:60px auto;box-shadow:0 10px 30px #00000014}.auth-card form{display:flex;flex-direction:column;gap:8px}.auth-card input,.auth-card select{padding:10px;border-radius:8px;border:1px solid #ccd6ff;margin-top:4px}.button.danger{background:#f8485e}.button.danger:hover{background:#db2f47}.user-admin{margin-top:24px}.user-panel{margin-top:12px;border:1px solid #e0e5ff;padding:16px;border-radius:10px;background:#f9faff}.user-form,.user-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.user-form input,.user-form select,.user-actions input,.user-actions select{padding:8px;border-radius:8px;border:1px solid #ccd6ff}.user-list{display:flex;flex-direction:column;gap:12px}.user-row{display:flex;gap:12px;flex-wrap:wrap;padding:12px;border:1px solid #e3e8ff;border-radius:8px;background:#fff}.button:disabled,button:disabled{opacity:.6;cursor:not-allowed}.list{margin-top:10px}.tracker-filters{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0}.tracker-filters .secondary{background:#eef3ff;color:#0b3a99}.row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #eee}.history-row-main{display:flex;gap:12px;align-items:flex-start;flex:1}.history-select{margin-top:4px}.history-select input{width:16px;height:16px}.history-actions{display:flex;flex-direction:column;gap:6px}.history-photo{margin-top:8px;display:flex;flex-direction:column;gap:4px}.history-photo img{max-width:220px;border-radius:8px;border:1px solid #e1e1e1;object-fit:cover}.history-photo-actions{display:flex;gap:12px;font-size:13px}.history-photo-actions a{color:var(--accent);text-decoration:none}.history-photo-actions a:hover{text-decoration:underline}.photo-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;padding:24px;z-index:200}.photo-modal{background:#fff;border-radius:12px;padding:16px;max-width:min(92vw,560px);width:100%;box-shadow:0 24px 48px #0f172a33;display:flex;flex-direction:column;gap:12px}.photo-modal-header{display:flex;align-items:center;justify-content:space-between;font-weight:600}.history-bulk-modal{gap:16px}.history-bulk-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.history-bulk-fields label{display:flex;flex-direction:column;gap:6px;font-size:13px}.history-quick-actions{display:flex;flex-wrap:wrap;gap:8px}.history-bulk-actions{display:flex;justify-content:flex-end;gap:8px}.photo-modal-controls{display:flex;align-items:center;gap:12px}.photo-size-toggle{display:flex;border:1px solid #d0d7ec;border-radius:999px;overflow:hidden}.photo-size-toggle button{border:none;background:none;padding:4px 10px;font-size:13px;cursor:pointer;color:#4c5773}.photo-size-toggle button.active{background:#e5edff;color:#0b3a99;font-weight:600}.photo-size-toggle button:not(.active):hover{background:#f3f6ff}.photo-modal img{width:100%;max-height:70vh;object-fit:contain;border-radius:10px;border:1px solid #e2e8f0}.photo-modal-links{display:flex;gap:12px;font-size:13px}.photo-modal-links a{color:var(--accent);text-decoration:none}.photo-modal-links a:hover{text-decoration:underline}.photo-modal-empty{padding:32px 24px;text-align:center;color:#475569;border:1px dashed #cbd5ff;border-radius:10px}.chat-container{display:flex;flex-direction:column;gap:12px}.chat-mode{display:flex;flex-wrap:wrap;gap:12px}.chat-mode label{display:flex;flex-direction:column;gap:4px;font-size:14px;color:#0b3a99;flex:1}.chat-mode select{padding:8px;border-radius:8px;border:1px solid #ccd6ff}.chat-hint{font-size:12px;color:#55607a;margin-top:4px;display:block}.chat-share-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:8px}.chat-share-panel{border:1px solid #dbe2f0;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:10px;background:#f8fbff}.chat-share-log{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;border-bottom:1px solid #e5eaf4;padding-bottom:8px}.chat-share-log:last-child{border-bottom:none;padding-bottom:0}.chat-share-info{min-width:180px}.chat-share-title{font-weight:600}.chat-share-meta{font-size:12px;color:#667}.chat-share-actions{display:flex;gap:8px;flex-wrap:wrap}.chat-share-panel button{padding:6px 10px;border-radius:6px;border:1px solid #ccd6ff;background:#fff;cursor:pointer}.chat-share-panel button:disabled{opacity:.5;cursor:not-allowed}.chat-share-empty{color:#666;font-size:14px;text-align:center}.chat-shared{border:1px solid #e0e5ff;border-radius:10px;padding:12px;background:#f9fbff;display:flex;flex-direction:column;gap:8px}.chat-shared-header{display:flex;justify-content:space-between;align-items:center}.chat-shared-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:6px 0;border-top:1px solid #e4e9ff}.chat-shared-item:first-of-type{border-top:none}.chat-shared-title{font-weight:600}.chat-shared-meta{font-size:12px;color:#555}.chat-spinner{display:flex;align-items:center;gap:8px;font-size:14px;color:#0b3a99}.spinner-dot{width:14px;height:14px;border-radius:50%;border:2px solid #0b5cff;border-bottom-color:transparent;animation:chat-spin .8s linear infinite}@keyframes chat-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-messages{border:1px solid #e0e5ff;border-radius:12px;padding:12px;min-height:240px;max-height:360px;overflow-y:auto;background:#f9faff;display:flex;flex-direction:column;gap:10px}.chat-empty{color:#666;text-align:center;font-size:14px}.chat-bubble{padding:10px 12px;border-radius:10px;max-width:85%;display:flex;flex-direction:column;gap:4px;font-size:15px}.chat-bubble .chat-role{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#555}.chat-bubble.user{align-self:flex-end;background:#0b5cff;color:#fff}.chat-bubble.assistant{align-self:flex-start;background:#fff;border:1px solid #e2e5ff}.chat-timestamp{font-size:12px;color:#7a8399}.chat-image-button{border:none;background:none;padding:0;margin-top:6px;cursor:pointer;align-self:flex-start}.chat-image-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.chat-inline-image{max-width:220px;max-height:220px;border-radius:12px;border:1px solid #dbe2f0;display:block}.chat-input{display:flex;gap:8px}.chat-input input{flex:1;padding:10px;border-radius:8px;border:1px solid #ccd6ff}.chat-actions{display:flex;gap:8px;flex-wrap:wrap}.muted{color:var(--muted);font-size:14px;margin:4px 0 12px}.status{padding:10px 12px;border-radius:8px;margin-bottom:12px;border:1px solid #d0defc;background:#eef3ff;color:#0b3a99}.status.error{border-color:#f5c4c4;background:#fde8e8;color:#761919}.history-controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.history-controls input{padding:8px}.small.danger{background:#ffe2e2;color:#a10000;border:1px solid #f5b1b1}.settings-section{margin-bottom:16px}.setting-row{display:flex;gap:8px;margin-bottom:4px}.setting-row input{flex:1;padding:6px 8px}.category-list{display:flex;flex-direction:column;gap:10px;margin:12px 0}.category-btn{border:1px solid #d5ddff;background:#f7f9ff;border-radius:999px;padding:10px 16px;cursor:pointer;font-size:16px;text-align:left}.category-btn.full{width:100%;border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.category-btn.selected{background:var(--accent);color:#fff;border-color:var(--accent)}.category-btn:disabled{opacity:.6;cursor:not-allowed}.custom-action{margin-bottom:12px}.custom-action input{width:100%;padding:8px 10px;border-radius:8px;border:1px solid #d0d7ff;margin-top:4px}.secondary{background:#eef3ff;border:1px solid #d0defc;color:#0b3a99}.amount-select{margin-bottom:12px}.amount-select input{width:100%;padding:10px;border-radius:8px;border:1px solid #ccd6ff;margin-top:4px;text-align:center}.amount-stepper{display:flex;gap:8px;align-items:center}.amount-stepper button{min-width:40px}.amount-stepper input{margin-top:0}.amount-options{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.shortcut-filter{margin-bottom:12px}.shortcut-filter input{width:100%;padding:10px;border-radius:8px;border:1px solid #ccd6ff;margin-top:4px}
