:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none}body{margin:0;background:var(--color-body)}#root{min-height:100vh}.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh;background:var(--color-surface)}.app-shell__sidebar{background:linear-gradient(160deg,#0c1730,#1a315e);color:#fff;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:2rem}.app-shell__brand{display:flex;gap:1rem;align-items:center}.app-shell__brand-mark{display:grid;place-content:center;background:#ffffff1f;color:#fff;font-weight:700;width:3rem;height:3rem;border-radius:.75rem}.app-shell__brand-title{font-size:1.2rem;font-weight:600;margin:0}.app-shell__brand-subtitle{margin:0;font-size:.85rem;opacity:.7}.app-shell__nav{display:grid;gap:.5rem}.app-shell__nav-link{padding:.75rem 1rem;border-radius:.75rem;color:#ffffffd9;text-decoration:none;font-weight:500;transition:background .2s ease,color .2s ease;border:none;background:transparent;text-align:left;cursor:pointer}.app-shell__nav-link.active,.app-shell__nav-link:hover{background:#ffffff29;color:#fff}.app-shell__content{display:flex;flex-direction:column;background:var(--color-body)}.app-shell__topbar{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid rgba(12,23,48,.08);background:#fff}.app-shell__welcome{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary)}.app-shell__welcome-sub{margin:0;color:var(--color-text-muted)}.app-shell__user{display:flex;align-items:center;gap:1rem}.app-shell__topbar-actions{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.app-shell__language{display:flex;flex-direction:column;font-size:.75rem;color:var(--color-text-muted);gap:.25rem}.app-shell__language select{border-radius:.5rem;border:1px solid rgba(12,23,48,.12);padding:.35rem .75rem;font-size:.85rem;color:var(--color-text-primary);background:#fff}.app-shell__user-name{margin:0;font-weight:600;color:var(--color-text-primary)}.app-shell__user-role{margin:0;font-size:.8rem;letter-spacing:.1em;color:var(--color-text-muted)}.app-shell__logout{border:none;background:#dc2626;color:#fff;font-weight:600;padding:.6rem 1.2rem;border-radius:999px;cursor:pointer}.app-shell__logout:hover{background:#b91c1c}.app-shell__main{padding:2rem;flex:1;overflow-y:auto}@media (max-width: 1080px){.app-shell{grid-template-columns:1fr}.app-shell__sidebar{position:sticky;top:0;flex-direction:row;align-items:center;justify-content:space-between;padding:1rem 1.5rem;z-index:2}.app-shell__nav{display:flex;flex-wrap:wrap;gap:.75rem}.app-shell__topbar{flex-direction:column;align-items:flex-start;gap:1rem}.app-shell__topbar-actions{width:100%;justify-content:space-between}}.button{border:none;border-radius:.75rem;font-weight:600;padding:.65rem 1.25rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.button:disabled{opacity:.6;cursor:not-allowed}.button--primary{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;box-shadow:0 10px 20px #2563eb4d}.button--primary:hover:not(:disabled){transform:translateY(-1px)}.button--secondary{background:#2563eb1f;color:#1d4ed8}.button--ghost{background:transparent;color:var(--color-text-muted)}.section-card{background:#fff;border-radius:1rem;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 12px 32px #0f172a14}.section-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.section-card__title{margin:0;font-size:1.25rem;color:var(--color-text-primary)}.section-card__description{margin:.25rem 0 0;color:var(--color-text-muted);max-width:52ch}.section-card__actions{display:flex;gap:.5rem}.section-card__content{display:flex;flex-direction:column;gap:1rem}.table__container{overflow-x:auto;border-radius:1rem;background:#fff;box-shadow:0 10px 30px #0f172a0f}.table{width:100%;border-collapse:collapse;min-width:720px}.table th,.table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid rgba(15,23,42,.06)}.table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-weight:700}.table td{color:var(--color-text-primary);font-size:.95rem}.table tr:last-child td{border-bottom:none}.table__empty{padding:2rem;border-radius:1rem;background:#fff;text-align:center;color:var(--color-text-muted);box-shadow:0 10px 30px #0f172a0f}.dashboard__metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;margin-bottom:2rem}.dashboard__filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-field{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:var(--color-text-muted)}.form-field input,.form-field select,.form-field textarea{border:1px solid rgba(15,23,42,.12);border-radius:.75rem;padding:.65rem .85rem;font-size:.95rem;color:var(--color-text-primary);background:#fff}.form-field textarea{min-height:120px;resize:vertical}.form-field--checkbox{flex-direction:row;align-items:center;gap:.75rem}.form-field--checkbox input{width:1.1rem;height:1.1rem}.form-grid{display:grid;gap:1rem}.form-grid--two{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.form-grid--three{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.tag-list{display:flex;gap:.5rem;flex-wrap:wrap;font-size:.8rem}.tag{padding:.3rem .6rem;border-radius:999px;background:#94a3b833;color:#475569}.clients{display:flex;flex-direction:column;gap:2rem}.metric-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 10px 30px #0f172a14;display:flex;flex-direction:column;gap:.5rem;min-width:0}.metric-card__header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.metric-card__title{margin:0;font-size:.9rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em}.metric-card__value{margin:0;font-size:2rem;font-weight:700;color:var(--color-text-primary)}.metric-card__hint{margin:0;color:var(--color-text-muted);font-size:.85rem}.metric-card__trend{font-size:.75rem;font-weight:600;padding:.3rem .75rem;border-radius:999px;background:#3b82f61f;color:#2563eb}.metric-card__trend--down{background:#ef44441f;color:#dc2626}.metric-card__trend--flat{background:#94a3b81f;color:#475569}.materials{display:flex;flex-direction:column;gap:2rem}.materials__history{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.materials__history-item{background:#0f172a08;border-radius:1rem;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.materials__history-item h3{margin:0}.materials__history-item ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.5rem}.materials__history-item li{display:flex;justify-content:space-between;color:var(--color-text-muted)}.status-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;border-radius:999px;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;background:#0f172a0f;color:#1f2937}.status-badge--success{background:#22c55e26;color:#15803d}.status-badge--danger{background:#ef444426;color:#b91c1c}.status-badge--info{background:#2563eb26;color:#1d4ed8}.status-badge--muted{background:#94a3b833;color:#475569}.status-badge--neutral{background:#64748b1f;color:#334155}.pending{display:flex;flex-direction:column;gap:2rem}.quotes__actions{display:flex;gap:.5rem}.quotes__actions .button{padding:.4rem .75rem}.quotes__actions-bar{display:flex;gap:1rem;align-items:flex-end;flex-wrap:wrap;justify-content:flex-end}.quotes__dropzone{border:1px dashed var(--border-muted, #d9d9d9);border-radius:.75rem;padding:1.25rem;text-align:center;background:var(--surface-muted, #f8f8f8);display:grid;gap:.75rem;justify-items:center}.quotes__dropzone input[type=file]{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.quotes__file-list{margin-top:1rem;display:grid;gap:.75rem;list-style:none;padding:0}.quotes__file-item{display:grid;grid-template-columns:auto 1fr auto;gap:.75rem;align-items:center;background:var(--surface-default, #ffffff);border:1px solid var(--border-subtle, #ededed);border-radius:.75rem;padding:.75rem 1rem}.quotes__file-preview{width:56px;height:56px;object-fit:cover;border-radius:.5rem;border:1px solid var(--border-muted, #d9d9d9)}.quotes__file-icon{width:56px;height:56px;border-radius:.5rem;display:grid;place-items:center;background:var(--accent-muted, #f0f4ff);color:var(--accent-foreground, #2643a0);font-weight:600}.quotes__file-meta{display:grid;gap:.15rem;justify-items:start;font-size:.9rem}.suppliers{display:flex;flex-direction:column;gap:2rem}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f1f5f9;--color-body: #f1f5f9;--color-surface: #0f172a;--color-text-primary: #1f2937;--color-text-muted: #64748b}*,*:before,*:after{box-sizing:border-box}body{margin:0}a{color:inherit}button,input,select,textarea{font:inherit}main{min-height:100vh}
