@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=light]{--bg:#fafafa;--bg-subtle:#f4f4f5;--surface:#fff;--surface-hover:#f4f4f5;--border:#e4e4e7;--border-subtle:#f4f4f5;--muted:#e4e4e7;--muted-fg:#71717a;--fg:#09090b;--fg-muted:#52525b;--fg-subtle:#71717a;--accent:#2563eb;--accent-hover:#1d4ed8;--accent-subtle:#2563eb14;--accent-border:#2563eb33;--accent-fg:#2563eb;--success:#16a34a;--success-subtle:#16a34a14;--success-border:#16a34a33;--warning:#d97706;--warning-subtle:#d9770614;--warning-border:#d9770633;--danger:#dc2626;--danger-subtle:#dc262614;--danger-border:#dc262633;--font:"Inter", system-ui, -apple-system, sans-serif;--text-xs:11px;--text-sm:13px;--text-base:14px;--text-md:15px;--text-lg:18px;--text-xl:22px;--text-2xl:28px;--radius-sm:4px;--radius:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--sidebar-w:240px;--sidebar-w-collapsed:60px;--header-h:56px}[data-theme=dark]{--bg:#09090b;--bg-subtle:#111113;--surface:#18181b;--surface-hover:#1e1e21;--border:#27272a;--border-subtle:#1f1f22;--muted:#52525b;--muted-fg:#a1a1aa;--fg:#fafafa;--fg-muted:#a1a1aa;--fg-subtle:#71717a;--accent:#3b82f6;--accent-hover:#2563eb;--accent-subtle:#3b82f626;--accent-border:#3b82f64d;--accent-fg:#93c5fd;--success:#22c55e;--success-subtle:#22c55e26;--success-border:#22c55e4d;--warning:#f59e0b;--warning-subtle:#f59e0b26;--warning-border:#f59e0b4d;--danger:#ef4444;--danger-subtle:#ef444426;--danger-border:#ef44444d}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes pulse-glow{0%,to{box-shadow:0 8px 32px #1e3a8a66}50%{box-shadow:0 8px 40px #2563eba6}}.fade-in-up{animation:.4s ease-out forwards fadeInUp}.chatbot-fab,.feedback-fab{bottom:24px!important}.chatbot-fab{right:24px!important}.feedback-fab{left:24px!important}html,body{background-color:var(--bg);height:100%;color:var(--fg);font-family:var(--font);font-size:var(--text-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg);border-right:1px solid var(--border);z-index:50;flex-direction:column;flex-shrink:0;height:100vh;transition:width .2s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.main-content{margin-left:var(--sidebar-w);background:var(--bg);flex:1;height:100vh;transition:margin-left .2s;overflow-y:auto}.main-content.expanded{margin-left:var(--sidebar-w-collapsed)}.page-container{max-width:1100px;margin:0 auto;padding:32px 28px}.sticky-page-header{z-index:20;background:var(--bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);margin:-32px -28px 24px;padding:16px 28px;position:sticky;top:0}.tender-title-bar{align-items:center;gap:12px;min-width:0;display:flex}.tender-title-bar h1{white-space:nowrap;text-overflow:ellipsis;font-size:var(--text-lg);letter-spacing:-.2px;flex:1;overflow:hidden}.tender-title-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}h1{font-size:var(--text-xl);color:var(--fg);letter-spacing:-.3px;font-weight:600}h2{font-size:var(--text-lg);color:var(--fg);font-weight:600}h3{font-size:var(--text-md);color:var(--fg);font-weight:500}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-muted{color:var(--fg-muted)}.text-subtle{color:var(--fg-subtle)}.text-accent{color:var(--accent-fg)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md)}.card-hover{cursor:pointer;transition:border-color .15s,background .15s}.card-hover:hover{border-color:var(--muted);background:var(--surface-hover)}.card-pad{padding:20px}.card-pad-sm{padding:14px 16px}.hover-card{transition:transform .2s,border-color .2s,box-shadow .2s}.hover-card:hover{border-color:var(--accent-fg);background:var(--surface-hover);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.text-expired{font-weight:600;color:var(--danger)!important}.dash-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;padding:20px;transition:transform .2s,border-color .2s,box-shadow .2s,background .2s;position:relative;overflow:hidden}.dash-stat-card:after{content:"";border-radius:var(--radius-md);opacity:0;background:linear-gradient(135deg,#2563eb0a 0%,#0000 60%);transition:opacity .2s;position:absolute;inset:0}.dash-stat-card:hover{border-color:var(--accent-border);background:var(--surface-hover);transform:translateY(-3px);box-shadow:0 8px 24px #2563eb1a,0 2px 8px #00000014}.dash-stat-card:hover:after{opacity:1}.dash-stat-card:active{transform:translateY(-1px)}.dash-stat-link{font-size:var(--text-xs);color:var(--fg-subtle);opacity:0;margin-top:8px;transition:opacity .2s,transform .2s;transform:translateY(4px)}.dash-stat-card:hover .dash-stat-link{opacity:1;transform:translateY(0)}.dash-action-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;padding:18px;transition:transform .2s,border-color .2s,box-shadow .2s,background .2s}.dash-action-card:hover{border-color:var(--accent-border);background:var(--surface-hover);transform:translateY(-3px);box-shadow:0 6px 20px #2563eb14,0 2px 8px #0000000f}.dash-action-card:hover>div:first-child{transition:background .2s;background:var(--accent-subtle)!important}.dash-action-card:active{transform:translateY(-1px)}.divider{background:var(--border);height:1px}.badge{font-size:var(--text-xs);border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-weight:500;line-height:18px;display:inline-flex}.badge-default{background:var(--surface-hover);color:var(--fg-muted);border:1px solid var(--border)}.badge-active{background:var(--success-subtle);color:var(--success);border:1px solid var(--success-border)}.badge-pending{background:var(--warning-subtle);color:var(--warning);border:1px solid var(--warning-border)}.badge-expired{background:var(--danger-subtle);color:var(--danger);border:1px solid var(--danger-border)}.badge-quoted{background:var(--accent-subtle);color:var(--accent-fg);border:1px solid var(--accent-border)}.badge-completed{background:var(--success-subtle);color:var(--success);border:1px solid var(--success-border)}.badge-draft{background:var(--surface-hover);color:var(--fg-subtle);border:1px solid var(--border)}.badge-cancelled{background:var(--danger-subtle);color:var(--danger);border:1px solid var(--danger-border)}.badge-ongoing{background:var(--accent-subtle);color:var(--accent-fg);border:1px solid var(--accent-border)}.btn{font-size:var(--text-sm);border-radius:var(--radius);cursor:pointer;white-space:nowrap;font-weight:500;font-family:var(--font);border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:7px 14px;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--fg-muted);border-color:var(--border)}.btn-secondary:hover{background:var(--surface-hover);color:var(--fg);border-color:var(--muted)}.btn-ghost{color:var(--fg-muted);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--surface);color:var(--fg)}.btn-danger{background:var(--danger-subtle);color:var(--danger);border-color:var(--danger-border)}.btn-danger:hover{background:#ef444426}.btn-success{background:var(--success-subtle);color:var(--success);border-color:var(--success-border)}.btn-success:hover{background:#22c55e26}.btn-sm{font-size:var(--text-xs);padding:4px 10px}.btn-lg{font-size:var(--text-md);padding:10px 20px}.btn-full{width:100%}.btn-icon{padding:7px}.input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--fg);font-size:var(--text-sm);font-family:var(--font);outline:none;padding:8px 12px;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--fg-subtle)}.input-icon-l{padding-left:36px}.input-group{position:relative}.input-group .icon-l{color:var(--fg-subtle);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}label{font-size:var(--text-xs);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-weight:500;display:block}select.input{cursor:pointer}textarea.input{resize:vertical;line-height:1.6}.field{flex-direction:column;gap:4px;display:flex}.field-error{font-size:var(--text-xs);color:var(--danger);margin-top:3px}.grid-tenders{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}@media (max-width:640px){.grid-tenders{grid-template-columns:1fr}}.grid-2{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}@media (max-width:768px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.stack{flex-direction:column;display:flex}.stack-sm{gap:8px}.stack-md{gap:16px}.stack-lg{gap:24px}.stack-xl{gap:32px}.row{align-items:center;display:flex}.row-between{justify-content:space-between;align-items:center;display:flex}.row-gap-sm{gap:8px}.row-gap-md{gap:12px}.row-gap-lg{gap:16px}.wrap{flex-wrap:wrap}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:var(--text-sm);min-width:520px}thead tr{border-bottom:1px solid var(--border)}th{text-align:left;font-size:var(--text-xs);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;padding:10px 14px;font-weight:500}td{color:var(--fg-muted);border-bottom:1px solid var(--border-subtle);padding:12px 14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--surface-hover)}tbody tr{transition:background .1s}tfoot td{padding:10px 14px}.alert{border-radius:var(--radius);font-size:var(--text-sm);border:1px solid;align-items:flex-start;gap:10px;padding:12px 14px;display:flex}.alert-error{background:var(--danger-subtle);border-color:var(--danger-border);color:var(--danger)}.alert-success{background:var(--success-subtle);border-color:var(--success-border);color:var(--success)}.alert-warning{background:var(--warning-subtle);border-color:var(--warning-border);color:var(--warning)}.alert-info{background:var(--accent-subtle);border-color:var(--accent-border);color:var(--accent-fg)}.progress-bar{background:var(--border);border-radius:99px;height:4px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:99px;height:100%;transition:width .4s}.progress-fill-success{background:var(--success)}.stat-label{font-size:var(--text-xs);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:500}.stat-value{font-size:var(--text-xl);color:var(--fg);letter-spacing:-.5px;font-weight:600}.stat-meta{font-size:var(--text-xs);color:var(--fg-subtle);margin-top:4px}.page-header{margin-bottom:24px}.page-title{font-size:var(--text-xl);color:var(--fg);letter-spacing:-.3px;font-weight:600}.page-desc{font-size:var(--text-sm);color:var(--fg-muted);margin-top:3px}.empty-state{text-align:center;padding:60px 20px}.empty-icon{width:40px;height:40px;color:var(--muted);margin:0 auto 14px}.empty-title{font-size:var(--text-md);color:var(--fg-muted);margin-bottom:6px;font-weight:500}.empty-desc{font-size:var(--text-sm);color:var(--fg-subtle);margin-bottom:20px}.nav-item{border-radius:var(--radius);font-size:var(--text-sm);color:var(--fg-muted);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:6px 10px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;overflow:hidden}.nav-item:hover,.nav-item.active{background:var(--surface);color:var(--fg)}.nav-item .nav-icon{color:var(--muted-fg);flex-shrink:0}.nav-item.active .nav-icon{color:var(--accent-fg)}.tag{font-size:var(--text-xs);border:1px solid var(--border);background:var(--surface);color:var(--fg-subtle);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:4px;align-items:center;gap:4px;padding:4px 10px;font-weight:500;transition:all .12s;display:inline-flex}.tag:hover{border-color:var(--muted);color:var(--fg-muted)}.tag.selected{background:var(--accent-subtle);border-color:var(--accent-border);color:var(--accent-fg)}.tag.selected-green{background:var(--success-subtle);border-color:var(--success-border);color:var(--success)}.tag.selected-purple{color:#c084fc;background:#a855f714;border-color:#a855f733}.tag-success{background:var(--success-subtle);border-color:var(--success-border);color:var(--success)}.tag-error{background:var(--danger-subtle);border-color:var(--danger-border);color:var(--danger)}.tag-warning{background:var(--warning-subtle);border-color:var(--warning-border);color:var(--warning)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000b3;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}@media (min-width:600px){.modal-overlay{align-items:center}}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:92vh;padding:24px;overflow-y:auto}@media (max-width:599px){.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:88vh;padding-bottom:calc(24px + var(--safe-bottom))}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-size:var(--text-md);color:var(--fg);font-weight:600}.upload-zone{border:1.5px dashed var(--border);border-radius:var(--radius-md);text-align:center;cursor:pointer;padding:32px 20px;transition:border-color .15s,background .15s}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-subtle)}.step-dot{border:1.5px solid var(--border);background:var(--surface);width:28px;height:28px;font-size:var(--text-xs);color:var(--fg-subtle);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex}.step-dot.active{border-color:var(--accent);color:var(--accent-fg);background:var(--accent-subtle)}.step-dot.done{border-color:var(--success);background:var(--success-subtle);color:var(--success)}.step-line{background:var(--border);flex:1;height:1px}.tabs{border-bottom:1px solid var(--border);gap:0;display:flex;overflow-x:auto}.tab{font-size:var(--text-sm);color:var(--fg-subtle);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;font-weight:500;transition:color .12s,border-color .12s}.tab:hover{color:var(--fg-muted)}.tab.active{color:var(--fg);border-bottom-color:var(--accent)}.section-title{font-size:var(--text-xs);color:var(--fg-subtle);text-transform:uppercase;letter-spacing:.8px;margin-bottom:10px;padding-left:10px;font-weight:600}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:.7s linear infinite spin}:root{--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px)}@media (max-width:1024px){.app-shell{padding-top:var(--safe-top);height:calc(100vh - var(--safe-top))}.main-content{padding-bottom:calc(60px + var(--safe-bottom) + 16px);overflow-x:hidden}.sidebar{z-index:100;padding-top:var(--safe-top);transition:transform .2s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0!important}.mobile-bottom-nav{display:flex!important}.page-container{max-width:100vw;padding:20px 16px}h1,h2,h3{word-break:break-word;overflow-wrap:break-word;line-height:1.3}.row-between{flex-wrap:wrap;gap:12px}.btn{min-height:40px}.card-pad{padding:16px}}.mobile-bottom-nav{z-index:60;padding:6px 8px;padding-bottom:calc(6px + var(--safe-bottom));height:calc(60px + var(--safe-bottom));background:var(--surface);border-top:1px solid var(--border);-webkit-backdrop-filter:blur(10px);flex-direction:row;justify-content:space-around;align-items:center;display:none;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 16px #00000014}.logomark{background:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a}.logomark-icon{color:#3b82f6;width:20px;height:20px}.splash-logo{border-radius:20px;width:80px;height:80px}.splash-logo .logomark-icon{width:50px;height:50px}[data-theme=dark] .logomark{background:#18181b}
