@import"https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@600;700;800&family=Barlow:wght@400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--clr-primary: #C0302A;--clr-primary-dk: #9E201A;--clr-primary-lt: #FDF1F0;--clr-bg: #F5F2F1;--clr-surface: #ffffff;--clr-border: #E0D6D4;--clr-text: #1C1412;--clr-muted: #7D6E6B;--clr-error-bg: #fef2f2;--clr-error-border:#fca5a5;--clr-error-text: #b91c1c;--radius: 4px;--shadow: 0 2px 12px rgba(0,0,0,.07);--clr-status-draft: #6B7280;--clr-status-draft-bg: #F3F4F6;--clr-status-sent: #2563EB;--clr-status-sent-bg: #EFF6FF;--clr-status-accepted: #059669;--clr-status-accepted-bg: #ECFDF5;--clr-status-expired: #D97706;--clr-status-expired-bg: #FFFBEB;--shadow-card: 0 1px 3px rgba(0,0,0,.05), 0 4px 12px rgba(0,0,0,.06);--radius-lg: 8px}html,body{height:100%}body{font-family:Barlow,system-ui,sans-serif;font-size:15px;color:var(--clr-text);background:var(--clr-bg);line-height:1.55}.app-header{background:#1c1412;padding:0 2rem;height:64px;display:flex;align-items:center;border-bottom:3px solid var(--clr-primary);box-shadow:0 1px 4px #0003}.header-inner{display:flex;align-items:center;gap:1rem}.header-logo{display:flex;align-items:center}.header-logo-img{height:36px;width:auto}.header-divider{width:1px;height:28px;background:#fff3}.header-subtitle{font-family:Barlow,system-ui,sans-serif;font-size:.82rem;font-weight:500;color:#ffffff8c;letter-spacing:.02em}.app-main{max-width:860px;margin:2rem auto;padding:0 1.5rem 4rem;display:flex;flex-direction:column;gap:2rem}.form-type-tabs{display:flex;gap:0;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.form-type-tab{flex:1;padding:.75rem 1rem;border:none;background:transparent;font-family:Barlow Condensed,system-ui,sans-serif;font-size:1rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--clr-muted);cursor:pointer;transition:background .15s,color .15s;border-bottom:3px solid transparent}.form-type-tab:not(:last-child){border-right:1px solid var(--clr-border)}.form-type-tab:hover:not(.active){background:var(--clr-bg);color:var(--clr-text)}.form-type-tab.active{color:var(--clr-primary);border-bottom-color:var(--clr-primary);background:var(--clr-primary-lt)}.catalog-list{display:flex;flex-direction:column;gap:.1rem}.catalog-row{border-radius:var(--radius);transition:background .12s}.catalog-row--active{background:var(--clr-primary-lt)}.catalog-check-label{display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;cursor:pointer;border-radius:var(--radius);font-size:.95rem;font-weight:400;color:var(--clr-text);text-transform:none;letter-spacing:0;-webkit-user-select:none;user-select:none}.catalog-check-label:hover{background:var(--clr-bg)}.catalog-row--active .catalog-check-label:hover{background:#f5e0de}.catalog-check-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--clr-primary);cursor:pointer;flex-shrink:0}.catalog-naam{flex:1}.catalog-prijs{font-family:Barlow Condensed,system-ui,sans-serif;font-size:.9rem;font-weight:700;color:var(--clr-muted);letter-spacing:.02em;white-space:nowrap}.catalog-row--active .catalog-prijs{color:var(--clr-primary)}.catalog-aantal{display:flex;align-items:center;gap:.75rem;margin:.1rem .6rem .5rem 2.4rem;padding:.45rem .75rem;background:#c0302a0f;border-left:3px solid var(--clr-primary);border-radius:0 var(--radius) var(--radius) 0}.catalog-aantal label{font-size:.78rem;white-space:nowrap}.catalog-aantal input[type=number]{width:80px}.catalog-totaal{font-family:Barlow Condensed,system-ui,sans-serif;font-size:.95rem;font-weight:700;color:var(--clr-primary);letter-spacing:.02em}textarea{padding:.6rem .75rem;border:1px solid var(--clr-border);border-radius:var(--radius);font-family:Barlow,system-ui,sans-serif;font-size:.95rem;color:var(--clr-text);background:var(--clr-surface);resize:vertical;width:100%;transition:border-color .15s,box-shadow .15s}.offert-form{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.form-section{padding:1.75rem 2rem;border-bottom:1px solid var(--clr-border)}.form-section:last-of-type{border-bottom:none}.form-section h2{font-family:Barlow Condensed,system-ui,sans-serif;font-size:1.05rem;font-weight:700;color:var(--clr-primary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1.25rem;padding-bottom:.45rem;border-bottom:2px solid var(--clr-primary);display:inline-block}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem}.field{display:flex;flex-direction:column;gap:.35rem}.field--full{grid-column:1 / -1}.field-required{color:var(--clr-primary);margin-left:2px}label{font-size:.82rem;font-weight:600;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.04em}input[type=text],input[type=email],input[type=tel],input[type=date],input[type=number],select{height:40px;padding:0 .75rem;border:1px solid var(--clr-border);border-radius:var(--radius);font-size:.95rem;color:var(--clr-text);background:var(--clr-surface);transition:border-color .15s,box-shadow .15s;width:100%}input[type=text]:focus,input[type=date]:focus,input[type=number]:focus,input[type=email]:focus,input[type=tel]:focus,select:focus{outline:none;border-color:var(--clr-primary);box-shadow:0 0 0 3px #c0302a1f}.checkbox-group{display:flex;flex-direction:column;gap:.65rem}.checkbox-label{display:flex;align-items:center;gap:.6rem;font-size:.95rem;font-weight:400;color:var(--clr-text);text-transform:none;letter-spacing:0;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:17px;height:17px;accent-color:var(--clr-primary);cursor:pointer;flex-shrink:0}.form-info-text{font-size:.88rem;color:var(--clr-muted);line-height:1.6;margin:.5rem 0 0 1.6rem;padding:.75rem 1rem;background:var(--clr-primary-lt);border-left:3px solid var(--clr-primary);border-radius:0 var(--radius) var(--radius) 0}.form-info-text a{color:var(--clr-primary);text-decoration:underline}.checkbox-group-label{font-size:.78rem;font-weight:700;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.5rem;margin-bottom:.15rem}.checkbox-label--indented{margin-left:1rem}.sub-field{display:flex;align-items:center;gap:.75rem;margin-left:2rem;padding:.5rem .75rem;background:var(--clr-primary-lt);border-left:3px solid var(--clr-primary);border-radius:0 var(--radius) var(--radius) 0}.sub-field label{white-space:nowrap;font-size:.82rem}.sub-field input[type=number]{width:90px}.form-actions{padding:1.25rem 2rem;background:var(--clr-bg);border-top:1px solid var(--clr-border);display:flex;justify-content:flex-end}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.4rem;border:none;border-radius:var(--radius);font-size:.95rem;font-weight:600;cursor:pointer;text-decoration:none;transition:background .15s,box-shadow .15s,opacity .15s}.btn-primary{background:var(--clr-primary);color:#fff;min-width:180px;justify-content:center;font-family:Barlow Condensed,system-ui,sans-serif;font-size:1rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.btn-primary:hover:not(:disabled){background:var(--clr-primary-dk);box-shadow:0 3px 10px #c0302a4d}.btn-primary:disabled{opacity:.65;cursor:not-allowed}.btn-download{background:var(--clr-primary);color:#fff;font-family:Barlow Condensed,system-ui,sans-serif;font-size:.95rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.btn-download:hover{background:var(--clr-primary-dk);box-shadow:0 3px 8px #c0302a59}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.error-banner{padding:.9rem 1.25rem;background:var(--clr-error-bg);border:1px solid var(--clr-error-border);border-radius:var(--radius);color:var(--clr-error-text);font-size:.9rem}.pdf-preview{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.pdf-preview-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--clr-border);background:var(--clr-bg)}.pdf-preview-header h2{font-family:Barlow Condensed,system-ui,sans-serif;font-size:1rem;font-weight:700;color:var(--clr-primary);text-transform:uppercase;letter-spacing:.1em}.pdf-frame{display:block;width:100%;height:780px;border:none}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.pdf-skeleton{height:780px;background:#f9f7f6;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:3rem 2rem 2rem;gap:0}.pdf-skeleton__page{width:100%;max-width:540px;display:flex;flex-direction:column;gap:.75rem}.pdf-skeleton__block{border-radius:4px;background:linear-gradient(90deg,#e8e0de 25%,#f0e8e6,#e8e0de 75%);background-size:1200px 100%;animation:shimmer 1.6s ease-in-out infinite}.pdf-skeleton__block--logo{height:36px;width:140px}.pdf-skeleton__block--title{height:22px;width:60%;margin-top:.5rem}.pdf-skeleton__block--subtitle{height:14px;width:40%}.pdf-skeleton__block--line{height:12px;width:100%}.pdf-skeleton__block--short{width:55%}.pdf-skeleton__block--med{width:75%}.pdf-skeleton__divider{height:1px;background:#e0d6d4;margin:.5rem 0}.pdf-skeleton__label{margin-top:2rem;font-family:Barlow Condensed,sans-serif;font-size:.85rem;font-weight:600;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.1em}.overige-wrapper{display:flex;flex-direction:column;gap:.75rem}.overige-list{display:flex;flex-direction:column;gap:.5rem}.overige-row{display:grid;grid-template-columns:70px 1fr 140px auto;gap:.75rem;align-items:flex-end;padding:.65rem .75rem;background:var(--clr-primary-lt);border:1px solid var(--clr-border);border-left:3px solid var(--clr-primary);border-radius:0 var(--radius) var(--radius) 0}.overige-remove{height:40px;width:36px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--clr-border);border-radius:var(--radius);font-size:1.25rem;line-height:1;color:var(--clr-muted);cursor:pointer;transition:background .15s,color .15s,border-color .15s;flex-shrink:0}.overige-remove:hover{background:#fef2f2;color:var(--clr-primary);border-color:var(--clr-primary)}.btn-add-regel{align-self:flex-start;display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;background:none;border:1.5px dashed var(--clr-border);border-radius:var(--radius);font-size:.88rem;font-weight:600;color:var(--clr-muted);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.btn-add-regel:hover{border-color:var(--clr-primary);color:var(--clr-primary);background:var(--clr-primary-lt)}.btn-add-icon{font-size:1.1rem;line-height:1;font-weight:400}.vrije-tekst-field{margin-top:1.25rem}textarea{padding:.6rem .75rem;border:1px solid var(--clr-border);border-radius:var(--radius);font-size:.95rem;font-family:Barlow,system-ui,sans-serif;color:var(--clr-text);background:var(--clr-surface);resize:vertical;width:100%;line-height:1.55;transition:border-color .15s,box-shadow .15s}textarea:focus{outline:none;border-color:var(--clr-primary);box-shadow:0 0 0 3px #c0302a1f}@media (max-width: 600px){.form-grid{grid-template-columns:1fr}.field--full{grid-column:1}.app-main{padding:0 1rem 3rem;margin:1rem auto}.form-section{padding:1.25rem 1rem}.form-actions{padding:1rem}.pdf-frame{height:500px}.overige-row{grid-template-columns:60px 1fr auto;grid-template-rows:auto auto}.overige-naam{grid-column:2}.overige-bedrag{grid-column:1 / 3}.overige-remove{grid-column:3;grid-row:1 / 3;align-self:center}}.header-inner{width:100%;justify-content:space-between}.header-left{display:flex;align-items:center;gap:1rem}.header-nav{display:flex;align-items:stretch;gap:0;height:100%}.header-nav-btn{background:none;border:none;padding:0 1.1rem;font-family:Barlow,system-ui,sans-serif;font-size:.88rem;font-weight:500;color:#ffffff80;cursor:pointer;letter-spacing:.02em;position:relative;transition:color .15s;height:64px}.header-nav-btn:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--clr-primary);transform:scaleX(0);transition:transform .2s ease}.header-nav-btn:hover{color:#ffffffd9}.header-nav-btn.active{color:#fff;font-weight:600}.header-nav-btn.active:after{transform:scaleX(1)}.app-main--wide{max-width:1280px;padding:0 2rem 4rem}.dashboard{display:flex;flex-direction:column;gap:1.75rem}.dash-header{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding:2rem 0 .5rem}.dash-header-text h1{font-family:Barlow Condensed,system-ui,sans-serif;font-size:1.75rem;font-weight:800;color:var(--clr-text);letter-spacing:.01em;line-height:1.1}.dash-header-text p{font-size:.88rem;color:var(--clr-muted);margin-top:.25rem}.dash-header-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.btn-dash-primary{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:var(--clr-primary);color:#fff;border:none;border-radius:var(--radius);font-family:Barlow Condensed,system-ui,sans-serif;font-size:.95rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:background .15s,box-shadow .15s}.btn-dash-primary:hover{background:var(--clr-primary-dk);box-shadow:0 3px 10px #c0302a47}.btn-dash-secondary{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;background:var(--clr-surface);color:var(--clr-text);border:1px solid var(--clr-border);border-radius:var(--radius);font-family:Barlow,system-ui,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s}.btn-dash-secondary:hover{background:var(--clr-bg);border-color:#bbb}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.stat-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:1.4rem 1.5rem 1.2rem;display:flex;flex-direction:column;gap:.35rem;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--clr-primary);opacity:.15}.stat-card__value{font-family:Barlow Condensed,system-ui,sans-serif;font-size:2.1rem;font-weight:800;color:var(--clr-text);line-height:1;letter-spacing:-.01em}.stat-card__label{font-size:.78rem;font-weight:600;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.07em}.stat-tag{display:inline-flex;align-items:center;padding:.18rem .55rem;border-radius:99px;font-size:.75rem;font-weight:600;margin-top:.3rem;width:fit-content}.stat-tag--neutral{background:#f3f4f6;color:#6b7280}.stat-tag--info{background:#eff6ff;color:#2563eb}.stat-tag--success{background:#ecfdf5;color:#059669}.stat-tag--warn{background:#fffbeb;color:#d97706}.dash-tabs-wrapper{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow:hidden}.dash-tab-bar{display:flex;gap:0;border-bottom:1px solid var(--clr-border);background:var(--clr-bg);padding:0 1rem}.dash-tab-btn{background:none;border:none;padding:.85rem 1.1rem;font-family:Barlow,system-ui,sans-serif;font-size:.9rem;font-weight:500;color:var(--clr-muted);cursor:pointer;position:relative;transition:color .15s;white-space:nowrap}.dash-tab-btn:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--clr-primary);transform:scaleX(0);transition:transform .2s ease}.dash-tab-btn:hover{color:var(--clr-text)}.dash-tab-btn.active{color:var(--clr-text);font-weight:600}.dash-tab-btn.active:after{transform:scaleX(1)}.dash-tab-panel{padding:1.75rem 2rem;animation:tabFadeIn .18s ease both}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.dash-section-title{font-family:Barlow Condensed,system-ui,sans-serif;font-size:1.15rem;font-weight:700;color:var(--clr-text);letter-spacing:.02em;margin-bottom:1rem}.dash-separator{border:none;border-top:1px solid var(--clr-border);margin:1.75rem 0}.dash-loading{color:var(--clr-muted);font-size:.875rem;padding:1rem 0}.dash-error{background:#fef2f2;color:#b91c1c;border:1px solid #FECACA;border-radius:var(--radius);padding:.75rem 1rem;font-size:.875rem;margin-bottom:1rem}.quotes-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--clr-border)}table.quotes-table{width:100%;border-collapse:collapse;font-size:.88rem}.quotes-table th{font-family:Barlow Condensed,system-ui,sans-serif;font-size:.76rem;font-weight:700;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.08em;padding:.75rem 1rem;text-align:left;background:var(--clr-bg);border-bottom:1px solid var(--clr-border);white-space:nowrap}.quotes-table td{padding:.72rem 1rem;border-bottom:1px solid var(--clr-border);color:var(--clr-text);white-space:nowrap}.quotes-table tbody tr:last-child td{border-bottom:none}.quotes-table tbody tr:hover td{background:var(--clr-primary-lt)}.quotes-table .col-id{font-family:Barlow Condensed,system-ui,sans-serif;font-weight:700;font-size:.9rem;color:var(--clr-primary)}.quotes-table .col-amount{font-weight:600;text-align:right}.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .65rem;border-radius:99px;font-size:.76rem;font-weight:600;text-transform:capitalize}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.8}.badge--draft{background:var(--clr-status-draft-bg);color:var(--clr-status-draft)}.badge--sent{background:var(--clr-status-sent-bg);color:var(--clr-status-sent)}.badge--accepted{background:var(--clr-status-accepted-bg);color:var(--clr-status-accepted)}.badge--expired{background:var(--clr-status-expired-bg);color:var(--clr-status-expired)}.col-status{white-space:nowrap}.status-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:99px;padding:.2rem .65rem;font-size:.76rem;font-weight:600;font-family:inherit;cursor:pointer;outline-offset:2px}.status-select:disabled{opacity:.55;cursor:default}.status-select--draft{background:var(--clr-status-draft-bg);color:var(--clr-status-draft)}.status-select--sent{background:var(--clr-status-sent-bg);color:var(--clr-status-sent)}.status-select--accepted{background:var(--clr-status-accepted-bg);color:var(--clr-status-accepted)}.status-select--expired{background:var(--clr-status-expired-bg);color:var(--clr-status-expired)}.status-error{display:block;font-size:.7rem;color:var(--clr-primary);margin-top:.15rem}.activity-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.activity-card{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.25rem 1.4rem}.activity-card__title{font-family:Barlow Condensed,system-ui,sans-serif;font-size:1.3rem;font-weight:800;color:var(--clr-text);line-height:1}.activity-card__label{font-size:.76rem;font-weight:600;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.5rem}.activity-card__desc{font-size:.88rem;color:var(--clr-muted);line-height:1.5;margin-top:.4rem}.filters-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.25rem}.filter-btns{display:flex;gap:.4rem;flex-wrap:wrap}.filter-btn{padding:.35rem .85rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);font-size:.82rem;font-weight:600;color:var(--clr-muted);cursor:pointer;transition:all .15s}.filter-btn:hover{border-color:#bbb;color:var(--clr-text)}.filter-btn.active{background:var(--clr-primary-lt);border-color:var(--clr-primary);color:var(--clr-primary)}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.chart-card{background:var(--clr-bg);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1.4rem 1.5rem}.chart-card__title{font-family:Barlow Condensed,system-ui,sans-serif;font-size:.9rem;font-weight:700;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1rem}.create-quote-form{max-width:640px}.dash-create-success{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#ecfdf5;border:1px solid #6EE7B7;border-radius:var(--radius-lg);margin-bottom:1.5rem}.dash-create-success__msg{font-family:Barlow Condensed,sans-serif;font-weight:600;font-size:.95rem;color:#059669;flex:1}.dash-create-success__msg:before{content:"✓ "}.create-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem}.create-form-field{display:flex;flex-direction:column;gap:.35rem}.create-form-field--full{grid-column:1 / -1}.create-form-field label{font-size:.78rem;font-weight:600;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.05em}.create-form-field input,.create-form-field select,.create-form-field textarea{font-size:.93rem}.slider-wrap{display:flex;align-items:center;gap:.75rem}.slider-wrap input[type=range]{flex:1;height:4px;accent-color:var(--clr-primary);cursor:pointer}.slider-value{font-family:Barlow Condensed,system-ui,sans-serif;font-size:1rem;font-weight:700;color:var(--clr-primary);min-width:2.5rem;text-align:right}.create-form-actions{display:flex;gap:.6rem;margin-top:1.5rem;flex-wrap:wrap}.btn-dash-tertiary{display:inline-flex;align-items:center;padding:.55rem 1.1rem;background:none;color:var(--clr-muted);border:1px solid var(--clr-border);border-radius:var(--radius);font-family:Barlow,system-ui,sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s}.btn-dash-tertiary:hover{color:var(--clr-text);border-color:#bbb}@media (max-width: 960px){.stats-row{grid-template-columns:repeat(2,1fr)}.analytics-grid{grid-template-columns:1fr}}@media (max-width: 640px){.stats-row{grid-template-columns:1fr 1fr}.activity-grid{grid-template-columns:1fr}.dash-tab-panel{padding:1.25rem 1rem}.create-form-grid{grid-template-columns:1fr}.create-form-field--full{grid-column:1}.app-main--wide{padding:0 1rem 3rem}}@media (max-width: 400px){.stats-row{grid-template-columns:1fr}}.app-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--clr-bg)}.app-loading-spinner{width:48px;height:48px;border:4px solid var(--clr-border);border-top-color:var(--clr-primary);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:var(--clr-bg)}.login-card{width:100%;max-width:420px;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:2.5rem 2rem;border-top:4px solid var(--clr-primary)}.login-logo{display:flex;justify-content:center;margin-bottom:1.5rem}.login-logo img{height:56px;width:auto}.login-title{font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:1.75rem;color:var(--clr-primary);margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.5px;text-align:center}.login-subtitle{text-align:center;color:var(--clr-muted);margin:0 0 2rem;font-size:.95rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-label{display:flex;flex-direction:column;gap:.35rem}.login-label>span{font-family:Barlow Condensed,sans-serif;font-weight:600;text-transform:uppercase;font-size:.8rem;letter-spacing:.5px;color:var(--clr-text)}.login-label input{padding:.65rem .85rem;border:1px solid var(--clr-border);border-radius:var(--radius);font-size:1rem;font-family:inherit;background:var(--clr-surface)}.login-label input:focus{outline:none;border-color:var(--clr-primary);box-shadow:0 0 0 3px var(--clr-primary-lt)}.login-error{padding:.65rem .85rem;background:var(--clr-primary-lt);border-left:3px solid var(--clr-primary);color:var(--clr-primary-dk);border-radius:var(--radius);font-size:.9rem}.login-submit{margin-top:.5rem;padding:.85rem 1rem;background:var(--clr-primary);color:#fff;border:none;border-radius:var(--radius);font-family:Barlow Condensed,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.75px;font-size:1rem;cursor:pointer;transition:background .15s ease}.login-submit:hover:not(:disabled){background:var(--clr-primary-dk)}.login-submit:disabled{background:#c7b8b6;cursor:not-allowed}.user-menu{position:relative;margin-left:1rem}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem .4rem .4rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:999px;cursor:pointer;font-family:inherit;font-size:.9rem;color:var(--clr-text);transition:border-color .15s,box-shadow .15s}.user-menu-trigger:hover{border-color:var(--clr-primary)}.user-menu-avatar{width:30px;height:30px;border-radius:50%;background:var(--clr-primary);color:#fff;font-family:Barlow Condensed,sans-serif;font-weight:700;font-size:.85rem;display:flex;align-items:center;justify-content:center;letter-spacing:.5px}.user-menu-name{font-weight:500}.user-menu-dropdown{position:absolute;right:0;top:calc(100% + 6px);width:240px;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);z-index:50;overflow:hidden}.user-menu-info{padding:.85rem 1rem;border-bottom:1px solid var(--clr-border);background:var(--clr-bg)}.user-menu-info-name{font-weight:600;font-size:.95rem;color:var(--clr-text)}.user-menu-info-email{font-size:.8rem;color:var(--clr-muted);margin-top:2px}.user-menu-info-role{display:inline-block;margin-top:6px;font-size:.7rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;background:var(--clr-primary-lt);color:var(--clr-primary-dk);padding:2px 8px;border-radius:999px}.user-menu-item{display:block;width:100%;text-align:left;padding:.7rem 1rem;background:transparent;border:none;color:var(--clr-text);font-family:inherit;font-size:.9rem;cursor:pointer}.user-menu-item:hover{background:var(--clr-primary-lt);color:var(--clr-primary-dk)}.login-link{margin-top:.5rem;background:transparent;border:none;color:var(--clr-primary);font-family:inherit;font-size:.9rem;cursor:pointer;text-align:center;padding:.4rem;text-decoration:underline}.login-link:hover{color:var(--clr-primary-dk)}@media (max-width: 680px){.app-header{padding:0 1rem}.header-divider,.header-subtitle{display:none}.header-left{gap:0}.header-inner{gap:.5rem}.header-nav-btn{padding:0 .7rem;font-size:.82rem}.user-menu{margin-left:.25rem}.user-menu-name{display:none}.user-menu-trigger{gap:0;padding:.25rem}}@media (max-width: 400px){.header-logo-img{height:30px}.header-nav-btn{padding:0 .5rem;font-size:.78rem}}.tarieven-tab{padding-top:.5rem}.tarieven-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.tarieven-filterbar{display:grid;grid-template-columns:220px 220px 1fr;gap:1rem;margin-bottom:1rem;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);padding:1rem}.tarieven-filterbar label{display:flex;flex-direction:column;gap:.25rem;font-family:Barlow Condensed,sans-serif;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;color:var(--clr-muted)}.tarieven-filterbar select,.tarieven-filterbar input{font-family:Barlow,sans-serif;font-size:.95rem;padding:.4rem .6rem;border:1px solid var(--clr-border);border-radius:var(--radius);background:#fff;text-transform:none;letter-spacing:normal;color:var(--clr-text)}.tarieven-zoek{min-width:0}.tarieven-zoek input{width:100%}.tarieven-empty{padding:2rem;text-align:center;color:var(--clr-muted);font-style:italic}.tarieven-tabel{width:100%;border-collapse:collapse;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card)}.tarieven-tabel thead th{text-align:left;font-family:Barlow Condensed,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;color:var(--clr-muted);background:var(--clr-bg);padding:.6rem .75rem;border-bottom:1px solid var(--clr-border)}.tarieven-tabel tbody td,.tarieven-tabel tbody th{padding:.55rem .75rem;border-bottom:1px solid var(--clr-border);font-size:.92rem;color:var(--clr-text)}.tarieven-groep-rij th{background:#fafafa;font-family:Barlow Condensed,sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:.85rem;color:var(--clr-primary)}.tarieven-tabel .mono{font-family:SFMono-Regular,Consolas,monospace;font-size:.85rem;color:var(--clr-muted)}.tarieven-tabel .num{text-align:right;font-variant-numeric:tabular-nums}.tarieven-tabel .muted{color:var(--clr-muted);font-size:.85rem}.tarieven-tabel .tarief-inactief td:not(.tarieven-acties){opacity:.55}.tarieven-acties{white-space:nowrap;text-align:right}.tarieven-acties button{background:transparent;border:1px solid var(--clr-border);border-radius:var(--radius);width:28px;height:28px;font-size:.9rem;cursor:pointer;margin-left:.25rem;color:var(--clr-muted)}.tarieven-acties button:hover{border-color:var(--clr-primary);color:var(--clr-primary)}.badge--admin{background:var(--clr-primary-lt);color:var(--clr-primary-dk);border:1px solid var(--clr-primary)}.badge--user{background:#f3f4f6;color:#4b5563;border:1px solid #D1D5DB}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c141273;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem}.modal{position:relative;background:var(--clr-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #00000040;width:100%;max-width:560px;max-height:90vh;overflow:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--clr-border)}.modal-header h3{margin:0;font-family:Barlow Condensed,sans-serif;font-weight:700}.modal-close{background:transparent;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--clr-muted);padding:0 .25rem}.tarief-form{padding:1.25rem;display:flex;flex-direction:column;gap:.85rem}.tarief-form .form-row{display:flex;flex-direction:column;gap:.3rem}.tarief-form .form-row>span{font-family:Barlow Condensed,sans-serif;text-transform:uppercase;font-weight:600;letter-spacing:.04em;font-size:.8rem;color:var(--clr-muted)}.tarief-form input,.tarief-form select{padding:.5rem .65rem;border:1px solid var(--clr-border);border-radius:var(--radius);font-family:Barlow,sans-serif;font-size:.95rem;background:#fff}.tarief-form .form-row-pair{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-error{color:var(--clr-primary);font-size:.8rem}.form-error-banner{background:var(--clr-primary-lt);color:var(--clr-primary-dk);padding:.6rem .75rem;border-radius:var(--radius);border:1px solid var(--clr-primary);font-size:.9rem}.form-success-banner{background:#ecfdf5;color:#065f46;padding:.6rem .75rem;border-radius:var(--radius);border:1px solid #10B981;font-size:.9rem}.modal-footer{display:flex;justify-content:flex-end;gap:.5rem;border-top:1px solid var(--clr-border);margin-top:.5rem;padding:.75rem 0 0}.modal-footer button,.modal-confirm-actions button{padding:.5rem 1rem;border-radius:var(--radius);border:1px solid var(--clr-border);background:#fff;font-family:Barlow Condensed,sans-serif;text-transform:uppercase;letter-spacing:.04em;font-weight:600;cursor:pointer}.modal-footer button.btn-primary,.modal-confirm-actions button.btn-primary{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff}.modal-footer button.btn-primary:hover,.modal-confirm-actions button.btn-primary:hover{background:var(--clr-primary-dk)}.modal-confirm{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;padding:1rem}.modal-confirm-inner{background:var(--clr-surface);border:1px solid var(--clr-primary);border-radius:var(--radius-lg);padding:1.5rem;max-width:420px;box-shadow:0 8px 24px #00000026}.modal-confirm-inner h4{margin-top:0}.modal-confirm-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.tarieven-tab .btn-primary{padding:.5rem 1rem;border-radius:var(--radius);border:1px solid var(--clr-primary);background:var(--clr-primary);color:#fff;font-family:Barlow Condensed,sans-serif;text-transform:uppercase;letter-spacing:.04em;font-weight:700;cursor:pointer}.tarieven-tab .btn-primary:hover{background:var(--clr-primary-dk)}.modal-audit{max-width:620px}.modal-body{padding:1rem 1.25rem;max-height:60vh;overflow:auto}.audit-lijst{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.65rem}.audit-item{border-left:3px solid var(--clr-border);padding:.5rem .75rem;background:var(--clr-bg);border-radius:var(--radius)}.audit-item.audit--create{border-left-color:var(--clr-status-accepted)}.audit-item.audit--update{border-left-color:var(--clr-status-sent)}.audit-item.audit--deactivate{border-left-color:var(--clr-status-expired)}.audit-item.audit--reactivate{border-left-color:var(--clr-status-accepted)}.audit-item.audit--password_reset{border-left-color:var(--clr-status-sent)}.audit-kop{display:flex;flex-wrap:wrap;gap:.5rem;align-items:baseline;font-size:.9rem}.audit-detail{margin-top:.25rem;font-size:.92rem;color:var(--clr-text)}.quotes-table__row--clickable{cursor:pointer}.quotes-table__row--clickable:focus-visible{outline:2px solid var(--clr-primary);outline-offset:-2px}.quotes-table__row--clickable .col-id:before{content:"▸";display:inline-block;margin-right:.45rem;color:var(--clr-primary);opacity:0;transform:translate(-3px);transition:opacity .15s,transform .15s}.quotes-table__row--clickable:hover .col-id:before,.quotes-table__row--clickable:focus-visible .col-id:before{opacity:1;transform:translate(0)}.offerte-detail{display:flex;flex-direction:column;gap:1.25rem;animation:tabFadeIn .2s ease both}.offerte-detail__back{align-self:flex-start;display:inline-flex;align-items:center;gap:.45rem;background:none;border:none;padding:.35rem .1rem;font-family:Barlow Condensed,system-ui,sans-serif;font-size:.92rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--clr-muted);cursor:pointer;transition:color .15s,gap .15s}.offerte-detail__back:hover{color:var(--clr-primary);gap:.7rem}.offerte-doc{background:var(--clr-surface);border:1px solid var(--clr-border);border-top:4px solid var(--clr-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:2.25rem 2.5rem 2rem;max-width:720px}.offerte-doc>*{animation:docRise .4s ease both}.offerte-doc__head{animation-delay:.04s}.offerte-doc__party{animation-delay:.1s}.offerte-doc__amounts{animation-delay:.16s}.offerte-doc__meta{animation-delay:.22s}.offerte-doc__note{animation-delay:.28s}@keyframes docRise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.offerte-doc__head{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--clr-border);flex-wrap:wrap}.offerte-doc__eyebrow{display:block;font-family:Barlow Condensed,system-ui,sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--clr-muted)}.offerte-doc__id{font-family:Barlow Condensed,system-ui,sans-serif;font-size:2.4rem;font-weight:800;line-height:1;margin:.15rem 0 0;color:var(--clr-text);letter-spacing:.01em}.offerte-doc__type{margin:.5rem 0 0;font-size:.95rem;color:var(--clr-muted)}.offerte-doc__status{display:flex;flex-direction:column;align-items:flex-end;gap:.55rem;text-align:right}.offerte-doc__status-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .7rem;border-radius:99px;font-family:Barlow Condensed,system-ui,sans-serif;font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:var(--status-clr, #9CA3AF)}.offerte-doc__status-edit{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}.offerte-doc__status-edit>span{font-size:.72rem;color:var(--clr-muted);letter-spacing:.04em}.offerte-doc__status-error{font-size:.78rem;color:var(--clr-primary)}.offerte-doc__party{padding:1.5rem 0;border-bottom:1px solid var(--clr-border)}.offerte-doc__label{display:block;font-family:Barlow Condensed,system-ui,sans-serif;font-size:.76rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--clr-muted);margin-bottom:.35rem}.offerte-doc__client{margin:0;font-size:1.3rem;font-weight:600;color:var(--clr-text)}.offerte-doc__company{margin:.2rem 0 0;font-size:.95rem;color:var(--clr-muted)}.offerte-doc__amounts{padding:1.5rem 0;border-bottom:1px solid var(--clr-border)}.amount-line{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0;font-size:.98rem;color:var(--clr-text)}.amount-line span:first-child{color:var(--clr-muted)}.amount-line__val{font-variant-numeric:tabular-nums;font-weight:600}.amount-line--total{margin-top:.4rem;padding-top:1rem;border-top:2px solid var(--clr-text)}.amount-line--total span:first-child{font-family:Barlow Condensed,system-ui,sans-serif;font-weight:800;font-size:1.05rem;letter-spacing:.04em;text-transform:uppercase;color:var(--clr-text)}.amount-line--total .amount-line__val{font-family:Barlow Condensed,system-ui,sans-serif;font-size:1.9rem;font-weight:800;color:var(--clr-primary)}.offerte-doc__meta{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem 2rem;margin:1.5rem 0 0;padding:0}.offerte-doc__meta-item dt{font-family:Barlow Condensed,system-ui,sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--clr-muted);margin-bottom:.2rem}.offerte-doc__meta-item dd{margin:0;font-size:.95rem;color:var(--clr-text)}.offerte-doc__note{margin:1.75rem 0 0;padding-top:1.25rem;border-top:1px dashed var(--clr-border);font-size:.82rem;line-height:1.5;color:var(--clr-muted)}@media (max-width: 600px){.offerte-doc{padding:1.5rem 1.25rem}.offerte-doc__head{flex-direction:column}.offerte-doc__status,.offerte-doc__status-edit{align-items:flex-start;text-align:left}.offerte-doc__id{font-size:2rem}.offerte-doc__meta{grid-template-columns:1fr}}
