*{margin:0;padding:0;box-sizing:border-box}:root{--ink: #0f0e0c;--paper: #f7f4ef;--cream: #ede9e1;--accent: #119295;--accent-light: #e6f3f3;--gold: #c9a84c;--muted: #8a8379;--border: #d6d0c6;--white: #ffffff;--shadow: 0 2px 24px rgba(15,14,12,.08);--shadow-lg: 0 8px 48px rgba(15,14,12,.14);--r: 4px;--font-main: "Inter", sans-serif;--font-display: "Playfair Display", serif}[data-theme=dark]{--ink: #e8e6e3;--paper: #121212;--cream: #1e1e1e;--accent: #119295;--accent-light: #1a3d3a;--gold: #c9a84c;--muted: #8a8379;--border: #333333;--white: #2a2a2a;--shadow: 0 2px 24px rgba(0,0,0,.3);--shadow-lg: 0 8px 48px rgba(0,0,0,.5)}body{font-family:var(--font-main);background:var(--paper);color:var(--ink);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-container{display:flex;flex:1;height:calc(100vh - 92px);overflow:hidden;align-items:flex-start}.form-panel-wrapper{height:calc(100vh - 56px);min-width:350px;overflow:hidden;display:flex;flex-direction:column}.form-panel{flex:1;overflow-y:auto;height:100%}.resizer{width:6px;background:var(--border);cursor:col-resize;flex-shrink:0;transition:background .2s;position:relative;align-self:stretch}.resizer:hover,.resizer:active{background:var(--accent)}.resizer:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:2px;height:40px;background:var(--muted);border-radius:2px;opacity:.5}.resizer:hover:before{background:var(--white);opacity:1}.header{position:sticky;top:0;z-index:100;background:var(--paper);border-bottom:1px solid var(--border);padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:56px}.logo{font-family:var(--font-display);font-size:1.25rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.4rem}.logo-dot{color:var(--accent)}.header-actions{display:flex;gap:.5rem;align-items:center}.font-selector{font-size:.7rem;padding:.3rem .6rem;border:1px solid var(--border);border-radius:var(--r);background:var(--white);color:var(--ink);cursor:pointer;outline:none;transition:border-color .2s;max-width:120px}.font-selector:hover{border-color:var(--muted)}.font-selector:focus{border-color:var(--accent)}.lang-selector{display:flex;gap:.25rem;align-items:center}.lang-btn{width:32px;height:24px;border-radius:4px;border:1px solid var(--border);font-size:.65rem;font-weight:600;background:var(--cream);color:var(--muted);font-family:var(--font-main);cursor:pointer;transition:all .2s}.lang-btn:hover{background:var(--white);color:var(--ink);border-color:var(--muted)}.lang-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.separator{width:1px;height:24px;background:var(--border);margin:0 .5rem}.btn-ghost{font-size:.78rem;color:var(--muted);background:none;border:none;cursor:pointer;padding:.35rem .6rem;border-radius:var(--r);font-family:var(--font-main);transition:color .2s,background .2s}.btn-ghost:hover{color:var(--ink);background:var(--cream)}.form-panel{padding:1.5rem 2rem 3rem;overflow-y:auto;background:var(--paper);border-right:1px solid var(--border)}.section-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.form-section{margin-bottom:1.5rem}.field-row{display:grid;gap:.6rem;margin-bottom:.6rem}.field-row.cols-2{grid-template-columns:1fr 1fr}.field-row.cols-3{grid-template-columns:1fr 1fr 1fr}.field{display:flex;flex-direction:column;gap:.25rem}.field label{font-size:.68rem;font-weight:500;color:var(--muted);letter-spacing:.03em;text-transform:uppercase}.field input,.field textarea,.field select{font-family:var(--font-main);font-size:.85rem;color:var(--ink);background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:.5rem .7rem;outline:none;transition:border-color .2s,box-shadow .2s;width:100%}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.field textarea{resize:vertical;min-height:60px;line-height:1.5}.items-header{display:grid;grid-template-columns:1fr 70px 85px 85px 32px;gap:.4rem;font-size:.6rem;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;padding:0 .2rem .35rem;border-bottom:1px solid var(--border);margin-bottom:.4rem}.item-row{display:grid;grid-template-columns:1fr auto;gap:.4rem;align-items:center;margin-bottom:.35rem;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.item-row input{font-family:var(--font-main);font-size:.8rem;color:var(--ink);background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:.4rem .5rem;outline:none;width:100%;transition:border-color .2s,box-shadow .2s}.item-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.item-total{font-size:.75rem;color:var(--muted);text-align:right;padding:.4rem .2rem}.item-qty-price{display:grid;grid-template-columns:70px 85px 85px 32px;gap:.4rem;align-items:center}.qty-price-field{display:flex;flex-direction:column;gap:.15rem}.qty-price-field label{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;display:none}.item-desc-input{width:100%}.item-qty-input{text-align:center}.item-price-input{text-align:right}.btn-remove{background:none;border:none;cursor:pointer;color:var(--border);font-size:1.2rem;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .2s,background .2s}.btn-remove:hover{color:var(--accent);background:var(--accent-light)}.btn-add-item{margin-top:.4rem;display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--accent);background:none;border:1px dashed var(--accent);border-radius:var(--r);padding:.4rem .8rem;cursor:pointer;transition:background .2s;width:100%;justify-content:center;font-family:var(--font-main)}.btn-add-item:hover{background:var(--accent-light)}.totals-box{background:var(--white);border:1px solid var(--border);border-radius:6px;padding:.85rem 1rem;margin-top:.85rem}.totals-row{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;font-size:.82rem}.totals-row.grand{border-top:1px solid var(--border);margin-top:.35rem;padding-top:.6rem;font-weight:600;font-size:.95rem}.totals-row.grand .amount{font-family:var(--font-main);font-size:1.1rem;color:var(--accent);font-weight:600}.totals-label{color:var(--muted);font-size:.75rem}.totals-value{font-weight:500}.tax-row{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}.tax-row label{font-size:.75rem;color:var(--muted);white-space:nowrap}.tax-row input{font-family:var(--font-main);font-size:.8rem;color:var(--ink);background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:.4rem .6rem;outline:none;width:70px}.tax-row input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border);transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.generate-section{margin-top:1.5rem;display:flex;gap:.6rem;flex-wrap:wrap}.btn-primary{flex:1;background:var(--accent);color:#fff;border:none;border-radius:var(--r);padding:.75rem 1.25rem;font-family:var(--font-display);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:filter .2s,transform .15s}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--white);color:var(--ink);border:1px solid var(--border);border-radius:var(--r);padding:.75rem 1rem;font-size:.82rem;cursor:pointer;display:flex;align-items:center;gap:.35rem;transition:background .2s,border-color .2s;font-family:var(--font-main)}.btn-secondary:hover{background:var(--cream);border-color:var(--muted)}.preview-panel{background:#d8d3cb;display:flex;flex-direction:column;flex:1;min-width:350px;height:calc(100vh - 56px);overflow:hidden;position:sticky;top:56px;flex-shrink:0}.preview-panel .preview-toolbar{padding:.75rem 1rem;flex-shrink:0}.preview-panel .preview-container{flex:1;overflow:auto;display:flex;justify-content:center}.preview-toolbar{width:100%;display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.preview-label{font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.preview-actions{display:flex;gap:.3rem;align-items:center}.zoom-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);border-radius:var(--r);background:var(--white);color:var(--muted);cursor:pointer;transition:all .2s;padding:0}.zoom-btn:hover{background:var(--cream);color:var(--ink);border-color:var(--muted)}.zoom-level{width:auto;padding:0 .5rem;font-size:.7rem;font-weight:500;min-width:42px}.invoice-preview{width:360px;background:var(--white);border-radius:4px;box-shadow:var(--shadow-lg);padding:1.75rem 1.75rem 2rem;font-size:.72rem;line-height:1.5;color:var(--ink);min-height:510px;position:relative;flex-shrink:0}.inv-accent-bar{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),var(--gold))}.inv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem;padding-top:.4rem}.inv-logo-name{font-family:var(--font-display);font-size:1rem;letter-spacing:-.01em;line-height:1.2}.inv-logo-tagline{font-size:.62rem;color:var(--muted);margin-top:.15rem}.inv-meta-right{text-align:right}.inv-title{font-family:var(--font-display);font-size:.95rem;letter-spacing:.02em;color:var(--accent);text-transform:uppercase}.inv-number{font-size:.62rem;color:var(--muted);margin-top:.1rem}.inv-divider{border:none;border-top:1px solid var(--border);margin:.75rem 0}.inv-parties{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-bottom:1.25rem}.inv-party-label{font-size:.52rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.15rem}.inv-party-name{font-weight:600;font-size:.75rem}.inv-party-detail{font-size:.65rem;color:var(--muted);line-height:1.35}.inv-items-head{display:grid;grid-template-columns:1fr 45px 55px 55px;gap:.25rem;font-size:.55rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding-bottom:.3rem;border-bottom:1px solid var(--border)}.inv-items-head span:not(:first-child){text-align:right}.inv-item-row{display:grid;grid-template-columns:1fr 45px 55px 55px;gap:.25rem;padding:.3rem 0;border-bottom:1px dashed var(--cream);font-size:.68rem}.inv-item-row span:not(:first-child){text-align:right;font-size:.65rem}.inv-item-desc{line-height:1.3}.inv-totals{margin-top:.5rem;display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.inv-total-row{display:flex;gap:1.25rem;justify-content:flex-end;font-size:.68rem}.inv-total-row .t-label{color:var(--muted)}.inv-total-row .t-val{min-width:65px;text-align:right}.inv-total-row.grand-total{margin-top:.35rem;padding-top:.4rem;border-top:1.5px solid var(--ink);font-size:.8rem;font-weight:600}.inv-total-row.grand-total .t-val{font-family:var(--font-display);font-size:.95rem;color:var(--accent)}.inv-notes{margin-top:1.25rem;padding:.55rem .65rem;background:var(--accent-light);border-left:3px solid var(--accent);border-radius:2px;font-size:.62rem;color:var(--muted);line-height:1.45}.inv-notes-label{font-size:.52rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);margin-bottom:.15rem}.inv-footer{margin-top:1.25rem;padding-top:.6rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;font-size:.58rem;color:var(--muted)}.currency-row{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem}.currency-btn{font-size:.68rem;padding:.25rem .55rem;border:1px solid var(--border);border-radius:20px;background:var(--white);cursor:pointer;color:var(--muted);transition:all .2s;font-family:var(--font-main)}.currency-btn.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);padding:.55rem 1.1rem;border-radius:40px;font-size:.78rem;z-index:999;white-space:nowrap}.empty-hint{color:var(--muted);font-size:.7rem;font-style:italic;padding:.85rem 0;text-align:center}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.version-badge{font-size:.55rem;color:var(--muted);background:var(--cream);padding:.15rem .4rem;border-radius:2px}.btn-templates{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:var(--cream);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.78rem;color:var(--ink);font-family:var(--font-main);transition:all .2s}.btn-templates:hover{background:var(--white);border-color:var(--accent)}.template-color-dot{width:14px;height:14px;border-radius:50%;border:2px solid rgba(0,0,0,.1)}.template-name-label{max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.templates-modal{max-width:900px;max-height:85vh}.templates-body{padding:1.5rem;overflow-y:auto;flex:1}.templates-intro{font-size:.82rem;color:var(--muted);margin-bottom:1.25rem;line-height:1.5}.templates-grid-modal{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.template-card-modal{background:var(--white);border:2px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .2s}.template-card-modal:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:var(--shadow)}.template-card-modal.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.template-preview-modal{height:120px;padding:.75rem;position:relative}.tp-accent-modal{position:absolute;top:0;left:0;right:0;height:3px}.tp-header-modal{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.4rem}.tp-logo-modal{width:45px;height:6px;border-radius:2px}.tp-meta-modal{width:30px;height:4px;border-radius:2px}.tp-divider-modal{height:1px;margin:.4rem 0}.tp-content-modal{display:flex;gap:.35rem;margin-bottom:.4rem}.tp-block-modal{flex:1;height:16px;border-radius:3px}.tp-block-short{flex:.5}.tp-lines-modal{display:flex;flex-direction:column;gap:3px}.tp-line-modal{height:4px;border-radius:2px}.tp-line-short{width:60%}.template-info-modal{padding:.6rem .75rem;border-top:1px solid var(--border)}.template-name-modal{display:flex;align-items:center;justify-content:space-between;font-size:.82rem;font-weight:600;color:var(--ink);margin-bottom:.15rem}.template-applied-badge{width:18px;height:18px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center}.template-desc-modal{font-size:.68rem;color:var(--muted)}.templates-tip{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--accent-light);border-radius:6px;font-size:.78rem;color:var(--accent)}.templates-tip svg{flex-shrink:0}@media (max-width: 1000px){.app-container{flex-direction:column}.form-panel-wrapper{width:100%!important;min-width:auto}.resizer{display:none}.preview-panel{position:relative;top:0;height:auto;order:-1;min-height:auto}.preview-container{overflow-x:auto;padding:.75rem 0;display:flex;justify-content:center}.invoice-preview{width:340px;flex-shrink:0}.form-panel{border-right:none;border-top:1px solid var(--border);padding:1rem}.items-header{display:none}.item-row{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--white);border:1px solid var(--border);border-radius:var(--r);margin-bottom:.5rem}.item-qty-price{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:.5rem;align-items:end}.qty-price-field{display:flex;flex-direction:column;gap:.2rem}.qty-price-field label{display:block;font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.item-total{font-size:.8rem;padding:.4rem;background:var(--cream);border-radius:var(--r);text-align:center}}@media (max-width: 480px){.preview-container{padding:.5rem .25rem}.invoice-preview{width:300px}.form-panel{padding:.75rem}.item-row{padding:.6rem}.item-qty-price{grid-template-columns:1fr 1fr auto;gap:.4rem}.qty-price-field:last-of-type{display:none}.qty-price-field .btn-remove{margin-bottom:0}}@media (max-width: 360px){.invoice-preview{width:260px}.item-qty-price{grid-template-columns:1fr 1fr;gap:.3rem}}.marketplace{flex:1;padding:2rem;overflow-y:auto;max-width:1200px;margin:0 auto;width:100%}.marketplace-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.marketplace-title{font-family:var(--font-display);font-size:1.25rem;display:flex;align-items:center;gap:.5rem;color:var(--ink)}.category-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.category-tab{font-size:.78rem;padding:.4rem 1rem;border:1px solid var(--border);border-radius:20px;background:var(--white);color:var(--muted);cursor:pointer;transition:all .2s;font-family:var(--font-main)}.category-tab:hover{border-color:var(--accent);color:var(--accent)}.category-tab.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.template-card{background:var(--white);border:1px solid var(--border);border-radius:8px;overflow:hidden;cursor:pointer;transition:all .25s;position:relative}.template-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}.template-card.selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.template-preview{height:160px;padding:1rem;position:relative}.template-preview.theme-default{background:#f7f4ef}.template-preview.theme-dark{background:#1a1917}.template-preview.theme-ocean{background:#f0f6f8}.template-preview.theme-forest{background:#f5f8f2}.template-preview.theme-sunset{background:#fdf8f3}.template-preview.theme-midnight{background:#0d1117}.template-preview.theme-elegant{background:#faf9f7}.template-preview.theme-modern{background:#0a0a0c}.template-preview.theme-berry{background:#f9f5f8}.tp-accent{position:absolute;top:0;left:0;right:0;height:3px}.theme-default .tp-accent{background:linear-gradient(90deg,#d4522a,#c9a84c)}.theme-dark .tp-accent{background:linear-gradient(90deg,#e8663d,#d4b05a)}.theme-ocean .tp-accent{background:linear-gradient(90deg,#0d7377,#14919b)}.theme-forest .tp-accent{background:linear-gradient(90deg,#2d6a4f,#52b788)}.theme-sunset .tp-accent{background:linear-gradient(90deg,#c44536,#e07a3d)}.theme-midnight .tp-accent{background:linear-gradient(90deg,#58a6ff,#79c0ff)}.theme-elegant .tp-accent{background:linear-gradient(90deg,#8b5a2b,#c9a84c)}.theme-modern .tp-accent{background:linear-gradient(90deg,#00c896,gold)}.theme-berry .tp-accent{background:linear-gradient(90deg,#9b3d6e,#c77dab)}.tp-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem}.tp-logo{width:60px;height:8px;border-radius:2px}.theme-default .tp-logo{background:#d4522a}.theme-dark .tp-logo{background:#e8663d}.theme-ocean .tp-logo{background:#0d7377}.theme-forest .tp-logo{background:#2d6a4f}.theme-sunset .tp-logo{background:#c44536}.theme-midnight .tp-logo{background:#58a6ff}.theme-elegant .tp-logo{background:#8b5a2b}.theme-modern .tp-logo{background:#00c896}.theme-berry .tp-logo{background:#9b3d6e}.tp-meta{width:40px;height:6px;border-radius:2px}.theme-default .tp-meta{background:#d4522a}.theme-dark .tp-meta{background:#e8663d}.theme-ocean .tp-meta{background:#0d7377}.theme-forest .tp-meta{background:#2d6a4f}.theme-sunset .tp-meta{background:#c44536}.theme-midnight .tp-meta{background:#58a6ff}.theme-elegant .tp-meta{background:#8b5a2b}.theme-modern .tp-meta{background:#00c896}.theme-berry .tp-meta{background:#9b3d6e}.tp-divider{height:1px;margin:.5rem 0}.theme-default .tp-divider{background:#d6d0c6}.theme-dark .tp-divider{background:#3d3a36}.theme-ocean .tp-divider{background:#c5d5da}.theme-forest .tp-divider{background:#c5d8c2}.theme-sunset .tp-divider{background:#e0d0c0}.theme-midnight .tp-divider{background:#30363d}.theme-elegant .tp-divider{background:#e0ddd5}.theme-modern .tp-divider{background:#333}.theme-berry .tp-divider{background:#e0d0dc}.tp-content{display:flex;gap:.5rem;margin-bottom:.5rem}.tp-block{flex:1;height:24px;border-radius:3px}.theme-default .tp-block{background:#ede9e1}.theme-dark .tp-block{background:#252320}.theme-ocean .tp-block{background:#e3ecf0}.theme-forest .tp-block{background:#e8efe4}.theme-sunset .tp-block{background:#f5ebe0}.theme-midnight .tp-block{background:#161b22}.theme-elegant .tp-block{background:#f0eeea}.theme-modern .tp-block{background:#1a1a1a}.theme-berry .tp-block{background:#efe6ec}.tp-block.short{flex:.5}.tp-lines{display:flex;flex-direction:column;gap:4px}.tp-line{height:6px;border-radius:2px}.theme-default .tp-line,.theme-dark .tp-line{background:#8a8379}.theme-ocean .tp-line{background:#5a7d85}.theme-forest .tp-line{background:#5a7d60}.theme-sunset .tp-line{background:#8a6a5a}.theme-midnight .tp-line{background:#6e7681}.theme-elegant .tp-line{background:#7a7a7a}.theme-modern .tp-line{background:#888}.theme-berry .tp-line{background:#8a6a7a}.tp-line.short{width:60%}.template-info{padding:.75rem 1rem;border-top:1px solid var(--border)}.template-name{font-size:.85rem;font-weight:600;color:var(--ink);display:block;margin-bottom:.2rem}.template-desc{font-size:.7rem;color:var(--muted)}.template-applied{position:absolute;top:.75rem;right:.75rem;width:24px;height:24px;background:var(--accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center}.marketplace-footer{text-align:center;padding:1rem}.footer-text{font-size:.78rem;color:var(--muted)}.gradient-text{background:linear-gradient(135deg,var(--accent),var(--gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:600}.nav-tabs{display:flex;gap:2px;background:var(--cream);padding:3px;border-radius:6px}.btn-nav{display:flex;align-items:center;gap:.35rem;font-size:.72rem;padding:.4rem .85rem;border:none;border-radius:4px;background:transparent;color:var(--muted);cursor:pointer;transition:all .2s;font-family:var(--font-main);font-weight:500}.btn-nav:hover{color:var(--ink);background:var(--white)}.btn-nav.active{background:var(--white);color:var(--ink);box-shadow:0 1px 3px #0000001a}.header-left{display:flex;align-items:center;gap:1rem}.company-switcher{position:relative}.company-btn{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;background:var(--cream);border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:.78rem;color:var(--ink);font-family:var(--font-main);transition:all .2s}.company-btn:hover{background:var(--white);border-color:var(--accent)}.company-logo-small{width:22px;height:22px;border-radius:4px;object-fit:contain}.company-initial-sm{width:22px;height:22px;border-radius:4px;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:600}.company-name-sm{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-toolbar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:6px;background:var(--white);color:var(--muted);cursor:pointer;transition:all .2s}.btn-toolbar:hover{border-color:var(--accent);color:var(--accent)}.company-logo-display{display:flex;justify-content:center;padding:1rem;margin-bottom:.5rem;border-bottom:1px solid var(--border)}.company-logo-display img{max-height:60px;max-width:200px;object-fit:contain}.section-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-label-row .section-label{margin-bottom:0}.section-label-row .section-label:after{display:none}.btn-link-sm{display:flex;align-items:center;gap:.25rem;font-size:.65rem;color:var(--accent);background:none;border:none;cursor:pointer;font-family:var(--font-main)}.btn-link-sm:hover{text-decoration:underline}.client-search-container{position:relative}.client-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--white);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow-lg);z-index:100;max-height:200px;overflow-y:auto}.client-dropdown-item{padding:.6rem .75rem;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--cream)}.client-dropdown-item:last-child{border-bottom:none}.client-dropdown-item:hover{background:var(--cream)}.client-dropdown-item .client-name{display:block;font-size:.82rem;font-weight:500;color:var(--ink)}.client-dropdown-item .client-detail{display:block;font-size:.68rem;color:var(--muted);margin-top:.1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.modal-content{background:var(--paper);border-radius:12px;width:100%;max-width:950px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-content.clients-modal,.modal-content.companies-modal{max-width:1000px;max-height:80vh}.modal-content.settings-modal{max-width:500px;max-height:85vh}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-body{padding:1.5rem;flex:1;overflow:hidden}.clients-layout,.companies-layout{display:grid;grid-template-columns:42% 58%;gap:1.5rem;height:100%}.clients-list-section,.companies-list-section{border-right:1px solid var(--border);padding-right:1.5rem;display:flex;flex-direction:column;overflow:hidden}.client-form-section,.company-form-section{padding-left:.5rem;padding-right:1.5rem;display:flex;flex-direction:column;overflow:hidden}.clients-list,.companies-list{flex:1;overflow-y:auto;min-height:0}.clients-toolbar,.companies-toolbar{flex-shrink:0;margin-bottom:1rem}.clients-list-section .clients-list,.companies-list-section .companies-list{max-height:none;flex:1}.modal-content{background:var(--paper);border-radius:12px;width:100%;max-width:900px;max-height:calc(100vh - 2rem);display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-content.clients-modal,.modal-content.companies-modal{max-width:950px}.modal-content.settings-modal{max-width:550px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.modal-header h3{font-family:var(--font-display);font-size:1.1rem;color:var(--ink)}.modal-close{width:28px;height:28px;border-radius:50%;border:none;background:var(--cream);color:var(--muted);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{background:var(--accent);color:#fff}.modal-body{padding:1.25rem;overflow-y:auto;flex:1}.clients-layout,.companies-layout{display:grid;grid-template-columns:45% 55%;gap:2rem;min-height:350px}.clients-list-section,.companies-list-section{border-right:1px solid var(--border);padding-right:2rem;display:flex;flex-direction:column}.client-form-section,.company-form-section{padding-left:.5rem;display:flex;flex-direction:column}.clients-list,.companies-list{flex:1;overflow-y:auto;max-height:400px}.client-form-section h4,.company-form-section h4{font-size:.9rem;color:var(--ink);margin-bottom:1rem}.clients-toolbar,.companies-toolbar{display:flex;gap:.5rem;margin-bottom:1rem}.search-input{flex:1;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.82rem;font-family:var(--font-main);background:var(--white)}.search-input:focus{outline:none;border-color:var(--accent)}.btn-primary-sm{padding:.5rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.78rem;font-family:var(--font-main);cursor:pointer;white-space:nowrap;transition:filter .2s}.btn-primary-sm:hover{filter:brightness(1.1)}.clients-list,.companies-list{max-height:350px;overflow-y:auto}.empty-state{text-align:center;padding:2rem;color:var(--muted)}.empty-state p{margin-bottom:.5rem}.btn-link{color:var(--accent);background:none;border:none;cursor:pointer;font-size:.82rem}.client-item,.company-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:6px;cursor:pointer;transition:background .15s;margin-bottom:.25rem}.client-item:hover,.company-item:hover{background:var(--cream)}.client-info,.company-info{flex:1}.client-name,.company-name{display:block;font-size:.85rem;font-weight:500;color:var(--ink)}.client-email,.company-nif{display:block;font-size:.7rem;color:var(--muted);margin-top:.1rem}.client-actions,.company-actions{display:flex;gap:.25rem}.btn-icon{width:26px;height:26px;border-radius:4px;border:none;background:transparent;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.btn-icon:hover{background:var(--cream);color:var(--ink)}.btn-icon.danger:hover{background:#fee;color:#d32f2f}.company-item{position:relative}.company-item.active{background:var(--accent-light)}.company-logo-small{width:36px;height:36px;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--cream);flex-shrink:0}.company-logo-small img{width:100%;height:100%;object-fit:contain}.company-initial{font-size:.9rem;font-weight:600;color:var(--accent)}.active-badge{position:absolute;top:.5rem;right:.5rem;font-size:.55rem;background:var(--accent);color:#fff;padding:.15rem .4rem;border-radius:3px;text-transform:uppercase;letter-spacing:.05em}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field.full{grid-column:span 2}.form-field label{font-size:.7rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.form-field input,.form-field select{padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.82rem;font-family:var(--font-main);background:var(--white);color:var(--ink)}.form-field input:focus,.form-field select:focus{outline:none;border-color:var(--accent)}.form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.btn-secondary{padding:.5rem 1rem;background:var(--white);border:1px solid var(--border);border-radius:6px;font-size:.78rem;font-family:var(--font-main);cursor:pointer;color:var(--muted)}.btn-secondary:hover{border-color:var(--muted);color:var(--ink)}.logo-upload-section{margin-bottom:1rem}.logo-preview{position:relative;display:inline-block}.logo-preview img{max-width:120px;max-height:80px;border-radius:6px;border:1px solid var(--border)}.btn-remove-logo{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;border:none;background:#d32f2f;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.logo-upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;border:2px dashed var(--border);border-radius:8px;cursor:pointer;color:var(--muted);transition:all .2s}.logo-upload-area:hover{border-color:var(--accent);color:var(--accent)}.logo-upload-area span{font-size:.78rem}.logo-upload-area input{display:none}.settings-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 1.25rem}.settings-tab{display:flex;align-items:center;gap:.4rem;padding:.75rem 1rem;background:none;border:none;font-size:.82rem;font-family:var(--font-main);color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .2s}.settings-tab:hover{color:var(--ink)}.settings-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.settings-body{padding:1.5rem}.settings-section{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.section-info{margin-bottom:1.25rem}.section-info h4{font-size:.95rem;color:var(--ink);margin-bottom:.35rem}.section-desc{font-size:.78rem;color:var(--muted);line-height:1.5}.pattern-presets{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.pattern-preset{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.75rem;background:var(--white);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:all .2s;text-align:left}.pattern-preset:hover{border-color:var(--accent)}.pattern-preset.active{border-color:var(--accent);background:var(--accent-light)}.pattern-preset code{font-size:.82rem;color:var(--ink);font-family:monospace}.pattern-example{font-size:.7rem;color:var(--muted)}.counter-section{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--cream);border-radius:6px;margin-bottom:1rem}.counter-info{display:flex;align-items:center;gap:.75rem}.counter-label{font-size:.78rem;color:var(--muted)}.counter-value{font-size:1.1rem;font-weight:600;color:var(--ink);font-family:monospace}.btn-sm{padding:.35rem .75rem;font-size:.72rem}.preview-box{padding:.75rem;background:var(--cream);border-radius:6px;text-align:center}.preview-label{display:block;font-size:.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem}.preview-value{font-size:1.1rem;color:var(--ink);font-family:monospace}.inv-header-left{display:flex;flex-direction:column;gap:.15rem}.inv-logo-img{max-height:40px;max-width:120px;object-fit:contain}.inv-qr-section{margin-top:1rem;padding:.75rem;background:var(--cream);border-radius:6px;display:flex;justify-content:flex-end}.inv-qr-box{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--white);border-radius:6px}.qr-placeholder-small{color:var(--ink)}.inv-qr-info{display:flex;flex-direction:column}.qr-label{font-size:.6rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.qr-type{font-size:.75rem;font-weight:600;color:var(--accent)}@media (max-width: 768px){.modal-overlay{padding:1rem .5rem .5rem;align-items:flex-start}.modal-content{max-height:95vh;border-radius:8px}.modal-content.clients-modal,.modal-content.companies-modal{max-height:95vh}.modal-body{padding:1rem;overflow-y:auto}.clients-layout,.companies-layout{grid-template-columns:1fr;gap:1rem;height:auto;overflow:visible}.clients-list-section,.companies-list-section{border-right:none;border-bottom:1px solid var(--border);padding-right:0;padding-bottom:1rem;max-height:180px}.client-form-section,.company-form-section{padding-left:0;padding-right:0}.clients-toolbar,.companies-toolbar{flex-direction:column;gap:.5rem}.search-input{width:100%}.btn-primary-sm{width:100%;text-align:center;padding:.5rem}.form-grid{grid-template-columns:1fr;gap:.6rem}.form-field.full{grid-column:span 1}.form-actions{flex-direction:column;gap:.5rem}.form-actions button{width:100%}.settings-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:0 1rem}.settings-tab{white-space:nowrap;flex-shrink:0}.pattern-presets{grid-template-columns:1fr}}.input-readonly{background:var(--cream)!important;color:var(--muted)!important;cursor:not-allowed;border-style:dashed!important}.company-selected-hint{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--accent-light);border-radius:4px;font-size:.72rem;color:var(--accent);margin-top:.75rem}.company-selected-hint svg{flex-shrink:0}input[type=date]{color-scheme:light}[data-theme=dark] input[type=date]{color-scheme:dark}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1)}
