@charset "UTF-8";

/** 
* @author     : mefamex (https://mefamex.com/)
* @company    : demirosgb (https://demirosgb.com/)
* @website    : https://demirosgb.com/
* @copyright  : © 2025 Demirosgb. Tüm hakları saklıdır
* @file       : components.css
* @created    : 2025-08-29
* @updated    : 2025-08-29
* @description: components stylesheet (buttons, cards, ...)
* @version    : 1.0.0
*
* @changelog: 
* - v1.0.0 (2025-08-29) - İlk versiyon
*
* =============================
*           NOTES 
* =============================
* 
* TODO:
* - [ ] Dark mode toggle
* - [ ] Performance optimizasyonu
* 
* FIXME:
* - 
**/

/* =============================
 * COMPONENTS
 * ============================= */

.skip-link {
    position: absolute;
    top: -10rem;
    left: 0.5rem;
    background: #000;
    color: #fff;
    padding: 0.6rem 1rem;
    border-radius: 0.5rem;
    font-size: var(--font-scale-sm, .9rem);
    z-index: 2000;
    text-decoration: none;
    box-shadow: 0 0.3rem 0.6rem rgba(0, 0, 0, .3);
    transition: top .25s ease;
}

.skip-link:focus {
    top: 0.5rem;
}

/* Buttons */
.btn {
    --btn-bg: var(--accent-primary, #E67E22);
    --btn-bg-hover: var(--accent-primary-hover, #E8934A);
    --btn-color: var(--text-on-primary, #fff);
    display: inline-flex;
    align-items: center;
    gap: .5em;
    background: var(--btn-bg);
    color: var(--btn-color);
    padding: 0.75em 1.3em;
    border: 0;
    border-radius: 0.9rem;
    font-weight: 600;
    font-size: var(--font-scale-sm, .95rem);
    letter-spacing: .02em;
    text-decoration: none;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    box-shadow: var(--shadow-light);
    transition: all .25s ease;
}

.btn:hover, .btn:focus-visible {
    background: var(--btn-bg-hover);
    transform: translateY(-2px);
    box-shadow: var(--shadow-medium);
}

.btn:active {
    transform: translateY(0);
    box-shadow: var(--shadow-light);
}

.btn.outline {
    background: transparent;
    color: var(--accent-primary, #E67E22);
    border: 2px solid currentColor;
}

.btn.outline:hover {
    background: var(--accent-primary, #E67E22);
    color: #fff;
}

/* Sections */
.section {
    width: 100%;
    padding: clamp(2.5rem, 6vw, 5rem) 1.2rem;
    margin-inline: auto;
    max-width: 75rem;
    position: relative;
}

.section--alt {
    background: linear-gradient(135deg, #ffffff 0%, #f5f7fa 100%);
}

.section-header {
    text-align: center;
    margin-bottom: 2.5rem;
}

.section-header h2 {
    margin: 0 0 .6rem;
    font-size: var(--font-scale-xl, clamp(1.8rem, 3.5vw, 2.4rem));
    letter-spacing: -.02em;
}

.section-header p {
    margin: 0;
    color: var(--text-secondary);
    font-size: var(--font-scale-base, 1rem);
    max-width: 50ch;
    margin-inline: auto;
}

/* Grid Utility */
.grid {
    display: grid;
    gap: 1.8rem;
}

.grid.cols-2 {
    grid-template-columns: repeat(auto-fit, minmax(min(20rem, 100%), 1fr));
}

.grid.cols-3 {
    grid-template-columns: repeat(auto-fit, minmax(min(16rem, 100%), 1fr));
}

@media (min-width: 64rem) {
    .grid.cols-3-lg {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Card */
.card {
    background: #fff;
    border-radius: 1.1rem;
    padding: 1.35rem 1.2rem 1.5rem;
    position: relative;
    overflow: hidden;
    border: 1px solid var(--neutral-border, #D1D8E0);
    box-shadow: var(--shadow-light);
    transition: all .3s ease;
}

.card:hover {
    box-shadow: var(--shadow-medium);
    transform: translateY(-4px);
}

.card h3 {
    margin-top: 0;
    font-size: var(--font-scale-md, 1.1rem);
    letter-spacing: -.01em;
}

.card p {
    font-size: var(--font-scale-sm, .9rem);
    line-height: 1.5;
}

/* Badge */
.badge {
    display: inline-block;
    background: var(--gradient-accent, #E67E22);
    color: #fff;
    font-size: calc(var(--font-scale-xs, .75rem) - .05rem);
    padding: .35em .55em;
    border-radius: .5rem;
    letter-spacing: .05em;
    font-weight: 600;
    text-transform: uppercase;
}

/* Icon Row */
.icon-row {
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    align-items: center;
}

.icon-row img {
    height: 2.3rem;
    width: auto;
    filter: grayscale(.2);
    opacity: .85;
    transition: all .25s ease;
}

.icon-row img:hover {
    filter: none;
    opacity: 1;
    transform: scale(1.05);
}

/* FAQ */
.faq-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.faq-item {
    border: 1px solid var(--neutral-border, #D1D8E0);
    border-radius: .9rem;
    margin-bottom: 1rem;
    overflow: hidden;
    background: #fff;
}

.faq-item button {
    all: unset;
    display: flex;
    width: 100%;
    cursor: pointer;
    padding: 1rem 1.1rem;
    font-weight: 600;
    font-size: var(--font-scale-sm, .95rem);
    justify-content: space-between;
    align-items: center;
}

.faq-item button:focus-visible {
    outline: 2px solid var(--accent-primary, #E67E22);
    outline-offset: 2px;
}

.faq-item[open] button .faq-icon {
    transform: rotate(180deg);
}

.faq-answer {
    padding: 0 1.1rem 1.2rem;
    font-size: var(--font-scale-sm, .9rem);
    line-height: 1.55;
    color: var(--text-secondary);
}

.faq-icon {
    transition: transform .3s ease;
}

/* Utility */
.text-center {
    text-align: center;
}

.muted {
    color: var(--text-secondary);
}

.mt-0 {
    margin-top: 0;
}

.mb-0 {
    margin-bottom: 0;
}

.mb-1 {
    margin-bottom: .5rem;
}

.mb-2 {
    margin-bottom: 1rem;
}

.mb-3 {
    margin-bottom: 1.5rem;
}

.mt-2 {
    margin-top: 1rem;
}

.mt-3 {
    margin-top: 2rem;
}

/* Hero Mini */
.hero-mini {
    padding: 3.5rem 1.2rem 2.5rem;
    text-align: center;
    background: var(--gradient-hero, linear-gradient(135deg, #1B365D 0%, #2D5A3D 100%));
    color: #fff;
    position: relative;
    overflow: hidden;
}

.hero-mini h1 {
    margin: 0 0 .8rem;
    font-size: var(--font-scale-xl, clamp(2rem, 4.5vw, 2.8rem));
    letter-spacing: -.02em;
}

.hero-mini p {
    margin: 0 auto;
    max-width: 55ch;
    font-size: var(--font-scale-base, 1rem);
    line-height: 1.55;
}

.hero-mini::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 70% 30%, rgba(255, 255, 255, .25), transparent 60%);
    pointer-events: none;
}

/* Table (mevzuat) */
.table-responsive {
    width: 100%;
    overflow-x: auto;
    border: 1px solid var(--neutral-border, #D1D8E0);
    border-radius: .8rem;
    background: #fff;
    box-shadow: var(--shadow-light);
}

table.data-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--font-scale-sm, .85rem);
}

table.data-table th, table.data-table td {
    padding: .7rem .8rem;
    text-align: left;
    border-bottom: 1px solid var(--neutral-border, #E5E9F2);
}

table.data-table th {
    background: #f5f7fa;
    font-weight: 600;
    font-size: calc(var(--font-scale-xs, .75rem) - .02rem);
    letter-spacing: .05em;
    text-transform: uppercase;
}

table.data-table tr:last-child td {
    border-bottom: none;
}

table.data-table tbody tr:hover {
    background: #fdf4ed;
}

/* Animations helpers */
@media (prefers-reduced-motion: no-preference) {
    .fade-in {
        animation: fadeIn .6s ease both;
    }

    .rise {
        animation: rise .6s ease both;
    }
}

@keyframes rise {
    from {
        transform: translateY(14px);
        opacity: 0;
    }

    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* =============================
 *  RESPONSIVE OPTIMIZATIONS
 * ============================= */
@media (max-width: 48rem) {
    .section {
        padding: 2.5rem 1rem;
    }

    .grid {
        gap: 1.2rem;
    }

    .card {
        padding: 1.05rem 1rem 1.15rem;
    }

    .card h3 {
        font-size: var(--font-scale-md, 1.05rem);
    }

    .card p {
        font-size: calc(var(--font-scale-sm, .9rem) - .05rem);
    }

    .hero-mini {
        padding: 2.8rem 1rem 2rem;
    }

    .hero-mini h1 {
        font-size: var(--font-scale-xl, clamp(1.9rem, 7vw, 2.3rem));
    }

    .hero-mini p {
        font-size: var(--font-scale-sm, .9rem);
    }

    .btn {
        padding: 0.65em 1.05em;
        font-size: calc(var(--font-scale-sm, .9rem) - .05rem);
    }

    .icon-row img {
        height: 2rem;
    }

    table.data-table th, table.data-table td {
        padding: .55rem .6rem;
    }

    .faq-item button {
        padding: .8rem .9rem;
        font-size: calc(var(--font-scale-sm, .9rem) - .07rem);
    }

    .faq-answer {
        padding: 0 .9rem 1rem;
        font-size: calc(var(--font-scale-sm, .9rem) - .1rem);
    }

    .hero .hero-sub {
        font-size: var(--font-scale-sm, .9rem);
    }

    .hero .hero-cta {
        display: flex;
        flex-wrap: wrap;
        gap: .6rem;
        justify-content: center;
    }
}

@media (max-width: 30rem) {
    .btn {
        width: 100%;
        justify-content: center;
    }

    .grid.cols-3 {
        grid-template-columns: repeat(auto-fit, minmax(min(14rem, 100%), 1fr));
    }

    .grid.cols-2 {
        grid-template-columns: repeat(auto-fit, minmax(min(14rem, 100%), 1fr));
    }

    .section-header h2 {
        font-size: clamp(1.5rem, 6.5vw, 2rem);
    }

    .section-header p {
        font-size: .85rem;
    }
}