*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f3f4f6;color:#1f2937;min-height:100vh;width:100vw}a{color:inherit;text-decoration:none}button{font-family:inherit}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:#6b7280}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{display:flex;align-items:flex-start;padding:16px;background-color:#fff;border-radius:4px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;min-width:320px;max-width:400px;animation:slideIn .3s ease-out forwards;pointer-events:auto;border-left:4px solid transparent;transition:opacity .3s ease-out}.toast.hiding{opacity:0;pointer-events:none}.toast-success{border-left-color:#10b981}.toast-error{border-left-color:#ef4444}.toast-warning{border-left-color:#f59e0b}.toast-info{border-left-color:#3b82f6}.toast-icon{flex-shrink:0;margin-right:12px;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.toast-success .toast-icon{color:#10b981}.toast-error .toast-icon{color:#ef4444}.toast-warning .toast-icon{color:#f59e0b}.toast-info .toast-icon{color:#3b82f6}.toast-content{flex-grow:1}.toast-message{margin:0;font-size:14px;font-weight:500;color:#1f2937;line-height:1.5}.toast-close-btn{background:none;border:none;color:#9ca3af;cursor:pointer;margin-left:12px;padding:0;display:flex;align-items:center;justify-content:center}.toast-close-btn:hover{color:#4b5563}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#2d5a87);padding:20px}.login-card{background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:32px 40px;width:100%;max-width:440px;box-shadow:0 20px 60px #0003;animation:slideUp .4s ease-out}.login-header{text-align:center;margin-bottom:24px}.login-logo-img{width:64px;height:auto;margin-bottom:16px}.login-header h1{font-size:26px;color:#1e3a5f;margin:0 0 8px;font-weight:700;letter-spacing:-.5px}.login-header p{color:#6b7280;margin:0;font-size:15px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;transition:all .2s ease;background:#f9fafb}.form-group input:focus{outline:none;border-color:#1e3a5f;background:#fff;box-shadow:0 0 0 3px #1e3a5f1a}.form-group input::placeholder{color:#9ca3af}.error-message{background-color:#fef2f2;border:1px solid #fee2e2;color:#991b1b;padding:12px;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px}.login-btn{background:linear-gradient(135deg,#1e3a5f,#2d5a87);color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px;box-shadow:0 4px 6px -1px #1e3a5f33}.login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 15px -3px #1e3a5f4d}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;margin-top:20px;padding-top:16px;border-top:1px solid #e5e7eb}.login-footer p{color:#4b5563;font-size:14px;margin:0}.login-footer a{color:#1e3a5f;font-weight:600;text-decoration:none;margin-left:4px}.login-footer a:hover{text-decoration:underline}.google-login-wrapper{margin-bottom:12px}.google-login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;padding:12px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 2px #0000000d;height:48px}.google-login-btn:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.google-login-btn:active{transform:translateY(0)}.login-divider{display:flex;align-items:center;margin:12px 0;color:#9ca3af;font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.login-divider span{padding:0 12px;text-transform:uppercase;letter-spacing:.5px}.register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#2d5a87);padding:20px}.register-card{background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:40px;width:100%;max-width:650px;box-shadow:0 20px 60px #0003;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.register-header{text-align:center;margin-bottom:30px}.register-logo-img{width:64px;height:auto;margin-bottom:16px}.register-header h1{font-size:26px;color:#1e3a5f;margin:0 0 8px;font-weight:700;letter-spacing:-.5px}.register-header p{color:#6b7280;margin:0;font-size:15px}.register-form{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.register-group{display:flex;flex-direction:column;gap:6px}.register-group label{font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.5px}.register-group input{padding:12px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:15px;transition:all .2s ease;background:#f9fafb}.register-group input:focus{outline:none;border-color:#1e3a5f;background:#fff;box-shadow:0 0 0 3px #1e3a5f1a}.register-group input::placeholder{color:#9ca3af}.register-btn{background:linear-gradient(135deg,#1e3a5f,#2d5a87);color:#fff;border:none;padding:14px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:10px;box-shadow:0 4px 6px -1px #1e3a5f33}.register-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 15px -3px #1e3a5f4d}.register-btn:disabled{opacity:.7;cursor:not-allowed}.register-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.register-footer p{color:#4b5563;font-size:14px;margin:0}.register-footer a{color:#1e3a5f;font-weight:600;text-decoration:none;margin-left:4px}.register-footer a:hover{text-decoration:underline}.error-banner{background-color:#fef2f2;border:1px solid #fee2e2;color:#991b1b;padding:12px;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px}@media(max-width:640px){.form-row{grid-template-columns:1fr;gap:16px}.register-card{padding:24px}}.dashboard{height:100vh;overflow-y:auto;background:#f3f4f6}.dashboard .dashboard-main{max-width:1200px;margin:0 auto;padding:32px}.dashboard .dashboard-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.dashboard .dashboard-actions h2{font-size:24px;color:#1e3a5f;margin:0}.dashboard .loading{text-align:center;padding:60px;color:#6b7280;font-size:16px}.dashboard .empty-state{text-align:center;padding:80px 40px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.dashboard .empty-icon{font-size:64px;margin-bottom:16px}.dashboard .empty-state h3{color:#374151;margin:0 0 8px;font-size:18px}.dashboard .empty-state p{color:#6b7280;margin:0;font-size:14px}.dashboard .documents-table{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d}.dashboard .table-container{max-height:600px;overflow-y:auto;border-radius:12px}.dashboard .table-container::-webkit-scrollbar{width:6px;height:6px}.dashboard .table-container::-webkit-scrollbar-track{background:transparent}.dashboard .table-container::-webkit-scrollbar-thumb{background:#e5e7eb;border-radius:3px}.dashboard .table-container::-webkit-scrollbar-thumb:hover{background:#d1d5db}.dashboard .documents-table table{width:100%;border-collapse:separate;border-spacing:0}.dashboard .documents-table th,.dashboard .documents-table td{padding:16px 20px;text-align:left}.dashboard .documents-table th{position:sticky;top:0;z-index:10;background:#f9fafb;font-weight:600;color:#374151;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e5e7eb;box-shadow:0 1px 2px #0000000d}.dashboard .documents-table td{border-bottom:1px solid #e5e7eb;font-size:14px;color:#4b5563}.dashboard .documents-table tr:hover td{background:#f9fafb}.dashboard .status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.dashboard .status-draft{background:#e5e7eb;color:#4b5563}.dashboard .status-review{background:#fef3c7;color:#92400e}.dashboard .status-approved{background:#d1fae5;color:#065f46}.dashboard .status-issued{background:#dbeafe;color:#1e40af}.dashboard .status-rejected{background:#fee2e2;color:#991b1b}.dashboard .action-cell{display:flex;gap:8px}.dashboard .action-view-btn{background:#1e3a5f;color:#fff;border:none;padding:6px 16px;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease}.dashboard .action-view-btn:hover{background:#2d5a87}.dashboard .delete-btn{background:#fee2e2;color:#dc2626;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s ease}.dashboard .delete-btn:hover{background:#fecaca}.dashboard .title-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;color:#1e3a5f}.dashboard .no-title{color:#9ca3af;font-style:italic;font-weight:400}.dashboard .search-bar{display:flex;align-items:center;gap:12px;background:#fff;padding:12px 20px;border-radius:8px;margin-bottom:20px;box-shadow:0 1px 3px #00000014}.dashboard .search-icon{font-size:18px;opacity:.6}.dashboard .search-input{flex:1;border:none;outline:none;font-size:15px;background:transparent}.dashboard .search-input::placeholder{color:#9ca3af}.dashboard .search-result-count{font-size:13px;color:#6b7280;background:#f3f4f6;padding:4px 12px;border-radius:12px}.dashboard .text-muted{font-size:.85rem;color:#94a3b8;font-style:italic}.dashboard .doc-code{font-family:Consolas,Monaco,monospace;font-weight:500;color:#334155;background:#f1f5f9;border:1px solid #e2e8f0}.dashboard .pagination-controls{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px;padding-top:16px;border-top:1px solid #e5e7eb}.dashboard .pagination-controls button{background:#fff;border:1px solid #d1d5db;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;color:#374151;transition:all .2s}.dashboard .pagination-controls button:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af;color:#111827}.dashboard .pagination-controls button:disabled{opacity:.5;cursor:not-allowed;background:#f9fafb}.dashboard .pagination-controls span{font-size:14px;color:#4b5563;font-weight:500}.app-header{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000000d;padding:0 32px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.header-left{display:flex;align-items:center;gap:12px}.header-logo-link{display:flex;align-items:center;text-decoration:none;color:inherit;transition:opacity .2s}.header-logo-link:hover{opacity:.9}.header-logo-img{height:36px;width:36px;object-fit:contain}.header-brand-name{font-size:20px;font-weight:700;color:#1e3a5f;margin-left:12px;letter-spacing:.5px;display:none}@media(min-width:768px){.header-brand-name{display:block}}.header-center{display:none;align-items:center;gap:8px;position:absolute;left:50%;transform:translate(-50%)}@media(min-width:1024px){.header-center{display:flex}}.nav-item{position:relative;padding:8px 12px;cursor:pointer;font-size:15px;font-weight:700;color:#4b5563;display:flex;align-items:center;gap:4px;border-radius:6px;transition:all .2s}.nav-item:hover{color:#111827;background-color:#f3f4f6}.nav-item.active{color:#2563eb;background-color:#eff6ff}.nav-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;min-width:220px;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;z-index:100}.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-link{display:block;padding:10px 16px;color:#374151;text-decoration:none;font-size:14px;transition:background-color .15s;border-radius:4px;margin:4px}.dropdown-link:hover{background-color:#f3f4f6;color:#111827}.dropdown-divider{height:1px;background-color:#e5e7eb;margin:4px 0}.admin-action-link{color:#2563eb;font-weight:500;display:flex;align-items:center;gap:8px}.admin-action-link:hover{background-color:#eff6ff}.header-right{display:flex;align-items:center;gap:16px}.lang-selector{display:flex;align-items:center;cursor:pointer;padding:6px;border-radius:4px;transition:background .2s}.lang-selector:hover{background-color:#f3f4f6}.quota-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;background-color:#f0fdf4;border:1px solid #dcfce7;border-radius:20px;font-size:13px;font-weight:600;color:#166534;cursor:pointer;position:relative}.quota-badge.limit{background-color:#fef2f2;border-color:#fee2e2;color:#991b1b}.quota-wrapper{position:relative;cursor:pointer}.quota-popup{position:absolute;top:100%;right:0;margin-top:10px;background:#fff;border-radius:12px;box-shadow:0 10px 25px #0000001a;width:280px;z-index:100;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.98);transition:all .2s cubic-bezier(.16,1,.3,1);border:1px solid #e2e8f0}.quota-wrapper:hover .quota-popup{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.quota-popup:before{content:"";position:absolute;top:-6px;right:20px;width:12px;height:12px;background:#fff;transform:rotate(45deg);border-top:1px solid #e2e8f0;border-left:1px solid #e2e8f0}.quota-popup-header{padding:12px;border-bottom:1px solid #f1f5f9;font-size:13px;font-weight:600;color:#475569;background:#f8fafc;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center}.quota-popup-body{padding:8px}.quota-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:8px;margin-bottom:4px;transition:background .2s}.quota-item:hover{background:#f8fafc}.quota-item-icon{font-size:16px;margin-right:10px;width:24px;text-align:center}.quota-item-info{flex:1;display:flex;flex-direction:column}.quota-label{font-size:12px;font-weight:600;color:#334155;text-align:left}.quota-sublabel{font-size:11px;color:#64748b;text-align:left}.quota-value{font-size:13px;font-weight:700;color:#0f172a}.quota-value.unlimited{color:#059669}.upgrade-btn{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;border:none;padding:8px 16px;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s ease;display:none;box-shadow:0 2px 4px #2563eb33}@media(min-width:640px){.upgrade-btn{display:block}}.upgrade-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #2563eb4d;border-color:transparent;color:#fff;opacity:.95;background:linear-gradient(135deg,#2563eb,#1d4ed8)}.user-menu-trigger{display:flex;align-items:center;gap:8px;cursor:pointer;position:relative;padding:4px;border-radius:6px;transition:background .2s}.user-menu-trigger:hover{background-color:#f3f4f6}.user-avatar{width:32px;height:32px;border-radius:50%;background-color:#e0e7ff;color:#4338ca;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.user-status-dot{width:8px;height:8px;border-radius:50%;position:absolute;bottom:4px;right:4px;border:1px solid white}.user-status-dot.online{background-color:#22c55e}.user-dropdown{right:0;left:auto;width:200px}.user-info-header{padding:12px 16px;border-bottom:1px solid #f3f4f6}.user-name-display{font-size:14px;font-weight:500;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.user-email-display{font-size:12px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.dropdown-link.logout-btn{width:100%;text-align:left;color:#dc2626;background:transparent;border:none;cursor:pointer;font-family:inherit;font-weight:inherit}.dropdown-link.logout-btn:hover{background-color:#fef2f2}.app-footer{background-color:#f8fafc;border-top:1px solid #e2e8f0;padding-top:40px;padding-bottom:24px;color:#475569;font-family:Inter,system-ui,-apple-system,sans-serif;margin-top:auto;width:100%}.footer-content{max-width:1280px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px}.footer-brand-col{display:flex;flex-direction:column;gap:16px}.footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:8px}.footer-logo-img{height:32px;width:auto}.footer-brand-name{font-size:1.25rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.footer-desc{font-size:.9rem;line-height:1.5;color:#64748b;max-width:300px}.footer-contact-info{display:flex;flex-direction:column;gap:8px;font-size:.9rem;margin-top:8px}.contact-item{display:flex;align-items:center;gap:8px}.contact-icon{color:#2563eb}.footer-col-title{font-size:.95rem;font-weight:700;color:#0f172a;text-transform:uppercase;letter-spacing:.05em;margin-bottom:20px}.footer-links-list{display:flex;flex-direction:column;gap:12px}.footer-link{color:#64748b;text-decoration:none;font-size:.9rem;transition:all .2s ease;width:fit-content}.footer-link:hover{color:#2563eb;transform:translate(4px)}.social-links{display:flex;gap:12px;margin-top:16px}.social-btn{width:36px;height:36px;border-radius:8px;background:#fff;border:1px solid #e2e8f0;display:flex;align-items:center;justify-content:center;color:#64748b;transition:all .2s;cursor:pointer}.social-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.footer-bottom{max-width:1280px;margin:32px auto 0;padding:24px 24px 0;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#94a3b8}.footer-bottom-links{display:flex;gap:24px}.bottom-link{color:#94a3b8;text-decoration:none}.bottom-link:hover{color:#475569}@media(max-width:1024px){.footer-content{grid-template-columns:1fr 1fr;gap:40px}.footer-brand-col{grid-column:span 2}}@media(max-width:640px){.footer-content{grid-template-columns:1fr;gap:40px}.footer-bottom{flex-direction:column-reverse;gap:16px;align-items:center;text-align:center}.footer-bottom-links{justify-content:center;width:100%}}.verify-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#2d5a87);padding:20px}.verify-card{background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:40px;width:100%;max-width:440px;box-shadow:0 20px 60px #0003;text-align:center;animation:slideUp .4s ease-out}.verify-icon{font-size:64px;margin-bottom:20px}.verify-card h2{color:#1e3a5f;margin-bottom:12px}.status-message{color:#6b7280;margin-bottom:30px;font-size:16px}.status-message.error{color:#dc2626}.status-message.success{color:#059669}.back-btn{background:#1e3a5f;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.back-btn:hover{background:#2d5a87;transform:translateY(-1px)}
