/* ===== Reset & Theme ===== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    /* Light (default) */
    --bg: #f5f5f5;      /* page background */
    --surface: #ffffff; /* cards / wrap */
    --ink: #111111;     /* primary text */
    --muted: #6b7280;   /* secondary text */
    --line: #e5e7eb;    /* borders / dividers */
    --shadow-1: 0 6px 16px rgba(0, 0, 0, .08);
    --shadow-2: 0 16px 40px rgba(0, 0, 0, .20);
    --accent: #111111;  /* subtle accent (still monochrome) */
    --accent-weak: #9ca3af;

    /* iOS viewport düzeltmesi için dinamik vh (JS bunu güncelleyecek) */
    --vh: 1vh;
}

#blog-body {
    font: 16px/1.7 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
    color: var(--ink);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;

    /* yatay taşmaları önle */
    overflow-x: hidden;
}

/* ====== Layout ====== */
.wrap {
    max-width: 1100px;
    margin: 0 auto;
    background: var(--surface);
    border-radius: 18px;
    padding: 40px;
    box-shadow: var(--shadow-2);
    border: 1px solid var(--line);
}

.wrap > h1 {
    margin: 0 0 28px;
    font-size: 2.2rem;
    letter-spacing: .2px;
    color: var(--ink);
    text-align: left; /* başlıklar solda kalsın (PC) */
}

section.project {
    padding: 28px;
    border: 1px solid var(--line);
    border-radius: 14px;
    margin-bottom: 26px;
    background: var(--surface);
    box-shadow: var(--shadow-1);
    transition: transform .25s ease, box-shadow .25s ease;
}

section.project:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-2);
}

.project > h2 {
    color: var(--ink);
    margin-bottom: 18px;
    font-size: 1.6rem;
    position: relative;
    padding-bottom: 10px;
}

.project > h2:after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 60px;
    height: 2px;
    background: var(--accent);
    border-radius: 2px;
    opacity: .9;
}

.project > h3 {
    margin: 18px 0 10px;
    font-size: 1.1rem;
    color: var(--ink);
}

.project > p {
    color: #333;
    margin-bottom: 14px;
}

.footnote{
    margin-top: 10px; color: var(--muted); font-size: .96rem;
    padding: 18px 20px; background: var(--surface); border:1px solid var(--line);
    border-left: 4px solid var(--accent); border-radius: 10px;
}
.footnote span{ display:block; margin:6px 0; }

/* ===== iOS 100vh / scroll jitter sadece BLOG sayfasında düzeltme ===== */
/* Global style.css'e dokunmadan, bu sayfada yüksekliği stabil tutuyoruz */
#blog-body .mil-wrapper,
#blog-body .mil-content,
#blog-body #swupMain {
    min-height: calc(var(--vh) * 100);
}
@supports (height: 100svh) {
    #blog-body .mil-wrapper,
    #blog-body .mil-content,
    #blog-body #swupMain {
        min-height: 100svh;
    }
}
/* iOS WebKit'te globalde height:100vh varsa bastırmak için */
@supports (-webkit-touch-callout: none) {
    #blog-body .mil-wrapper,
    #blog-body .mil-content,
    #blog-body #swupMain {
        height: auto !important;
    }
}

/* ===== Mobile-only polish (PC etkilenmez) ===== */
@media (max-width: 576px) {
    .wrap { padding: 22px; border-radius: 16px; }

    /* uzun başlıkların dengeli kırılması ve & yalnız kalmaması için */
    .wrap > h1,
    .project > h2 {
        text-align: left !important;
        line-height: 1.15;
        word-break: normal;
        overflow-wrap: break-word;
        hyphens: auto;
        text-wrap: balance; /* modern iOS/Chrome */
    }

    .wrap > h1 { font-size: clamp(22px, 6.2vw, 32px); }
    .project > h2 { font-size: clamp(18px, 5.2vw, 24px); }

    .project { padding: 18px; }
}
