/* ═══════════════════════════════════════════════════════════════
   Çamlıca Kağıt — Üretim Takip · Mobil arayüz
   Profesyonel, kurumsal görünüm — marka yeşili (logo) temel alınmıştır.
   ═══════════════════════════════════════════════════════════════ */
:root {
    --bg:          #EEF1EE;   /* sayfa zemini */
    --surface:     #FFFFFF;   /* kartlar */
    --surface-2:   #F4F7F4;   /* hafif vurgulu zemin */
    --brand:       #1F7A43;   /* marka yeşili (logo) */
    --brand-dark:  #143D27;   /* başlık çubuğu / koyu */
    --brand-hover: #196235;
    --brand-tint:  #E7F1EA;   /* açık yeşil ton */
    --text:        #18241E;
    --text-2:      #56685E;
    --text-3:      #8A968F;
    --border:      #E0E6E1;
    --danger:      #B23B30;
    --warning:     #9A6312;
    --radius:      14px;
    --shadow:      0 1px 3px rgba(20,61,39,.08), 0 1px 2px rgba(20,61,39,.04);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html, body {
    margin: 0; padding: 0;
    background: var(--bg);
    color: var(--text);
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    font-size: 16px;
    line-height: 1.45;
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
}

/* ── Üst çubuk ── */
.ust-bar {
    position: sticky; top: 0; z-index: 50;
    background: var(--brand-dark);
    padding: env(safe-area-inset-top) 0 0 0;
    box-shadow: 0 1px 8px rgba(0,0,0,.12);
}
.ust-ic {
    display: flex; align-items: center; gap: 12px;
    height: 54px; padding: 0 14px;
    max-width: 720px; margin: 0 auto;
}
.ust-baslik {
    font-size: 16px; font-weight: 700; letter-spacing: .2px;
    color: #fff; flex: 1; min-width: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.geri-btn {
    color: #fff; text-decoration: none; flex: 0 0 auto;
    font-size: 22px; line-height: 1; width: 34px; height: 34px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 9px; background: rgba(255,255,255,.12);
}
.geri-btn:active { background: rgba(255,255,255,.24); }
.ust-isci {
    display: flex; align-items: center; gap: 8px; flex: 0 0 auto;
    text-decoration: none; color: #DCEAE0;
    background: rgba(255,255,255,.12); padding: 6px 12px; border-radius: 999px;
    font-size: 13px; font-weight: 600;
}
.isci-ad { max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cikis-yazi { font-size: 11px; font-weight: 700; opacity: .8; padding-left: 2px;
    border-left: 1px solid rgba(255,255,255,.25); }

/* ── Gövde ── */
.govde { max-width: 720px; margin: 0 auto; padding: 20px 16px 48px; }
.sayfa-baslik { font-size: 22px; font-weight: 800; margin: 2px 0 4px; letter-spacing: -.2px; }
.sayfa-alt    { color: var(--text-2); font-size: 14px; margin: 0 0 20px; }

/* ── Marka başlığı (giriş ekranı) ── */
.marka { text-align: center; padding: 14px 0 26px; }
.marka-logo { max-height: 64px; max-width: 220px; margin: 0 auto 12px; display: block; }
.marka-ad {
    font-size: 22px; font-weight: 800; color: var(--brand);
    letter-spacing: 1.5px; text-transform: uppercase;
}
.marka-alt { font-size: 13px; color: var(--text-3); letter-spacing: 2px;
    text-transform: uppercase; margin-top: 4px; }

/* ── Bildirim ── */
.bildirim {
    padding: 13px 16px; border-radius: 12px; margin-bottom: 16px;
    font-weight: 600; font-size: 14px; line-height: 1.4;
    animation: girisanim .22s ease;
}
.bildirim.basari { background: var(--brand-tint); color: #15623A; border: 1px solid #BFE0CC; }
.bildirim.hata   { background: #FBEAE8; color: #8E2D24; border: 1px solid #F0C8C3; }
@keyframes girisanim { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }

/* ── Personel listesi ── */
.isci-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.isci-kart {
    display: flex; flex-direction: column; align-items: center; gap: 11px;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 22px 12px; text-decoration: none;
    color: var(--text); box-shadow: var(--shadow);
    transition: transform .08s ease, border-color .12s ease;
}
.isci-kart:active { transform: scale(0.97); border-color: var(--brand); }
.isci-avatar {
    width: 56px; height: 56px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; font-weight: 700; color: #fff; letter-spacing: .5px;
}
.isci-kart .ad { font-size: 15px; font-weight: 700; text-align: center; }

/* ── PIN ekranı ── */
.pin-wrap { display: flex; flex-direction: column; align-items: center; padding-top: 8px; }
.pin-avatar {
    width: 78px; height: 78px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 28px; font-weight: 700; color: #fff; margin-bottom: 14px;
}
.pin-isim { font-size: 20px; font-weight: 800; margin-bottom: 4px; }
.pin-ipucu { color: var(--text-2); font-size: 14px; margin-bottom: 28px; }
.pin-noktalar { display: flex; gap: 18px; margin-bottom: 34px; }
.pin-nokta {
    width: 16px; height: 16px; border-radius: 50%;
    border: 2px solid var(--text-3); transition: all .12s ease;
}
.pin-nokta.dolu { background: var(--brand); border-color: var(--brand); }
.pin-nokta.hatali { border-color: var(--danger); animation: salla .4s; }
@keyframes salla { 0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-8px)} 40%,80%{transform:translateX(8px)} }

.tus-pad { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; width: 100%; max-width: 300px; }
.tus {
    height: 66px; border-radius: 16px; border: 1px solid var(--border);
    background: var(--surface); color: var(--text);
    font-size: 26px; font-weight: 600; cursor: pointer; box-shadow: var(--shadow);
    transition: transform .06s ease, background .12s ease;
}
.tus:active { transform: scale(0.94); background: var(--brand-tint); }
.tus.bos { background: transparent; border: none; box-shadow: none; pointer-events: none; }
.tus.sil { font-size: 22px; color: var(--text-2); }

/* ── Kategori kartları (profesyonel — beyaz kart + renkli kenar) ── */
.kategori-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.kategori-kart {
    position: relative; background: var(--surface);
    border: 1px solid var(--border); border-left: 4px solid var(--brand);
    border-radius: 12px; padding: 16px 14px; min-height: 104px;
    text-decoration: none; color: var(--text); box-shadow: var(--shadow);
    display: flex; flex-direction: column; justify-content: space-between;
    transition: transform .08s ease;
}
.kategori-kart:active { transform: scale(0.97); }
.kategori-kart .k-ad { font-size: 16px; font-weight: 700; line-height: 1.25; }
.kategori-kart .k-sayi { font-size: 12px; font-weight: 600; color: var(--text-3); margin-top: 2px; }
.kategori-kart .k-rozet {
    align-self: flex-start; background: var(--brand-tint); color: var(--brand);
    padding: 3px 10px; border-radius: 999px; font-size: 13px; font-weight: 700;
    margin-bottom: 10px;
}

/* ── Arama ── */
.arama-form { margin-bottom: 16px; display: flex; gap: 8px; }
.arama-form input {
    flex: 1 1 auto; min-width: 0;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 11px; padding: 12px 15px; color: var(--text); font-size: 16px;
}
.arama-form input:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-tint); }
.arama-form button {
    flex: 0 0 auto; background: var(--brand); border: none; color: #fff; font-weight: 700;
    border-radius: 11px; padding: 0 18px; font-size: 15px;
}
.arama-form button:active { background: var(--brand-hover); }

/* ── Sipariş listesi ── */
.siparis-liste { display: flex; flex-direction: column; gap: 10px; }
.siparis-kart {
    display: block; text-decoration: none; color: var(--text);
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 12px; padding: 14px 16px; box-shadow: var(--shadow);
    transition: transform .08s ease, border-color .12s;
}
.siparis-kart:active { transform: scale(0.985); border-color: var(--brand); }
.sk-ust { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.sk-ad { font-size: 16px; font-weight: 700; }
.sk-no { color: var(--text-3); font-size: 12px; font-weight: 700; white-space: nowrap; }
.sk-mus { color: var(--text-2); font-size: 13px; margin-top: 2px; }
.sk-alt { display: flex; justify-content: space-between; align-items: center; margin-top: 10px; gap: 12px; }
.sk-teslim { color: var(--text-3); font-size: 12px; }
.sk-teslim b { color: var(--warning); font-weight: 700; }
.sk-satir { color: var(--text-3); font-size: 12px; font-weight: 600; }

/* ── İlerleme çubuğu ── */
.ilerleme { height: 7px; border-radius: 999px; background: var(--surface-2); overflow: hidden; margin-top: 10px; border: 1px solid var(--border); }
.ilerleme > span { display: block; height: 100%; border-radius: 999px; background: var(--brand); transition: width .3s ease; }
.ilerleme.tam > span { background: var(--brand); }

/* ── Sipariş detay başlık ── */
.detay-baslik {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--radius); padding: 16px 18px; margin-bottom: 16px; box-shadow: var(--shadow);
}
.db-ad { font-size: 19px; font-weight: 800; }
.db-mus { color: var(--text-2); margin-top: 4px; font-size: 14px; }
.db-meta { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 10px; color: var(--text-3); font-size: 13px; }
.db-meta b { color: var(--text); }
.db-ozet { display: flex; align-items: center; gap: 12px; margin-top: 14px; }
.db-ozet .yuzde-buyuk { font-size: 22px; font-weight: 800; color: var(--brand); flex: 0 0 auto; }

/* ── Satır (iş) kartı ── */
.satir-kart {
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 12px; padding: 15px 16px; margin-bottom: 12px; box-shadow: var(--shadow);
}
.satir-kart.bitti { border-color: #BFE0CC; background: var(--brand-tint); }
.satir-baslik { display: flex; justify-content: space-between; gap: 10px; align-items: flex-start; }
.satir-ac { font-size: 14px; font-weight: 700; line-height: 1.35; }
.satir-rozet { font-size: 12px; font-weight: 800; padding: 3px 10px; border-radius: 999px; white-space: nowrap; flex: 0 0 auto; }
.satir-rozet.acik { background: #FBF1DE; color: var(--warning); }
.satir-rozet.kapali { background: var(--brand); color: #fff; }
.satir-rakam { display: flex; gap: 18px; margin-top: 11px; font-size: 13px; color: var(--text-2); flex-wrap: wrap; }
.satir-rakam b { color: var(--text); font-size: 15px; font-weight: 700; }
.kalan-vurgu b { color: var(--warning); }

/* ── Miktar girişi (taşma düzeltildi: input min-width:0) ── */
.kayit-form { display: flex; gap: 8px; margin-top: 13px; align-items: stretch; }
.kayit-form input {
    flex: 1 1 auto; min-width: 0;                /* ← taşmayı önler */
    background: var(--surface-2); border: 1px solid var(--border);
    border-radius: 11px; padding: 12px 14px; color: var(--text);
    font-size: 16px; font-weight: 600;
}
.kayit-form input:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-tint); }
.birim-eki {
    flex: 0 0 auto; display: flex; align-items: center; color: var(--text-3);
    font-size: 13px; font-weight: 700;
}
.kayit-form button {
    flex: 0 0 auto; white-space: nowrap;
    background: var(--brand); border: none; color: #fff; font-weight: 800;
    border-radius: 11px; padding: 0 18px; font-size: 15px;
}
.kayit-form button:active { background: var(--brand-hover); }

/* ── Boş durum ── */
.bos-durum { text-align: center; color: var(--text-3); padding: 56px 24px; font-size: 15px; line-height: 1.6; }

/* ── Hızlı miktar (kalanı doldur) ── */
.hizli { display: flex; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.hizli button {
    background: var(--surface); border: 1px solid var(--border); color: var(--brand);
    border-radius: 999px; padding: 7px 14px; font-size: 13px; font-weight: 700;
}
.hizli button:active { background: var(--brand-tint); }
