:root{--primary:#6366f1;--primary-hover:#4f46e5;--bg:#f8fafc;--card-bg:#fff;--text:#1e293b;--text-dim:#64748b;--border:#e2e8f0;--accent:#10b981;--shadow:0 4px 6px -1px #0000000d, 0 2px 4px -2px #0000000d;--font-sans:"Outfit", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}.login-container{background:#f8fafc;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{text-align:center;background:#fff;border-radius:1rem;width:100%;max-width:400px;padding:2.5rem 2rem;box-shadow:0 10px 25px #0000000d}.login-card h2{background:linear-gradient(90deg,#6366f1,#10b981);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:1.5rem}.login-card p{color:var(--text-dim);margin-bottom:1.5rem;font-size:.9rem}.login-card input{border:1px solid var(--border);text-align:center;border-radius:.6rem;width:100%;margin-bottom:1rem;padding:.8rem;font-size:1.1rem;transition:border-color .2s}.login-card input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #6366f11a}.login-card .btn{justify-content:center;width:100%;height:3rem;font-size:1rem}.error-text{color:#ef4444;margin-top:-.5rem;margin-bottom:1rem;font-size:.85rem}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-tap-highlight-color:transparent;background-image:radial-gradient(circle at 0 0,#6366f10d 0%,#0000 40%),radial-gradient(circle at 100% 100%,#10b98108 0%,#0000 40%);min-height:100vh}#root{max-width:600px;margin:0 auto;padding:1rem 1rem 5rem}.card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:1.25rem;margin-bottom:1rem;padding:1.25rem}.main-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}h1{background:linear-gradient(90deg,#6366f1,#10b981);-webkit-text-fill-color:transparent;text-align:left;-webkit-background-clip:text;background-clip:text;flex:1;margin-bottom:0;font-size:1.5rem;font-weight:700}.floating-actions{z-index:1000;flex-direction:column;gap:.75rem;display:flex;position:fixed;bottom:2rem;right:1.5rem}.btn-floating{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;transition:all .3s;display:flex;box-shadow:0 4px 15px #6366f166}.btn-floating:hover{background:var(--primary-hover);transform:scale(1.1)}.btn-preview{color:var(--primary);border:1px solid var(--border);background:#fff}.preview-overlay{z-index:2000;background:#fff;padding:2rem 1rem;position:fixed;inset:0;overflow-y:auto}.preview-content{max-width:800px;margin:0 auto}.preview-header{border-bottom:2px solid var(--primary);flex-direction:column;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;display:flex}@media (width>=640px){.preview-header{flex-direction:row;justify-content:space-between}}.preview-title-nav{align-items:center;gap:1rem;display:flex}.preview-title-nav h2{white-space:nowrap;margin:0;font-size:1.25rem}.preview-nav-btn{border:1px solid var(--border);color:var(--primary);cursor:pointer;background:#f8fafc;border-radius:50%;justify-content:center;align-items:center;padding:.4rem;transition:all .2s;display:flex}.preview-nav-btn:hover{background:var(--primary);color:#fff}.preview-btns{flex-wrap:nowrap;gap:.5rem;display:flex}.preview-btns .btn{white-space:nowrap;align-items:center;gap:.3rem;min-width:fit-content;height:2.4rem;padding:.5rem .8rem;font-size:.8rem;display:flex}.preview-table{border-collapse:collapse;width:100%;font-size:.9rem}.preview-table th,.preview-table td{text-align:left;border:1px solid #cbd5e1;padding:.75rem}.preview-table th{background:#f8fafc;font-weight:600}.p-date{text-align:center;width:60px}.p-name{white-space:nowrap;font-weight:600}.p-item{background:#f1f5f9;border-radius:.3rem;margin-right:.3rem;padding:.1rem .4rem;font-size:.8rem;display:inline-block}@media print{.main-header,form,.month-nav,.summary-list,.history-list,.floating-actions,.preview-btns{display:none!important}.container{background:0 0;max-width:none;margin:0;padding:0}.preview-overlay{z-index:9999;background:#fff;width:100%;height:auto;margin:0;padding:0;position:absolute;top:0;left:0;overflow:visible;display:block!important}.preview-content{max-width:none;margin:0;padding:0}body{background:#fff}}.form-group{margin-bottom:1rem}label{color:var(--text-dim);margin-bottom:.35rem;padding-left:.25rem;font-size:.8rem;font-weight:600;display:block}input,select,textarea{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:.75rem;padding:.65rem .85rem;font-family:inherit;font-size:.95rem;transition:all .2s}input:focus,select:focus,textarea:focus{border-color:var(--primary);background:#fff;outline:none;box-shadow:0 0 0 4px #6366f114}.btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.75rem;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{color:var(--text);background:#f1f5f9}.btn-secondary:hover{background:#e2e8f0}.date-selector{align-items:center;gap:.5rem;display:flex}.date-controls{flex-direction:column;gap:.2rem;display:flex}.date-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:#f1f5f9;border-radius:.4rem;justify-content:center;align-items:center;padding:.2rem;display:flex}.autocomplete-container{position:relative}.suggestions{border:1px solid var(--border);z-index:100;background:#fff;border-radius:.75rem;max-height:200px;margin-top:.5rem;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 10px 15px -3px #0000001a}.suggestion-item{cursor:pointer;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem 1rem;transition:background .2s;display:flex}.suggestion-item:hover{background:#f1f5f9}.suggestion-delete-btn{color:#ef4444;opacity:.3;cursor:pointer;background:0 0;border:none;border-radius:.4rem;align-items:center;padding:.4rem;display:flex}.suggestion-delete-btn:hover{opacity:1;background:#fee2e2}.content-group{gap:.5rem;display:flex}.custom-items-manager{border:1px dashed var(--border);background:#f8fafc;border-radius:.75rem;margin-top:.75rem;padding:.5rem}.custom-items-manager label{margin-bottom:.4rem;font-size:.7rem;display:block}.custom-items-tags{flex-wrap:wrap;gap:.35rem;max-height:80px;padding:.25rem;display:flex;overflow-y:auto}.item-tag{color:var(--text);border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:.4rem;align-items:center;gap:.3rem;padding:.15rem .5rem;font-size:.75rem;transition:all .2s;display:flex}.item-tag:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.item-tag-wrapper{border:1px solid var(--border);background:#fff;border-radius:.4rem;align-items:center;transition:all .2s;display:flex;overflow:hidden}.item-tag-wrapper:hover{border-color:var(--primary)}.item-tag-wrapper .item-tag{border:none;border-radius:0;padding-right:.25rem}.item-tag-del-btn{border:none;border-left:1px solid var(--border);color:#ef4444;opacity:.3;cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:.2rem .4rem;transition:all .2s;display:flex}.item-tag-del-btn:hover{opacity:1;background:#fee2e2}.history-item.compact{border:1px solid var(--border);border-left:3px solid var(--primary);background:#fff;border-radius:.6rem;margin-bottom:.35rem;padding:.5rem .75rem;transition:all .2s;box-shadow:0 1px 2px #00000005}.history-item.compact:hover{border-color:var(--primary);background:#f8fafc}.history-main-line{justify-content:space-between;align-items:center;gap:.5rem;width:100%;display:flex}.history-data-group{flex:1;align-items:center;gap:.6rem;display:flex;overflow:hidden}.h-date{color:var(--text-dim);min-width:35px;font-family:Outfit,sans-serif;font-size:.7rem}.h-name{color:var(--text);white-space:nowrap;font-size:.85rem;font-weight:600}.h-content{color:var(--text);white-space:nowrap;font-size:.85rem}.h-remarks{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;border-left:1px solid var(--border);flex:1;padding-left:.5rem;font-size:.8rem;font-style:italic;overflow:hidden}.h-delete-btn{color:#ef4444;opacity:.3;cursor:pointer;background:0 0;border:none;align-items:center;padding:.2rem;display:flex}.h-delete-btn:hover{opacity:1}.history-list{max-height:55vh;overflow-y:auto}.month-nav{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.month-nav-btn{border:1px solid var(--border);cursor:pointer;background:#f1f5f9;border-radius:.5rem;justify-content:center;align-items:center;padding:.4rem;transition:all .2s;display:flex}.month-nav-btn:hover{background:#e2e8f0}.export-section{width:calc(100% - 2rem);max-width:550px;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.input-with-btn{gap:.5rem;width:100%;display:flex}.add-btn{background:var(--bg);border:1px solid var(--border);cursor:pointer;color:var(--primary);border-radius:.75rem;justify-content:center;align-items:center;padding:0 .75rem;transition:all .2s;display:flex}.add-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.tags-list{flex-wrap:wrap;gap:.4rem;margin-top:.5rem;padding:.2rem;display:flex}.tag{border:1px solid var(--border);color:var(--text);background:#f1f5f9;border-radius:2rem;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:flex}.tag-content{color:#059669;background:#10b9811a;border-color:#10b98133}.tag svg{cursor:pointer;opacity:.5}.tag svg:hover{opacity:1;color:#ef4444}.editing-mode{position:relative;overflow:hidden;border:2px solid var(--primary)!important}.edit-badge{background:var(--primary);color:#fff;border-bottom-left-radius:.75rem;align-items:center;gap:.4rem;padding:.2rem .75rem;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:0;right:0}.cancel-edit-btn{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;display:flex}.btn-success{color:#fff;background:#10b981;border-color:#10b981}.btn-update{background:linear-gradient(135deg, var(--primary), #8b5cf6)}.highlight-edit{transform:scale(1.02);border-color:var(--primary)!important;background:#6366f108!important}.h-names-container,.h-contents-container{flex-wrap:wrap;align-items:center;gap:.25rem;display:flex}.h-content-badge{border:1px solid var(--border);color:var(--text-dim);background:#f8fafc;border-radius:.35rem;padding:.1rem .4rem;font-size:.75rem}.history-actions{align-items:center;gap:.4rem;display:flex}.h-edit-btn{color:var(--primary);opacity:.3;cursor:pointer;background:0 0;border:none;align-items:center;padding:.2rem;display:flex}.h-edit-btn:hover{opacity:1}@media (width<=480px){.history-data-group{flex-direction:column;align-items:flex-start;gap:.2rem}.h-remarks{border-left:none;margin-top:.2rem;padding-left:0}}
