:root{--bg-primary:#f0f7e8;--bg-secondary:#fff;--accent:#4caf50;--accent-dark:#2e7d32;--accent-light:#81c784;--text-primary:#1a2e1a;--text-secondary:#2c3e2f;--text-muted:#5a6b5a;--border:#d0e2c0;--border-focus:#4caf50;--danger:#c55a5a;--danger-dark:#a04444;--danger-light:#d97a7a;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--font-sans:system-ui, "Segoe UI", Roboto, sans-serif;--font-mono:ui-monospace, Consolas, monospace}[data-theme=dark]{--bg-primary:#1a241a;--bg-secondary:#2a352a;--accent:#6fbf6f;--accent-dark:#4caf50;--accent-light:#9ad89a;--text-primary:#eef5e6;--text-secondary:#d0e2c0;--text-muted:#9ab89a;--border:#3a4a3a;--border-focus:#6fbf6f;--danger:#b87171;--danger-dark:#9a5e5e;--danger-light:#cf8a8a;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 6px -1px #0000004d;--shadow-lg:0 10px 15px -3px #0000004d}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);color:var(--text-primary);background-color:var(--bg-primary);font-size:18px;line-height:1.45;transition:background-color .3s,color .2s}@media (width<=1024px){body{font-size:16px}}#root{border-inline:1px solid var(--border);flex-direction:column;width:1126px;max-width:100%;min-height:100vh;margin:0 auto;display:flex}h1,h2,h3{color:var(--text-primary);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}h2{letter-spacing:-.24px;margin-bottom:16px;font-size:24px;line-height:1.18}@media (width<=1024px){h1{margin:20px 0;font-size:36px}h2{font-size:20px}}a{color:var(--accent);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-dark)}button{cursor:pointer;font-family:inherit}.btn{cursor:pointer;background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px)}.btn-secondary{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary)}.btn-secondary:hover{background:var(--accent-light);border-color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:var(--danger-dark);transform:translateY(-1px)}.input,textarea,select{border:1px solid var(--border);background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:.5rem;padding:.5rem .75rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.input:focus,textarea:focus,select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #4caf5033}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);min-width:320px;max-width:90%;box-shadow:var(--shadow-lg);border:1px solid var(--border);border-radius:1rem;padding:1.5rem}.modal-content h3{margin-top:0;margin-bottom:1rem}.modal-buttons{justify-content:flex-end;gap:.75rem;margin-top:1.5rem;display:flex}.card{background:var(--bg-secondary);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:.75rem;padding:1rem}.loading{text-align:center;color:var(--text-muted);padding:2rem}.theme-switcher{background:var(--bg-secondary);border:1px solid var(--border);border-radius:9999px;gap:.25rem;padding:.25rem;display:flex}.theme-btn{cursor:pointer;background:0 0;border:none;border-radius:9999px;padding:.25rem .5rem;font-size:1.2rem;transition:background .2s}.theme-btn.active{background:var(--accent);color:#fff}.theme-btn:hover:not(.active){background:var(--accent-light)}.user-menu{justify-content:flex-end;align-items:center;gap:.75rem;display:flex;position:relative}.login-form{background:var(--bg-secondary);box-shadow:var(--shadow-lg);z-index:50;border:1px solid var(--border);border-radius:1rem;flex-direction:column;gap:.75rem;min-width:220px;padding:1rem;display:flex;position:absolute;top:2.5rem;right:0}.login-form button{margin-top:0}.user-menu.logged-in{gap:.75rem}.user-name{background:var(--accent-light);color:var(--accent-dark);border-radius:2rem;align-items:center;gap:.5rem;padding:.3rem .9rem;font-size:.85rem;font-weight:600;display:inline-flex}.user-name:before{content:"👤";filter:drop-shadow(0 1px 1px #0000001a);font-size:.9rem}.user-menu-container{z-index:100;position:fixed;top:1rem;right:1.5rem}@media (width<=640px){.user-menu-container{top:.75rem;right:.75rem}.user-name{padding:.2rem .7rem;font-size:.75rem}.login-form{min-width:180px;padding:.75rem;top:2.2rem;right:0}}.ticker{background:var(--bg-secondary);border-top:1px solid var(--border);white-space:nowrap;z-index:100;padding:.5rem;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.ticker-scroll{animation:1800s linear infinite scrollTicker;display:inline-block}.ticker-group{margin-right:3rem}.ticker-item{color:var(--text-primary);margin-right:2rem;font-size:.9rem}.ticker:hover .ticker-scroll{animation-play-state:paused}@keyframes scrollTicker{0%{transform:translate(0)}to{transform:translate(-100%)}}.layout{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--bg-secondary);border-bottom:1px solid var(--border);z-index:100;align-items:center;gap:1rem;height:60px;padding:0 1rem;display:flex;position:fixed;top:0;left:0;right:0}.burger-menu{cursor:pointer;flex-direction:column;padding:.5rem;display:none}.burger-line{background:var(--text-primary);width:25px;height:2px;margin:3px 0}.logo{color:var(--accent);font-size:1.2rem;font-weight:700}.desktop-nav{gap:1.5rem;margin-left:auto;display:flex}.desktop-nav a{color:var(--text-primary);font-weight:500;text-decoration:none;transition:color .2s}.desktop-nav a:hover{color:var(--accent)}.header-right{align-items:center;gap:1rem;display:flex}.signalr-status{cursor:default;font-size:1.2rem}.mobile-menu{background:var(--bg-secondary);border-right:1px solid var(--border);z-index:99;width:80%;max-width:300px;height:calc(100% - 60px);padding:1rem;transition:left .3s;position:fixed;top:60px;left:-100%}.mobile-menu.open{left:0}.mobile-nav{flex-direction:column;gap:1rem;display:flex}.mobile-nav a{color:var(--text-primary);border-bottom:1px solid var(--border);padding:.5rem;font-size:1.2rem;text-decoration:none}.content{flex:1;margin-top:60px;margin-bottom:60px;padding:1rem}@media (width<=768px){.burger-menu{display:flex}.desktop-nav{display:none}}.ticker{background:var(--bg-secondary);border-top:1px solid var(--border);white-space:nowrap;z-index:100;padding:.5rem;font-size:.85rem;position:fixed;bottom:0;left:0;right:0;overflow:hidden}.ticker-content{animation:30s linear infinite scroll;display:inline-block}.ticker-item{color:var(--text-primary);margin-right:2rem}.ticker:hover .ticker-content{animation-play-state:paused}.ticker.warning{background:var(--danger);color:#fff;text-align:center;white-space:normal;animation:none}@keyframes scroll{0%{transform:translate(100%)}to{transform:translate(-100%)}}.calendar-page{max-width:1200px;margin:0 auto;padding:1rem}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.calendar-weekdays{text-align:center;grid-template-columns:repeat(7,1fr);margin-bottom:.5rem;font-weight:700;display:grid}.weekday{background:var(--bg-secondary);border-radius:.5rem;padding:.5rem}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-day{border:1px solid var(--border);background:var(--bg-secondary);cursor:pointer;border-radius:.5rem;min-height:100px;padding:4px;transition:all .2s}.calendar-day.other-month{opacity:.6}.calendar-day.selected{border:2px solid var(--accent);box-shadow:0 0 0 1px var(--accent);background-color:var(--accent-light)!important}.day-number{justify-content:space-between;align-items:center;font-weight:700;display:flex}.add-event-btn{cursor:pointer;color:var(--accent);background:0 0;border:none;border-radius:9999px;justify-content:center;align-items:center;width:24px;height:24px;font-size:1rem;font-weight:700;display:inline-flex}.add-event-btn:hover{background:var(--accent-light)}.events-list{max-height:70px;font-size:.75rem;overflow-y:auto}.event-item{background:#ffffff4d;border-radius:4px;justify-content:space-between;align-items:center;margin:2px 0;padding:2px 4px;display:flex}.event-title{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.delete-event-btn{cursor:pointer;opacity:.6;background:0 0;border:none}.delete-event-btn:hover{opacity:1}.selected-day-detail{background:var(--bg-secondary);border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:1rem;margin-top:2rem;padding:1.25rem}.detail-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.detail-date{color:var(--text-primary);margin:0;font-size:1.25rem;font-weight:500}.detail-add-btn{white-space:nowrap}.detail-events-list{flex-direction:column;gap:.5rem;display:flex}.detail-event-item{background:var(--bg-primary);border:1px solid var(--border);border-radius:.75rem;justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.detail-event-title{word-break:break-word;flex:1;font-size:1rem;font-weight:500}.detail-no-events{text-align:center;color:var(--text-muted);padding:1.5rem;font-style:italic}@media (width<=768px){.calendar-page{padding:.5rem}.calendar-header h2{margin:0;font-size:1.2rem}.calendar-header .btn{padding:.3rem .7rem;font-size:.8rem}.calendar-weekdays .weekday{padding:.25rem;font-size:.75rem}.calendar-grid{gap:2px}.calendar-day{flex-direction:column;min-height:70px;max-height:80px;padding:2px;display:flex;overflow:hidden}.day-number{flex-shrink:0;font-size:.8rem}.add-event-btn{width:20px;height:20px;font-size:.8rem}.events-list{flex-direction:column;gap:1px;margin-top:2px;font-size:.65rem;display:flex;overflow:hidden}.event-item{white-space:nowrap;background:0 0;margin:0;padding:1px 2px}.event-title{white-space:nowrap;text-overflow:ellipsis;font-size:.65rem;overflow:hidden}.calendar-day .delete-event-btn{display:none}.more-events-indicator{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;padding:1px 2px;font-size:.6rem;overflow:hidden}.selected-day-detail{margin-top:1.5rem;padding:1rem}.detail-header{flex-direction:column;align-items:stretch}.detail-date{text-align:center;font-size:1.1rem}.detail-add-btn{justify-content:center;width:100%}.detail-event-item{padding:.6rem .8rem}.detail-event-title{font-size:.9rem}.delete-event-btn{font-size:1rem}}@media (width<=480px){.calendar-day{min-height:60px;max-height:70px}.event-title{font-size:.6rem}.day-number{font-size:.7rem}.add-event-btn{width:18px;height:18px;font-size:.7rem}.more-events-indicator{font-size:.55rem}.detail-date{font-size:1rem}.detail-event-item{padding:.5rem .6rem}.detail-event-title{font-size:.85rem}}.chats-page{max-width:800px;margin:0 auto}.new-chat{gap:.5rem;margin-bottom:1.5rem;display:flex}.chat-list{flex-direction:column;gap:.75rem;padding:0;list-style:none;display:flex}.chat-item{cursor:pointer;justify-content:space-between;align-items:center;transition:transform .1s;display:flex}.chat-item:hover{transform:translate(4px)}.chat-item span{flex:1;font-weight:500}.message-mine{text-align:right;background-color:var(--accent-light);border-radius:1rem .5rem .5rem 1rem;width:fit-content;max-width:80%;margin-left:auto}.message-other{text-align:left;background-color:var(--bg-primary);border-radius:.5rem 1rem 1rem .5rem;width:fit-content;max-width:80%;margin-right:auto}.message{box-shadow:var(--shadow-sm);flex-direction:column;margin-bottom:.5rem;padding:.5rem 1rem;display:flex}.message-author{margin-bottom:.25rem;font-size:.8rem;font-weight:700}.message-time{color:var(--text-muted);margin-left:.5rem;font-size:.7rem;font-weight:400}.message-text{word-break:break-word}.btn-danger-small{cursor:pointer;color:var(--danger);background:0 0;border:none;align-self:flex-end;margin-top:.25rem;font-size:1rem}.message-highlight{animation:1s ease-in-out highlightFlash;background-color:#fff3b0!important}@keyframes highlightFlash{0%{background-color:inherit}50%{background-color:#fff3b0}to{background-color:inherit}}.loading-more{text-align:center;color:var(--text-muted);padding:.5rem;font-size:.8rem}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-container{width:100%;max-width:400px;padding:2rem}.login-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.login-header h2{margin:0}.form-group{margin-bottom:1rem}.error-message{color:var(--danger);text-align:center;margin-bottom:1rem;font-size:.875rem}.login-container button[type=submit]{width:100%}.files-page{max-width:1200px;margin:0 auto;padding:1rem}.files-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.filter-bar{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.filter-btn{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:9999px;padding:.5rem 1rem;transition:all .2s}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.files-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.file-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;flex-direction:column;gap:.5rem;padding:.75rem;transition:box-shadow .2s;display:flex}.file-card:hover{box-shadow:var(--shadow-md)}.file-icon{text-align:center;font-size:2rem}.file-info{flex:1}.file-name{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.25rem;font-weight:700;overflow:hidden}.file-meta{color:var(--text-muted);margin-bottom:.5rem;font-size:.75rem}.file-description{color:var(--text-secondary);background:var(--bg-primary);cursor:pointer;word-break:break-word;border-radius:.5rem;padding:.25rem .5rem;font-size:.8rem}.file-description .placeholder{color:var(--text-muted);font-style:italic}.edit-description{align-items:center;gap:.25rem;display:flex}.input-small{border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);border-radius:.5rem;flex:1;padding:.25rem .5rem;font-size:.8rem}.file-actions{justify-content:flex-end;gap:.5rem;display:flex}.icon-btn{cursor:pointer;background:0 0;border:none;border-radius:.5rem;padding:.25rem;font-size:1.2rem;transition:background .2s}.icon-btn:hover{background:var(--accent-light)}.icon-btn.delete:hover{background:var(--danger-light)}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1rem;display:flex}.page-info{color:var(--text-primary)}.no-files{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:2rem}.error-message{text-align:center;color:var(--danger);padding:1rem}.preview-content{background:var(--bg-secondary);border-radius:1rem;max-width:90vw;max-height:90vh;padding:1rem;overflow:auto}.preview-image,.preview-video{max-width:100%;max-height:70vh;margin:1rem auto;display:block}.resources-page{max-width:1200px;margin:0 auto;padding:1rem}.resources-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.resources-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.resource-card{background:var(--bg-secondary);border-radius:.75rem;flex-direction:column;justify-content:space-between;padding:1rem;transition:transform .1s;display:flex}.resource-info h3{margin:0 0 .25rem;font-size:1.2rem}.resource-unit{color:var(--text-muted);margin-bottom:.5rem;font-size:.85rem}.resource-stock{margin-top:.5rem;font-size:1rem;font-weight:500}.resource-actions{justify-content:flex-end;gap:.5rem;margin-top:1rem;display:flex}.modal-content.large{width:90%;max-width:1000px;max-height:85vh;overflow-y:auto}.transaction-form{flex-wrap:wrap;align-items:flex-end;gap:.5rem;margin:1rem 0;display:flex}.transaction-form .input{flex:1;min-width:120px}.transactions-table{border-collapse:collapse;width:100%;margin-top:.5rem}.transactions-table th,.transactions-table td{border:1px solid var(--border);text-align:left;vertical-align:top;padding:.5rem}.transactions-table th{background:var(--bg-primary);font-weight:600}.empty-state{text-align:center;color:var(--text-muted);padding:2rem;font-style:italic}.kanban-page{padding:1rem}.kanban-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.boards-list{flex-wrap:wrap;gap:1rem;margin-bottom:2rem;display:flex}.board-card{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:.75rem;min-width:200px;padding:.75rem 1rem;transition:all .2s}.board-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.board-card.active{border-color:var(--accent);background:var(--accent-light);color:var(--text-primary)}.board-card-header{justify-content:space-between;align-items:center;display:flex}.board-title{font-size:1.1rem;font-weight:700}.board-meta{color:var(--text-muted);margin-top:.5rem;font-size:.75rem}.btn-icon{cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 .2rem;font-size:1.1rem}.btn-icon:hover{opacity:1}.kanban-board{margin-top:1rem}.board-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.sections-container{gap:1rem;padding-bottom:1rem;display:flex;overflow-x:auto}.section{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;flex-direction:column;width:320px;min-width:300px;display:flex}.section-header{border-bottom:1px solid var(--border);background:var(--bg-primary);border-radius:.75rem .75rem 0 0;justify-content:space-between;align-items:center;padding:.75rem;display:flex}.section-title{font-weight:700}.cards-list{flex-direction:column;flex:1;gap:.75rem;padding:.75rem;display:flex}.card{background:var(--bg-primary);border:1px solid var(--border);border-radius:.5rem;padding:.5rem}.card-description{color:var(--text-secondary);word-break:break-word;margin-bottom:.5rem;font-size:.85rem}.card-dates{color:var(--text-muted);margin-bottom:.5rem;font-size:.7rem}.card-meta{color:var(--text-muted);border-top:1px dashed var(--border);padding-top:.25rem;font-size:.7rem}.add-card-btn{background:var(--bg-secondary);border:1px dashed var(--border);cursor:pointer;text-align:center;color:var(--accent);border-radius:.5rem;padding:.5rem;font-weight:500}.add-card-btn:hover{background:var(--accent-light);border-color:var(--accent)}.person-files-page{max-width:1000px;margin:0 auto}.items-list{flex-direction:column;gap:1rem;display:flex}.person-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;padding:1rem;transition:box-shadow .2s}.person-card:hover{box-shadow:var(--shadow-md)}.full-name{color:var(--text-primary);font-size:1.1rem;font-weight:700}.card-actions{gap:.5rem;display:flex}.birth-date{color:var(--text-muted);margin:.25rem 0;font-size:.85rem}.description{white-space:pre-wrap;margin:.5rem 0}.recipes-page{max-width:1000px;margin:0 auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.recipes-list{flex-direction:column;gap:1rem;display:flex}.recipe-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;padding:1rem;transition:box-shadow .2s}.recipe-card:hover{box-shadow:var(--shadow-md)}.card-header{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.recipe-title{color:var(--text-primary);font-size:1.1rem;font-weight:700}.recipe-description{white-space:pre-wrap;color:var(--text-secondary);margin:.5rem 0}.meta{color:var(--text-muted);border-top:1px solid var(--border);margin-top:.5rem;padding-top:.5rem;font-size:.7rem}.empty-state{text-align:center;color:var(--text-muted);padding:2rem}.modal-content.large{min-width:600px;max-width:90%}.ingredients-list{border:1px solid var(--border);background:var(--bg-primary);border-radius:.5rem;margin:.5rem 0 1rem;padding:.75rem}.ingredient-row{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.ingredient-row select,.ingredient-row input{flex:2}.ingredient-row input:first-of-type{flex:1}.ingredient-row button{flex-shrink:0;padding:.5rem}@media (width<=640px){.ingredient-row{flex-wrap:wrap}.ingredient-row select,.ingredient-row input{flex:100%}.modal-content.large{min-width:auto}}
