/* =========================================
   PLISSEE SHOP — Frontend Styles
   ========================================= */

:root {
    --plissee-primary:    #2C5F6E;
    --plissee-accent:     #E8A830;
    --plissee-light:      #F7F4EF;
    --plissee-text:       #2A2A2A;
    --plissee-muted:      #6B7280;
    --plissee-border:     #E5E0D8;
    --plissee-radius:     10px;
    --plissee-shadow:     0 4px 20px rgba(0,0,0,.08);
    --plissee-transition: .25s ease;
}

/* ── Layout ──────────────────────────────── */
.plissee-shop-wrap,
.plissee-konfigurator-wrap {
    font-family: 'Georgia', serif;
    color: var(--plissee-text);
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

/* ── Category Nav ────────────────────────── */
.plissee-category-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 32px;
}
.cat-btn {
    padding: 8px 20px;
    border: 2px solid var(--plissee-border);
    border-radius: 30px;
    background: #fff;
    color: var(--plissee-text);
    cursor: pointer;
    font-size: .9rem;
    transition: var(--plissee-transition);
}
.cat-btn:hover,
.cat-btn.active {
    background: var(--plissee-primary);
    border-color: var(--plissee-primary);
    color: #fff;
}

/* ── Product Grid ────────────────────────── */
.plissee-product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 24px;
}
.plissee-product-card {
    background: #fff;
    border: 1px solid var(--plissee-border);
    border-radius: var(--plissee-radius);
    overflow: hidden;
    box-shadow: var(--plissee-shadow);
    transition: transform var(--plissee-transition), box-shadow var(--plissee-transition);
    display: flex;
    flex-direction: column;
}
.plissee-product-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 36px rgba(0,0,0,.13);
}
.plissee-product-card.hidden { display: none; }

/* Product Image */
.product-image {
    position: relative;
    height: 200px;
    overflow: hidden;
}
.product-image img {
    width: 100%; height: 100%;
    object-fit: cover;
}
.product-image-placeholder {
    width: 100%; height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    letter-spacing: 6px;
}
.plissee-icon {
    opacity: .3;
    font-size: 5rem;
    letter-spacing: 8px;
    user-select: none;
}

/* Light Badge */
.light-badge {
    position: absolute;
    top: 12px; right: 12px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: .75rem;
    font-weight: bold;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.light-tageslicht   { background: #FEF3C7; color: #92400E; }
.light-verdunkelung { background: #1F2937; color: #F9FAFB; }
.light-sonnenschutz { background: #DBEAFE; color: #1E40AF; }
.light-sichtschutz  { background: #D1FAE5; color: #065F46; }

/* Product Info */
.product-info {
    padding: 20px;
    flex: 1;
}
.product-info h3 {
    margin: 0 0 8px;
    font-size: 1.1rem;
    color: var(--plissee-primary);
}
.product-color {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 8px;
    font-size: .85rem;
    color: var(--plissee-muted);
}
.color-dot {
    width: 14px; height: 14px;
    border-radius: 50%;
    border: 1px solid rgba(0,0,0,.15);
    display: inline-block;
    flex-shrink: 0;
}
.product-desc {
    font-size: .85rem;
    color: var(--plissee-muted);
    line-height: 1.5;
    margin: 0 0 12px;
}
.product-pricing {
    display: flex;
    align-items: baseline;
    gap: 6px;
    margin-bottom: 4px;
}
.price-from { font-size: .8rem; color: var(--plissee-muted); }
.price-main { font-size: 1.5rem; font-weight: bold; color: var(--plissee-primary); }
.price-sub  { font-size: .8rem; color: var(--plissee-muted); }
.product-sizes { font-size: .78rem; color: var(--plissee-muted); }

/* Product Actions */
.product-actions {
    padding: 16px 20px;
    border-top: 1px solid var(--plissee-border);
}

/* ── Buttons ─────────────────────────────── */
.btn-primary {
    display: inline-block;
    width: 100%;
    padding: 12px 24px;
    background: var(--plissee-primary);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-size: .95rem;
    cursor: pointer;
    transition: background var(--plissee-transition);
    text-align: center;
}
.btn-primary:hover { background: #1d4a57; }
.btn-primary:disabled { background: #9CA3AF; cursor: not-allowed; }
.btn-secondary {
    display: inline-block;
    padding: 11px 24px;
    background: #fff;
    color: var(--plissee-primary);
    border: 2px solid var(--plissee-primary);
    border-radius: 8px;
    font-size: .95rem;
    cursor: pointer;
    transition: var(--plissee-transition);
}
.btn-secondary:hover { background: var(--plissee-light); }
.btn-configure { font-family: inherit; }

/* ── Modal ───────────────────────────────── */
.plissee-modal {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.55);
    backdrop-filter: blur(2px);
}
.modal-content {
    position: relative;
    z-index: 1;
    background: #fff;
    border-radius: 16px;
    padding: 36px;
    max-width: 520px;
    width: 90%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 24px 60px rgba(0,0,0,.25);
}
.modal-content h2 { margin-top: 0; color: var(--plissee-primary); }
.modal-close {
    position: absolute;
    top: 16px; right: 20px;
    background: none;
    border: none;
    font-size: 1.6rem;
    cursor: pointer;
    color: var(--plissee-muted);
    line-height: 1;
}
.modal-close:hover { color: var(--plissee-text); }

/* ── Config Modal ────────────────────────── */
.config-hint { font-size:.88rem; color:var(--plissee-muted); margin:0 0 18px; }
.measure-inputs { display: grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:20px; }
.measure-group label { display:block; font-size:.85rem; font-weight:600; margin-bottom:4px; }
.measure-group input {
    width: 100%;
    padding: 10px 12px;
    border: 2px solid var(--plissee-border);
    border-radius: 8px;
    font-size: 1rem;
    box-sizing: border-box;
    transition: border-color var(--plissee-transition);
}
.measure-group input:focus {
    outline: none;
    border-color: var(--plissee-primary);
}
.measure-limits { display:block; font-size:.75rem; color:var(--plissee-muted); margin-top:3px; }

.price-display {
    background: var(--plissee-light);
    border: 1px solid var(--plissee-border);
    border-radius: 10px;
    padding: 16px;
    margin: 0 0 16px;
    text-align: center;
}
.price-result { font-size:1.2rem; }
.price-result strong { font-size:2rem; color:var(--plissee-primary); margin-left:6px; }
.config-error {
    background: #FEF2F2;
    border: 1px solid #FECACA;
    color: #B91C1C;
    border-radius: 8px;
    padding: 10px 14px;
    font-size:.88rem;
    margin-bottom:12px;
}

/* ── Cart ─────────────────────────────────── */
.plissee-cart {
    position: fixed;
    top: 0; right: 0;
    width: 360px;
    height: 100vh;
    background: #fff;
    box-shadow: -8px 0 40px rgba(0,0,0,.15);
    z-index: 9998;
    display: flex;
    flex-direction: column;
}
.cart-header {
    padding: 20px;
    border-bottom: 1px solid var(--plissee-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.cart-header h3 { margin: 0; color: var(--plissee-primary); }
.cart-close { background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--plissee-muted); }
.cart-items { flex:1; overflow-y:auto; padding:16px; }
.cart-item {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
    padding: 12px 0;
    border-bottom: 1px solid var(--plissee-border);
    font-size: .88rem;
}
.cart-item-name { font-weight:600; }
.cart-item-detail { color:var(--plissee-muted); }
.cart-item-price { font-weight:700; color:var(--plissee-primary); }
.cart-item-remove { color:#EF4444;cursor:pointer;background:none;border:none;font-size:1rem;padding:0; }
.cart-total {
    padding: 16px 20px;
    border-top: 2px solid var(--plissee-border);
    font-size:1.1rem;
    text-align: right;
}
.cart-total strong { font-size:1.4rem; color:var(--plissee-primary); }
.plissee-cart .btn-primary { margin:0 20px 20px; width:calc(100% - 40px); }

/* Cart FAB */
.cart-fab { position:fixed; bottom:24px; right:24px; z-index:9997; }
.cart-fab button {
    background: var(--plissee-primary);
    color: #fff;
    border: none;
    border-radius: 30px;
    padding: 14px 24px;
    font-size: 1rem;
    cursor: pointer;
    box-shadow: 0 6px 24px rgba(44,95,110,.4);
    transition: var(--plissee-transition);
}
.cart-fab button:hover { background:#1d4a57; }
#cart-count-badge {
    background: var(--plissee-accent);
    color: #1a1a1a;
    border-radius: 50%;
    padding: 2px 7px;
    font-weight: bold;
    font-size:.85rem;
    margin-left:4px;
}

/* ── Checkout Form ────────────────────────── */
.modal-checkout { max-width:560px; }
.form-row { margin-bottom:14px; }
.form-row label { display:block; font-size:.85rem; font-weight:600; margin-bottom:4px; color:var(--plissee-text); }
.form-row input, .form-row textarea {
    width:100%;
    padding: 10px 12px;
    border: 2px solid var(--plissee-border);
    border-radius: 8px;
    font-size: .95rem;
    font-family: inherit;
    box-sizing: border-box;
    transition: border-color var(--plissee-transition);
}
.form-row input:focus, .form-row textarea:focus {
    outline:none;
    border-color: var(--plissee-primary);
}

/* Success */
.checkout-success { text-align:center; padding:20px 0; }
.success-icon { font-size:3rem; margin-bottom:12px; }
.checkout-success h3 { color:var(--plissee-primary); }

/* ── Konfigurator ────────────────────────── */
.konfig-steps-nav {
    display: flex;
    gap: 0;
    margin-bottom: 32px;
    border-radius: var(--plissee-radius);
    overflow: hidden;
    border: 1px solid var(--plissee-border);
}
.konfig-step-tab {
    flex: 1;
    padding: 14px;
    text-align: center;
    background: var(--plissee-light);
    color: var(--plissee-muted);
    font-size: .9rem;
    cursor: default;
    border-right: 1px solid var(--plissee-border);
    transition: var(--plissee-transition);
}
.konfig-step-tab:last-child { border-right:none; }
.konfig-step-tab.active { background:var(--plissee-primary); color:#fff; font-weight:600; }
.konfig-step-tab.done   { background:#D1FAE5; color:#065F46; }

.konfig-step-content h2 { color:var(--plissee-primary); margin-top:0; }
.konfig-product-list { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:12px; margin-bottom:24px; }
.konfig-product-option input { display:none; }
.option-card {
    display:flex; gap:14px; align-items:center;
    padding:14px; border-radius:var(--plissee-radius);
    border:2px solid var(--plissee-border);
    cursor:pointer; transition:var(--plissee-transition);
    background:#fff;
}
.konfig-product-option input:checked + .option-card {
    border-color:var(--plissee-primary);
    box-shadow: 0 0 0 3px rgba(44,95,110,.15);
}
.option-swatch { width:42px;height:42px;border-radius:8px;border:1px solid rgba(0,0,0,.1);flex-shrink:0; }
.option-info { display:flex;flex-direction:column;gap:2px; font-size:.88rem; }
.option-info strong { font-size:.95rem; }
.option-info span { color:var(--plissee-muted); font-size:.82rem; }
.option-info em { color:var(--plissee-primary); font-weight:600; font-style:normal; }

.konfig-measure-help { display:flex; gap:32px; align-items:flex-start; margin-bottom:24px; }
.measure-illustration { flex-shrink:0; }
.measure-inputs-konfig { flex:1; }
.measure-field { margin-bottom:14px; }
.measure-field label { display:block; font-size:.85rem; font-weight:600; margin-bottom:4px; }
.measure-field input {
    width:100%; padding:10px 12px;
    border:2px solid var(--plissee-border);
    border-radius:8px; font-size:1rem; box-sizing:border-box;
    transition:border-color var(--plissee-transition);
}
.measure-field input:focus { outline:none; border-color:var(--plissee-primary); }
.hint { display:block; font-size:.75rem; color:var(--plissee-muted); margin-top:3px; }
.konfig-price-box {
    background:var(--plissee-light); border:1px solid var(--plissee-border);
    border-radius:10px; padding:14px; text-align:center; margin-bottom:12px;
}
.price-badge { font-size:1.1rem; }
.price-badge strong { font-size:1.7rem; color:var(--plissee-primary); margin-left:4px; }

.konfig-nav { display:flex; gap:12px; margin-top:12px; }
.konfig-nav .btn-primary { flex:1; }

.konfig-summary {
    background:var(--plissee-light); border:1px solid var(--plissee-border);
    border-radius:var(--plissee-radius); padding:16px; margin-bottom:20px; font-size:.9rem;
}
.konfig-summary strong { color:var(--plissee-primary); }

.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-grid .full { grid-column:1/-1; }

/* ── Responsive ───────────────────────────── */
@media (max-width: 640px) {
    .plissee-product-grid { grid-template-columns:1fr; }
    .measure-inputs { grid-template-columns:1fr; }
    .plissee-cart { width:100%; }
    .konfig-measure-help { flex-direction:column; }
    .form-grid { grid-template-columns:1fr; }
}
