:root{--container-max-width:1200px;--container-max-width-tablet:800px;--container-max-width-mobile:420px;--container-padding:24px;--border-radius:12px;--border-radius-large:24px;--font-size-base:16px;--font-size-large:1.1rem;--font-size-small:.9rem;--spacing-unit:8px;--logo-size:180px;--modal-max-width:500px}*{box-sizing:border-box}body{color:#222;min-height:100vh;font-family:SF Pro Display,Segoe UI,Roboto,Arial,sans-serif;font-size:var(--font-size-base);background:#f8f8fa;justify-content:center;align-items:center;margin:0;padding:0;line-height:1.5;display:flex}.welcome-container{width:100%;max-width:var(--container-max-width);border-radius:var(--border-radius);min-height:100vh;padding:calc(var(--spacing-unit) * 4) calc(var(--spacing-unit) * 3);box-sizing:border-box;background:#fff;flex-direction:column;justify-content:center;align-items:center;margin:0 auto;transition:box-shadow .3s;display:flex;box-shadow:0 4px 32px #00000014}.logo{width:var(--logo-size);width:var(--logo-size);max-width:80vw;height:auto;margin-bottom:calc(var(--spacing-unit) * 4);height:auto;margin-bottom:calc(var(--spacing-unit) * 4);filter:drop-shadow(0 2px 8px #0000000f)}.tagline{margin-bottom:calc(var(--spacing-unit) * 5);margin-bottom:calc(var(--spacing-unit) * 5);color:#444;letter-spacing:.02em;text-align:center;font-size:1.4rem;font-weight:400}.primary-btn{color:#222;font-size:var(--font-size-large);font-size:var(--font-size-large);padding:calc(var(--spacing-unit) * 2.25) calc(var(--spacing-unit) * 6);padding:calc(var(--spacing-unit) * 2.25) calc(var(--spacing-unit) * 6);cursor:pointer;background:linear-gradient(90deg,#e0e7ef 0%,#f3f4f6 100%);border:none;border-radius:32px;outline:none;justify-content:center;align-items:center;min-height:48px;font-weight:600;transition:background .2s,box-shadow .2s,transform .1s;display:flex;box-shadow:0 2px 12px #00000014}.primary-btn:hover,.primary-btn:focus{background:linear-gradient(90deg,#f3f4f6 0%,#e0e7ef 100%);transform:translateY(-2px)scale(1.03);box-shadow:0 4px 16px #0000001f}.room-selection-container{max-width:var(--container-max-width);width:100%;padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 3);border-radius:var(--border-radius);box-sizing:border-box;background:#fff;flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:100vh;margin:0 auto;display:flex;position:relative;box-shadow:0 4px 32px #00000014}.room-selection-container h2{margin:calc(var(--spacing-unit) * 1.25) 0 calc(var(--spacing-unit) * .25) 0;margin:calc(var(--spacing-unit) * 1.25) 0 calc(var(--spacing-unit) * .25) 0;text-align:center;width:100%;font-size:1.4rem;font-weight:600}.room-selection-container .subtitle{color:#888;margin-bottom:var(--spacing-unit);margin-bottom:var(--spacing-unit);text-align:center;width:100%;margin-top:0;font-size:1rem}.room-grid{gap:calc(var(--spacing-unit) * 1.25);gap:calc(var(--spacing-unit) * 1.25);width:100%;margin-bottom:calc(var(--spacing-unit) * 1.5);margin-bottom:calc(var(--spacing-unit) * 1.5);grid-template-columns:repeat(auto-fit,minmax(120px,1fr));display:grid}.room-btn{padding:calc(var(--spacing-unit) * 1.5) 0 calc(var(--spacing-unit) * 1) 0;padding:calc(var(--spacing-unit) * 1.5) 0 calc(var(--spacing-unit) * 1) 0;color:#222;cursor:pointer;aspect-ratio:1;aspect-ratio:1;background:#f8f8fa;border:none;border-radius:12px;outline:none;flex-direction:column;justify-content:center;align-items:center;min-height:70px;font-size:.98rem;font-weight:500;transition:background .2s,box-shadow .2s,transform .1s;display:flex;position:relative;box-shadow:0 1px 4px #00000008}.room-btn .room-icon{margin-bottom:calc(var(--spacing-unit) * .5);margin-bottom:calc(var(--spacing-unit) * .5);font-size:1.4rem}.add-room-btn{color:#444;padding:calc(var(--spacing-unit) * 2) 0;padding:calc(var(--spacing-unit) * 2) 0;width:100%;margin-top:var(--spacing-unit);margin-top:var(--spacing-unit);cursor:pointer;background:#f0f0f3;border:none;border-radius:18px;min-height:48px;font-size:1.1rem;font-weight:500;transition:background .2s,box-shadow .2s,transform .1s;box-shadow:0 2px 8px #0000000a}.add-room-btn:hover,.add-room-btn:focus{background:#eaeaea;transform:translateY(-1px)scale(1.01)}.back-btn{top:calc(var(--spacing-unit) * 2.25);left:calc(var(--spacing-unit) * 2.25);top:calc(var(--spacing-unit) * 2.25);left:calc(var(--spacing-unit) * 2.25);z-index:10;position:absolute}.back-btn:active,.back-btn:focus,.back-btn:hover{color:#174ea6;background:#e0e7ef}.scanner-container{max-width:var(--container-max-width);width:100%;max-width:var(--container-max-width);width:100%;padding:calc(var(--spacing-unit) * 3) calc(var(--spacing-unit) * 1) 0 calc(var(--spacing-unit) * 1);padding:calc(var(--spacing-unit) * 3) calc(var(--spacing-unit) * 1) 0 calc(var(--spacing-unit) * 1);border-radius:var(--border-radius);border-radius:var(--border-radius);box-sizing:border-box;background:#fff;flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:100vh;margin:0 auto;display:flex;position:relative;box-shadow:0 4px 32px #0000000a}.scanner-container .back-btn{top:calc(var(--spacing-unit) * 2.25);left:calc(var(--spacing-unit) * 2.25);z-index:10;top:calc(var(--spacing-unit) * 2.25);left:calc(var(--spacing-unit) * 2.25);z-index:10;position:absolute}.scanner-header{width:100%;margin-bottom:var(--spacing-unit);margin-bottom:var(--spacing-unit);justify-content:flex-start;align-items:center;display:flex}.room-badge{color:#2563eb;padding:calc(var(--spacing-unit) * .75) calc(var(--spacing-unit) * 2);margin-left:calc(var(--spacing-unit) * 1.5);font-weight:600;font-size:var(--font-size-small);padding:calc(var(--spacing-unit) * .75) calc(var(--spacing-unit) * 2);margin-left:calc(var(--spacing-unit) * 1.5);font-size:var(--font-size-small);background:#e0e7ef;border-radius:12px}.camera-preview{aspect-ratio:4/3;width:100%;max-width:340px;margin-bottom:calc(var(--spacing-unit) * 2.25);margin-bottom:calc(var(--spacing-unit) * 2.25);backface-visibility:hidden;perspective:1000px;background:#222;border-radius:18px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden;transform:translateZ(0);box-shadow:0 2px 12px #0000001a}#scanner-video{object-fit:contain;backface-visibility:hidden;border-radius:18px;width:100%;height:100%;transform:translateZ(0)}#scanner-viewport{backface-visibility:hidden;perspective:1000px;touch-action:manipulation;-webkit-user-select:none;user-select:none;transform:translateZ(0)}#scanner-viewport video{object-fit:cover;transform:translateZ(0);width:100%!important;height:100%!important}#scanner-viewport canvas{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}#scanner-overlay{pointer-events:none;position:absolute;inset:0}.scan-area{box-sizing:border-box;z-index:2;border:2px solid #2563eb;border-radius:12px;position:absolute;inset:20% 10%}.scan-line{z-index:3;background:linear-gradient(90deg,#2563eb 0%,#e0e7ef 100%);border-radius:1px;height:2px;animation:1.2s infinite alternate scan-move;position:absolute;top:40%;left:12%;right:12%}@keyframes scan-move{0%{top:30%}to{top:60%}}.manual-entry{width:100%;margin:calc(var(--spacing-unit) * 2.25) 0 var(--spacing-unit) 0;margin:calc(var(--spacing-unit) * 2.25) 0 var(--spacing-unit) 0;flex-direction:column;align-items:flex-start;display:flex}.manual-entry label{color:#666;margin-bottom:calc(var(--spacing-unit) * .5);margin-bottom:calc(var(--spacing-unit) * .5);font-size:.98rem}#manual-barcode{width:100%;padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);margin-bottom:var(--spacing-unit);margin-bottom:var(--spacing-unit);box-sizing:border-box;border:1px solid #e0e0e0;border-radius:10px;font-size:1.1rem}#manual-search-btn{color:#1a7f4e;padding:var(--spacing-unit) calc(var(--spacing-unit) * 2.25);padding:var(--spacing-unit) calc(var(--spacing-unit) * 2.25);cursor:pointer;background:#e6f7ec;border:none;border-radius:10px;align-self:flex-end;min-height:40px;font-size:1rem;font-weight:600;transition:background .2s}#manual-search-btn:hover,#manual-search-btn:focus{background:#d2f4e3}.scanner-actions{width:100%;margin-top:calc(var(--spacing-unit) * 1.5);margin-top:calc(var(--spacing-unit) * 1.5);justify-content:flex-end;display:flex}#scanner-feedback{width:100%;min-height:calc(var(--spacing-unit) * 3);min-height:calc(var(--spacing-unit) * 3);color:#1a7f4e;text-align:center;margin-top:var(--spacing-unit);margin-top:var(--spacing-unit);font-size:1.1rem}.product-details-container{max-width:var(--container-max-width);width:100%;padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 3);border-radius:var(--border-radius);box-sizing:border-box;background:#fff;flex-direction:column;justify-content:flex-start;align-items:center;min-height:100vh;margin:0 auto;display:flex;position:relative;box-shadow:0 4px 32px #00000014}.product-image-wrap{border-radius:18px;justify-content:center;align-items:center;width:200px;height:200px;margin:0 auto 8px;display:flex;box-shadow:none!important;background:0 0!important;margin:4px auto!important;padding:0!important}#product-image{object-fit:contain;background:#fff;border-radius:12px;width:100%;max-width:200px;height:auto;max-height:200px;margin:0 auto;display:block}#product-name{margin:var(--spacing-unit) 0 calc(var(--spacing-unit) * .5) 0;margin:var(--spacing-unit) 0 calc(var(--spacing-unit) * .5) 0;text-align:center;color:#222;width:100%;font-size:1.3rem;font-weight:600}.product-meta{color:#888;width:100%;margin-bottom:var(--spacing-unit);flex-direction:row;justify-content:space-between;gap:8px;font-size:1rem;display:flex}#product-price-inline{text-align:right;color:#1a7f4e;margin-bottom:var(--spacing-unit);font-weight:600}#product-code,#product-price-inline{color:#888;text-align:left;flex:1 1 0;font-size:1rem;font-weight:500}#product-price-inline{text-align:right;color:#1a7f4e;font-weight:600}.product-price{color:#1a7f4e;text-align:center;margin-bottom:8px;margin-bottom:var(--spacing-unit);font-size:1.08rem;font-weight:600}.product-description{color:#444;margin-bottom:calc(var(--spacing-unit) * 1.5);margin-bottom:calc(var(--spacing-unit) * 1.5);text-align:left;width:100%;font-size:1rem}.product-links{margin-bottom:calc(var(--spacing-unit) * 2);margin-bottom:calc(var(--spacing-unit) * 2);flex-flow:row;justify-content:space-between;gap:8px;width:100%;display:flex}.product-links a{text-align:center;color:#2563eb;text-align:center;width:auto;min-width:0;font-size:var(--font-size-small);font-size:var(--font-size-small);box-shadow:none;box-shadow:none;background:#f8f8fa;border:none;border-radius:10px;flex:1 1 0;justify-content:center;align-items:center;gap:4px;margin:0;padding:10px 0;font-weight:500;text-decoration:none;transition:background .2s,transform .1s;display:flex}.product-links a:hover{background:#e0e7ef;text-decoration:none;transform:translateY(-1px)}.product-details-row{width:100%;margin-bottom:calc(var(--spacing-unit) * 1.5);width:100%;margin-bottom:calc(var(--spacing-unit) * 1.5);flex-direction:row;justify-content:space-between;align-items:flex-end;gap:4px;display:flex}.room-select-field{flex-direction:column;flex:1 1 0;align-items:flex-start;min-width:0;display:flex}.quantity-field{flex-direction:column;flex:0 0 64px;align-items:flex-end;width:64px;display:flex}.room-select-field label,.room-select-field select{text-align:left;align-self:flex-start;margin-left:0}.quantity-field label,.quantity-field select{text-align:right;align-self:flex-end}.variant-select-row label{font-size:var(--font-size-small);color:#666;margin-bottom:calc(var(--spacing-unit) * .5);font-size:var(--font-size-small);margin-bottom:calc(var(--spacing-unit) * .5)}#room-select,#product-quantity{width:100%;padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);margin-bottom:calc(var(--spacing-unit) * 1.5);min-height:44px;padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);margin-bottom:calc(var(--spacing-unit) * 1.5);background:#fff;border:1px solid #e0e0e0;border-radius:10px;min-height:44px;font-size:1rem}#room-select:focus,#product-quantity:focus{border-color:#2563eb;outline:none}.annotation-field{width:100%;margin-bottom:calc(var(--spacing-unit) * 2);margin-bottom:calc(var(--spacing-unit) * 2)}.annotation-label-row{margin-bottom:calc(var(--spacing-unit) * .5);margin-bottom:calc(var(--spacing-unit) * .5);justify-content:space-between;align-items:center;display:flex}.annotation-char-count{font-size:var(--font-size-small);font-size:var(--font-size-small);color:#888}#add-to-room-btn{color:#222;cursor:pointer;width:100%;margin-top:calc(var(--spacing-unit) * 1.5);background:linear-gradient(90deg,#e0e7ef 0%,#f3f4f6 100%);border:none;border-radius:32px;outline:none;min-height:48px;padding:18px 48px;font-size:1.2rem;font-weight:600;transition:background .2s,box-shadow .2s,transform .1s;box-shadow:0 2px 12px #00000014}#add-to-room-btn:hover,#add-to-room-btn:focus{background:linear-gradient(90deg,#f3f4f6 0%,#e0e7ef 100%);transform:translateY(-2px)scale(1.03);box-shadow:0 4px 16px #0000001f}.product-search{width:100%;margin-bottom:calc(var(--spacing-unit) * 1.5);margin-bottom:calc(var(--spacing-unit) * 1.5);position:relative}.product-search label{font-size:var(--font-size-small);font-size:var(--font-size-small);color:#666;margin-bottom:calc(var(--spacing-unit) * .5);margin-bottom:calc(var(--spacing-unit) * .5);display:block}#product-search-input{width:100%;padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);background:#fff;border:1px solid #e0e0e0;border-radius:10px;min-height:44px;font-size:1rem}.search-dropdown{z-index:1000;z-index:1000;max-height:200px;margin-top:calc(var(--spacing-unit) * .5);margin-top:calc(var(--spacing-unit) * .5);background:#fff;border:1px solid #e0e0e0;border-radius:10px;display:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #0000001a}.search-dropdown.visible{display:block}.search-dropdown li{padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);cursor:pointer;border-bottom:1px solid #f0f0f0;font-size:1rem;transition:background .2s}.search-dropdown li:last-child{border-bottom:none}.search-dropdown li:hover,.search-dropdown li.active{background:#f8f8fa}#product-annotation{width:100%;padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);padding:calc(var(--spacing-unit) * 1.25) calc(var(--spacing-unit) * 1.5);resize:vertical;resize:vertical;background:#fff;border:1px solid #e0e0e0;border-radius:10px;min-height:80px;font-family:inherit;font-size:1rem}.top-bar{flex-direction:row;justify-content:center;align-items:center;width:100%;min-height:48px;margin-bottom:8px;display:flex;position:relative}.top-bar .back-btn{z-index:2;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;min-height:44px;font-size:2.2rem;display:flex;position:absolute;top:0;left:0}.top-bar .page-logo{opacity:.85;width:auto;height:22px;margin:0 auto;display:block;position:relative;left:0;right:0}.review-container{max-width:var(--container-max-width);width:100%;padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 3);border-radius:var(--border-radius);box-sizing:border-box;background:#fff;flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:100vh;margin:0 auto;display:flex;position:relative;box-shadow:0 4px 32px #00000014}.review-container h2{text-align:center;margin:12px 0 2px;font-size:1.4rem;font-weight:600}.review-container .subtitle{display:none}#review-list{width:100%;margin-bottom:12px}.review-room-group{margin-bottom:8px}.review-room-group+.review-room-group{border-top:1px solid #e0e0e0;margin-top:8px}.review-room-header{color:#2563eb;align-items:center;gap:6px;margin-top:8px;margin-bottom:2px;font-size:1.05rem;font-weight:600;display:flex}.review-product-card{background:#fff;border-radius:16px;flex-direction:row;align-items:flex-start;margin-bottom:4px;padding:20px 16px 16px;display:flex;position:relative;box-shadow:0 2px 12px #00000012}.review-product-thumb-wrap{flex-direction:column;justify-content:flex-start;align-items:flex-start;min-width:96px;display:flex;position:relative}.review-product-thumb{object-fit:cover;background:#fff;border-radius:12px;width:96px;height:96px;margin-bottom:10px}.review-qty-pill{box-shadow:none;background:0 0;border:1.5px solid #bbb;border-radius:999px;align-items:center;gap:2px;min-width:56px;min-height:28px;margin:16px 0 0;padding:0 8px;font-size:1.1rem;font-weight:500;display:flex;position:static}.review-product-info{flex-direction:column;align-items:flex-start;gap:2px;width:100%;margin-top:6px;margin-left:18px;display:flex}.review-product-title{color:#222;margin-bottom:2px;font-size:.98rem;font-weight:600}.review-product-meta{color:#888;flex-direction:row;justify-content:flex-start;align-items:flex-start;width:100%;margin-bottom:2px;font-size:.96rem;display:flex}.review-product-code{text-align:left;flex:1}.review-product-price{color:#222;text-align:right;min-width:70px;margin-left:8px;font-size:.96rem;font-weight:500}.review-product-notes{color:#444;margin-bottom:2px;font-size:.98rem}.review-actions{justify-content:space-between;gap:8px;width:100%;margin-top:48px;margin-bottom:18px;display:flex}.secondary-btn{color:#2563eb;cursor:pointer;background:#f3f4f6;border:none;border-radius:14px;width:48%;padding:10px 0;font-size:1rem;font-weight:500;transition:background .2s,box-shadow .2s,transform .1s;box-shadow:0 1px 4px #00000008}.secondary-btn:hover,.secondary-btn:focus{background:#e0e7ef;transform:translateY(-1px)scale(1.01)}.empty-state{color:#888;text-align:center;margin-top:18px;font-size:1rem}.review-product-description-full{display:none}.review-qty-pill{box-shadow:none;background:0 0;border:1.5px solid #bbb;border-radius:999px;align-items:center;gap:2px;min-width:48px;min-height:24px;margin:4px 0 0;padding:0 6px;font-size:.98rem;font-weight:500;display:flex;position:absolute;bottom:-10px;left:0}.review-qty-btn{color:#111;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.4rem;font-weight:700;transition:background .15s;display:flex}.review-qty-btn:active{background:#ededed}.review-qty-btn.delete{color:#111;font-size:1.6rem}.review-qty-btn svg{width:20px;height:20px;display:block}.review-qty-value{text-align:center;min-width:16px;font-size:1rem;font-weight:500}.clear-selection-btn{cursor:pointer;font-weight:600;transition:background .2s,box-shadow .2s,transform .1s;color:#b91c1c!important;width:auto!important;min-width:120px!important;box-shadow:none!important;background:#fff0f0!important;border:none!important;border-radius:32px!important;margin:32px auto 8px!important;padding:12px 32px!important;font-size:1.05rem!important;display:block!important}.clear-selection-btn:hover,.clear-selection-btn:focus{transform:translateY(-2px)scale(1.03);color:#a00!important;background:#ffe5e5!important}.logo,.page-logo{width:var(--logo-size);max-width:80vw;height:auto;margin-bottom:calc(var(--spacing-unit) * 4);filter:drop-shadow(0 2px 8px #0000000f);opacity:.85;align-self:center;display:block}@media (width<=600px){html,body{background:#f4f6f9;width:100vw;height:auto;min-height:100vh;margin:0;padding:0;scroll-padding-top:32px;overflow:hidden auto}.scanner-container{width:100vw;max-width:none;height:100vh;min-height:100vh;box-shadow:none;background:#f4f6f9;border-radius:0;flex-direction:column;align-items:center;padding:0 0 32px;display:flex}.scanner-header{box-sizing:border-box;background:#f4f6f9;width:100vw;padding:24px 18px 0}.camera-preview{background:#fff;border-radius:18px;justify-content:center;align-items:center;width:94vw;max-width:none;height:60vw;min-height:240px;max-height:60vh;margin:24px 0 18px;padding:0;display:flex;position:relative;box-shadow:0 4px 24px #0000001a}#scanner-viewport{object-fit:contain;background:#222;min-height:240px;max-height:60vh;display:block;backface-visibility:hidden!important;perspective:1000px!important;border-radius:18px!important;width:100%!important;height:100%!important;transform:translateZ(0)!important}#scanner-overlay{pointer-events:none;border-radius:18px}.product-search,.scanner-actions,#scanner-feedback{padding-left:18px;padding-right:18px}.product-search,.scanner-actions{margin-top:18px}#scanner-feedback{margin-top:12px}.product-details-container{width:100vw;max-width:none;height:100vh;min-height:100vh;box-shadow:none;background:#fff;border-radius:0;flex-direction:column;align-items:stretch;padding:0 0 24px;display:flex}.product-image-wrap{width:140px;height:140px;margin-bottom:6px}#product-image{max-width:140px;max-height:140px}.annotation-field,.room-select-field,.quantity-field,.product-links{width:92vw;max-width:420px;margin-left:auto;margin-right:auto}.room-selection-container{width:100vw;max-width:none;height:100vh;min-height:100vh;box-shadow:none;background:#fff;border-radius:0;flex-direction:column;align-items:center;padding:0 0 32px;display:flex}.room-grid,.add-room-btn{width:94vw;margin-left:auto;margin-right:auto}.room-selection-container h2,.room-selection-container .subtitle{text-align:center;padding-left:18px;padding-right:18px}.review-container{width:100vw;max-width:none;min-height:unset;height:auto;box-shadow:none;background:#f4f6f9;border-radius:0;flex-direction:column;align-items:center;margin-top:0;padding:0 8px 24px;display:flex;overflow:hidden visible}.review-actions{justify-content:space-between;gap:8px;width:100%;margin-top:24px;margin-bottom:12px;padding:0 12px;display:flex}.secondary-btn{border-radius:10px;width:48%;min-width:0;max-width:100%;padding:10px 0;font-size:1rem;box-shadow:0 1px 4px #00000008}.back-btn{width:auto;min-width:0;height:auto;min-height:0;margin-top:8px;margin-bottom:8px;padding:0 0 0 2px;font-size:1.2rem}.review-container h2{margin-top:12px}}.modal{z-index:1000;background:#00000052;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{border-radius:var(--border-radius);padding:calc(var(--spacing-unit) * 3);max-width:var(--modal-max-width);background:#fff;width:90%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 48px #0000001f}.page-logo{opacity:.85;align-self:center;width:48px;height:auto;margin:24px auto 12px;display:block}.product-details-container,.review-container,.scanner-container,.room-selection-container{justify-content:flex-start!important;align-items:flex-start!important}@media (width>=1200px){:root{--container-max-width:1400px;--container-max-width-tablet:1000px;--logo-size:200px;--modal-max-width:600px}.welcome-container{padding:calc(var(--spacing-unit) * 6) calc(var(--spacing-unit) * 4)}.room-selection-container,.product-details-container,.review-container,.product-lookup-container{padding:calc(var(--spacing-unit) * 4) calc(var(--spacing-unit) * 6)}.room-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media (width>=768px) and (width<=1199px){:root{--container-max-width:var(--container-max-width-tablet);--logo-size:160px;--modal-max-width:500px}.welcome-container{padding:calc(var(--spacing-unit) * 4) calc(var(--spacing-unit) * 3)}.room-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.camera-preview{max-width:400px}.product-image-wrap{width:180px;height:180px}#product-image{max-width:180px;max-height:180px}}@media (width>=481px) and (width<=767px){:root{--container-max-width:var(--container-max-width-mobile);--logo-size:140px}.welcome-container{padding:calc(var(--spacing-unit) * 3) calc(var(--spacing-unit) * 2)}.room-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}@media (width<=480px){:root{--container-max-width:var(--container-max-width-mobile);--logo-size:120px}body{padding:calc(var(--spacing-unit) * 1)}.welcome-container{padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 1.5);min-height:calc(100vh - 16px)}.room-selection-container,.product-details-container,.review-container,.product-lookup-container{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 1);min-height:calc(100vh - 16px)}.room-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.room-btn{min-height:80px;font-size:.9rem}.room-btn .room-icon{font-size:1.2rem}.camera-preview{aspect-ratio:4/3;border-radius:12px;max-width:100%}.product-image-wrap{width:140px;height:140px;margin-bottom:6px}#product-image{max-width:140px;max-height:140px}.product-details-row{gap:calc(var(--spacing-unit) * 1);flex-flow:row}.room-select-field,.quantity-field{max-width:50%}.product-links{gap:calc(var(--spacing-unit) * 1);flex-direction:row}.product-links a{width:auto;min-width:60px;font-size:var(--font-size-small)}.back-btn{top:calc(var(--spacing-unit) * 1.5);left:calc(var(--spacing-unit) * 1.5);width:40px;min-width:40px;height:40px;min-height:40px;font-size:1.8rem}.primary-btn,.secondary-btn{padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 4);font-size:var(--font-size-large);min-height:44px}.scanner-actions,.review-actions{gap:calc(var(--spacing-unit) * 1);flex-direction:column}.review-product-card{gap:calc(var(--spacing-unit) * 1.5);flex-direction:column}.review-product-thumb-wrap{align-self:center}.review-product-info{text-align:center;margin-left:0}}@media (width<=320px){:root{--spacing-unit:5px;--logo-size:150px}.welcome-container{padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 1)}.room-selection-container,.scanner-container,.product-details-container,.review-container{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 1)}.room-grid{grid-template-columns:repeat(2,1fr)}.room-btn{min-height:60px;font-size:.85rem}.primary-btn,.secondary-btn{padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 3);font-size:1rem}}@media (orientation:landscape) and (height<=600px){.welcome-container{min-height:100vh;padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 3)}.room-selection-container,.scanner-container,.product-details-container,.review-container{min-height:100vh;padding:calc(var(--spacing-unit) * 1.5) calc(var(--spacing-unit) * 2)}.logo,.tagline{margin-bottom:calc(var(--spacing-unit) * 2)}.camera-preview{aspect-ratio:16/9;max-height:40vh}}@media (-webkit-device-pixel-ratio>=2),(resolution>=192dpi){.logo,#product-image{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.scan-line{animation:none}}@media (prefers-contrast:high){:root{--border-radius:0}.primary-btn,.secondary-btn,.room-btn{border:2px solid #000}.product-links a{border:1px solid #000}}@media print{.back-btn,.scanner-actions,.review-actions,.product-search{display:none!important}.welcome-container,.room-selection-container,.scanner-container,.product-details-container,.review-container{box-shadow:none;border-radius:0;width:100%;max-width:none}}.row-actions-responsive{flex-direction:row;justify-content:space-between;align-items:center;gap:12px;width:100%;margin:0 0 8px;display:flex}.small-btn{letter-spacing:.01em;border-radius:10px;min-width:90px;min-height:38px;padding:10px 22px;font-size:1rem;font-weight:600;box-shadow:0 2px 8px #00000012}.left-btn{margin-right:auto}.right-btn{margin-left:auto}.secondary-btn.small-btn{color:#2563eb;background:#fff;border:2px solid #2563eb;transition:background .2s,color .2s}.secondary-btn.small-btn:hover,.secondary-btn.small-btn:focus{color:#fff;background:#2563eb}.primary-btn.small-btn{color:#fff;background:#2563eb;border:2px solid #2563eb;transition:background .2s,color .2s}.primary-btn.small-btn:hover,.primary-btn.small-btn:focus{color:#fff;background:#174ea6}@media (width<=600px){.row-actions-responsive{flex-direction:row;gap:8px;margin:0 0 6px}.small-btn{border-radius:8px;min-width:70px;min-height:34px;padding:8px 10px;font-size:.98rem}}.cancel-btn{color:#2563eb;min-width:70px;box-shadow:none;text-align:left;background:#fff;border:none;border-radius:8px;margin-right:auto;padding:8px 0;font-size:.98rem}.send-btn{color:#fff;text-align:center;background:#2563eb;border:none;border-radius:10px;min-width:120px;margin-left:auto;padding:10px 0;font-size:1.08rem;font-weight:600;box-shadow:0 2px 8px #00000012}@media (width<=600px){.cancel-btn{min-width:54px;padding:7px 0;font-size:.95rem}.send-btn{min-width:90px;padding:8px 0;font-size:1rem}}.product-lookup-container{max-width:var(--container-max-width);width:100%;padding:calc(var(--spacing-unit) * 3) calc(var(--spacing-unit) * 4);border-radius:var(--border-radius);box-sizing:border-box;background:#fff;flex-direction:column;min-height:100vh;margin:0 auto;display:flex;box-shadow:0 4px 32px #00000014}.lookup-header-section{width:100%;margin-bottom:calc(var(--spacing-unit) * 4);padding-bottom:calc(var(--spacing-unit) * 3);border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;display:flex}.lookup-header-section .back-btn{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:12px;justify-content:center;align-items:center;width:48px;min-width:48px;height:48px;min-height:48px;font-size:1.8rem;transition:all .2s;display:flex}.lookup-header-section .back-btn:hover{background:#e5e7eb;transform:translateY(-1px)}.header-content{text-align:center;flex-direction:column;flex:1;align-items:center;display:flex}.header-content .page-logo{width:120px;height:auto;margin-bottom:calc(var(--spacing-unit) * 2);filter:drop-shadow(0 2px 8px #0000000f)}.page-title{color:#1f2937;margin:0 0 calc(var(--spacing-unit) * 1) 0;letter-spacing:-.025em;font-size:2.2rem;font-weight:600}.page-subtitle{color:#6b7280;margin:0;font-size:1.1rem;font-weight:400}.header-actions{align-items:center;gap:calc(var(--spacing-unit) * 2);flex-shrink:0;justify-content:flex-end;display:flex}.search-section{width:100%;margin-bottom:calc(var(--spacing-unit) * 4)}.search-actions{margin-top:calc(var(--spacing-unit) * 3);justify-content:center;display:flex}.search-input-container{max-width:600px;margin:0 auto;position:relative}.search-input-container input{width:100%;padding:calc(var(--spacing-unit) * 2.5) calc(var(--spacing-unit) * 6) calc(var(--spacing-unit) * 2.5) calc(var(--spacing-unit) * 3);border-radius:calc(var(--border-radius) * 2);background:#f9fafb;border:2px solid #e5e7eb;font-size:1.1rem;transition:all .2s;box-shadow:0 1px 3px #0000001a}.search-input-container input:focus{background:#fff;border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a,0 1px 3px #0000001a}#product-search-dropdown{margin:calc(var(--spacing-unit) * 1) 0 0 0;border-radius:calc(var(--border-radius) * 1.5);z-index:100;background:#fff;border:2px solid #e5e7eb;max-height:320px;padding:0;list-style:none;position:relative;overflow-y:auto;box-shadow:0 4px 16px #0000001a}#product-search-dropdown li{padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 3);cursor:pointer;border-bottom:1px solid #f3f4f6;transition:background .15s}#product-search-dropdown li:last-child{border-bottom:none}#product-search-dropdown li:hover,#product-search-dropdown li.active{color:#1e40af;background:#f0f9ff}.room-badge{color:#2563eb;padding:calc(var(--spacing-unit) * 1) calc(var(--spacing-unit) * 2);border-radius:calc(var(--border-radius) * .75);background:#eff6ff;border:1px solid #bfdbfe;font-size:1rem;font-weight:600}#lookup-feedback{margin-top:calc(var(--spacing-unit) * 2);color:#dc2626;text-align:center;font-size:1rem;display:none}#lookup-feedback:not(:empty){min-height:24px;display:block}@media (width<=1000px){.product-lookup-container{padding:calc(var(--spacing-unit) * 2) calc(var(--spacing-unit) * 3)}.page-title{font-size:1.8rem}.page-subtitle{font-size:1rem}}@media (width<=768px){.lookup-header-section{gap:calc(var(--spacing-unit) * 2);flex-direction:column;align-items:center}.lookup-header-section .back-btn{align-self:flex-start;width:44px;min-width:44px;height:44px;min-height:44px;font-size:1.6rem}.header-actions{justify-content:center;width:auto}.search-input-container{max-width:100%}.page-title{font-size:1.6rem}}.split-container{background:#f8f8fa;width:100%;max-width:100vw;min-height:100vh;display:flex;overflow:hidden}.left-panel{background:#fff;border-right:1px solid #e0e0e0;flex-direction:column;width:60%;display:flex;overflow:hidden}.right-panel{background:#fff;flex-direction:column;width:40%;display:flex;overflow:hidden}.panel-header{background:#fafbfc;border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;min-height:80px;padding:16px 20px;display:flex}.panel-header .header-content{flex-direction:column;flex:1;align-items:center;display:flex}.panel-header .header-content h2{color:#1f2937;margin:0 0 4px;font-size:1.3rem;font-weight:600}.panel-header .subtitle{color:#6b7280;margin:0;font-size:.9rem}.panel-logo{width:auto;height:32px;margin-bottom:8px}.selection-summary{color:#374151;margin-top:4px;font-size:.85rem}.header-actions{align-items:center;gap:8px;display:flex}.header-actions .primary-btn,.header-actions .secondary-btn{border-radius:8px;min-height:auto;padding:8px 16px;font-size:.9rem}.review-table-container{flex-direction:column;flex:1;display:flex;overflow:hidden}.review-table-container .empty-state{text-align:center;color:#6b7280;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.review-table-container .empty-state p{margin:0 0 8px;font-size:1rem}.review-table-container .empty-state .subtitle{color:#9ca3af;font-size:.9rem}.review-table{flex-direction:column;flex:1;display:flex;overflow:hidden}.table-header{color:#374151;text-transform:uppercase;letter-spacing:.025em;background:#f9fafb;border-bottom:1px solid #e5e7eb;grid-template-columns:60px 4fr 1.5fr 80px 80px 100px 30px;gap:12px;padding:12px 16px;font-size:.85rem;font-weight:600;display:grid}.table-body{flex:1;overflow-y:auto}.table-row{border-bottom:1px solid #f3f4f6;grid-template-columns:60px 4fr 1.5fr 80px 80px 100px 30px;align-items:center;gap:12px;padding:12px 16px;transition:background-color .2s;display:grid}.table-row:hover{background:#f9fafb}.table-row .product-info{flex-direction:column;gap:2px;display:flex}.table-row .product-name{color:#1f2937;font-size:.9rem;font-weight:500;line-height:1.3}.table-row .product-code{color:#6b7280;font-size:.8rem}.table-row input,.table-row select{background:#fff;border:1px solid #d1d5db;border-radius:4px;width:100%;padding:6px 8px;font-size:.85rem}.table-row input:focus,.table-row select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f61a}.table-row .quantity-input{text-align:center}.table-row .price-display{color:#059669;font-size:.9rem;font-weight:500}.table-row .remove-btn{color:#dc2626;cursor:pointer;background:#fee2e2;border:none;border-radius:4px;padding:2px 4px;font-size:.8rem;transition:background-color .2s}.table-row .remove-btn:hover{background:#fecaca}.table-product-image{object-fit:contain;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;width:50px;height:50px}.search-section{flex-direction:column;flex:1;padding:16px 20px;display:flex;overflow:auto}.search-section .search-input-container{margin-bottom:16px;position:relative}.search-section .search-input-container input{background:#fff;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:12px 16px 12px 44px;font-size:1rem}.search-section .search-input-container input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.search-results{margin-bottom:16px}.loading-state,.no-results{text-align:center;color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;height:240px;padding:40px 20px;display:flex}.results-list{background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-height:240px;overflow-y:auto}.result-item{cursor:pointer;color:#1f2937;background:#fff;border-bottom:1px solid #f3f4f6;align-items:center;min-height:48px;padding:12px 16px;font-size:.9rem;line-height:1.4;transition:background-color .2s;display:flex}.result-item:last-child{border-bottom:none}.result-item:hover{background:#f9fafb}.result-item .result-code{color:#2563eb;font-weight:600}.product-details{background:#f9fafb;border-top:1px solid #e5e7eb;max-height:50%;padding:20px;overflow-y:auto}.product-header{gap:16px;margin-bottom:20px;display:flex;position:relative}.close-btn{cursor:pointer;color:#6b7280;background:#e5e7eb;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.2rem;transition:background-color .2s;display:flex;position:absolute;top:-8px;right:-8px}.close-btn:hover{background:#d1d5db}.product-image-container{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.product-details .product-image{object-fit:contain;border-radius:6px;max-width:100%;max-height:100%}.product-details .product-info{flex:1}.product-details .product-name{color:#1f2937;margin:0 0 4px;font-size:1.1rem;font-weight:600;line-height:1.3}.product-details .product-code{color:#6b7280;margin:0 0 4px;font-size:.9rem}.product-details .product-price{color:#059669;margin:0;font-size:1rem;font-weight:600}.product-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;font-size:.9rem;font-weight:500}.room-select,.quantity-input,.notes-input{border:1px solid #d1d5db;border-radius:6px;padding:8px 12px;font-size:.95rem}.room-select:focus,.quantity-input:focus,.notes-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f61a}.notes-input{resize:vertical;min-height:60px}.form-actions{margin-top:8px}.form-actions .primary-btn{border-radius:6px;width:100%;min-height:auto;padding:10px 16px;font-size:.95rem}@media (width<=768px){body{justify-content:stretch;align-items:stretch}.split-container{flex-direction:column}.left-panel,.right-panel{width:100%}.left-panel{border-bottom:1px solid #e0e0e0;border-right:none;min-height:40vh}.right-panel{min-height:60vh}.panel-header{min-height:60px;padding:12px 16px}.panel-header .header-content h2{font-size:1.1rem}.table-header{grid-template-columns:40px 2fr 1fr 60px 60px;gap:8px;padding:8px 12px;font-size:.75rem}.table-row{grid-template-columns:40px 2fr 1fr 60px 60px;gap:8px;padding:8px 12px}.col-price-ea,.col-total,.col-actions{display:none}.table-product-image{width:35px;height:35px}.product-details{padding:16px}.product-header{flex-direction:column;gap:12px}.product-image-container{align-self:center}}.grid-container{background:#fafbfc;flex-direction:column;width:100%;min-height:100vh;display:flex}.grid-header{z-index:100;background:#fff;border-bottom:1px solid #e5e7eb;position:sticky;top:0;box-shadow:0 1px 3px #0000001a}.header-top{justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.header-left{align-items:center;gap:12px;display:flex}.header-center{flex:1;justify-content:center;display:flex}.header-right{align-items:center;gap:8px;display:flex}.header-bottom{padding:0 24px 12px}.grid-header .back-btn{cursor:pointer;background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;justify-content:center;align-items:center;width:44px;min-width:44px;height:44px;min-height:44px;font-size:1.8rem;transition:all .2s;display:flex}.grid-header .back-btn:hover{background:#e5e7eb;border-color:#9ca3af}.grid-header .panel-logo{width:auto;height:32px}.grid-header h2{color:#1f2937;margin:0;font-size:1.5rem;font-weight:600}.grid-header .selection-summary{color:#6b7280;font-size:.875rem}.version-display{letter-spacing:.5px;background:#f5f5f5;border-radius:4px;margin-top:12px;margin-right:0;padding:2px 8px;font-size:1rem;font-weight:500;display:inline-block;color:#222!important}.btn-import-quote{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.btn-import-quote:hover{background:#2563eb}.btn-clear-all{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.btn-clear-all:hover{background:#dc2626}.btn-settings{color:#fff;cursor:pointer;background:#6b7280;border:none;border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.btn-settings:hover{background:#4b5563}.btn-create{color:#fff;cursor:pointer;background:#10b981;border:none;border-radius:6px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .15s}.btn-create:hover{background:#059669}.sort-controls{align-items:center;gap:8px;margin-right:16px;display:flex}.sort-select{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:6px 8px;font-size:.875rem;transition:all .15s}.grid-content{flex:1;min-height:calc(100vh - 120px);padding:24px;overflow:visible}.empty-state{text-align:center;color:#6b7280;padding:60px 20px}.empty-state p{margin:0 0 8px;font-size:1.125rem}.empty-state .subtitle{color:#9ca3af;font-size:.875rem}.grid-table{table-layout:fixed;width:100%;display:table;overflow:visible!important}.grid-table.has-open-dropdown{table-layout:auto!important;overflow:visible!important}.grid-header-row{background:#f9fafb;border-bottom:2px solid #e5e7eb;display:table-row}.grid-header-row>div{color:#374151;text-transform:uppercase;letter-spacing:.05em;border-right:1px solid #e5e7eb;padding:12px;font-size:.8rem;font-weight:600;display:table-cell}.col-image{width:7%}.col-ref{width:5%}.col-product{width:29%}.col-room{width:11%}.col-qty{width:4%}.col-price,.col-total{width:6%}.col-notes{width:24%}.col-actions{width:8%}.col-ref .grid-input{text-transform:uppercase;letter-spacing:.02em;color:#1e40af;text-align:center;width:100%;padding:3px 5px;font-family:SF Mono,Monaco,Menlo,monospace;font-size:.75rem;font-weight:600}.grid-body{display:table-row-group}.grid-row{height:auto;transition:background-color .15s;display:table-row}.grid-row>div{vertical-align:middle;border-bottom:1px solid #f3f4f6;border-right:1px solid #e5e7eb;height:auto;padding:4px 6px;font-size:.85rem;display:table-cell;position:relative;overflow:visible}.grid-search-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;width:100%;padding:3px 6px;font-size:.8rem;transition:all .15s}.grid-search-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.grid-search-input.populated{background:#f0f9ff;border-color:#3b82f6}.grid-search-dropdown{z-index:2000;background:#fff;border:1px solid #d1d5db;border-radius:6px;max-height:300px;margin-top:2px;display:none;overflow-y:auto;box-shadow:0 8px 25px -5px #00000026;width:500px!important;min-width:500px!important;max-width:none!important;position:absolute!important;top:100%!important;left:0!important;overflow-x:visible!important}.grid-search-dropdown.visible{display:block}.grid-search-dropdown li{cursor:pointer;border-bottom:1px solid #f3f4f6;min-width:450px;padding:10px 14px;font-size:.875rem;line-height:1.4;white-space:nowrap!important;word-wrap:normal!important;text-overflow:clip!important;overflow:visible!important}.grid-search-dropdown li:last-child{border-bottom:none}.grid-search-dropdown li:hover,.grid-search-dropdown li.active{color:#1e40af;background:#f0f9ff}.col-price .grid-search-dropdown,.col-notes .grid-search-dropdown,.col-actions .grid-search-dropdown{width:500px!important;left:auto!important;right:0!important}.grid-table-container .grid-search-dropdown{z-index:9999!important;width:500px!important;max-width:none!important;position:absolute!important;overflow-x:visible!important}.grid-image-cell{text-align:center;vertical-align:middle;padding:2px 4px!important}.grid-product-image{object-fit:contain;border:1px solid #e5e7eb;border-radius:4px;width:auto;max-width:100%;height:100%;max-height:60px;margin:0 auto;display:block}.grid-product-cell{position:relative;padding:2px 6px!important}.grid-product-cell.has-product .grid-product-display{padding:2px;display:block}.grid-product-cell.empty-product .grid-search-input{display:block}.grid-product-name{color:#1f2937;font-size:.8rem;font-weight:400;line-height:1.2}.grid-product-name strong{color:#374151;margin-right:6px;font-weight:600}.grid-select,.grid-input,.grid-textarea{background:#fff;border:1px solid #d1d5db;border-radius:4px;width:100%;padding:2px 4px;font-size:.8rem;transition:all .15s}.grid-select:focus,.grid-input:focus,.grid-textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f61a}.grid-textarea{resize:vertical;min-height:16px;max-height:40px}.grid-input[type=number]{text-align:center}.grid-total-display{color:#1f2937;text-align:right;background-color:#f9fafb;border-radius:4px;padding:4px 8px;font-size:.85rem;font-weight:600}.grid-actions-cell{text-align:center;padding:2px 4px!important}.grid-actions-group{justify-content:center;align-items:center;gap:4px;display:flex}.grid-move-btn{color:#374151;cursor:pointer;background:#e5e7eb;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;line-height:1;transition:all .15s;display:flex}.grid-move-btn:hover{background:#d1d5db;transform:scale(1.1)}.grid-move-btn:disabled{opacity:.5;cursor:not-allowed}.grid-drag-handle{color:#6b7280;cursor:grab;-webkit-user-select:none;user-select:none;background:#f3f4f6;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;line-height:1;transition:all .15s;display:flex}.grid-drag-handle:hover{color:#374151;background:#e5e7eb}.grid-remove-btn{color:#dc2626;cursor:pointer;background:#fee2e2;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;line-height:1;transition:all .15s;display:flex}.grid-remove-btn:hover{background:#fecaca;transform:scale(1.1)}.grid-footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:16px 24px}.add-row-btn{color:#1d4ed8;cursor:pointer;background:#f0f9ff;border:1px dashed #3b82f6;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.add-row-btn:hover{background:#dbeafe;border-color:#1d4ed8}.room-group{border-radius:8px;margin-bottom:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.room-group-header{color:#fff;z-index:10;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%);border-bottom:none;justify-content:space-between;align-items:center;padding:12px 20px;font-size:.95rem;font-weight:600;display:flex;position:sticky;top:0}.room-group-header .room-name{align-items:center;gap:8px;display:flex}.room-group-header .room-icon{font-size:1.1rem}.room-group-header .room-count{color:#fff;background:#fff3;border-radius:12px;padding:2px 8px;font-size:.8rem;font-weight:500}.room-group-header.blank-room{background:linear-gradient(135deg,#6b7280 0%,#4b5563 100%)}.room-group-header.bath-room{background:linear-gradient(135deg,#0ea5e9 0%,#0284c7 100%)}.room-group-header.kitchen-room{background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%)}.room-group-header.laundry-room{background:linear-gradient(135deg,#10b981 0%,#059669 100%)}.room-header-row{font-weight:600;color:#fff!important;background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%)!important;border-bottom:2px solid #1e40af!important}.room-header-row:hover,.room-header-row:nth-child(2n){background:linear-gradient(135deg,#3b82f6 0%,#1d4ed8 100%)!important}.room-header-row .room-header-cell{border-right:none!important;padding:10px 12px!important}.room-header-content{color:#fff;align-items:center;gap:8px;font-weight:600;display:flex}.room-header-content .room-icon{font-size:1.1rem}.room-header-content .room-count{color:#fff;background:#fff3;border-radius:12px;margin-left:auto;padding:2px 8px;font-size:.8rem;font-weight:500}.grid-row.dragging{opacity:.5}.grid-row.drag-over{border-top:2px solid #3b82f6;background:#dbeafe!important}@media (width<=1200px){.col-image{width:7%}.col-ref{width:5%}.col-product{width:27%}.col-notes{width:22%}}@media (width<=900px){.grid-header{padding:12px 16px}.grid-header .header-content{margin:0 16px}.grid-header h2{font-size:1.25rem}.grid-content{padding:16px}.col-image{width:7%}.col-ref{width:6%}.col-product{width:29%}.col-notes{width:20%}.grid-header-row>div,.grid-row>div{padding:4px 6px;font-size:.8rem}.grid-search-input,.grid-select,.grid-input,.grid-textarea{padding:2px 4px;font-size:.8rem}.grid-product-image{width:auto;max-width:100%;height:100%;max-height:60px}}@media (width<=768px){.header-top{flex-direction:column;gap:12px;padding:12px 16px}.header-left,.header-center{justify-content:center}.header-right{flex-wrap:wrap;justify-content:center;gap:6px}.header-bottom{text-align:center;padding:0 16px 8px}.btn-import-quote,.btn-clear-all,.btn-settings,.btn-create{padding:6px 12px;font-size:.8rem}.grid-header h2{font-size:1.25rem}.grid-header .panel-logo{height:28px}.col-notes{display:none}.col-product{width:40%}.col-room{width:16%}.col-qty{width:8%}.col-price,.col-total{width:10%}.col-actions{width:8%}}.grid-row.loading{opacity:.6;pointer-events:none}.grid-row.loading .grid-search-input{background:#f3f4f6}.grid-row.success{border-left:3px solid #10b981;background:#f0fdf4!important}.grid-row.error{border-left:3px solid #ef4444;background:#fef2f2!important}.grid-search-input.error{background:#fef2f2;border-color:#ef4444}.grid-row.selected{border-left:3px solid #3b82f6;background:#dbeafe!important}.bulk-actions{background:#f0f9ff;border-bottom:1px solid #bfdbfe;align-items:center;gap:12px;padding:12px 24px;display:none}.bulk-actions.visible{display:flex}.bulk-actions-text{color:#1e40af;font-size:.875rem;font-weight:500}.bulk-action-btn{color:#3b82f6;cursor:pointer;background:#fff;border:1px solid #3b82f6;border-radius:6px;padding:6px 12px;font-size:.8rem;transition:all .15s}.bulk-action-btn:hover{color:#fff;background:#3b82f6}.global-search-dropdown{scrollbar-width:thin;scrollbar-color:#2563eb #f3f4f6}.global-search-dropdown::-webkit-scrollbar{background:#f3f4f6;width:8px}.global-search-dropdown li{cursor:pointer;background:#fff;transition:background .15s,border-left .15s,padding-left .15s}.global-search-dropdown li.active,.global-search-dropdown li:active{border-left:3px solid #2563eb;padding-left:13px;background:#e0f2fe!important}.global-search-dropdown li:hover{border-left:3px solid #3b82f6;padding-left:13px;background:#f0f9ff!important}.global-search-dropdown{z-index:10010;background:#fff;border:1px solid #d1d5db;border-radius:8px;width:auto;min-width:200px;max-height:300px;margin:0;padding:4px 0;font-size:14px;list-style:none;transition:box-shadow .2s;overflow:hidden auto;box-shadow:0 10px 25px -5px #00000026,0 8px 10px -6px #0000001a;position:fixed!important}.global-search-dropdown li{cursor:pointer;color:#374151;white-space:normal;word-wrap:break-word;background:#fff;border-bottom:1px solid #f3f4f6;width:100%;margin:0;padding:12px 16px;font-size:14px;line-height:1.5;transition:background .15s,color .15s;display:block;overflow:visible}.global-search-dropdown li.active{font-weight:700;color:#fff!important;background:#2563eb!important}.global-search-dropdown li.hover:not(.active){color:#1e293b!important;background:#e0e7ff!important}.global-search-dropdown::-webkit-scrollbar{width:8px}.global-search-dropdown::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.global-search-dropdown::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}body{align-items:initial!important;justify-content:initial!important;display:block!important}.grid-container{opacity:1}.app-loading-overlay{z-index:9999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#fafafad9;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.app-loading-overlay.fade-out{opacity:0;pointer-events:none}.app-loading-spinner{flex-direction:column;align-items:center;gap:16px;display:flex}.app-loading-spinner .spinner-ring{border:4px solid #e5e7eb;border-top-color:#b87333;border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.app-loading-spinner .spinner-text{font-family:var(--font-primary,"DM Sans", sans-serif);color:#6b7280;letter-spacing:.02em;font-size:14px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.grid-container{font-family:var(--font-primary,"DM Sans", -apple-system, BlinkMacSystemFont, sans-serif);background:var(--bg-secondary,#fafafa);flex-direction:column;min-height:100vh;display:flex}.app-navbar{background:var(--color-charcoal,#1a1a1a);color:#fff;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.navbar-brand{align-items:center;gap:16px;display:flex}.navbar-logo{filter:brightness(10);width:auto;height:28px}.navbar-divider{background:#fff3;width:1px;height:20px}.navbar-title{color:#ffffffe6;letter-spacing:-.01em;font-size:.9375rem;font-weight:500}.navbar-actions{align-items:center;gap:16px;display:flex}.navbar-btn{color:#fffc;cursor:pointer;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;transition:all .15s;display:flex}.navbar-btn:hover{color:#fff;background:#fff3}.navbar-actions .navbar-link{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:6px 12px;font-family:inherit;font-size:.75rem;transition:all .15s}.navbar-actions .navbar-link:hover{color:#ffffffe6;background:#ffffff1a}.navbar-actions .navbar-link--staff{color:var(--color-copper-light,#d4915a);background:#b8733314;border:1px solid #b8733366}.navbar-actions .navbar-link--staff:hover{color:#fff;border-color:var(--color-copper,#b87333);background:#b8733333}.navbar-actions .navbar-divider{margin:0 4px}.context-header{background:linear-gradient(180deg, var(--bg-secondary,#f9fafb) 0%, var(--bg-primary,#fff) 100%);border-bottom:1px solid var(--border-light,#e5e5e5);justify-content:space-between;align-items:center;padding:10px 24px;display:flex}.context-left{align-items:center;gap:12px;display:flex}.context-label{color:var(--text-muted,#a3a3a3);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.selection-status{align-items:center;gap:10px;display:flex}.status-icon{color:var(--color-sage,#7c9082);font-size:.875rem}.status-icon.saved{color:var(--color-sage,#7c9082)}.status-icon.unsaved{color:var(--color-copper,#b87333)}.selection-name{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-primary,#1a1a1a);white-space:nowrap;text-overflow:ellipsis;max-width:300px;font-size:.9375rem;font-weight:600;overflow:hidden}.save-indicator{color:var(--color-copper,#b87333);background:#b873331a;border-radius:12px;align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;animation:2s ease-in-out infinite pulse-subtle;display:flex}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.7}}.dot-unsaved{background:var(--color-copper,#b87333);border-radius:50%;width:6px;height:6px}.context-right{align-items:center;gap:8px;display:flex}.context-btn{border:1px solid var(--border-light,#e5e5e5);font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-secondary,#404040);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.context-btn:hover{background:var(--bg-tertiary,#f5f5f5);border-color:var(--border-medium,#d4d4d4)}.context-btn-primary{background:var(--color-charcoal,#1a1a1a);border-color:var(--color-charcoal,#1a1a1a);color:#fff}.context-btn-primary:hover{background:var(--color-graphite,#2d2d2d);border-color:var(--color-graphite,#2d2d2d)}.app-toolbar{background:var(--bg-primary,#fff);border-bottom:1px solid var(--border-light,#e5e5e5);justify-content:space-between;align-items:center;gap:24px;padding:12px 24px;display:flex}.toolbar-left,.toolbar-right{align-items:center;gap:12px;display:flex}.tender-import-banner{color:#1e40af;white-space:nowrap;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;align-items:center;gap:8px;padding:6px 12px;font-size:12px;animation:.3s ease-out fadeIn;display:flex}.tender-banner-close{color:#60a5fa;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:14px;line-height:1}.tender-banner-close:hover{color:#1e40af}.toolbar-center{flex:1;justify-content:center;display:flex}.toolbar-btn{border:1px solid var(--border-light,#e5e5e5);background:var(--bg-primary,#fff);font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-secondary,#404040);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:8px 16px;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.toolbar-btn:hover{background:var(--bg-tertiary,#f5f5f5);border-color:var(--border-medium,#d4d4d4)}.toolbar-btn-primary{background:var(--color-charcoal,#1a1a1a);border-color:var(--color-charcoal,#1a1a1a);color:#fff}.toolbar-btn-primary:hover{background:var(--color-graphite,#2d2d2d)}.toolbar-btn-danger{color:var(--color-error,#c44536);border-color:var(--color-error-light,#fbeae8);background:var(--color-error-light,#fbeae8)}.toolbar-btn-danger:hover{background:var(--color-error,#c44536);color:#fff;border-color:var(--color-error,#c44536)}.toolbar-btn-accent{background:var(--color-copper,#b87333);border-color:var(--color-copper,#b87333);color:#fff}.toolbar-btn-accent:hover{background:var(--color-copper-dark,#8b5a2b);border-color:var(--color-copper-dark,#8b5a2b)}.stats-bar{background:var(--bg-tertiary,#f5f5f5);border-radius:24px;align-items:center;gap:20px;padding:8px 24px;display:flex}.stat-item{align-items:baseline;gap:6px;display:flex}.stat-value{color:var(--text-primary,#1a1a1a);font-size:1.125rem;font-weight:600}.stat-label{color:var(--text-muted,#a3a3a3);text-transform:lowercase;font-size:.75rem}.stat-total .stat-value{color:var(--color-copper,#b87333)}.stat-divider{background:var(--border-light,#e5e5e5);width:1px;height:20px}.empty-state-hero{flex:1;justify-content:center;align-items:center;padding:48px 24px;display:none;position:relative;overflow:hidden}.empty-state-hero[style*="display: block"],.empty-state-hero[style*=display\:block]{display:flex!important}.empty-hero-bg{pointer-events:none;background:radial-gradient(at 30% 20%,#b8733314 0%,#0000 50%),radial-gradient(at 70% 80%,#7c908214 0%,#0000 50%);position:absolute;inset:0}.empty-hero-content{text-align:center;max-width:540px;position:relative}.empty-hero-logo{opacity:.15;height:48px;margin-bottom:32px}.empty-hero-title{font-family:var(--font-display,"Fraunces", Georgia, serif);color:var(--text-primary,#1a1a1a);letter-spacing:-.02em;margin:0 0 16px;font-size:2rem;font-weight:600}.empty-hero-text{color:var(--text-tertiary,#737373);margin:0 0 32px;font-size:1.0625rem;line-height:1.6}.empty-hero-actions{justify-content:center;align-items:center;gap:16px;margin-bottom:48px;display:flex}.hero-btn{font-family:var(--font-primary,"DM Sans", sans-serif);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:10px;padding:14px 28px;font-size:.9375rem;font-weight:600;transition:all .2s;display:flex}.hero-btn-primary{background:var(--color-charcoal,#1a1a1a);color:#fff;box-shadow:0 4px 12px #1a1a1a33}.hero-btn-primary:hover{background:var(--color-graphite,#2d2d2d);transform:translateY(-2px);box-shadow:0 6px 16px #1a1a1a40}.hero-btn-secondary{background:var(--bg-primary,#fff);color:var(--text-secondary,#404040);border:1px solid var(--border-medium,#d4d4d4)}.hero-btn-secondary:hover{background:var(--bg-tertiary,#f5f5f5);border-color:var(--text-tertiary,#737373)}.hero-divider{color:var(--text-muted,#a3a3a3);font-size:.875rem}.entry-options{width:100%;max-width:500px;margin-bottom:32px}.entry-card{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e5e5);cursor:pointer;border-radius:12px;align-items:center;gap:16px;margin-bottom:16px;padding:16px 20px;transition:all .2s;display:flex}.entry-card:hover{border-color:var(--color-copper,#b87333);transform:translateY(-2px);box-shadow:0 4px 12px #b8733326}.entry-card-primary{border-color:var(--color-copper,#b87333);background:linear-gradient(135deg,#b8733314 0%,#b8733305 100%)}.entry-icon{flex-shrink:0;font-size:1.5rem}.entry-content{flex:1;min-width:0}.entry-title{color:var(--text-primary,#1a1a1a);margin-bottom:2px;font-size:.9375rem;font-weight:600}.entry-subtitle{color:var(--text-tertiary,#737373);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;overflow:hidden}.entry-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.entry-btn{background:var(--bg-primary,#fff);border:1px solid var(--border-medium,#d4d4d4);font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-secondary,#404040);cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:12px 20px;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.entry-btn:hover{background:var(--bg-tertiary,#f5f5f5);border-color:var(--text-tertiary,#737373);transform:translateY(-1px)}.entry-btn-primary{background:var(--color-charcoal,#1a1a1a);border-color:var(--color-charcoal,#1a1a1a);color:#fff;box-shadow:0 4px 12px #1a1a1a33}.entry-btn-primary:hover{background:var(--color-graphite,#2d2d2d);transform:translateY(-2px);box-shadow:0 6px 16px #1a1a1a40}.empty-hero-hints{justify-content:center;gap:24px;display:flex}.empty-hero-hints .hint{color:var(--text-muted,#a3a3a3);align-items:center;gap:8px;font-size:.75rem;display:flex}.empty-hero-hints kbd{min-width:22px;height:20px;color:var(--text-secondary,#404040);background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e5e5);box-shadow:0 1px 0 var(--border-medium,#d4d4d4);border-radius:4px;justify-content:center;align-items:center;padding:0 5px;font-size:.6875rem;font-weight:500;display:inline-flex}.grid-header{background:var(--bg-primary,#fff);border-bottom:1px solid var(--border-light,#e5e5e5);box-shadow:0 1px 3px #0000000a;display:none!important}.header-top{padding:16px 32px}.header-left h2{font-family:var(--font-display,"Fraunces", Georgia, serif);color:var(--text-primary,#1a1a1a);letter-spacing:-.02em;font-size:1.5rem;font-weight:600}.btn-import-quote,.btn-clear-all,.btn-settings,.btn-create{font-family:var(--font-primary,"DM Sans", sans-serif);cursor:pointer;border:none;border-radius:8px;padding:10px 20px;font-size:.875rem;font-weight:500;transition:all .15s}.btn-import-quote{background:var(--color-charcoal,#1a1a1a);color:#fff}.btn-import-quote:hover{background:var(--color-graphite,#2d2d2d);transform:translateY(-1px)}.btn-clear-all{background:var(--color-error-light,#fbeae8);color:var(--color-error,#c44536);border:1px solid var(--color-error,#c44536)}.btn-clear-all:hover{background:var(--color-error,#c44536);color:#fff}.btn-settings{background:var(--bg-tertiary,#f5f5f5);color:var(--text-secondary,#404040);border:1px solid var(--border-medium,#d4d4d4)}.btn-settings:hover{background:var(--bg-primary,#fff);border-color:var(--text-secondary,#404040)}.btn-create{background:var(--color-copper,#b87333);color:#fff}.btn-create:hover{background:var(--color-copper-dark,#8b5a2b);transform:translateY(-1px);box-shadow:0 4px 12px #b873334d}.sort-controls{align-items:center;gap:10px;display:flex}.sort-controls label{color:var(--text-tertiary,#737373);font-size:.875rem;font-weight:500}.sort-select{font-family:var(--font-primary,"DM Sans", sans-serif);border:1px solid var(--border-light,#e5e5e5);background:var(--bg-primary,#fff);color:var(--text-primary,#1a1a1a);cursor:pointer;border-radius:6px;padding:8px 12px;font-size:.875rem;transition:all .15s}.sort-select:hover{border-color:var(--border-medium,#d4d4d4)}.sort-select:focus{border-color:var(--color-copper,#b87333);outline:none;box-shadow:0 0 0 3px #b8733326}.selection-summary{color:var(--text-secondary,#404040);padding:8px 0;font-size:.875rem}.guided-assist-wrap{margin:10px 0 14px}.guided-assist-toggle{border:1px solid var(--border-medium,#d4d4d4);background:var(--bg-primary,#fff);color:var(--text-secondary,#404040);cursor:pointer;border-radius:8px;padding:8px 12px;font-size:.85rem;font-weight:600}.guided-assist-toggle:hover{border-color:var(--color-copper,#b87333);color:var(--color-copper,#b87333)}.guided-assist-panel{border:1px solid var(--border-light,#e5e5e5);background:var(--bg-primary,#fff);border-radius:10px;margin-top:10px;padding:12px}.guided-assist-controls{flex-wrap:wrap;align-items:flex-end;gap:10px;display:flex}.guided-range-search-wrap{min-width:280px}.guided-assist-controls label{color:var(--text-tertiary,#737373);flex-direction:column;gap:4px;font-size:.75rem;display:flex}.guided-assist-controls select{border:1px solid var(--border-light,#e5e5e5);min-width:180px;color:var(--text-primary,#1a1a1a);background:var(--bg-primary,#fff);border-radius:6px;padding:6px 8px;font-size:.85rem}.guided-assist-controls input{border:1px solid var(--border-light,#e5e5e5);min-width:280px;color:var(--text-primary,#1a1a1a);background:var(--bg-primary,#fff);border-radius:6px;padding:6px 8px;font-size:.85rem}.guided-clear-btn{border:1px solid var(--border-medium,#d4d4d4);background:var(--bg-secondary,#fafafa);color:var(--text-secondary,#404040);cursor:pointer;border-radius:6px;height:32px;padding:0 10px;font-size:.8rem}.guided-fred-btn{border:1px solid var(--color-copper,#b87333);background:var(--bg-primary,#fff);color:var(--color-copper,#b87333);cursor:pointer;border-radius:6px;height:32px;padding:0 10px;font-size:.8rem;font-weight:600}.guided-selection-hint{color:var(--text-tertiary,#737373);margin:10px 0 8px;font-size:.8rem}.guided-suggestions-list{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;max-height:420px;display:grid;overflow-y:auto}.guided-suggestion-item{border:1px solid var(--border-light,#e5e5e5);background:var(--bg-secondary,#fafafa);cursor:pointer;border-radius:8px;grid-template-columns:64px 1fr auto;align-items:center;gap:8px;padding:8px 10px;display:grid}.guided-suggestion-item:hover{border-color:var(--color-copper,#b87333);box-shadow:0 2px 10px #0000000f}.guided-suggestion-image{object-fit:contain;border:1px solid var(--border-light,#e5e5e5);background:#fff;border-radius:6px;width:56px;height:56px}.guided-suggestion-main{color:var(--text-primary,#1a1a1a);font-size:.82rem;line-height:1.3}.guided-suggestion-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.guided-suggestion-actions{align-self:center}.guided-suggestion-add{border:1px solid var(--color-copper,#b87333);background:var(--bg-primary,#fff);color:var(--color-copper,#b87333);cursor:pointer;white-space:nowrap;border-radius:6px;padding:4px 10px;font-size:.75rem;font-weight:600}.guided-suggestion-add:hover{background:#b8733314}.guided-badges{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.guided-badge{color:#7f4f24;background:#b8733324;border-radius:999px;padding:1px 8px;font-size:.68rem}@media (width<=1320px){.guided-suggestions-list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=980px){.guided-suggestions-list{grid-template-columns:1fr}}#app-version{font-weight:500;color:var(--text-muted,#a3a3a3)!important;text-decoration:none!important}.grid-table-container{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e5e5);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.grid-header-row{background:var(--bg-tertiary,#f5f5f5);border-bottom:2px solid var(--border-light,#e5e5e5)}.grid-header-row>div{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-tertiary,#737373);text-transform:uppercase;letter-spacing:.05em;border-right:1px solid var(--border-light,#e5e5e5);padding:14px 12px;font-size:.75rem;font-weight:600}.grid-header-row>div:last-child{border-right:none}.grid-row{transition:background-color .1s}.grid-row:nth-child(2n){background:var(--bg-secondary,#fafafa)}.grid-row:hover{background:#b873330a}.grid-row.dragging{opacity:.5;background:var(--bg-secondary,#f5f5f5)!important}.grid-row.drag-over-above{position:relative}.grid-row.drag-over-above:before{content:"";background:var(--color-copper,#b87333);z-index:10;height:3px;position:absolute;top:0;left:0;right:0;box-shadow:0 0 8px #b8733380}.grid-row.drag-over-below{position:relative}.grid-row.drag-over-below:after{content:"";background:var(--color-copper,#b87333);z-index:10;height:3px;position:absolute;bottom:0;left:0;right:0;box-shadow:0 0 8px #b8733380}.grid-drag-handle{cursor:grab}.grid-drag-handle:active{cursor:grabbing}.grid-row>div{font-family:var(--font-primary,"DM Sans", sans-serif);border-right:1px solid var(--border-light,#e5e5e5);border-bottom:1px solid var(--border-light,#e5e5e5);color:var(--text-primary,#1a1a1a);padding:4px 6px;font-size:.875rem}.grid-row>div:last-child{border-right:none}.grid-product-name{color:var(--text-primary,#1a1a1a);word-wrap:break-word;overflow-wrap:break-word;font-weight:500;line-height:1.4}.grid-product-name strong{color:var(--color-copper,#b87333);font-weight:600}.grid-product-code-line{margin-bottom:2px;display:block}.grid-product-title-line{color:var(--text-primary,#1a1a1a);font-weight:500;display:block}.grid-part-ext-not-public,.grid-search-ext-not-public{cursor:help;border:0;font-weight:700;text-decoration:none}.grid-part-ext-not-public{color:var(--text-muted,#78716c)}.grid-search-ext-not-public{color:#92400e;margin-left:1px}.grid-non-public-pill{letter-spacing:.03em;text-transform:uppercase;color:#92400e;vertical-align:middle;background:#fffbeb;border:1px solid #fde68a;border-radius:4px;margin-left:6px;padding:0 5px;font-size:.65rem;font-weight:600;line-height:1.3;display:inline-block}.grid-plan-code-pill{letter-spacing:.04em;text-transform:uppercase;color:#1e40af;vertical-align:middle;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;margin-right:6px;padding:1px 6px;font-family:SF Mono,Monaco,Menlo,monospace;font-size:.65rem;font-weight:700;line-height:1.3;display:inline-block}.grid-product-code{color:var(--text-muted,#a3a3a3);font-family:SF Mono,Monaco,Menlo,monospace;font-size:.75rem}.grid-search-input,.grid-select,.grid-input,.grid-textarea{font-family:var(--font-primary,"DM Sans", sans-serif);border:1px solid var(--border-light,#e5e5e5);background:var(--bg-primary,#fff);color:var(--text-primary,#1a1a1a);border-radius:6px;padding:4px 6px;font-size:.8125rem;transition:all .15s}.grid-search-input:hover,.grid-select:hover,.grid-input:hover,.grid-textarea:hover{border-color:var(--border-medium,#d4d4d4)}.grid-search-input:focus,.grid-select:focus,.grid-input:focus,.grid-textarea:focus{border-color:var(--color-copper,#b87333);outline:none;box-shadow:0 0 0 3px #b8733326}.col-notes{padding:1px 2px!important}.col-notes .grid-textarea{resize:vertical;border:1px solid var(--border-light,#e5e5e5);word-wrap:break-word;overflow-wrap:break-word;white-space:pre-wrap;min-height:2.8em;padding:2px 4px;font-size:.78rem;line-height:1.35}.grid-input[type=number]{appearance:textfield}.grid-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.grid-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grid-search-input::placeholder{color:var(--text-muted,#a3a3a3)}.grid-placeholder-hint{color:#6b21a8;word-wrap:break-word;overflow-wrap:break-word;background:#faf5ff;border:1px dashed #d8b4fe;border-radius:4px;margin-bottom:4px;padding:4px 8px;font-size:11px;line-height:1.3}.grid-seima-match-wrap{margin-top:4px}.grid-seima-match-btn{color:#1d4ed8;cursor:pointer;word-wrap:break-word;overflow-wrap:break-word;background:#eff6ff;border:1px solid #93c5fd;border-radius:4px;max-width:100%;padding:2px 8px;font-size:.75rem;display:inline-block}.grid-seima-match-btn:hover{background:#dbeafe;border-color:#3b82f6}.grid-placeholder-hint .grid-competitor-code-link{color:#5b21b6;text-underline-offset:2px;font-weight:600;text-decoration:underline}.grid-placeholder-hint .grid-competitor-code-link:hover{color:#3730a3}.grid-validator-overlay{z-index:9000;background:#1a1a1a26;position:fixed;inset:0}.grid-validator-modal{z-index:9001;background:#fff;border-radius:12px;flex-direction:column;width:760px;max-width:92vw;max-height:88vh;animation:.15s ease-out gvm-fade-in;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 20px 60px #00000040}.grid-validator-modal.gvm-seima-picker-modal{width:min(1120px,94vw);max-height:92vh}@keyframes gvm-fade-in{0%{opacity:0;transform:translate(-50%,-48%)}to{opacity:1;transform:translate(-50%,-50%)}}.gvm-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex}.gvm-title{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:1rem;font-weight:600;overflow:hidden}.gvm-subtitle{color:#6b7280;margin-top:2px;font-size:.78rem}.gvm-close{cursor:pointer;color:#6b7280;background:#f3f4f6;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.gvm-close:hover{color:#111;background:#e5e7eb}.gvm-body{flex:1;padding:20px;overflow-y:auto}.gvm-seima-picker-modal .gvm-body{background:#f8fafc;padding:18px}.gvm-imported-context{background:#fff;border:1px solid #e5e7eb;border-radius:12px;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;padding:14px 16px;display:flex;box-shadow:0 1px 2px #0f172a0a}.gvm-context-label{letter-spacing:.08em;text-transform:uppercase;color:#9ca3af;margin-bottom:4px;font-size:.68rem;font-weight:700}.gvm-context-title{color:#111827;font-size:.95rem;font-weight:700}.gvm-context-meta{color:#6b7280;margin-top:5px;font-size:.78rem;line-height:1.35}.gvm-context-action{flex-shrink:0}.gvm-layout{grid-template-columns:220px 1fr;gap:20px;display:grid}.gvm-product-detail{flex-direction:column;gap:8px;display:flex}.gvm-product-img{object-fit:contain;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;width:100%;max-height:160px}.gvm-product-table{border-collapse:collapse;width:100%;font-size:.8rem}.gvm-product-table td{vertical-align:top;padding:3px 0}.gvm-product-table td:first-child{color:#9ca3af;text-transform:uppercase;width:70px;padding-right:6px;font-size:.7rem;font-weight:600}.gvm-matches-panel{flex-direction:column;gap:6px;display:flex}.gvm-panel-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:14px;padding:14px;box-shadow:0 1px 2px #0f172a0a}.gvm-search-panel{z-index:1;position:sticky;top:0}.gvm-search-panel-header{justify-content:space-between;gap:12px;margin-bottom:10px;display:flex}.gvm-search-help{color:#6b7280;margin-top:2px;font-size:.76rem}.gvm-filter-row{grid-template-columns:1fr 1fr;gap:10px;margin-top:10px;display:grid}.gvm-filter-row select{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:8px;width:100%;padding:8px 10px}.gvm-result-count{color:#6b7280;margin:10px 0 6px;font-size:.75rem}.gvm-card-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;display:grid}.gvm-section-title{text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;margin-bottom:4px;font-size:.7rem;font-weight:700}.gvm-match-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:10px;margin-bottom:4px;padding:8px 10px;display:flex}.gvm-match-card.status-verified{background:#f0fdf4;border-left:3px solid #22c55e}.gvm-match-card.status-rejected{opacity:.5;border-left:3px solid #ef4444}.gvm-match-card.status-pending-user{background:#fffbeb;border-left:3px solid #f59e0b}.gvm-match-card.status-pending-dispute{background:#fffbeb;border-left:3px solid #ef4444}.gvm-match-img{object-fit:contain;background:#f3f4f6;border-radius:6px;flex-shrink:0;width:44px;height:44px}.gvm-match-img-placeholder{color:#d1d5db;background:#f3f4f6;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:9px;display:flex}.gvm-match-info{flex:1;min-width:0}.gvm-match-name{font-size:.8rem;font-weight:600}.gvm-match-sku{color:#9ca3af;font-size:.7rem}.gvm-match-reason{color:#9ca3af;margin-top:2px;font-size:.65rem;font-style:italic}.gvm-match-price{text-align:right;flex-shrink:0;min-width:55px;font-size:.8rem;font-weight:500}.gvm-match-actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.gvm-btn{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:3px 10px;font-size:.7rem;transition:all .15s}.gvm-btn:disabled{opacity:.5;cursor:not-allowed}.gvm-btn-verify{color:#15803d;background:#f0fdf4;border-color:#86efac}.gvm-btn-verify:hover{background:#dcfce7}.gvm-btn-reject{color:#b91c1c;background:#fef2f2;border-color:#fca5a5}.gvm-btn-reject:hover{background:#fee2e2}.gvm-btn-undo{color:#6b7280;background:0 0;border:none;font-size:.65rem;text-decoration:underline}.gvm-status-label{border-radius:8px;padding:2px 6px;font-size:.65rem;font-weight:600}.gvm-status-verified{color:#15803d;background:#dcfce7}.gvm-status-rejected{color:#b91c1c;background:#fee2e2}.gvm-status-pending-user,.gvm-status-pending-dispute{color:#92400e;background:#fef3c7}.gvm-no-matches{text-align:center;color:#9ca3af;padding:20px;font-size:.8rem;font-style:italic}.gvm-search-add{border-top:1px dashed #e5e7eb;margin-top:12px;padding-top:12px}.gvm-search-add-label{text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;margin-bottom:6px;font-size:.7rem;font-weight:700}.gvm-search-add-input{border:1px solid #d1d5db;border-radius:8px;width:100%;padding:10px 12px;font-size:.95rem}.gvm-search-add-input:focus{border-color:#b87333;outline:none;box-shadow:0 0 0 2px #b8733326}.gvm-search-results{max-height:420px;margin-top:6px;overflow-y:auto}.gvm-search-result{cursor:pointer;text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:8px;margin-bottom:4px;padding:8px;display:flex}.gvm-search-result:hover{border-color:#b87333}.gvm-product-card{align-items:flex-start;min-height:86px;transition:border-color .15s,box-shadow .15s,transform .15s}.gvm-product-card:hover{transform:translateY(-1px);box-shadow:0 8px 22px #0f172a14}.gvm-product-card .gvm-match-img,.gvm-product-card .gvm-match-img-placeholder{border:1px solid #eef2f7;width:68px;height:68px}.gvm-product-card .gvm-match-name{font-size:.86rem;line-height:1.25}.gvm-product-card .gvm-match-sku{margin-top:4px;font-size:.72rem;line-height:1.35}.gvm-badge{border-radius:8px;margin-left:4px;padding:1px 5px;font-size:.6rem;font-weight:600;display:inline-block}.gvm-badge-high{color:#15803d;background:#dcfce7}.gvm-badge-med{color:#92400e;background:#fef3c7}.gvm-badge-low{color:#b91c1c;background:#fee2e2}@media (width<=700px){.gvm-layout{grid-template-columns:1fr}.grid-validator-modal{width:96vw}.gvm-imported-context{flex-direction:column}.gvm-filter-row,.gvm-card-grid{grid-template-columns:1fr}}.gvm-detail-overlay{z-index:9010;background:#00000014;position:fixed;inset:0}.gvm-detail-panel{z-index:9011;background:#fff;flex-direction:column;width:420px;max-width:50vw;height:100vh;animation:.2s ease-out gvm-slide-in;display:flex;position:fixed;top:0;right:0;box-shadow:-8px 0 32px #00000026}@keyframes gvm-slide-in{0%{opacity:.8;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.gvm-detail-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.gvm-detail-title{text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:1rem;font-weight:600;overflow:hidden}.gvm-detail-body{flex:1;padding:20px;overflow-y:auto}.gvm-detail-img{object-fit:contain;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;width:100%;max-height:280px;margin-bottom:16px}.gvm-detail-table{border-collapse:collapse;width:100%;font-size:.8rem}.gvm-detail-table tr{border-bottom:1px solid #f3f4f6}.gvm-detail-table td{vertical-align:top;padding:6px 0}.gvm-detail-table td:first-child{color:#9ca3af;text-transform:uppercase;letter-spacing:.3px;width:100px;padding-right:10px;font-size:.7rem;font-weight:600}.grid-search-input.populated{border-color:var(--color-copper,#b87333);background:#b873330d}.grid-price-cell{color:var(--color-sage,#7c9082);font-weight:500}.grid-total-display{color:var(--text-primary,#1a1a1a);background:var(--bg-tertiary,#f5f5f5);text-align:right;border-radius:4px;padding:6px 10px;font-weight:600}.grid-move-btn{background:var(--bg-tertiary,#f5f5f5);width:28px;height:28px;color:var(--text-tertiary,#737373);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:14px;transition:all .15s;display:flex}.grid-move-btn:hover{background:var(--border-medium,#d4d4d4);color:var(--text-primary,#1a1a1a)}.grid-drag-handle{background:var(--bg-tertiary,#f5f5f5);width:28px;height:28px;color:var(--text-muted,#a3a3a3);cursor:grab;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.grid-drag-handle:hover{background:var(--border-medium,#d4d4d4);color:var(--text-secondary,#404040)}.grid-remove-btn{background:var(--color-error-light,#fbeae8);width:28px;height:28px;color:var(--color-error,#c44536);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.grid-remove-btn:hover{background:var(--color-error,#c44536);color:#fff}.add-row-btn{font-family:var(--font-primary,"DM Sans", sans-serif);background:var(--bg-primary,#fff);border:2px dashed var(--border-medium,#d4d4d4);color:var(--text-tertiary,#737373);cursor:pointer;border-radius:8px;padding:14px 24px;font-size:.875rem;font-weight:500;transition:all .15s}.add-row-btn:hover{border-color:var(--color-copper,#b87333);color:var(--color-copper,#b87333);background:#b873330a}.room-header-row{background:var(--color-charcoal,#1a1a1a)!important}.room-header-content{color:#fff;white-space:nowrap;align-items:center;gap:8px;font-weight:600;display:flex}.room-header-content .room-name{white-space:nowrap}.room-header-content .room-drag-handle{cursor:grab;opacity:.6;letter-spacing:-2px;-webkit-user-select:none;user-select:none;border-radius:4px;padding:2px 4px;font-size:14px;transition:opacity .15s,background .15s}.room-header-content .room-drag-handle:hover{opacity:1;background:#fff3}.room-header-content .room-drag-handle:active{cursor:grabbing}.room-header-row[draggable=true]{cursor:grab}.room-header-row[draggable=true]:active{cursor:grabbing}.room-header-row.dragging{opacity:.5}.room-header-content .room-count{background:#ffffff26;border-radius:12px;padding:2px 10px;font-size:.75rem}.room-header-row.blank-room{background:var(--color-slate,#404040)!important}.room-header-row.bath-room{background:#4a7c8c!important}.room-header-row.kitchen-room{background:var(--color-copper,#b87333)!important}.room-header-row.laundry-room{background:var(--color-sage,#7c9082)!important}.room-header-row.alfresco-room{background:#6b8e6b!important}.room-header-row.butlers-room{background:#8b7355!important}.room-header-row.standard-room{background:#5a6f7a!important}.room-header-row.upgrade-room{background:#9b7b3b!important}.room-header-row.other-room{background:#7a7a7a!important}.grid-row[data-room=bath]>div:first-child,.grid-row.bath-room-row>div:first-child{border-left:3px solid #4a7c8c}.grid-row[data-room=kitchen]>div:first-child,.grid-row.kitchen-room-row>div:first-child{border-left:3px solid var(--color-copper,#b87333)}.grid-row[data-room=laundry]>div:first-child,.grid-row.laundry-room-row>div:first-child{border-left:3px solid var(--color-sage,#7c9082)}.grid-row[data-room=alfresco]>div:first-child,.grid-row.alfresco-room-row>div:first-child{border-left:3px solid #6b8e6b}.grid-row[data-room=butlers]>div:first-child,.grid-row.butlers-room-row>div:first-child{border-left:3px solid #8b7355}.grid-row[data-room=standard]>div:first-child,.grid-row.standard-room-row>div:first-child{border-left:3px solid #5a6f7a}.grid-row[data-room=upgrade]>div:first-child,.grid-row.upgrade-room-row>div:first-child{border-left:3px solid #9b7b3b}.global-search-dropdown{font-family:var(--font-primary,"DM Sans", sans-serif);background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e5e5);border-radius:8px;box-shadow:0 8px 24px #0000001f}.global-search-dropdown li{color:var(--text-primary,#1a1a1a);border-bottom:1px solid var(--border-light,#e5e5e5);padding:12px 16px;font-size:.875rem;transition:background-color .1s}.global-search-dropdown li:last-child{border-bottom:none}.global-search-dropdown li:hover{background:var(--bg-secondary,#fafafa)}.global-search-dropdown li.active{outline:2px solid var(--color-copper,#b87333);outline-offset:-2px;border-radius:6px;background:#b873331f!important}.modal{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a1a1a99}.modal-content{font-family:var(--font-primary,"DM Sans", sans-serif);background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e5e5);border-radius:16px;max-width:480px;padding:32px;box-shadow:0 24px 48px #0003}.modal-content h3{font-family:var(--font-display,"Fraunces", Georgia, serif);color:var(--text-primary,#1a1a1a);margin-bottom:24px;font-size:1.5rem;font-weight:600}.modal-content label{color:var(--text-secondary,#404040);margin-bottom:6px;font-size:.875rem;font-weight:500;display:block}.modal-content input[type=text],.modal-content input[type=email],.modal-content input[type=tel],.modal-content select,.modal-content textarea{font-family:var(--font-primary,"DM Sans", sans-serif);border:1px solid var(--border-light,#e5e5e5);width:100%;color:var(--text-primary,#1a1a1a);background:var(--bg-primary,#fff);border-radius:8px;margin-bottom:16px;padding:12px 14px;font-size:1rem;transition:all .15s}.modal-content input:focus,.modal-content select:focus,.modal-content textarea:focus{border-color:var(--color-copper,#b87333);outline:none;box-shadow:0 0 0 3px #b8733326}.modal-content .primary-btn{background:var(--color-charcoal,#1a1a1a);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 24px;font-weight:500;transition:all .15s}.modal-content .primary-btn:hover{background:var(--color-graphite,#2d2d2d);transform:translateY(-1px)}.modal-content .secondary-btn{background:var(--bg-tertiary,#f5f5f5);color:var(--text-secondary,#404040);border:1px solid var(--border-medium,#d4d4d4);cursor:pointer;border-radius:8px;padding:12px 24px;font-weight:500;transition:all .15s}.modal-content .secondary-btn:hover{background:var(--bg-primary,#fff);border-color:var(--text-tertiary,#737373)}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:80px 40px;display:flex}.empty-state-icon{color:var(--border-medium,#d4d4d4);margin-bottom:8px}.empty-state-title{font-family:var(--font-display,"Fraunces", Georgia, serif);color:var(--text-primary,#1a1a1a);margin:0;font-size:1.5rem;font-weight:600}.empty-state-text{color:var(--text-tertiary,#737373);max-width:400px;margin:0;font-size:1rem}.empty-state-hints{flex-wrap:wrap;justify-content:center;gap:24px;margin-top:24px;display:flex}.empty-state-hints .hint{color:var(--text-muted,#a3a3a3);align-items:center;gap:8px;font-size:.8125rem;display:flex}.empty-state-hints kbd{min-width:24px;height:22px;font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-secondary,#404040);background:var(--bg-tertiary,#f5f5f5);border:1px solid var(--border-light,#e5e5e5);box-shadow:0 1px 0 var(--border-medium,#d4d4d4);border-radius:4px;justify-content:center;align-items:center;padding:0 6px;font-size:.75rem;font-weight:500;display:inline-flex}#pdf-spinner{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a1a1ab3!important}#pdf-spinner>div{background:var(--bg-primary,#fff)!important;border-radius:16px!important;padding:40px!important;box-shadow:0 24px 48px #0003!important}#pdf-spinner div[style*=border-top]{border-color:var(--border-light,#e5e5e5)!important;border-top-color:var(--color-copper,#b87333)!important}.grid-product-image{border:1px solid var(--border-light,#e5e5e5);background:var(--bg-primary,#fff);cursor:pointer;border-radius:8px;transition:box-shadow .15s,border-color .15s}.grid-product-image:hover{border-color:var(--color-copper,#b87333);box-shadow:0 2px 8px #b8733333}.grid-product-modal-overlay{z-index:10000;background:#1a1a1a80;justify-content:center;align-items:center;animation:.15s gridPdmFadeIn;display:flex;position:fixed;inset:0}@keyframes gridPdmFadeIn{0%{opacity:0}to{opacity:1}}.grid-product-modal{background:var(--color-white,#fff);border-radius:16px;width:min(620px,94vw);max-height:85vh;animation:.2s gridPdmSlideUp;overflow-y:auto;box-shadow:0 24px 48px #0003}@keyframes gridPdmSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.grid-pdm-header{justify-content:flex-end;padding:12px 16px 0;display:flex}.grid-pdm-close{cursor:pointer;color:var(--color-stone,#737373);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:24px;line-height:1;display:flex}.grid-pdm-close:hover{color:var(--color-charcoal,#1a1a1a);background:var(--color-cloud,#f5f5f5)}.grid-pdm-body{flex-direction:column;align-items:stretch;gap:14px;padding:0 28px 24px;display:flex}.grid-pdm-img{object-fit:contain;border-radius:12px;align-self:center;width:220px;height:220px}.grid-pdm-title{color:var(--color-charcoal,#1a1a1a);text-align:center;margin:0;font-size:17px;font-weight:700;line-height:1.4}.grid-pdm-specs{grid-template-columns:auto 1fr;gap:6px 16px;width:100%;margin:0;font-size:13px;line-height:1.5;display:grid}.grid-pdm-specs-compact{grid-template-columns:auto 1fr auto 1fr;gap:4px 10px}.grid-pdm-specs dt{color:var(--color-stone,#737373);white-space:nowrap;font-weight:500}.grid-pdm-specs dd{color:var(--color-charcoal,#1a1a1a);margin:0;font-weight:600}.grid-pdm-desc{color:var(--color-slate,#404040);border-top:1px solid var(--border-light,#e5e5e5);width:100%;padding-top:12px;font-size:13px;line-height:1.55}.grid-pdm-orderline{width:100%;color:var(--color-copper,#b87333);margin-top:-4px;font-size:13px;font-weight:700}.grid-pdm-price{color:var(--color-charcoal,#1a1a1a);text-align:center;font-size:20px;font-weight:700}.grid-pdm-links{border-top:1px solid var(--border-light,#e5e5e5);flex-wrap:wrap;justify-content:center;gap:16px;width:100%;padding-top:10px;display:flex}.grid-pdm-link{color:var(--color-copper,#b87333);font-size:13px;font-weight:500;text-decoration:none;transition:color .15s}.grid-pdm-link:hover{color:var(--color-charcoal,#1a1a1a);text-decoration:underline}@media (width<=680px){.grid-pdm-specs-compact{grid-template-columns:auto 1fr}}.grid-content::-webkit-scrollbar{width:8px;height:8px}.modal-content::-webkit-scrollbar{width:8px;height:8px}.grid-content::-webkit-scrollbar-track{background:var(--bg-tertiary,#f5f5f5);border-radius:4px}.modal-content::-webkit-scrollbar-track{background:var(--bg-tertiary,#f5f5f5);border-radius:4px}.grid-content::-webkit-scrollbar-thumb{background:var(--border-medium,#d4d4d4);border-radius:4px}.modal-content::-webkit-scrollbar-thumb{background:var(--border-medium,#d4d4d4);border-radius:4px}.grid-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted,#a3a3a3)}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted,#a3a3a3)}.modal-content input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-copper,#b87333);cursor:pointer;margin-right:10px}.modal-content input[type=file]{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-secondary,#404040);font-size:.875rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:.2s ease-out fadeIn}.modal-content{animation:.3s ease-out slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-section-title{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-secondary,#404040);border-top:1px solid var(--border-light,#e5e5e5);margin:24px 0 12px;padding-top:16px;font-size:.875rem;font-weight:600}.form-section-title:first-of-type{border-top:none;margin-top:0;padding-top:0}.label-optional{color:var(--text-muted,#a3a3a3);font-size:.875em;font-weight:400}.checkbox-group{background:var(--bg-secondary,#fafafa);border-radius:8px;flex-direction:column;gap:12px;margin:16px 0;padding:16px;display:flex}.checkbox-label{cursor:pointer;color:var(--text-secondary,#404040);align-items:center;gap:10px;font-size:.875rem;display:flex}.checkbox-label input[type=checkbox]{margin:0}.checkbox-label span{-webkit-user-select:none;user-select:none}.logo-preview{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e5e5);border-radius:8px;justify-content:center;align-items:center;width:auto;max-width:200px;min-height:60px;max-height:120px;margin:12px 0;padding:8px;display:flex}.logo-preview img{object-fit:contain;max-width:100%;max-height:100%}.tip-tail-section{background:var(--bg-secondary,#fafafa);border-radius:8px;margin-bottom:16px;padding:16px}.tip-tail-section label,.tip-tail-section select{margin-bottom:8px}.tip-tail-section input[type=file]{margin-bottom:8px;font-size:.875rem}.file-status{color:var(--color-sage,#7c9082);margin-top:4px;font-size:.875rem}.btn-sm{margin-bottom:8px;padding:6px 12px!important;font-size:.75rem!important}.modal-actions{border-top:1px solid var(--border-light,#e5e5e5);justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;display:flex}.modal-actions .primary-btn,.modal-actions .secondary-btn{min-width:100px}.modal-wide{max-width:600px!important}.file-drop-zone{border:2px dashed var(--border-medium,#d4d4d4);text-align:center;background:var(--bg-secondary,#fafafa);cursor:pointer;border-radius:12px;margin:20px 0;padding:48px 24px;transition:all .2s}.file-drop-zone:hover{border-color:var(--color-copper,#b87333);background:#b873330a}.file-drop-zone.drag-over{border-color:var(--color-copper,#b87333);background:#b8733314}.drop-zone-text{color:var(--text-secondary,#404040);margin:0 0 8px;font-size:1rem;font-weight:500}.drop-zone-formats{color:var(--text-muted,#a3a3a3);margin:0;font-size:.875rem}.file-selected-info{border:1px solid var(--color-sage,#7c9082);color:var(--color-sage-dark,#5a6b5e);background:#7c90821f;border-radius:8px;margin:16px 0;padding:12px 16px}.step-description{color:var(--text-secondary,#404040);margin-bottom:20px;font-size:1rem}.import-mode-options{margin:24px 0}.radio-label{cursor:pointer;background:var(--bg-secondary,#fafafa);border:1px solid var(--border-light,#e5e5e5);border-radius:8px;align-items:flex-start;gap:12px;margin-bottom:16px;padding:16px;transition:all .15s;display:flex}.radio-label:hover{border-color:var(--border-medium,#d4d4d4);background:var(--bg-primary,#fff)}.radio-label input[type=radio]{width:18px;height:18px;accent-color:var(--color-copper,#b87333);flex-shrink:0;margin-top:2px}.radio-label span{-webkit-user-select:none;user-select:none;flex:1}.radio-label strong{color:var(--text-primary,#1a1a1a)}.warning-box{background:var(--color-error-light,#fbeae8);border:1px solid var(--color-error,#c44536);color:var(--color-error,#c44536);border-radius:8px;margin:16px 0;padding:16px;font-size:.875rem}.processing-step{text-align:center;padding:48px 24px}.spinner{border:4px solid var(--border-light,#e5e5e5);border-top:4px solid var(--color-copper,#b87333);border-radius:50%;width:48px;height:48px;margin:0 auto 20px;animation:.8s linear infinite spin}.processing-step p{color:var(--text-secondary,#404040);margin:0;font-size:1rem}.success-title{color:var(--color-sage,#7c9082);margin:0 0 16px;font-size:1.25rem;font-weight:600}.import-summary{background:var(--bg-secondary,#fafafa);border-radius:8px;margin-bottom:20px;padding:16px;font-size:.9375rem;line-height:1.6}.not-found-section{margin-top:24px}.not-found-title{color:var(--color-error,#c44536);margin:0 0 12px;font-size:.875rem;font-weight:600}.not-found-list{border:1px solid var(--border-light,#e5e5e5);background:var(--bg-secondary,#fafafa);border-radius:8px;max-height:200px;padding:12px 16px;font-size:.875rem;overflow-y:auto}.modal-confirm{max-width:420px!important}.confirm-text{color:var(--text-secondary,#404040);margin-bottom:16px;line-height:1.6}.clear-options{background:var(--bg-tertiary,#f5f5f5);border-radius:8px;margin-bottom:24px;padding:12px 16px}.clear-options .checkbox-label{margin:0;font-size:.875rem}.settings-section{margin-bottom:24px}.section-description{color:var(--text-muted,#a3a3a3);margin:0 0 20px;font-size:.875rem}.btn-refresh{background:var(--bg-tertiary,#f5f5f5);width:100%;color:var(--color-copper,#b87333);border:1px solid var(--color-copper,#b87333);font-family:var(--font-primary,"DM Sans", sans-serif);cursor:pointer;border-radius:8px;margin-top:16px;padding:12px 20px;font-size:.9375rem;font-weight:500;transition:all .15s}.btn-refresh:hover{background:#b8733314}.changelog-title{align-items:center;gap:8px;display:flex}.version-highlight{color:var(--color-copper,#b87333);font-weight:700}.changelog-content{max-height:400px;color:var(--text-secondary,#404040);padding-right:8px;line-height:1.7;overflow-y:auto}.changelog-content h4{color:var(--text-primary,#1a1a1a);margin:20px 0 10px;font-size:1rem}.changelog-content ul{margin:0 0 16px;padding-left:20px}.changelog-content li{margin-bottom:6px}.spinner-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#1a1a1ab3;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.spinner-content{background:var(--bg-primary,#fff);text-align:center;border-radius:16px;max-width:320px;padding:40px 48px;box-shadow:0 24px 48px #0003}.spinner-content .spinner{width:48px;height:48px;margin:0 auto 20px}.spinner-content p{color:var(--text-secondary,#404040);margin:0;font-size:1rem;font-weight:500}#sort-refresh-btn{cursor:pointer;color:var(--color-copper,#b87333);background:0 0;border:none;border-radius:4px;margin-left:8px;padding:4px;font-size:1.1rem;transition:all .15s}#sort-refresh-btn:hover{background:#b873331a}.header-bottom{background:var(--bg-secondary,#fafafa);border-top:1px solid var(--border-light,#e5e5e5);justify-content:space-between;align-items:center;padding:8px 32px;display:flex}.header-meta{align-items:center;gap:12px;display:flex}.version-badge{color:var(--text-muted,#a3a3a3);background:var(--bg-tertiary,#f5f5f5);cursor:pointer;border-radius:12px;padding:4px 10px;font-size:.75rem;transition:all .15s}.version-badge:hover{background:var(--border-light,#e5e5e5);color:var(--text-secondary,#404040)}.selection-summary{color:var(--text-secondary,#404040);font-size:.875rem}.selection-summary #total-value{color:var(--color-copper,#b87333);font-weight:600}.header-left h2{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-secondary,#404040);margin:0;font-size:1.125rem;font-weight:500}.panel-logo{width:auto;height:28px}.modal-fullscreen{flex-direction:column;width:90vw;max-width:1000px;height:85vh;max-height:85vh;padding:0;display:flex;overflow:hidden}.modal-fullscreen>h3{margin:0;padding:20px 24px 0}.modal-fullscreen #import-spec-results-step{flex-direction:column;flex:1;min-height:0;padding:16px 24px;display:flex;overflow:hidden}.modal-fullscreen #import-spec-results-step .modal-actions{flex-shrink:0}.modal-fullscreen #spec-results-content{flex:1;min-height:0;overflow-y:auto}.user-guide-header{background:var(--color-charcoal,#1a1a1a);color:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 28px;display:flex}.user-guide-header h2{font-size:1.25rem;font-weight:600;font-family:var(--font-primary,"DM Sans", sans-serif);margin:0}.modal-close-btn{color:#fffc;cursor:pointer;background:#ffffff1a;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .15s;display:flex}.modal-close-btn:hover{color:#fff;background:#fff3}.user-guide-content{background:var(--bg-primary,#fff);flex:1;padding:32px;overflow-y:auto}.user-guide-content h3{font-family:var(--font-display,"Fraunces", serif);color:var(--color-charcoal,#1a1a1a);border-bottom:2px solid var(--color-copper,#b87333);margin:0 0 16px;padding-bottom:12px;font-size:1.5rem;font-weight:500}.user-guide-content h4{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--color-charcoal,#1a1a1a);margin:28px 0 12px;font-size:1.125rem;font-weight:600}.user-guide-content p{color:var(--text-secondary,#404040);margin:0 0 16px;font-size:.9375rem;line-height:1.7}.user-guide-content ul,.user-guide-content ol{margin:0 0 20px;padding-left:24px}.user-guide-content li{color:var(--text-secondary,#404040);margin-bottom:8px;font-size:.9375rem;line-height:1.7}.user-guide-content .guide-header{border-bottom:1px solid var(--border-light,#e5e5e5);align-items:center;gap:20px;margin-bottom:32px;padding:32px 0;display:flex}.user-guide-content .guide-logo{width:auto;height:44px}.user-guide-content .guide-header-text{flex-direction:column;gap:2px;display:flex}.user-guide-content .guide-header-title{font-family:var(--font-display,"Fraunces", serif);color:var(--color-charcoal,#1a1a1a);margin:0;font-size:1.5rem;font-weight:600;line-height:1.2}.user-guide-content .guide-header-subtitle{color:var(--color-copper,#b87333);text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.875rem;font-weight:500}.user-guide-content .guide-section{margin-bottom:36px}.user-guide-content .guide-tip{border-left:4px solid var(--color-copper,#b87333);background:linear-gradient(135deg,#fef3c7 0%,#fed7aa 100%);border-radius:0 8px 8px 0;margin:20px 0;padding:16px 20px}.user-guide-content .guide-tip strong{color:#92400e}.user-guide-content .guide-tip p{color:#78350f;margin:0}.user-guide-content .shortcut-table{border-collapse:collapse;width:100%;margin:16px 0 24px}.user-guide-content .shortcut-table th,.user-guide-content .shortcut-table td{text-align:left;border-bottom:1px solid var(--border-light,#e5e5e5);padding:12px 16px}.user-guide-content .shortcut-table th{background:var(--bg-tertiary,#f5f5f5);color:var(--color-charcoal,#1a1a1a);font-size:.875rem;font-weight:600}.user-guide-content .shortcut-table td{color:var(--text-secondary,#404040);font-size:.875rem}.user-guide-content .shortcut-table kbd{background:var(--color-charcoal,#1a1a1a);color:#fff;border-radius:4px;padding:4px 8px;font-family:SF Mono,Consolas,monospace;font-size:.75rem;font-weight:500;display:inline-block}.user-guide-content .guide-img{border-radius:8px;max-width:100%;margin:16px 0;box-shadow:0 4px 12px #0000001a}.user-guide-content .step-number{background:var(--color-copper,#b87333);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;margin-right:12px;font-size:.875rem;font-weight:600;display:inline-flex}.user-guide-content .guide-footer{border-top:1px solid var(--border-light,#e5e5e5);text-align:center;margin-top:48px;padding-top:32px}.user-guide-content .guide-footer-brand{justify-content:center;align-items:center;gap:16px;margin-bottom:16px;display:flex}.user-guide-content .guide-footer-logo{opacity:.7;width:auto;height:32px}.user-guide-content .guide-footer-tagline{color:var(--text-muted,#a3a3a3);font-size:.875rem;font-style:italic}.user-guide-content .guide-footer-copyright{color:var(--text-muted,#a3a3a3);margin:0;font-size:.75rem}.spec-summary-bar{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.spec-stat{white-space:nowrap;border-radius:16px;padding:4px 12px;font-size:13px}.spec-stat strong{font-weight:700}.spec-stat-verified{color:#166534;background:#dcfce7}.spec-stat-alt{color:#1e40af;background:#dbeafe}.spec-stat-ai{color:#92400e;background:#fef3c7}.spec-stat-none{color:#991b1b;background:#fee2e2}.spec-table-wrap{border:1px solid var(--border-light,#e5e5e5);max-height:360px;overflow-y:auto}.modal-fullscreen .spec-table-wrap{border-radius:8px;max-height:none;overflow-y:visible}.spec-table{border-collapse:collapse;width:100%;font-size:13px}.spec-table thead{z-index:1;position:sticky;top:0}.spec-table th{background:var(--bg-header,#f5f5f5);text-align:left;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted,#737373);border-bottom:1px solid var(--border-light,#e5e5e5);padding:8px 10px;font-size:11px;font-weight:600}.spec-table td{border-bottom:1px solid var(--border-light,#e5e5e5);vertical-align:top;padding:8px 10px}.spec-row:last-child td{border-bottom:none}.spec-row-verified,.spec-row-seima-own{background:#f0fdf4}.spec-row-alternative{background:#eff6ff}.spec-row-catalog-suggestion{background:#faf5ff}.spec-row-ai-suggested{background:#fffbeb}.spec-row-unmatched{background:#fef2f2}.spec-stat-review{color:#b45309}.spec-confidence-review{color:#92400e;background:#fef3c7;border-radius:3px;margin-top:2px;padding:1px 5px;font-size:10px;font-weight:700;display:inline-block}.spec-ambiguity-box{color:#78350f;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;margin:0 0 12px;padding:8px 12px;font-size:13px}.spec-learned-layout{color:#14532d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;margin:0 0 12px;padding:8px 12px;font-size:13px}.spec-learned-layout button{color:#166534;cursor:pointer;background:0 0;border:0;margin-left:8px;text-decoration:underline}.spec-mapping-summary{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:12px;margin:0 0 12px;padding:10px 12px;display:flex}.spec-mapping-summary-text{color:#334155;min-width:0;font-size:13px}.spec-mapping-summary-text>div{flex-wrap:wrap;gap:6px;margin-top:6px;display:flex}.spec-mapping-chip{background:#fff;border:1px solid #cbd5e1;border-radius:999px;align-items:center;gap:4px;padding:3px 7px;font-size:11px;display:inline-flex}.spec-section-header td{color:#fff;text-transform:uppercase;letter-spacing:.5px;background:#1a1a2e;padding:6px 10px;font-size:11px;font-weight:600}.spec-row-check{cursor:pointer;width:16px;height:16px}.spec-badge{text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.spec-badge-seima,.spec-badge-verified{color:#166534;background:#dcfce7}.spec-badge-alt{color:#1e40af;background:#dbeafe}.spec-badge-suggest{color:#6b21a8;background:#f3e8ff}.spec-badge-ai{color:#92400e;background:#fef3c7}.spec-badge-none{color:#991b1b;background:#fee2e2}.lmw-overlay{z-index:10000;background:#0f172a8c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.lmw-modal{background:#fff;border-radius:12px;flex-direction:column;width:min(1040px,96vw);max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 80px #0f172a59}.lmw-header,.lmw-actions{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;display:flex}.lmw-header h3,.lmw-header p,.lmw-panel h4{margin:0}.lmw-header p{color:#64748b;margin-top:4px}.lmw-close{cursor:pointer;background:0 0;border:0;font-size:28px;line-height:1}.lmw-body{grid-template-columns:1.2fr .8fr;gap:16px;min-height:0;padding:18px 22px;display:grid;overflow:auto}.lmw-panel{min-width:0}.lmw-sample-list{border:1px solid #e5e7eb;border-radius:8px;max-height:460px;margin-top:12px;overflow:auto}.lmw-sample-item{border-bottom:1px solid #f1f5f9;grid-template-columns:72px 1fr;gap:10px;padding:9px 10px;font-size:13px;display:grid}.lmw-sample-item:last-child{border-bottom:0}.lmw-fields{gap:10px;margin-top:12px;display:grid}.lmw-field-row{grid-template-columns:140px 1fr;align-items:center;gap:10px;font-size:13px;display:grid}.lmw-field-row select{width:100%;padding:7px}.lmw-ambiguity{color:#78350f;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;margin-top:8px;padding:7px 9px;font-size:12px}.lmw-remember{cursor:pointer;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;margin-top:14px;padding:9px;font-size:13px;display:flex}.lmw-remember-note{color:#64748b;margin:6px 0 0;font-size:12px}.lmw-muted{color:#64748b;padding:12px}.lmw-actions{border-top:1px solid #e5e7eb;border-bottom:0;justify-content:flex-end}.spec-action-btn{color:#2d8a56;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #2d8a56;border-radius:6px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.spec-action-btn:hover:not(:disabled){color:#fff;background:#2d8a56}.spec-add-done,.spec-action-btn:disabled{color:#166534;cursor:default;background:#dcfce7;border-color:#2d8a56}.toast-container{z-index:100000;pointer-events:none;flex-direction:column-reverse;gap:12px;max-width:400px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-primary,#fff);pointer-events:auto;opacity:0;border-radius:10px;align-items:flex-start;gap:12px;padding:14px 16px;transition:opacity .2s,transform .3s cubic-bezier(.4,0,.2,1);display:flex;transform:translate(100%);box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d}.toast-enter{opacity:1;transform:translate(0)}.toast-exit{animation:.2s ease-in forwards toast-slide-out}@keyframes toast-slide-out{to{opacity:0;transform:translate(100%)}}.toast-icon{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:700;display:flex}.toast-success .toast-icon{background:var(--color-sage,#7c9082)}.toast-error .toast-icon{background:var(--color-error,#c44536)}.toast-warning .toast-icon{background:var(--color-warning,#d4915a)}.toast-info .toast-icon{background:var(--color-copper,#b87333)}.toast-content{flex:1;min-width:0}.toast-message{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--text-primary,#1a1a1a);font-size:.9375rem;font-weight:500;line-height:1.4;display:block}.toast-action{font-family:var(--font-primary,"DM Sans", sans-serif);color:var(--color-copper,#b87333);cursor:pointer;background:#b873331a;border:none;border-radius:6px;margin-top:8px;padding:6px 14px;font-size:.8125rem;font-weight:600;transition:all .15s;display:inline-block}.toast-action:hover{color:var(--color-copper-dark,#8b5a2b);background:#b8733333}.toast-close{width:24px;height:24px;color:var(--text-muted,#a3a3a3);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:18px;font-weight:300;transition:all .15s;display:flex}.toast-close:hover{color:var(--text-primary,#1a1a1a);background:var(--bg-tertiary,#f5f5f5)}.toast-success{border-left:3px solid var(--color-sage,#7c9082)}.toast-error{border-left:3px solid var(--color-error,#c44536)}.toast-warning{border-left:3px solid var(--color-warning,#d4915a)}.toast-info{border-left:3px solid var(--color-copper,#b87333)}@media (width<=480px){.toast-container{max-width:none;bottom:16px;left:16px;right:16px}.toast{transform:translateY(100%)}.toast-enter{transform:translateY(0)}@keyframes toast-slide-out{to{opacity:0;transform:translateY(100%)}}}@media (width<=1024px){.grid-header-row>div,.grid-row>div{padding:8px 10px}.col-notes{display:none}#pdf-wizard .wizard-sidebar{width:320px;min-width:320px;padding:24px}.header-right{gap:8px}.header-right .btn-import-quote,.header-right .btn-clear-all,.header-right .btn-settings{padding:8px 12px;font-size:.8125rem}}@media (width<=768px){.header-top{flex-direction:column;gap:16px;padding:16px}.header-left{text-align:center;width:100%}.header-right{grid-template-columns:1fr 1fr;gap:8px;width:100%;display:grid}.header-right button,.sort-controls{justify-content:center;width:100%}.grid-table-container{box-shadow:none;background:0 0;border:none}.grid-header-row{display:none!important}.grid-row{background:var(--bg-primary,#fff);border:1px solid var(--border-light,#e5e5e5);border-radius:12px;grid-template-rows:auto auto auto;grid-template-columns:80px 1fr;gap:8px;margin-bottom:12px;padding:16px;box-shadow:0 1px 3px #0000000a;display:grid!important}.grid-row.room-header-row{border-radius:8px;grid-template-columns:1fr;margin-bottom:8px;padding:12px 16px}.grid-row>div{border:none!important;padding:0!important}.grid-row .col-image{grid-row:1/3;align-self:start}.grid-row .grid-product-image{object-fit:contain;width:80px;height:80px}.grid-row .col-product{grid-area:1/2}.grid-row .col-product .grid-product-name{font-size:.9375rem;line-height:1.4}.grid-row .col-room,.grid-row .col-qty,.grid-row .col-price,.grid-row .col-total{grid-column:2}.grid-row .col-room{grid-row:2}.grid-row .col-room select{width:100%;padding:10px 12px;font-size:1rem}.grid-row .col-qty,.grid-row .col-price{width:auto!important;display:inline-block!important}.grid-row .col-total{grid-area:3/1/auto/-1;justify-content:space-between;align-items:center;margin-top:8px;border-top:1px solid var(--border-light,#e5e5e5)!important;padding-top:12px!important;display:flex!important}.grid-row .col-total:before{content:"Total";color:var(--text-tertiary,#737373);font-weight:500}.grid-row .col-actions{grid-area:4/1/auto/-1;justify-content:flex-end;gap:8px;padding-top:12px!important;display:flex!important}.grid-row .grid-actions-group{gap:8px;display:flex}.grid-row .grid-move-btn,.grid-row .grid-drag-handle,.grid-row .grid-remove-btn{width:36px;height:36px;font-size:16px}.grid-row .col-notes{display:none!important}.add-row-btn{width:100%}#pdf-wizard .wizard-content{flex-direction:column}#pdf-wizard .wizard-sidebar{order:-1;width:100%;min-width:100%;max-height:200px;overflow-y:auto}#pdf-wizard .wizard-main{padding:20px}.wizard-progress{padding:12px 16px;overflow-x:auto}.wizard-step-label{font-size:.75rem}.wizard-step-indicator{width:28px;height:28px;font-size:.75rem}.modal-content{border-radius:0;max-height:100vh;margin:0;max-width:100%!important}.empty-state{padding:48px 24px}.empty-state-icon svg{width:60px;height:60px}.empty-state-title{font-size:1.25rem}.empty-state-hints{flex-direction:column;gap:12px}}@media (width<=480px){.header-right{grid-template-columns:1fr}.grid-row{grid-template-columns:60px 1fr;padding:12px}.grid-row .grid-product-image{width:60px;height:60px}.wizard-step-label{display:none}.wizard-step{flex-direction:column;gap:4px}}@media (hover:none) and (pointer:coarse){.btn-import-quote,.btn-clear-all,.btn-settings,.btn-create{min-height:44px}.grid-move-btn,.grid-drag-handle,.grid-remove-btn{min-width:44px;min-height:44px}.grid-row:hover{background:inherit}.btn-import-quote:active,.btn-clear-all:active,.btn-settings:active,.btn-create:active{transform:scale(.98)}}@media print{.grid-header,.grid-footer,.header-right,.col-actions,.toast-container{display:none!important}.grid-row{break-inside:avoid}}.ai-chat-trigger{z-index:9990;background:var(--color-charcoal,#1a1a1a);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:transform .2s,box-shadow .2s,background .2s;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #0003,0 2px 4px #0000001a}.ai-chat-trigger:hover{background:var(--color-graphite,#2d2d2d);transform:scale(1.08);box-shadow:0 6px 24px #00000040,0 3px 6px #00000026}.ai-chat-trigger:active{transform:scale(.96)}.ai-chat-panel{z-index:9995;background:var(--color-white,#fff);width:620px;min-width:380px;max-width:90vw;height:100vh;font-family:var(--font-primary,"DM Sans", sans-serif);flex-direction:column;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:-640px;overflow:hidden;box-shadow:-4px 0 24px #0000001f,-1px 0 4px #0000000f}.ai-chat-panel.open{right:0}.ai-chat-resize-handle{cursor:ew-resize;z-index:10;background:0 0;width:6px;height:100%;transition:background .15s;position:absolute;top:0;left:0}.ai-chat-resize-handle:hover,.ai-chat-resize-handle.active{background:var(--color-ocean,#0077b6);opacity:.4}.ai-chat-header{background:var(--color-charcoal,#1a1a1a);color:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.ai-chat-header-left{align-items:center;gap:12px;display:flex}.ai-chat-avatar{background:var(--color-copper,#b87333);letter-spacing:.5px;border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.ai-chat-title{font-size:15px;font-weight:600;line-height:1.2}.ai-chat-subtitle{opacity:.6;font-size:12px;line-height:1.2}.ai-chat-header-actions{gap:4px;display:flex}.ai-chat-clear-btn,.ai-chat-close-btn{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;transition:opacity .15s,background .15s;display:flex}.ai-chat-clear-btn:hover,.ai-chat-close-btn:hover{opacity:1;background:#ffffff1a}.ai-chat-messages{background:var(--color-ivory,#fafafa);flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.ai-chat-welcome{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.ai-chat-welcome-icon{background:var(--color-cloud,#f5f5f5);width:56px;height:56px;color:var(--color-stone,#737373);border-radius:16px;justify-content:center;align-items:center;margin-bottom:16px;display:flex}.ai-chat-welcome h3{color:var(--color-charcoal,#1a1a1a);margin:0 0 8px;font-size:18px;font-weight:600}.ai-chat-welcome p{color:var(--color-stone,#737373);max-width:300px;margin:0 0 24px;font-size:14px;line-height:1.5}.ai-chat-suggestions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.ai-suggestion-btn{border:1px solid var(--color-mist,#e5e5e5);background:var(--color-white,#fff);color:var(--color-slate,#404040);cursor:pointer;border-radius:20px;padding:8px 14px;font-family:inherit;font-size:13px;line-height:1.3;transition:all .15s}.ai-suggestion-btn:hover{border-color:var(--color-copper,#b87333);color:var(--color-copper,#b87333);background:var(--color-warning-light,#fef3e8)}.ai-msg{flex-direction:column;max-width:100%;display:flex}.ai-msg-user{align-items:flex-end}.ai-msg-user .ai-msg-bubble{background:var(--color-charcoal,#1a1a1a);color:#fff;border-radius:16px 16px 4px;max-width:85%}.ai-msg-assistant .ai-msg-bubble{background:var(--color-white,#fff);color:var(--color-charcoal,#1a1a1a);border:1px solid var(--color-mist,#e5e5e5);border-radius:16px 16px 16px 4px;max-width:90%}.ai-msg-error .ai-msg-bubble{background:var(--color-error-light,#fbeae8);border:1px solid var(--color-error,#c44536);border-radius:16px 16px 16px 4px;max-width:90%}.ai-msg-bubble{word-break:break-word;padding:12px 16px;font-size:14px;line-height:1.55}.ai-msg-bubble p{margin:0 0 8px}.ai-msg-bubble p:last-child{margin-bottom:0}.ai-msg-bubble h3,.ai-msg-bubble h4{color:var(--color-charcoal,#1a1a1a);margin:12px 0 6px;font-size:14px;font-weight:600}.ai-msg-bubble h3:first-child,.ai-msg-bubble h4:first-child{margin-top:0}.ai-msg-bubble ul{margin:6px 0;padding-left:18px}.ai-msg-bubble li{margin-bottom:4px}.ai-msg-bubble code{background:var(--color-cloud,#f5f5f5);border-radius:4px;padding:2px 6px;font-family:SF Mono,Consolas,monospace;font-size:13px}.ai-msg-bubble strong{font-weight:600}.ai-msg-error{color:var(--color-error,#c44536);font-size:13px}.ai-msg-streaming{white-space:pre-wrap}.ai-msg-streaming:after{content:"";background:var(--color-copper,#b87333);vertical-align:text-bottom;width:2px;height:1em;margin-left:2px;animation:.8s infinite ai-cursor-blink;display:inline-block}@keyframes ai-cursor-blink{0%,to{opacity:1}50%{opacity:0}}.ai-msg-thinking{flex-direction:column;align-items:flex-start;gap:6px;padding:14px 20px;display:flex}.ai-thinking-spinner{color:var(--color-copper,#b87333);font-size:18px;line-height:1}.ai-thinking-status{color:var(--color-pewter,#a3a3a3);letter-spacing:.01em;min-height:16px;font-size:12px;transition:opacity .2s}.ai-chat-input-area{border-top:1px solid var(--color-mist,#e5e5e5);background:var(--color-white,#fff);flex-shrink:0;padding:16px 20px}.ai-chat-input-wrapper{background:var(--color-cloud,#f5f5f5);border:1px solid var(--color-mist,#e5e5e5);border-radius:12px;align-items:flex-end;gap:8px;padding:4px 4px 4px 16px;transition:border-color .15s;display:flex}.ai-chat-input-wrapper:focus-within{border-color:var(--color-copper,#b87333)}.ai-chat-input{resize:none;color:var(--color-charcoal,#1a1a1a);background:0 0;border:none;outline:none;flex:1;max-height:120px;padding:8px 0;font-family:inherit;font-size:14px;line-height:1.5}.ai-chat-input::placeholder{color:var(--color-pewter,#a3a3a3)}.ai-chat-send-btn{background:var(--color-charcoal,#1a1a1a);color:#fff;cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s,opacity .15s,transform .1s;display:flex}.ai-chat-send-btn:hover:not(:disabled){background:var(--color-copper,#b87333)}.ai-chat-send-btn:active:not(:disabled){transform:scale(.92)}.ai-chat-send-btn:disabled{opacity:.3;cursor:default}.ai-chat-footer{text-align:center;color:var(--color-pewter,#a3a3a3);margin-top:8px;font-size:11px}.ai-comparison-table{border-collapse:collapse;border:1px solid var(--color-mist,#e5e5e5);border-radius:8px;width:100%;margin:8px 0;font-size:12px;overflow:hidden}.ai-comparison-table th{background:var(--color-cloud,#f5f5f5);text-align:left;border-bottom:2px solid var(--color-mist,#e5e5e5);color:var(--color-charcoal,#1a1a1a);white-space:nowrap;padding:8px 10px;font-weight:600}.ai-comparison-table td{border-bottom:1px solid var(--color-mist,#e5e5e5);color:var(--color-slate,#404040);vertical-align:top;padding:6px 10px}.ai-comparison-table tr:last-child td{border-bottom:none}.ai-comparison-table tr:hover td{background:var(--color-cloud,#f5f5f5)}.ai-table-image-row td{text-align:center;border-bottom:1px solid var(--color-mist,#e5e5e5);padding:10px 8px}.ai-table-product-img{object-fit:cover;border:1px solid var(--color-mist,#e5e5e5);border-radius:6px;width:64px;height:64px}.ai-chat-image-btn{cursor:pointer;color:var(--color-pewter,#a3a3a3);background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex}.ai-chat-image-btn:hover{color:var(--color-copper,#b87333);background:var(--color-cloud,#f5f5f5)}.ai-chat-image-preview{background:var(--color-cloud,#f5f5f5);border:1px solid var(--color-mist,#e5e5e5);border-radius:10px;align-items:center;gap:8px;margin-bottom:8px;padding:8px 12px;display:flex}.ai-chat-image-preview img{object-fit:cover;border-radius:6px;width:48px;height:48px}.ai-chat-image-remove{cursor:pointer;color:var(--color-pewter,#a3a3a3);background:0 0;border:none;border-radius:4px;margin-left:auto;padding:4px;transition:color .15s;display:flex}.ai-chat-image-remove:hover{color:var(--color-error,#c44536)}.ai-product-card{border:1px solid var(--color-mist,#e5e5e5);background:var(--color-white,#fff);cursor:pointer;border-radius:10px;gap:14px;margin:6px 0;padding:10px 12px;transition:box-shadow .15s,border-color .15s,transform .1s;display:flex}.ai-product-card:hover{border-color:var(--color-copper,#b87333);transform:translateY(-1px);box-shadow:0 3px 12px #00000014}.ai-product-card-img{object-fit:contain;border-radius:8px;flex-shrink:0;width:72px;height:72px}.ai-product-card-info{flex-direction:column;flex:1;justify-content:center;gap:3px;min-width:0;display:flex}.ai-product-card-name{color:var(--color-charcoal,#1a1a1a);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13.5px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.ai-product-card-meta{color:var(--color-stone,#737373);white-space:nowrap;text-overflow:ellipsis;font-size:12px;line-height:1.35;overflow:hidden}.ai-product-card-footer{justify-content:space-between;align-items:center;gap:8px;margin-top:2px;display:flex}.ai-product-card-price{color:var(--color-charcoal,#1a1a1a);font-size:14px;font-weight:700}.ai-card-add-btn{border:1px solid var(--color-copper,#b87333);background:var(--color-white,#fff);color:var(--color-copper,#b87333);cursor:pointer;white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;line-height:1.4;transition:all .15s;display:inline-flex}.ai-card-add-btn:hover{background:var(--color-copper,#b87333);color:var(--color-white,#fff)}.ai-card-add-btn.added{border-color:var(--color-sage,#7c9082);background:var(--color-success-light,#e8f0ea);color:var(--color-sage,#7c9082);pointer-events:none}.ai-show-more-btn{border:1px dashed var(--color-mist,#e5e5e5);width:100%;color:var(--color-copper,#b87333);cursor:pointer;background:0 0;border-radius:10px;margin:6px 0;padding:10px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s,border-color .15s;display:block}.ai-show-more-btn:hover{background:var(--color-cloud,#f5f5f5);border-color:var(--color-copper,#b87333)}.ai-product-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;background:#1a1a1a80;justify-content:center;align-items:center;animation:.15s aiModalFadeIn;display:flex;position:fixed;inset:0}@keyframes aiModalFadeIn{0%{opacity:0}to{opacity:1}}.ai-product-modal{background:var(--color-white,#fff);border-radius:16px;width:440px;max-width:92vw;max-height:85vh;animation:.2s aiModalSlideUp;overflow-y:auto;box-shadow:0 24px 48px #0003}@keyframes aiModalSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ai-product-modal-header{justify-content:flex-end;padding:12px 16px 0;display:flex}.ai-product-modal-close{cursor:pointer;color:var(--color-pewter,#a3a3a3);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.ai-product-modal-close:hover{color:var(--color-charcoal,#1a1a1a);background:var(--color-cloud,#f5f5f5)}.ai-product-modal-body{flex-direction:column;align-items:center;gap:16px;padding:0 24px 24px;display:flex}.ai-product-modal-img{object-fit:contain;border-radius:12px;width:200px;height:200px}.ai-product-modal-title{color:var(--color-charcoal,#1a1a1a);text-align:center;margin:0;font-size:17px;font-weight:700;line-height:1.35}.ai-product-modal-specs{grid-template-columns:auto 1fr;gap:6px 16px;width:100%;font-size:13px;line-height:1.5;display:grid}.ai-product-modal-specs dt{color:var(--color-stone,#737373);white-space:nowrap;font-weight:500}.ai-product-modal-specs dd{color:var(--color-charcoal,#1a1a1a);margin:0}.ai-product-modal-desc{color:var(--color-slate,#404040);border-top:1px solid var(--color-mist,#e5e5e5);width:100%;padding-top:12px;font-size:13px;line-height:1.55}.ai-product-modal-price{color:var(--color-charcoal,#1a1a1a);font-size:22px;font-weight:700}.ai-product-modal-add{background:var(--color-charcoal,#1a1a1a);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;padding:12px;font-family:inherit;font-size:14px;font-weight:600;transition:background .15s,transform .1s}.ai-product-modal-add:hover:not(:disabled){background:var(--color-copper,#b87333)}.ai-product-modal-add:active:not(:disabled){transform:scale(.98)}.ai-product-modal-add.added{background:var(--color-sage,#7c9082);cursor:default}.ai-add-product-btn{border:1px solid var(--color-copper,#b87333);background:var(--color-white,#fff);color:var(--color-copper,#b87333);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:4px;padding:3px 10px;font-family:SF Mono,Consolas,monospace;font-size:12px;font-weight:600;line-height:1.4;transition:all .15s;display:inline-flex}.ai-add-product-btn:hover:not(:disabled){background:var(--color-copper,#b87333);color:var(--color-white,#fff)}.ai-add-icon{font-size:13px;font-weight:700;line-height:1}.ai-add-product-btn.ai-add-success{border-color:var(--color-sage,#7c9082);background:var(--color-success-light,#e8f0ea);color:var(--color-sage,#7c9082);cursor:default}.ai-add-product-btn.ai-add-error{border-color:var(--color-error,#c44536);color:var(--color-error,#c44536);cursor:not-allowed}.ai-comp-card{border-color:#e8a94f;position:relative}.ai-comp-card:hover{border-color:#d4912a;box-shadow:0 3px 12px #d4912a26}.ai-comp-card-badge{color:#9a6b1e;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;background:#fdf0d5;border-radius:4px;padding:2px 8px;font-size:10.5px;font-weight:700;line-height:1.4;display:inline-block}.ai-comp-card-name{color:var(--color-charcoal,#1a1a1a)}.ai-comp-card-code{color:var(--color-stone,#737373);font-family:SF Mono,Consolas,monospace;font-size:11px}.ai-comp-product-btn{color:#9a6b1e;cursor:pointer;white-space:nowrap;background:#fdf8ef;border:1px solid #e8a94f;border-radius:6px;align-items:center;gap:4px;padding:3px 10px;font-family:SF Mono,Consolas,monospace;font-size:12px;font-weight:600;line-height:1.4;transition:all .15s;display:inline-flex}.ai-comp-product-btn:hover{color:#fff;background:#e8a94f}.ai-comp-modal .ai-product-modal-header{justify-content:space-between;align-items:center}.ai-comp-modal-badge{color:#9a6b1e;text-transform:uppercase;letter-spacing:.3px;background:#fdf0d5;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:700}.ai-comp-modal-price small{color:var(--color-stone,#737373);font-size:12px;font-weight:400}.ai-comp-modal-link{color:#9a6b1e;text-align:center;background:#fdf0d5;border-radius:8px;width:100%;padding:10px 20px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s;display:inline-block}.ai-comp-modal-link:hover{background:#f5e0b5}.ai-comp-modal-loading{text-align:center;color:var(--color-stone,#737373);padding:32px;font-size:13px}.ai-chat-history-btn{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:6px;transition:opacity .15s,background .15s;display:flex}.ai-chat-history-btn:hover{opacity:1;background:#ffffff1a}.ai-chat-history-panel{background:var(--color-white,#fff);z-index:10;flex-direction:column;width:100%;height:100%;display:none;position:absolute;top:0;left:0}.ai-chat-history-panel.open{display:flex}.ai-chat-history-header{background:var(--color-charcoal,#1a1a1a);color:#fff;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.ai-chat-history-header h3{margin:0;font-size:15px;font-weight:600}.ai-chat-history-close{color:#fff;cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:6px;padding:6px;transition:opacity .15s;display:flex}.ai-chat-history-close:hover{opacity:1}.ai-chat-history-list{flex-direction:column;flex:1;gap:6px;padding:12px;display:flex;overflow-y:auto}.ai-chat-history-item{text-align:left;border:1px solid var(--color-mist,#e5e5e5);background:var(--color-white,#fff);cursor:pointer;border-radius:10px;width:100%;padding:12px 14px;font-family:inherit;transition:border-color .15s,background .15s;display:block}.ai-chat-history-item:hover{border-color:var(--color-copper,#b87333);background:var(--color-cloud,#f5f5f5)}.ai-chat-history-title{color:var(--color-charcoal,#1a1a1a);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:600;overflow:hidden}.ai-chat-history-meta{color:var(--color-stone,#737373);margin-top:3px;font-size:11px}.ai-chat-history-empty{text-align:center;color:var(--color-pewter,#a3a3a3);padding:40px 20px;font-size:13px}.ai-chat-restored{text-align:center;color:var(--color-pewter,#a3a3a3);background:var(--color-cloud,#f5f5f5);border-radius:12px;align-self:center;padding:6px 12px;font-size:11px}.ai-feedback-row{gap:2px;padding:4px 0 0 4px;display:flex}.ai-feedback-btn{cursor:pointer;color:var(--color-pewter,#a3a3a3);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px 6px;transition:color .15s,background .15s;display:flex}.ai-feedback-btn:hover{background:var(--color-cloud,#f5f5f5);color:var(--color-slate,#404040)}.ai-feedback-btn.active.ai-feedback-up{color:var(--color-sage,#7c9082);background:var(--color-success-light,#e8f0ea)}.ai-feedback-btn.active.ai-feedback-down{color:var(--color-error,#c44536);background:var(--color-error-light,#fbeae8)}@media (width<=580px){.ai-chat-panel{width:100vw;right:-100vw}.ai-chat-trigger{width:48px;height:48px;bottom:16px;right:16px}.ai-product-modal{width:95vw}}.uv-overlay{z-index:9000;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.uv-modal{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:1000px;max-height:88vh;animation:.15s ease-out uv-fade-in;display:flex;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000038}@keyframes uv-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.uv-header{border-bottom:1px solid #e5e7eb;flex-shrink:0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.uv-header h2{color:#111;text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;font-size:1.1rem;font-weight:600;overflow:hidden}.uv-close{cursor:pointer;color:#6b7280;background:#f3f4f6;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:18px;display:flex}.uv-close:hover{color:#111;background:#e5e7eb}.uv-body{flex:1;min-height:0;padding:20px;overflow-y:auto}.uv-search-prompt{max-width:500px;margin:3rem auto}.uv-search-prompt-label{color:#374151;text-align:center;margin-bottom:.75rem;font-size:.9rem;font-weight:600}.uv-search-wrap{margin-bottom:.5rem;position:relative}.uv-search-input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:8px;outline:none;width:100%;padding:10px 12px 10px 36px;font-size:.9rem}.uv-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.uv-search-icon{color:#9ca3af;pointer-events:none;font-size:.9rem;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.uv-search-results{background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-height:300px;margin-top:4px;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.uv-search-item{cursor:pointer;border-bottom:1px solid #f3f4f6;align-items:center;gap:.75rem;padding:.6rem .75rem;font-size:.85rem;display:flex}.uv-search-item:last-child{border-bottom:none}.uv-search-item:hover{background:#f9fafb}.uv-search-item img{object-fit:contain;background:#f9fafb;border-radius:4px;flex-shrink:0;width:36px;height:36px}.uv-search-item-info{flex:1;min-width:0}.uv-search-item-code{color:#111;font-weight:600;display:block}.uv-search-item-name{color:#6b7280;font-size:.8rem;display:block}.uv-search-item-type{color:#9ca3af;font-size:.75rem;display:block}.uv-layout{grid-template-columns:300px 1fr;gap:24px;min-height:400px;display:grid}.uv-product-detail{flex-direction:column;align-self:start;gap:12px;max-height:calc(88vh - 120px);display:flex;position:sticky;top:0;overflow-y:auto}.uv-product-img{object-fit:contain;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;width:100%;max-height:220px}.uv-product-img-placeholder{color:#d1d5db;background:#f3f4f6;border-radius:8px;justify-content:center;align-items:center;width:100%;height:140px;font-size:.85rem;display:flex}.uv-product-table{border-collapse:collapse;width:100%;font-size:.8rem}.uv-product-table td{vertical-align:top;padding:4px 0}.uv-product-table td:first-child{color:#9ca3af;text-transform:uppercase;letter-spacing:.3px;width:80px;padding-right:8px;font-size:.7rem;font-weight:600}.uv-features-cell{color:#374151;font-size:.75rem;line-height:1.5}.uv-matches-panel{flex-direction:column;min-width:0;display:flex}.uv-matches-heading{color:#111;margin-bottom:10px;font-size:.95rem;font-weight:600}.uv-matches-panel .uv-search-wrap{margin-bottom:12px}.uv-matches-panel .uv-seima-search{padding:9px 12px 9px 36px;font-size:.85rem}.uv-results-area{flex:1;min-height:0;overflow-y:auto}.uv-section-divider{border-top:1px dashed #e5e7eb;margin:4px 0 8px}.uv-section-title{text-transform:uppercase;letter-spacing:.5px;color:#9ca3af;margin-bottom:8px;font-size:.7rem;font-weight:700}.uv-match-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;flex-wrap:wrap;align-items:flex-start;gap:12px;margin-bottom:6px;padding:10px 12px;transition:border-color .15s;display:flex}.uv-match-card:hover{border-color:#93c5fd}.uv-card-expanded{border-width:2px;border-color:#93c5fd}.uv-card-expanded>.uv-match-img,.uv-card-expanded .uv-match-desc-preview,.uv-card-expanded .uv-match-spec,.uv-card-expanded .uv-match-reasons,.uv-card-expanded .uv-match-right{display:none}.uv-match-img{object-fit:contain;cursor:pointer;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;flex-shrink:0;width:90px;height:90px;transition:box-shadow .15s,border-color .15s}.uv-match-img:hover{border-color:#93c5fd;transform:scale(1.05);box-shadow:0 2px 8px #0000001f}.uv-match-body{flex:1;min-width:0}.uv-match-name{color:#111;font-size:.85rem;font-weight:600}.uv-match-meta{color:#9ca3af;margin-top:2px;font-size:.75rem}.uv-match-spec{color:#6b7280;margin-top:2px;font-size:.75rem}.uv-match-desc-preview{color:#9ca3af;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:3px;font-size:.73rem;line-height:1.4;display:-webkit-box;overflow:hidden}.uv-match-reasons{color:#9ca3af;margin-top:2px;font-size:.7rem;font-style:italic}.uv-match-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:6px;display:flex}.uv-match-price{color:#111;white-space:nowrap;font-size:.85rem;font-weight:600}.uv-btn-match{cursor:pointer;color:#fff;white-space:nowrap;background:#2563eb;border:1px solid #1d4ed8;border-radius:6px;padding:5px 12px;font-size:.75rem;font-weight:600;transition:background .15s}.uv-btn-match:hover{background:#1d4ed8}.uv-btn-match:disabled{opacity:.5;cursor:not-allowed}.uv-match-expanded{border-top:1px solid #f3f4f6;gap:16px;width:100%;margin-top:8px;padding-top:12px;animation:.2s ease-out uv-expand-in;display:flex}@keyframes uv-expand-in{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.uv-expanded-img{object-fit:contain;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;flex-shrink:0;width:240px;height:200px}.uv-expanded-details{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.uv-expanded-specs{color:#374151;grid-template-columns:1fr 1fr;gap:4px 16px;font-size:.8rem;display:grid}.uv-expanded-label{color:#9ca3af;text-transform:uppercase;letter-spacing:.3px;margin-right:6px;font-size:.7rem;font-weight:600}.uv-expanded-desc{color:#6b7280;margin-top:4px;font-size:.78rem;line-height:1.5}.uv-btn-match-expanded{align-self:flex-end;margin-top:auto;padding:7px 16px;font-size:.8rem}.uv-badge{vertical-align:middle;border-radius:8px;margin-left:4px;padding:2px 6px;font-size:.65rem;font-weight:600;display:inline-block}.uv-badge-high{color:#15803d;background:#dcfce7}.uv-badge-med{color:#92400e;background:#fef3c7}.uv-badge-low{color:#b91c1c;background:#fee2e2}.uv-no-equivalent{text-align:center;border-top:1px dashed #e5e7eb;margin-top:12px;padding-top:12px}.uv-no-equivalent-btn{color:#9ca3af;cursor:pointer;text-underline-offset:2px;background:0 0;border:none;padding:4px 8px;font-size:.8rem;text-decoration:underline}.uv-no-equivalent-btn:hover{color:#6b7280}.uv-footer{border-top:1px solid #e5e7eb;flex-shrink:0;padding:.75rem 1.5rem}.uv-notice{color:#92400e;background:#fef3c7;border-radius:8px;align-items:center;gap:.5rem;padding:.6rem .75rem;font-size:.8rem;display:flex}.uv-notice-icon{flex-shrink:0;font-size:1rem}.uv-confirm-overlay{z-index:10;background:#00000059;border-radius:12px;justify-content:center;align-items:center;animation:.12s ease-out uv-fade-in;display:flex;position:absolute;inset:0}.uv-confirm-box{text-align:center;background:#fff;border-radius:12px;max-width:380px;padding:28px 32px;box-shadow:0 12px 40px #0000002e}.uv-confirm-message{color:#111;margin-bottom:8px;font-size:.95rem;line-height:1.5}.uv-confirm-product{color:#2563eb;margin-bottom:20px;font-size:.85rem;font-weight:600}.uv-confirm-actions{justify-content:center;gap:10px;display:flex}.uv-confirm-cancel{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:8px 20px;font-size:.85rem;font-weight:500;transition:background .15s}.uv-confirm-cancel:hover{background:#f3f4f6}.uv-confirm-done{cursor:pointer;color:#fff;background:#2563eb;border:1px solid #1d4ed8;border-radius:8px;padding:8px 20px;font-size:.85rem;font-weight:600;transition:background .15s}.uv-confirm-done:hover{background:#1d4ed8}.uv-toast{z-index:9999;opacity:0;pointer-events:none;text-align:center;border-radius:10px;max-width:500px;padding:12px 24px;font-size:.9rem;font-weight:500;transition:opacity .3s,transform .3s;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(20px)}.uv-toast-success{color:#92400e;background:#fef3c7;border:1px solid #f59e0b}.uv-toast-error{color:#991b1b;background:#fee2e2;border:1px solid #ef4444}.uv-toast-visible{opacity:1;transform:translate(-50%)translateY(0)}.uv-empty{text-align:center;color:#9ca3af;padding:1.5rem;font-size:.85rem}.uv-login-prompt{text-align:center;padding:3rem 1rem}.uv-login-prompt p{color:#6b7280;margin-bottom:1rem}.uv-login-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:.5rem 1.25rem;font-size:.9rem}.uv-login-btn:hover{background:#1d4ed8}@media (width<=700px){.uv-layout{grid-template-columns:1fr}.uv-modal{max-width:96vw;max-height:94vh}.uv-expanded-img{width:160px;height:140px}}
