:root{--green: #3da35d;--green-dark: #0f3d2e;--bg: #f4f6f5;--card: #ffffff;--text: #1a1f1c;--muted: #6b7770;--border: #dde3e0;--error: #c0392b}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text)}button{cursor:pointer;font:inherit;border:none;border-radius:6px;padding:.6rem 1.1rem;background:var(--green);color:#fff;font-weight:600}button:hover{background:var(--green-dark)}button:disabled{opacity:.6;cursor:not-allowed}button.ghost{background:transparent;color:var(--green-dark);border:1px solid var(--border)}button.ghost:hover{background:#eef2f0}input{font:inherit;padding:.55rem .7rem;border:1px solid var(--border);border-radius:6px;width:100%}input:focus{outline:2px solid var(--green);outline-offset:-1px}.centered-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem}.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:1.75rem}.login-card{width:100%;max-width:360px;display:flex;flex-direction:column;gap:.9rem}.login-card label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem;font-weight:600}.brand{margin:0;color:var(--green-dark);font-size:1.8rem}.brand-logo{display:block;width:100%;max-width:220px;height:auto;margin:0 auto .4rem}.brand-link{display:inline-flex;align-items:center;text-decoration:none}.brand-logo-sm{height:32px;width:auto;display:block}.muted{color:var(--muted);font-size:.9rem;margin:0}.error{background:#fdecea;color:var(--error);padding:.5rem .7rem;border-radius:6px;font-size:.88rem}.app-shell{min-height:100vh}.topbar{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1.5rem;background:var(--card);border-bottom:1px solid var(--border)}.topbar-right{display:flex;align-items:center;gap:1rem}.role-badge{background:var(--green);color:#fff;border-radius:4px;padding:.05rem .4rem;font-size:.75rem;text-transform:uppercase}.content{max-width:900px;margin:0 auto;padding:2rem 1.5rem}.placeholder ul{margin:.5rem 0 .8rem;padding-left:1.2rem;color:var(--muted)}.topbar-left{display:flex;align-items:center;gap:1.5rem}.nav{display:flex;gap:1rem}.nav a{text-decoration:none;color:var(--muted);font-weight:600;font-size:.9rem;padding:.2rem 0;border-bottom:2px solid transparent}.nav a.active{color:var(--green-dark);border-bottom-color:var(--green)}.page-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.8rem;margin-bottom:1rem}.page-head h2{margin:0}.actions{display:flex;gap:.5rem;flex-wrap:wrap}button.small{padding:.35rem .7rem;font-size:.85rem}.notice{background:#e8f5ec;color:var(--green-dark);padding:.5rem .7rem;border-radius:6px;font-size:.88rem;margin-bottom:1rem}.error{margin-bottom:1rem}.filters{display:flex;gap:.8rem;align-items:center;flex-wrap:wrap;margin-bottom:1rem;padding:1rem}.filters select,.filters input[type=search]{width:auto;min-width:200px}.inline-check{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.inline-check input{width:auto}.bulk-panel{margin-bottom:1rem}.bulk-panel h3{margin-top:0}.bulk-panel .row{display:flex;gap:1rem;flex-wrap:wrap}.bulk-panel label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600}.data-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.data-table th,.data-table td{text-align:left;padding:.65rem .8rem;border-bottom:1px solid var(--border);font-size:.9rem}.data-table th{background:#eef2f0;color:var(--green-dark);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.data-table tr:last-child td{border-bottom:none}.row-inactive td{color:var(--muted)}.row-actions{display:flex;gap:.6rem}.link-btn{background:none;border:none;color:var(--green-dark);padding:0;font-size:.88rem;font-weight:600}.link-btn:hover{background:none;text-decoration:underline}.link-btn.danger{color:var(--error)}.pill{font-size:.75rem;padding:.1rem .5rem;border-radius:999px;font-weight:600}.pill-on{background:#e8f5ec;color:var(--green-dark)}.pill-off{background:#f0f0f0;color:var(--muted)}.pill-info{background:#e6eef5;color:#2c5f8a}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-grid label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600}.form-grid textarea,.form-grid select{font:inherit;padding:.55rem .7rem;border:1px solid var(--border);border-radius:6px;width:100%}.full-row{grid-column:1 / -1}.specs-head{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.85rem;margin-bottom:.5rem}.spec-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.form-actions{display:flex;gap:.6rem}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}}.stepper{display:flex;list-style:none;padding:0;margin:0 0 1.2rem;gap:.4rem;flex-wrap:wrap}.stepper li button{background:var(--card);color:var(--muted);border:1px solid var(--border);font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:.4rem}.stepper li button:disabled{opacity:1;cursor:default}.stepper li.active button{border-color:var(--green);color:var(--green-dark)}.stepper li.done button{color:var(--green-dark);cursor:pointer}.step-num{display:inline-flex;align-items:center;justify-content:center;width:1.3rem;height:1.3rem;border-radius:999px;background:#eef2f0;font-size:.75rem}.stepper li.active .step-num,.stepper li.done .step-num{background:var(--green);color:#fff}.wizard-grid{display:grid;grid-template-columns:1fr 280px;gap:1.2rem;align-items:start}.wizard-main{min-width:0}.step-card{margin-bottom:1rem}.step-card h3{margin-top:0}.wizard-actions{display:flex;justify-content:space-between;gap:.6rem}.wizard-summary{position:sticky;top:1rem}.wizard-summary h3{margin-top:0;font-size:1rem}.summary-stat{display:flex;justify-content:space-between;font-size:.85rem;padding:.25rem 0;color:var(--muted)}.summary-stat strong{color:var(--text)}.wizard-summary hr{border:none;border-top:1px solid var(--border);margin:.7rem 0}.summary-line{display:flex;justify-content:space-between;gap:.75rem;font-size:.9rem;padding:.2rem 0}.summary-line span:last-child{white-space:nowrap;flex-shrink:0}.summary-stat{gap:.75rem}.summary-stat strong{white-space:nowrap;flex-shrink:0}.summary-line.discount{color:var(--error)}.summary-line.total{font-weight:700;font-size:1rem;border-top:1px solid var(--border);margin-top:.3rem;padding-top:.4rem;color:var(--green-dark)}.warn-text{background:#fff6e5;color:#8a6d1a;font-size:.82rem;padding:.4rem .6rem;border-radius:6px;margin-top:.6rem}.search-row,.add-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.8rem;flex-wrap:wrap}.search-row input[type=search],.add-row select{flex:1;min-width:0}.table-scroll{overflow-x:auto;margin-bottom:1rem}.table-scroll .data-table{margin-bottom:0}.search-results{list-style:none;padding:0;margin:0 0 1rem;border:1px solid var(--border);border-radius:8px;overflow:hidden}.search-results li button{width:100%;background:var(--card);color:var(--text);border:none;border-bottom:1px solid var(--border);border-radius:0;display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;text-align:left}.search-results li button:hover{background:#eef2f0}.link-notice{display:flex;justify-content:space-between;align-items:center;gap:1rem}.block-label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;margin-bottom:1rem}.config-block{border:1px solid var(--border);border-radius:8px;padding:.9rem 1rem;margin-bottom:1rem}.config-block legend{font-weight:700;color:var(--green-dark);padding:0 .4rem;font-size:.9rem}.config-row{display:flex;gap:.8rem;align-items:flex-end}.config-row label{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:600;min-width:0}.config-row select{min-width:0}.config-row .grow{flex:1}.config-row .qty{width:90px}.dim-row{display:flex;align-items:center;gap:.4rem}.data-table.editable td{padding:.35rem .4rem}.data-table.editable input,.data-table.editable select{padding:.35rem .4rem;font-size:.85rem}.qty-cell{width:80px}.data-table.editable .qty-cell input{width:70px}.mini-stats{display:flex;gap:1.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}.mini-stats div{display:flex;flex-direction:column}.mini-stats strong{font-size:1.1rem;color:var(--green-dark)}.review-section{margin-bottom:1.2rem}.review-section h4{margin:0 0 .4rem;color:var(--green-dark)}.grand-total-box{margin-top:1rem;padding:.8rem 1rem;background:#eef2f0;border-radius:8px}.view-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.view-grid .card,.card+.card{margin-bottom:0}.view-grid .card h3,.card h3:first-child{margin-top:0}.stat-row{display:flex;gap:1.5rem}.stat-row div{display:flex;flex-direction:column}.stat-row strong{font-size:1.15rem;color:var(--green-dark)}.note-box{background:#fff6e5;color:#8a6d1a;padding:.5rem .7rem;border-radius:6px;margin-bottom:1rem}.clickable-row{cursor:pointer}.clickable-row:hover td{background:#f4f8f5}.pill-status{text-transform:uppercase;font-size:.7rem}.status-Draft{background:#f0f0f0;color:var(--muted)}.status-Sent{background:#e6eef5;color:#2c5f8a}.status-Accepted{background:#e8f5ec;color:var(--green-dark)}.status-Rejected{background:#fdecea;color:var(--error)}.status-Expired{background:#fff6e5;color:#8a6d1a}.admin-grid{list-style:none;padding:0;margin:1rem 0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.admin-card{display:block;background:var(--card);border:1px solid var(--border);border-left:5px solid var(--green);border-radius:10px;padding:1.1rem 1.2rem;text-decoration:none;color:var(--text)}.admin-card:hover{background:#eef4f0}.admin-card h3{margin:0 0 .3rem;color:var(--green-dark)}.admin-card p{margin:0;font-size:.88rem;color:var(--muted)}.create-user-form{margin-bottom:1.2rem;padding:1rem 1.2rem}.create-user-form h3{margin:0 0 .6rem}.users-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.user-row{display:flex;gap:1rem;align-items:center;padding:.8rem 1rem}.user-row-fields{flex:1;display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}.user-row-fields label{font-size:.8rem;font-weight:600;display:flex;flex-direction:column;gap:.2rem}.user-row-fields>label:nth-child(1),.user-row-fields>label:nth-child(2){flex:1;min-width:160px}.user-row-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}@media (max-width: 700px){.user-row{flex-direction:column;align-items:stretch}}.color-row{display:flex;gap:.5rem;align-items:center}.color-row input[type=color]{width:42px;height:38px;padding:0;border:1px solid var(--border);border-radius:6px;cursor:pointer}.color-row input[type=text],.color-row input:not([type]){flex:1}.subhead{margin-top:.8rem;font-size:.9rem;color:var(--green-dark)}.stat-pair{display:grid;grid-template-columns:1fr 2fr;gap:.5rem;align-items:end}.clause-list{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.6rem}.clause-row{display:grid;grid-template-columns:2rem 1fr auto;gap:.6rem;align-items:start;padding:.6rem .8rem;background:#f4f6f5;border:1px solid var(--border);border-radius:8px}.clause-num{font-weight:700;color:var(--green-dark);text-align:right;padding-top:.4rem}.clause-fields{display:flex;flex-direction:column;gap:.3rem;min-width:0}.clause-fields input,.clause-fields textarea{font:inherit;padding:.4rem .55rem;border:1px solid var(--border);border-radius:6px;width:100%}.clause-actions{display:flex;flex-direction:column;gap:.2rem;align-items:center}.audit-diff{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;color:var(--muted);background:#f4f6f5;padding:.1rem .4rem;border-radius:4px}.audit-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;gap:1rem}button.danger-btn{color:var(--error);border-color:#f3c1bd}button.danger-btn:hover{background:#fdecea}.status-select{width:auto;font-size:.75rem;text-transform:uppercase;font-weight:700;letter-spacing:.04em;padding:.25rem .6rem;border-radius:999px;border:1px solid var(--border)}section.card{margin-bottom:1rem}.image-grid{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.9rem}.image-card{display:flex;flex-direction:column;gap:.4rem;border:1px solid var(--border);border-radius:8px;padding:.6rem;background:var(--card)}.image-thumb{display:block;width:100%;aspect-ratio:4 / 3;background-size:cover;background-position:center;background-color:#eef2f0;border-radius:6px}.image-card input[type=text],.image-card input:not([type]){font-size:.82rem;padding:.35rem .45rem}.image-card .inline-check{font-size:.82rem}.image-card-actions{display:flex;gap:.6rem;align-items:center}.image-label{font-size:.85rem;font-weight:600}.small-note{font-size:.75rem}.view-images .image-thumb{cursor:zoom-in}.equipment-image-row{display:flex;gap:1rem;align-items:flex-start}.equipment-image-preview{width:140px;height:110px;object-fit:contain;background:#fff;border:1px solid var(--border);border-radius:8px;padding:4px}.equipment-image-preview.placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.85rem;background:#f4f6f5}.equipment-image-actions{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}.file-btn{cursor:pointer;display:inline-flex;align-items:center;padding:.45rem .9rem;border-radius:6px;font-size:.85rem;font-weight:600;color:var(--green-dark);border:1px solid var(--border);background:transparent}.file-btn:hover{background:#eef2f0}.add-bank-form{display:flex;gap:.5rem;align-items:center;margin-bottom:1rem;padding:.8rem 1rem}.add-bank-form input{flex:1;min-width:0}.banks-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.bank-row{display:flex;gap:1rem;align-items:center;padding:.8rem 1rem}.bank-row-logo{width:100px;height:60px;border:1px solid var(--border);border-radius:6px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bank-row-logo img{max-width:100%;max-height:100%;object-fit:contain}.bank-row-fields{flex:1;display:flex;gap:.8rem;align-items:center}.bank-row-fields label{font-size:.8rem;font-weight:600;display:flex;flex-direction:column;gap:.2rem}.bank-row-fields>label:first-child{flex:1}.bank-row-sort input{width:70px}.bank-row-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}@media (max-width: 700px){.bank-row{flex-direction:column;align-items:stretch}.bank-row-fields{flex-wrap:wrap}}.equipment-thumb{width:48px;height:36px;object-fit:contain;background:#fff;border:1px solid var(--border);border-radius:4px;padding:2px}@media (max-width: 800px){.wizard-grid,.view-grid{grid-template-columns:1fr}.wizard-summary{position:static}}.not-found{text-align:center;padding:2.5rem 1rem}.not-found h2{margin:0 0 .5rem;color:var(--green-dark)}.not-found .link-btn{display:inline-block;margin-top:1rem}.nav-toggle{display:none;background:transparent;border:1px solid var(--border);border-radius:6px;padding:.4rem .55rem;flex-direction:column;gap:4px;width:38px;height:38px;align-items:center;justify-content:center}.nav-toggle:hover{background:#eef2f0}.nav-toggle span{display:block;width:18px;height:2px;background:var(--green-dark);border-radius:1px}@media (max-width: 720px){.topbar{padding:.7rem 1rem;flex-wrap:wrap;gap:.6rem}.topbar-left{gap:.7rem}.nav-toggle{display:inline-flex}.nav{display:none;flex-direction:column;width:100%;order:3;padding:.4rem 0 .2rem;border-top:1px solid var(--border);margin-top:.5rem;gap:.6rem}.nav.nav-open{display:flex}.nav a{border-bottom:none;padding:.5rem 0;font-size:1rem}.nav a.active{color:var(--green-dark);border-bottom:none}.user-chip{font-size:.8rem}.content{padding:1.2rem 1rem}.page-head{flex-direction:column;align-items:stretch}.actions{width:100%}.actions button{flex:1;min-width:0}.data-table{display:block;overflow-x:auto;white-space:nowrap}.filters{flex-direction:column;align-items:stretch}.filters select,.filters input[type=search]{width:100%;min-width:0}.stepper{gap:.3rem}.stepper li button{padding:.4rem .55rem;font-size:.8rem}.form-grid{grid-template-columns:1fr}.status-select{width:100%}.stat-row{flex-wrap:wrap;gap:1rem}.stat-row>div{flex:1 1 45%}}@media (max-width: 480px){.user-chip{display:none}.topbar-right{gap:.5rem}.brand-logo-sm{height:28px}.clause-row{grid-template-columns:1.5rem 1fr}.clause-actions{grid-column:1 / -1;flex-direction:row;justify-content:flex-end}}
