.loading-spinner__container{display:flex;justify-content:center;align-items:center;padding:5px}.loading-spinner__spinner{border:5px solid rgba(0,0,0,.1);border-top:5px solid var(--primary-bg-color);border-radius:50%;width:50px;height:50px;animation:loading-spinner-spin 1s linear infinite}@keyframes loading-spinner-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.layout-admin{margin-top:0;min-height:100vh;display:flex;background-color:#fafafa;width:100%}.layout-root{flex:1;min-width:0;padding:1rem}.sidebar{width:0px;height:calc(100vh - 64px);background-color:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000;display:flex;flex-direction:column;overflow:hidden;border-right:1px solid #f0f0f0;position:sticky;top:64px;flex-shrink:0}.sidebar--open{width:200px}.sidebar__header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #f0f0f0;width:100%;flex-shrink:0;box-sizing:border-box}.sidebar__header-text{font-size:11px;font-weight:700;color:#8c8c8c;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__close-btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:8px;border-radius:50%;transition:background-color .2s;flex-shrink:0}.sidebar__close-btn:hover{background-color:#f5f5f5}.sidebar__content{flex:1;overflow-y:auto;padding:16px 0;width:100%;flex-shrink:0;box-sizing:border-box}.sidebar__menu-items-list{list-style:none;padding:0;margin:0}.sidebar__menu-item{list-style:none;margin-bottom:2px}.sidebar__menu-item a{text-decoration:none;display:block}.sidebar__menu-title{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;color:#595959;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:48px;box-sizing:border-box;border-left:3px solid transparent}.sidebar__menu-title-left{display:flex;align-items:center;gap:12px}.sidebar__menu-title:hover{background-color:#f0f7f0;color:#2e7d32;border-left:3px solid #4caf50}.sidebar__menu-icon{display:flex;align-items:center;justify-content:center;width:20px;flex-shrink:0}.sidebar__menu-text{font-size:14px;white-space:nowrap}.sidebar__menu-title.level-0{padding-left:24px}.sidebar__menu-title.level-1{padding-left:48px}.sidebar__menu-title.level-2{padding-left:72px}.sidebar__menu-item.active>a .sidebar__menu-title{background-color:#e8f5e9;color:#2e7d32!important;border-radius:0 24px 24px 0;margin-right:12px;border-left:3px solid #2e7d32;font-weight:600}.sidebar__submenu{list-style:none;padding:0;display:none;margin-top:1px;background-color:#fafafa;border-left:1px solid #f0f0f0;margin-left:24px}.sidebar__submenu.open{display:block}.sidebar__submenu .sidebar__menu-item{margin-bottom:0}.sidebar__submenu .sidebar__menu-title{padding-top:10px;padding-bottom:10px}.toggle-icon{display:flex;transition:transform .3s ease;color:#a0a0a0}.toggle-icon.open{transform:rotate(180deg)}.sidebar__footer{padding:16px 24px;border-top:1px solid #f0f0f0;width:100%;flex-shrink:0;box-sizing:border-box}.sidebar__logout{display:flex;align-items:center;gap:12px;color:#6c757d;cursor:pointer;font-size:14px;padding:12px 0;transition:color .2s ease}.sidebar__logout:hover{color:#ff4d4f}.sidebar__toggle-btn.outside{position:fixed;bottom:24px;right:24px;z-index:2000;background:#4caf50;color:#fff;border:none;border-radius:50%;width:56px;height:56px;cursor:pointer;box-shadow:0 4px 12px #4caf5066;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.sidebar__toggle-btn.outside.hidden{opacity:0;pointer-events:none;transform:scale(.8)}.sidebar__icon{width:24px;height:24px}.sidebar__overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2001;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;height:100vh;height:100dvh;z-index:2002;box-shadow:10px 0 25px #0000001a;transform:translate(-100%);width:240px;max-width:85%;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar--open{transform:translate(0)}.sidebar__overlay{display:block}.sidebar__toggle-btn.outside{display:flex}}@media (min-width: 769px){.sidebar__toggle-btn.outside{bottom:auto;top:110px;left:20px;width:40px;height:40px;background:#fff;color:#595959;border:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000d}.sidebar__toggle-btn.outside:hover{background-color:#f5f5f5}}.profile-menu{position:relative}.profile-btn{background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:.75rem}.profile-avatar{width:40px;height:40px;border-radius:50%;background-color:#fff;color:var(--secondary-color);display:flex;align-items:center;justify-content:center;font-weight:600;text-transform:uppercase}.profile-dropdown{opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .25s ease,transform .25s ease;position:absolute;right:0;top:55px;background-color:var(--surface-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);border:1px solid var(--border-color);width:220px;overflow:hidden;z-index:1001}.profile-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}.profile-info{padding:1rem;display:flex;flex-direction:column;gap:.25rem;color:var(--text-primary)}.profile-info strong{font-size:.95rem}.profile-info small{font-size:.8rem;color:var(--text-secondary)}.dropdown-divider{margin:0;border:none;border-top:1px solid var(--border-color)}#logout-btn{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;cursor:pointer;font-size:.9rem;color:var(--text-secondary);transition:background-color .2s ease,color .2s ease}#logout-btn:hover{background-color:#f1f5f9;color:var(--text-primary)}@media (max-width: 850px){.profile-dropdown{position:fixed;bottom:auto;right:5%;left:5%;width:90%;max-width:320px;margin:0 auto;top:100px;z-index:3000;transform:translateY(10px)}.profile-dropdown.show{transform:translateY(0)}.profile-menu{position:static}}.header{background-color:var(--secondary-bg-color);width:100%;position:sticky;top:-48px;z-index:1500;transition:all .3s ease;box-shadow:0 4px 10px #0000000d}.header.scrolled{box-shadow:0 10px 30px #00000026}.header__top{padding:8px 5%;height:48px;box-sizing:border-box;background-color:#36c;display:flex;align-items:center}.header__menu{padding:1rem 5%;display:flex;align-items:center;background-color:var(--primary-color, #2b5c3e);justify-content:space-between;flex-wrap:wrap;color:#fff;transition:all .4s cubic-bezier(.16,1,.3,1);border-top:1px solid rgba(255,255,255,.1)}.header.scrolled .header__menu{background-color:var(--primary-color, #2b5c3e);padding:.6rem 5%;box-shadow:0 15px 40px #0000001f}.header__menu-logo h3{font-weight:800;letter-spacing:1px;font-size:1.5rem;margin:0}.header__menu-logo{display:flex;flex-direction:row;align-items:center;white-space:nowrap;gap:.5rem;transition:transform .3s ease}.header__menu-search{display:flex;align-items:center}.header.scrolled .header__menu-logo img{transform:translateY(-5px)}.header__nav{display:flex;gap:.5rem}.header__nav-link{text-decoration:none;color:#ffffffe6;margin-right:.5rem;font-size:1.05rem;font-weight:600;padding:.6rem 1rem;transition:all .3s cubic-bezier(.16,1,.3,1);border-radius:8px;display:flex;flex-direction:row;justify-content:center;align-items:center;gap:.6rem;position:relative;overflow:hidden}.header__nav-link:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:2px;background:linear-gradient(90deg,transparent,#ffffff,transparent);transition:all .3s cubic-bezier(.25,1,.5,1);transform:translate(-50%);opacity:0}.header__nav-link:hover:after{width:80%;opacity:1}.header__nav-link svg{transition:transform .4s cubic-bezier(.175,.885,.32,1.275),opacity .3s;opacity:.9}@media (max-width: 850px){.header__top{height:40px;padding:5px 5%}.header__top img{height:24px;width:auto}.header{top:-40px}.header__menu{flex-wrap:wrap;flex-direction:column;padding:1rem 5%;gap:.5rem}.header__menu-logo{width:100%;justify-content:center}.header__menu-logo img{width:60px;height:auto}.header__menu-logo h3{font-size:1.1rem}.header__nav{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;padding-bottom:5px;justify-content:flex-start}.header__nav::-webkit-scrollbar{height:0;display:none}}.header__nav-link:hover{background-color:#ffffff14;color:#fff;transform:translateY(-2px)}.header__nav-link:hover svg{transform:scale(1.15) rotate(-8deg);opacity:1}.footer{background:linear-gradient(135deg,#1e3c28,var(--primary-color, #2b5c3e));color:#fff;padding:4rem 5% 2rem;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--secondary-color, #f7b731)}.footer__content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1200px;gap:2rem;border-radius:0 200px 0 153px}.footer__logo{display:flex;align-items:center}.footer__title{font-size:1.5rem;margin:0;font-weight:700;color:#e6e6e6}.footer__nav{display:flex;align-items:center}.footer__nav-list{list-style:none;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:2rem}.footer__nav-item{margin:0}.footer__nav-link{text-decoration:none;color:#ffffffd9;font-size:1.05rem;font-weight:500;transition:all .3s ease;position:relative}.footer__nav-link:hover{color:#fff;text-shadow:0 0 10px rgba(255,255,255,.5)}.footer__dev-card{display:flex;flex-direction:column;align-items:flex-start;gap:.65rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:1rem 1.25rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%;max-width:240px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.footer__dev-card:hover{background:#ffffff14;transform:translateY(-3px);border-color:#ffffff40;box-shadow:0 10px 20px #0003}.footer__dev-label{color:#ffffffe6;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em;font-family:Inter,system-ui,sans-serif}.footer__dev-logo-wrapper{background:#fff;border-radius:8px;padding:.5rem .8rem;display:flex;justify-content:center;align-items:center;width:100%;box-sizing:border-box;transition:transform .2s ease}.footer__dev-card:hover .footer__dev-logo-wrapper{transform:scale(1.02)}.footer__dev-logo{height:32px;width:auto;max-width:100%;object-fit:contain}.footer__bottom{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);width:100%;max-width:1200px;text-align:center}.footer_copy{font-size:1.1rem;font-weight:600;color:#fff}.footer__bottom-text{font-size:.9rem;color:#fff9}@media (max-width: 1024px){.footer__content{flex-direction:column;align-items:center;border-radius:0 100px 0 70px}.footer__nav-list{flex-direction:column;gap:10px}}@media (max-width: 768px){.footer__title{font-size:1.5rem}.footer__nav-list{flex-direction:column;gap:8px}.footer__dev-card{margin-top:1rem;align-items:center}.footer__title{font-size:1.2rem;margin-bottom:1rem}}@media (max-width: 480px){.footer{padding:30px 15px}.footer__content{border-radius:0 50px 0 30px}.footer__nav-list{gap:5px}.footer__bottom-text{font-size:.8rem}}*{font-family:Raleway,Helvetica,Arial,sans-serif!important;box-sizing:border-box;padding:0%;margin:0%}body{width:100%;height:100%;background-color:#fff}:root{--primary-bg-color: #368234;--secondary-bg-color: #3366cc;--primary-button-color: #3366cc;--secondary-button-color: #1255db;--message-error-color: red;--surface-color: #ffffff;--text-primary: #0f172a;--text-secondary: #64748b;--border-color: #e2e8f0;--success-color: #16a34a;--warning-color: #f97316;--error-color: #dc2626;--font-family: "Raleway", Helvetica, Arial, sans-serif !important;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--border-radius: .75rem}.loading__page{display:flex;justify-content:center;height:100vh}.skeleton{background:#e2e8f0;border-radius:4px;position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:skeleton-shimmer 1.5s infinite}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-text{height:1rem;margin-bottom:.5rem;border-radius:4px}.skeleton-label{width:50%;height:12px}.skeleton-value{width:80%;height:28px;margin-top:4px;margin-bottom:8px}.skeleton-trend{width:60%;height:12px}.skeleton-chart{width:100%;height:260px;border-radius:8px}.skeleton-table-row{height:48px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;padding:0 24px;gap:16px}.skeleton-table-cell{height:16px;border-radius:4px}
