/* iletisim.css — İletişim sayfası */

.contact-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    max-width: 900px; margin: 0 auto 2.5rem;
}
.contact-card {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(0,245,255,0.2);
    border-radius: var(--radius-card);
    padding: 2rem 1.75rem; text-align: center;
    transition: var(--transition); backdrop-filter: blur(16px);
}
.contact-card:hover {
    transform: translateY(-8px);
    border-color: var(--brand-purple);
    box-shadow: 0 20px 50px rgba(124,58,237,0.25);
}
.contact-icon { font-size: 2.8rem; margin-bottom: 1rem; display: block; }
.contact-card h3 {
    font-family: var(--font-heading);
    font-size: 1.2rem; font-weight: 700;
    color: var(--brand-purple); margin-bottom: 0.6rem;
}
.contact-card p { font-size: 0.9rem; color: var(--text-muted); margin-bottom: 1.25rem; }

/* İletişim linki butonu */
.contact-link {
    display: inline-block; padding: 0.7rem 1.75rem;
    font-size: 0.875rem; font-weight: 700;
    color: #fff;
    background: var(--brand-purple);
    border-radius: 50px; text-decoration: none;
    box-shadow: 0 8px 30px rgba(124,58,237,0.4);
    transition: var(--transition);
    font-family: var(--font-body);
}
.contact-link:hover {
    background: var(--brand-purple-hover);
    transform: scale(1.04);
    box-shadow: 0 12px 40px rgba(124,58,237,0.55);
}

/* Bilgi kutusu */
.info-box {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(0,245,255,0.2);
    border-radius: var(--radius-card);
    padding: 2rem; text-align: center;
    max-width: 700px; margin: 0 auto;
    backdrop-filter: blur(16px);
}
.info-box h3 {
    font-family: var(--font-heading);
    font-size: 1.25rem; font-weight: 700;
    color: var(--brand-cyan); margin-bottom: 0.75rem;
}
.info-box p { font-size: 0.9rem; color: var(--text-muted); line-height: 1.7; margin-bottom: 0.5rem; }

/* ── İletişim Formu ── */
.contact-form-section {
    max-width: 780px; margin: 0 auto 4rem; padding: 0 1.5rem;
    position: relative; z-index: 1;
}
.contact-form-card {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(124,58,237,0.3);
    border-radius: 20px; padding: 2.5rem 2rem;
    backdrop-filter: blur(20px);
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.contact-form-card h2 {
    font-family: var(--font-heading); font-weight: 700;
    font-size: 1.4rem; color: #fff; margin-bottom: 0.4rem;
    display: flex; align-items: center; gap: 0.5rem;
}
.contact-form-card h2 i { color: var(--brand-purple); }
.contact-form-card > p {
    font-size: 0.875rem; color: var(--text-muted); margin-bottom: 2rem;
}
.form-row {
    display: grid; gap: 1rem; margin-bottom: 1rem;
}
.form-row.two-col { grid-template-columns: 1fr 1fr; }
@media (max-width: 580px) { .form-row.two-col { grid-template-columns: 1fr; } }
.form-group { display: flex; flex-direction: column; gap: 0.4rem; }
.form-group label {
    font-size: 0.8rem; font-weight: 700;
    color: rgba(255,255,255,0.65);
    text-transform: uppercase; letter-spacing: 0.06em;
}
.form-group label span.req { color: var(--brand-purple); margin-left: 2px; }
.form-input, .form-select, .form-textarea {
    background: rgba(255,255,255,0.05);
    border: 1.5px solid rgba(124,58,237,0.25);
    border-radius: 10px; padding: 0.7rem 1rem;
    color: #fff; font-family: var(--font-body);
    font-size: 0.9rem; transition: var(--transition);
    width: 100%;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline: none;
    border-color: var(--brand-purple);
    background: rgba(124,58,237,0.07);
    box-shadow: 0 0 0 3px rgba(124,58,237,0.15);
}
.form-input::placeholder, .form-textarea::placeholder { color: rgba(255,255,255,0.28); }
.form-select { cursor: pointer; appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%237c3aed'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 1rem center;
    padding-right: 2.5rem;
}
.form-select option { background: #1a0a2e; color: #fff; }
.form-textarea { resize: vertical; min-height: 130px; line-height: 1.6; }

/* Yıldız puanlama */
.rating-wrap { display: flex; flex-direction: column; gap: 0.5rem; }
.rating-label { font-size: 0.8rem; font-weight: 700; color: rgba(255,255,255,0.65); text-transform: uppercase; letter-spacing: 0.06em; }
.star-rating { display: flex; gap: 0.4rem; }
.star-rating input[type="radio"] { display: none; }
.star-rating label {
    font-size: 1.6rem; cursor: pointer; opacity: 0.35;
    transition: opacity 0.2s, transform 0.2s;
    line-height: 1;
}
.star-rating label:hover,
.star-rating label:hover ~ label { opacity: 0.6; }
.star-rating input:checked ~ label { opacity: 0.35; }
.star-rating label:has(~ input:checked),
.star-rating input:checked + label { opacity: 1; }
/* Fallback for older browsers */
.star-rating.rated label { opacity: 0.35; }
.star-rating.rated .active-star { opacity: 1; }

/* E-posta doğrulama */
.email-verify-row {
    display: flex; gap: 0.6rem; align-items: flex-end;
}
.email-verify-row .form-input { flex: 1; }
.btn-verify-send {
    background: rgba(124,58,237,0.15);
    border: 1.5px solid rgba(124,58,237,0.5);
    color: #c4b5fd; font-family: var(--font-body);
    font-size: 0.8rem; font-weight: 700;
    padding: 0.7rem 1rem; border-radius: 10px;
    cursor: pointer; transition: var(--transition);
    white-space: nowrap; flex-shrink: 0;
}
.btn-verify-send:hover:not(:disabled) {
    background: rgba(124,58,237,0.3);
    border-color: var(--brand-purple); color: #fff;
}
.btn-verify-send:disabled { opacity: 0.4; cursor: not-allowed; }
.verify-code-row {
    display: none; gap: 0.6rem; align-items: flex-end; margin-top: 0.5rem;
}
.verify-code-row.show { display: flex; }
.verify-code-input {
    letter-spacing: 0.3em; font-size: 1.1rem; font-weight: 700;
    text-align: center; max-width: 160px;
}
.verify-status {
    font-size: 0.8rem; font-weight: 700; margin-top: 0.3rem;
    display: flex; align-items: center; gap: 0.4rem;
    min-height: 1.2rem;
}
.verify-status.ok { color: #4ade80; }
.verify-status.err { color: #f87171; }
.verify-status.info { color: var(--brand-cyan); }
.verify-countdown { font-size: 0.75rem; color: var(--text-dim); margin-top: 0.2rem; }

/* Ekler */
.attachment-label {
    display: flex; align-items: center; gap: 0.6rem;
    padding: 0.8rem 1rem;
    border: 1.5px dashed rgba(124,58,237,0.3);
    border-radius: 10px; cursor: pointer;
    font-size: 0.85rem; color: rgba(255,255,255,0.5);
    transition: var(--transition);
}
.attachment-label:hover {
    border-color: var(--brand-purple); color: #c4b5fd;
    background: rgba(124,58,237,0.06);
}
.attachment-label i { color: var(--brand-purple); font-size: 1rem; }
.attachment-name { font-size: 0.8rem; color: #4ade80; margin-top: 0.3rem; }

/* Form mesaj kutusu (sent / error) */
.form-msg {
    display: none; padding: 0.85rem 1.2rem; border-radius: 10px;
    font-size: 0.875rem; font-weight: 600;
    margin-bottom: 1rem; align-items: center; gap: 0.5rem;
}
.form-msg.show { display: flex; }
.form-msg.success { background: rgba(74,222,128,0.1); border: 1px solid rgba(74,222,128,0.3); color: #4ade80; }
.form-msg.error   { background: rgba(248,113,113,0.1); border: 1px solid rgba(248,113,113,0.3); color: #f87171; }

/* Gönder butonu */
.btn-submit {
    width: 100%; padding: 0.9rem 2rem; margin-top: 1.5rem;
    background: var(--brand-purple); color: #fff;
    border: none; border-radius: 10px; cursor: pointer;
    font-family: var(--font-body); font-size: 0.95rem; font-weight: 700;
    transition: var(--transition); display: flex; align-items: center;
    justify-content: center; gap: 0.5rem;
    box-shadow: 0 8px 25px rgba(124,58,237,0.4);
}
.btn-submit:hover:not(:disabled) {
    background: var(--brand-purple-hover);
    transform: translateY(-2px);
    box-shadow: 0 14px 35px rgba(124,58,237,0.55);
}
.btn-submit:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
.btn-submit .spinner {
    display: none; width: 16px; height: 16px;
    border: 2px solid rgba(255,255,255,0.3);
    border-top-color: #fff; border-radius: 50%;
    animation: spin 0.7s linear infinite;
}
.btn-submit.loading .spinner { display: inline-block; }
.btn-submit.loading .btn-text { display: none; }
@keyframes spin { to { transform: rotate(360deg); } }

/* KVKK onay satırı */
.form-kvkk {
    display: flex; align-items: flex-start; gap: 0.6rem;
    font-size: 0.8rem; color: rgba(255,255,255,0.55);
    margin-top: 1rem; line-height: 1.5;
}
.form-kvkk input[type="checkbox"] {
    width: 16px; height: 16px; flex-shrink: 0; margin-top: 1px;
    accent-color: var(--brand-purple); cursor: pointer;
}
.form-kvkk a { color: var(--brand-cyan); text-decoration: underline; }
/* Honeypot */
.hp-field { display: none !important; }
