/* ============================================================
   DLStore Frontend CSS - Temelden bağımsız, tema override'a açık
   ============================================================ */

/* CSS Variables - Admin'den override edilir (tema head'de yazılır) */
:root {
    --dls-primary:      #f5a623;
    --dls-primary-dark: #e6941a;
    --dls-bg:           #0d1117;
    --dls-bg-2:         #161b22;
    --dls-bg-card:      #1c2128;
    --dls-border:       rgba(255,255,255,.1);
    --dls-text:         #e6edf3;
    --dls-text-muted:   #8b949e;
    --dls-success:      #3fb950;
    --dls-danger:       #f85149;
    --dls-radius:       10px;
    --dls-shadow:       0 4px 24px rgba(0,0,0,.3);
}
[data-theme="light"] {
    --dls-bg:       #f0f2f8;
    --dls-bg-2:     #ffffff;
    --dls-bg-card:  #ffffff;
    --dls-border:   rgba(0,0,0,.1);
    --dls-text:     #1a1a2e;
    --dls-text-muted: #555;
    --dls-shadow:   0 4px 24px rgba(0,0,0,.08);
}

/* ========================
   BUTONLAR
======================== */
.dlstore-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 20px; border: none; border-radius: var(--dls-radius);
    font-size: 14px; font-weight: 600; cursor: pointer;
    text-decoration: none; transition: all .2s;
}
.dlstore-btn-primary { background: var(--dls-primary); color: #fff; }
.dlstore-btn-primary:hover { background: var(--dls-primary-dark); color: #fff; transform: translateY(-1px); }
.dlstore-btn-secondary { background: var(--dls-bg-card); color: var(--dls-text); border: 1px solid var(--dls-border); }
.dlstore-btn-secondary:hover { border-color: var(--dls-primary); color: var(--dls-primary); }
.dlstore-btn-danger { background: var(--dls-danger); color: #fff; }
.dlstore-btn-sm { padding: 6px 14px; font-size: 13px; }
.dlstore-btn-lg { padding: 14px 32px; font-size: 16px; }

/* ========================
   CART ICON (header'da)
======================== */
.dlstore-cart-icon {
    position: relative; cursor: pointer; display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 12px; border-radius: var(--dls-radius);
    background: var(--dls-bg-card); color: var(--dls-text);
    border: 1px solid var(--dls-border); text-decoration: none;
    transition: all .2s;
}
.dlstore-cart-icon:hover { border-color: var(--dls-primary); color: var(--dls-primary); }
.dlstore-cart-count {
    position: absolute; top: -6px; right: -6px;
    background: var(--dls-primary); color: #fff;
    width: 18px; height: 18px; border-radius: 50%;
    font-size: 11px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
}
.dlstore-cart-count[data-count="0"] { display: none; }

/* ========================
   MINI CART DROPDOWN
======================== */
.dlstore-mini-cart-wrap {
    position: relative;
}
.dlstore-mini-cart-dropdown {
    position: absolute; top: calc(100% + 8px); right: 0;
    width: 320px; background: var(--dls-bg-card);
    border: 1px solid var(--dls-border); border-radius: var(--dls-radius);
    box-shadow: var(--dls-shadow); z-index: 1000;
    display: none;
}
.dlstore-mini-cart-dropdown.open { display: block; }
.dlstore-mini-cart-empty { padding: 24px; text-align: center; color: var(--dls-text-muted); }
.dlstore-mini-cart-empty span { font-size: 32px; display: block; margin-bottom: 8px; }
.dlstore-mini-item { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 1px solid var(--dls-border); }
.dlstore-mini-item-info { flex: 1; }
.dlstore-mini-item-name { font-size: 13px; font-weight: 600; color: var(--dls-text); }
.dlstore-mini-item-price { font-size: 12px; color: var(--dls-primary); margin-top: 2px; }
.dlstore-mini-remove { background: none; border: none; cursor: pointer; color: var(--dls-text-muted); font-size: 14px; padding: 4px; }
.dlstore-mini-remove:hover { color: var(--dls-danger); }
.dlstore-mini-cart-footer { padding: 12px 16px; }
.dlstore-mini-cart-total { display: flex; justify-content: space-between; font-size: 14px; font-weight: 600; margin-bottom: 10px; color: var(--dls-text); }
.dlstore-mini-cart-actions { display: flex; gap: 8px; }
.dlstore-mini-cart-actions .dlstore-btn { flex: 1; justify-content: center; }

/* ========================
   CART PAGE
======================== */
.dlstore-cart-page { max-width: 1100px; margin: 0 auto; padding: 40px 20px; }
.dlstore-cart-title { font-size: 28px; font-weight: 700; color: var(--dls-text); margin-bottom: 28px; }
.dlstore-cart-empty { text-align: center; padding: 60px 20px; color: var(--dls-text-muted); }
.dlstore-cart-layout { display: grid; grid-template-columns: 1fr 360px; gap: 24px; }
@media (max-width: 768px) { .dlstore-cart-layout { grid-template-columns: 1fr; } }
.dlstore-cart-table { width: 100%; border-collapse: collapse; }
.dlstore-cart-table th { padding: 12px 16px; text-align: left; font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: var(--dls-text-muted); border-bottom: 1px solid var(--dls-border); }
.dlstore-cart-table td { padding: 14px 16px; border-bottom: 1px solid var(--dls-border); vertical-align: middle; color: var(--dls-text); }
.dlstore-cart-product { display: flex; align-items: center; gap: 12px; }
.dlstore-cart-product-name { font-weight: 600; color: var(--dls-text); text-decoration: none; }
.dlstore-cart-product-name:hover { color: var(--dls-primary); }
.dlstore-cart-thumb { width: 48px; height: 48px; object-fit: cover; border-radius: 6px; }
.dlstore-cart-variation { font-size: 12px; color: var(--dls-text-muted); display: block; }
.dlstore-license-badge { display: inline-block; background: rgba(245,166,35,.15); color: var(--dls-primary); padding: 2px 7px; border-radius: 4px; font-size: 11px; font-weight: 700; }
.dlstore-qty-control { display: flex; align-items: center; gap: 0; border: 1px solid var(--dls-border); border-radius: 6px; overflow: hidden; width: fit-content; }
.dlstore-qty-minus, .dlstore-qty-plus { background: var(--dls-bg-2); border: none; cursor: pointer; padding: 6px 12px; font-size: 16px; color: var(--dls-text); transition: background .2s; }
.dlstore-qty-minus:hover, .dlstore-qty-plus:hover { background: var(--dls-primary); color: #fff; }
.dlstore-qty-input { width: 48px; text-align: center; border: none; background: var(--dls-bg-card); color: var(--dls-text); font-size: 14px; padding: 6px 0; }
.dlstore-cart-remove { background: none; border: none; cursor: pointer; color: var(--dls-text-muted); font-size: 16px; padding: 6px; border-radius: 4px; }
.dlstore-cart-remove:hover { color: var(--dls-danger); background: rgba(248,81,73,.1); }
.dlstore-cart-summary-box { background: var(--dls-bg-card); border: 1px solid var(--dls-border); border-radius: var(--dls-radius); padding: 20px; position: sticky; top: 20px; }
.dlstore-cart-summary-box h3 { font-size: 16px; font-weight: 700; color: var(--dls-text); margin: 0 0 16px; }
.dlstore-cart-total-row { display: flex; justify-content: space-between; font-size: 14px; padding: 8px 0; border-bottom: 1px solid var(--dls-border); color: var(--dls-text); }
.dlstore-cart-grand-total { font-size: 18px; font-weight: 700; border-bottom: none; color: var(--dls-primary); padding-top: 12px; }
.dlstore-coupon-form { margin: 16px 0; }
.dlstore-coupon-input-wrap { display: flex; gap: 8px; }
.dlstore-coupon-input-wrap input { flex: 1; padding: 9px 12px; border: 1.5px solid var(--dls-border); border-radius: 6px; background: var(--dls-bg); color: var(--dls-text); font-size: 13px; }
.dlstore-coupon-input-wrap input:focus { outline: none; border-color: var(--dls-primary); }
.dlstore-checkout-btn { width: 100%; justify-content: center; margin-top: 16px; font-size: 15px; padding: 14px; }

/* ========================
   CHECKOUT PAGE
======================== */
.dlstore-checkout-page { max-width: 1100px; margin: 0 auto; padding: 40px 20px; }
.dlstore-checkout-layout { display: grid; grid-template-columns: 1fr 380px; gap: 24px; }
@media (max-width: 768px) { .dlstore-checkout-layout { grid-template-columns: 1fr; } }
.dlstore-checkout-form-wrap h2 { font-size: 22px; font-weight: 700; color: var(--dls-text); margin-bottom: 24px; }
.dlstore-form-group { margin-bottom: 18px; }
.dlstore-form-group label { display: block; font-size: 13px; font-weight: 600; color: var(--dls-text); margin-bottom: 6px; }
.dlstore-form-group .required { color: var(--dls-danger); }
.dlstore-form-group input[type="text"],
.dlstore-form-group input[type="email"],
.dlstore-form-group input[type="tel"] {
    width: 100%; padding: 12px 16px; border: 1.5px solid var(--dls-border);
    border-radius: var(--dls-radius); background: var(--dls-bg-card);
    color: var(--dls-text); font-size: 14px; box-sizing: border-box;
    transition: border-color .2s;
}
.dlstore-form-group input:focus { outline: none; border-color: var(--dls-primary); }
.dlstore-form-group .description { font-size: 12px; color: var(--dls-text-muted); margin-top: 4px; }
.dlstore-payment-methods { margin: 24px 0; }
.dlstore-payment-methods h3 { font-size: 15px; font-weight: 700; color: var(--dls-text); margin-bottom: 12px; }
.dlstore-payment-option {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 16px; border: 1.5px solid var(--dls-border);
    border-radius: var(--dls-radius); cursor: pointer; margin-bottom: 8px;
    background: var(--dls-bg-card); color: var(--dls-text);
    transition: all .2s;
}
.dlstore-payment-option:hover { border-color: var(--dls-primary); }
.dlstore-payment-option.active { border-color: var(--dls-primary); background: rgba(245,166,35,.08); }
.dlstore-place-order-btn { width: 100%; justify-content: center; font-size: 16px; padding: 16px; margin-top: 8px; }
.dlstore-checkout-summary { background: var(--dls-bg-card); border: 1px solid var(--dls-border); border-radius: var(--dls-radius); padding: 20px; position: sticky; top: 20px; }
.dlstore-checkout-summary h3 { font-size: 16px; font-weight: 700; color: var(--dls-text); margin: 0 0 16px; }
.dlstore-checkout-item { display: flex; justify-content: space-between; padding: 8px 0; border-bottom: 1px solid var(--dls-border); font-size: 13px; color: var(--dls-text); }
.dlstore-checkout-grand { font-weight: 700; font-size: 16px; color: var(--dls-primary); border-bottom: none; }
.dlstore-checkout-trust { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 20px; }
.dlstore-checkout-trust div { font-size: 12px; color: var(--dls-text-muted); background: var(--dls-bg-2); padding: 8px 10px; border-radius: 6px; text-align: center; }

/* ========================
   TEŞEKKÜR SAYFASI
======================== */
.dlstore-thankyou-page { max-width: 700px; margin: 40px auto; padding: 0 20px; }
.dlstore-thankyou-hero { text-align: center; padding: 40px; background: var(--dls-bg-card); border-radius: var(--dls-radius); border: 1px solid var(--dls-border); margin-bottom: 24px; }
.dlstore-thankyou-icon { font-size: 56px; margin-bottom: 16px; }
.dlstore-thankyou-hero h1 { font-size: 26px; font-weight: 700; color: var(--dls-text); margin: 0 0 12px; }
.dlstore-thankyou-hero p { color: var(--dls-text-muted); }
.dlstore-order-key-badge { display: inline-block; background: rgba(245,166,35,.15); color: var(--dls-primary); padding: 8px 20px; border-radius: 20px; font-size: 14px; font-weight: 700; margin-top: 12px; letter-spacing: 1px; }
.dlstore-thankyou-licenses h2 { font-size: 18px; font-weight: 700; color: var(--dls-text); margin-bottom: 16px; }
.dlstore-license-delivery-card { background: var(--dls-bg-card); border: 1px solid var(--dls-border); border-radius: var(--dls-radius); padding: 20px; margin-bottom: 16px; }
.dlstore-license-product-name { font-size: 13px; color: var(--dls-text-muted); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 12px; }
.dlstore-license-key-display { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.dlstore-license-key-display code { background: #0d1117; color: var(--dls-primary); padding: 12px 16px; border-radius: 8px; font-family: 'Courier New', monospace; font-size: 15px; letter-spacing: 2px; word-break: break-all; flex: 1; }
.dlstore-activation-link { display: inline-block; margin-top: 12px; font-size: 13px; color: var(--dls-primary); text-decoration: none; }

/* ========================
   UPSELL POPUP
======================== */
.dlstore-upsell-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.7); z-index: 9999;
    display: flex; align-items: center; justify-content: center; padding: 20px;
    opacity: 0; pointer-events: none; transition: opacity .3s;
}
.dlstore-upsell-overlay.open { opacity: 1; pointer-events: all; }
.dlstore-upsell-modal {
    background: var(--dls-bg-card); border-radius: 16px; padding: 32px;
    max-width: 560px; width: 100%; position: relative;
    border: 1px solid var(--dls-border);
    transform: scale(.95); transition: transform .3s;
    max-height: 90vh; overflow-y: auto;
}
.dlstore-upsell-overlay.open .dlstore-upsell-modal { transform: scale(1); }
.dlstore-upsell-close { position: absolute; top: 16px; right: 16px; background: none; border: none; cursor: pointer; color: var(--dls-text-muted); font-size: 20px; }
.dlstore-upsell-header { margin-bottom: 20px; }
.dlstore-upsell-header h3 { font-size: 20px; font-weight: 700; color: var(--dls-text); margin: 0 0 6px; }
.dlstore-upsell-header p { color: var(--dls-text-muted); font-size: 14px; margin: 0; }
.dlstore-upsell-products { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }
.dlstore-upsell-product { display: flex; align-items: center; gap: 14px; padding: 14px; border: 1.5px solid var(--dls-border); border-radius: var(--dls-radius); cursor: pointer; transition: all .2s; }
.dlstore-upsell-product:hover { border-color: var(--dls-primary); background: rgba(245,166,35,.05); }
.dlstore-upsell-product img { width: 56px; height: 56px; object-fit: cover; border-radius: 8px; }
.dlstore-upsell-product-info { flex: 1; }
.dlstore-upsell-product-name { font-size: 14px; font-weight: 600; color: var(--dls-text); }
.dlstore-upsell-product-meta { font-size: 12px; color: var(--dls-text-muted); margin-top: 2px; }
.dlstore-upsell-product-price { font-size: 18px; font-weight: 700; color: var(--dls-primary); }
.dlstore-upsell-add-btn { white-space: nowrap; }
.dlstore-upsell-skip { display: block; text-align: center; color: var(--dls-text-muted); font-size: 13px; cursor: pointer; text-decoration: underline; }

/* ========================
   NOTICE
======================== */
.dlstore-notice { padding: 12px 16px; border-radius: var(--dls-radius); margin-bottom: 16px; border-left: 4px solid; }
.dlstore-notice--success { background: rgba(63,185,80,.1); border-color: var(--dls-success); color: var(--dls-text); }
.dlstore-notice--error { background: rgba(248,81,73,.1); border-color: var(--dls-danger); color: var(--dls-text); }
.dlstore-notice p { margin: 0; font-size: 13px; }

/* ========================
   ACCOUNT PAGE
======================== */
.dlstore-account-page { max-width: 800px; margin: 0 auto; padding: 40px 20px; }
.dlstore-account-lookup { max-width: 420px; }
.dlstore-lookup-form { display: flex; flex-direction: column; gap: 12px; }
.dlstore-lookup-form input { padding: 12px 16px; border: 1.5px solid var(--dls-border); border-radius: var(--dls-radius); background: var(--dls-bg-card); color: var(--dls-text); font-size: 14px; }
.dlstore-account-order { background: var(--dls-bg-card); border: 1px solid var(--dls-border); border-radius: var(--dls-radius); margin-bottom: 16px; overflow: hidden; }
.dlstore-account-order-header { display: flex; align-items: center; gap: 12px; padding: 14px 16px; border-bottom: 1px solid var(--dls-border); flex-wrap: wrap; }
.dlstore-order-key { font-weight: 700; color: var(--dls-text); font-size: 13px; }
.dlstore-account-licenses { padding: 14px 16px; }
.dlstore-account-license { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--dls-border); flex-wrap: wrap; }
.dlstore-account-license code { font-family: monospace; font-size: 13px; color: var(--dls-primary); background: var(--dls-bg-2); padding: 4px 10px; border-radius: 4px; }

/* ========================
   WHATSAPP BUTONU
======================== */
.dlstore-whatsapp-btn {
    position: fixed; bottom: 24px; right: 24px; z-index: 999;
    background: #25d366; color: #fff; border-radius: 50px;
    padding: 12px 18px; display: flex; align-items: center; gap: 8px;
    text-decoration: none; font-weight: 600; font-size: 14px;
    box-shadow: 0 4px 20px rgba(37,211,102,.4);
    transition: all .2s;
}
.dlstore-whatsapp-btn:hover { background: #20bc5a; color: #fff; transform: translateY(-2px); }
.dlstore-whatsapp-btn svg { width: 20px; height: 20px; }

/* ========================
   MOBILE
======================== */
@media (max-width: 600px) {
    .dlstore-checkout-summary { order: -1; position: static; }
    .dlstore-cart-table th:nth-child(2),
    .dlstore-cart-table td:nth-child(2) { display: none; }
    .dlstore-upsell-modal { padding: 20px; }
    .dlstore-place-order-btn { position: sticky; bottom: 0; border-radius: 0; margin: 0 -20px; width: calc(100% + 40px); }
}
