/* Google Fonts Import */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');

:root {
    --arkaplan: #EDF2FF; 
    --kutu-arkaplan: #FFFFFF; 
    --border-renk: #DDE5F2; 
    --metin-rengi: #1c1c38; 
    --metin-gri: #5a5a72; 
    --ana-vurgu: #c039de; 
    --ikincil-vurgu: #5F27CD;
    --whatsapp-yesil: #25D366;
}

#sps-paket-hesaplayici-root {
    font-family: 'Poppins', sans-serif;
    background-color: var(--arkaplan);
    color: var(--metin-rengi);
    padding: 35px;
    border-radius: 18px;
    margin: 40px auto;
    box-shadow: 0 8px 32px rgba(67, 83, 110, 0.15);
    overflow: hidden;
}

#sps-paket-hesaplayici-root h2 {
    text-align: center; margin-bottom: 35px; font-weight: 700; font-size: 2.5rem;
    background: linear-gradient(-45deg, var(--ikincil-vurgu), var(--ana-vurgu), var(--ikincil-vurgu));
    background-size: 300% 300%;
    -webkit-background-clip: text; background-clip: text; color: transparent;
    animation: textGradientShine 5s linear infinite;
}

.sps-secenek-grubu { margin-bottom: 30px; }
.sps-secenek-grubu label { display: block; font-size: 1rem; font-weight: 500; margin-bottom: 15px; color: var(--metin-gri); }

.sps-secenek-butonlari { display: flex; flex-wrap: wrap; gap: 12px; }
.sps-sure-butonlari { display: grid; grid-template-columns: repeat(3, 1fr); }

.sps-secenek-butonlari button {
    border: 1px solid var(--border-renk); border-radius: 10px; cursor: pointer; transition: all 0.3s ease; 
    font-size: 0.95rem; font-weight: 500; background-color: var(--kutu-arkaplan); 
    color: var(--metin-gri); font-family: 'Poppins', sans-serif; padding: 10px 15px;
    flex: 1 1 auto; display: flex; align-items: center; justify-content: center;
    text-align: center; min-height: 50px; line-height: 1.3; word-break: break-word;
}
.sps-sure-butonlari button { flex: none; }

.sps-secenek-butonlari button.active {
    color: #ffffff; border-color: transparent; box-shadow: 0 0 20px rgba(192, 57, 222, 0.4); 
    transform: translateY(-2px);
    background-image: linear-gradient(45deg, var(--ikincil-vurgu), var(--ana-vurgu));
    background-size: 250% auto; animation: gradientShine 3s linear infinite; 
}

.sps-secenek-butonlari button:not(.active):hover { border-color: var(--ikincil-vurgu); color: var(--ikincil-vurgu); }
.sps-sonuc-alani { margin-top: 40px; padding: 30px; background-color: var(--kutu-arkaplan); border-radius: 12px; min-height: 300px; }
.sps-fiyat-bolumu { display: flex; justify-content: space-between; align-items: center; padding-bottom: 20px; margin-bottom: 20px; }
.sps-fiyat-etiketi { font-size: 1.1rem; font-weight: 500; color: var(--metin-gri); }
.sps-toplam-fiyat { font-size: 2.8rem; font-weight: 700; color: var(--ikincil-vurgu); }
.sps-toplam-fiyat .eski-fiyat { font-size: 1.5rem; text-decoration: line-through; color: #aaa; margin-right: 10px; font-weight: 400; }

.sps-paket-icerigi ul { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--border-renk); padding-top: 20px; }
.sps-paket-icerigi li { padding: 8px 0; display: flex; align-items: center; font-size: 1rem; color: var(--metin-gri); }
.sps-paket-icerigi li::before { content: '✓'; color: var(--ana-vurgu); font-weight: bold; font-size: 1.2rem; margin-right: 12px; }

.sps-satinal-buton { display: block; width: 100%; padding: 15px; margin-top: 25px; text-align: center; text-decoration: none;
    font-weight: 600; font-size: 1.1rem; color: #fff; background: linear-gradient(45deg, var(--ikincil-vurgu), var(--ana-vurgu));
    border-radius: 10px; transition: all 0.3s ease; cursor: pointer;
}
.sps-satinal-buton:hover { transform: scale(1.02); box-shadow: 0 5px 15px rgba(192, 57, 222, 0.4); }

.sps-anim-update { animation: spsFadeOut 0.2s ease-out forwards; }
@keyframes spsFadeOut { to { opacity: 0; transform: translateY(-5px); } }
.sps-anim-updated { animation: spsFadeIn 0.3s ease-in backwards; }
@keyframes spsFadeIn { from { opacity: 0; transform: translateY(5px); } to { opacity: 1; transform: translateY(0); } }

/* =================================================================
   MODAL PENCERE STİLLERİ (YENİ TASARIMLA GÜNCELLENDİ)
   ================================================================= */
.sps-modal-overlay {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    background-color: rgba(0, 0, 0, 0.7); display: none;
    justify-content: center; align-items: center; z-index: 10000;
    opacity: 0; visibility: hidden; transition: opacity 0.3s ease, visibility 0.3s ease;
}
.sps-modal-content {
    background-color: var(--arkaplan); padding: 0; border-radius: 12px;
    width: 90%; max-width: 500px; position: relative;
    box-shadow: 0 5px 25px rgba(0,0,0,0.2); transform: scale(0.9);
    transition: transform 0.3s ease; overflow: hidden;
}
.sps-modal-overlay[style*="display: flex"] { opacity: 1; visibility: visible; }
.sps-modal-overlay[style*="display: flex"] .sps-modal-content { transform: scale(1); }

.sps-modal-close {
    position: absolute; top: 15px; right: 20px; background: none; border: none;
    font-size: 2.5rem; color: rgba(255,255,255,0.7); cursor: pointer;
    line-height: 1; padding: 0; transition: color 0.2s ease; z-index: 10;
}
.sps-modal-close:hover { color: #fff; }

.sps-modal-header {
    text-align: center; padding: 20px 30px; margin: 0;
    background: linear-gradient(45deg, var(--ikincil-vurgu), var(--ana-vurgu));
    color: #fff;
}
.sps-modal-header h3 { margin: 0; font-size: 1.4rem; font-weight: 600; }

.sps-modal-body { padding: 25px; display: flex; flex-direction: column; gap: 15px; }

.sps-payment-button {
    display: flex; align-items: center; gap: 15px; text-align: left;
    width: 100%; padding: 15px 20px; background-color: #fff;
    border: 1px solid #ddd; border-radius: 8px; font-size: 1.1rem;
    font-weight: 600; color: var(--metin-rengi); text-decoration: none;
    transition: all 0.2s ease;
}
.sps-payment-button:hover {
    border-color: var(--ikincil-vurgu); color: var(--ikincil-vurgu);
    transform: translateY(-2px); box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}
.sps-payment-button svg { width: 32px; height: 32px; flex-shrink: 0; color: var(--ikincil-vurgu); }
.sps-payment-button div { display: flex; flex-direction: column; }
.sps-payment-subtitle { font-size: 0.8rem; font-weight: 400; color: var(--metin-gri); margin-top: 2px; }

.sps-payment-button-whatsapp {
    background-color: var(--whatsapp-yesil); border-color: var(--whatsapp-yesil); color: #fff;
}
.sps-payment-button-whatsapp:hover {
    background-color: var(--whatsapp-yesil); color: #fff; opacity: 0.9;
}
.sps-payment-button-whatsapp svg, .sps-payment-button-whatsapp div, .sps-payment-button-whatsapp span { color: #fff; }

.sps-modal-footer {
    padding: 20px 25px; background-color: #fff; border-top: 1px solid #eee;
}
.sps-whatsapp-notice {
    font-size: 0.9rem; color: var(--metin-gri);
    text-align: center; margin-top: 0; margin-bottom: 15px;
}
.sps-whatsapp-button {
    display: flex; align-items: center; justify-content: center;
    gap: 10px; padding: 12px 20px; background-color: var(--whatsapp-yesil);
    color: #fff; text-decoration: none; border-radius: 8px;
    font-weight: 600; font-size: 1rem; transition: opacity 0.2s ease;
}
.sps-whatsapp-button:hover { opacity: 0.9; }
.sps-whatsapp-button svg { width: 20px; height: 20px; }

.sps-crypto-warning, .sps-crypto-address-box, .sps-back-button, .sps-copy-button { font-family: 'Poppins', sans-serif; }
.sps-crypto-warning {
    background-color: #fff3cd; color: #665700; border: 1px solid #ffeeba;
    border-radius: 5px; padding: 15px; margin-bottom: 20px;
    font-size: 0.9rem; line-height: 1.5;
}
.sps-crypto-warning p { margin: 0; padding: 0; }
.sps-crypto-warning p:first-child { margin-bottom: 10px; }
.sps-crypto-address-box { margin-bottom: 15px; }
.sps-crypto-address-box label { display: block; font-weight: 600; margin-bottom: 8px; color: var(--metin-rengi); }
.sps-address-line { display: flex; align-items: center; gap: 10px; }
.sps-address-line input {
    flex-grow: 1; padding: 10px; border: 1px solid #ccc;
    border-radius: 5px; font-size: 1rem; background-color: #fff;
    font-family: 'Courier New', Courier, monospace; color: var(--metin-gri);
}
.sps-copy-button {
    background-color: var(--ikincil-vurgu); color: #fff; border: none;
    border-radius: 5px; padding: 10px 15px; cursor: pointer;
    font-size: 0.9rem; font-weight: 600; transition: background-color 0.2s ease;
}
.sps-copy-button.copied { background-color: #28a745; }

.sps-back-button {
    display: block; width: 100%; padding: 15px; margin-top: 20px; text-align: center; text-decoration: none;
    font-weight: 600; font-size: 1.1rem; color: #fff !important;
    background: linear-gradient(45deg, var(--ikincil-vurgu), var(--ana-vurgu));
    border: none; border-radius: 10px; transition: all 0.3s ease; cursor: pointer;
}
.sps-back-button:hover { transform: scale(1.02); box-shadow: 0 5px 15px rgba(192, 57, 222, 0.4); }

/* Animasyonlar */
@keyframes gradientShine { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }
@keyframes textGradientShine { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; } }

/* =================================================================
   MOBİL VE TABLET OPTİMİZASYONU (İSTEĞİNİZE GÖRE DÜZENLENDİ)
   ================================================================= */
/* =================================================================
   MOBİL VE TABLET OPTİMİZASYONU (NİHAİ SÜRÜM)
   ================================================================= */
@media (max-width: 768px) {
    /* --- Ana Eklenti Tablet Stilleri --- */
    #sps-paket-hesaplayici-root {
        padding: 25px; margin: 20px auto;
    }
    #sps-paket-hesaplayici-root h2 {
        font-size: 2.2rem;
    }
    .sps-sure-butonlari {
        grid-template-columns: repeat(2, 1fr);
    }
    .sps-toplam-fiyat {
        font-size: 2.5rem;
    }
    .sps-sonuc-alani {
        padding: 25px;
    }

    /* --- Yeni Fiyat Tablosu Tablet Stilleri --- */
    .sps-new-paket-grid { 
        grid-template-columns: 1fr; 
    }
    .sps-filters-wrapper { 
        flex-direction: column; 
    }
}

@media (max-width: 480px) {
    /* === ANA EKLENTİ MOBİL STİLLERİ === */
    #sps-paket-hesaplayici-root {
        padding: 20px 15px; border-radius: 0; margin: 0;
    }
    #sps-paket-hesaplayici-root h2 {
        font-size: 1.8rem; margin-bottom: 25px;
    }
    .sps-sure-butonlari {
        grid-template-columns: repeat(2, 1fr); gap: 10px;
    }
    .sps-secenek-butonlari {
        gap: 10px;
    }
    .sps-secenek-butonlari button {
        padding: 10px; font-size: 0.9rem;
    }
    .sps-sure-butonlari button {
        width: 100%; min-width: 0; font-size: 0.8rem;
        line-height: 1.25; padding: 8px 5px; height: auto;
    }
    .sps-fiyat-bolumu {
        flex-direction: column; align-items: flex-start; gap: 8px;
    }
    .sps-toplam-fiyat {
        font-size: 2.2rem;
    }
    .sps-sonuc-alani {
        padding: 20px;
    }
    .sps-paket-icerigi li,
    .sps-secenek-grubu label {
        font-size: 0.95rem;
    }

    /* === ORTAK MOBİL MODAL STİLLERİ (SIĞDIRMA ODAKLI) === */
    .sps-modal-content,
    .sps-modal-content-new {
        max-height: none;
        display: block;
    }
    .sps-modal-header h3,
    .sps-modal-header-new h3 {
        font-size: 1.2rem;
    }
    .sps-modal-body,
    .sps-modal-body-new {
        padding: 15px;
        gap: 10px;
        overflow-y: visible;
    }
    .sps-payment-button,
    .sps-payment-button-new {
        font-size: 1rem; padding: 12px 15px;
    }
    .sps-crypto-warning {
        padding: 10px; margin-bottom: 10px;
        font-size: 0.8rem; line-height: 1.4;
    }
    .sps-crypto-warning p:first-child { margin-bottom: 5px; }
    .sps-crypto-address-box { margin-bottom: 10px; }
    .sps-crypto-address-box label { font-size: 0.9rem; margin-bottom: 5px; }
    
    /* DÜZELTME BURADA: Tutar kutusunun tüm stillerini koruyarak küçült */
    .sps-crypto-amount-box {
        display: flex;
        justify-content: space-between;
        align-items: center;
        background-color: var(--kutu-arkaplan);
        border: 1px solid var(--border-renk);
        border-radius: 5px;
        padding: 8px 12px;
        margin-bottom: 8px;
    }
    .sps-crypto-amount-label {
        font-size: 0.8rem; /* Mobil için biraz daha küçük */
    }
    .sps-crypto-amount {
        font-size: 1rem;
    }
    
    .sps-address-line input,
    .sps-copy-button { padding: 8px 12px; font-size: 0.9rem; }
    .sps-back-button { padding: 12px; margin-top: 5px; font-size: 1rem; }
    .sps-modal-footer,
    .sps-modal-footer-new { padding: 15px; }
    .sps-whatsapp-notice,
    .sps-whatsapp-notice-new { font-size: 0.85rem; }
    .sps-whatsapp-button,
    .sps-whatsapp-button-new { font-size: 0.95rem; }
}