:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f4f7fb;color:#102a43;--app-header-height:64px;--app-max-width:520px}*{box-sizing:border-box}body,html{margin:0;padding:0;min-height:100%;overflow-x:hidden;max-width:100%}body{background:#f4f7fb;line-height:1.6}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{border:none;cursor:pointer}.page-shell{display:flex;flex-direction:column;min-height:100vh;max-width:780px;margin:0 auto;padding:0 16px 92px}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;background:#f4f7fb;padding:20px 0 10px}.brand{display:block;font-size:1rem;letter-spacing:.12em;font-weight:700;color:#0f172a}.subtitle{margin:6px 0 0;color:#475569;font-size:.95rem}.content{flex:1 1}.hero,.section{background:hsla(0,0%,100%,.98);border:1px solid #dce7f2;border-radius:24px;padding:20px;margin:18px 0;box-shadow:0 18px 40px rgba(16,42,67,.05)}.text-muted{color:#52667a;margin:0 0 18px}.card-grid{display:grid;grid-gap:12px;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.card{display:block;padding:18px 16px;background:#fff;border:1px solid #d7e0ed;border-radius:18px;text-align:center;font-weight:700;color:#102a43;box-shadow:0 10px 24px rgba(16,42,67,.08)}.full-width{grid-column:1/-1}.form-card{display:grid;grid-gap:14px;gap:14px}label{display:grid;grid-gap:8px;gap:8px;font-weight:600;color:#102a43}input{width:100%;padding:14px 16px;border:1px solid #cbd5e1;border-radius:14px;background:#fff;outline:none}input:focus{box-shadow:0 0 0 4px rgba(59,130,246,.12);border-color:#2563eb}.button-primary{display:inline-flex;align-items:center;justify-content:center;background:#2563eb;color:#fff;border-radius:14px;padding:14px 18px;font-weight:700;transition:background .2s ease}.button-primary:hover{background:#1d4ed8}.info-block{margin-top:20px;padding:16px;border-radius:18px;background:#eef2ff;color:#334155}.link-button{display:inline-flex;margin-top:10px;color:#0f62fe;font-weight:700}.list-card{list-style:none;padding:0;margin:0;display:grid;grid-gap:14px;gap:14px}.list-item{padding:16px;border-radius:18px;border:1px solid #d8e3ef;background:#fff}.list-item h3{margin:0 0 8px;font-size:1rem}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:6px;gap:6px;padding:10px;background:hsla(0,0%,100%,.98);border-top:1px solid #d8e3ef;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-link{display:inline-flex;align-items:center;justify-content:center;padding:10px 8px;border-radius:16px;background:#f8fbff;color:#334e68;font-size:.82rem;font-weight:700}.nav-link.active{background:#2563eb;color:#fff}.chat-panel{display:grid;grid-gap:14px;gap:14px}.chat-window{display:grid;grid-gap:12px;gap:12px}.chat-bubble{max-width:100%;padding:14px 16px;border-radius:18px;background:#fff;border:1px solid #d9e6f5}.chat-bubble.user{background:#e0f2fe;border-color:#bae6fd;justify-self:end}.chat-bubble.assistant{background:#f8fafc}.chat-form{display:grid;grid-gap:10px;gap:10px}.chat-form input{width:100%}.inventory-page{position:relative;min-height:100vh;padding:20px 16px 120px;background:linear-gradient(180deg,#f6fbff,#eef6ff)}.inventory-heading.big{margin-top:0}.inventory-lead{margin:6px 0 0;color:#475569;line-height:1.6;font-size:.95rem;text-align:left}.inventory-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:22px}.topbar-button{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:14px;background:hsla(0,0%,100%,.92);border:1px solid #e2e8f0;color:#1f2937;position:relative}.topbar-button span{display:block;width:22px;height:2px;background:#1f2937;border-radius:999px}.topbar-button span+span{margin-top:4px}.bell-button:before{content:"";display:block;width:20px;height:20px;border-radius:50%;border:2px solid #1f2937}.bell-button:after{content:"";position:absolute;top:10px;left:50%;transform:translateX(-50%);width:12px;height:6px;border-radius:4px;background:#1f2937}.bell-badge{position:absolute;top:-4px;right:-4px;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:999px;background:#ef4444;color:#fff;font-size:.72rem;font-weight:700}.topbar-brand{display:flex;align-items:center;gap:12px;flex:1 1}.brand-mark{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:12px;background:#1d4ed8;color:#fff;font-weight:800;font-size:1rem}.brand-name{margin:0;font-weight:800;font-size:.95rem;color:#0f172a}.brand-subtitle{margin:3px 0 0;color:#475569;font-size:.78rem;line-height:1.4}.inventory-heading h1{margin:0;letter-spacing:-.03em}.inventory-heading p{margin:10px 0 0;line-height:1.75;font-size:.96rem}.inventory-card-list{display:grid;grid-gap:12px;gap:12px}.inventory-card{display:grid;grid-template-columns:auto 1fr auto;grid-gap:16px;gap:16px;padding:18px;min-height:100px;border-radius:18px;background:#fff;border:1px solid #e2e8f0;align-items:center;color:#0f172a;text-align:left}.inventory-card-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:16px;background:#eef5ff;color:#2563eb}.inventory-card-icon svg{width:22px;height:22px}.inventory-card-body strong{display:block;margin-bottom:6px;font-size:1rem}.inventory-card-body span{display:block;color:#475569;font-size:.95rem;line-height:1.6}.inventory-card-arrow{color:#94a3b8;font-size:1.3rem}.inventory-notice-card{border-radius:20px;background:#eff6ff;border:1px solid #dbeafe}.notice-title{margin:0 0 10px;font-size:1rem;font-weight:800;color:#0f172a}.inventory-notice-card ul{margin:0;padding-left:18px;color:#475569;line-height:1.75}.inventory-notice-card li{margin-bottom:8px}.inventory-bottom-nav{border-top:1px solid #e2e8f0}.nav-item{min-height:48px;padding:10px 8px;border-radius:16px;background:#f8fbff;font-size:.78rem}.nav-item-icon{width:18px;height:18px}.nav-item.active{background:#2563eb;color:#fff}.inventory-topbar.centered{position:relative;padding:6px 0 18px}.inventory-topbar .topbar-button.left{position:absolute;left:0;top:8px}.inventory-topbar .topbar-button.right{position:absolute;right:0;top:8px}.topbar-center{display:flex;justify-content:center;width:100%}.topbar-logo{display:flex;align-items:center;gap:10px}.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:linear-gradient(180deg,#fff,#eef6ff);color:#1d4ed8;font-weight:800;font-size:1.1rem;box-shadow:0 8px 24px rgba(16,42,67,.06)}.logo-text .logo-title{font-weight:800;color:#12204c;font-size:1rem}.logo-text .logo-sub{font-size:.78rem;color:#64748b}.app-shell:not(.is-admin-page):not(.is-login-page){width:100%;max-width:var(--app-max-width);margin:0 auto;min-height:100vh}.app-container{width:100%;max-width:var(--app-max-width);margin:18px auto;position:relative;background:hsla(0,0%,100%,.98);border-radius:20px;padding:18px;box-shadow:0 28px 80px rgba(16,42,67,.06)}.app-shell:not(.is-admin-page) .app-main{width:100%;max-width:100%;overflow-x:hidden}@media (max-width:520px){.app-container{margin:12px;border-radius:14px;padding:12px;box-shadow:none;background:transparent}.is-login-page .app-container{width:100%;max-width:none;margin:0;padding:0 20px;border-radius:0}.has-app-header .app-background{padding-top:calc(var(--app-header-height) + 12px)}}.app-top-header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--app-header-height);background:rgba(246,251,255,.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(148,163,184,.18)}.app-top-header-inner{width:100%;max-width:var(--app-max-width);height:100%;margin:0 auto;position:relative;display:flex;align-items:center;justify-content:center;padding:0 16px}@media (min-width:521px){.app-shell:not(.is-admin-page) .app-top-header{left:50%;right:auto;width:min(100%,var(--app-max-width));transform:translateX(-50%)}}.app-top-header-brand{display:flex;align-items:center;justify-content:center;max-width:calc(100% - 120px);text-align:center;cursor:pointer;text-decoration:none}.app-top-header-title{margin:0;font-size:1.05rem;font-weight:800;color:#16224d;letter-spacing:-.03em;line-height:1.2}.app-top-header-action{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:14px;border:1px solid rgba(148,163,184,.22);background:hsla(0,0%,100%,.94);display:inline-flex;align-items:center;justify-content:center;color:#334155;box-shadow:0 10px 24px rgba(16,42,67,.08);z-index:2;transition:background .2s ease,transform .2s ease}.app-top-header-action:hover{background:#f8fbff;transform:translateY(-50%) scale(1.02)}.app-top-header-action-left{left:16px}.app-top-header-action-right{right:16px}.app-top-header-action svg{width:18px;height:18px}.has-app-header .app-background{padding-top:calc(var(--app-header-height) + 20px)}.app-background{min-height:100vh;background:linear-gradient(180deg,#f6fbff,#eef6ff);padding:20px 16px 40px}.app-header{position:relative;display:flex;justify-content:center;align-items:center;padding:10px 0 6px;min-height:64px}.app-main{width:100%}.inventory-heading h1{margin:0 0 8px;font-size:1.9rem;color:#0f172a;text-align:left}.inventory-heading p{margin:6px 0 0;color:#475569;line-height:1.6;font-size:.95rem;text-align:left}.inventory-cards{display:flex;flex-direction:column;gap:14px;margin-top:10px}.menu-card{display:flex;align-items:center;gap:16px;padding:18px;min-height:98px;border-radius:18px;background:#fff;border:1px solid rgba(226,235,255,.75);box-shadow:0 12px 28px rgba(16,42,67,.06);transition:transform .18s ease,box-shadow .18s ease;text-decoration:none;color:inherit;width:100%;cursor:pointer;font:inherit}button.menu-card{text-align:left}.menu-card:hover{transform:translateY(-1px);box-shadow:0 16px 38px rgba(16,42,67,.09)}.menu-card-left{flex-shrink:0}.menu-card-left,.menu-icon{display:flex;align-items:center;justify-content:center}.menu-icon{width:64px;height:64px;border-radius:18px;background:#eef4ff;color:#2563eb}.menu-icon svg{width:26px;height:26px}.menu-card-body{display:flex;flex-direction:column;gap:4px;flex:1 1;min-width:0}.menu-card-body strong{font-size:1.05rem;margin:0;padding:0;color:#081a3f;font-weight:800;line-height:1.2;text-align:left}.menu-card-body span{color:#64748b;font-size:clamp(11px,2.8vw,14px);line-height:1.5;text-align:left;word-break:break-word;overflow-wrap:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.menu-card-right{color:#94a3b8;font-size:1.3rem;flex-shrink:0}.extra-box{margin-top:12px;border-radius:16px;border:2px solid rgba(37,99,235,.12);padding:14px;position:relative;background:linear-gradient(180deg,#fff,#fbfdff)}.extra-badge{position:absolute;left:12px;top:-10px;background:#2563eb;color:#fff;padding:4px 10px;border-radius:10px;font-weight:800;font-size:.8rem}.extra-list{display:grid;grid-gap:12px;gap:12px}.inventory-notice-card{margin-top:18px;padding:18px;border-radius:14px;background:linear-gradient(180deg,#fbfdff,#eef7ff);border:1px solid rgba(30,64,175,.06);box-shadow:0 10px 30px rgba(16,42,67,.06)}.inventory-bottom-nav{position:fixed;left:0;right:0;bottom:0;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-gap:8px;gap:8px;padding:12px;background:hsla(0,0%,100%,.98);border-top:1px solid #e6eefc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.nav-item{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:64px;padding:6px 8px;border-radius:12px;background:transparent;color:#475569;font-size:.74rem;font-weight:700}.nav-item-icon{display:inline-flex;width:24px;height:24px}.nav-item-icon svg{width:100%;height:100%}.nav-item.active{background:#eef5ff;border-radius:12px;color:#2563eb;box-shadow:0 8px 20px rgba(37,99,235,.08)}@media (max-width:640px){.inventory-topbar{gap:10px}.extra-card,.inventory-card{grid-template-columns:auto 1fr auto}.inventory-card-body strong{font-size:.98rem}}.is-login-page.app-shell{width:100%;max-width:none;margin:0;min-height:100dvh;overflow-x:hidden}.is-login-page .app-background{padding:0;align-items:stretch;background:linear-gradient(180deg,#f6fbff,#eef6ff)}.is-login-page .app-background,.is-login-page .app-container{width:100%;max-width:none;margin:0;display:flex;flex-direction:column;min-height:100dvh;overflow-x:hidden;box-sizing:border-box}.is-login-page .app-container{padding:0 20px;background:transparent;border-radius:0;box-shadow:none}.is-login-page .app-main{width:100%;max-width:none;margin:0;overflow-x:hidden;flex:1 1;display:flex;flex-direction:column}.is-login-page .app-header{width:100%;max-width:none;margin:0;padding:calc(48px + env(safe-area-inset-top, 0px)) 0 20px;min-height:auto;box-sizing:border-box;flex-shrink:0}.is-login-page .logo-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;width:100%;margin:0;padding:0;text-align:center;box-sizing:border-box}.is-login-page .app-title{margin:0;font-size:clamp(2rem,8.2vw,2.4rem);font-weight:800;letter-spacing:-.04em;line-height:1.08;color:#081a3f}.is-login-page .app-subtitle{margin:0;font-size:.72rem;color:#5f708f;letter-spacing:.12em;text-transform:uppercase;font-weight:600}.transfer-page{width:100%}.transfer-heading{margin:8px 0 20px}.transfer-heading h1{margin:0 0 8px;font-size:1.9rem;color:#0f172a;text-align:left}.transfer-lead{margin:6px 0 0;color:#475569;line-height:1.6;font-size:.95rem;text-align:left}.transfer-form{gap:20px;margin-bottom:24px}.form-group,.transfer-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-label{display:inline-flex;align-items:center;gap:4px;font-size:1.05rem;font-weight:700;color:#081a3f;margin:0}.required{color:#ef4444;font-weight:700}.form-description{font-size:.88rem;color:#64748b;margin:0;display:block;line-height:1.4}.form-select{width:100%;border:1px solid #e2e8f0;border-radius:16px;background:#fff;color:#1f2937;font-size:clamp(11px,2.8vw,14px);outline:none;transition:border-color .2s ease,box-shadow .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23334155' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding:14px 40px 14px 16px}.form-select:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}.form-input-wrapper{position:relative;display:flex;align-items:center}.form-input{width:100%;padding:14px 16px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;color:#1f2937;font-size:clamp(11px,2.8vw,14px);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.form-input::placeholder{color:#9ca3af}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}.form-input-counter{position:absolute;right:14px;font-size:.85rem;color:#94a3b8;pointer-events:none}.transfer-notice{background:#eef4ff;border:1px solid #e0ebff;border-radius:16px;padding:14px 16px;margin-top:8px}.notice-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.notice-label{font-size:.95rem;font-weight:700;color:#081a3f}.notice-icon{width:16px;height:16px;color:#2563eb}.notice-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.notice-list li{font-size:.88rem;color:#475569;line-height:1.4;padding-left:18px;position:relative}.notice-list li:before{content:"•";position:absolute;left:6px}.form-buttons{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;margin-top:16px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:16px 18px;border-radius:16px;font-size:1.05rem;font-weight:700;min-height:50px;transition:transform .15s ease,box-shadow .15s ease}.btn-cancel{background:transparent;border:1px solid #d1d5db;color:#374151;box-shadow:none}.btn-cancel:hover{background:#f3f4f6;transform:translateY(-1px)}.btn-cancel:active{transform:translateY(0)}.btn-primary{background:#2563eb;border:none;color:#fff;box-shadow:0 12px 28px rgba(37,99,235,.15)}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 16px 38px rgba(37,99,235,.2)}.btn-primary:active{transform:translateY(0);box-shadow:0 8px 16px rgba(37,99,235,.12)}.notification{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:100;animation:slideUp .3s ease-out}.notification-content{background:#081a3f;color:#fff;padding:16px 24px;border-radius:12px;font-size:1rem;font-weight:600;text-align:center;box-shadow:0 20px 50px rgba(8,26,63,.3);min-width:240px}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (max-width:520px){.transfer-heading h1{font-size:1.7rem}.transfer-lead{font-size:.88rem}.form-buttons{grid-template-columns:1fr 1fr;gap:10px}.btn{padding:14px 16px;font-size:.98rem;min-height:48px}}.approval-page{width:100%;padding-bottom:24px}.approval-tabs{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:0;gap:0;margin-bottom:18px;border-bottom:1px solid #e2e8f0}.approval-tab{padding:12px 8px 14px;background:transparent;color:#64748b;font-size:.92rem;font-weight:600;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .2s ease,border-color .2s ease}.approval-tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:700}.approval-filters{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.approval-search{position:relative;display:flex;align-items:center}.approval-search-icon{position:absolute;left:14px;width:18px;height:18px;color:#94a3b8;pointer-events:none}.approval-search-input{width:100%;padding:14px 16px 14px 42px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;color:#1f2937;font-size:clamp(11px,2.8vw,14px);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.approval-search-input::placeholder{color:#9ca3af}.approval-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}.approval-filter-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.approval-filter-select{min-width:0;padding-top:12px;padding-bottom:12px}.approval-date-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:12px 14px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;color:#334155;font-size:clamp(11px,2.8vw,13px);font-weight:600;cursor:pointer;overflow:hidden}.approval-date-btn svg{width:18px;height:18px;flex-shrink:0;color:#64748b}.approval-date-btn span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.approval-date-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.approval-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.approval-count{margin:0;font-size:.9rem;font-weight:700;color:#0f172a}.approval-sort-select{width:auto;min-width:130px;max-width:48%;padding-top:10px;padding-bottom:10px;font-size:.85rem}.approval-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.approval-empty{padding:32px 16px;text-align:center;color:#64748b;font-size:.95rem;border-radius:16px;background:#fff;border:1px dashed #e2e8f0}.approval-card{position:relative;width:100%;padding:16px 40px 16px 16px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;text-align:left;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.approval-card:hover{border-color:#bfdbfe;box-shadow:0 8px 24px rgba(37,99,235,.08)}.approval-card-top{margin-bottom:12px}.approval-card-top.approval-detail-status-row{padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid #e2e8f0}.approval-card-label{font-size:.82rem;color:#64748b;font-weight:600}.approval-badge{flex-shrink:0;display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:.78rem;font-weight:700;line-height:1.2}.approval-badge-pending{background:#fff7ed;color:#ea580c}.approval-badge-approved{background:#ecfdf5;color:#059669}.approval-badge-rejected{background:#fef2f2;color:#dc2626}.approval-card-details{margin:0;display:flex;flex-direction:column;gap:8px}.approval-detail-row{display:grid;grid-template-columns:minmax(88px,108px) 1fr;grid-gap:8px 12px;gap:8px 12px;align-items:center}.approval-detail-row dt{margin:0;font-size:.82rem;color:#64748b;font-weight:600;text-align:left}.approval-detail-row dd{margin:0;font-size:.88rem;color:#1e293b;font-weight:600;text-align:right;word-break:break-all}.approval-card-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#94a3b8;font-size:1.4rem;line-height:1}.approval-detail-page .approval-detail-card{padding:18px 16px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;margin-bottom:20px}.approval-detail-status-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid #e2e8f0}.approval-detail-fields{gap:10px}.approval-result-banner{margin-bottom:16px;padding:14px 16px;border-radius:16px;background:#eef4ff;border:1px solid #dbeafe}.approval-result-banner p{margin:0;font-size:.95rem;font-weight:700;color:#081a3f;line-height:1.5;text-align:center}.approval-detail-back-btn{display:flex;width:100%;margin-bottom:12px;text-decoration:none}.approval-detail-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;margin-bottom:20px}.approval-detail-actions .btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.approval-back-link{display:inline-flex;align-items:center;font-size:.95rem;font-weight:700;color:#2563eb;text-decoration:none}.approval-back-link:hover{text-decoration:underline}@media (max-width:520px){.approval-tab{font-size:.84rem;padding:10px 4px 12px}.approval-detail-row{grid-template-columns:minmax(80px,96px) 1fr;gap:8px 10px}}.is-admin-page .app-background{min-height:100vh;padding:0;background:#eef2f7}.app-container-admin{width:100%;max-width:none;margin:0;padding:0;border-radius:0;box-shadow:none;background:transparent}.admin-shell{display:grid;grid-template-columns:240px minmax(0,1fr);min-height:100vh}.admin-sidebar{background:#0f172a;color:#e2e8f0;padding:24px 16px}.admin-sidebar-brand{display:flex;flex-direction:column;gap:4px;margin-bottom:28px;padding:0 8px}.admin-sidebar-logo{font-size:1rem;font-weight:800;letter-spacing:.02em}.admin-sidebar-sub{font-size:.82rem;color:#94a3b8}.admin-sidebar-nav{display:flex;flex-direction:column;gap:6px}.admin-sidebar-link{display:block;padding:11px 12px;border-radius:10px;color:#cbd5e1;text-decoration:none;font-size:.92rem;font-weight:600;transition:background .15s ease,color .15s ease}.admin-sidebar-link:hover{background:hsla(0,0%,100%,.06);color:#fff}.admin-sidebar-link.is-active{background:#2563eb;color:#fff}.admin-sidebar-group{display:flex;flex-direction:column;gap:4px}.admin-sidebar-group-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:11px 12px;border:none;border-radius:10px;background:transparent;color:#cbd5e1;font-size:.92rem;font-weight:600;cursor:pointer;text-align:left;transition:background .15s ease,color .15s ease}.admin-sidebar-group-toggle:hover{background:hsla(0,0%,100%,.06);color:#fff}.admin-sidebar-group-toggle.is-active{background:rgba(37,99,235,.22);color:#fff}.admin-sidebar-group-chevron{font-size:.82rem;color:#94a3b8;transition:transform .15s ease}.admin-sidebar-group-toggle.is-active .admin-sidebar-group-chevron,.admin-sidebar-group-toggle:hover .admin-sidebar-group-chevron{color:#e2e8f0}.admin-sidebar-group-chevron.is-open{transform:rotate(0deg)}.admin-sidebar-group-chevron:not(.is-open){transform:rotate(-90deg)}.admin-sidebar-submenu{display:flex;flex-direction:column;gap:4px;padding-left:10px;margin-left:10px;border-left:1px solid hsla(0,0%,100%,.12)}.admin-sidebar-sublink{display:block;padding:9px 12px;border-radius:8px;color:#94a3b8;text-decoration:none;font-size:.86rem;font-weight:600;transition:background .15s ease,color .15s ease}.admin-sidebar-sublink:hover{background:hsla(0,0%,100%,.06);color:#fff}.admin-sidebar-sublink.is-active{background:#2563eb;color:#fff}.admin-main-wrap{display:flex;flex-direction:column;min-width:0}.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 32px;background:#fff;border-bottom:1px solid #e2e8f0}.admin-topbar-title{margin:0;font-size:1.5rem;color:#0f172a}.admin-topbar-desc{margin:6px 0 0;color:#64748b;font-size:.92rem}.admin-topbar-user{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.admin-topbar-user-label{font-size:.78rem;color:#94a3b8}.admin-topbar-user-name{font-size:.92rem;font-weight:700;color:#0f172a}.admin-content{padding:24px 32px 40px}.admin-dashboard{display:flex;flex-direction:column;gap:24px}.admin-stat-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-gap:16px;gap:16px}.admin-stat-card{display:flex;flex-direction:column;gap:10px;padding:20px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 8px 24px rgba(15,23,42,.04);text-decoration:none;color:inherit}.admin-stat-card.is-clickable{cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.admin-stat-card.is-clickable:hover{transform:translateY(-1px);border-color:#bfdbfe;box-shadow:0 12px 28px rgba(37,99,235,.1)}.admin-stat-label{font-size:.88rem;color:#64748b;font-weight:600}.admin-stat-value{font-size:1.05rem;color:#0f172a;line-height:1.4}.admin-panel{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 8px 24px rgba(15,23,42,.04);padding:24px}.admin-panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.admin-panel-header h2{margin:0;font-size:1.15rem;color:#0f172a}.admin-panel-meta{font-size:.88rem;color:#64748b;font-weight:600}.admin-panel-desc{margin:0 0 20px;color:#64748b;font-size:.92rem}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;min-width:860px}.admin-table-wide{min-width:1400px}.admin-table td,.admin-table th{padding:12px 14px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:middle;font-size:.9rem;color:#0f172a}.admin-table th{color:#475569;font-weight:700;white-space:nowrap}.admin-table tbody tr:hover,.admin-table th{background:#f8fafc}.admin-table-empty{text-align:center;color:#64748b;padding:32px 14px!important}.admin-table-message{max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-table-link{color:#2563eb;font-weight:700;text-decoration:none}.admin-table-link:hover{text-decoration:underline}.admin-table-muted{color:#94a3b8}.admin-status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:.78rem;font-weight:700;background:#eff6ff;color:#2563eb}.admin-status-badge-pending{background:#fff7ed;color:#ea580c}.admin-status-badge-approved{background:#ecfdf5;color:#059669}.admin-status-badge-rejected{background:#fef2f2;color:#dc2626}.admin-table-actions{display:flex;gap:8px;white-space:nowrap}.admin-btn{border:none;border-radius:8px;padding:8px 12px;font-size:.84rem;font-weight:700;cursor:pointer}.admin-btn-primary{background:#2563eb;color:#fff}.admin-btn-primary:hover{background:#1d4ed8}.admin-btn-secondary{background:#fff;color:#334155;border:1px solid #cbd5e1}.admin-btn-secondary:hover{background:#f8fafc}.admin-form{margin-top:8px}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:16px;gap:16px}.admin-form-field{display:flex;flex-direction:column;gap:6px}.admin-form-field label{font-size:.86rem;font-weight:700;color:#475569}.admin-form-input{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;font-size:.9rem;color:#0f172a;background:#fff}.admin-form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12)}.admin-form-actions{margin-top:18px}@media (max-width:1200px){.admin-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:900px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{padding:16px}.admin-sidebar-nav{flex-direction:row;flex-wrap:wrap}.admin-content,.admin-topbar{padding-left:20px;padding-right:20px}.admin-form-grid{grid-template-columns:1fr}}