@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;min-height:100vh;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}#root{flex-direction:column;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.custom-toast{cursor:pointer!important;background:linear-gradient(135deg,#1f2937 0%,#111827 100%)!important;border:1px solid #ffffff1a!important;border-radius:16px!important;transition:transform .2s,box-shadow .2s!important;box-shadow:0 10px 25px -5px #0000004d!important}.custom-toast .Toastify__toast-body{color:#fff!important;font-family:inherit!important}.custom-toast .Toastify__toast-body a{color:#fff!important}@keyframes shimmer{0%{background-position:-468px 0}to{background-position:468px 0}}@keyframes pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#ffffffe6;flex-direction:column;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.loading-spinner{border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.loading-text{color:#6b7280;margin-top:16px;font-size:14px;font-weight:500}.skeleton-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 3px #0000000d}.skeleton-line{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/936px 100%;border-radius:4px;height:14px;margin-bottom:12px;animation:1.5s linear infinite shimmer}.skeleton-line-short{width:60%}.skeleton-line-medium{width:80%}.skeleton-line-long{width:100%}.skeleton-title{width:70%;height:18px;margin-bottom:16px}.skeleton-badge{border-radius:14px;width:120px;height:28px;margin-bottom:16px}.skeleton-image{border-radius:8px;width:100%;height:120px;margin-top:12px}.skeleton-detail{background:#fff;border-radius:20px;max-width:900px;margin:0 auto;padding:24px}.skeleton-detail-header{width:50%;height:32px;margin-bottom:24px}.skeleton-detail-row{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;display:grid}.skeleton-detail-field{height:16px;padding:12px 0}.skeleton-detail-table{border-radius:8px;height:200px;margin-top:20px}.skeleton-pulse{background:#e5e7eb;border-radius:4px;animation:1.5s ease-in-out infinite pulse}.fade-in{animation:.3s fadeIn}.spinner-small{vertical-align:middle;border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;width:16px;height:16px;margin-right:6px;animation:.6s linear infinite spin;display:inline-block}.loading-placeholder{color:#9ca3af;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;font-size:14px;display:flex}.skeleton-detail-wrapper{background:#f5f5f5;min-height:100vh}.skeleton-detail-header-bar{background:#fff;align-items:center;gap:16px;margin-bottom:20px;padding:16px 24px;display:flex;box-shadow:0 1px 3px #0000000d}.skeleton-detail-content{max-width:900px;margin:0 auto;padding:0 20px 40px}.skeleton-detail-grid{background:#fff;border-radius:16px;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;padding:24px;display:grid;box-shadow:0 1px 3px #00000008}.skeleton-section{background:#fff;border-radius:16px;margin-bottom:20px;padding:24px;box-shadow:0 1px 3px #00000008}.skeleton-table{border:1px solid #f0f0f0;border-radius:8px;overflow:hidden}.skeleton-table-header{background:#fafafa;border-bottom:1px solid #f0f0f0;gap:16px;padding:12px 16px;display:flex}.skeleton-table-row{border-bottom:1px solid #f5f5f5;gap:16px;padding:14px 16px;display:flex}.skeleton-table-row:last-child{border-bottom:none}.skeleton-actions{gap:12px;margin-bottom:20px;padding:20px 0;display:flex}@media (width<=768px){.skeleton-detail-grid{grid-template-columns:1fr}.skeleton-detail-content{padding:0 12px 20px}.skeleton-detail-header-bar{padding:12px 16px}}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74d3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-container-width:fit-content;--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-padding:14px;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-toast-shadow:0px 4px 12px #0000001a;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-bgo:.2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0, 0, var(--toastify-z-index));width:var(--toastify-container-width);box-sizing:border-box;color:#fff;flex-direction:column;display:flex;position:fixed}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);align-items:center;left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);align-items:center;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y:0;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;word-break:break-word;flex:auto;align-items:center;margin-bottom:1rem;display:flex;position:relative}@media only screen and (width<=480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width:100%;border-radius:0;margin-bottom:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{width:100%;transform:translate3d(0, var(--y), 0) scale(var(--s));transition:transform .3s;position:absolute}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";height:calc(var(--g) * 1px);position:absolute;bottom:100%;left:0;right:0}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";z-index:-1;height:100%;position:absolute;bottom:0;left:0;right:0;transform:scaleY(3)}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{flex-shrink:0;width:22px;margin-inline-end:10px;display:flex}.Toastify--animate{animation-duration:.5s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;cursor:pointer;opacity:.7;z-index:1;background:0 0;border:none;outline:none;padding:0;transition:all .3s;position:absolute;top:6px;right:6px}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;width:14px;height:16px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{z-index:1;opacity:.7;transform-origin:0;width:100%;height:100%;position:absolute;bottom:0;left:0}.Toastify__progress-bar--animated{animation:linear forwards Toastify__trackProgress}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:100%;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius);width:100%;height:5px;position:absolute;bottom:0;left:0;overflow:hidden}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{box-sizing:border-box;border:2px solid;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);border-radius:100%;width:20px;height:20px;animation:.65s linear infinite Toastify__spin}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(3000px)}60%{opacity:1;transform:translate(-25px)}75%{transform:translate(10px)}90%{transform:translate(-5px)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px, var(--y), 0)}to{opacity:0;transform:translate3d(2000px, var(--y), 0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(-3000px)}60%{opacity:1;transform:translate(25px)}75%{transform:translate(-10px)}90%{transform:translate(5px)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px, var(--y), 0)}to{opacity:0;transform:translate3d(-2000px, var(--y), 0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(3000px)}60%{opacity:1;transform:translateY(-20px)}75%{transform:translateY(10px)}90%{transform:translateY(-5px)}to{transform:translate(0,0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(-2000px)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(-3000px)}60%{opacity:1;transform:translateY(25px)}75%{transform:translateY(-10px)}90%{transform:translateY(5px)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(2000px)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0, var(--y), 0) scale3d(.3, .3, .3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{opacity:0;animation-timing-function:ease-in;transform:perspective(400px)rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px)rotateX(-20deg)}60%{opacity:1;transform:perspective(400px)rotateX(10deg)}80%{transform:perspective(400px)rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0, var(--y), 0) perspective(400px)}30%{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, -20deg);opacity:1}to{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, 90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{visibility:visible;transform:translate(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInLeft{0%{visibility:visible;transform:translate(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInUp{0%{visibility:visible;transform:translateY(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInDown{0%{visibility:visible;transform:translateY(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(110%, var(--y), 0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(-110%, var(--y), 0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(500px)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(-500px)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-duration:.3s;animation-timing-function:ease-in}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.login-container:before{content:"";background:radial-gradient(circle,#ffffff1a 0%,#0000 50%);width:200%;height:200%;animation:20s linear infinite rotate;position:absolute}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-box{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1;background:#fffffff2;border-radius:24px;width:100%;max-width:480px;padding:48px;animation:.6s ease-out slideUp;position:relative;box-shadow:0 25px 50px -12px #00000040}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.logo-wrapper{justify-content:center;margin-bottom:32px;display:flex}.medical-icon{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:20px;justify-content:center;align-items:center;width:80px;height:80px;font-size:40px;transition:transform .3s;display:flex;transform:rotate(-5deg);box-shadow:0 10px 30px -5px #667eea80}.medical-icon:hover{transform:rotate(0)scale(1.05)}.login-box h1{color:#1a1a1a;text-align:center;letter-spacing:-.5px;margin-bottom:8px;font-size:32px;font-weight:700}.login-box h2{color:#666;text-align:center;margin-bottom:40px;font-size:18px;font-weight:400}.form-group label{color:#374151;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:14px;font-weight:600;display:block}.form-group label i{color:#667eea;margin-right:8px}.form-control{color:#1f2937;background:#fff;border:2px solid #e5e7eb;border-radius:12px;outline:none;width:100%;padding:14px 18px;font-family:Inter,sans-serif;font-size:16px;transition:all .3s}.form-control:hover{border-color:#d1d5db}.form-control:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}select.form-control{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 16px center;background-repeat:no-repeat;background-size:16px;padding-right:48px}select.form-control option{padding:12px;font-size:16px}.login-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;width:100%;margin-top:16px;padding:16px 24px;font-family:Inter,sans-serif;font-size:18px;font-weight:600;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 10px 20px -5px #667eea66}.login-button:before{content:"";background:#fff3;border-radius:50%;width:0;height:0;transition:width .6s,height .6s;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-button:hover{transform:translateY(-2px);box-shadow:0 15px 30px -5px #667eea99}.login-button:hover:before{width:300px;height:300px}.login-button:active{transform:translateY(0)}.error-message{color:#b91c1c;background:linear-gradient(135deg,#fef2f2 0%,#fee2e2 100%);border-left:4px solid #ef4444;border-radius:12px;align-items:center;gap:12px;margin-bottom:24px;padding:16px 20px;font-size:14px;font-weight:500;animation:.5s ease-in-out shake;display:flex}@keyframes shake{0%,to{transform:translate(0)rotate(0)}25%{transform:translate(-2px)rotate(-2deg)}75%{transform:translate(2px)rotate(2deg)}}.error-message i{color:#ef4444;font-size:20px}.demo-info{text-align:center;border-top:2px solid #f3f4f6;margin-top:32px;padding-top:24px}.demo-info p{color:#6b7280;justify-content:center;align-items:center;gap:8px;margin-bottom:12px;font-size:14px;display:flex}.demo-info i{color:#fbbf24;font-size:16px}.demo-users{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.demo-user-tag{color:#374151;cursor:default;background:#f3f4f6;border-radius:20px;padding:6px 12px;font-size:12px;transition:all .2s}.demo-user-tag:hover{background:#e5e7eb;transform:scale(1.05)}.demo-user-tag.admin{color:#991b1b;background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%)}.demo-user-tag.manager{color:#1e40af;background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%)}.demo-user-tag.driver{color:#166534;background:linear-gradient(135deg,#dcfce7 0%,#bbf7d0 100%)}.demo-user-tag.coordinator{color:#92400e;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%)}@media (width<=768px){.login-box{max-width:450px;padding:36px}.login-box h1{font-size:28px}.login-box h2{margin-bottom:32px;font-size:16px}.medical-icon{width:70px;height:70px;font-size:35px}}@media (width<=480px){.login-box{border-radius:20px;padding:24px}.login-box h1{font-size:24px}.login-box h2{margin-bottom:24px;font-size:14px}.medical-icon{border-radius:16px;width:60px;height:60px;font-size:30px}.form-group label{font-size:12px}.form-control{border-radius:10px;padding:12px 16px;font-size:14px}select.form-control{background-position:right 12px center;padding-right:40px}.login-button{border-radius:10px;padding:14px 20px;font-size:16px}.demo-info{margin-top:24px;padding-top:20px}.demo-info p{font-size:12px}.demo-user-tag{padding:4px 10px;font-size:11px}.error-message{padding:12px 16px;font-size:13px}}@media (width<=320px){.login-box{padding:20px}.demo-users{flex-direction:column;align-items:center}.demo-user-tag{text-align:center;width:100%}}@media (prefers-color-scheme:dark){.login-box{background:#1f2937f2}.login-box h1{color:#f9fafb}.login-box h2{color:#9ca3af}.form-group label{color:#e5e7eb}.form-control{color:#f9fafb;background:#374151;border-color:#4b5563}.form-control option{color:#f9fafb;background:#374151}.demo-info{border-top-color:#374151}.demo-info p{color:#9ca3af}.demo-user-tag{color:#e5e7eb;background:#374151}}.admin-panel{background:#f5f5f5;min-height:100vh}.admin-header{background:#fff;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:15px;padding:20px;display:flex;box-shadow:0 2px 4px #0000001a}.admin-header h1{color:#333;margin:0;font-size:24px}.back-button{color:#fff;cursor:pointer;background:#6c757d;border:none;border-radius:5px;padding:8px 15px;font-size:14px;transition:background .3s}.admin-message{color:#fff;text-align:center;background:#28a745;padding:10px;animation:.3s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.admin-content{max-width:1200px;margin:0 auto;padding:20px}.admin-content h2{color:#333;margin:0 0 10px}.admin-info{color:#666;background:#e9ecef;border-radius:5px;margin-bottom:20px;padding:15px}.users-table-container{background:#fff;border-radius:10px;overflow-x:auto;box-shadow:0 2px 4px #0000001a}.users-table{border-collapse:collapse;width:100%;min-width:600px}.users-table th,.users-table td{text-align:left;border-bottom:1px solid #dee2e6;padding:15px}.users-table th{color:#495057;background:#f8f9fa;font-weight:600}.users-table tr:hover{background:#f8f9fa}.role-select{cursor:pointer;border:1px solid #ced4da;border-radius:5px;width:100%;max-width:150px;padding:8px;font-size:14px}.role-select:focus{border-color:#667eea;outline:none}.loading{color:#666;justify-content:center;align-items:center;min-height:100vh;font-size:18px;display:flex}@media (width<=768px){.admin-header{text-align:center;flex-direction:column}.back-button{width:100%}.users-table th,.users-table td{padding:10px;font-size:14px}.role-select{max-width:120px;padding:6px;font-size:12px}}@media (width<=480px){.admin-header h1{font-size:20px}.users-table{min-width:450px}.users-table th,.users-table td{padding:8px;font-size:12px}.role-select{max-width:100px}}.settings-section{background:#fff;border-radius:20px;margin-top:40px;padding:24px;box-shadow:0 10px 25px -5px #0000001a}.settings-section h3{color:#1f2937;margin:0 0 20px;font-size:20px;font-weight:600}.settings-card{background:#f9fafb;border-radius:12px;padding:20px}.setting-item{flex-direction:column;gap:12px;display:flex}.setting-item label{color:#374151;font-size:14px;font-weight:600}.setting-control{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.interval-input{border:2px solid #e5e7eb;border-radius:8px;width:120px;padding:8px 12px;font-size:14px}.interval-input:focus{border-color:#667eea;outline:none}.save-interval-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:8px;padding:8px 20px;font-size:14px;font-weight:600;transition:all .3s}.save-interval-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.setting-info{color:#166534;background:#f0fdf4;border-left:4px solid #10b981;border-radius:8px;margin-top:12px;padding:12px;font-size:13px}.setting-note{color:#6b7280;margin:8px 0 0;font-size:13px}.admin-tabs{gap:10px;max-width:1400px;margin:0 auto;padding:20px 40px 0;display:flex}.tab-button{cursor:pointer;color:#4b5563;background:#e5e7eb;border:none;border-radius:12px 12px 0 0;padding:12px 24px;font-size:16px;font-weight:600;transition:all .3s}.tab-button.active{color:#667eea;background:#fff;box-shadow:0 -4px 10px #0000000d}.contractors-section{background:#fff;border-radius:20px;padding:30px;box-shadow:0 10px 25px -5px #0000001a}.add-contractor{gap:12px;margin-bottom:30px;display:flex}.contractor-input{border:2px solid #e5e7eb;border-radius:12px;flex:1;padding:12px 16px;font-size:16px;transition:all .2s}.contractor-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.add-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:12px;padding:12px 24px;font-size:16px;font-weight:600;transition:all .3s}.add-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.add-button:disabled{opacity:.5;cursor:not-allowed}.contractors-list{border:1px solid #e5e7eb;border-radius:12px;max-height:400px;margin-bottom:20px;overflow-y:auto}.contractor-item{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 16px;transition:all .2s;display:flex}.contractor-item:last-child{border-bottom:none}.contractor-item:hover{background:#f9fafb}.contractor-name{color:#1f2937;font-size:15px}.contractor-actions{gap:8px;display:flex}.edit-button,.delete-button{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:all .2s;display:flex}.edit-button:hover{color:#4b5563;background:#d1d5db}.contractor-edit{gap:8px;width:100%;display:flex}.edit-input{border:2px solid #667eea;border-radius:8px;flex:1;padding:8px 12px;font-size:14px}.save-button,.cancel-button{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;transition:all .2s;display:flex}.save-button:hover{background:#059669}.no-contractors{text-align:center;color:#9ca3af;padding:40px;font-size:16px}.contractors-actions{justify-content:flex-end;margin-top:20px;display:flex}.save-all-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;padding:12px 30px;font-size:16px;font-weight:600;transition:all .3s}.save-all-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.create-role-section,.roles-list-section{background:#fff;border-radius:20px;margin-bottom:30px;padding:24px;box-shadow:0 10px 25px -5px #0000001a}.create-role-section h3,.roles-list-section h3{color:#1f2937;margin:0 0 20px;font-size:18px;font-weight:600}.create-role-form{flex-direction:column;gap:16px;display:flex}.role-name-input{border:2px solid #e5e7eb;border-radius:12px;padding:12px 16px;font-size:15px;transition:all .2s}.role-name-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.hubs-checkboxes{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.hubs-checkboxes>label{color:#374151;margin-right:8px;font-weight:600}.hub-checkbox{cursor:pointer;background:#f3f4f6;border-radius:30px;align-items:center;gap:8px;padding:6px 12px;transition:all .2s;display:flex}.hub-checkbox:hover{background:#e5e7eb}.hub-checkbox input{cursor:pointer;width:18px;height:18px}.hub-checkbox span{color:#374151;font-size:14px}.create-role-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:12px;align-self:flex-start;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.create-role-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.role-card-admin{background:#f9fafb;border:1px solid #e5e7eb;border-radius:16px;padding:20px;transition:all .2s}.role-card-admin:hover{border-color:#667eea;box-shadow:0 4px 12px #0000000d}.role-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.role-header h4{color:#1f2937;margin:0;font-size:18px;font-weight:600}.system-badge{color:#6b7280;background:#e5e7eb;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:500}.role-hubs{margin-bottom:20px}.role-hubs .label{color:#6b7280;text-transform:uppercase;letter-spacing:.3px;margin-bottom:8px;font-size:12px;font-weight:500;display:block}.hub-tags{flex-wrap:wrap;gap:8px;display:flex}.hub-tag{color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:4px 12px;font-size:13px}.no-access{color:#9ca3af;font-size:13px;font-style:italic}.role-actions{border-top:1px solid #e5e7eb;justify-content:flex-end;gap:12px;margin-top:16px;padding-top:16px;display:flex}.edit-role-button,.delete-role-button{cursor:pointer;border:none;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.edit-role-button{color:#4b5563;background:#e5e7eb}.edit-role-button:hover{background:#d1d5db}.delete-role-button{color:#ef4444;background:#fee2e2}.delete-role-button:hover{background:#fecaca}.role-edit-form{flex-direction:column;gap:16px;display:flex}.role-edit-actions{justify-content:flex-end;gap:12px;display:flex}.role-edit-actions .save-button{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:8px;padding:8px 20px}.role-edit-actions .cancel-button{color:#4b5563;cursor:pointer;background:#e5e7eb;border:none;border-radius:8px;padding:8px 20px}@media (width<=768px){.roles-grid{grid-template-columns:1fr}.hubs-checkboxes{flex-direction:column;align-items:flex-start}.hub-checkbox,.create-role-button{width:100%}}.hubs-buttons{flex-wrap:wrap;gap:12px;margin:12px 0;display:flex}.hub-select-button{cursor:pointer;color:#4b5563;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:12px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.hub-select-button:hover{background:#e5e7eb;transform:translateY(-1px)}.hub-select-button.selected{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea;box-shadow:0 4px 12px #667eea4d}.hub-select-button .hub-icon{font-size:18px}.hub-select-button .hub-check{margin-left:4px;font-weight:700}.selected-order{background:#f9fafb;border-left:3px solid #667eea;border-radius:10px;margin-top:12px;padding:12px}.order-label{color:#6b7280;text-transform:uppercase;letter-spacing:.3px;margin-bottom:8px;font-size:12px;font-weight:500;display:block}.order-tags{flex-wrap:wrap;gap:8px;display:flex}.order-tag{color:#374151;background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:4px 12px;font-size:13px}.hubs-label{color:#374151;margin-bottom:8px;font-weight:600;display:block}.add-user-button-container{text-align:right;margin-bottom:20px}.add-user-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:12px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.add-user-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.user-actions{flex-wrap:wrap;gap:8px;display:flex}.action-button{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:16px;transition:all .2s;display:inline-flex}.action-button.edit{color:#4b5563;background:#e5e7eb;padding:18px 28px}.action-button.edit:hover{background:#d1d5db}.action-button.password{color:#d97706;background:#fef3c7;padding:18px 28px}.action-button.password:hover{background:#fde68a}.action-button.delete{color:#ef4444;background:#fee2e2;padding:18px 28px}.action-button.delete:hover{background:#fecaca}.action-button.save{color:#fff;background:#10b981}.action-button.save:hover{background:#059669}.action-button.cancel:hover{background:#d1d5db}.edit-name-input{border:2px solid #667eea;border-radius:8px;width:100%;min-width:150px;padding:6px 10px;font-size:14px}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:20px;width:90%;max-width:400px;padding:24px;box-shadow:0 20px 40px #0003}.modal-content h3{color:#1f2937;margin:0 0 20px;font-size:20px}.modal-field{margin-bottom:16px}.modal-field label{color:#374151;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.modal-input,.modal-select{border:2px solid #e5e7eb;border-radius:10px;width:100%;padding:10px 12px;font-size:14px;transition:all .2s}.modal-input:focus,.modal-select:focus{border-color:#667eea;outline:none}.modal-actions{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}.modal-button{cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.modal-button.save{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.modal-button.save:hover{transform:translateY(-1px)}.modal-button.cancel{color:#4b5563;background:#e5e7eb}.modal-button.cancel:hover{background:#d1d5db}.duties-section{background:#fff;border-radius:20px;margin-top:40px;padding:24px;box-shadow:0 10px 25px -5px #0000001a}.duties-section h3{color:#1f2937;margin:0 0 8px;font-size:20px;font-weight:600}.duties-table-container{margin-top:20px;overflow-x:auto}.duties-table{border-collapse:collapse;width:100%;min-width:500px}.duties-table th,.duties-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:12px 16px}.duties-table th{color:#4b5563;background:#f9fafb;font-weight:600}.duty-user-name{color:#1f2937;font-weight:500}.duty-dates-list{max-width:300px}.duty-dates{flex-wrap:wrap;gap:8px;display:flex}.duty-date-badge{color:#374151;white-space:nowrap;background:#f3f4f6;border-radius:20px;padding:4px 10px;font-size:12px}.no-duties{color:#9ca3af;font-size:13px;font-style:italic}.duty-actions{text-align:center}.duty-button{cursor:pointer;color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.duty-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.duty-modal{max-width:500px}.duty-add-form{background:#f9fafb;border-radius:12px;margin:20px 0;padding:16px}.duty-date-input-group{gap:12px;display:flex}.duty-date-input{border:2px solid #e5e7eb;border-radius:10px;flex:1;padding:10px 12px;font-size:14px}.duty-date-input:focus{border-color:#667eea;outline:none}.duty-add-button{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:10px;padding:10px 20px;font-weight:500;transition:all .2s}.duty-add-button:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.duty-add-button:disabled{opacity:.5;cursor:not-allowed}.duty-dates-list-modal{margin:16px 0}.duty-dates-list-modal label{color:#374151;margin-bottom:8px;font-weight:500;display:block}.duty-dates-grid{flex-wrap:wrap;gap:10px;display:flex}.duty-date-item{background:#f3f4f6;border-radius:20px;align-items:center;gap:8px;padding:6px 12px;display:flex}.duty-date{color:#1f2937;font-size:13px}.duty-remove-button{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;transition:all .2s;display:inline-flex}.duty-remove-button:hover{background:#fecaca;transform:scale(1.1)}.no-duties-modal{text-align:center;color:#9ca3af;padding:20px;font-style:italic}.vacations-section{background:#fff;border-radius:20px;margin-top:40px;padding:24px;box-shadow:0 10px 25px -5px #0000001a}.vacations-section h3{color:#1f2937;margin:0 0 8px;font-size:20px;font-weight:600}.vacations-table-container{margin-top:20px;overflow-x:auto}.vacations-table{border-collapse:collapse;width:100%;min-width:500px}.vacations-table th,.vacations-table td{text-align:left;border-bottom:1px solid #e5e7eb;padding:12px 16px}.vacations-table th{color:#4b5563;background:#f9fafb;font-weight:600}.vacation-user-name{color:#1f2937;font-weight:500}.vacation-periods{flex-wrap:wrap;gap:8px;display:flex}.vacation-period-badge{color:#92400e;white-space:nowrap;background:#fef3c7;border-radius:20px;padding:4px 10px;font-size:12px}.no-vacations{color:#9ca3af;font-size:13px;font-style:italic}.vacation-button{cursor:pointer;color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:8px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.vacation-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.vacation-modal{max-width:550px}.vacation-add-form{background:#f9fafb;border-radius:12px;margin:20px 0;padding:16px}.vacation-date-inputs{flex-direction:column;gap:12px;display:flex}.vacation-date-group{flex-direction:column;gap:4px;display:flex}.vacation-date-group label{color:#6b7280;font-size:12px;font-weight:500}.vacation-date-input{border:2px solid #e5e7eb;border-radius:8px;padding:8px 12px;font-size:14px}.vacation-date-input:focus{border-color:#10b981;outline:none}.vacation-add-button{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:10px;margin-top:8px;padding:10px 20px;font-weight:500;transition:all .2s}.vacation-add-button:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.vacation-add-button:disabled{opacity:.5;cursor:not-allowed}.vacation-periods-list-modal{max-height:300px;margin:16px 0;overflow-y:auto}.vacation-periods-list-modal label{color:#374151;margin-bottom:12px;font-weight:500;display:block}.vacation-periods-grid{flex-direction:column;gap:10px;display:flex}.vacation-period-item{background:#fef3c7;border-radius:12px;justify-content:space-between;align-items:center;padding:10px 15px;display:flex}.vacation-period{color:#92400e;font-size:14px}.vacation-period-actions{gap:8px;display:flex}.vacation-edit-button,.vacation-remove-button{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;transition:all .2s;display:inline-flex}.vacation-edit-button{color:#4b5563;background:#e5e7eb}.vacation-edit-button:hover{background:#d1d5db}.vacation-remove-button{color:#ef4444;background:#fee2e2}.vacation-remove-button:hover{background:#fecaca}.vacation-edit-form{width:100%}.vacation-edit-inputs{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.vacation-edit-group{align-items:center;gap:4px;display:flex}.vacation-edit-group label{color:#6b7280;font-size:11px}.vacation-edit-input{border:1px solid #10b981;border-radius:6px;width:110px;padding:6px 8px;font-size:12px}.vacation-edit-save,.vacation-edit-cancel{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;display:inline-flex}.vacation-edit-save{color:#fff;background:#10b981}.vacation-edit-save:hover{background:#059669}.vacation-edit-cancel{color:#4b5563;background:#e5e7eb}.vacation-edit-cancel:hover{background:#d1d5db}.no-vacations-modal{text-align:center;color:#9ca3af;padding:20px;font-style:italic}.test-notification-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:12px;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s}.test-notification-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.dashboard{--dash-block-padding:24px 28px;--dash-block-radius:20px;--dash-block-shadow:0 8px 24px #0000000f;--dash-block-bg:white;--dash-block-gap:24px;--dash-title-size:22px;--dash-title-weight:700;--dash-title-color:#1f2937;--dash-text-size:15px;--dash-text-color:#6b7280;background:linear-gradient(135deg,#f5f7fa 0%,#e4e8f0 100%);flex-direction:column;width:100%;min-height:100vh;display:flex}.dashboard-header{z-index:100;background:#fff;justify-content:center;width:100%;padding:20px 32px;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #0000000f}.header-content{justify-content:space-between;align-items:center;gap:20px;width:100%;max-width:1400px;display:flex}.dashboard-header h1{color:#1a1a1a;white-space:nowrap;margin:0;font-size:28px;font-weight:700}.user-info{flex-shrink:0;align-items:center;gap:12px;display:flex}.dashboard-content{flex-direction:column;flex:1;gap:24px;width:100%;max-width:1400px;margin:0 auto;padding:32px;display:flex}.welcome-section{background:var(--dash-block-bg);padding:var(--dash-block-padding);border-radius:var(--dash-block-radius);box-shadow:var(--dash-block-shadow);border:1px solid #0000000a;position:relative}.welcome-section h2{color:var(--dash-title-color);font-size:var(--dash-title-size);font-weight:var(--dash-title-weight);margin:0 0 10px}.welcome-section p{color:var(--dash-text-color);font-size:var(--dash-text-size);margin:0}.close-welcome{color:#9ca3af;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:22px;transition:all .2s;display:flex;position:absolute;top:18px;right:18px}.close-welcome:hover{color:#4b5563;background:#f3f4f6}.welcome-info{border-top:1px solid #e5e7eb;margin-top:18px;padding-top:18px}.welcome-role,.welcome-duties,.welcome-vacation,.welcome-no-events{background:#f9fafb;border-radius:12px;flex-wrap:wrap;align-items:center;gap:10px;margin:12px 0;padding:12px 16px;font-size:15px;display:flex}.welcome-role{color:#fff;background:linear-gradient(135deg,#667eea 10%,#764ba2 100%)}.welcome-role strong{letter-spacing:1px;font-size:16px;font-weight:700}.welcome-icon{font-size:20px}.welcome-duties{color:#92400e;background:#fef3c7}.welcome-duties .duty-highlight{color:#d97706;margin:0 2px;font-weight:600}.welcome-duties .duty-urgent{color:#dc2626;font-weight:700}.welcome-duties .duty-soon{color:#f59e0b;font-weight:500}.welcome-vacation{color:#1e40af;background:#dbeafe}.welcome-vacation .vacation-urgent{color:#dc2626;font-weight:700}.welcome-vacation .vacation-soon{color:#f59e0b;font-weight:600}.welcome-no-events{color:#6b7280;background:#f3f4f6}.hubs-section{background:var(--dash-block-bg);padding:var(--dash-block-padding);border-radius:var(--dash-block-radius);box-shadow:var(--dash-block-shadow)}.hubs-section h3{color:var(--dash-title-color);font-size:var(--dash-title-size);font-weight:var(--dash-title-weight);margin:0 0 22px}.hubs-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;display:grid}.hub-button{cursor:pointer;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border:2px solid #e2e8f0;border-radius:16px;flex-direction:column;align-items:center;padding:22px 16px;transition:all .3s;display:flex;position:relative;overflow:hidden}.hub-button:before{content:"";background:linear-gradient(90deg,#667eea,#764ba2);height:4px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:translateY(-100%)}.hub-button:hover{border-color:#667eea;transform:translateY(-3px);box-shadow:0 12px 24px -8px #667eea40}.hub-button:hover:before{transform:translateY(0)}.hub-button.regions:hover{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 100%)}.hub-button.spb:hover{background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%)}.hub-button.invoices:hover{background:linear-gradient(135deg,#fef9c3 0%,#fef08a 100%)}.hub-button.tasks:hover{background:linear-gradient(135deg,#f3e8ff 0%,#e9d5ff 100%)}.hub-button.arrival:hover{background:linear-gradient(135deg,#ffe4e6 0%,#fecdd3 100%)}.hub-button.airtraffic:hover{background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 100%)}.hub-icon{margin-bottom:8px;font-size:32px}.hub-name{color:#1f2937;margin-bottom:4px;font-size:16px;font-weight:600}.hub-count{color:#667eea;justify-content:center;align-items:center;min-width:32px;font-size:24px;font-weight:700;display:inline-flex}.hub-count-spinner{border:2px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;width:20px;height:20px;animation:.8s linear infinite hub-spin;display:inline-block}@keyframes hub-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tasks-table-section{background:var(--dash-block-bg);border-radius:var(--dash-block-radius);padding:var(--dash-block-padding);box-shadow:var(--dash-block-shadow)}.tasks-table-section h3{color:var(--dash-title-color);font-size:var(--dash-title-size);font-weight:var(--dash-title-weight);margin:0 0 22px}.tasks-table-container{-webkit-overflow-scrolling:touch;border:1px solid #e5e7eb;border-radius:12px;overflow-x:auto}.tasks-table{border-collapse:collapse;width:100%;min-width:600px}.tasks-table th{text-align:left;color:#4b5563;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;background:#f9fafb;border-bottom:2px solid #e5e7eb;padding:14px 18px;font-size:14px;font-weight:600}.tasks-table td{color:#374151;border-bottom:1px solid #f3f4f6;padding:14px 18px;font-size:15px}.task-row{cursor:pointer;transition:background .15s}.task-row:hover{background:#f9fafb}.task-row:active{background:#f3f4f6}.task-title{color:#1f2937;font-weight:500}.task-contractor{color:#4b5563}.task-comment{color:#6b7280;text-overflow:ellipsis;white-space:nowrap;max-width:300px;overflow:hidden}.task-assignee{color:#667eea;font-weight:500}.roles-section{background:var(--dash-block-bg);padding:var(--dash-block-padding);border-radius:var(--dash-block-radius);box-shadow:var(--dash-block-shadow)}.roles-section h3{color:var(--dash-title-color);font-size:var(--dash-title-size);font-weight:var(--dash-title-weight);margin:0 0 22px}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.role-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;flex-direction:column;gap:12px;padding:22px;transition:all .3s;display:flex}.role-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 8px 20px #00000014}.role-card h4{color:#1f2937;margin:0;font-size:17px;font-weight:600}.role-badge{border-radius:20px;width:fit-content;padding:6px 14px;font-size:14px;font-weight:600;display:inline-block}.role-admin{color:#991b1b;background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%)}.role-manager{color:#1e40af;background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%)}.role-driver{color:#166534;background:linear-gradient(135deg,#dcfce7 0%,#bbf7d0 100%)}.role-coordinator{color:#92400e;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%)}.no-tasks-message{text-align:center;color:#9ca3af;padding:40px;font-size:15px}@media (width<=1024px){.dashboard-header{padding:16px 24px}.dashboard-header h1{font-size:24px}.dashboard-content{gap:20px;padding:24px}.welcome-section,.hubs-section,.tasks-table-section,.roles-section{padding:24px 28px}.welcome-section h2{font-size:24px}.welcome-section p{font-size:16px}.hubs-section h3,.tasks-table-section h3,.roles-section h3{font-size:20px}.hubs-grid{grid-template-columns:repeat(3,1fr)}.hub-button{padding:20px 14px}.hub-icon{font-size:28px}.hub-name{font-size:15px}.hub-count{font-size:22px}.tasks-table th{font-size:13px}.tasks-table td{font-size:14px}.roles-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.dashboard-header{padding:14px 18px}.dashboard-header h1{font-size:22px}.dashboard-content{gap:16px;padding:18px}.welcome-section,.hubs-section,.tasks-table-section,.roles-section{border-radius:16px;padding:20px}.welcome-section h2{font-size:22px}.welcome-section p{font-size:15px}.welcome-role,.welcome-duties,.welcome-vacation,.welcome-no-events{padding:10px 14px;font-size:14px}.welcome-role strong{font-size:14px}.welcome-icon{font-size:18px}.hubs-section h3,.tasks-table-section h3,.roles-section h3{margin-bottom:16px;font-size:18px}.hubs-grid{grid-template-columns:repeat(2,1fr);gap:10px}.hub-button{padding:18px 12px}.hub-icon{font-size:26px}.hub-name{font-size:14px}.hub-count{font-size:20px}.tasks-table th,.tasks-table td{padding:12px 14px;font-size:13px}.tasks-table{min-width:500px}.task-comment{max-width:150px}.roles-grid{grid-template-columns:1fr 1fr;gap:12px}.role-card{text-align:center;align-items:center;padding:18px}.role-card h4{font-size:15px}.role-badge{padding:5px 12px;font-size:13px}.desktop-only{display:none}}@media (width<=480px){.dashboard-header{padding:12px 14px}.dashboard-header h1{font-size:20px}.dashboard-content{gap:14px;padding:14px}.welcome-section,.hubs-section,.tasks-table-section,.roles-section{border-radius:14px;padding:18px 16px}.welcome-section h2{font-size:20px}.welcome-section p{font-size:14px}.close-welcome{width:32px;height:32px;font-size:18px;top:12px;right:12px}.welcome-role,.welcome-duties,.welcome-vacation,.welcome-no-events{gap:8px;padding:10px 12px;font-size:13px}.welcome-icon{font-size:16px}.hubs-grid{grid-template-columns:repeat(2,1fr);gap:8px}.hub-button{padding:14px 10px}.hub-icon{margin-bottom:4px;font-size:22px}.hub-name{font-size:13px}.hub-count{font-size:18px}.tasks-table th,.tasks-table td{padding:10px 12px;font-size:12px}.tasks-table{min-width:400px}.roles-grid{grid-template-columns:1fr}.role-card{flex-direction:row;justify-content:space-between;padding:16px}}@media (width<=360px){.dashboard-header h1{font-size:18px}.hubs-grid{grid-template-columns:1fr 1fr;gap:6px}.hub-button{padding:12px 8px}.hub-icon{font-size:20px}.hub-name{font-size:12px}.hub-count{font-size:16px}.tasks-table{min-width:350px}.tasks-table th,.tasks-table td{padding:8px 10px;font-size:11px}}@media (width<=768px){.header-content{flex-wrap:wrap;gap:10px}.header-hubs-mini{order:2;justify-content:center;width:100%;margin-left:0;margin-right:0}.user-info{order:3}.dashboard-header h1{order:1;font-size:20px}}@media (width<=480px){.header-hubs-mini{gap:6px}.hub-mini-item{gap:4px;padding:4px 10px}.hub-mini-count{min-width:18px;padding:1px 5px;font-size:10px}}@media (width<=768px){.mini-hubs-toggle{width:28px;height:28px}.hub-mini-item.total-badge{padding:4px 12px}}@media (width<=480px){.mini-hubs-toggle{width:26px;height:26px}.hub-mini-item.total-badge{padding:4px 10px}.toggle-arrow{width:12px;height:12px}}.notifications-bell{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex;position:relative}.notifications-bell:hover{color:#1f2937;background:#f3f4f6}.notifications-bell.has-unread{color:#1f2937}.notifications-badge{color:#fff;background:#ef4444;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;line-height:1;display:flex;position:absolute;top:2px;right:2px;box-shadow:0 0 0 2px #fff}.notifications-bell.ringing{animation:.6s bellRing}@keyframes bellRing{0%{transform:rotate(0)}10%{transform:rotate(15deg)}20%{transform:rotate(-15deg)}30%{transform:rotate(10deg)}40%{transform:rotate(-10deg)}50%{transform:rotate(5deg)}60%{transform:rotate(-5deg)}to{transform:rotate(0)}}.notifications-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2000;background:#0006;justify-content:center;align-items:flex-start;padding:60px 20px 20px;animation:.15s fadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}.notifications-modal{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:520px;max-height:70vh;animation:.2s slideDown;display:flex;box-shadow:0 20px 60px #0003}.notifications-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.notifications-header h2{color:#1f2937;margin:0;font-size:18px}.notifications-header-actions{align-items:center;gap:8px;display:flex}.mark-all-read-btn{color:#667eea;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 10px;font-size:13px;transition:background .2s}.mark-all-read-btn:hover{background:#f3f4f6}.close-btn{cursor:pointer;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;transition:all .2s;display:flex}.notifications-tabs{border-bottom:1px solid #f0f0f0;padding:0 16px;display:flex}.tab-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:12px 16px;font-size:14px;transition:all .2s}.tab-btn:hover{color:#1f2937}.tab-btn.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.notifications-list{flex:1;max-height:calc(70vh - 130px);overflow-y:auto}.notifications-empty{color:#9ca3af;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px 20px;font-size:14px;display:flex}.notification-group{border-bottom:1px solid #f5f5f5}.notification-group-header{color:#4b5563;background:#fafafa;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:600;display:flex}.unread-dot{background:#ef4444;border-radius:50%;width:8px;height:8px;margin-left:auto}.notification-item{cursor:pointer;align-items:center;gap:10px;padding:10px 20px 10px 36px;transition:background .15s;display:flex}.notification-item:hover{background:#f9fafb}.notification-item.unread{background:#f0f4ff}.notification-item-content{flex-direction:column;flex:1;gap:2px;display:flex}.notification-body{color:#1f2937;font-size:13px;line-height:1.4}.notification-time{color:#9ca3af;font-size:11px}.unread-indicator{background:#667eea;border-radius:50%;flex-shrink:0;width:8px;height:8px}.load-more-notifications{justify-content:center;padding:16px;display:flex}.load-more-btn{color:#667eea;cursor:pointer;background:#f3f4f6;border:none;border-radius:20px;padding:8px 20px;font-size:13px;transition:background .2s}.load-more-btn:hover{background:#e5e7eb}@media (width<=768px){.notifications-overlay{align-items:flex-end;padding:0}.notifications-modal{border-radius:16px 16px 0 0;max-width:100%;max-height:90vh}.notifications-list{max-height:calc(90vh - 130px)}}.user-menu{z-index:1000;align-items:center;gap:8px;display:flex;position:relative}.user-menu-trigger{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:12px;align-items:center;gap:10px;min-width:0;padding:8px 14px 8px 10px;transition:all .2s;display:flex}.user-menu-trigger:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 2px 8px #0000000f}.user-menu-trigger:active{background:#f3f4f6;transform:scale(.98)}.sse-indicator{flex-shrink:0;justify-content:center;align-items:center;display:flex}.sse-dot{border-radius:50%;width:9px;height:9px;display:inline-block}.sse-indicator.online .sse-dot{background:#10b981;animation:2s infinite pulse-green;box-shadow:0 0 6px #10b98180}.sse-indicator.offline .sse-dot{background:#ef4444;box-shadow:0 0 6px #ef44444d}@keyframes pulse-green{0%,to{box-shadow:0 0 4px #10b98166}50%{box-shadow:0 0 10px #10b981cc}}.user-avatar{color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:15px;font-weight:700;display:flex}.user-avatar.large{border-radius:14px;width:48px;height:48px;font-size:18px}.user-info-text{flex-direction:column;align-items:flex-start;min-width:0;line-height:1.2;display:flex}.user-name{color:#1f2937;white-space:nowrap;text-overflow:ellipsis;max-width:150px;font-size:15px;font-weight:600;overflow:hidden}.user-role-text{color:#6b7280;font-size:12px;font-weight:500}.chevron{color:#9ca3af;flex-shrink:0;transition:transform .2s}.chevron.open{transform:rotate(180deg)}.user-menu-dropdown{z-index:1000;background:#fff;border-radius:16px;width:300px;animation:.2s slideDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 20px 40px #0000001f,0 0 0 1px #0000000d}.menu-header{align-items:center;gap:14px;padding:18px 20px;display:flex}.menu-header-info{flex-direction:column;gap:3px;display:flex}.menu-header-name{color:#1f2937;font-size:16px;font-weight:600}.menu-header-role{color:#6b7280;font-size:13px;font-weight:500}.menu-divider{background:#f3f4f6;height:1px;margin:0}.menu-items{padding:8px}.menu-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:14px;width:100%;padding:12px 14px;font-family:inherit;transition:all .15s;display:flex}.menu-item:hover{background:#f3f4f6}.menu-item:active{background:#e5e7eb;transform:scale(.98)}.menu-item-icon{color:#4b5563;background:#f3f4f6;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.admin-icon{color:#7c3aed;background:#f5f3ff}.logout-icon{color:#ef4444;background:#fef2f2}.menu-item-text{flex-direction:column;gap:2px;min-width:0;display:flex}.menu-item-title{color:#1f2937;font-size:14px;font-weight:600}.menu-item-description{color:#9ca3af;white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.menu-footer{background:#fafafa;padding:8px}.logout-item:hover{background:#fef2f2}.logout-item .menu-item-title{color:#ef4444}@media (width<=768px){.user-menu-trigger{border-radius:10px;gap:8px;padding:6px 10px 6px 6px}.user-info-text,.chevron{display:none}.user-avatar{border-radius:9px;width:34px;height:34px;font-size:13px}.sse-dot{width:8px;height:8px}.user-menu-backdrop{z-index:999;background:#00000059;animation:.2s fadeIn;display:block;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.user-menu-dropdown{border-radius:20px 20px 0 0;width:100%;max-height:70vh;animation:.25s slideUp;position:fixed;inset:auto 0 0;overflow-y:auto;box-shadow:0 -10px 40px #00000026}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.menu-header{padding:20px 18px}.user-avatar.large{width:44px;height:44px;font-size:16px}.menu-header-name{font-size:17px}.menu-item{padding:14px 16px}.menu-item-icon{width:40px;height:40px}.menu-item-title{font-size:15px}.menu-item-description{font-size:13px}}@media (width<=480px){.user-avatar{width:32px;height:32px;font-size:12px}.sse-dot{width:7px;height:7px}}.news-widget{background:#fff;border-radius:20px;margin-bottom:24px;overflow:hidden;box-shadow:0 8px 24px #0000000f}.news-widget.collapsed{box-shadow:0 2px 8px #0000000a}.news-widget-header{justify-content:space-between;align-items:center;min-height:48px;padding:16px 20px;display:flex}.news-collapse-button{cursor:pointer;color:#1f2937;text-align:left;background:0 0;border:none;flex:1;align-items:center;gap:10px;padding:4px;font-size:18px;font-weight:700;transition:color .2s;display:flex}.news-collapse-button:hover{color:#667eea}.news-widget-header h3{color:#1f2937;align-items:center;gap:8px;margin:0;font-size:20px;font-weight:700;display:flex}.news-icon{font-size:24px}.news-header-icon{flex-shrink:0;font-size:22px}.news-header-title{font-size:20px;font-weight:700}.news-header-count{color:#fff;background:#667eea;border-radius:12px;justify-content:center;align-items:center;min-width:24px;height:24px;padding:0 6px;font-size:13px;font-weight:600;display:flex}.news-unread-badge{color:#fff;background:#ef4444;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:12px;font-weight:700;animation:2s infinite badgePulse;display:flex}@keyframes badgePulse{0%,to{transform:scale(1);box-shadow:0 0 #ef444466}50%{transform:scale(1.05);box-shadow:0 0 0 6px #ef444400}}.news-collapse-button .collapse-arrow{color:#9ca3af;flex-shrink:0;align-items:center;transition:transform .2s;display:flex}.news-collapse-button .collapse-arrow.collapsed{transform:rotate(-90deg)}.news-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.news-mark-read-button{cursor:pointer;color:#10b981;background:#fff;border:1px solid #e5e7eb;border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;transition:all .2s;display:flex}.news-mark-read-button:hover{background:#ecfdf5;border-color:#a7f3d0}.news-count{color:#fff;background:#667eea;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600}.news-add-button{cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:all .2s;display:flex}.news-add-button:hover{color:#fff;background:#667eea;border-color:#667eea}.news-list{flex-direction:column;gap:10px;padding:0 20px 16px;display:flex}.news-empty{text-align:center;color:#9ca3af;padding:20px 16px}.news-empty p{margin:0;font-size:14px}.news-card.important.unread{background:#fee2e2}.news-card.urgent{background:#fffbeb;border-left:4px solid #f59e0b}.unread-dot{background:#3b82f6;border-radius:50%;width:8px;height:8px;position:absolute;top:14px;left:10px;box-shadow:0 0 0 3px #3b82f633}.news-card.soon{background:#eff6ff;border-left:4px solid #3b82f6}.news-card-header{align-items:center;gap:10px;margin-bottom:8px;padding-left:8px;display:flex}.important-badge{color:#fff;letter-spacing:.5px;background:#ef4444;border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:10px;font-weight:700}.news-title{color:#1f2937;margin:0;font-size:16px;font-weight:600;line-height:1.3}.news-content{color:#6b7280;margin:0 0 10px;padding-left:8px;font-size:14px;line-height:1.5}.news-meta{color:#9ca3af;flex-wrap:wrap;gap:12px;padding-left:8px;font-size:12px;display:flex}.news-author{color:#667eea;font-weight:500}.news-expiry{font-weight:600}.news-expiry.urgent{color:#ef4444}.news-expiry.soon{color:#f59e0b}.news-date{color:#9ca3af}.news-edited{color:#9ca3af;font-style:italic}.news-all-button{cursor:pointer;color:#374151;text-align:center;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;width:calc(100% - 40px);margin:0 20px 16px;padding:10px;font-size:14px;font-weight:500;transition:all .2s;display:block}.news-all-button:hover{background:#e5e7eb;border-color:#d1d5db}.news-collapsed-indicator{cursor:pointer;color:#ef4444;align-items:center;gap:8px;padding:10px 20px 14px;font-size:14px;font-weight:500;animation:.3s fadeInUp;display:flex}@keyframes fadeInUp{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.pulse-dot{background:#ef4444;border-radius:50%;width:8px;height:8px;animation:1.5s infinite pulse}@media (width<=768px){.news-widget{border-radius:16px;padding:18px 16px}.news-widget-header h3{font-size:18px}.news-card{padding:14px 16px}.news-title{font-size:14px}.news-content{font-size:13px}.news-meta{gap:8px;font-size:11px}}@media (width<=480px){.news-widget{border-radius:14px;padding:16px 14px}}.calendar-widget{background:#fff;border-radius:20px;margin-bottom:24px;overflow:hidden;box-shadow:0 8px 24px #0000000f}.calendar-widget.collapsed{box-shadow:0 2px 8px #0000000a}.calendar-widget-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:14px 20px;display:flex}.calendar-header-icon{font-size:20px}.calendar-header-title{color:#1f2937;font-size:20px;font-weight:700}.collapse-arrow{color:#9ca3af;margin-left:auto;transition:transform .2s}.collapse-arrow.collapsed{transform:rotate(-90deg)}.calendar-body{border-top:1px solid #f3f4f6;min-height:260px;display:flex}.calendar-day-panel{border-right:1px solid #f3f4f6;flex-direction:column;gap:12px;width:50%;padding:16px 20px;display:flex}.day-panel-date{align-items:baseline;gap:8px;display:flex}.day-panel-num{color:#1f2937;font-size:36px;font-weight:700;line-height:1}.day-panel-month{color:#6b7280;font-size:15px;font-weight:500}.day-panel-events{flex-direction:column;gap:6px;max-height:180px;display:flex;overflow-y:auto}.day-no-events{color:#9ca3af;padding:10px 0;font-size:13px}.day-event-item{color:#374151;background:#f9fafb;border-left:3px solid #e5e7eb;border-radius:8px;align-items:flex-start;gap:8px;padding:8px 10px;font-size:13px;line-height:1.4;transition:background .15s;display:flex}.day-event-item.news{border-left-color:#ef4444}.day-event-item.duty{border-left-color:#f59e0b}.day-event-item.vacation{border-left-color:#8b5cf6}.day-event-item.task{border-left-color:#10b981}.day-event-item:hover{background:#f3f4f6}.event-icon{flex-shrink:0;font-size:14px}.event-text{min-width:0}.calendar-right{flex-direction:column;width:50%;padding:12px 14px;display:flex}.calendar-nav{color:#1f2937;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;font-weight:600;display:flex}.calendar-nav button{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;display:flex}.calendar-nav button:hover{background:#f3f4f6}.calendar-weekdays{text-align:center;color:#9ca3af;grid-template-columns:repeat(7,1fr);margin-bottom:4px;font-size:10px;font-weight:600;display:grid}.cal-wd.we{color:#ef4444}.calendar-grid{flex-direction:column;flex:1;display:flex}.cal-week{flex:1;grid-template-columns:repeat(7,1fr);display:grid}.cal-cell{cursor:pointer;color:#374151;border-radius:6px;flex-direction:column;justify-content:center;align-items:center;min-height:32px;font-size:12px;transition:background .1s;display:flex;position:relative}.cal-cell:hover{background:#f3f4f6}.cal-cell.empty{cursor:default}.cal-cell.we .cal-num{color:#ef4444}.cal-cell.today{background:#eff6ff;font-weight:700}.cal-cell.selected{background:#dbeafe;box-shadow:inset 0 0 0 2px #3b82f6}.cal-num{font-size:12px;line-height:1}.cal-dots{gap:2px;margin-top:1px;display:flex}.dot{border-radius:50%;width:4px;height:4px}.dot-news{background:#ef4444}.dot-duty{background:#f59e0b}.dot-vacation{background:#8b5cf6}.dot-task{background:#10b981}.calendar-legend{color:#9ca3af;flex-wrap:wrap;gap:10px;margin-top:8px;font-size:10px;display:flex}.calendar-legend span{align-items:center;gap:3px;display:flex}@media (width<=768px){.calendar-body{flex-direction:column}.calendar-day-panel{border-bottom:1px solid #f3f4f6;border-right:none;width:100%;padding:12px 16px}.calendar-right{width:100%;padding:12px 16px}.day-panel-num{font-size:28px}}.calendar-filter{color:#6b7280;cursor:pointer;align-items:center;gap:6px;margin-top:6px;font-size:10px;display:flex}.calendar-filter input{cursor:pointer;width:14px;height:14px}.day-panel-loading{color:#9ca3af;flex-direction:column;align-items:center;gap:8px;padding:20px 0;font-size:13px;display:flex}.dot-task-upcoming{background:#f59e0b}.day-event-item.task-upcoming{border-left-color:#f59e0b}.no-date-tasks{border-top:1px dashed #e5e7eb;margin-top:12px;padding-top:12px}.no-date-tasks-title{color:#6b7280;margin-bottom:6px;font-size:12px;font-weight:600}.calendar-header-left{cursor:pointer;-webkit-user-select:none;user-select:none;flex:1;align-items:center;gap:10px;display:flex}.calendar-add-task-btn{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .2s;display:flex}.calendar-add-task-btn:hover{color:#fff;background:#667eea;border-color:#667eea}.dot-task-overdue{background:#dc2626}.day-event-item.task-overdue{background:#fef2f2;border-left-color:#dc2626}.legend-item{-webkit-user-select:none;user-select:none;transition:opacity .2s;cursor:pointer!important}.legend-item:hover{opacity:.8!important}.day-event-item.completed-task{opacity:.6}.dot-task-completed{background:#9ca3af}.day-event-item.task-completed{border-left-color:#9ca3af}.snail-role-track{background:#0000000a;border-radius:16px;width:100%;height:32px;margin-bottom:8px;position:relative;overflow:visible}.snail-slime{z-index:1;background:linear-gradient(90deg,#a5d6a7,#66bb6a);border-radius:3px;height:3px;transition:width 2s;position:absolute;top:65%;left:0;transform:translateY(-50%)}.snail-role{z-index:3;width:46px;height:32px;transition:left 2s;position:absolute;top:50%;left:0;transform:translate(-50%,-50%)}.snail-role.sleeping{opacity:.6;width:24px;height:18px;transform:translate(-50%,-40%)}.snail-role-svg{width:100%;height:100%;display:block}.snail-tooltip{z-index:10;white-space:nowrap;margin-bottom:8px;animation:.2s tooltipFadeIn;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%)translateY(4px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.snail-tooltip-content{color:#fff;background:#1f2937;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:500;box-shadow:0 4px 12px #00000026}.snail-tooltip-arrow{border-top:6px solid #1f2937;border-left:6px solid #0000;border-right:6px solid #0000;width:0;height:0;margin:0 auto}@media (width<=768px){.snail-role-track{border-radius:14px;height:28px}.snail-role{width:38px;height:26px}.snail-slime{height:4px}.snail-role.sleeping{width:20px;height:15px}}.zzz-text{animation:.8s ease-in-out infinite floatZzz}@keyframes floatZzz{0%{opacity:0;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}to{opacity:0;transform:translateY(-4px)}}.global-header{z-index:100;background:#fff;justify-content:center;width:100%;padding:16px 32px;display:flex;position:sticky;top:0;box-shadow:0 2px 12px #0000000f}.global-header-content{justify-content:space-between;align-items:center;gap:20px;width:100%;max-width:1400px;display:flex}.header-logo{color:#1a1a1a;white-space:nowrap;cursor:pointer;margin:0;font-size:28px;font-weight:700;transition:opacity .2s}.header-logo:hover{opacity:.8}.header-hubs-mini{align-items:center;gap:8px;margin-left:auto;margin-right:16px;display:flex}.mini-hubs-toggle{cursor:pointer;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:30px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.mini-hubs-toggle:hover{background:#e2e8f0;border-color:#cbd5e1;transform:translateY(-1px)}.mini-hubs-toggle:active{transform:translateY(0)}.toggle-arrow{transition:transform .2s}.toggle-arrow.collapsed{transform:rotate(-90deg)}.hub-mini-item{cursor:pointer;color:#334155;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:30px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.hub-mini-item:hover{background:#e2e8f0;border-color:#cbd5e1;transform:translateY(-1px)}.hub-mini-item:active{transform:translateY(0)}.hub-mini-icon{font-size:14px}.hub-mini-count{color:#667eea;text-align:center;background:#fff;border-radius:20px;min-width:22px;padding:2px 7px;font-size:11px;font-weight:700}.hub-mini-item.tasks-mini .hub-mini-count{color:#10b981}.hub-mini-item.total-badge{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#667eea}.hub-mini-item.total-badge .hub-mini-count.total{color:#fff;box-shadow:none;background:#fff3}.header-right{align-items:center;gap:16px;display:flex}@media (width<=768px){.global-header{padding:12px 20px}.global-header-content{flex-wrap:wrap}.header-logo{order:1;font-size:22px}.header-hubs-mini{flex-wrap:wrap;order:2;justify-content:center;width:100%;margin-left:0;margin-right:0}.header-right{order:3}.mini-hubs-toggle{width:28px;height:28px}}@media (width<=480px){.global-header{padding:10px 14px}.header-logo{font-size:18px}.hub-mini-item{padding:4px 10px}.hub-mini-count{min-width:18px;padding:1px 5px;font-size:10px}.mini-hubs-toggle{width:26px;height:26px}}.comments-section{background:#fff;border-radius:20px;margin-top:24px;padding:24px;box-shadow:0 10px 25px -5px #0000001a}.comments-section h3{color:#1f2937;align-items:center;gap:8px;margin:0 0 20px;font-size:18px;font-weight:600;display:flex}.comments-list{max-height:400px;margin-bottom:20px;padding-right:10px;overflow-y:auto}.comment-item.deleted{opacity:.8;background:#f3f4f6;border-left-color:#9ca3af}.comment-item.deleted .comment-text{color:#6b7280;font-style:italic}.comment-header{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;display:flex}.comment-edited{color:#9ca3af;font-size:11px;font-style:italic}.comment-body{margin-bottom:8px}.comment-actions{justify-content:flex-end;gap:8px;display:flex}.edit-button,.delete-button{cursor:pointer;border:none;border-radius:6px;padding:4px 12px;font-size:12px;transition:all .2s}.edit-button{color:#4b5563;background:#e5e7eb}.edit-button:hover{background:#d1d5db}.delete-button{color:#ef4444;background:#fee2e2}.delete-button:hover{background:#fecaca}.comment-edit{width:100%}.edit-textarea{resize:vertical;color:#1f2937;background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;width:100%;min-height:80px;margin-bottom:8px;padding:10px;font-family:inherit;font-size:14px}.edit-textarea:focus{border-color:#667eea;outline:none}.edit-actions{justify-content:flex-end;gap:8px;display:flex}.save-button,.cancel-button{cursor:pointer;border:none;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:500;transition:all .2s}.save-button{color:#fff;background:#10b981}.save-button:hover:not(:disabled){background:#059669}.cancel-button{color:#4b5563;background:#e5e7eb}.cancel-button:hover{background:#d1d5db}.add-comment{flex-direction:column;gap:12px;display:flex}.comment-textarea{resize:vertical;color:#1f2937;background-color:#fff;border:2px solid #e5e7eb;border-radius:12px;width:100%;min-height:100px;padding:12px;font-family:inherit;font-size:14px;transition:all .2s;box-shadow:inset 0 2px 4px #00000005}.comment-textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a,inset 0 2px 4px #00000005}.comment-textarea:disabled{cursor:not-allowed;background-color:#f3f4f6}.add-comment-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:30px;align-self:flex-end;padding:10px 24px;font-size:14px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.add-comment-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.add-comment-button:disabled{opacity:.5;cursor:not-allowed}.no-comments{text-align:center;color:#9ca3af;background:#f9fafb;border-radius:12px;padding:30px;font-size:14px}@media (width<=768px){.comments-section{padding:16px}.comment-header{flex-direction:column;align-items:flex-start;gap:4px}.comment-actions{flex-wrap:wrap}.add-comment-button{width:100%}}.loading-comments{color:#667eea;justify-content:center;align-items:center;gap:12px;padding:30px;display:flex}.spinner-small{border:2px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin}.regions-hub,.task-detail{background:linear-gradient(135deg,#f5f7fa 0%,#e4e8f0 100%);flex-direction:column;width:100%;min-height:100vh;display:flex}.regions-header{z-index:100;background:#fff;justify-content:center;width:100%;padding:20px 40px;display:flex;position:sticky;top:0;box-shadow:0 4px 20px #00000014}.header-content{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;width:100%;max-width:1400px;display:flex}.regions-header h1{color:#1a1a1a;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:28px;font-weight:700}.header-actions{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toggle-view-button,.check-email-button,.back-button,.close-button{cursor:pointer;border:none;border-radius:12px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #0000001a}.toggle-view-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.check-email-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.check-email-button:disabled{opacity:.7;cursor:not-allowed}.close-button{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);justify-content:center;align-items:center;width:40px;height:40px;padding:0;font-size:18px;display:flex}.close-button:hover{transform:scale(1.1)}.regions-content,.task-detail-content{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:40px}.section-title{color:#1f2937;margin:0 0 20px;font-size:20px;font-weight:600}.tasks-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-bottom:30px;display:grid}.task-card{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:20px;flex-direction:column;gap:12px;height:100%;padding:20px;transition:all .3s;display:flex;box-shadow:0 10px 25px -5px #0000001a}.task-card:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 20px 35px -10px #0003}.card-status{border-radius:20px;align-self:flex-start;margin-bottom:8px;padding:6px 12px;font-size:12px;font-weight:600;display:inline-block}.status-new{color:#92400e;background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%)}.status-progress{color:#1e40af;background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%)}.status-completed{color:#166534;background:linear-gradient(135deg,#dcfce7 0%,#bbf7d0 100%)}.card-order{color:#1f2937;font-size:16px;font-weight:600}.card-department,.card-contractor,.card-initiator,.card-comment,.card-supplier,.card-city,.card-amount{color:#4b5563;margin:4px 0;font-size:14px;line-height:1.5}.card-author,.card-date{color:#6b7280;align-items:center;gap:6px;margin:4px 0;font-size:13px;display:flex}.card-author .label,.card-date .label{color:#9ca3af;text-transform:uppercase;font-size:11px;font-weight:500}.label{color:#6b7280;margin-right:6px;font-weight:500}.card-items-count{color:#667eea;align-items:center;gap:6px;margin-top:8px;font-size:14px;font-weight:500;display:flex}.card-stats{border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:16px;margin-top:auto;padding-top:12px;display:flex}.card-comments-count{color:#6b7280;white-space:nowrap;align-items:center;gap:6px;font-size:14px;font-weight:500;display:flex}.card-files-count{white-space:nowrap;color:#6b7280;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.load-more-container{justify-content:center;margin-top:30px;display:flex}.load-more-button{color:#667eea;cursor:pointer;background:#fff;border:2px solid #667eea;border-radius:30px;padding:12px 30px;font-size:16px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #0000001a}.load-more-button:hover{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-color:#0000;transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.no-tasks{text-align:center;color:#6b7280;background:#fff;border-radius:20px;padding:60px;font-size:18px;box-shadow:0 10px 25px -5px #0000001a}.loading-indicator{color:#667eea;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.task-status-badge{border-radius:30px;margin-bottom:30px;padding:10px 20px;font-size:16px;font-weight:600;display:inline-block}.task-info-grid{background:#fff;border-radius:20px;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:30px;padding:30px;display:grid;box-shadow:0 10px 25px -5px #0000001a}.info-item{flex-direction:column;gap:6px;display:flex}.info-item.full-width{grid-column:1/-1}.info-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;font-size:14px;font-weight:500}.info-value{color:#1f2937;font-size:16px;line-height:1.5}.task-actions{flex-wrap:wrap;justify-content:flex-end;gap:16px;margin-top:30px;margin-bottom:30px;display:flex}.action-button{cursor:pointer;border:none;border-radius:12px;padding:14px 28px;font-size:16px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #0000001a}.action-button.take{color:#fff;background:linear-gradient(135deg,#10b981 0%,#059669 100%)}.action-button.cancel{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%)}.action-button.complete{color:#fff;background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%)}.action-button.reassign,.action-button.edit{color:#fff;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%)}.action-button.delete{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%)}.action-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #00000026}.action-button:disabled{opacity:.5;cursor:not-allowed}.search-section{max-width:1400px;margin:0 auto;padding:20px 40px 0}.search-container{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.search-input{color:#1f2937;background:#fff;border:2px solid #e5e7eb;border-radius:30px;flex:1;padding:12px 20px;font-family:inherit;font-size:15px;transition:all .2s}.search-input::placeholder{color:#9ca3af;opacity:1}.search-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.search-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:30px;padding:12px 28px;font-size:15px;font-weight:600;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.search-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.clear-search-button{color:#4b5563;cursor:pointer;background:#f3f4f6;border:none;border-radius:30px;padding:12px 24px;font-size:15px;font-weight:500;transition:all .2s}.clear-search-button:hover{background:#e5e7eb;transform:translateY(-1px)}.search-info{color:#166534;background:#f0fdf4;border-radius:20px;margin-top:12px;padding:8px 16px;font-size:14px;font-weight:500;display:inline-block}.items-section{background:#fff;border-radius:20px;margin-bottom:24px;padding:24px;overflow-x:auto;box-shadow:0 10px 25px -5px #0000001a}.items-section h3{color:#1f2937;margin:0 0 16px;font-size:18px;font-weight:600}.items-table-container{border:1px solid #e5e7eb;border-radius:12px;overflow-x:auto}.items-table{border-collapse:collapse;width:100%;min-width:1200px;font-size:14px}.items-table th{text-align:left;color:#4b5563;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;background:#f9fafb;border-bottom:2px solid #e5e7eb;padding:12px 16px;font-size:12px;font-weight:600}.items-table td{color:#1f2937;vertical-align:top;border-bottom:1px solid #e5e7eb;padding:12px 16px}.first-location{background-color:#fff}.additional-location{background-color:#fafafa}.code-cell,.article-cell,.name-cell,.serial-cell,.quantity-cell,.unit-cell{border-right:1px solid #e5e7eb;font-weight:500}.quantity-cell,.storage-balance{text-align:right;font-weight:600}.quantity-cell{color:#059669}.storage-balance{color:#7c3aed}.storage-warehouse,.storage-cell,.storage-balance{padding:12px 16px}.storage-warehouse{color:#1f2937;font-weight:500}.storage-cell{color:#6b7280}.no-items{text-align:center;color:#9ca3af;padding:32px;font-style:italic}.attachments-section{background:#fff;border-radius:20px;margin-bottom:24px;padding:24px;box-shadow:0 10px 25px -5px #0000001a}.attachments-section h3{color:#1f2937;margin:0 0 16px;font-size:18px;font-weight:600}.attachments-list{flex-direction:column;gap:10px;display:flex}.attachment-item{cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;transition:all .2s;display:flex}.attachment-item:hover{background:#f3f4f6;border-color:#667eea;transform:translate(4px)}.attachment-name{color:#1f2937;flex:1;font-size:14px;font-weight:500}.attachment-buttons{gap:8px;display:flex}.view-button{cursor:pointer;color:#4b5563;background:#e5e7eb;border:none;border-radius:6px;padding:6px 12px;font-size:12px;transition:all .2s}.view-button:hover{color:#fff;background:#667eea}.download-button{cursor:pointer;color:#4b5563;background:#e5e7eb;border:none;border-radius:6px;padding:6px 12px;font-size:12px;transition:all .2s}.download-button:hover{color:#fff;background:#10b981}.photos-section{background:#fff;border-radius:20px;margin-bottom:24px;padding:24px}.photos-section h3{color:#1f2937;margin:0 0 16px;font-size:18px;font-weight:600}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;display:grid}.photos-grid .photo-item{cursor:pointer;aspect-ratio:1;border:2px solid #e5e7eb;border-radius:12px;transition:transform .2s;overflow:hidden}.photos-grid .photo-item:hover{border-color:#667eea;transform:scale(1.02)}.photo-thumbnail{object-fit:cover;width:100%;height:100%}.photo-placeholder{background:#f3f4f6;border-radius:12px;justify-content:center;align-items:center;width:100%;height:100%;min-height:100px;display:flex}.spinner-small{border:2px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;width:24px;height:24px;animation:.8s linear infinite spin;display:inline-block}.card-photo{margin:12px 0;position:relative}.photo-mini{object-fit:cover;border:1px solid #e5e7eb;border-radius:12px;width:100%;height:150px}.photo-count{color:#fff;background:#0009;border-radius:20px;padding:4px 8px;font-size:12px;position:absolute;bottom:8px;right:8px}.card-photos-count{color:#6b7280;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.modal-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:8px;font-size:24px;position:absolute;top:-40px;right:0}.modal-nav button{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;width:40px;height:40px;font-size:24px;transition:all .2s}.modal-nav button:hover:not(:disabled){background:#fff6}.gallery-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b5cf6 0%,#6d28d9 100%);border:none;border-radius:12px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s}.gallery-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #8b5cf64d}.create-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:12px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s}.create-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}@media (width<=1024px){.regions-header{padding:16px 24px}.regions-content,.task-detail-content{padding:24px}.tasks-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.task-info-grid{grid-template-columns:1fr;padding:24px}.items-table{min-width:1000px}}@media (width<=768px){.regions-header{padding:16px 20px}.header-content{text-align:center;flex-direction:column;align-items:stretch}.header-actions{flex-direction:column;width:100%}.toggle-view-button,.check-email-button,.back-button,.close-button{width:100%}.close-button{width:100%;height:auto;padding:10px}.regions-content,.task-detail-content{padding:20px}.tasks-grid{grid-template-columns:1fr}.task-info-grid{padding:20px}.task-actions{flex-direction:column}.action-button{width:100%}.items-section{padding:16px}.items-table{min-width:900px}.search-section{padding:16px 20px 0}.search-container{flex-direction:column}.search-input,.search-button,.clear-search-button{border-radius:12px;width:100%}.search-info{text-align:center;width:100%}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.photo-mini{height:120px}.modal-image{max-width:95vw;max-height:70vh}.card-stats{flex-direction:column;gap:8px}.attachment-item{flex-wrap:wrap}.attachment-name{order:1;width:100%}.attachment-size{order:2}.attachment-buttons{order:3;margin-left:auto}.view-button,.download-button{padding:4px 10px;font-size:11px}}@media (width<=480px){.regions-header h1{font-size:24px}.regions-content,.task-detail-content{padding:16px}.no-tasks{padding:40px 20px;font-size:16px}.items-table{min-width:800px}}.calculator-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);border:none;border-radius:12px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s}.calculator-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #f59e0b4d}.hub-toolbar{background:#fff;border-radius:16px;flex-wrap:wrap;gap:12px;margin-bottom:24px;padding:12px 16px;display:flex;box-shadow:0 2px 8px #0000000a}.hub-toolbar button{cursor:pointer;border:none;border-radius:10px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.toggle-view-button{color:#fff;background:#6b7280}.toggle-view-button:hover{background:#4b5563;transform:translateY(-1px)}.check-email-button{color:#fff;background:#10b981}.check-email-button:hover{background:#059669;transform:translateY(-1px)}.gallery-button{color:#fff;background:#8b5cf6}.gallery-button:hover{background:#7c3aed;transform:translateY(-1px)}.calculator-button{color:#fff;background:#f59e0b}.calculator-button:hover{background:#d97706;transform:translateY(-1px)}@media (width<=768px){.hub-toolbar{flex-direction:column;gap:8px}.hub-toolbar button{width:100%}}.card-comment{background:#f3f4f6;border-radius:10px;margin:8px 0;padding:10px}.task-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;-webkit-overflow-scrolling:touch;background:#00000080;justify-content:center;align-items:flex-start;padding:20px;animation:.2s overlayFadeIn;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.task-modal{background:#fff;border-radius:20px;width:100%;max-width:1000px;margin:20px auto;animation:.3s modalSlideIn;position:relative;overflow:hidden;box-shadow:0 25px 60px #0000004d}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.task-modal-header{z-index:10;background:#fff;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.task-modal-header h2{color:#1f2937;margin:0;font-size:20px}.task-modal-close{cursor:pointer;color:#4b5563;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:all .2s;display:flex}.task-modal-close:hover{color:#fff;background:#ef4444}.task-modal-body{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 140px);padding:24px;overflow-y:auto}@media (width<=768px){.task-modal-overlay{align-items:flex-start;padding:0}.task-modal{border-radius:0 0 20px 20px;width:100%;max-height:95vh;margin:0;animation:.3s modalSlideDown}@keyframes modalSlideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.task-modal-body{max-height:calc(95vh - 70px);padding:16px}.task-modal-header{border-radius:0;padding:12px 16px}.task-modal-header h2{font-size:18px}}.calculator-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2000;background:#0006;justify-content:center;align-items:flex-start;padding:40px 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.calculator-modal{background:#fff;border-radius:16px;flex-direction:column;width:100%;max-width:700px;max-height:85vh;display:flex;box-shadow:0 20px 60px #0003}.calculator-header{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.calculator-header h2{margin:0;font-size:18px}.close-btn{cursor:pointer;background:#f3f4f6;border:none;border-radius:50%;width:30px;height:30px;font-size:16px}.close-btn:hover{color:#fff;background:#ef4444}.calculator-body{flex:1;padding:20px;overflow-y:auto}.calculator-form-section{margin-bottom:24px}.calculator-form-section h3,.calculator-results-section h3{color:#1f2937;margin:0 0 12px;font-size:15px}.calc-form{flex-direction:column;gap:12px;display:flex}.form-row{gap:10px;display:flex}.dimensions-row{grid-template-columns:1fr 1fr 1fr 1fr;gap:8px;display:grid}.form-group{flex:1}.calc-input{border:2px solid #e5e7eb;border-radius:8px;width:100%;padding:8px 12px;font-size:14px;transition:border-color .2s}.calc-input:focus{border-color:#667eea;outline:none}.companies-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;display:grid}.company-checkbox{cursor:pointer;border:2px solid #e5e7eb;border-radius:10px;align-items:center;gap:8px;padding:10px 12px;font-size:13px;transition:all .2s;display:flex}.company-checkbox:hover{border-color:#667eea}.company-checkbox.selected{background:#f0f4ff;border-color:#667eea}.company-checkbox input{display:none}.company-icon{font-size:18px}.company-name{font-weight:500}.calc-error{color:#ef4444;background:#fee2e2;border-radius:8px;padding:8px 12px;font-size:13px}.calc-submit-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;padding:12px;font-size:15px;font-weight:600;transition:transform .2s}.calc-submit-btn:hover{transform:translateY(-1px)}.calc-submit-btn:disabled{opacity:.6;cursor:not-allowed}.calc-empty{color:#9ca3af;flex-direction:column;align-items:center;gap:8px;padding:30px;font-size:13px;display:flex}.empty-icon{font-size:32px}.empty-hint{font-size:11px}.calc-cards{flex-direction:column;gap:10px;display:flex}.calc-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:14px}.calc-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.calc-city{color:#1f2937;font-size:14px;font-weight:600}.calc-status{border-radius:12px;padding:3px 8px;font-size:11px;font-weight:600}.calc-status.pending{color:#92400e;background:#fef3c7}.calc-status.processing{color:#1e40af;background:#dbeafe}.calc-status.completed{color:#166534;background:#dcfce7}.calc-status.error{color:#ef4444;background:#fee2e2}.calc-card-info{color:#6b7280;gap:16px;margin-bottom:4px;font-size:12px;display:flex}.calc-card-date{color:#9ca3af;font-size:11px}.calc-results{margin-top:10px;font-size:12px}.calc-result-text{color:#1f2937;white-space:pre-line;line-height:1.4}.calc-errors{margin-top:8px}.calc-error-item{color:#ef4444;background:#fee2e2;border-radius:6px;margin-top:4px;padding:4px 8px;font-size:11px}@media (width<=768px){.calculator-overlay{align-items:flex-end;padding:0}.calculator-modal{border-radius:16px 16px 0 0;max-width:100%;max-height:90vh}.dimensions-row,.companies-grid{grid-template-columns:1fr 1fr}}.calc-company-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:12px;transition:all .2s;overflow:hidden}.calc-company-card:hover{box-shadow:0 2px 8px #00000014}.calc-company-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;border-left:4px solid;align-items:center;gap:10px;padding:12px 14px;display:flex}.calc-company-icon{font-size:20px}.calc-company-name{color:#1f2937;font-size:15px;font-weight:700}.calc-company-content{padding:12px 14px}.calc-result-text{color:#374151;font-size:13px;line-height:1.5}.calc-result-line{margin:4px 0}.calc-result-title{color:#1f2937;margin-top:8px;margin-bottom:6px;font-size:14px;font-weight:700}.calc-result-title:first-child{margin-top:0}.calc-result-bullet{color:#4b5563;padding-left:16px}.calc-result-bold{color:#1f2937;margin-top:8px;margin-bottom:4px;font-weight:700}.calc-result-simple{flex-direction:column;gap:8px;display:flex}.calc-result-simple-row{border-bottom:1px dashed #f3f4f6;justify-content:space-between;align-items:center;padding:6px 0;display:flex}.calc-result-simple-row:last-child{border-bottom:none}.calc-result-simple-label{color:#6b7280;font-size:13px;font-weight:600}.calc-result-simple-value{color:#059669;background:#ecfdf5;border-radius:20px;padding:4px 10px;font-size:14px;font-weight:700}.calc-errors{background:#fef2f2;border:1px solid #fee2e2;border-radius:10px;margin-top:12px;padding:10px}.calc-errors-title{color:#dc2626;margin-bottom:8px;font-size:12px;font-weight:600}.calc-error-item{color:#b91c1c;border-bottom:1px solid #fee2e2;padding:4px 0;font-size:12px}.calc-error-item:last-child{border-bottom:none}@media (width<=640px){.calc-company-header,.calc-company-content{padding:10px 12px}.calc-result-simple-row{flex-direction:column;align-items:flex-start;gap:4px}}.create-arrival{background:linear-gradient(135deg,#f5f7fa 0%,#e4e8f0 100%);flex-direction:column;min-height:100vh;display:flex}.arrival-header{background:#fff;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:20px 40px;display:flex;box-shadow:0 4px 20px #00000014}.arrival-header h1{color:#1f2937;margin:0;font-size:24px;font-weight:600}.back-button,.close-button{cursor:pointer;border:none;border-radius:12px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s}.back-button{color:#fff;background:linear-gradient(135deg,#6b7280 0%,#4b5563 100%)}.close-button{color:#fff;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%)}.create-arrival-content{flex:1;width:100%;max-width:800px;margin:0 auto;padding:40px}.arrival-form{background:#fff;border-radius:24px;padding:32px;box-shadow:0 20px 40px -15px #0000001a}.required{color:#ef4444}.form-input,.form-textarea{border:2px solid #e5e7eb;border-radius:12px;width:100%;padding:12px 16px;font-family:inherit;font-size:15px;transition:all .2s}.form-input:focus,.form-textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.photo-buttons{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.photo-button{cursor:pointer;border:none;border-radius:12px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.photo-button.upload{color:#4b5563;background:#e5e7eb}.photo-button.upload:hover{background:#d1d5db}.photo-button.camera{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.photo-button.camera:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.photo-preview{margin-top:16px}.photo-preview h4{color:#6b7280;margin:0 0 12px;font-size:14px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;display:grid}.photo-item{aspect-ratio:1;position:relative}.photo-thumb{object-fit:cover;border:2px solid #e5e7eb;border-radius:12px;width:100%;height:100%}.remove-photo{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex;position:absolute;top:-8px;right:-8px}.submit-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#10b981 0%,#059669 100%);border:none;border-radius:12px;width:100%;margin-top:16px;padding:14px;font-size:16px;font-weight:600;transition:all .3s}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #10b9814d}.submit-button:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#ef4444;text-align:center;background:#fee2e2;border-radius:12px;margin-bottom:20px;padding:12px}@media (width<=768px){.arrival-header{padding:16px 20px}.create-arrival-content,.arrival-form{padding:20px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}.not-found-container{background:linear-gradient(135deg,#f5f7fa 0%,#e4e8f0 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.not-found-content{text-align:center;background:#fff;border-radius:20px;max-width:500px;padding:60px;box-shadow:0 10px 25px #0000001a}.not-found-content h1{color:#667eea;margin:0;font-size:80px;line-height:1}.not-found-content h2{color:#1f2937;margin:20px 0 10px;font-size:24px}.not-found-content p{color:#6b7280;margin-bottom:30px}.not-found-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;padding:12px 30px;font-size:16px;font-weight:600;transition:all .3s}.not-found-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}@media (width<=480px){.not-found-content{padding:40px 20px}.not-found-content h1{font-size:60px}.not-found-content h2{font-size:20px}}.user-settings{background:#f3f4f6;min-height:100vh;padding-bottom:40px}.settings-header{z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000000f}.settings-header h1{color:#1f2937;margin:0;font-size:20px}.settings-message{border-radius:8px;margin:16px 24px;padding:12px 16px;font-size:14px}.settings-message.success{color:#065f46;background:#ecfdf5;border:1px solid #a7f3d0}.settings-message.error{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.settings-tabs{background:#fff;border-radius:12px 12px 0 0;gap:0;margin:0 24px;display:flex;overflow:hidden;box-shadow:0 1px 3px #0000000f}.tab-button{cursor:pointer;color:#6b7280;white-space:nowrap;background:#fff;border:none;border-bottom:2px solid #0000;flex:1;padding:14px 16px;font-size:14px;font-weight:500;transition:all .2s}.tab-button:hover{color:#374151;background:#f9fafb}.tab-button.active{color:#2563eb;background:#eff6ff;border-bottom-color:#2563eb}.settings-content{background:#fff;border-radius:0 0 12px 12px;margin:0 24px;padding:24px;box-shadow:0 1px 3px #0000000f}.section-description{color:#6b7280;margin-bottom:20px;font-size:14px}.password-section h2{color:#1f2937;margin:0 0 8px;font-size:20px}.password-form{max-width:400px}.form-input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-input:disabled{cursor:not-allowed;background:#f3f4f6}.save-password-button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;width:100%;padding:12px;font-size:14px;font-weight:500;transition:background .2s}.save-password-button:hover{background:#1d4ed8}.save-password-button:disabled{cursor:not-allowed;background:#93c5fd}.month-selector,.year-selector{background:#f9fafb;border-radius:8px;justify-content:center;align-items:center;gap:16px;margin-bottom:20px;padding:12px;display:flex}.month-nav-button,.year-nav-button{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;transition:all .2s;display:flex}.month-nav-button:hover,.year-nav-button:hover{background:#f3f4f6;border-color:#9ca3af}.month-title,.year-title{color:#1f2937;text-align:center;min-width:180px;font-size:18px;font-weight:600}.duty-calendar{border:1px solid #e5e7eb;border-radius:12px;margin-bottom:16px;overflow:hidden;box-shadow:0 1px 3px #0000000f}.duty-calendar-header{background:#f8fafc;border-bottom:1px solid #e5e7eb;grid-template-columns:repeat(7,1fr);display:grid}.calendar-header-cell{text-align:center;color:#64748b;text-transform:uppercase;letter-spacing:.5px;background:#f8fafc;padding:12px 4px;font-size:13px;font-weight:600}.calendar-header-cell.weekend-header{color:#ef4444}.duty-calendar-body{flex-direction:column;display:flex}.calendar-week{border-bottom:1px solid #f1f5f9;grid-template-columns:repeat(7,1fr);display:grid}.calendar-week:last-child{border-bottom:none}.calendar-day{background:#fff;border-right:1px solid #f1f5f9;flex-direction:column;gap:4px;min-height:90px;padding:8px 6px;transition:background .2s;display:flex;position:relative}.calendar-day:last-child{border-right:none}.calendar-day.other-month{background:#fafbfc}.calendar-day.weekend{background:#fffbeb}.calendar-day.weekend.other-month{background:#fefce8}.calendar-day.today{border-radius:0;box-shadow:inset 0 0 0 2px #3b82f6;background:#eff6ff!important}.calendar-day.has-duty{background:#f0fdf4}.calendar-day.my-duty{background:#dbeafe!important}.calendar-day.today.my-duty{box-shadow:inset 0 0 0 2px #2563eb;background:#bfdbfe!important}.day-number{color:#1f2937;font-size:14px;font-weight:500;display:block}.calendar-day.other-month .day-number{color:#cbd5e1}.calendar-day.weekend .day-number{color:#ef4444}.calendar-day.weekend.other-month .day-number{color:#fca5a5}.today-circle{color:#fff;background:#2563eb;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:600;display:inline-flex}.duty-names{flex-direction:column;gap:2px;margin-top:2px;display:flex}.duty-name{color:#166534;white-space:nowrap;text-overflow:ellipsis;cursor:default;background:#dcfce7;border-radius:4px;padding:2px 6px;font-size:11px;font-weight:500;line-height:1.4;display:block;overflow:hidden}.duty-name.my-duty-name{color:#fff;background:#2563eb;font-weight:600;box-shadow:0 1px 3px #2563eb4d}.vacation-table-container{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:16px;overflow-x:auto}.vacation-table{border-collapse:collapse;width:100%;min-width:900px;font-size:13px}.vacation-table thead{background:#f9fafb}.vacation-table th{text-align:center;color:#374151;white-space:nowrap;border-bottom:1px solid #e5e7eb;padding:10px 8px;font-weight:600}.vacation-table .name-col{text-align:left;padding-left:16px}.vacation-table td{text-align:center;vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:6px 4px}.vacation-table td.name-col{color:#1f2937;white-space:nowrap;padding:8px 16px;font-weight:500}.vacation-table tr.current-user-row{background:#f0f9ff}.vacation-table tr.current-user-row:hover{background:#e0f2fe}.current-user-name{color:#2563eb;font-weight:600}.vacation-cell{min-width:70px}.vacation-cell.has-vacation{background:#fef9c3;padding:4px}.vacation-cell-content{flex-direction:column;gap:2px;display:flex}.vacation-range{color:#1f2937;white-space:nowrap;cursor:default;background:#fdba74;border-radius:4px;padding:2px 4px;font-size:11px}.vacation-range.full-month{color:#fff;background:#f97316;font-weight:500}.vacation-range.my-vacation{color:#fff;background:#3b82f6;font-weight:500}.no-data{text-align:center;color:#9ca3af;padding:40px}.legend{background:#f9fafb;border-radius:12px;flex-wrap:wrap;gap:16px;margin-top:8px;padding:16px;display:flex}.legend-item{color:#6b7280;align-items:center;gap:8px;font-size:13px;display:flex}.legend-sample{border:1px solid #0000000f;border-radius:4px;flex-shrink:0;width:20px;height:20px}.weekend-sample{background:#fffbeb;border-color:#fde68a}.today-sample{background:#eff6ff;border-color:#93c5fd}.my-duty-sample{background:#dbeafe;border-color:#93c5fd}.other-duty-sample{background:#f0fdf4;border-color:#bbf7d0}.vacation-legend-sample{border-radius:4px;flex-shrink:0;width:28px;height:16px}.my-vacation-sample{background:#3b82f6}.other-vacation-sample{background:#fdba74}.back-button{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:8px;padding:8px 16px;font-size:14px;transition:background .2s}.back-button:hover{background:#e5e7eb}.close-button{cursor:pointer;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;transition:background .2s;display:flex}.close-button:hover{background:linear-gradient(135deg,#852424 0%,#af0c0c 100%)}.loading-container{color:#6b7280;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px;display:flex}@media (width<=768px){.settings-header{padding:12px 16px}.settings-header h1{font-size:18px}.settings-tabs{flex-direction:column;margin:0 12px}.tab-button{border-bottom:1px solid #e5e7eb}.tab-button.active{border-bottom-color:#2563eb}.settings-content{margin:0 12px;padding:16px}.month-selector,.year-selector{flex-wrap:wrap;gap:8px}.calendar-day{min-height:70px;padding:4px 3px}.day-number{font-size:12px}.duty-name{padding:1px 4px;font-size:10px}.calendar-header-cell{padding:8px 2px;font-size:11px}.vacation-table{font-size:11px}}@media (width<=480px){.calendar-day{min-height:60px;padding:2px}.duty-name{padding:1px 3px;font-size:9px}.day-number{font-size:11px}}.notifications-section h2{color:#1f2937;margin:0 0 8px;font-size:20px}.notification-settings-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:16px;margin-bottom:20px;padding:24px}.notification-info{gap:16px;margin-bottom:20px;display:flex}.notification-icon-large{background:#fff;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;font-size:40px;display:flex;box-shadow:0 2px 8px #0000000f}.notification-details h3{color:#1f2937;margin:0 0 6px;font-size:18px}.notification-details p{color:#6b7280;margin:0;font-size:14px;line-height:1.5}.notification-status{margin-bottom:16px}.status-badge{border-radius:30px;align-items:center;gap:8px;padding:8px 16px;font-size:14px;font-weight:600;display:inline-flex}.status-badge.enabled{color:#065f46;background:#ecfdf5}.status-badge.disabled{color:#991b1b;background:#fef2f2}.status-dot{border-radius:50%;width:8px;height:8px}.status-badge.enabled .status-dot{background:#10b981;box-shadow:0 0 6px #10b98180}.status-badge.disabled .status-dot{background:#ef4444}.notification-toggle-button{cursor:pointer;border:none;border-radius:10px;width:100%;padding:14px;font-size:15px;font-weight:600;transition:all .2s}.notification-toggle-button.enable{color:#fff;background:#2563eb}.notification-toggle-button.enable:hover{background:#1d4ed8}.notification-toggle-button.disable{color:#991b1b;background:#fee2e2}.notification-toggle-button.disable:hover{background:#fecaca}.notification-toggle-button:disabled{opacity:.6;cursor:not-allowed}.notification-hint{color:#1e40af;background:#eff6ff;border-radius:10px;gap:10px;margin-top:16px;padding:12px 16px;font-size:13px;line-height:1.5;display:flex}.hint-icon{flex-shrink:0;font-size:18px}.notification-hubs-info{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:24px}.notification-hubs-info h3{color:#1f2937;margin:0 0 16px;font-size:16px}.hubs-list{flex-wrap:wrap;gap:10px;display:flex}.hub-notification-item{color:#374151;background:#f3f4f6;border-radius:10px;align-items:center;gap:8px;padding:8px 14px;font-size:14px;font-weight:500;display:flex}.hub-notification-icon{font-size:18px}@media (width<=768px){.settings-header{padding:12px 14px}.settings-header h1{font-size:17px}.settings-message{margin:12px 14px;padding:10px 12px;font-size:13px}.settings-tabs{border-radius:12px 12px 0 0;flex-flow:wrap;margin:0 12px}.tab-button{border-bottom:1px solid #e5e7eb;flex:auto;min-width:70px;padding:10px 12px;font-size:12px}.tab-button.active{border-bottom-color:#2563eb}.settings-content{border-radius:0 0 12px 12px;margin:0 12px;padding:16px 14px}.password-form{max-width:100%}.month-selector,.year-selector{gap:10px;padding:10px}.month-nav-button,.year-nav-button{width:36px;height:36px;font-size:14px}.month-title,.year-title{min-width:140px;font-size:15px}.calendar-day{gap:2px;min-height:65px;padding:4px 3px}.day-number{font-size:11px}.calendar-header-cell{padding:8px 2px;font-size:10px}.duty-name{padding:1px 3px;font-size:9px}.vacation-table{min-width:600px;font-size:11px}.vacation-table th{padding:8px 4px;font-size:10px}.vacation-table td{padding:4px 2px}.vacation-table td.name-col{padding:6px 10px;font-size:11px}.vacation-range{font-size:9px}.legend{flex-direction:column;gap:10px;padding:12px}.notification-info{text-align:center;flex-direction:column;align-items:center}.notification-icon-large{width:48px;height:48px;font-size:28px}.hubs-list{gap:6px}.hub-notification-item{padding:6px 10px;font-size:12px}}@media (width<=480px){.settings-header{padding:10px 12px}.settings-header h1{font-size:16px}.settings-tabs{-webkit-overflow-scrolling:touch;border-radius:10px 10px 0 0;flex-wrap:nowrap;margin:0 8px;overflow-x:auto}.tab-button{white-space:nowrap;flex:none;padding:10px 14px;font-size:11px}.settings-content{margin:0 8px;padding:14px 12px}.calendar-day{min-height:55px;padding:2px}.day-number{font-size:10px}.calendar-header-cell{padding:6px 1px;font-size:9px}.duty-name{padding:1px 2px;font-size:8px}.duty-calendar,.vacation-table-container{border-radius:8px}.vacation-table{min-width:500px;font-size:10px}.vacation-range{font-size:8px}.notification-settings-card{padding:16px}.notification-toggle-button{padding:12px;font-size:14px}.legend-item{font-size:11px}}.snail-settings-section{padding:20px 0}.snail-settings-section h2{color:#1f2937;margin:0 0 8px;font-size:20px}.snail-settings-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:16px;margin-top:16px;padding:24px}.setting-item{margin-bottom:20px}.setting-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.setting-icon{font-size:24px}.setting-title{color:#1f2937;font-size:16px;font-weight:600}.setting-description{color:#6b7280;margin-top:8px;font-size:13px;line-height:1.4}.toggle-switch{width:52px;height:28px;display:inline-block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{cursor:pointer;background-color:#ccc;border-radius:28px;transition:all .3s;position:absolute;inset:0}.toggle-slider:before{content:"";background-color:#fff;border-radius:50%;width:22px;height:22px;transition:all .3s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background-color:#667eea}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.setting-divider{background:#e5e7eb;height:1px;margin:20px 0}.radio-group{flex-direction:column;gap:12px;margin-top:8px;display:flex}.radio-option{cursor:pointer;background:#fff;border:2px solid #e5e7eb;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;transition:all .2s;display:flex}.radio-option:hover{background:#fefce8;border-color:#cbd5e1}.radio-option.selected{background:#f0f4ff;border-color:#667eea}.radio-option input{cursor:pointer;accent-color:#667eea;width:18px;height:18px}.radio-icon{font-size:24px}.radio-text{flex:1}.radio-title{color:#1f2937;font-size:15px;font-weight:600;display:block}.radio-description{color:#6b7280;margin-top:2px;font-size:12px;display:block}.setting-info-box{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:12px;align-items:flex-start;gap:14px;padding:16px;display:flex}.setting-info-box .info-icon{font-size:28px}.setting-info-box .info-text{color:#92400e;font-size:13px;line-height:1.5}.setting-info-box .info-text strong{font-weight:700}@media (width<=768px){.snail-settings-card{padding:16px}.radio-option{padding:12px}.radio-icon{font-size:20px}.radio-title{font-size:14px}}.idle-timeout-control{flex-wrap:wrap;align-items:center;gap:20px;margin-top:8px;display:flex}.idle-timeout-slider{appearance:none;background:#e5e7eb;border-radius:3px;outline:none;flex:1;min-width:200px;height:6px}.idle-timeout-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#667eea;border:none;border-radius:50%;width:18px;height:18px;box-shadow:0 2px 6px #0003}.idle-timeout-slider::-webkit-slider-thumb:hover{background:#5a67d8;transform:scale(1.2)}.idle-timeout-slider::-moz-range-thumb{cursor:pointer;background:#667eea;border:none;border-radius:50%;width:18px;height:18px}.idle-timeout-value{color:#667eea;text-align:center;background:#f0f4ff;border-radius:20px;min-width:80px;padding:4px 12px;font-size:14px;font-weight:600}.news-page{background:#f3f4f6;min-height:100vh;padding-bottom:40px}.news-page-header{z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000000f}.news-page-header h1{color:#1f2937;margin:0;font-size:20px}.news-filters{background:#fff;border-top:1px solid #f3f4f6;flex-wrap:wrap;gap:8px;padding:16px 24px;display:flex}.filter-button{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px 16px;font-size:14px;transition:all .2s}.filter-button:hover{background:#f9fafb}.filter-button.active{color:#fff;background:#667eea;border-color:#667eea}.news-page-content{max-width:900px;margin:0 auto;padding:24px}.news-grid{flex-direction:column;gap:14px;display:flex}.news-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:20px 22px;transition:all .2s;position:relative}.news-card:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 12px #0000000f}.news-card.unread{background:#eff6ff;border-color:#bfdbfe}.news-card.important{background:#fef2f2;border-left:4px solid #ef4444}.news-card-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.important-badge{color:#fff;background:#ef4444;border-radius:6px;flex-shrink:0;padding:3px 10px;font-size:11px;font-weight:700}.news-card-title{color:#1f2937;margin:0;font-size:18px;font-weight:600}.news-card-content{color:#6b7280;margin:0 0 12px;font-size:14px;line-height:1.5}.news-card-meta{color:#9ca3af;flex-wrap:wrap;gap:14px;font-size:13px;display:flex}.news-card-actions{opacity:0;gap:6px;transition:opacity .2s;display:flex;position:absolute;top:16px;right:16px}.news-card:hover .news-card-actions{opacity:1}.news-detail-card{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 12px #0000000f}.news-detail-card.important{border-left:4px solid #ef4444}.news-detail-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.news-detail-header h2{margin:0;font-size:22px;font-weight:700}.news-detail-meta{color:#6b7280;border-top:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:14px 0;font-size:13px;display:flex}.news-detail-content{color:#374151;white-space:pre-wrap;font-size:15px;line-height:1.7}.news-form{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 12px #0000000f}.form-input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.form-textarea{resize:vertical;box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px}.form-checkboxes{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.checkbox-label{cursor:pointer;align-items:center;gap:8px;font-size:14px;display:flex}.submit-button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:10px;width:100%;padding:12px;font-size:15px;font-weight:600;transition:background .2s}.submit-button:hover{background:#5a67d8}.submit-button:disabled{cursor:not-allowed;background:#a5b4fc}.add-news-button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500}.close-button{cursor:pointer;background:linear-gradient(135deg,#ef4444 0%,#dc2626 100%);border:none;border-radius:50%;width:36px;height:36px;font-size:18px}.action-icon-button{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:6px;width:32px;height:32px;font-size:14px}.action-icon-button.delete:hover{background:#fef2f2;border-color:#fecaca}.loading-container{flex-direction:column;align-items:center;gap:12px;padding:60px;display:flex}.news-empty-page{text-align:center;color:#9ca3af;padding:60px 20px}.news-empty-icon{margin-bottom:12px;font-size:48px;display:block}.create-first-button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:10px;margin-top:16px;padding:10px 24px;font-size:15px}.load-more-button{cursor:pointer;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;padding:10px 24px;font-size:14px}@media (width<=768px){.news-page-header,.news-filters{padding:12px 16px}.news-page-content,.news-card{padding:16px}.news-card-title{font-size:16px}.news-card-actions{opacity:1;top:12px;right:12px}.form-row{grid-template-columns:1fr}.news-detail-card{padding:20px}}.personal-tasks-page{background:#f3f4f6;min-height:100vh;padding-bottom:40px}.personal-tasks-header{z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000000f}.personal-tasks-header h1{color:#1f2937;margin:0;font-size:20px}.close-button{cursor:pointer;border:none;border-radius:50%;width:36px;height:36px;font-size:18px}.tasks-filters{background:#fff;border-top:1px solid #f3f4f6;gap:8px;padding:14px 24px;display:flex}.filter-btn{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:7px 14px;font-size:13px;transition:all .2s}.filter-btn:hover{background:#f9fafb}.filter-btn.active{color:#fff;background:#667eea;border-color:#667eea}.personal-tasks-content{max-width:800px;margin:0 auto;padding:24px}.tasks-list{flex-direction:column;gap:10px;display:flex}.task-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:18px 20px;transition:all .2s}.task-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000014}.task-card.high-priority{background:#fef2f2;border-left:4px solid #ef4444}.task-card.completed{opacity:.7;background:#f9fafb}.task-card-header{align-items:center;gap:10px;margin-bottom:10px;display:flex}.task-card-header h3{color:#1f2937;margin:0;font-size:16px;font-weight:600}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.status-dot.new{background:#f59e0b}.status-dot.progress{background:#3b82f6}.status-dot.completed{background:#10b981}.priority-tag{color:#fff;background:#ef4444;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.task-card-meta{color:#6b7280;flex-wrap:wrap;gap:12px;font-size:13px;display:flex}.task-card-progress{align-items:center;gap:8px;margin-top:10px;display:flex}.mini-progress{background:#e5e7eb;border-radius:3px;flex:1;height:6px;overflow:hidden}.mini-progress-fill{background:#10b981;border-radius:3px;height:100%;transition:width .3s}.task-card-progress span{color:#6b7280;font-size:12px}.task-detail-card{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000f}.task-detail-card.high-priority{border-left:4px solid #ef4444}.task-status-line{gap:10px;margin-bottom:14px;display:flex}.status-badge{border-radius:20px;padding:4px 12px;font-size:13px;font-weight:600}.status-badge.new{color:#92400e;background:#fef3c7}.status-badge.progress{color:#1e40af;background:#dbeafe}.status-badge.completed{color:#166534;background:#dcfce7}.priority-badge{border-radius:20px;padding:4px 12px;font-size:13px;font-weight:600}.priority-badge.high{color:#991b1b;background:#fee2e2}.priority-badge.normal{color:#92400e;background:#fef3c7}.priority-badge.low{color:#166534;background:#dcfce7}.task-detail-card h2{color:#1f2937;margin:0 0 14px;font-size:22px;font-weight:700}.task-description{color:#6b7280;white-space:pre-wrap;margin-bottom:18px;font-size:14px;line-height:1.6}.task-info-row{border-top:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6;flex-wrap:wrap;gap:16px;margin-bottom:18px;padding:14px 0;display:flex}.info-block{flex-direction:column;gap:4px;display:flex}.info-label{color:#9ca3af;text-transform:uppercase;font-size:11px;font-weight:500}.info-value{color:#374151;font-size:14px}.subtasks-section{margin-bottom:18px}.subtasks-section h3{color:#1f2937;margin:0 0 10px;font-size:16px}.progress-bar{background:#e5e7eb;border-radius:4px;height:8px;margin-bottom:12px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width .3s}.subtasks-list{flex-direction:column;gap:8px;display:flex}.subtask-item{cursor:pointer;color:#374151;align-items:center;gap:10px;font-size:14px;display:flex}.subtask-item input[type=checkbox]{cursor:pointer;width:18px;height:18px}.subtask-item span.completed{color:#9ca3af;text-decoration:line-through}.task-actions-row{gap:10px;margin-bottom:20px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .2s}.action-btn.take{color:#fff;background:#10b981}.action-btn.take:hover{background:#059669}.action-btn.cancel{color:#fff;background:#f59e0b}.action-btn.cancel:hover{background:#d97706}.action-btn.complete{color:#fff;background:#3b82f6}.action-btn.complete:hover{background:#2563eb}.comment-text{color:#374151;white-space:pre-wrap;font-size:14px;line-height:1.5}.add-comment-row button{color:#fff;cursor:pointer;white-space:nowrap;background:#667eea;border:none;border-radius:8px;padding:10px 16px;font-weight:500}.add-comment-row button:disabled{cursor:not-allowed;background:#a5b4fc}.task-form{background:#fff;border-radius:16px;padding:24px;box-shadow:0 4px 12px #0000000f}.form-error{color:#991b1b;background:#fef2f2;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:14px}.form-group input,.form-group textarea,.form-group select{box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px}.form-group textarea{resize:vertical}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.assignees-list{flex-wrap:wrap;gap:8px;display:flex}.assignee-checkbox{cursor:pointer;background:#f3f4f6;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:background .2s;display:flex}.assignee-checkbox:hover{background:#e5e7eb}.assignee-checkbox input{width:auto}.form-hint{color:#ef4444;margin-top:6px;font-size:12px;display:block}.subtask-input-row{gap:8px;display:flex}.subtask-input-row input{flex:1}.subtask-input-row button{cursor:pointer;background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;padding:10px 16px;font-size:16px}.subtasks-preview{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.subtask-preview-item{background:#f3f4f6;border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;display:flex}.subtask-preview-item button{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;display:flex}.submit-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:10px;width:100%;margin-top:8px;padding:12px;font-size:15px;font-weight:600;transition:background .2s}.submit-btn:hover{background:#5a67d8}.empty-state button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:10px;margin-top:16px;padding:10px 24px;font-size:15px}.load-more-btn{cursor:pointer;color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;padding:10px 24px;font-size:14px}@media (width<=768px){.personal-tasks-header{padding:12px 16px}.tasks-filters{padding:10px 16px}.personal-tasks-content{padding:16px}.form-row{grid-template-columns:1fr}.task-card{padding:14px 16px}}.task-card.overdue{background:#fffbeb;border-left:4px solid #f59e0b}.overdue-tag{color:#fff;background:#f59e0b;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700;animation:2s infinite overduePulse}@keyframes overduePulse{0%,to{opacity:1}50%{opacity:.7}}.task-card-description{color:#6b7280;background:#f9fafb;border-radius:8px;margin-bottom:10px;padding:8px 10px;font-size:13px;line-height:1.5}.task-card-status{background:#f0fdf4;border-radius:8px;margin-bottom:10px;padding:6px 10px;font-size:13px;font-weight:600;display:inline-block}.task-card.completed .task-card-status{color:#166534;background:#dcfce7}.task-card.overdue .task-card-status{color:#92400e;background:#fef3c7}.task-card-row{align-items:baseline;gap:6px;margin-bottom:4px;font-size:13px;display:flex}.meta-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0;min-width:85px;font-size:11px;font-weight:500}.meta-value{color:#374151}.meta-value.author{color:#667eea;font-weight:500}.meta-value.assignees{color:#374151}.task-card-footer{border-top:1px solid #f3f4f6;justify-content:space-between;align-items:center;margin-top:10px;padding-top:10px;display:flex}.due-date{color:#6b7280;font-size:13px}.due-date.overdue{color:#ef4444;font-weight:600}.attachments-section{border-top:1px solid #f3f4f6;margin-bottom:20px;padding-top:18px}.attachments-section h3{color:#1f2937;margin:0 0 12px;font-size:16px}.attach-buttons{gap:8px;margin-bottom:12px;display:flex}.attach-btn{color:#667eea;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px 14px;font-size:13px;transition:all .2s}.attach-btn.camera:hover{background:#eff6ff}.upload-progress{margin-bottom:12px}.upload-progress .progress-bar{background:#e5e7eb;border-radius:3px;height:6px;margin-bottom:4px;overflow:hidden}.upload-progress .progress-fill{background:#667eea;height:100%;transition:width .3s}.upload-progress span{color:#6b7280;font-size:12px}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-bottom:12px;display:grid}.photo-item{aspect-ratio:1;border:1px solid #e5e7eb;border-radius:10px;position:relative;overflow:hidden}.photo-thumbnail{object-fit:cover;cursor:pointer;width:100%;height:100%}.photo-delete{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;display:flex;position:absolute;top:4px;right:4px}.attachment-item{background:#f9fafb;border-radius:8px;align-items:center;gap:10px;margin-bottom:6px;padding:10px 12px;display:flex}.attachment-icon{font-size:20px}.attachment-name{color:#374151;flex:1;font-size:13px}.attachment-size{color:#9ca3af;font-size:11px}.attach-controls{margin-bottom:10px}.attach-btn.edit-mode{color:#92400e;background:#fef3c7;border-color:#fde68a}.subtask-completed-by{color:#10b981;margin-left:6px;font-size:11px}.regions-gallery-page{background:#f3f4f6;min-height:100vh;padding-bottom:40px}.gallery-header{z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0000000f}.gallery-header h1{color:#1f2937;margin:0;font-size:20px}.header-actions{align-items:center;gap:8px;display:flex}.back-button{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:8px;padding:8px 16px;font-size:14px}.add-button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500}.icon-button{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:36px;height:36px;font-size:16px}.icon-button.delete:hover{background:#fef2f2;border-color:#fecaca}.search-container{gap:8px;max-width:600px;display:flex}.search-input{border:1px solid #e5e7eb;border-radius:8px;flex:1;padding:10px 14px;font-size:14px}.search-button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:10px 20px}.gallery-content{max-width:1000px;margin:0 auto;padding:24px}.gallery-form{background:#fff;border-radius:16px;padding:24px}.form-group{margin-bottom:16px}.form-group label{color:#374151;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-group input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.submit-btn{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:10px;width:100%;padding:12px;font-size:15px;font-weight:600}.submit-btn:disabled{cursor:not-allowed;background:#a5b4fc}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.gallery-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:18px 20px;transition:all .2s}.gallery-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000014}.gallery-card h3{color:#1f2937;margin:0 0 10px;font-size:18px}.gallery-card-info{color:#6b7280;gap:14px;margin-bottom:8px;font-size:13px;display:flex}.gallery-card-stats{color:#667eea;gap:14px;font-size:13px;display:flex}.gallery-info{color:#6b7280;background:#fff;border-radius:14px;gap:20px;margin-bottom:16px;padding:16px 20px;font-size:14px;display:flex}.upload-section{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.attach-btn{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:8px 14px;font-size:13px}.attach-btn:hover{background:#f3f4f6}.attach-btn.camera{color:#667eea;border-color:#667eea}.attach-btn:disabled{opacity:.5;cursor:not-allowed}.gallery-photos-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:20px;display:grid}.gallery-photo-item{background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;display:flex;position:relative;overflow:hidden}.gallery-photo-thumb{aspect-ratio:1;object-fit:cover;cursor:pointer;width:100%}.photo-info{color:#9ca3af;background:#f9fafb;justify-content:space-between;padding:8px 10px;font-size:11px;display:flex}.photo-delete-btn{color:#fff;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;display:flex;position:absolute;top:6px;right:6px}.photo-modal{z-index:1000;background:#000000e6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.photo-modal-content{max-width:90vw;max-height:90vh;position:relative}.modal-close{color:#fff;cursor:pointer;background:0 0;border:none;font-size:24px;position:absolute;top:-40px;right:0}.modal-image{object-fit:contain;max-width:90vw;max-height:80vh}.modal-nav{justify-content:center;align-items:center;gap:20px;display:flex;position:absolute;bottom:-50px;left:0;right:0}.modal-nav button{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:50%;width:40px;height:40px;font-size:24px}.modal-nav button:disabled{opacity:.3;cursor:not-allowed}.modal-nav span{color:#fff;font-size:14px}.comments-section{background:#fff;border-radius:14px;padding:20px}.comments-section h3{color:#1f2937;margin:0 0 14px;font-size:16px}.comments-list{max-height:300px;margin-bottom:14px;overflow-y:auto}.comment-item{background:#f9fafb;border-left:3px solid #667eea;border-radius:10px;margin-bottom:8px;padding:12px}.comment-header{gap:10px;margin-bottom:6px;display:flex}.comment-author{color:#1f2937;font-size:13px;font-weight:600}.comment-date{color:#9ca3af;font-size:11px}.comment-text{color:#374151;font-size:14px}.no-comments{text-align:center;color:#9ca3af;padding:20px;font-size:14px}.add-comment-row{gap:8px;display:flex}.add-comment-row textarea{resize:vertical;border:1px solid #e5e7eb;border-radius:8px;flex:1;padding:10px;font-family:inherit;font-size:14px}.add-comment-row button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:8px;padding:10px 16px;font-weight:500}.add-comment-row button:disabled{background:#a5b4fc}.loading-container{color:#6b7280;flex-direction:column;align-items:center;gap:12px;padding:60px;display:flex}.spinner{border:3px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}.empty-state{text-align:center;color:#9ca3af;padding:60px}.empty-state span{margin-bottom:12px;font-size:48px;display:block}.empty-state button{color:#fff;cursor:pointer;background:#667eea;border:none;border-radius:10px;margin-top:16px;padding:10px 24px}.load-more-container{text-align:center;margin-top:16px}.load-more-btn{cursor:pointer;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:10px;padding:10px 24px;font-size:14px}@media (width<=768px){.gallery-header{padding:12px 16px}.gallery-content{padding:16px}.gallery-grid{grid-template-columns:1fr}.gallery-photos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.gallery-info{flex-wrap:wrap;gap:10px}}.wandering-snail{z-index:9999;pointer-events:auto;cursor:pointer;filter:drop-shadow(2px 4px 8px #00000026);width:48px;height:36px;transition:left .5s cubic-bezier(.4,0,.2,1),top .4s ease-out;position:fixed}.wandering-snail:hover{filter:drop-shadow(2px 6px 12px #00000040)}.snail-svg{width:100%;height:100%;display:block}.snail-svg.shake{animation:.25s ease-in-out 3 shake}.snail-bubble{color:#1f2937;white-space:nowrap;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:linear-gradient(135deg,#fff 0%,#f9fafb 100%);border:1px solid #667eea33;border-radius:24px;margin-bottom:10px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;animation:.25s ease-out bubblePop;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 6px 16px #0000001f}.snail-bubble:after{content:"";filter:drop-shadow(0 1px 1px #0000000d);border:8px solid #0000;border-top-color:#f9fafb;position:absolute;top:100%;left:50%;transform:translate(-50%)}@keyframes bubblePop{0%{opacity:0;transform:translate(-50%)scale(.7)}to{opacity:1;transform:translate(-50%)scale(1)}}@media (width<=768px){.wandering-snail{display:none}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}.Toastify__toast{border-radius:12px!important;font-family:inherit!important}.Toastify__toast-body{font-size:14px!important}.Toastify__toast--info{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)!important}.Toastify__close-button:hover{opacity:1!important}.custom-toast{color:#f3f4f6!important;cursor:pointer!important;background:linear-gradient(135deg,#1f2937 0%,#111827 100%)!important;border:1px solid #ffffff1a!important;border-radius:16px!important;transition:transform .2s,box-shadow .2s!important;box-shadow:0 10px 25px -5px #0000004d!important}.custom-toast:hover{background:linear-gradient(135deg,#2d3748 0%,#1a202c 100%)!important;transform:translateY(-2px)!important;box-shadow:0 15px 35px -8px #0006!important}.custom-toast-body{padding:4px 0!important;font-family:inherit!important}.custom-toast-progress{background:linear-gradient(90deg,#667eea,#764ba2)!important}.Toastify__close-button{color:#9ca3af!important;opacity:.7!important}.Toastify__close-button:hover{color:#f3f4f6!important;opacity:1!important}
