*,*:before,*:after{box-sizing:border-box}body{font-family:DM Sans,sans-serif;background:#f7f3ed;color:#2a1f0f;min-height:100vh;margin:0;padding:0}.font-display{font-family:Fraunces,serif}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-thumb{background:#c9beb0;border-radius:3px}.cal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width: 1100px){.cal-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 720px){.cal-grid{grid-template-columns:repeat(2,1fr)}.notes-sidebar{display:none}.main{padding-left:20px}}@media (max-width: 460px){.cal-grid{grid-template-columns:1fr}}.month-card{background:#fff;border-radius:13px;overflow:hidden;box-shadow:0 1px 5px #00000014;border:1px solid #E4DAD0}.month-header{background:#1b3a08;color:#fff;text-align:center;padding:8px 4px;font-size:.85rem;font-weight:600;letter-spacing:.01em}.dow-row{display:grid;grid-template-columns:repeat(7,1fr);background:#ede5d8;border-bottom:1px solid #E4DAD0}.dow-cell{text-align:center;font-size:8.5px;font-weight:700;color:#8a7055;padding:4px 0;letter-spacing:.04em}.day-grid{display:grid;grid-template-columns:repeat(7,1fr)}.day-cell{height:76px;border-right:1px solid #F0EBE3;border-bottom:1px solid #F0EBE3;padding:4px 3px 3px;display:flex;flex-direction:column;align-items:center;position:relative;user-select:none;-webkit-user-select:none;cursor:pointer;transition:filter .08s}.day-cell:hover{filter:brightness(.96)}.day-cell.drag-hover{outline:2px dashed #5B7A2F;outline-offset:-2px;filter:brightness(.92);z-index:2}.blank-cell{height:76px;border-right:1px solid #F0EBE3;border-bottom:1px solid #F0EBE3;background:#fafaf8}.day-num{width:24px;height:24px;font-size:13px;font-weight:400;color:#4a3822;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.day-num.weekend{font-weight:600;color:#8a7055}.day-num.today{font-weight:700;color:#fff;background:#1b3a08}.dots-row{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;width:100%;margin-top:4px;overflow:hidden;max-height:36px}.event-dot{width:12px;height:12px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:transform .12s}.event-dot:hover{transform:scale(1.6);z-index:20}.day-cell.is-highlighted{outline:2px solid #1B3A08;outline-offset:-2px;z-index:3}.app-header{background:#f7f3ed;border-bottom:1px solid #DED4C6;position:sticky;top:0;z-index:40}.header-inner{max-width:1440px;margin:0 auto;padding:10px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px}.header-left{display:flex;align-items:center;gap:12px}.header-right{display:flex;align-items:center;gap:10px}.paw{font-size:2.2rem;line-height:1}.app-title{font-size:1.5rem;font-weight:700;color:#1b3a08;line-height:1.15;margin:0}.app-subtitle{font-size:.65rem;color:#8a7055;letter-spacing:.1em;text-transform:uppercase;margin:1px 0 0}.event-meta{text-align:right;line-height:1.5}.event-count{font-size:.72rem;font-weight:600;color:#8a7055}.event-hint{font-size:.62rem;color:#8a7055}.clear-btn{font-size:.72rem;padding:5px 12px;border-radius:8px;border:1px solid #C9BEB0;background:#fff;color:#8a7055;cursor:pointer;font-family:DM Sans,sans-serif}.clear-btn:hover{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.toolbar{background:#ede5d8;border-bottom:1px solid #DED4C6;overflow-x:auto}.toolbar-inner{max-width:1440px;margin:0 auto;padding:9px 20px;display:flex;align-items:center;gap:8px;min-width:max-content}.toolbar-label{font-size:.62rem;font-weight:700;color:#8a7055;letter-spacing:.1em;text-transform:uppercase;margin-right:4px;white-space:nowrap}.cat-btn{display:flex;align-items:center;gap:6px;padding:5px 13px;border-radius:999px;font-size:.73rem;font-weight:500;white-space:nowrap;font-family:DM Sans,sans-serif;cursor:pointer;border:1px solid #C9BEB0;background:#fff;color:#4a3822;transition:all .15s}.dot-preview{width:12px;height:12px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.login-backdrop{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f7f3ed;padding:20px}.login-card{background:#fff;border-radius:20px;padding:40px 36px;width:100%;max-width:360px;box-shadow:0 8px 40px #0000001a;border:1px solid #E4DAD0;text-align:center}.login-logo{font-size:2.8rem;line-height:1;margin-bottom:10px}.login-title{font-size:1.5rem;font-weight:700;color:#1b3a08;margin:0 0 4px}.login-subtitle{font-size:.68rem;color:#8a7055;text-transform:uppercase;letter-spacing:.1em;margin:0 0 28px}.login-form{display:flex;flex-direction:column;gap:14px;text-align:left}.login-field{display:flex;flex-direction:column;gap:5px}.login-label{font-size:.62rem;font-weight:700;color:#8a7055;text-transform:uppercase;letter-spacing:.09em}.login-input{border:1.5px solid #C9BEB0;border-radius:9px;padding:9px 13px;font-size:.9rem;font-family:DM Sans,sans-serif;color:#2a1f0f;outline:none;transition:border-color .12s}.login-input:focus{border-color:#1b3a08}.login-error{font-size:.78rem;color:#b91c1c;background:#fee2e2;border-radius:8px;padding:8px 12px;text-align:center}.login-btn{padding:10px 0;border-radius:10px;background:#1b3a08;color:#fff;font-size:.9rem;font-weight:600;border:none;cursor:pointer;font-family:DM Sans,sans-serif;transition:background .15s;margin-top:4px}.login-btn:hover:not(:disabled){background:#2d5a10}.login-btn:disabled{opacity:.6;cursor:not-allowed}.header-user{display:flex;align-items:center;gap:8px}.header-user-name{font-size:.75rem;font-weight:600;color:#4a3822}.logout-btn{font-size:.68rem;padding:4px 10px;border-radius:7px;border:1px solid #C9BEB0;background:#fff;color:#8a7055;cursor:pointer;font-family:DM Sans,sans-serif}.logout-btn:hover{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.app-body{display:flex;align-items:flex-start;max-width:1600px;margin:0 auto}.notes-sidebar{width:200px;min-width:200px;padding:20px 0 48px 16px;position:sticky;top:89px;max-height:calc(100vh - 89px);overflow-y:auto}.notes-sidebar-header{display:flex;align-items:center;gap:6px;font-size:.62rem;font-weight:700;color:#1b3a08;text-transform:uppercase;letter-spacing:.1em;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #DED4C6}.notes-empty{font-size:.7rem;color:#b0a090;line-height:1.6;padding:4px 0}.notes-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.note-item{display:flex;align-items:flex-start;gap:8px;padding:7px 8px;border-radius:8px;cursor:default;transition:background .12s;border:1px solid transparent}.note-item:hover{background:#fff;border-color:#ded4c6;box-shadow:0 1px 4px #00000012}.note-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px}.note-body{min-width:0}.note-label{font-size:.75rem;font-weight:600;color:#2a1f0f;line-height:1.3;word-break:break-word}.note-span{font-size:.65rem;color:#8a7055;margin-top:2px}.main{flex:1;min-width:0;padding:24px 20px 48px 16px}.loading{text-align:center;padding:60px 0;font-size:.9rem;color:#8a7055}.legend{margin-top:24px;display:flex;flex-wrap:wrap;gap:6px 20px;justify-content:center;font-size:.68rem;color:#8a7055}.legend-swatch{display:inline-block;width:12px;height:12px;border-radius:2px;vertical-align:middle;margin-right:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#00000073}.modal{background:#fff;border-radius:18px;padding:24px;width:100%;max-width:360px;margin:16px;box-shadow:0 24px 64px #00000038}.modal-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.modal-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0}.modal-cat-label{font-size:.62rem;font-weight:700;color:#8a7055;text-transform:uppercase;letter-spacing:.09em}.modal-date{font-size:.875rem;font-weight:600;color:#2a1f0f}.input-label{display:block;font-size:.62rem;font-weight:700;color:#8a7055;text-transform:uppercase;letter-spacing:.09em;margin-bottom:6px}.modal-input{width:100%;border:1.5px solid #C9BEB0;border-radius:9px;padding:9px 13px;font-size:.875rem;font-family:DM Sans,sans-serif;outline:none;margin-bottom:18px;color:#2a1f0f;transition:border-color .12s}.modal-input:focus{border-color:#1b3a08}.modal-actions{display:flex;justify-content:space-between;align-items:center}.btn-group{display:flex;gap:8px}.btn-delete{padding:8px 16px;border-radius:9px;background:#fee2e2;color:#b91c1c;font-size:.8rem;font-weight:500;border:none;cursor:pointer;font-family:DM Sans,sans-serif}.btn-cancel{padding:8px 16px;border-radius:9px;background:#f3f0ec;color:#6b6050;font-size:.8rem;font-weight:500;border:none;cursor:pointer;font-family:DM Sans,sans-serif}.btn-save{padding:8px 18px;border-radius:9px;background:#1b3a08;color:#fff;font-size:.8rem;font-weight:600;border:none;cursor:pointer;font-family:DM Sans,sans-serif}.btn-delete:hover{background:#fca5a5}.btn-cancel:hover{background:#e9e4dc}.btn-save:hover{background:#2d5a10}
