/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial}}}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:calc(var(--spacing,.25rem) * 0)}.inset-4{inset:calc(var(--spacing,.25rem) * 4)}.inset-8{inset:calc(var(--spacing,.25rem) * 8)}.z-\[9999\]{z-index:9999}.mb-8{margin-bottom:calc(var(--spacing,.25rem) * 8)}.flex{display:flex}.h-16{height:calc(var(--spacing,.25rem) * 16)}.h-28{height:calc(var(--spacing,.25rem) * 28)}.w-28{width:calc(var(--spacing,.25rem) * 28)}.w-44{width:calc(var(--spacing,.25rem) * 44)}.animate-spin{animation:var(--animate-spin,spin 1s linear infinite)}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.rounded-full{border-radius:3.40282e38px}.border-4{border-style:var(--tw-border-style);border-width:4px}.border-transparent{border-color:#0000}.border-t-amber-300{border-top-color:var(--color-amber-300,oklch(87.9% .169 91.605))}.border-t-emerald-400{border-top-color:var(--color-emerald-400,oklch(76.5% .177 163.223))}.border-r-emerald-400{border-right-color:var(--color-emerald-400,oklch(76.5% .177 163.223))}.border-b-sky-400{border-bottom-color:var(--color-sky-400,oklch(74.6% .16 232.661))}.border-l-amber-300{border-left-color:var(--color-amber-300,oklch(87.9% .169 91.605))}.border-l-sky-400{border-left-color:var(--color-sky-400,oklch(74.6% .16 232.661))}.bg-slate-950{background-color:var(--color-slate-950,oklch(12.9% .042 264.695))}.object-contain{object-fit:contain}.text-white{color:var(--color-white,#fff)}.opacity-0{opacity:0}.drop-shadow-\[0_18px_32px_rgba\(16\,185\,129\,0\.22\)\]{--tw-drop-shadow-size:drop-shadow(0 18px 32px var(--tw-drop-shadow-color,#10b98138));--tw-drop-shadow:var(--tw-drop-shadow-size);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function,cubic-bezier(.4, 0, .2, 1)));transition-duration:var(--tw-duration,var(--default-transition-duration,.15s))}.duration-500{--tw-duration:.5s;transition-duration:.5s}.\[animation-direction\:reverse\]{animation-direction:reverse}.\[animation-duration\:0\.9s\]{animation-duration:.9s}.\[animation-duration\:1\.4s\]{animation-duration:1.4s}.\[animation-duration\:2\.1s\]{animation-duration:2.1s}:root{--app-bg:#f5f9ff;--card-bg:#fff;--card-border:#0f172a14;--card-shadow:0 18px 44px #00347814;--sidebar-bg:#fff;--sidebar-accent:#007bff;--sidebar-text:#e2e8f0f0;--sidebar-muted:#64748b;--header-bg:#007bff;--title-color:#0f172a;--body-color:#475569;--line-color:#94a3b840;--primary-color:#007bff;--primary-dark:#005fc4;--warning-soft:#fff7ed;--success-soft:#ecfdf5;--danger-soft:#fef2f2;--sidebar-width:290px;--sidebar-width-collapsed:96px}*{box-sizing:border-box}html{font-size:14px}body{background:var(--app-bg);color:var(--body-color);margin:0;font-family:Manrope,sans-serif}a{text-decoration:none}.app-body{min-height:100vh}.app-shell{min-height:100vh;display:flex}.app-sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);color:var(--sidebar-text);z-index:1035;border-right:1px solid #007bff1f;flex-direction:column;gap:1.5rem;height:100vh;padding:1.5rem 1.1rem;transition:width .25s,transform .25s;display:flex;position:sticky;top:0}.sidebar-brand{justify-content:center;align-items:center;gap:.9rem;display:flex}.sidebar-brand-mark{color:#fff;width:min(140px,100%);height:auto;box-shadow:0 12px 28px #007bff33;box-shadow:none;background:0 0;border-radius:0;place-items:center;font-weight:800;display:grid;overflow:visible}.sidebar-brand-logo{width:100%;height:auto;display:block}.sidebar-brand-logo-icon{display:none}.sidebar-scroll{flex:1;padding-right:.25rem;overflow-y:auto}.sidebar-scroll::-webkit-scrollbar{width:6px}.sidebar-scroll::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:999px}.sidebar-nav .nav-item+.nav-item{margin-top:.15rem}.sidebar-link{color:#334155;border-radius:18px;justify-content:space-between;align-items:center;gap:.75rem;min-height:52px;padding:.85rem 1rem;transition:transform .2s,background .2s,color .2s,box-shadow .2s;display:flex}.sidebar-link:hover{color:var(--primary-color);background:#007bff14;transform:translate(3px)}.sidebar-link.active{color:var(--primary-color);background:#007bff1a;box-shadow:inset 0 0 0 1px #007bff2e}.sidebar-link-start{align-items:center;gap:.9rem;min-width:0;display:inline-flex}.sidebar-link-start i{font-size:1.15rem}.sidebar-label{white-space:nowrap;font-weight:600}.sidebar-chevron{font-size:.9rem;transition:transform .2s}.sidebar-link[aria-expanded=true] .sidebar-chevron{transform:rotate(180deg)}.submenu-list{border-left:1px solid #007bff24;margin-top:.45rem;padding-left:.85rem}.sidebar-link-nested{color:#475569;min-height:46px;margin-left:.45rem}.app-main{flex:1;min-width:0}.app-header{background:var(--header-bg);color:#fff;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex;box-shadow:0 16px 30px #0f4c812e}.header-toggle{color:#fff;background:#ffffff24;border:0;border-radius:16px;width:48px;height:48px}.header-toggle:hover{color:#fff;background:#ffffff38}.header-kicker,.section-kicker{letter-spacing:.12em;text-transform:uppercase;font-size:.75rem;font-weight:800}.page-title,.section-title{color:var(--title-color);font-weight:800}.app-header .page-title{color:#fff;font-size:1.6rem}.header-user-menu{color:#fff;background:0 0;border:0;align-items:center;gap:.75rem;padding:.25rem .35rem;display:inline-flex}.header-user-menu:hover,.header-user-menu:focus,.header-user-menu.show{color:#fff;background:#ffffff1f}.header-user-menu:after{margin-left:0}.header-user-icon{font-size:1.35rem}.header-user-avatar{object-fit:cover;background:#ffffff2e;border:2px solid #ffffffb8;border-radius:8px;flex:0 0 34px;width:34px;height:34px}.header-user{flex-direction:column;line-height:1.2}.header-user-name{font-weight:700}.header-user-role{color:#ffffffbf;font-size:.9rem}.account-menu{border:0;border-radius:8px;padding:.45rem;box-shadow:0 18px 42px #0f172a2e}.account-menu .dropdown-item{color:#334155;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:.65rem;width:100%;padding:.65rem .8rem;font-weight:700;display:flex}.account-menu .dropdown-item:hover,.account-menu .dropdown-item:focus{color:var(--primary-color);background:#007bff14}.account-menu form{margin:0}.account-menu .account-menu-danger{color:#b91c1c}.account-menu .account-menu-danger:hover,.account-menu .account-menu-danger:focus{color:#991b1b;background:#ef444414}.app-content{padding:1.5rem}.content-card,.metric-card{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--card-shadow);border-radius:8px}.content-card{padding:1.5rem}.metric-card{padding:1.35rem;position:relative;overflow:hidden}.metric-icon,.shortcut-icon{color:#fff;background:#007bff;border-radius:8px;place-items:center;width:52px;height:52px;display:grid;box-shadow:0 12px 24px #007bff2e}.metric-icon i,.shortcut-icon i{font-size:1.25rem}.metric-label{color:#64748b;margin-top:1rem;font-weight:700}.metric-value{color:var(--title-color);margin-top:.45rem;font-size:1.65rem;font-weight:800}.section-heading{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.section-title{margin:.2rem 0 0;font-size:1.35rem}.shortcut-card{height:100%;color:inherit;background:#fff;border:1px solid #94a3b833;border-radius:22px;align-items:center;gap:1rem;padding:1rem;transition:transform .2s,box-shadow .2s;display:flex}.shortcut-card:hover{transform:translateY(-2px);box-shadow:0 18px 34px #0f172a14}.shortcut-title{color:var(--title-color);font-weight:800}.shortcut-copy,.timeline-copy,.empty-state{color:#64748b}.timeline-list{flex-direction:column;gap:1rem;display:flex}.timeline-item{align-items:flex-start;gap:.9rem;display:flex}.timeline-dot{background:#007bff;border-radius:999px;width:12px;height:12px;margin-top:.35rem;box-shadow:0 0 0 6px #007bff1f}.timeline-title{color:var(--title-color);font-weight:700}.empty-state{text-align:center;border:1px dashed #94a3b859;border-radius:20px;padding:2rem}.empty-state i{color:var(--primary-color);margin-bottom:.8rem;font-size:1.8rem;display:inline-block}.app-alert{border:0;border-radius:18px;align-items:flex-start;gap:.85rem;display:flex;box-shadow:0 16px 30px #0f172a14}.alert-success.app-alert{background:var(--success-soft);color:#065f46}.alert-danger.app-alert{background:var(--danger-soft);color:#991b1b}.app-table{--bs-table-bg:transparent;--bs-table-border-color:#94a3b82e;margin-bottom:0}.app-table thead th{color:#475569;text-transform:uppercase;letter-spacing:.08em;padding-bottom:.9rem;font-size:.8rem}.app-table tbody tr:hover{background:#f8fafce6}.selection-card{cursor:pointer;background:#fff;border:1px solid #94a3b83d;border-radius:18px;align-items:center;gap:.75rem;padding:.9rem 1rem;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex}.selection-card:hover{border-color:#0f766e61;transform:translateY(-1px);box-shadow:0 14px 26px #0f172a0f}.menu-access-groups{flex-direction:column;gap:.75rem;display:flex}.menu-access-row{grid-template-columns:minmax(140px,180px) minmax(0,1fr);align-items:stretch;gap:.75rem;min-width:0;display:grid}.menu-access-group-title{color:var(--title-color);background:#f8fafce0;border:1px solid #94a3b83d;border-radius:8px;padding:.85rem .95rem;font-weight:800}.menu-access-items{gap:.65rem;min-width:0;padding-bottom:.25rem;display:flex;overflow-x:auto}.menu-access-items::-webkit-scrollbar{height:6px}.menu-access-items::-webkit-scrollbar-thumb{background:#64748b47;border-radius:999px}.menu-access-item{border-radius:8px;flex:none;min-width:180px;max-width:240px}.menu-access-item span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.form-control,.form-select{border-color:#94a3b859;border-radius:16px;padding:.8rem .95rem;font-size:.875rem}.form-label,.form-check-label,.invalid-feedback{font-size:.85rem}.form-control-lg{font-size:.95rem}.form-control:focus,.form-select:focus{border-color:#0f766e70;box-shadow:0 0 0 .25rem #0f766e1f}.select2-container--default .select2-selection--single,.select2-container--default .select2-selection--multiple{border-color:#94a3b859;border-radius:16px;align-items:center;min-height:45px;display:flex}.select2-container--default .select2-selection--single .select2-selection__rendered{color:var(--body-color);padding-left:.95rem;padding-right:2.2rem;line-height:43px}.select2-container--default .select2-selection--single .select2-selection__arrow{height:43px;right:.65rem}.select2-container--default.select2-container--focus .select2-selection--single,.select2-container--default.select2-container--focus .select2-selection--multiple,.select2-container--default.select2-container--open .select2-selection--single,.select2-container--default.select2-container--open .select2-selection--multiple{border-color:#0f766e70;box-shadow:0 0 0 .25rem #0f766e1f}.select2-container--default .select2-selection--multiple{padding:.25rem .45rem}.select2-container--default .select2-selection--multiple .select2-selection__choice{color:var(--title-color);background:#007bff1a;border:0;border-radius:10px;padding:.25rem .45rem .25rem 1.35rem;font-weight:700}.select2-container--default .select2-selection--multiple .select2-selection__choice__remove{color:#64748b;border-right:0;left:.35rem}.select2-dropdown{border-color:#94a3b859;border-radius:8px;overflow:hidden;box-shadow:0 18px 42px #0f172a1f}.select2-container--default .select2-search--dropdown .select2-search__field{border-color:#94a3b859;border-radius:10px;padding:.55rem .7rem}.select2-results__option{padding:.65rem .85rem}.select2-container--default .select2-results__option--highlighted.select2-results__option--selectable{background:var(--primary-color)}.btn{border-radius:16px;font-weight:700}.btn-primary{background:var(--primary-color);border-color:#0000}.btn-primary:hover,.btn-primary:focus{background:var(--primary-dark);border-color:#0000}.pagination{--bs-pagination-border-radius:14px;--bs-pagination-color:var(--primary-color);--bs-pagination-hover-color:var(--primary-dark);--bs-pagination-active-bg:var(--primary-color);--bs-pagination-active-border-color:var(--primary-color)}.sidebar-overlay{display:none}.sidebar-collapsed .app-sidebar{width:var(--sidebar-width-collapsed)}.sidebar-collapsed .sidebar-brand-mark{width:34px;height:34px;overflow:visible}.sidebar-collapsed .sidebar-brand-logo-full{display:none}.sidebar-collapsed .sidebar-brand-logo-icon{object-fit:contain;width:100%;height:100%;display:block}.sidebar-collapsed .sidebar-label,.sidebar-collapsed .sidebar-chevron{display:none}.sidebar-collapsed .sidebar-link{justify-content:center;padding-inline:.75rem}.sidebar-collapsed .sidebar-link-start{justify-content:center}.sidebar-collapsed .submenu-list{border-left:0;padding-left:0}.auth-body{background:linear-gradient(135deg,#e8f0fe 0%,#f0f4ff 40%,#e8f0fe 100%);place-items:center;min-height:100vh;padding:2rem;display:grid;position:relative}.auth-body:before{content:"";pointer-events:none;background-image:radial-gradient(circle at 20% 20%,#007bff0f 0%,#0000 50%),radial-gradient(circle at 80% 80%,#007bff0d 0%,#0000 50%);position:absolute;inset:0}.auth-shell{z-index:1;background:#fff;border-radius:28px;grid-template-columns:1.1fr .9fr;width:min(1100px,100%);display:grid;position:relative;overflow:hidden;box-shadow:0 40px 100px #0f172a38,0 0 0 1px #007bff14}.auth-panel{padding:3rem}.auth-panel-copy{color:#fff;background:linear-gradient(150deg,#0062cc 0%,#007bff 45%,#1a8aff 100%);flex-direction:column;justify-content:center;display:flex;position:relative;overflow:hidden}.auth-panel-copy:before{content:"";pointer-events:none;background:#ffffff0f;border-radius:50%;width:420px;height:420px;position:absolute;top:-40%;right:-20%}.auth-panel-copy:after{content:"";pointer-events:none;background:#ffffff0a;border-radius:50%;width:320px;height:320px;position:absolute;bottom:-30%;left:-15%}.status-badge{border-radius:999px;justify-content:center;align-items:center;min-width:74px;padding:.35rem .7rem;font-size:.78rem;font-weight:800;display:inline-flex}.user-table-avatar{object-fit:cover;width:38px;height:38px;color:var(--primary-color);background:#007bff1a;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.status-selesai{color:#166534;background:#dcfce7}.status-proses{color:#9a3412;background:#ffedd5}.status-pending{color:#854d0e;background:#fef9c3}.progress-history-list{gap:.85rem;display:grid}.progress-history-card{background:#fff;border:1px solid #94a3b847;border-radius:4px;padding:.85rem;box-shadow:0 2px 8px #0f172a0a}.progress-history-title{color:#1f2937;margin:0;font-size:.95rem;font-weight:800}.progress-history-subtitle,.progress-history-meta{color:#64748b;font-size:.76rem}.progress-history-bar{background:#e5e7eb;border-radius:2px;height:12px;margin:.7rem 0}.progress-history-bar .progress-bar{font-size:.68rem;font-weight:800;line-height:12px}.progress-history-bar-pending .progress-bar{background:#f59e0b}.progress-history-bar-proses .progress-bar{background:#0d6efd}.progress-history-bar-selesai .progress-bar{background:#22a060}.progress-history-actions{align-items:center;gap:.55rem;display:flex}.progress-history-form{flex:1;grid-template-columns:minmax(140px,1fr) minmax(90px,.75fr) auto;gap:.55rem;display:grid}.progress-history-actions .btn{min-width:74px}@media (width<=575.98px){.progress-history-actions,.progress-history-form{grid-template-columns:1fr;display:grid}.progress-history-actions .btn{width:100%}}.app-modal{border:0;border-radius:8px;box-shadow:0 24px 60px #0f172a2e}.audit-json{white-space:pre-wrap;background:#f8fafc;border:1px solid #94a3b838;border-radius:8px;max-height:160px;padding:.75rem;overflow:auto}.auth-badge{letter-spacing:.1em;text-transform:uppercase;background:#ffffff26;border:1px solid #fff3;border-radius:999px;width:fit-content;margin-bottom:.25rem;padding:.45rem 1rem;font-size:.75rem;font-weight:800;display:inline-flex}.auth-logo{filter:brightness(0)invert();opacity:.95;width:min(160px,65%);height:auto;margin-bottom:2rem;display:block}.auth-title{color:#fff;margin:1.25rem 0 .75rem;font-size:clamp(1.75rem,2.8vw,2.6rem);font-weight:800;line-height:1.1}.auth-text{color:#e2e8f0d9;max-width:34rem;font-size:1rem;line-height:1.6}.auth-credentials{background:#ffffff14;border:1px solid #ffffff1f;border-radius:22px;margin-top:2rem;padding:1.2rem}.auth-credentials-label{margin-bottom:.45rem;font-weight:800}.auth-panel-form{background:#fff;justify-content:center;align-items:center;padding:3rem 3.5rem;display:flex}.auth-form-wrap{width:100%;max-width:380px}.auth-form-logo-wrap{margin-bottom:2rem}.auth-form-logo{object-fit:contain;object-position:center;width:auto;max-width:160px;height:44px;margin:0 auto 1.25rem;display:block}.auth-form-divider{opacity:1;background:linear-gradient(90deg,#007bff 0%,#007bff4d 50%,#0000 100%);border:0;height:2px;margin:0}@media (width<=991.98px){.app-sidebar{position:fixed;left:0;transform:translate(-100%);box-shadow:0 24px 60px #0f172a47}.sidebar-open .app-sidebar{transform:translate(0)}.sidebar-overlay{background:#0f172a6b;border:0;position:fixed;inset:0}.sidebar-open .sidebar-overlay{z-index:1030;display:block}.app-header,.app-content{padding:1rem}.menu-access-row{grid-template-columns:1fr}.menu-access-item{min-width:160px}.auth-shell{grid-template-columns:1fr}.auth-panel-copy{display:none}}@media (width<=767.98px){.section-heading,.app-header{flex-direction:column;align-items:stretch}.auth-body{align-items:flex-start;padding:1rem}.auth-shell{border-radius:20px;min-height:auto}.auth-panel,.auth-panel-form{padding:2rem 1.5rem}}.doc-manager{background:var(--card-bg);border:1px solid var(--card-border);height:calc(100vh - 120px);box-shadow:var(--card-shadow);border-radius:8px;grid-template-columns:300px 1fr;gap:0;display:grid;overflow:hidden}.doc-panel{flex-direction:column;min-height:0;display:flex}.doc-panel-tree{background:#f8fafc;border-right:1px solid #94a3b838}.doc-panel-files{background:#fff}.doc-panel-header{border-bottom:1px solid #94a3b82e;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;min-height:56px;padding:.85rem 1rem;display:flex}.doc-panel-title{color:var(--title-color);align-items:center;gap:.5rem;margin:0;font-size:.9rem;font-weight:800;display:flex}.doc-panel-header-info{flex-direction:column;flex:1;gap:.25rem;min-width:0;display:flex}.doc-panel-header-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.doc-breadcrumbs{flex-wrap:wrap;align-items:center;gap:.35rem;font-size:.82rem;display:flex}.doc-breadcrumb-item{color:#64748b;font-weight:600;transition:color .15s}.doc-breadcrumb-item:hover{color:var(--primary-color)}.doc-breadcrumb-item.active{color:var(--title-color);font-weight:800}.doc-breadcrumb-sep{color:#cbd5e1;font-size:.7rem}.doc-file-count{color:#94a3b8;font-size:.75rem;font-weight:600}.doc-owner-badge{color:#64748b;background:#007bff14;border-radius:999px;align-items:center;gap:.3rem;width:fit-content;padding:.15rem .55rem;font-size:.75rem;font-weight:700;display:inline-flex}.doc-search-form{min-width:180px}.doc-search-wrap{position:relative}.doc-search-wrap i{color:#94a3b8;pointer-events:none;font-size:.8rem;position:absolute;top:50%;left:.65rem;transform:translateY(-50%)}.doc-search-wrap .form-control{border-radius:10px;padding-left:2rem;font-size:.82rem}.doc-tree-filter{border-bottom:1px solid #94a3b826;padding:.5rem .75rem}.doc-tree-filter .form-select{border-radius:8px;padding:.45rem .65rem;font-size:.8rem}.doc-tree-scroll{flex:1;padding:.5rem;overflow-y:auto}.doc-tree-scroll::-webkit-scrollbar{width:5px}.doc-tree-scroll::-webkit-scrollbar-thumb{background:#94a3b840;border-radius:999px}.doc-tree-list{margin:0;padding:0;list-style:none}.doc-tree-sublist{border-left:1px solid #007bff1f;margin-left:.25rem}.doc-tree-item{margin-bottom:1px}.doc-tree-item-row{align-items:center;gap:.15rem;padding-right:.25rem;display:flex}.doc-tree-toggle{color:#94a3b8;cursor:pointer;background:0 0;border:0;border-radius:4px;flex-shrink:0;place-items:center;width:22px;height:22px;padding:0;font-size:.7rem;transition:transform .2s,color .2s;display:grid}.doc-tree-toggle:hover{color:var(--primary-color);background:#007bff14}.doc-tree-toggle:not(.collapsed) i{transform:rotate(90deg)}.doc-tree-toggle-placeholder{flex-shrink:0;width:22px;height:22px}.doc-tree-item-link{color:#475569;border-radius:8px;flex:1;align-items:center;gap:.45rem;min-width:0;padding:.4rem .55rem;font-size:.82rem;font-weight:600;text-decoration:none;transition:all .15s;display:flex}.doc-tree-item-link:hover{color:var(--primary-color);background:#007bff0f}.doc-tree-item-link.active{color:var(--primary-color);background:#007bff1a;font-weight:800}.doc-tree-item-link i{color:#f59e0b;flex-shrink:0;font-size:1rem}.doc-tree-item-link.active i{color:var(--primary-color)}.doc-tree-item-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.doc-tree-owner-tag{color:#94a3b8;white-space:nowrap;background:#94a3b81f;border-radius:4px;flex-shrink:0;padding:.1rem .4rem;font-size:.65rem;font-weight:700}.doc-tree-user-link{color:var(--title-color);border-radius:8px;flex:1;align-items:center;gap:.45rem;min-width:0;padding:.45rem .55rem;font-size:.82rem;font-weight:800;display:flex}.doc-tree-user-link i{color:var(--primary-color);flex-shrink:0;font-size:1rem}.doc-tree-empty{color:#94a3b8;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:2rem 1rem;display:flex}.doc-tree-empty i{color:#cbd5e1;margin-bottom:.5rem;font-size:2rem}.doc-tree-empty p{margin:0;font-size:.82rem;line-height:1.5}.doc-files-scroll{flex:1;padding:1rem;overflow-y:auto}.doc-files-scroll::-webkit-scrollbar{width:5px}.doc-files-scroll::-webkit-scrollbar-thumb{background:#94a3b840;border-radius:999px}.doc-files-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.85rem;display:grid}.doc-file-card{background:#fff;border:1px solid #94a3b833;border-radius:12px;flex-direction:column;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;overflow:hidden}.doc-file-card:hover{border-color:#007bff40;transform:translateY(-2px);box-shadow:0 8px 24px #0f172a14}.doc-file-preview{background:linear-gradient(135deg,#f1f5f9,#e2e8f0);place-items:center;height:120px;display:grid;overflow:hidden}.doc-file-preview img{object-fit:cover;width:100%;height:100%}.doc-file-preview>i{font-size:2.5rem}.doc-file-info{flex-direction:column;flex:1;gap:.15rem;padding:.65rem .75rem;display:flex}.doc-file-name{color:var(--title-color);text-overflow:ellipsis;white-space:nowrap;font-size:.78rem;font-weight:700;overflow:hidden}.doc-file-meta{color:#94a3b8;font-size:.7rem;font-weight:600}.doc-file-actions{gap:.35rem;padding:0 .75rem .65rem;display:flex}.doc-file-actions .btn{border-radius:8px;padding:.25rem .45rem;font-size:.75rem}.doc-file-actions form{margin:0}.doc-files-empty,.doc-no-selection{text-align:center;justify-content:center;align-items:center;height:100%;display:flex}.doc-files-empty{color:#94a3b8;flex-direction:column;padding:2rem}.doc-files-empty i{color:#cbd5e1;margin-bottom:.75rem;font-size:2.5rem}.doc-files-empty p{margin:0 0 .75rem;font-size:.9rem}.doc-no-selection-inner{color:#94a3b8;flex-direction:column;align-items:center;gap:.5rem;display:flex}.doc-no-selection-inner i{color:#cbd5e1;font-size:3rem}.doc-no-selection-inner h5{color:var(--title-color);margin:0;font-weight:800}.doc-no-selection-inner p{max-width:260px;margin:0 0 .5rem;font-size:.85rem}.doc-upload-zone{text-align:center;color:#64748b;background:#007bff05;border:2px dashed #007bff4d;border-radius:16px;flex-direction:column;align-items:center;gap:.35rem;padding:2rem;transition:border-color .2s,background .2s;display:flex}.doc-upload-zone i{color:var(--primary-color);opacity:.6;font-size:2.5rem}.doc-upload-zone p{margin:0;font-size:.85rem}.doc-upload-zone-active{border-color:var(--primary-color);background:#007bff0f}.doc-upload-zone-active i{opacity:1}.doc-upload-preview{border:1px solid #94a3b833;border-radius:12px;margin-top:1rem;overflow:hidden}.doc-upload-preview-header{background:#f8fafc;border-bottom:1px solid #94a3b826;justify-content:space-between;align-items:center;padding:.65rem .85rem;font-size:.82rem;display:flex}.doc-upload-preview-list{max-height:280px;padding:.45rem;overflow-y:auto}.doc-upload-item{border-radius:8px;align-items:center;gap:.65rem;padding:.45rem .55rem;transition:background .15s;display:flex}.doc-upload-item:hover{background:#f8fafc}.doc-upload-item-thumb{background:#f1f5f9;border-radius:8px;flex-shrink:0;place-items:center;width:48px;height:48px;display:grid;overflow:hidden}.doc-upload-item-thumb img{object-fit:cover;width:100%;height:100%}.doc-upload-item-icon i{font-size:1.5rem}.doc-upload-item-info{flex-direction:column;flex:1;min-width:0;display:flex}.doc-upload-item-name{color:var(--title-color);text-overflow:ellipsis;white-space:nowrap;font-size:.8rem;font-weight:700;overflow:hidden}.doc-upload-item-size{color:#94a3b8;font-size:.72rem}.doc-upload-item-remove{border-radius:6px;flex-shrink:0;padding:.2rem .35rem;font-size:.7rem}@media (width<=991.98px){.doc-manager{grid-template-columns:250px 1fr;height:calc(100vh - 100px)}}@media (width<=767.98px){.doc-manager{grid-template-columns:1fr;height:auto;min-height:calc(100vh - 100px)}.doc-panel-tree{border-bottom:1px solid #94a3b838;border-right:0;max-height:250px}.doc-files-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.doc-panel-header{flex-direction:column;align-items:stretch}.doc-panel-header-actions{justify-content:flex-end}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}
