:root{--grad-start: #7c3aed;--grad-end: #06b6d4;--accent: #06b6d4;--accent2: #7c3aed;--bg: #f8f8fc;--surface: #ffffff;--text: #111827;--muted: #6b7280;--border: #e5e7eb;--card-shadow: 0 2px 16px rgba(0, 0, 0, .07)}[data-theme=dark]{--bg: #0f0e1a;--surface: #1a1826;--text: #f1f0f8;--muted: #9ca3af;--border: #2d2b42;--card-shadow: 0 2px 20px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);transition:background .3s,color .3s;min-height:100vh;display:flex;flex-direction:column}#root{display:flex;flex-direction:column;min-height:100vh}header{background:linear-gradient(120deg,var(--grad-start),var(--grad-end));padding:0 2rem;height:72px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.logo-wrap{display:flex;align-items:center;gap:12px;text-decoration:none}.logo-img{width:52px;height:52px;border-radius:8px;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:#fff;border:2px solid rgba(255,255,255,.3);flex-shrink:0;font-family:Playfair Display,serif}.logo-text{font-family:Playfair Display,serif;font-size:1.35rem;color:#fff;letter-spacing:-.3px}nav{display:flex;align-items:center;gap:.25rem}.nav-btn{background:transparent;border:none;color:#ffffffe6;cursor:pointer;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;padding:8px 14px;border-radius:8px;display:flex;align-items:center;gap:6px;transition:background .2s}.nav-btn:hover{background:#ffffff26}.nav-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2}.badge{background:#ef4444;color:#fff;border-radius:50%;width:18px;height:18px;font-size:.7rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;margin-left:2px}.form-group{margin-bottom:1.2rem}.form-label{display:block;font-weight:600;font-size:.85rem;color:var(--text);margin-bottom:6px}.form-label span{color:#ef4444}select,input[type=number],input[type=text],input[type=email],input[type=tel],input[type=password],textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:10px;font-family:DM Sans,sans-serif;font-size:.95rem;background:var(--bg);color:var(--text);transition:border-color .2s;outline:none}select:focus,input:focus,textarea:focus{border-color:var(--accent2)}input[type=password]{display:block!important;width:100%!important;box-sizing:border-box!important;-webkit-appearance:none!important;-moz-appearance:none!important;appearance:none!important;padding:10px 14px!important;border:1.5px solid var(--border)!important;border-radius:10px!important;font-family:DM Sans,sans-serif!important;font-size:.95rem!important;background:var(--bg)!important;color:var(--text)!important}.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:#111827;color:#fff;border:none;border-radius:12px;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:600;cursor:pointer;margin-top:1.2rem;transition:background .2s,transform .1s}.btn-primary:hover{background:#1f2937;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2}.btn-ghost{background:var(--surface);border:1.5px solid var(--border);border-radius:8px;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;color:var(--text);cursor:pointer;transition:border-color .15s;padding:8px 16px}.btn-ghost:hover{border-color:var(--muted)}.products-wrapper{flex:1;display:flex;flex-direction:column}.products-section{padding:2rem 2rem 4rem;max-width:1200px;margin:0 auto;flex:1;width:100%}.products-section h2{text-align:center;font-family:Playfair Display,serif;font-size:2rem;margin-bottom:2rem;color:var(--text)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1.2rem}.product-card{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:1.5rem 1.25rem 1.25rem;text-align:center;box-shadow:var(--card-shadow);transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column}.product-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #7c3aed24;border-color:var(--accent2)}.product-card.active-card{border-color:var(--accent2);box-shadow:0 0 0 3px #7c3aed26}.product-name{font-weight:700;font-size:1rem;color:var(--text);margin-bottom:8px}.product-price{font-size:1.5rem;font-weight:800;color:var(--accent);margin-bottom:4px}.product-unit{font-size:.78rem;color:var(--muted);margin-bottom:1rem}.btn-view-details{width:100%;padding:9px 14px;border:2px solid var(--accent2);border-radius:10px;background:transparent;color:var(--accent2);font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .2s,color .2s;margin-top:auto}.btn-view-details:hover{background:var(--accent2);color:#fff}.btn-view-details svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.2;flex-shrink:0}.overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:200;justify-content:flex-end;align-items:stretch}.overlay.show{display:flex}.quotes-panel{background:var(--surface);width:420px;max-width:100vw;padding:2rem 1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.panel-header h2{font-family:Playfair Display,serif;font-size:1.5rem}.close-btn{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1.4rem;line-height:1;padding:4px}.close-btn:hover{color:var(--text)}.quote-item{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:1rem 1.25rem;position:relative}.quote-item-name{font-weight:700;font-size:.95rem;margin-bottom:3px}.quote-item-price-unit{font-size:.82rem;color:var(--muted);margin-bottom:10px}.quote-item-row{display:flex;align-items:center;justify-content:space-between}.qty-wrap{display:flex;align-items:center;gap:8px;font-size:.85rem}.qty-input{width:72px;padding:6px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:.9rem;background:var(--surface);color:var(--text)}.quote-item-total{font-weight:700;font-size:.95rem}.remove-btn{position:absolute;top:10px;right:10px;background:none;border:none;color:#ef4444;cursor:pointer;font-size:1.1rem}.quote-summary{background:#eff6ff;border-radius:12px;padding:1.25rem;margin-top:auto}[data-theme=dark] .quote-summary{background:#7c3aed1a}.quote-summary h3{font-weight:700;font-size:1rem;margin-bottom:.8rem}.summary-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--muted);padding:2px 0}.summary-row.bold{font-weight:700;color:var(--text);font-size:1rem}.summary-note{font-size:.78rem;color:var(--muted);margin-top:8px;font-style:italic}.empty-quote{text-align:center;color:var(--muted);padding:3rem 1rem;font-size:.95rem}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;align-items:center;justify-content:center;padding:1rem}.modal-overlay.show{display:flex}.modal{background:var(--surface);border-radius:20px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;padding:2rem;animation:fadeUp .3s ease}.account-modal{max-width:560px}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{font-family:Playfair Display,serif;font-size:1.4rem}.section-label{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:1rem 0 .5rem}.order-detail-card{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:.75rem 1rem;display:flex;justify-content:space-between;margin-bottom:6px;font-size:.9rem}.order-detail-qty{color:var(--muted);font-size:.82rem;margin-top:2px}.order-detail-file{color:var(--accent2);font-size:.78rem;margin-top:3px;font-weight:500}.modal-price-summary{background:#eff6ff;border-radius:12px;padding:1.2rem;margin:1rem 0}[data-theme=dark] .modal-price-summary{background:#7c3aed1a}.mps-title{font-weight:700;font-size:.95rem;margin-bottom:.8rem}.mps-row{display:flex;justify-content:space-between;font-size:.87rem;color:var(--muted);padding:2px 0}.mps-row.total-row{border-top:1.5px solid var(--border);margin-top:8px;padding-top:10px;font-weight:800;font-size:1rem;color:var(--text)}.mps-row.total-row .amount{color:var(--accent);font-size:1.15rem}.mode-toggle-group{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1rem}.mode-toggle-option{cursor:pointer}.mode-toggle-option input[type=radio]{display:none}.mode-toggle-card{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:2px solid var(--border);border-radius:12px;transition:border-color .2s,background .2s;background:var(--bg)}.mode-toggle-option input[type=radio]:checked+.mode-toggle-card{border-color:var(--accent2);background:#7c3aed0f}.mode-toggle-card svg{flex-shrink:0;margin-top:2px;color:var(--muted)}.mode-toggle-option input[type=radio]:checked+.mode-toggle-card svg{color:var(--accent2)}.design-notes-box{display:flex;gap:10px;align-items:flex-start;background:#7c3aed0d;border:1.5px solid rgba(124,58,237,.2);border-radius:12px;padding:12px 14px}.design-notes-box textarea{background:transparent;border:none;padding:0;font-size:.9rem;resize:vertical}.design-notes-box textarea:focus{border:none;box-shadow:none}.proof-pay-banner{display:flex;align-items:center;gap:8px;background:#10b9811a;border:1.5px solid rgba(16,185,129,.25);border-radius:10px;padding:10px 14px;font-size:.88rem;font-weight:600;color:#059669;margin-bottom:1.2rem}#square-card-container,#proof-pay-card-container{min-height:80px;margin-bottom:0;padding:12px;background:#ffffffeb;border-radius:10px;overflow:hidden}#square-card-container iframe,#proof-pay-card-container iframe{max-width:100%!important;border-radius:10px}#payment-status-container{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:500;color:#374151!important;padding:0 12px;min-height:0;background:transparent}#payment-status-container:not(:empty){padding:6px 12px 8px}#payment-status-container *{color:#374151!important}.signin-modal .modal-header{align-items:flex-start;margin-bottom:1.5rem}.signin-subtitle{font-size:.88rem;color:var(--muted);margin-top:4px;font-weight:400}.signin-switch{text-align:center;font-size:.85rem;color:var(--muted);margin-top:1.2rem}.signin-switch a{color:var(--accent2);font-weight:600;text-decoration:none}.signin-switch a:hover{text-decoration:underline}.account-details-section{border:1.5px solid var(--border);border-radius:12px;padding:12px 16px;margin-bottom:.5rem}.account-details-section summary{font-weight:600;font-size:.9rem;cursor:pointer;color:var(--text);list-style:none;display:flex;align-items:center;justify-content:space-between}.account-details-section summary:after{content:"﹢";font-size:1.2rem;color:var(--muted)}.account-details-section[open] summary:after{content:"－"}.order-card{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:1rem 1.25rem;margin-bottom:8px}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(100px);background:#111827;color:#fff;padding:12px 24px;border-radius:50px;font-size:.9rem;font-weight:500;z-index:500;transition:transform .3s;pointer-events:none;white-space:nowrap;max-width:90vw;text-align:center}.toast.show{transform:translate(-50%) translateY(0)}.admin-panel{background:var(--surface);width:100%;max-width:1100px;margin:auto;border-radius:20px;overflow:hidden;display:flex;flex-direction:column;height:88vh;min-height:560px;max-height:92vh;box-shadow:0 24px 80px #0006;animation:fadeUp .3s ease}.admin-panel-header{background:linear-gradient(120deg,#7c3aed,#06b6d4);padding:0 1.5rem;height:60px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;flex-wrap:wrap;gap:8px}.admin-tab-bar{display:flex;background:#0003;border-radius:8px;padding:3px;gap:2px}.admin-tab{display:flex;align-items:center;gap:6px;padding:6px 14px;background:transparent;border:none;border-radius:6px;color:#ffffffb3;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.admin-tab:hover{color:#ffffffe6}.admin-tab.active{background:#fff3;color:#fff}.admin-tab svg{opacity:.8}.admin-tab.active svg{opacity:1}.admin-signout-btn{padding:7px 16px;background:#ffffff26;border:1.5px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.admin-signout-btn:hover{background:#ffffff40}.admin-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.admin-products-pane{display:grid;grid-template-columns:380px 1fr;flex:1;overflow:hidden}.admin-orders-pane{flex:1;overflow:hidden}.admin-orders-layout{display:grid;grid-template-columns:320px 1fr;height:100%;overflow:hidden}.admin-orders-list{overflow-y:auto;border-right:1px solid var(--border);padding:10px;display:flex;flex-direction:column;gap:6px}.admin-order-detail{overflow-y:auto;display:flex;flex-direction:column}.admin-order-card{border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;cursor:pointer;transition:border-color .15s,background .15s}.admin-order-card:hover{border-color:#7c3aed66;background:#7c3aed08}.admin-order-card.active{border-color:#7c3aed;background:#7c3aed0d}.admin-detail-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.admin-detail-section:last-child{border-bottom:none}.admin-detail-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}.admin-list-col{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.admin-list-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.admin-count-badge{font-size:11px;font-weight:700;background:#7c3aed1f;color:#7c3aed;padding:2px 8px;border-radius:20px;margin-left:6px}.admin-add-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;border:none;border-radius:8px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .2s;box-shadow:0 3px 10px #7c3aed59}.admin-add-btn:hover{opacity:.9}.admin-product-list{overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:7px;flex:1}.admin-product-list::-webkit-scrollbar{width:4px}.admin-product-list::-webkit-scrollbar-thumb{background:#7c3aed40;border-radius:4px}.admin-product-card{border:1.5px solid var(--border);border-radius:11px;padding:12px 14px;cursor:pointer;transition:border-color .15s,box-shadow .15s;display:flex;align-items:center;animation:fadeIn .25s ease both}.admin-product-card:hover{border-color:#7c3aed66;box-shadow:0 2px 10px #7c3aed1a}.admin-product-card.active{border-color:#7c3aed;background:#7c3aed0d}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.admin-product-name{font-size:14px;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-product-desc{font-size:12px;color:var(--muted);margin-bottom:6px}.admin-product-price{font-size:14px;font-weight:700;color:var(--accent)}.admin-icon-btn{width:32px;height:32px;border-radius:7px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;color:var(--muted)}.admin-icon-btn svg{width:15px;height:15px}.admin-icon-btn.edit:hover{background:#7c3aed1f;color:#7c3aed}.admin-icon-btn.del:hover{background:#ef44441a;color:#ef4444}.admin-edit-col{display:flex;flex-direction:column;overflow:hidden}.admin-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center}.admin-edit-form{padding:24px;flex-direction:column;gap:16px;overflow-y:auto;flex:1}.admin-mode-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}.admin-mode-badge.new{background:#7c3aed26;color:#7c3aed}.admin-mode-badge.edit{background:#06b6d426;color:#06b6d4}.admin-field{display:flex;flex-direction:column;gap:6px}.admin-field label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.admin-field input,.admin-field textarea{padding:11px 13px;border:1.5px solid var(--border);border-radius:9px;font-family:DM Sans,sans-serif;font-size:14px;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s,box-shadow .2s;resize:none}.admin-field input:focus,.admin-field textarea:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.admin-save-btn{flex:1;padding:11px;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;border:none;border-radius:9px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s;box-shadow:0 3px 10px #7c3aed4d}.admin-save-btn:hover{opacity:.9}.admin-save-btn:disabled{opacity:.6;cursor:not-allowed}.admin-cancel-btn{padding:11px 20px;background:var(--surface);border:1.5px solid var(--border);border-radius:9px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;transition:border-color .15s}.admin-cancel-btn:hover{border-color:var(--muted)}#adminNavBtn{color:#ffd700f2}#adminNavBtn:hover{background:#ffffff26}@media (max-width: 700px){.admin-products-pane{grid-template-columns:1fr}.admin-list-col{border-right:none;border-bottom:1px solid var(--border);max-height:40vh}.admin-orders-layout{grid-template-columns:1fr}.admin-orders-list{max-height:40vh;border-right:none;border-bottom:1px solid var(--border)}.mode-toggle-group{grid-template-columns:1fr}.logo-text{font-size:1rem}.quotes-panel{width:100vw}.admin-panel-header{height:auto;padding:10px 1rem}}.pd-modal{max-width:600px;padding:0;overflow:hidden;display:flex;flex-direction:column;max-height:92vh}.pd-header{background:linear-gradient(120deg,#7c3aed,#06b6d4);padding:1.75rem 2rem;display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-shrink:0}.pd-name{font-family:Playfair Display,serif;font-size:1.4rem;color:#fff;line-height:1.25;margin-bottom:6px}.pd-price-tag{display:inline-flex;align-items:center;gap:6px;background:#ffffff2e;border:1px solid rgba(255,255,255,.3);border-radius:30px;padding:4px 14px;font-size:.9rem;font-weight:700;color:#fff}.pd-body{padding:1.75rem 2rem 2rem;overflow-y:auto;flex:1}.pd-body::-webkit-scrollbar{width:4px}.pd-body::-webkit-scrollbar-thumb{background:#7c3aed33;border-radius:4px}.pd-desc{font-size:.92rem;color:var(--muted);line-height:1.6;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.pd-section-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--muted);margin-bottom:10px}.pd-qty-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.qty-stepper{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:10px;overflow:hidden}.qty-stepper button{width:40px;height:40px;background:var(--bg);border:none;color:var(--text);font-size:1.2rem;font-weight:500;cursor:pointer;transition:background .15s;line-height:1}.qty-stepper button:hover{background:#7c3aed14}.qty-stepper-val{min-width:48px;text-align:center;font-size:1rem;font-weight:700;color:var(--text);background:var(--surface);height:40px;display:flex;align-items:center;justify-content:center;border-left:1.5px solid var(--border);border-right:1.5px solid var(--border)}.pd-est-total{font-size:.88rem;color:var(--muted)}.pd-est-total strong{color:var(--accent);font-size:1.05rem}.pd-mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1.5rem}.pd-mode-card{border:2px solid var(--border);border-radius:14px;padding:1.1rem 1rem;background:var(--bg);cursor:pointer;text-align:left;transition:border-color .18s,background .18s,box-shadow .18s;display:flex;flex-direction:column;gap:8px;font-family:DM Sans,sans-serif}.pd-mode-card:hover{border-color:#7c3aed66}.pd-mode-card.active{border-color:#7c3aed;background:#7c3aed0f;box-shadow:0 0 0 3px #7c3aed1a}.pd-mode-icon{width:36px;height:36px;border-radius:9px;background:#7c3aed1a;display:flex;align-items:center;justify-content:center;color:#7c3aed;flex-shrink:0}.pd-mode-card.active .pd-mode-icon{background:#7c3aed26}.pd-mode-title{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.3}.pd-mode-sub{font-size:.76rem;color:var(--muted);line-height:1.4}.pd-panel{animation:fadeUp .2s ease}.pd-quote-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;border:none;border-radius:12px;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;margin-top:1rem;transition:opacity .2s,transform .1s;box-shadow:0 4px 14px #7c3aed59}.pd-quote-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.pd-quote-btn:disabled{opacity:.6;cursor:not-allowed}.pd-dropzone{border:2px dashed var(--border);border-radius:14px;transition:border-color .2s,background .2s;margin-bottom:1rem}.pd-dropzone.dragging{border-color:#7c3aed;background:#7c3aed0a}.pd-dropzone-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:2rem 1rem;cursor:pointer;text-align:center}.pd-dropzone-text{font-size:.9rem;font-weight:600;color:var(--text)}.pd-dropzone-hint{font-size:.78rem;color:var(--muted)}.pd-file-attached{display:flex;align-items:center;gap:12px;padding:1rem 1.25rem}.pd-file-name{flex:1;font-size:.88rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pd-file-remove{font-size:.78rem;color:#ef4444;background:none;border:none;cursor:pointer;font-family:DM Sans,sans-serif;flex-shrink:0}.pd-cart-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;background:linear-gradient(135deg,#06b6d4,#0891b2);color:#fff;border:none;border-radius:12px;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s;box-shadow:0 4px 14px #06b6d459}.pd-cart-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.pd-cart-btn:disabled{opacity:.45;cursor:not-allowed}.pd-btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}.quote-success-icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#7c3aed26,#06b6d426);margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center}.quote-success-checkmark{width:28px;height:28px;stroke:#7c3aed;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.qh-card{background:var(--bg);border:1.5px solid var(--border);border-radius:13px;padding:1rem 1.1rem;margin-bottom:.6rem;animation:fadeUp .25s ease both;transition:border-color .15s}.qh-card:hover{border-color:#7c3aed59}.qh-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.qh-product-name{font-weight:700;font-size:.95rem;color:var(--text);line-height:1.3}.qh-status-badge{font-size:.7rem;font-weight:700;padding:3px 9px;border-radius:20px;flex-shrink:0;text-transform:uppercase;letter-spacing:.05em}.qh-meta{display:flex;gap:14px;font-size:.83rem;color:var(--muted);margin-bottom:6px}.qh-meta strong{color:var(--text)}.qh-notes{font-size:.8rem;color:var(--muted);font-style:italic;line-height:1.4;margin-bottom:8px;padding:6px 10px;background:#7c3aed0d;border-radius:7px;border-left:3px solid rgba(124,58,237,.3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qh-footer{display:flex;justify-content:space-between;align-items:center;margin-top:6px}.qh-date{font-size:.75rem;color:var(--muted)}.qh-remove-btn{font-size:.75rem;color:#ef4444;background:none;border:none;cursor:pointer;font-family:DM Sans,sans-serif;padding:0;opacity:.7;transition:opacity .15s}.qh-remove-btn:hover{opacity:1;text-decoration:underline}.hero{position:relative;width:100%;height:540px;overflow:hidden;flex-shrink:0}@media (max-width: 700px){.hero{height:360px}}.slides-track{display:flex;width:100%;height:100%;transition:transform .7s cubic-bezier(.77,0,.175,1)}.slide{min-width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.slide-1{background:linear-gradient(135deg,#1a0533,#3b0764 40%,#0c4a6e)}.slide-2{background:linear-gradient(135deg,#064e3b,#065f46 40%,#0c4a6e)}.slide-3{background:linear-gradient(135deg,#1e1b4b,#312e81 40%,#4c1d95)}.slide-4{background:linear-gradient(135deg,#450a0a,#7f1d1d 40%,#1a0533)}.slide:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to right,#000000a6,#0000004d 55%,#0000000d);pointer-events:none}.slide-content{position:relative;z-index:2;max-width:1100px;width:100%;padding:0 3rem}@media (max-width: 700px){.slide-content{padding:0 1.5rem}}.slide-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#06b6d4;margin-bottom:14px;display:flex;align-items:center;gap:10px}.slide-eyebrow:not(:empty):before{content:"";display:block;width:28px;height:2px;background:var(--eyebrow-line, #06b6d4);border-radius:2px;flex-shrink:0}.slide-headline{font-family:Playfair Display,serif;font-size:clamp(2rem,5vw,3.6rem);line-height:1.1;color:#fff;margin-bottom:18px;max-width:560px}.slide-headline em{font-style:italic;color:#a78bfa}.slide-body{font-size:1rem;color:#ffffffc7;line-height:1.65;max-width:420px;margin-bottom:28px}@media (max-width: 700px){.slide-body{display:none}.slide-headline{font-size:2rem;margin-bottom:20px}}.slide-cta{display:inline-flex;align-items:center;gap:10px;padding:13px 28px;background:linear-gradient(135deg,#7c3aed,#06b6d4);color:#fff;border:none;border-radius:50px;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;text-decoration:none;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px #7c3aed66}.slide-cta:hover{transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed80}.slide-cta svg{width:16px;height:16px;flex-shrink:0}.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:44px;height:44px;border-radius:50%;background:#ffffff1f;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1.5px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.hero-arrow:hover{background:#ffffff40}.hero-arrow.prev{left:20px}.hero-arrow.next{right:20px}.hero-arrow svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}@media (max-width: 700px){.hero-arrow{display:none}}.hero-controls{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:10;display:flex;align-items:center;gap:8px}.hero-dot{width:8px;height:8px;border-radius:50%;background:#ffffff59;border:none;cursor:pointer;padding:0;transition:background .3s,width .3s,border-radius .3s}.hero-dot.active{background:#fff;width:22px;border-radius:4px}.hero-progress{position:absolute;bottom:0;left:0;height:3px;background:linear-gradient(90deg,#7c3aed,#06b6d4);z-index:10;width:0%}.how-section{padding:5rem 2rem;background:var(--surface);position:relative;overflow:hidden}.how-section:before{content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.07) 0%,transparent 70%);pointer-events:none}.how-inner{max-width:1100px;margin:0 auto;position:relative;z-index:1}.how-label{text-align:center;font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent2);margin-bottom:12px}.how-title{text-align:center;font-family:Playfair Display,serif;font-size:clamp(1.8rem,3.5vw,2.5rem);color:var(--text);margin-bottom:.6rem;line-height:1.2}.how-subtitle{text-align:center;font-size:1rem;color:var(--muted);margin-bottom:3.5rem;max-width:480px;margin-left:auto;margin-right:auto;line-height:1.6}.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;position:relative}.how-grid:before{content:"";position:absolute;top:38px;left:calc(16.67% + 20px);right:calc(16.67% + 20px);height:2px;background:linear-gradient(90deg,#7c3aed,#06b6d4);opacity:.2;z-index:0}.how-step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:2rem 1.5rem;border-radius:20px;border:1.5px solid var(--border);background:var(--bg);position:relative;z-index:1;transition:border-color .2s,box-shadow .2s,transform .2s}.how-step:hover{border-color:#7c3aed59;box-shadow:0 8px 32px #7c3aed1a;transform:translateY(-4px)}.how-step-number{position:absolute;top:-14px;left:50%;transform:translate(-50%);width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#06b6d4);color:#fff;font-size:.7rem;font-weight:800;display:flex;align-items:center;justify-content:center}.how-icon{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#7c3aed1a,#06b6d41a);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;flex-shrink:0}.how-icon svg{width:28px;height:28px;stroke:var(--accent2);fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.how-step-title{font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:10px}.how-step-body{font-size:.88rem;color:var(--muted);line-height:1.65}@media (max-width: 700px){.how-grid{grid-template-columns:1fr;gap:2.5rem}.how-grid:before{display:none}.how-section{padding:3.5rem 1.5rem}}.products-cta-section{padding:5rem 2rem;background:var(--bg);text-align:center}.products-cta-inner{max-width:640px;margin:0 auto}.products-cta-eyebrow{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}.products-cta-title{font-family:Playfair Display,serif;font-size:clamp(1.8rem,3.5vw,2.4rem);color:var(--text);margin-bottom:1rem;line-height:1.2}.products-cta-sub{font-size:1rem;color:var(--muted);line-height:1.65;margin-bottom:2.25rem}.products-cta-btn{display:inline-flex;align-items:center;gap:10px;padding:15px 36px;background:linear-gradient(135deg,#7c3aed,#06b6d4);color:#fff;border:none;border-radius:50px;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:700;text-decoration:none;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px #7c3aed59}.products-cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed80}.products-cta-btn svg{width:18px;height:18px;flex-shrink:0}.products-page-back{margin-bottom:1rem}.products-back-link{display:inline-flex;align-items:center;gap:6px;font-size:.88rem;font-weight:600;color:var(--muted);text-decoration:none;transition:color .15s}.products-back-link:hover{color:var(--accent2)}.products-back-link svg{stroke:currentColor;fill:none}.admin-settings-section{border:1.5px solid var(--border);border-radius:14px;padding:20px 22px;margin-bottom:20px;background:var(--bg)}.admin-settings-section-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:18px;display:flex;align-items:center;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--border)}.admin-settings-section-title svg{color:var(--accent2);stroke:currentColor;flex-shrink:0}

/* === AUDIT PATCH 2026-06-09: ultrawide hero — scale height with viewport and cap width so cover-crop stays reasonable on ultrawide monitors === */
@media (min-width: 701px){.hero{height:clamp(540px,30vw,800px);max-width:2200px;margin:0 auto}}

/* === AUDIT PATCH 2026-06-09 (visual review): dist-level fixes, ship with deploy === */

/* V7 — reserve product-card title height so 1-line and 2-line titles keep the
   price row aligned across a grid row */
.product-name{min-height:2.8em;display:flex;align-items:center;justify-content:center;text-align:center}

/* V4 — hero headline legibility scrim. Per-slide headline colors (white/gray/red)
   sit over photos with no contrast guarantee; the gray "Flyers" headline nearly
   vanishes. Left-anchored dark scrim + text-shadow rescue legibility without
   darkening the whole image. */
.hero .slide::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(100deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.22) 38%,rgba(0,0,0,0) 68%);z-index:1}
.hero .slide-content{position:relative;z-index:2}
.hero .slide-headline{text-shadow:0 2px 14px rgba(0,0,0,.55)}
.hero .slide-eyebrow{text-shadow:0 1px 8px rgba(0,0,0,.5)}

/* V10 — footer stacks to one column on small screens (was a fixed 1.5fr/1fr/1fr
   grid that overflowed the viewport -> horizontal page scroll) */
@media (max-width:640px){
  footer>div{grid-template-columns:1fr !important;gap:1.5rem !important;text-align:left}
  footer{padding:2.25rem 1.25rem 1.5rem !important}
}

/* V9 — partial mobile-nav compaction. Header doesn't collapse to a hamburger
   (true fix needs JS — see AUDIT.md); this keeps brand + actions on one line at
   phone widths by trimming type, padding and gaps. */
@media (max-width:600px){
  header{padding:0 .9rem;gap:6px}
  header .logo-wrap span{font-size:1.05rem;line-height:1.12}
  header .nav-btn{font-size:.78rem;padding:6px 8px;gap:5px}
  header .nav-btn svg{width:15px;height:15px}
}
@media (max-width:400px){
  header .logo-wrap span{font-size:.92rem}
  header .nav-btn{font-size:.72rem;padding:5px 6px;gap:4px}
}
