.product-details-island{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:999999;display:flex;align-items:center;justify-content:center;margin:0;padding:0}.product-details-island .modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999998}@media (prefers-color-scheme: dark){.product-details-island .modal-overlay{background:#000c}}.product-details-island .modal-content{position:relative;background:var(--background-color, white);color:var(--text-color, #111827);border-radius:12px;max-width:900px;max-height:90vh;width:90%;overflow:hidden;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;z-index:999999;margin:auto}@media (prefers-color-scheme: dark){.product-details-island .modal-content{background:#1f2937;color:#f9fafb}}.product-details-island .modal-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.product-details-island .modal-header h2{margin:0;font-size:1.5rem;color:inherit}.product-details-island .close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6b7280;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.product-details-island .close-btn:hover{background:#f3f4f6;color:#111827}@media (prefers-color-scheme: dark){.product-details-island .close-btn:hover{background:#374151;color:#f9fafb}}.product-details-island .modal-body{flex:1;overflow-y:auto;padding:1.5rem}.product-main-info{display:grid;grid-template-columns:300px 1fr;gap:2rem;margin-bottom:2rem}.product-image{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#f9fafb}.product-image img{width:100%;height:100%;object-fit:contain}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:.875rem}.product-details{display:flex;flex-direction:column;gap:1rem}.sku{color:#6b7280;font-size:.875rem}.base-price{font-size:1.75rem;font-weight:600;color:#059669}.description{color:#4b5563;line-height:1.6}.product-details-island .loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:#6b7280}.product-details-island .spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.product-details-island .configuration-section{border-top:1px solid #e5e7eb;padding-top:1.5rem}.product-details-island .config-section{margin-bottom:2rem;padding:1rem;background:#f9fafb;border-radius:8px}@media (prefers-color-scheme: dark){.product-details-island .config-section{background:#374151}}.product-details-island .config-section h4{margin:0 0 1rem;color:inherit;font-size:1rem;font-weight:600}.product-details-island .config-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid #e5e7eb}.product-details-island .config-item:last-child{border-bottom:none}.product-details-island .item-info{display:flex;align-items:center;gap:.75rem;flex:1}.product-details-island .item-name{color:inherit}.product-details-island .required-badge{background:#dc2626;color:#fff;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.product-details-island .item-pricing{display:flex;align-items:center;gap:1rem}.product-details-island .quantity-input{width:80px;padding:.5rem;border:1px solid #d1d5db;border-radius:6px;text-align:center;background:#fff}@media (prefers-color-scheme: dark){.product-details-island .quantity-input{background:#1f2937;border-color:#4b5563;color:#f9fafb}}.product-details-island .price{font-weight:600;color:#059669;min-width:80px;text-align:right}.product-details-island .choice-group-section{margin-bottom:1.5rem;padding:.75rem;border-radius:6px;transition:all .2s}.product-details-island .choice-group-section.has-error{background-color:#fef2f2;border:1px solid #ef4444}.product-details-island .choice-group-title{font-weight:500;color:#ea580c;margin-bottom:.75rem;font-size:.875rem}.product-details-island .choice-group-section.has-error .choice-group-title{color:#dc2626}.product-details-island .choice-group-options{display:flex;flex-direction:column;gap:.5rem}.product-details-island .radio-option{display:flex;align-items:center;padding:.75rem;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s}.product-details-island .radio-option:hover{background:#f9fafb;border-color:#ea580c}.product-details-island input[type=radio]{margin-right:.75rem;cursor:pointer}.product-details-island .radio-label{flex:1;color:inherit}.product-details-island .radio-price{font-weight:600;color:#059669}@media (prefers-color-scheme: dark){.product-details-island .radio-option{background:#1f2937;border-color:#4b5563}.product-details-island .radio-option:hover{background:#374151;border-color:#ea580c}}.product-details-island input[type=checkbox]{margin-right:.75rem;cursor:pointer}.product-details-island .checkbox-disabled{opacity:.6;cursor:not-allowed}.product-details-island .pricing-summary{background:#f9fafb;border-radius:8px;padding:1.5rem;margin-top:2rem}@media (prefers-color-scheme: dark){.product-details-island .pricing-summary{background:#374151}}.product-details-island .applied-rules{background:#dbeafe;color:#1e40af;padding:.5rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}@media (prefers-color-scheme: dark){.product-details-island .applied-rules{background:#1e3a8a;color:#dbeafe}}.product-details-island .total-price{display:flex;justify-content:space-between;align-items:center;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.product-details-island .total-price .price{font-size:1.5rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-success{background:#10b981;color:#fff;width:100%}.btn-success:hover:not(:disabled){background:#059669}.btn:disabled{opacity:.5;cursor:not-allowed}.debug-panel{position:absolute;bottom:1rem;right:1rem;background:#000c;color:#fff;padding:1rem;border-radius:8px;font-family:monospace;font-size:.75rem;max-width:300px}.debug-panel h4{margin:0 0 .5rem;color:#fbbf24}.debug-panel pre{margin:0;white-space:pre-wrap;word-break:break-all}@media (max-width: 768px){.modal-content{width:100%;height:100%;max-height:100vh;border-radius:0}.product-main-info{grid-template-columns:1fr;gap:1rem}.product-image{max-width:200px;margin:0 auto}.config-item{flex-direction:column;align-items:stretch;gap:.5rem}.item-pricing{justify-content:space-between}}
