:root{--navy: #284868;--navy-deep: #1e3550;--navy-soft: #5c7896;--ink: #2a2a2a;--grey-700: #383838;--grey-500: #6b7280;--grey-400: #9aa3ae;--grey-300: #d5dae0;--grey-200: #e6e9ed;--grey-100: #f5f7f9;--bg: #ffffff;--app-bg: #eef1f4;--status-draft: #9aa3ae;--status-sent: #2563eb;--status-accepted: #047857;--status-declined: #b0413e;--status-expired: #6b7280}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{background:var(--app-bg);font-family:Inter,Helvetica Neue,Helvetica,Arial,sans-serif;color:var(--ink);-webkit-font-smoothing:antialiased;font-size:13px}#root{height:100%}.topbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:16px;padding:8px 22px;background:#fff;border-bottom:1px solid var(--grey-200);height:44px}.topbar .brand-mini{font-size:12px;font-weight:700;color:var(--navy);letter-spacing:.12em;text-transform:uppercase}.topbar .brand-mini .dot{margin:0 4px;color:var(--grey-400)}.app{display:grid;grid-template-columns:440px 1fr;height:calc(100vh - 44px);overflow:hidden}.app.full{grid-template-columns:1fr}.preview-pane{overflow-y:auto;height:calc(100vh - 44px);background:var(--app-bg);padding:24px}.doc-wrap{margin:0 auto;max-width:794px}.toast{position:fixed;bottom:22px;left:50%;transform:translate(-50%);background:var(--navy);color:#fff;padding:10px 18px;border-radius:4px;font-size:12px;font-weight:500;letter-spacing:.04em;box-shadow:0 4px 16px #2848684d;z-index:100;opacity:0;transition:opacity .2s ease;pointer-events:none}.toast.show{opacity:1}.empty-state{padding:48px 24px;text-align:center;color:var(--grey-500);font-size:13px}.flex-row{display:flex;align-items:center;gap:8px}.spacer{flex:1}@media (max-width: 960px){.app{grid-template-columns:1fr;height:auto;overflow:visible}.preview-pane{height:auto;padding:12px}}@page{size:A4 portrait;margin:12mm 10mm}@media print{body{background:#fff!important}.app{display:block!important;height:auto!important;overflow:visible!important}.panel,.panel-head,.nav,.toast{display:none!important}.preview-pane{overflow:visible!important;height:auto!important;padding:0!important;background:#fff!important}.doc-wrap{max-width:none!important}.doc{width:100%!important;min-height:0!important;box-shadow:none!important;padding:0!important;transform:none!important}.doc .header,.doc .reference,.doc .summary,.doc .terms,.doc .payment,.doc .prepared,.doc .footer,.doc table.quote,.doc table.quote tr{page-break-inside:avoid;break-inside:avoid}a{color:inherit;text-decoration:none}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}.panel{background:#fff;border-right:1px solid var(--grey-200);overflow-y:auto;height:calc(100vh - 44px);display:flex;flex-direction:column}.panel-inner{padding:22px 22px 60px;flex:1}.panel-head{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;border-bottom:1px solid var(--grey-200);position:sticky;top:0;background:#fff;z-index:5;gap:12px}.panel-head .title{font-size:13px;font-weight:700;color:var(--navy);letter-spacing:.12em;text-transform:uppercase}.panel-head .sub{font-size:10.5px;color:var(--grey-500);letter-spacing:.04em;margin-top:2px}.nav{display:flex;gap:4px}.nav-item{appearance:none;border:none;background:transparent;font-family:inherit;font-size:11px;font-weight:600;color:var(--grey-500);letter-spacing:.06em;text-transform:uppercase;padding:6px 10px;border-radius:3px;cursor:pointer;text-decoration:none;transition:all .12s ease}.nav-item:hover,.nav-item.active{color:var(--navy);background:var(--grey-100)}.toolbar{display:flex;gap:6px;flex-wrap:wrap}.btn{appearance:none;border:1px solid var(--grey-300);background:#fff;font-family:inherit;font-size:11px;font-weight:500;color:var(--grey-700);padding:7px 11px;border-radius:4px;cursor:pointer;letter-spacing:.02em;transition:all .12s ease;display:inline-flex;align-items:center;gap:6px;text-decoration:none}.btn:hover{border-color:var(--navy);color:var(--navy)}.btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}.btn.primary:hover{background:var(--navy-deep);border-color:var(--navy-deep);color:#fff}.btn.ghost{border-color:transparent;color:var(--grey-500)}.btn.ghost:hover{color:var(--navy);border-color:var(--grey-300)}.btn.danger:hover{color:#b0413e;border-color:#b0413e}.btn:disabled{opacity:.5;cursor:not-allowed}.section{margin-bottom:22px}.section-label{font-size:10px;font-weight:700;color:var(--navy);letter-spacing:.16em;text-transform:uppercase;padding-bottom:6px;border-bottom:1px solid var(--grey-200);margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}.field{margin-bottom:11px}.field label{display:block;font-size:10px;font-weight:600;color:var(--grey-500);letter-spacing:.1em;text-transform:uppercase;margin-bottom:4px}.field input,.field textarea,.field select{width:100%;appearance:none;font-family:inherit;font-size:12.5px;color:var(--ink);background:#fff;border:1px solid var(--grey-300);border-radius:4px;padding:7px 10px;transition:border-color .12s ease,box-shadow .12s ease}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #28486814}.field textarea{min-height:56px;resize:vertical}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.field-row.three{grid-template-columns:1fr 1fr 1fr}.helper{font-size:10.5px;color:var(--grey-500);margin-top:4px}.products{display:flex;flex-direction:column;gap:6px}.product-row{display:grid;grid-template-columns:22px 1fr 56px 70px 26px;gap:6px;align-items:center}.product-row input[type=text],.product-row input[type=number]{padding:6px 8px;font-size:12px}.product-row .autocomplete{width:100%;min-width:0}.product-row .autocomplete input[type=text]{width:100%}.product-row .stock-toggle{border:1px solid var(--grey-300);background:#fff;width:22px;height:22px;border-radius:3px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;color:var(--grey-400);font-size:11px}.product-row.oos .stock-toggle{background:#fbe9e7;border-color:#e5a39e;color:#b0413e}.product-row.oos input{color:var(--grey-400)}.product-row .remove-btn{border:none;background:transparent;color:var(--grey-400);cursor:pointer;font-size:16px;padding:0;line-height:1}.product-row .remove-btn:hover{color:#b0413e}.add-product{margin-top:8px;width:100%;border:1px dashed var(--grey-300);background:#fff;color:var(--grey-500);padding:8px;border-radius:4px;cursor:pointer;font-family:inherit;font-size:11.5px;letter-spacing:.04em}.add-product:hover{border-color:var(--navy);color:var(--navy)}.product-head{display:grid;grid-template-columns:22px 1fr 56px 70px 26px;gap:6px;font-size:9.5px;font-weight:700;color:var(--grey-500);letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid var(--grey-200)}.product-head .h-stock{text-align:center}.product-head .h-qty,.product-head .h-price{text-align:right}.autocomplete{position:relative}.ac-list{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--grey-300);border-top:none;max-height:160px;overflow-y:auto;z-index:20;border-radius:0 0 4px 4px;box-shadow:0 4px 12px #00000014}.ac-item{padding:7px 10px;font-size:12px;cursor:pointer;border-bottom:1px solid var(--grey-100)}.ac-item:hover,.ac-item.active{background:var(--grey-100);color:var(--navy)}.ac-item .ac-sub{font-size:10px;color:var(--grey-500);margin-top:1px}.drafts-list{display:flex;flex-direction:column;gap:8px}.draft-card{border:1px solid var(--grey-200);border-radius:6px;padding:12px 14px;background:#fff;cursor:pointer;transition:all .12s ease;display:flex;flex-direction:column;gap:6px}.draft-card:hover{border-color:var(--navy);box-shadow:0 2px 8px #28486814}.draft-card .row1{display:flex;justify-content:space-between;align-items:center;gap:8px}.draft-card .ref{font-size:12px;font-weight:700;color:var(--navy);font-variant-numeric:tabular-nums}.draft-card .client{font-size:12px;color:var(--ink);font-weight:500}.draft-card .row2{display:flex;justify-content:space-between;align-items:center;font-size:10.5px;color:var(--grey-500)}.draft-card .actions{display:flex;gap:4px;flex-shrink:0}.status-pill{display:inline-block;padding:2px 8px;border-radius:999px;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.status-pill.draft{background:#f3f4f6;color:var(--status-draft)}.status-pill.sent{background:#dbeafe;color:var(--status-sent)}.status-pill.accepted{background:#d1fae5;color:var(--status-accepted)}.status-pill.declined{background:#fee2e2;color:var(--status-declined)}.status-pill.expired{background:#f3f4f6;color:var(--status-expired)}.seg{display:flex;gap:0;border:1px solid var(--grey-300);border-radius:4px;overflow:hidden}.seg button{flex:1;appearance:none;background:#fff;border:none;font-family:inherit;font-size:10.5px;font-weight:600;color:var(--grey-500);letter-spacing:.08em;text-transform:uppercase;padding:7px 8px;cursor:pointer;border-right:1px solid var(--grey-300)}.seg button:last-child{border-right:none}.seg button.active{background:var(--navy);color:#fff}.toggle{display:inline-flex;align-items:center;gap:8px;cursor:pointer;user-select:none;font-size:12px}.toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--navy)}.logo-preview{display:flex;align-items:center;justify-content:center;padding:18px;background:var(--grey-100);border:1px dashed var(--grey-300);border-radius:6px;min-height:130px}.logo-preview img{max-width:200px;max-height:100px;height:auto;display:block}.logo-preview.dark{background:var(--navy)}.doc{width:794px;min-height:1123px;background:#fff;padding:52px 60px 44px;box-shadow:0 4px 24px #2848681a,0 1px #2848680a;display:flex;flex-direction:column;color:var(--ink);font-size:13px;line-height:1.45;transform-origin:top center}.doc .header{display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:20px;border-bottom:2px solid var(--navy);gap:24px}.doc .brand img{width:130px;height:auto;display:block}.doc .company-info{text-align:right;font-size:11.5px;color:var(--grey-700);line-height:1.65}.doc .company-info .co-name{font-size:13.5px;font-weight:700;color:var(--navy);margin-bottom:3px}.doc .company-info .co-tag{font-size:10px;font-weight:500;color:var(--navy-soft);letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px}.doc .company-info .info-grid{display:grid;grid-template-columns:max-content max-content;justify-content:end;column-gap:12px;row-gap:2px}.doc .company-info .lbl{color:var(--grey-500);font-size:10px;letter-spacing:.1em;text-transform:uppercase;text-align:right;align-self:baseline}.doc .company-info .val{color:var(--grey-700);font-weight:500;font-variant-numeric:tabular-nums;text-align:left;align-self:baseline}.doc .company-info .val a{color:var(--grey-700);text-decoration:none}.doc .title-block{margin:26px 0 20px;text-align:center}.doc .title-block h1{margin:0;font-size:18px;font-weight:700;letter-spacing:.18em;color:var(--navy);text-transform:uppercase}.doc .title-rule{width:56px;height:2px;background:var(--navy);margin:10px auto 0}.doc .reference{display:grid;grid-template-columns:1fr 1fr;column-gap:48px;row-gap:8px;padding:16px 20px;background:var(--grey-100);border-left:3px solid var(--navy);margin-bottom:22px;font-size:12px}.doc .ref-row{display:flex;align-items:baseline;gap:10px}.doc .ref-row .k{color:var(--grey-500);font-weight:500;letter-spacing:.06em;text-transform:uppercase;font-size:10.5px;min-width:110px}.doc .ref-row .v{color:var(--ink);font-weight:500;flex:1;border-bottom:1px dotted var(--grey-400);min-height:16px}.doc .ref-row .v.filled{border-bottom:none;color:var(--navy);font-weight:600}.doc table.quote{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:12px}.doc table.quote thead th{background:#fff;color:var(--navy);font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:10.5px;padding:9px 12px;text-align:left;border-top:1.5px solid var(--navy);border-bottom:1.5px solid var(--navy)}.doc table.quote tbody td{padding:8px 12px;border-bottom:1px solid var(--grey-200);color:var(--grey-700);vertical-align:middle}.doc table.quote tbody tr:last-child td{border-bottom:1px solid var(--grey-300)}.doc table.quote .col-no{width:42px;text-align:center}.doc table.quote .col-uom,.doc table.quote .col-qty{width:60px;text-align:center}.doc table.quote .col-price,.doc table.quote .col-total{width:130px;text-align:right}.doc table.quote tbody td.col-no{color:var(--grey-500);font-variant-numeric:tabular-nums}.doc table.quote tbody td.product{color:var(--ink);font-weight:500}.doc table.quote tbody td.col-price,.doc table.quote tbody td.col-total{font-variant-numeric:tabular-nums;letter-spacing:.04em}.doc table.quote tbody td.empty,.doc table.quote tbody tr.oos td{color:var(--grey-400)}.doc table.quote tbody tr.oos td.product{color:var(--grey-500);font-weight:500}.doc .oos-badge{display:inline-block;margin-left:8px;font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500);background:var(--grey-100);border:1px solid var(--grey-300);padding:2px 6px;border-radius:2px;vertical-align:1px}.doc .discount-tag{display:inline-block;margin-left:8px;font-size:9px;font-weight:700;letter-spacing:.06em;color:var(--navy);background:#e0e7ee;padding:2px 6px;border-radius:2px;vertical-align:1px}.doc .summary{display:flex;justify-content:flex-end;margin-bottom:24px}.doc .summary-box{width:340px;font-size:12px}.doc .summary-row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--grey-200)}.doc .summary-row .lbl{color:var(--grey-700);font-weight:500}.doc .summary-row .val{font-variant-numeric:tabular-nums;min-width:140px;text-align:right;letter-spacing:.04em;color:var(--ink)}.doc .summary-row .val.empty{color:var(--grey-400)}.doc .summary-row.discount .val{color:var(--navy)}.doc .summary-row.grand{border-top:1.5px solid var(--navy);border-bottom:1.5px solid var(--navy);margin-top:4px;padding:10px 0}.doc .summary-row.grand .lbl{color:var(--navy);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:11px}.doc .summary-row.grand .val{color:var(--navy);font-weight:700}.doc .terms{margin-bottom:22px}.doc .section-h{font-size:11px;font-weight:700;color:var(--navy);letter-spacing:.16em;text-transform:uppercase;padding-bottom:6px;border-bottom:1px solid var(--grey-300);margin-bottom:12px}.doc .terms-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px 40px;font-size:12px}.doc .term{display:flex;align-items:baseline;gap:10px}.doc .term:before{content:"";width:5px;height:5px;background:var(--navy);border-radius:50%;flex-shrink:0;transform:translateY(-2px)}.doc .term .t-label{color:var(--grey-700);font-weight:500;white-space:nowrap}.doc .term .t-fill{flex:1;min-height:14px;color:var(--ink);font-weight:500}.doc .term .t-fill.empty{border-bottom:1px dotted var(--grey-400);color:var(--grey-400)}.doc .payment{margin-bottom:22px}.doc .pay-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--grey-200)}.doc .pay-method{padding:12px 16px;display:flex;flex-direction:column;gap:6px}.doc .pay-method+.pay-method{border-left:1px solid var(--grey-200)}.doc .pay-method .pm-head{display:flex;align-items:center;gap:8px;margin-bottom:2px}.doc .pay-method .pm-badge{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--navy);padding:3px 7px;border-radius:2px}.doc .pay-method .pm-title{font-size:12px;font-weight:600;color:var(--navy);letter-spacing:.02em}.doc .pay-method .pm-row{display:flex;justify-content:space-between;align-items:baseline;font-size:11.5px;padding:2px 0}.doc .pay-method .pm-row .k{color:var(--grey-500);font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}.doc .pay-method .pm-row .v{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:.04em}.doc .pay-note{margin-top:8px;font-size:10.5px;color:var(--grey-500);line-height:1.5}.doc .prepared{display:grid;grid-template-columns:1fr 1fr;gap:14px 40px;padding:14px 18px;border:1px solid var(--grey-200);border-left:3px solid var(--navy);background:var(--grey-100);margin-bottom:22px;font-size:12px}.doc .prep-field{display:flex;flex-direction:column;gap:4px}.doc .prep-field .k{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500);font-weight:600}.doc .prep-field .v{min-height:18px;color:var(--ink);font-weight:500}.doc .prep-field .v.empty{border-bottom:1px dotted var(--grey-400);color:var(--grey-400)}.doc .footer{margin-top:auto;padding-top:22px;border-top:1px solid var(--grey-200);display:flex;justify-content:space-between;align-items:flex-end;gap:24px}.doc .closing{font-size:12px;color:var(--grey-700);max-width:360px;line-height:1.55}.doc .signoff{text-align:right;font-size:11.5px;flex-shrink:0}.doc .sig-line{width:220px;border-bottom:1px solid var(--grey-400);height:38px;margin-bottom:6px}.doc .sig-for{color:var(--navy);font-weight:600;letter-spacing:.04em}.doc .sig-role{color:var(--grey-500);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;margin-top:2px}.doc .status-stamp{position:absolute;top:80px;right:60px;transform:rotate(-12deg);border:3px solid;padding:6px 18px;font-size:22px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;opacity:.18;pointer-events:none}.doc .status-stamp.sent{color:var(--status-sent)}.doc .status-stamp.accepted{color:var(--status-accepted)}.doc .status-stamp.declined{color:var(--status-declined)}.doc .status-stamp.expired{color:var(--status-expired)}.doc{position:relative}.doc.exporting{box-shadow:none!important;transform:none!important;margin:0!important}.auth-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:24px;z-index:200;overflow:hidden;background:#0c1f33}.ocean-canvas{position:absolute;inset:0;z-index:0}.ocean-canvas canvas{display:block;width:100%!important;height:100%!important}.auth-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,#0c1f338c,#0c1f331a 35% 65%,#0c1f33a6);pointer-events:none}.auth-vignette{position:absolute;inset:0;z-index:1;background:radial-gradient(ellipse at center,transparent 0%,transparent 45%,rgba(8,22,38,.55) 100%);pointer-events:none}.auth-card{position:relative;z-index:2;width:100%;max-width:400px;padding:36px 32px 28px;border-radius:16px;text-align:center;background:#ffffff14;backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border:1px solid rgba(255,255,255,.18);box-shadow:0 24px 60px #00000073,inset 0 1px #ffffff2e;color:#fff}.auth-brand{display:flex;align-items:center;justify-content:center;background:#ffffffeb;border-radius:12px;padding:14px 16px;margin-bottom:20px;box-shadow:0 8px 24px #00000040}.auth-brand img{max-width:170px;max-height:78px;height:auto;display:block}.auth-title{font-size:17px;font-weight:700;color:#fff;letter-spacing:.06em}.auth-sub{font-size:11px;color:#ffffffa6;letter-spacing:.18em;text-transform:uppercase;margin-top:4px;margin-bottom:26px}.auth-form .field{text-align:left;margin-bottom:14px}.auth-form .field label{color:#ffffffb8;font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}.auth-form .field input{width:100%;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 12px;border-radius:8px;font-family:inherit;font-size:13px;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.auth-form .field input::placeholder{color:#ffffff61}.auth-form .field input:focus{outline:none;background:#ffffff29;border-color:#ffffff8c;box-shadow:0 0 0 3px #ffffff1a}.auth-error{font-size:12px;color:#ffd0cd;background:#b0413e38;border:1px solid rgba(255,175,170,.4);padding:8px 10px;border-radius:6px;margin-bottom:14px;text-align:left}.auth-submit{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;font-family:inherit;font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border-radius:8px;border:1px solid rgba(255,255,255,.35);color:#0c1f33;background:linear-gradient(180deg,#fff,#d8e6f1);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .15s ease;box-shadow:0 6px 18px #0000004d}.auth-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #00000059}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{margin-top:22px;font-size:10.5px;color:#ffffff8c;letter-spacing:.04em;line-height:1.5}.auth-tagline{position:absolute;bottom:22px;left:0;right:0;z-index:2;text-align:center;color:#ffffff59;font-size:10px;letter-spacing:.36em;text-transform:uppercase;pointer-events:none}
