:root{--red: #E52420;--red-dark: #C41E1A;--red-light: #FEF2F2;--black: #0F172A;--gray-900: #1E293B;--gray-700: #334155;--gray-500: #64748B;--gray-400: #94A3B8;--gray-300: #CBD5E1;--gray-200: #E2E8F0;--gray-100: #F1F5F9;--gray-50: #F8FAFC;--white: #FFFFFF;--green: #10B981;--green-light: #ECFDF5;--yellow: #F59E0B;--yellow-light: #FFFBEB;--blue: #3B82F6;--blue-light: #EFF6FF;--orange: #F97316;--radius: 12px;--bottom-nav-h: 64px;--safe-bottom: env(safe-area-inset-bottom, 0px)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;display:flex;align-items:stretch;justify-content:space-around;background:#fff;border-top:1px solid var(--gray-200);height:var(--bottom-nav-h);padding-bottom:var(--safe-bottom);z-index:100;box-shadow:0 -2px 10px #0000000f}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;cursor:pointer;color:var(--gray-400);font-size:.65rem;font-weight:600;transition:color .15s;position:relative;padding:.4rem 0;-webkit-tap-highlight-color:transparent}.nav-tab.active{color:var(--red)}.nav-tab .nav-icon{font-size:1.3rem;line-height:1}.nav-tab .nav-label{line-height:1}.nav-tab.fab{position:relative}.nav-tab.fab .nav-icon{width:44px;height:44px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;box-shadow:0 2px 8px #e5242059;margin-top:-12px;transition:transform .15s}.nav-tab.fab:active .nav-icon{transform:scale(.92)}.nav-tab.fab .nav-label{color:var(--red)}.nav-tab .chat-badge{position:absolute;top:4px;right:calc(50% - 18px);background:var(--red);color:#fff;font-size:.55rem;font-weight:700;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 60px - var(--bottom-nav-h) - var(--safe-bottom));height:calc(100dvh - 60px - var(--bottom-nav-h) - var(--safe-bottom))}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.chat-bubble{max-width:80%;padding:.6rem .85rem;border-radius:12px;font-size:.85rem;line-height:1.4;word-break:break-word}.chat-bubble.mine{align-self:flex-end;background:var(--red);color:#fff;border-bottom-right-radius:4px}.chat-bubble.theirs{align-self:flex-start;background:var(--gray-100);color:var(--black);border-bottom-left-radius:4px}.chat-bubble .cb-time{font-size:.6rem;opacity:.7;margin-top:.2rem;text-align:right}.chat-bubble.theirs .cb-sender{font-size:.65rem;font-weight:700;color:var(--gray-500);margin-bottom:.15rem}.chat-input-bar{display:flex;gap:.5rem;padding:.75rem 1rem;background:#fff;border-top:1px solid var(--gray-200)}.chat-input-bar input{flex:1;padding:.6rem .85rem;border:1.5px solid var(--gray-200);border-radius:20px;font-family:inherit;font-size:.85rem;outline:none}.chat-input-bar input:focus{border-color:var(--red)}.chat-send-btn{width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;flex-shrink:0}.chat-send-btn:disabled{background:var(--gray-300);cursor:not-allowed}.conv-item{display:flex;gap:.75rem;padding:.85rem;border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background .15s}.conv-item:active{background:var(--gray-50)}.conv-item .conv-avatar{width:40px;height:40px;border-radius:50%;background:var(--gray-200);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0}.conv-item .conv-body{flex:1;min-width:0}.conv-item .conv-title{font-weight:600;font-size:.85rem}.conv-item .conv-preview{font-size:.75rem;color:var(--gray-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-item .conv-time{font-size:.65rem;color:var(--gray-400);flex-shrink:0}.conv-item.unread .conv-title{color:var(--black)}.conv-item.unread .conv-preview{color:var(--gray-700);font-weight:500}.typing-dot{width:8px;height:8px;border-radius:50%;background:var(--gray-400);display:inline-block;animation:typingBounce 1.2s infinite ease-in-out}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--gray-100);color:var(--black);-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain}.portal-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;max-width:520px;margin:0 auto;background:var(--gray-100)}.portal-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(135deg,var(--gray-900),#334155);color:#fff;flex-shrink:0}.portal-header .logo{display:flex;align-items:center;gap:.5rem}.portal-header .logo-text{font-size:.95rem;font-weight:700}.portal-header .logo-text span{color:var(--red)}.portal-header .obj-info{font-size:.7rem;opacity:.7}.portal-header .header-right{display:flex;align-items:center;gap:.75rem}.portal-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1rem;padding-bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 1rem)}.card{background:#fff;border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;box-shadow:0 1px 3px #00000014}.card h3{font-size:.85rem;font-weight:700;margin-bottom:.75rem;color:var(--gray-600);text-transform:uppercase;letter-spacing:.03em;display:flex;align-items:center;gap:.5rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.8rem;font-weight:600;color:var(--gray-600);margin-bottom:.35rem}.form-input{width:100%;padding:.7rem .85rem;border:1.5px solid var(--gray-200);border-radius:8px;font-size:.9rem;font-family:inherit;transition:border-color .2s;background:#fff}.form-input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px #e524201a}textarea.form-input{resize:vertical;min-height:80px}.btn{padding:.75rem 1.5rem;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;border:none;display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{width:100%;background:var(--red);color:#fff}.btn-primary:hover{background:var(--red-dark);transform:translateY(-1px)}.btn-primary:disabled{background:var(--gray-400);cursor:not-allowed;transform:none}.btn-green{background:var(--green);color:#fff;padding:.5rem 1rem;font-size:.8rem}.btn-green:hover{background:#059669}.btn-outline{background:#fff;color:var(--gray-600);border:1.5px solid var(--gray-200);padding:.5rem 1rem;font-size:.8rem}.btn-outline:hover{border-color:var(--red);color:var(--red)}.btn-red-outline{background:#fff;color:var(--red);border:1.5px solid var(--red);padding:.5rem 1rem;font-size:.8rem}.btn-sm{padding:.45rem .9rem;font-size:.8rem}.badge{display:inline-block;padding:.2rem .6rem;border-radius:20px;font-size:.7rem;font-weight:600}.badge-red{background:var(--red-light);color:var(--red)}.badge-green{background:var(--green-light);color:var(--green)}.badge-yellow{background:var(--yellow-light);color:var(--yellow)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-gray{background:var(--gray-100);color:var(--gray-500)}.alert{padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.alert-error{background:var(--red-light);color:var(--red)}.alert-success{background:var(--green-light);color:var(--green)}.ticket-item{padding:1rem;border:1px solid var(--gray-200);border-radius:8px;margin-bottom:.75rem;transition:border-color .2s;cursor:pointer;background:#fff}.ticket-item:hover{border-color:var(--blue)}.ticket-item .ticket-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.4rem}.ticket-item .ticket-nr{font-weight:700;font-size:.85rem;color:var(--blue)}.ticket-item .ticket-title{font-weight:600;font-size:.9rem;margin-bottom:.25rem}.ticket-item .ticket-meta{font-size:.75rem;color:var(--gray-400)}.doc-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--gray-100)}.doc-item:last-child{border-bottom:none}.doc-item .doc-name{font-weight:600;font-size:.85rem}.doc-item .doc-meta{font-size:.75rem;color:var(--gray-400);margin-top:.15rem}.appointment-card{padding:.75rem;background:var(--yellow-light);border-radius:8px;margin-top:.5rem;font-size:.8rem}.appointment-card .appt-date{font-weight:700;margin-bottom:.25rem}.appointment-card .appt-actions{display:flex;gap:.5rem;margin-top:.5rem}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:.65rem 0;border-bottom:1px solid var(--gray-100)}.toggle-row:last-child{border-bottom:none}.toggle-label{font-size:.85rem;font-weight:500}.toggle{position:relative;width:44px;height:24px;cursor:pointer;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle .slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--gray-300);border-radius:12px;transition:.2s}.toggle .slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.toggle input:checked+.slider{background:var(--green)}.toggle input:checked+.slider:before{transform:translate(20px)}.bell-wrap{position:relative;cursor:pointer;display:flex;align-items:center}.bell-icon{font-size:1.2rem;line-height:1}.bell-badge{position:absolute;top:-6px;right:-8px;background:var(--red);color:#fff;font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.stat-card{background:#fff;border-radius:var(--radius);padding:1rem;box-shadow:0 1px 3px #00000014;cursor:pointer;transition:transform .15s}.stat-card:active{transform:scale(.97)}.stat-label{font-size:.65rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.5rem;font-weight:700;margin-top:.15rem}.quick-actions{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.25rem}.quick-action{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.75rem;border-radius:var(--radius);background:#fff;box-shadow:0 1px 3px #00000014;min-width:80px;cursor:pointer;font-size:.7rem;font-weight:600;color:var(--gray-700);transition:transform .15s;flex-shrink:0}.quick-action:active{transform:scale(.95)}.quick-action .qa-icon{font-size:1.3rem}.priority-group{display:flex;gap:.5rem}.priority-btn{flex:1;padding:.6rem;border:1.5px solid var(--gray-200);border-radius:8px;background:#fff;font-size:.8rem;font-weight:600;cursor:pointer;text-align:center;transition:all .2s}.priority-btn.selected{border-color:var(--red);background:var(--red-light);color:var(--red)}.photo-upload{border:2px dashed var(--gray-200);border-radius:8px;padding:1.5rem;text-align:center;cursor:pointer;transition:border-color .2s}.photo-upload:hover{border-color:var(--red)}.photo-upload .icon{font-size:1.5rem;margin-bottom:.25rem}.photo-upload .text{font-size:.8rem;color:var(--gray-400)}.empty{text-align:center;padding:2rem 1rem;color:var(--gray-400);font-size:.85rem}.spinner{display:inline-block;width:28px;height:28px;border:3px solid var(--gray-200);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading{text-align:center;padding:3rem}.link{color:var(--blue);cursor:pointer;text-decoration:underline;font-size:.8rem;background:none;border:none;font-family:inherit}.link:hover{color:var(--red)}.tabs{display:flex;gap:0;margin-bottom:1rem;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 1px 3px #00000014}.tab{flex:1;padding:.7rem;text-align:center;font-size:.78rem;font-weight:600;color:var(--gray-400);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab.active{color:var(--red);border-bottom-color:var(--red);background:var(--red-light)}.section-title{font-size:.8rem;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--gray-900),var(--black));padding:1rem}.login-card{background:var(--white);border-radius:16px;padding:2rem;width:100%;max-width:400px;box-shadow:0 25px 60px #0000004d}.login-logo{text-align:center;margin-bottom:1.5rem}.login-logo h1{font-size:1.3rem;font-weight:700}.login-logo h1 span{color:var(--red)}.login-logo p{color:var(--gray-500);font-size:.8rem;margin-top:.25rem}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;opacity:0;transition:opacity .2s;pointer-events:none}.drawer-overlay.open{opacity:1;pointer-events:auto}.drawer{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:520px;background:#fff;border-radius:16px 16px 0 0;z-index:201;transform:translate(-50%) translateY(100%);transition:transform .3s ease;padding-bottom:var(--safe-bottom)}.drawer-overlay.open .drawer{transform:translate(-50%) translateY(0)}.drawer-handle{width:40px;height:4px;background:var(--gray-300);border-radius:2px;margin:.75rem auto}.drawer-items{padding:.5rem 1rem 1.5rem}.drawer-item{display:flex;align-items:center;gap:.75rem;padding:.85rem .5rem;border-bottom:1px solid var(--gray-100);cursor:pointer;font-size:.9rem;font-weight:500;color:var(--gray-700)}.drawer-item:last-child{border-bottom:none}.drawer-item:active{background:var(--gray-50)}.drawer-item .di-icon{font-size:1.1rem;width:1.5rem;text-align:center}.timeline-item{border-left:2px solid var(--gray-200);margin-left:.5rem;padding:.75rem 0 .75rem 1rem;position:relative}.timeline-item:before{content:"";position:absolute;left:-5px;top:1rem;width:8px;height:8px;border-radius:50%;background:var(--gray-300)}.timeline-item.status-change:before{background:var(--blue)}.timeline-item .tl-meta{font-size:.7rem;color:var(--gray-400);margin-bottom:.2rem}.timeline-item .tl-text{font-size:.85rem}.meter-tabs{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.25rem}.meter-tab{padding:.5rem 1rem;border-radius:20px;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;background:#fff;color:var(--gray-500);border:1.5px solid var(--gray-200);transition:all .2s}.meter-tab.active{background:var(--red);color:#fff;border-color:var(--red)}.nk-card{display:flex;justify-content:space-between;align-items:center}.nk-card .nk-amount{font-size:1.5rem;font-weight:700}.nk-card .nk-amount.positive{color:var(--green)}.nk-card .nk-amount.negative{color:var(--red)}
