*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,sans-serif;background:linear-gradient(180deg,#fffdfd 0%,#f7f8ff 35%,#eef4ff 100%);color:#15213d;min-height:100vh;-webkit-font-smoothing:antialiased}img{max-width:100%}a{text-decoration:none;color:inherit}button,input,select,textarea{font:inherit}svg{width:1.1rem;height:1.1rem;display:block;flex:none}
:root{--bg:#f5f7ff;--surface:rgba(255,255,255,.72);--surface-strong:#fff;--stroke:rgba(105,129,184,.18);--stroke-strong:rgba(105,129,184,.28);--text:#15213d;--muted:#61708f;--primary:#6b73ff;--primary-2:#8f5bff;--cyan:#18b8d8;--pink:#ff5fa2;--gold:#f1b33d;--green:#29b574;--danger:#ef4e61;--shadow:0 24px 80px rgba(95,116,180,.16);--radius:24px;--radius-sm:16px}
.light-theme{background:radial-gradient(circle at top left,#ffe7f3 0%,transparent 30%),radial-gradient(circle at bottom right,#d8efff 0%,transparent 30%),linear-gradient(160deg,#fffefc 0%,#f4f7ff 55%,#eef4ff 100%)}
.glass-card{background:var(--surface);backdrop-filter:blur(20px);border:1px solid var(--stroke);box-shadow:var(--shadow);border-radius:var(--radius)}
.app-shell{display:flex;min-height:100vh}.sidebar{width:300px;padding:22px 18px 18px;display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100vh}.main-content{flex:1;padding:22px 22px 28px;min-width:0}.sidebar-logo{display:flex;gap:14px;align-items:center;padding:16px;border-radius:28px;background:rgba(255,255,255,.65);border:1px solid var(--stroke);box-shadow:0 12px 30px rgba(113,128,183,.12)}.brand-logo{width:70px;height:70px;object-fit:cover;border-radius:18px;border:1px solid rgba(0,0,0,.05);background:#fff}.logo-kicker{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--pink)}.logo-name{font-family:Manrope,Inter,sans-serif;font-weight:800;font-size:1.35rem;letter-spacing:-.03em}.sidebar-nav{display:flex;flex-direction:column;gap:12px;padding:18px;border-radius:28px;background:rgba(255,255,255,.62);border:1px solid var(--stroke);box-shadow:0 12px 30px rgba(113,128,183,.12)}.nav-section{font-size:.73rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#8a97b7;padding:2px 6px}.nav-item{display:flex;align-items:center;gap:12px;padding:13px 14px;border-radius:18px;color:#33415f;transition:.25s ease;font-weight:600}.nav-item:hover,.nav-item.active{background:linear-gradient(135deg,rgba(107,115,255,.13),rgba(143,91,255,.14));color:#1e2a49;transform:translateY(-1px)}.nav-badge{margin-left:auto;min-width:30px;text-align:center;padding:4px 8px;border-radius:999px;background:#eef2ff;color:#5460f3;font-size:.75rem;font-weight:700}.side-mini-card{display:flex;gap:12px;align-items:center;padding:12px 14px;border-radius:18px;background:rgba(248,250,255,.88);border:1px solid rgba(125,143,194,.15)}.side-mini-card strong{display:block;font-size:1rem}.side-mini-card span{display:block;color:var(--muted);font-size:.82rem}.sidebar-user{display:flex;align-items:center;gap:12px;margin-top:auto;padding:16px;border-radius:28px;background:rgba(255,255,255,.72);border:1px solid var(--stroke);box-shadow:0 12px 30px rgba(113,128,183,.12)}.user-avatar{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#6b73ff,#ff5fa2);display:grid;place-items:center;color:#fff;font-weight:800}.user-copy{min-width:0}.user-name{font-weight:700}.user-role{font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.logout-form{margin-left:auto}.btn-logout,.btn-icon{width:40px;height:40px;border-radius:14px;border:1px solid var(--stroke);background:#fff;color:#33415f;display:grid;place-items:center;cursor:pointer;transition:.2s}.btn-logout:hover,.btn-icon:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(94,112,176,.15)}
.topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:24px 26px;margin-bottom:20px;border-radius:32px;background:linear-gradient(135deg,rgba(255,255,255,.78),rgba(250,250,255,.62));border:1px solid var(--stroke);box-shadow:var(--shadow)}.topbar-kicker,.hero-kicker{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--pink)}.topbar-title{font-family:Manrope,Inter,sans-serif;font-weight:800;font-size:2rem;letter-spacing:-.04em;margin-top:6px}.topbar-sub{margin-top:8px;color:var(--muted);max-width:760px}.topbar-actions{display:flex;gap:10px;flex-wrap:wrap}.page-body{display:flex;flex-direction:column;gap:20px}.hero-banner{display:flex;justify-content:space-between;align-items:end;gap:18px;padding:28px 30px;background:linear-gradient(135deg,rgba(255,255,255,.7),rgba(239,246,255,.66)),radial-gradient(circle at top right,rgba(255,95,162,.16),transparent 33%),radial-gradient(circle at bottom left,rgba(107,115,255,.16),transparent 38%)}.hero-banner h1{margin:8px 0 10px;font-size:2.2rem;line-height:1.03;letter-spacing:-.05em;max-width:730px}.hero-banner p{margin:0;color:var(--muted);max-width:780px}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:12px 18px;border:none;border-radius:16px;font-weight:700;cursor:pointer;transition:.25s ease}.btn:hover{transform:translateY(-1px)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 16px 38px rgba(107,115,255,.3)}.btn-secondary{background:#fff;border:1px solid var(--stroke);color:#24314f}.btn-danger{background:linear-gradient(135deg,#ff708c,#ef4e61);color:#fff;box-shadow:0 14px 34px rgba(239,78,97,.25)}.btn-ghost{background:rgba(255,255,255,.55);border:1px solid var(--stroke);color:#435071}.btn-sm{padding:9px 12px;border-radius:12px}.btn-block{width:100%}.btn-login-xl{padding:15px 22px;font-size:1rem}
.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px}.stat-card{padding:22px;border-radius:28px;border:1px solid var(--stroke);background:rgba(255,255,255,.72);box-shadow:var(--shadow);overflow:hidden;position:relative}.stat-card::after{content:"";position:absolute;inset:auto -20px -36px auto;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.45)}.stat-icon{width:50px;height:50px;border-radius:18px;display:grid;place-items:center;color:#fff;margin-bottom:18px}.stat-num{font-size:2rem;font-weight:800;letter-spacing:-.05em}.stat-lbl{color:var(--muted)}.stat-blue .stat-icon{background:linear-gradient(135deg,#6b73ff,#7697ff)}.stat-pink .stat-icon{background:linear-gradient(135deg,#ff5fa2,#ff8c8f)}.stat-cyan .stat-icon{background:linear-gradient(135deg,#10b2d8,#4ecbff)}.stat-gold .stat-icon{background:linear-gradient(135deg,#f1b33d,#f6d36c)}.stat-green .stat-icon{background:linear-gradient(135deg,#24b678,#6ddf9d)}
.filter-bar{display:grid;grid-template-columns:minmax(220px,1.5fr) repeat(3,minmax(160px,.6fr)) auto auto;gap:12px;padding:18px}.search-wrap{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--stroke);padding:0 14px;border-radius:18px}.search-input,.filter-select,.notes-area{width:100%;border:1px solid var(--stroke);background:#fff;border-radius:16px;padding:12px 14px;color:var(--text);outline:none}.search-wrap .search-input{border:none;padding:13px 0;background:transparent}.search-input:focus,.filter-select:focus,.notes-area:focus{border-color:rgba(107,115,255,.45);box-shadow:0 0 0 4px rgba(107,115,255,.08)}
.doc-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.doc-card{display:flex;flex-direction:column;gap:14px;padding:18px;transition:.25s ease}.doc-card:hover{transform:translateY(-3px)}.doc-card-header{display:flex;gap:12px;align-items:flex-start}.doc-cat-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center}.doc-title{font-weight:800;font-size:1.08rem;line-height:1.2}.doc-issuer{color:var(--muted);font-size:.92rem;margin-top:4px}.doc-thumb{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:18px;border:1px solid rgba(0,0,0,.05);background:#fff}.doc-thumb-ph{display:grid;place-items:center;width:100%;aspect-ratio:16/10;border-radius:18px;background:linear-gradient(135deg,#f7f1ff,#e9f2ff);color:#6977ff;border:1px solid var(--stroke)}.doc-thumb-ph svg{width:52px;height:52px}.doc-meta,.tag-list{display:flex;gap:8px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:999px;border:1px solid var(--stroke-strong);background:#fff;font-size:.78rem;font-weight:700}.soft-badge{background:#f5f7ff;color:#586685}.imp-1{background:#f4f5f8;color:#768199}.imp-2{background:#edf4ff;color:#476fbf}.imp-3{background:#fff5dd;color:#b6841e}.imp-4{background:#ffe8d7;color:#ce6d1d}.imp-5{background:#ffe2e6;color:#d74f63}.doc-summary{color:var(--muted);line-height:1.5;min-height:48px}.doc-footer{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:auto}.doc-date{color:#8a95af;font-size:.86rem}.doc-actions-row{display:flex;gap:8px}.empty-state{padding:52px 24px;text-align:center}.empty-icon{width:82px;height:82px;margin:0 auto 16px;border-radius:24px;display:grid;place-items:center;background:linear-gradient(135deg,#eaefff,#ffe3f0);color:#6b73ff}.empty-icon svg{width:42px;height:42px}
.doc-detail{display:grid;grid-template-columns:minmax(0,1.6fr) 360px;gap:18px}.detail-preview,.detail-card{padding:18px}.detail-card h3{margin:0 0 14px;font-size:1.1rem}.detail-row{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid rgba(115,132,178,.12)}.detail-row:last-child{border-bottom:none}.detail-lbl{color:var(--muted);font-weight:600}.detail-val{font-weight:700;text-align:right}.text-muted{color:var(--muted);font-weight:500}.break-word{word-break:break-word}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem}.danger-text{color:var(--danger)}.notes-area{min-height:140px;resize:vertical}.fallback-preview{min-height:360px;display:grid;place-items:center;color:var(--muted);gap:12px}
.upload-zone{position:relative;padding:48px 24px;text-align:center;border:2px dashed rgba(107,115,255,.22);cursor:pointer}.upload-zone.drag{transform:scale(1.01);border-color:rgba(107,115,255,.55)}.upload-zone input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-zone-icon{width:78px;height:78px;margin:0 auto 14px;border-radius:24px;background:linear-gradient(135deg,#6b73ff,#ff5fa2);display:grid;place-items:center;color:#fff}.upload-zone-icon svg{width:34px;height:34px}.processing-card,.result-card,.alert{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;margin-top:14px;border-radius:20px;border:1px solid var(--stroke)}.result-main span,.processing-status{display:block;color:var(--muted);font-size:.92rem}.result-main p{margin:.35rem 0 0;color:var(--muted)}.alert{background:#fff}.alert-success{border-color:rgba(41,181,116,.2);background:#f6fff9}.alert-error{border-color:rgba(239,78,97,.2);background:#fff6f7;color:#9f3749}.spinner{width:24px;height:24px;border:3px solid rgba(107,115,255,.2);border-top-color:#6b73ff;border-radius:50%;animation:spin .9s linear infinite}
.admin-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:18px}.security-panel,.add-user-panel{padding:24px}.security-copy{color:var(--muted)}.user-list{display:flex;flex-direction:column;gap:12px;margin-top:18px}.user-card{border:1px solid var(--stroke);border-radius:20px;background:#fff;padding:0 16px}.user-card summary{list-style:none;display:flex;justify-content:space-between;gap:12px;align-items:center;padding:16px 0;cursor:pointer}.user-card summary::-webkit-details-marker{display:none}.user-card summary span{display:block;color:var(--muted);font-size:.9rem;margin-top:4px}.user-card-right{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.user-edit-form{padding:0 0 16px;display:flex;flex-direction:column;gap:14px}.form-grid-two{display:grid;grid-template-columns:1fr 1fr;gap:12px}.stack-form{display:flex;flex-direction:column;gap:12px}.stack-form label,.user-edit-form label{display:block;font-weight:700;font-size:.92rem;margin-bottom:7px}.checkbox-row{display:flex;align-items:center;gap:10px;font-weight:600;color:#31405f}.inline-actions{display:flex;gap:10px;flex-wrap:wrap}.security-box{margin-top:20px;padding:18px;border-radius:20px;background:linear-gradient(135deg,#f7f9ff,#fff4fb);border:1px solid var(--stroke)}.security-box h4{margin:0 0 10px}.security-box ul{margin:0;padding-left:18px;color:var(--muted);display:grid;gap:8px}
.login-page{position:relative;overflow:hidden}.login-scene{position:fixed;inset:0;pointer-events:none}.login-orb{position:absolute;border-radius:50%;filter:blur(40px);opacity:.55}.orb-one{width:360px;height:360px;background:#ffdce9;top:-80px;left:-60px}.orb-two{width:420px;height:420px;background:#dcecff;right:-120px;top:70px}.orb-three{width:360px;height:360px;background:#f4ddff;bottom:-110px;left:30%}.login-noise{position:absolute;inset:0;background-image:linear-gradient(rgba(107,115,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(107,115,255,.05) 1px,transparent 1px);background-size:44px 44px;opacity:.35}.login-layout{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:22px;max-width:1240px;margin:0 auto;padding:32px;min-height:100vh;align-items:center}.login-showcase,.login-card{padding:34px}.light-card{background:rgba(255,255,255,.84);border:1px solid var(--stroke);box-shadow:var(--shadow);border-radius:30px}.showcase-logo,.login-brand-logo,.intro-logo{width:110px;height:110px;object-fit:cover;border-radius:24px;border:1px solid rgba(0,0,0,.06);background:#fff}.login-brand-logo{width:80px;height:80px;border-radius:20px}.login-showcase h1{font-family:Manrope,Inter,sans-serif;font-size:3.2rem;line-height:.98;letter-spacing:-.06em;max-width:760px;margin:.5rem 0 1rem}.login-showcase p,.login-intro-copy p,.login-footer-copy{color:var(--muted);font-size:1.02rem;line-height:1.6}.showcase-kicker{margin-top:14px;color:var(--pink);font-size:.8rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.showcase-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:26px}.showcase-box{padding:18px;border-radius:22px;background:rgba(255,255,255,.72);border:1px solid var(--stroke)}.showcase-box strong{display:block;font-size:1rem}.showcase-box span{display:block;color:var(--muted);margin-top:6px;font-size:.92rem}.login-branding{display:flex;align-items:center;gap:14px}.login-brand-title{font-size:1.7rem;font-weight:800;letter-spacing:-.04em}.login-intro-copy h2{font-size:2rem;letter-spacing:-.05em;margin:20px 0 8px}.field-group{margin-top:16px}.field-group label{display:block;font-weight:700;font-size:.92rem;margin-bottom:8px}.field-wrap{position:relative}.field-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#7886a7}.field-wrap input{width:100%;padding:14px 14px 14px 46px;border-radius:16px;border:1px solid var(--stroke);background:#fff}.login-error{padding:12px 14px;border-radius:16px;background:#fff2f4;border:1px solid rgba(239,78,97,.18);color:#b3364f;margin:18px 0}.login-footer-copy{margin-top:18px;font-size:.92rem}
.intro-overlay{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;background:radial-gradient(circle at center,rgba(255,255,255,.88),rgba(235,242,255,.97));overflow:hidden}.intro-overlay.leave{animation:introFade .7s ease forwards}.intro-rings,.intro-particles{position:absolute;inset:0}.intro-rings::before,.intro-rings::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(107,115,255,.24);animation:ring 2.8s ease-out infinite}.intro-rings::before{width:240px;height:240px}.intro-rings::after{width:420px;height:420px;animation-delay:.35s}.intro-particles::before,.intro-particles::after{content:"";position:absolute;inset:-10%;background:radial-gradient(circle,rgba(255,95,162,.28) 1px,transparent 1px);background-size:42px 42px;animation:float 14s linear infinite;opacity:.35}.intro-particles::after{background:radial-gradient(circle,rgba(107,115,255,.28) 1px,transparent 1px);background-size:58px 58px;animation-direction:reverse}.intro-panel{text-align:center;position:relative;z-index:2;padding:32px 26px}.intro-kicker{margin-top:18px;color:var(--pink);font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;font-weight:800}.intro-title{font-family:Manrope,Inter,sans-serif;font-size:3.1rem;font-weight:800;letter-spacing:-.07em;max-width:780px;line-height:.96;margin-top:10px}.intro-line{width:130px;height:5px;border-radius:999px;margin:18px auto;background:linear-gradient(90deg,var(--primary),var(--pink))}.intro-sub{max-width:640px;color:var(--muted);font-size:1.05rem;line-height:1.6}.fade-in{animation:fadeIn .45s ease}
@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@keyframes ring{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}35%{opacity:1}100%{opacity:0;transform:translate(-50%,-50%) scale(1.1)}}@keyframes float{from{transform:translateY(0)}to{transform:translateY(-40px)}}@keyframes introFade{to{opacity:0;visibility:hidden}}
@media (max-width:1220px){.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.doc-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.login-layout,.admin-grid,.doc-detail{grid-template-columns:1fr}.sidebar{width:270px}.main-content{padding:18px}.filter-bar{grid-template-columns:1fr 1fr 1fr}.hero-banner{flex-direction:column;align-items:flex-start}}
@media (max-width:920px){.app-shell{display:block}.sidebar{position:relative;height:auto;width:auto;padding:16px}.topbar{padding:20px;flex-direction:column}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.filter-bar{grid-template-columns:1fr}.doc-grid{grid-template-columns:1fr}.login-layout{padding:18px}.login-showcase h1{font-size:2.35rem}.showcase-grid{grid-template-columns:1fr}.intro-title{font-size:2.25rem}}
@media (max-width:640px){.stats-grid{grid-template-columns:1fr}.form-grid-two{grid-template-columns:1fr}.topbar-title{font-size:1.5rem}.hero-banner h1{font-size:1.65rem}.login-showcase,.login-card{padding:22px}.showcase-logo,.intro-logo{width:88px;height:88px}.sidebar-logo,.sidebar-nav,.sidebar-user,.topbar,.hero-banner,.glass-card{border-radius:22px}}
