:root{--primary:#2f7f33;--primary-light:#3e9e43;--background:#f3f3f3;--white:#fff;--text:#333;--text-secondary:#666;--border:#ddd;--error:#e25045;--warning:#eca83a;--warning-dark:#b87d1f;--grey:#bbb;--dark-grey:#999;--color-background-primary:#fff;--color-background-secondary:#f9fafb;--color-background-success:#f0fdf4;--color-background-warning:#fffbeb;--color-background-danger:#fef2f2;--color-text-primary:#111827;--color-text-secondary:#9ca3af;--color-text-success:#15803d;--color-text-warning:#d97706;--color-text-danger:#dc2626;--color-border-tertiary:#f3f4f6;--color-border-secondary:#e5e7eb;--color-border-success:#86efac;--color-border-warning:#fde68a;--color-border-danger:#fca5a5;--border-radius-md:8px;--border-radius-lg:12px;--sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;font:16px/145% var(--sans);color:var(--text);background:var(--background);box-sizing:border-box;margin:0;padding:0}*{box-sizing:border-box}body{font-family:var(--sans);margin:0;padding:0}#root{min-height:100vh}button{font-family:var(--sans);cursor:pointer;border:none;outline:none}input,textarea,select{font-family:var(--sans)}*{font-family:Inter,Plus Jakarta Sans,sans-serif}.app-container{background:#f5f5f5 radial-gradient(circle at 1px 1px,#0000000d 1px,#0000 0) 0 0/20px 20px;flex-direction:column;min-height:100vh;display:flex}.top-nav{z-index:50;background:#fff;border-bottom:1px solid #ffffff1a;height:64px;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #00000026}.top-nav-content{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:12px 24px;display:flex}.hamburger-menu{cursor:pointer;color:var(--primary);background:0 0;border:none;padding:8px;transition:color .2s;display:none}.hamburger-menu:hover{color:var(--primary-light)}.mobile-menu-overlay{z-index:49;background:#00000080;animation:.2s fadeIn;display:none;position:fixed;inset:56px 0 0}@media (width>=641px){.mobile-menu-overlay{top:64px}}.mobile-menu{background:#fff;flex-direction:column;gap:8px;width:280px;height:calc(100vh - 56px);padding:16px;animation:.2s slideIn;display:flex;position:fixed;top:56px;right:0;overflow-y:auto;box-shadow:-4px 0 16px #00000026}@media (width>=641px){.mobile-menu{height:calc(100vh - 64px);top:64px}}.mobile-menu-item{cursor:pointer;color:var(--primary);background:#fff;border:none;border-radius:8px;align-items:center;gap:12px;padding:14px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000001a}.mobile-menu-item:hover{background:var(--primary);color:#fff;box-shadow:0 2px 6px #00000026}.mobile-menu-item:hover .mobile-menu-icon,.mobile-menu-item.active .mobile-menu-icon{color:#fff}.mobile-menu-item:hover .mobile-menu-badge,.mobile-menu-item.active .mobile-menu-badge{color:var(--primary);background:#fff}.mobile-menu-item.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #0003}.mobile-menu-icon{color:var(--primary)}.mobile-menu-label{text-align:left;flex:1}.mobile-menu-badge{background:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:28px;height:20px;padding:0;font-size:11px;font-weight:600;line-height:20px;display:inline-flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.brand{align-items:center;gap:8px;display:flex}.brand-name,.brand-copyright{color:var(--primary);font-family:Righteous,sans-serif;font-size:24px}.nav-menu{gap:15px;display:flex}.nav-item{cursor:pointer;color:var(--primary);background:#fff;border:none;border-radius:8px;align-items:center;gap:6px;height:36px;min-height:36px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000001a}.nav-item:hover{background:var(--primary);color:#fff;box-shadow:0 2px 6px #00000026}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{color:#fff}.nav-item:hover .nav-badge,.nav-item.active .nav-badge{color:var(--primary);background:#fff}.nav-item.active{background:var(--primary);color:#fff;box-shadow:0 2px 8px #0003}.nav-label{text-transform:uppercase;letter-spacing:.5px;font-size:13px}.nav-icon{color:var(--primary)}.task-icon{color:var(--primary);margin:0 5px}.nav-badge{background:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:28px;height:20px;margin-left:4px;padding:0;font-size:11px;font-weight:600;line-height:20px;display:inline-flex;overflow:hidden}.nav-badge-hidden{display:none}.nav-badge-spacer{width:28px;height:20px;margin-left:4px;display:inline-block}.content{flex:1;padding:65px 16px 16px;overflow-y:auto}.content-wrapper{max-width:1200px;margin:0 auto}.tab-bar{justify-content:space-around;padding:8px 0;display:flex}.tab-button{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;padding:8px 16px;transition:all .2s;display:flex}.tab-button.active{color:var(--primary)}.tab-label{margin-top:4px;font-size:11px;font-weight:500}.tab-button.active .tab-label{color:var(--primary);font-weight:600}.loading-container{background:var(--background);justify-content:center;align-items:center;min-height:100vh;display:flex}.loading-spinner{color:var(--primary);font-size:16px}.placeholder{min-height:50vh;color:var(--text-secondary);justify-content:center;align-items:center;font-size:16px;display:flex}.login-container{background:#f5f5f5 radial-gradient(circle at 1px 1px,#0000000d 1px,#0000 0) 0 0/20px 20px;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-content{background:var(--white);border-radius:20px;width:100%;max-width:400px;padding:40px;box-shadow:0 10px 40px #0000001a}.login-logo{border-radius:20px;width:120px;height:120px;margin:0 auto 20px;display:block}.login-title{text-align:center;color:#222;text-transform:uppercase;margin:0 0 8px;font-family:Righteous,sans-serif;font-size:36px;font-weight:900}.login-subtitle{text-align:center;color:var(--text-secondary);margin:20px 0 40px;font-size:16px}.input-container{margin-bottom:30px}.login-input{border:1px solid var(--border);border-radius:10px;width:100%;margin-bottom:15px;padding:15px;font-size:16px;transition:border-color .2s}.login-input:focus{border-color:var(--primary);outline:none}.password-container{margin-bottom:15px;position:relative}.password-input{padding-right:50px}.eye-icon{cursor:pointer;background:0 0;border:none;padding:5px;position:absolute;top:43%;right:15px;transform:translateY(-50%)}.error-message{color:var(--error);text-align:center;margin-bottom:15px;font-size:14px}.login-button{background:var(--primary);width:100%;color:var(--white);cursor:pointer;border:none;border-radius:10px;padding:15px;font-size:18px;font-weight:700;transition:background .2s}.login-button:hover{background:#1b5e20}.login-button.disabled{cursor:not-allowed;background:#ccc}.search-wrapper{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #fff9;border-radius:10px;align-items:center;max-width:400px;margin:15px 5px 10px;padding:0 12px;transition:all .2s;display:flex;background:#f0f0f080!important}.search-icon{margin-right:6px}.search-input{background:0 0;border:none;outline:none;flex:1;padding:5px 10px;font-size:16px}.search-wrapper:focus-within{border-color:#228b2280;box-shadow:0 0 0 3px #228b221a}.clear-button{cursor:pointer;background:0 0;border:none;margin-left:6px;padding:5px}.pharmacies-list{padding:0}.pharmacies-table-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff8c;border:1px solid #fff6;border-radius:16px;margin-top:15px;padding:24px;position:relative;overflow:hidden;box-shadow:0 8px 32px #00000014}.loading-overlay{z-index:10;background:#ffffffb3;border-radius:12px;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.loading-spinner-overlay{border:4px solid #f3f3f3;border-top-color:#2e7d32;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pharmacies-table{border-collapse:collapse;width:100%;font-size:13px}.pharmacies-table thead{z-index:10;background:#fff;position:sticky;top:0;box-shadow:0 2px 4px #0000000d}.table-header{color:#5a6a5a;text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid #00000014;padding:12px 16px;font-size:.75rem;font-weight:600}.table-header-right{text-align:right}.table-header-center{text-align:center}.table-row{cursor:pointer;transition:background-color .15s}.table-row:hover{background-color:#8b8b8b0f;transition:background-color .15s}.table-cell{border-bottom:1px solid #f0f0f0;padding:12px 16px 8px}.table-cell-right{text-align:right}.table-cell-center{text-align:center}.table-cell-mono{font-variant-numeric:tabular-nums;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,Droid Sans Mono,Source Code Pro,monospace}.pharmacy-name{color:#1a1a1a;font-weight:600;font-size:16px!important}.pharmacy-address{color:#999!important;font-size:12px!important}.maintenance-days{font-weight:500}.task-badge{text-align:center;border-radius:12px;min-width:24px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.task-badge-active{color:#cc8028;background:#f8af421f}.task-badge-empty{color:#999;background:#f0f0f0}.expiry-text{font-size:12px;font-weight:500}.expiry-empty{color:#999}.quick-maintenance-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:6px;transition:all .3s;display:inline-flex;position:relative}.quick-maintenance-btn:before{content:"";z-index:-1;background-color:#228b221f;border-radius:50%;width:100%;height:100%;transition:transform .3s;position:absolute;transform:scale(0)}.quick-maintenance-btn:hover:before{transform:scale(1.5)}.quick-maintenance-btn:hover svg{color:#1a4a2e}.badge{background:#e5f5dc;border-radius:12px;padding:4px 10px}.badge-text{color:#50ac2c;font-size:12px;font-weight:700}.empty-message{text-align:center;color:var(--grey);margin-top:40px;font-size:14px}.tasks-container,.pharmacies-container,.pharmacy-container,.agent-container{background:var(--background);min-height:90vh;padding:15px 10px}.tasks-list-container{position:relative}.filter-wrapper{background:#fff;border-radius:12px;grid-template-columns:2fr 3fr;align-items:center;gap:10px;margin-bottom:15px;padding:10px;display:grid;box-shadow:0 0 5px #1e1e1e1a}.filter-wrapper .search-wrapper{max-width:none;margin:0}.state-wrapper{gap:10px;display:flex}.filter-button{color:var(--text-secondary);cursor:pointer;background:#f7f7f7;border:1px solid #e0e0e0;border-radius:6px;flex:1;margin:0 2px;padding:8px 12px;font-size:12px;font-weight:600;transition:background .2s;box-shadow:0 1px 2px #0000000d}.filter-button.active{background:var(--primary);color:var(--white);box-shadow:0 2px 4px #0000001a}.tasks-list{padding:5px 0}.task-card{background:var(--white);cursor:pointer;border-radius:12px;align-items:center;margin-bottom:10px;padding:8px 12px;transition:box-shadow .2s;display:flex;box-shadow:0 2px 4px #0000001a}.task-card-done{opacity:.8;background:#f0f7f0}.task-card:hover{box-shadow:0 4px 8px #00000026}.task-left{justify-content:center;align-items:center;margin-right:12px;display:flex}.age-indicator{border-radius:50%;width:22px;height:22px}.task-middle{flex:1}.task-name{color:#111;align-items:center;margin-bottom:4px;font-size:14px;font-weight:700;display:flex}.task-address{color:var(--text-secondary);margin-bottom:2px;font-size:12px}.task-creator{color:#999;font-size:10px;font-style:italic}.task-right{align-items:center;gap:8px;display:flex}.task-actions{align-items:center;gap:6px;display:flex}.task-action-btn{cursor:pointer;background:#2e7d321a;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;font-size:11px;font-weight:500;transition:all .2s;display:flex}.task-action-btn:hover{background:#2e7d3233;transform:scale(1.05)}.task-action-label{color:#666}.delete-btn{background:#e250451a}.delete-btn:hover{background:#e2504533}.details-btn{background:#9999991a}.details-btn:hover{background:#9993}.newtask-wrapper{background:var(--background);min-height:100vh;padding:16px}.action-row{gap:10px;margin-top:24px;display:flex}.action-button{color:var(--white);cursor:pointer;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:14px;font-size:16px;font-weight:700;transition:all .3s;display:flex}.action-done{background:var(--primary)}.action-reopen{background:#ff9800}.action-delete,.modal-btn-delete{background:#e25045}.device-block{background:var(--white);border-radius:10px;margin-bottom:10px;padding:12px;box-shadow:0 2px 8px #0000000f}.device-header{align-items:center;gap:8px;margin-bottom:8px;display:flex}.device-badge{background:#2e7d3221;border-radius:6px;padding:4px 8px}.device-badge-text{color:var(--primary);font-size:11px;font-weight:700}.device-name{color:#111;flex:1;font-size:14px;font-weight:700}.add-component-btn{cursor:pointer;background:#2e7d3214;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;transition:background .2s;display:flex}.add-component-btn:hover{background:#2e7d3226}.add-component-text{color:var(--primary);font-size:11px;font-weight:700}.history-btn{cursor:pointer;background:0 0;border:none;padding:4px}.remove-battery-btn{cursor:pointer;border:none;border-radius:50%;padding:4px 6px}.remove-battery-btn svg{position:relative;top:1px}.component-row{border-top:1px solid #f0f0f0;justify-content:space-between;align-items:flex-start;padding:8px 0;display:flex}.component-left{align-items:top;flex:1;gap:8px;display:flex}.component-info{flex:1}.comp-name{color:#333;font-size:13px;font-weight:500}.comp-sub{color:#888;margin-top:2px;font-size:11px}.comp-actions{gap:6px;display:flex}.comp-action-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:6px;transition:background .2s}.comp-action-btn:hover{background:#0000000d}.retired-section{background:#f8f8f8;border-radius:8px;margin-top:8px;padding:10px}.retired-title{color:#aaa;margin-bottom:6px;font-size:12px;font-weight:700}.empty-small{color:#bbb;padding:8px 0;font-size:12px}.history-list{background:#f8f8f8;border-radius:8px;max-height:120px;margin-bottom:12px;padding:8px;overflow-y:auto}.history-item{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:6px 0;display:flex}.history-item:last-child{border-bottom:none}.history-date{color:#666;font-size:12px}.history-voltage{font-size:12px;font-weight:700}.battery-type-row{gap:8px;margin-bottom:12px;display:flex}.battery-type-btn{cursor:pointer;background:#f8f8f8;border:1px solid #ddd;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:12px 8px;transition:all .2s;display:flex}.battery-type-btn-active{background:var(--primary);border-color:var(--primary)}.battery-type-text{color:#555;text-align:center;font-size:11px;line-height:1.2}.battery-type-btn-active .battery-type-text{color:#fff;font-weight:700}.newtask-container{max-width:600px;margin:0 auto}.form-label{color:#333;margin-top:16px;margin-bottom:6px;font-size:14px;font-weight:700;display:block}.required{color:red}.optional{color:var(--grey);font-size:12px;font-weight:400}.picker-wrapper{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff80;border:1px solid #fff9;border-radius:8px;overflow:hidden}.form-select{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:#ffffff80;border:1px solid #fff9;border-radius:8px;width:100%;padding:12px;font-size:14px}.form-input{color:#111;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff80;border:1px solid #fff9;border-radius:8px;width:100%;padding:12px;font-size:14px}.form-input:focus{border-color:#228b2280;outline:none;box-shadow:0 0 0 3px #228b221a}.char-count{color:var(--grey);text-align:right;margin-top:4px;font-size:11px}.form-textarea{color:#111;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);resize:vertical;width:100%;font-size:14px;font-family:var(--sans);background:#ffffff80;border:1px solid #fff9;border-radius:8px;padding:12px}.form-textarea:focus{border-color:#228b2280;outline:none;box-shadow:0 0 0 3px #228b221a}.date-row{align-items:center;gap:8px;display:flex}.form-date{color:#111;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;background:#ffffff80;border:1px solid #fff9;border-radius:8px;flex:1;padding:12px;font-size:14px}.date-clear{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;color:#666;background:#ffffff80;border:1px solid #fff9;border-radius:8px;padding:12px;font-size:14px;transition:all .2s}.date-clear:hover{background:#ffffffb3}.form-button svg{margin-right:10px;position:relative;top:5px}.form-button{background:var(--primary);width:100%;color:var(--white);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;border-radius:10px;margin-top:30px;padding:16px;font-size:16px;font-weight:500;transition:all .2s}.form-button:hover{background:var(--primary-light);transform:translateY(-1px);box-shadow:0 4px 12px #16a34a4d}.form-button.disabled{opacity:.6;cursor:not-allowed}.toast{color:var(--white);z-index:9999999;white-space:nowrap;background:#333;border-radius:25px;padding:12px 20px;font-size:14px;transition:all .7s;position:fixed;top:90px;left:50%;transform:translate(-50%)}.profil-container{background:#f5f5f5;min-height:100vh;padding:16px}.profile-card{background:var(--white);border-radius:16px;padding:24px;box-shadow:0 2px 10px #0000001a}.image-container{justify-content:center;margin-bottom:24px;display:flex}.profile-image{border:3px solid var(--primary);object-fit:cover;border-radius:60px;width:120px;height:120px;animation:.3s ease-in fadeIn}.image-loading{opacity:0}.default-avatar{border:3px solid var(--primary);background:#f0f0f0;border-radius:60px;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.info-container{text-align:center;margin-bottom:32px}.nick-text{color:#333;margin-bottom:8px;font-size:24px;font-weight:700}.fullname-text{color:var(--text-secondary);margin-bottom:4px;font-size:18px}.username-text{color:var(--grey);font-size:14px;font-style:italic}.password-button{cursor:pointer;background:#f8f9fa;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:16px;transition:background .2s;display:flex}.password-button:hover{background:#e9ecef}.password-button-text{color:var(--primary);text-align:center;flex:1;font-size:16px;font-weight:600}.password-form{border-top:1px solid #eee;max-width:400px;margin-top:24px;margin-left:auto;margin-right:auto;padding-top:24px}.form-title{color:#333;text-align:center;margin-bottom:20px;font-size:18px;font-weight:700}.input-group{margin-bottom:16px}.input-label{color:#333;margin-bottom:8px;font-size:14px;font-weight:600;display:block}.password-input-container{align-items:center;display:flex;position:relative}.password-input-field{flex:1;padding-right:50px}.password-toggle{cursor:pointer;background:0 0;border:none;padding:5px;position:absolute;right:15px}.button-group{gap:12px;margin-top:24px;display:flex}.button{cursor:pointer;border:none;border-radius:8px;flex:1;padding:14px;font-size:16px;font-weight:600}.cancel-button{border:1px solid var(--border);color:var(--text-secondary);background:#f8f9fa}.save-button{background:var(--primary);color:var(--white)}.save-button.disabled{opacity:.6;cursor:not-allowed}.centered{justify-content:center;align-items:center;min-height:100vh;display:flex}.error-text{color:var(--error);text-align:center;font-size:16px}.pharmacy-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-radius:16px;min-height:100vh;padding:14px;box-shadow:0 4px 20px #0000000d}.pharmacy-container{padding-bottom:20px}.pharmacy-header{background:var(--white);border-radius:12px;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:0;padding:14px;display:flex;box-shadow:0 2px 4px #0000001a}.pharmacy-header-main{flex:1;align-items:center;gap:12px;min-width:200px;display:flex}.pharmacy-header-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.pharmacy-header-stats{flex-wrap:wrap;gap:12px;display:flex}.pharmacy-stat{background:#f5f5f5;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:12px;display:flex}.pharmacy-stat .stat-value{color:#333;font-weight:600}.pharmacy-stat .stat-label{color:#666;font-size:11px}.pharmacy-section-header{background:0 0;justify-content:space-between;align-items:center;margin-bottom:12px;padding:0;display:flex}.pharmacy-section-title{color:#333;align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.pharmacy-section-title svg{color:#2f7f33}.pharmacy-section-info{color:#666;margin-left:4px;font-size:13px;font-weight:400}.pharmacy-section-action{color:#fff;cursor:pointer;background:#2f7f33;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.pharmacy-section-action:hover{background:#2a722e;transform:translateY(-1px)}.pharmacy-section-action:disabled{opacity:.5;cursor:not-allowed;transform:none}.pharmacy-section-card{background:#fff;border-radius:12px;min-height:80px;padding:16px;box-shadow:0 2px 8px #00000012}.pharmacy-section-empty{color:#666;text-align:center;justify-content:center;align-items:center;padding:40px 20px;font-size:14px;display:flex}.pharmacy-section-empty.success{color:#2f7f33;background:#e8f5e9;border-radius:8px}.pharmacy-section-empty.warning{color:#f57c00;background:#fff3e0;border-radius:8px}.pharmacy-section-empty.error{color:#e53935;background:#ffebee;border-radius:8px}.pharmacy-section-empty.info{color:#5e5e5e;background:#eee;border-radius:8px}.pharmacy-section{margin-bottom:20px}.back-button{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:background .2s;display:flex}.back-button:hover{background:#2e7d321a}.kpi-bar{cursor:default;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0;display:grid}.kpi-card{background:var(--white);border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:15px 5px 10px;transition:all .2s;display:flex;box-shadow:0 1px 3px #00000014}.kpi-value{color:#2e7d32;font-size:16px;font-weight:700}.kpi-label{font-size:12px}.agent-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-bottom:2px solid #2e7d321a;border-radius:16px;flex-direction:column;align-items:center;margin-bottom:20px;padding:14px;display:flex;box-shadow:0 4px 20px #0000000d}.agent-title{color:#333;padding-bottom:7px;font-family:Inter,cursive;font-size:24px;font-weight:700;margin:7px!important}.agent-subtitle{color:#666;padding-bottom:7px;font-family:Inter,cursive;font-size:14px;margin:4px!important}.agent-content{flex-direction:column;gap:20px;display:flex}.agent-quick-actions{gap:12px;margin-bottom:8px;display:flex}.agent-quick-button{background:var(--white);cursor:pointer;color:var(--primary);border:2px solid #2e7d3233;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 4px #00000014}.agent-quick-button:hover:not(:disabled){background:var(--primary);color:var(--white);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 8px #2e7d3233}.agent-quick-button:disabled{opacity:.5;cursor:not-allowed}.agent-quick-button svg{flex-shrink:0}.agent-chat{background:var(--white);border-radius:12px;min-height:100px;max-height:300px;padding:20px;transition:max-height .3s;overflow-y:auto;box-shadow:0 2px 8px #0000000f}.agent-chat.with-response{max-height:750px}.agent-welcome{color:#666;text-align:center;justify-content:center;align-items:center;height:100%;font-size:14px;display:flex}.agent-welcome p{margin:0}.agent-response{animation:.3s ease-in fadeIn}.response-bubble{color:#333;white-space:pre-wrap;word-wrap:break-word;border-radius:12px;line-height:1.6}.agent-loading{color:#666;align-items:center;gap:12px;font-size:14px;display:flex}.agent-loading .spinner{animation:1s linear infinite spin}.agent-input-area{flex-direction:column;gap:12px;display:flex}.agent-input-grid{grid-template-columns:20% 80%;gap:12px;display:grid}.agent-input-left{align-items:flex-start;display:flex}.agent-input-right{flex-direction:column;gap:8px;display:flex}.agent-monthly-button{background:var(--primary);cursor:pointer;color:var(--white);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:100px;padding:14px 12px;font-size:14px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 6px #2e7d3233}.agent-monthly-button:hover:not(:disabled){background:var(--primary-light);transform:translateY(-2px);box-shadow:0 4px 10px #2e7d324d}.agent-monthly-button:disabled{opacity:.5;cursor:not-allowed}.agent-textarea{color:#333;background:var(--white);resize:vertical;border:2px solid #2e7d3233;border-radius:12px;flex:1;padding:14px;font-family:Inter,Plus Jakarta Sans,sans-serif;font-size:14px;transition:border-color .2s}.agent-textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2e7d321a}.agent-send-button{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;justify-content:center;align-self:flex-end;align-items:center;width:50px;height:50px;transition:all .2s;display:flex;box-shadow:0 2px 6px #2e7d3233}.agent-send-button:hover:not(:disabled){background:var(--primary-light);transform:translateY(-2px);box-shadow:0 4px 10px #2e7d324d}.agent-send-button:disabled{cursor:not-allowed;background:#e5e7eb;transform:none}.agent-send-button:disabled svg{color:#9ca3af}.kpi-sublabel{color:#888;text-align:center;margin-top:1px;font-size:10px;font-weight:400}.dashboard-grid{grid-template-columns:1fr 1fr;gap:40px;margin-top:16px;display:grid}.dashboard-left,.dashboard-right{flex-direction:column;display:flex}.device-cards-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.device-card-dashboard{background:var(--white);cursor:pointer;border-radius:10px;padding:14px;transition:all .2s;box-shadow:0 1px 3px #00000014}.device-card-dashboard:hover{transform:translateY(-2px);box-shadow:0 2px 8px #0000001f}.device-card-header{align-items:center;gap:8px;margin-bottom:10px;display:flex}.device-badge-dashboard{color:#2e7d32;background:#2e7d321f;border-radius:6px;padding:4px 8px;font-size:10px;font-weight:700}.device-card-name{color:#111;font-size:13px;font-weight:600}.battery-status-row{align-items:center;gap:6px;margin-bottom:8px;display:flex}.battery-status-text{font-size:12px;font-weight:600}.device-component-count{color:#888;font-size:11px}.maintenance-timeline{background:var(--white);border-radius:10px;padding:14px;box-shadow:0 1px 3px #00000014}.timeline-item{gap:12px;padding-bottom:14px;display:flex;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-item:not(:last-child):before{content:"";background:#e0e0e0;width:2px;position:absolute;top:18px;bottom:0;left:6px}.timeline-dot{background:#2e7d32;border-radius:50%;flex-shrink:0;width:14px;height:14px;margin-top:3px}.timeline-content{flex:1}.timeline-date{color:#2e7d32;margin-bottom:4px;font-size:12px;font-weight:600}.timeline-description{color:#333;font-size:13px;line-height:1.4}.info-collapsible-section{background:var(--white);border-radius:10px;overflow:hidden;box-shadow:0 1px 3px #00000014}.info-collapsible-header{cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:14px;transition:background .2s;display:flex}.info-collapsible-header:hover{background:#2e7d320d}.info-collapsible-content{border-top:1px solid #f0f0f0;padding:14px}.info-text{color:#333;margin-bottom:8px;font-size:13px;line-height:1.5}.info-meta{color:#888;font-size:11px}@media (width<=768px){.kpi-bar{grid-template-columns:repeat(2,1fr)}.dashboard-grid{grid-template-columns:1fr}.device-cards-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}}@media (width<=480px){.kpi-bar{grid-template-columns:1fr}}@media (width<=640px){.top-nav{height:56px;padding:0}.top-nav-content{flex-direction:row;gap:0;height:56px;padding:8px 12px}.brand{justify-content:flex-start;width:auto}.brand-name{font-size:18px}.brand-copyright{font-size:16px}.hamburger-menu{display:block}.nav-menu{display:none}.mobile-menu-overlay{display:block}.mobile-menu{display:flex}.content{padding:70px 12px 12px}.content-wrapper{padding:0}.login-container{align-items:flex-start;padding:40px 20px}.login-content{margin-top:0;padding:20px 16px}.login-logo{width:60px;height:60px;margin-bottom:12px}.login-title{margin-bottom:4px;font-size:24px}.login-subtitle{margin:8px 0 20px;font-size:13px}.login-input{padding:12px;font-size:14px}.login-button{padding:12px;font-size:16px}.search-wrapper{margin:10px 0;padding:0 10px}.search-input{font-size:14px}.pharmacies-table-container{margin-top:10px;padding:12px}.pharmacies-table,.pharmacies-table thead{display:none}.pharmacies-table tbody,.pharmacies-table tr{width:100%;display:block}.table-row{background:var(--white);cursor:pointer;border-radius:12px;margin-bottom:12px;padding:14px;display:block;box-shadow:0 2px 8px #00000014}.table-cell{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.table-cell:last-child{border-bottom:none}.table-cell:before{content:attr(data-label);color:#666;flex-shrink:0;margin-right:12px;font-size:11px;font-weight:600}.table-cell-right:before,.table-cell-center:before{display:none}.table-cell-right,.table-cell-center{justify-content:flex-end}.pharmacy-name{color:#1a1a1a;font-weight:600;font-size:15px!important}.pharmacy-address{color:#666;font-size:12px!important}.maintenance-days{font-size:13px;font-weight:600}.task-badge{padding:6px 12px;font-size:12px}.expiry-text{font-size:12px}.quick-maintenance-btn{padding:8px}.tasks-container,.pharmacies-container,.pharmacy-container,.agent-container{padding:10px 8px}.filter-wrapper{grid-template-columns:1fr;gap:8px;padding:8px}.state-wrapper{flex-wrap:wrap}.filter-button{padding:8px 10px;font-size:11px}.task-card{margin-bottom:8px;padding:10px}.task-name{font-size:13px}.task-address{font-size:11px}.task-action-btn{padding:5px 8px;font-size:10px}.newtask-wrapper{padding:12px}.newtask-container{max-width:100%}.form-label{font-size:13px}.form-input,.form-select,.form-textarea,.form-date{padding:10px;font-size:13px}.form-button{padding:14px;font-size:15px}.action-row{flex-direction:column;gap:8px}.action-button{padding:12px;font-size:14px}.device-block{padding:10px}.device-name{font-size:13px}.comp-name{font-size:12px}.comp-sub{font-size:10px}.profil-container{padding:12px}.profile-card{padding:16px}.profile-image,.default-avatar{width:80px;height:80px}.nick-text{font-size:20px}.fullname-text{font-size:16px}.password-form{max-width:100%}.pharmacy-wrapper{border-radius:12px;padding:10px}.pharmacy-header{flex-direction:column;align-items:flex-start;padding:12px}.pharmacy-header-main{width:100%}.pharmacy-header-stats{justify-content:flex-start;width:100%}.pharmacy-stat{padding:6px 10px;font-size:11px}.pharmacy-section-title{font-size:14px}.pharmacy-section-action{padding:6px 12px;font-size:12px}.kpi-bar{grid-template-columns:repeat(2,1fr);gap:8px;margin:12px 0}.kpi-card{padding:8px}.kpi-value{font-size:14px}.kpi-label{font-size:11px}.agent-header{padding:12px}.agent-title{font-size:20px}.agent-subtitle{font-size:13px}.agent-quick-actions{flex-direction:column;gap:8px}.agent-quick-button{padding:12px;font-size:13px}.agent-chat{min-height:80px;max-height:250px;padding:14px}.agent-chat.with-response{max-height:400px}.agent-input-grid{grid-template-columns:1fr;gap:8px}.agent-monthly-button{min-height:80px;padding:12px;font-size:13px}.agent-textarea{padding:12px;font-size:13px}.agent-send-button{width:44px;height:44px}.dashboard-grid{grid-template-columns:1fr;gap:20px}.device-cards-grid{grid-template-columns:1fr;gap:10px}.device-card-dashboard,.maintenance-timeline{padding:12px}.timeline-date{font-size:11px}.timeline-description{font-size:12px}.info-collapsible-header,.info-collapsible-content{padding:12px}.info-text{font-size:12px}.card{margin-bottom:10px;padding:12px}.card-title{font-size:13px}.card-long,.card-sub{font-size:11px}.modal-overlay{padding:12px!important}.modal-box{width:100%;max-width:100%;max-height:90vh;padding:14px}.modal-body{gap:4px}.char-count{display:none}.modal-box-large{max-width:100%}.modal-title{font-size:16px}.confirm-message{font-size:14px}.confirm-button{padding:10px 18px;font-size:13px}.kcard{padding:12px}.kcard-name{font-size:14px}.kcard-task{font-size:12px}.kcard-date{font-size:11px}.kcard-creator{font-size:10px}.kcard-action-btn{padding:5px 10px;font-size:11px}.kcard-dropdown{min-width:160px;top:40px;right:12px}.kcard-dropdown-item{padding:8px 10px;font-size:12px}.ai-grid{grid-template-columns:1fr;gap:16px}.ai-card{padding:8px 10px}.ai-card-title{font-size:10px}.ai-name{font-size:11px}.ai-row-desc{font-size:10px}.ai-badge{padding:1px 5px;font-size:9px}.ai-ol li{font-size:11px}.ai-summary{padding:6px 10px}.ai-summary-text{font-size:11px}.ai-pill{padding:2px 6px;font-size:10px}.section-header{margin-top:16px;margin-bottom:10px}.section-title{font-size:14px}.toast{padding:10px 16px;font-size:13px;top:80px}.pharmacy-section{margin-bottom:16px}.pharmacy-section-card{padding:12px}.pharmacy-section-empty{padding:24px 16px;font-size:13px}}.pharmacy-header-content{flex:1}.section-header{align-items:center;gap:8px;margin-top:24px;margin-bottom:12px;display:flex}.section-title{color:#1a1a1a;letter-spacing:.5px;flex:1;font-size:16px;font-weight:700}.section-add{cursor:pointer;background:#2e7d321a;border:none;border-radius:8px;padding:8px;transition:all .3s}.section-add:hover{background:#2e7d3233;transform:scale(1.1)}.empty-text{color:var(--grey);margin-bottom:8px;margin-left:4px;font-size:13px}.card{background:var(--white);cursor:pointer;border:1px solid #0000000a;border-radius:12px;align-items:center;margin-bottom:12px;padding:16px;transition:all .3s;display:flex;box-shadow:0 2px 8px #0000000f}.card:hover{border-color:#2e7d3233;transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.card-content{flex:1}.card-title{color:#111;margin-bottom:2px;font-size:14px;font-weight:700}.card-long,.card-sub{color:#888;font-size:12px}.card-sub-right{color:#888;text-align:right;margin-bottom:8px;font-size:12px}.card-done{opacity:.6}.card-title-done{color:#aaa;text-decoration:line-through}.show-more{color:var(--primary);cursor:pointer;background:0 0;border:none;margin-bottom:8px;margin-left:4px;padding:0;font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:99999;background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-box{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffe6;border-radius:16px;width:90%;max-width:500px;max-height:90vh;padding:24px;position:relative;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-box-large{max-width:600px}.confirm-message{color:#333;margin:0 0 16px;font-size:15px;line-height:1.5}.confirm-task-details{background:#f5f5f5;border-radius:8px;margin-bottom:24px;padding:12px 16px}.confirm-task-title{color:#333;margin-bottom:4px;font-size:14px;font-weight:600}.confirm-task-subtitle{color:#666;font-size:13px}.confirm-buttons{justify-content:flex-end;gap:12px;display:flex}.confirm-button{cursor:pointer;border:none;border-radius:10px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s}.confirm-button-cancel{color:#333;background:#f5f5f5}.confirm-button-cancel:hover{background:#e5e5e5}.confirm-button-danger{color:#fff;background:#dc2626}.confirm-button-danger:hover{background:#b91c1c;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{color:#1a1a1a;margin:0;font-size:18px;font-weight:700}.modal-close{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px;transition:background-color .2s}.modal-close:hover{background-color:#0000000d}.modal-body{flex-direction:column;gap:16px;display:flex}.modal-pharmacy-info{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff6;border:1px solid #ffffff80;border-radius:8px;align-items:center;gap:8px;padding:12px;display:flex}.modal-pharmacy-label{color:#666;font-size:12px;font-weight:500}.modal-pharmacy-name{color:#1a1a1a;font-size:14px;font-weight:600}.kcard{cursor:default;background:#fff;border-left:4px solid;border-radius:12px;flex-direction:column;width:100%;margin-bottom:20px;padding:14px 14px 10px;transition:box-shadow .2s;display:flex;position:relative;box-shadow:0 2px 8px #00000012}.kcard:hover{box-shadow:0 4px 12px #0000001a}.kcard-done{opacity:.65}.kcard-badge{border-radius:12px;align-self:flex-start;margin-bottom:8px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block;color:#444!important}.kcard-badge svg{position:relative;top:2px}.kcard-name{color:#1a1a1a;margin-bottom:4px;font-size:15px;font-weight:700}.kcard-name svg{position:relative;top:-1px}.kcard-task{color:#3a3a3a;-webkit-line-clamp:2;line-clamp:2;text-overflow:ellipsis;-webkit-box-orient:vertical;margin-bottom:12px;font-size:13px;font-weight:400;line-height:1.4;display:-webkit-box;overflow:hidden}.kcard-meta{justify-content:space-between;align-items:center;margin-top:auto;display:flex}.kcard-meta-left{align-items:center;display:flex}.kcard-date{color:#888;font-size:12px}.kcard-meta-right{align-items:center;gap:8px;display:flex}.kcard-avatar{border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.kcard-creator{color:#888;font-size:11px}.kcard-more-btn{cursor:pointer;opacity:.3;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:opacity .2s;display:flex;position:absolute;top:14px;right:14px}.kcard:hover .kcard-more-btn{opacity:1}.kcard-more-btn:hover{opacity:1;background:#0000000d}.kcard-actions{border-top:1px solid #f0f0f0;gap:8px;margin-top:12px;padding-top:12px;display:flex}.kcard-action-btn{cursor:pointer;color:#666;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.kcard-action-btn:hover{background:#0000000d;transform:translateY(-1px)}.kcard-action-btn-complete:hover{background:#2f7f331a}.kcard-action-btn-restore:hover{background:#ff98001a}.kcard-action-btn-edit:hover{background:#f59e0b1a}.kcard-action-btn-delete:hover{background:#e250451a}.kcard-dropdown{z-index:100;background:#fff;border-radius:8px;min-width:180px;padding:6px;position:absolute;top:44px;right:14px;box-shadow:0 4px 16px #0000001f}.kcard-dropdown-item{cursor:pointer;color:#333;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;transition:background .15s;display:flex}.kcard-dropdown-item:hover{background:#0000000d}.kcard-dropdown-item-danger{color:#e25045}.kcard-dropdown-item-danger:hover{background:#e2504514}.kcard-preview{pointer-events:none;opacity:.8;margin-bottom:20px}.newtask-form{margin-top:20px}.edit-task-actions{gap:8px;margin-top:16px;margin-bottom:16px;display:flex}.edit-task-actions .kcard-action-btn{cursor:pointer;background:#fff;border:1px solid;border-radius:6px;flex:1;padding:10px 16px;font-size:13px;font-weight:500;transition:all .2s}.edit-task-actions .kcard-action-btn-complete{color:#4caf50;background:#e8f5e9;border-color:#4caf50}.edit-task-actions .kcard-action-btn-complete:hover{color:#fff;background:#4caf50}.edit-task-actions .kcard-action-btn-restore{color:#ff9800;background:#fff3e0;border-color:#ff9800}.edit-task-actions .kcard-action-btn-restore:hover{color:#fff;background:#ff9800}.edit-task-actions .kcard-action-btn-delete{color:#e25045;background:#ffebee;border-color:#e25045}.edit-task-actions .kcard-action-btn-delete:hover{color:#fff;background:#e25045}.edit-task-actions .kcard-action-btn:disabled{opacity:.5;cursor:not-allowed}.ai-wrap{color:var(--color-text-primary);flex-direction:column;gap:10px;padding:4px 0;font-size:13px;display:flex}:root{--color-background-primary:#fff;--color-background-secondary:#f9fafb;--color-background-success:#f0fdf4;--color-background-warning:#fffbeb;--color-background-danger:#fef2f2;--color-text-primary:#111827;--color-text-secondary:#9ca3af;--color-text-success:#15803d;--color-text-warning:#d97706;--color-text-danger:#dc2626;--color-border-tertiary:#f3f4f6;--color-border-secondary:#e5e7eb;--color-border-success:#86efac;--color-border-warning:#fde68a;--color-border-danger:#fca5a5;--border-radius-md:8px;--border-radius-lg:12px}.ai-wrap{color:var(--color-text-primary);padding:4px 0;font-size:13px}.ai-summary{border-left:3px solid var(--color-text-warning);background:var(--color-background-warning);border-radius:0 6px 6px 0;justify-content:space-between;align-items:center;gap:12px;margin-bottom:6px;padding:8px 12px;display:flex}.ai-summary-text{color:var(--color-text-primary);flex:1;font-size:12px;line-height:1.5}.ai-pills{flex-shrink:0;gap:4px;display:flex}.ai-pill{border:.5px solid;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500}.ai-pill-green{background:var(--color-background-success);color:var(--color-text-success);border-color:var(--color-border-success)}.ai-pill-gray{background:var(--color-background-secondary);color:var(--color-text-secondary);border-color:var(--color-border-secondary)}.ai-pill-red{background:var(--color-background-danger);color:var(--color-text-danger);border-color:var(--color-border-danger)}.ai-grid{grid-template-columns:1fr 1fr;gap:30px;margin-bottom:20px;display:grid}.ai-card{background:var(--color-background-primary);border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);padding:8px 12px;box-shadow:0 1px 3px #0000001a}.ai-card-title{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:.5px solid var(--color-border-tertiary);align-items:center;gap:5px;margin:0 0 6px;padding-bottom:6px;font-size:11px;font-weight:500;display:flex}.ai-card-title i{font-size:13px}.ai-row{border-bottom:.5px solid var(--color-border-tertiary);padding:4px 0}.ai-row:last-child{border-bottom:none}.ai-row-top{justify-content:space-between;align-items:center;gap:6px;display:flex}.ai-row-top-left{justify-content:flex-start!important}.ai-row-desc{color:var(--color-text-secondary);margin-top:1px;font-size:11px}.ai-name{color:var(--color-text-primary);font-size:12px;font-weight:500}.ai-badge{white-space:nowrap;border-radius:8px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:500}.ai-badge-red{background:var(--color-background-danger);color:var(--color-text-danger);border:.5px solid var(--color-border-danger)}.ai-badge-orange{background:var(--color-background-warning);color:var(--color-text-warning);border:.5px solid var(--color-border-warning)}.ai-badge-green{background:var(--color-background-success);color:var(--color-text-success);border:.5px solid var(--color-border-success)}.ai-dot-red{color:var(--color-text-danger);margin-right:4px;font-size:10px}.ai-dot-orange{color:var(--color-text-warning);margin-right:4px;font-size:10px}.ai-ol{margin:0;padding-left:14px}.ai-ol li{border-bottom:.5px solid var(--color-border-tertiary);color:var(--color-text-primary);padding:3px 0;font-size:12px;line-height:1.5}.ai-ol li:last-child{border-bottom:none}.ai-ol li strong{color:var(--color-text-primary)}
