/* ==========================================================
   APY v4 — Modern Apartman Yönetim Sistemi
   Tasarım: Temiz, profesyonel, mobil öncelikli
   Font: Poppins + DM Sans (Google Fonts)
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@500;600;700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --ana:#1a56db; --ana-koyu:#1239a8; --ana-acik:#eff6ff; --ana-kenar:#bfdbfe;
  --yesil:#059669; --yesil-acik:#d1fae5;
  --kirmizi:#dc2626; --kirmizi-acik:#fee2e2;
  --turuncu:#d97706; --turuncu-acik:#fef3c7;
  --mor:#7c3aed; --mor-acik:#ede9fe;
  --cam:#0891b2; --cam-acik:#cffafe;
  --arkaplan:#f1f5f9; --kart:#fff; --kenar:#e2e8f0;
  --metin:#0f172a; --metin-2:#475569; --metin-3:#94a3b8;
  --font-b:'Poppins',sans-serif; --font-g:'DM Sans',sans-serif;
  --r:12px; --r-sm:8px; --r-lg:16px; --r-full:999px;
  --golge:0 1px 3px rgba(0,0,0,.08),0 4px 16px rgba(0,0,0,.06);
  --golge-lg:0 4px 6px rgba(0,0,0,.07),0 10px 40px rgba(0,0,0,.1);
  --gecis:all .18s ease;
  --hh:64px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-g);font-size:15px;line-height:1.65;color:var(--metin);background:var(--arkaplan);-webkit-font-smoothing:antialiased}
a{color:var(--ana);text-decoration:none;transition:var(--gecis)}
a:hover{color:var(--ana-koyu)}
img{max-width:100%;height:auto;display:block}
button{font-family:var(--font-g);cursor:pointer}
input,select,textarea{font-family:var(--font-g)}
h1,h2,h3,h4,h5{font-family:var(--font-b);color:var(--metin);line-height:1.3}

.apy-site-wrap{min-height:100vh;display:flex;flex-direction:column}
.apy-site-icerik{flex:1;padding:28px 0 60px}
.apy-container{max-width:1180px;margin:0 auto;padding:0 20px}

/* ── HEADER ── */
.apy-topbar{background:var(--ana-koyu);padding:6px 0}
.apy-topbar-inner{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:rgba(255,255,255,.7)}
.apy-topbar-links{display:flex;gap:16px}
.apy-topbar-links a{color:rgba(255,255,255,.7);font-size:12px}
.apy-topbar-links a:hover{color:#fff}

.apy-header{background:#fff;border-bottom:1px solid var(--kenar);position:sticky;top:0;z-index:1000;height:var(--hh);box-shadow:0 1px 0 var(--kenar),0 2px 12px rgba(0,0,0,.04)}
.apy-header-ic{display:flex;align-items:center;justify-content:space-between;height:var(--hh);gap:16px}

.apy-logo{display:flex;align-items:center;gap:10px;color:var(--metin);font-family:var(--font-b);font-weight:700;font-size:17px;flex-shrink:0}
.apy-logo:hover{color:var(--ana)}
.apy-logo-badge{width:36px;height:36px;background:linear-gradient(135deg,var(--ana),var(--ana-koyu));color:#fff;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;font-family:var(--font-b);flex-shrink:0}
.apy-logo-text-wrap{display:flex;flex-direction:column;line-height:1.2}
.apy-logo-text-wrap small{font-size:10px;font-weight:400;color:var(--metin-3);font-family:var(--font-g)}
.custom-logo-link img,.custom-logo{max-height:40px;width:auto}

.apy-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.apy-nav a{color:var(--metin-2);padding:6px 12px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;white-space:nowrap;transition:var(--gecis)}
.apy-nav a:hover{color:var(--ana);background:var(--ana-acik)}
.apy-nav a.aktif{color:var(--ana);background:var(--ana-acik);font-weight:600}

.apy-header-kullanici{display:flex;align-items:center;gap:10px;flex-shrink:0}
.apy-user-pill{display:flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--kenar);border-radius:var(--r-full);padding:6px 12px 6px 8px}
.apy-user-pill-dot{width:8px;height:8px;background:var(--yesil);border-radius:50%;flex-shrink:0}
.apy-header-kullanici-ad{font-size:13px;color:var(--metin-2);font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.apy-hamburger{display:none;background:none;border:1px solid var(--kenar);border-radius:var(--r-sm);width:40px;height:40px;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0}
.apy-hamburger span{display:block;width:20px;height:2px;background:var(--metin);border-radius:2px;transition:var(--gecis)}
.apy-hamburger.aktif span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.apy-hamburger.aktif span:nth-child(2){opacity:0}
.apy-hamburger.aktif span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── BUTONLAR ── */
.apy-btn,.apy-btn-sm,.apy-btn-primary,.apy-btn-accent{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;font-family:var(--font-g);font-weight:600;border-radius:var(--r-sm);cursor:pointer;transition:var(--gecis);white-space:nowrap;text-decoration:none;line-height:1}
.apy-btn{background:var(--ana);color:#fff;padding:10px 18px;font-size:14px;box-shadow:0 1px 2px rgba(26,86,219,.3)}
.apy-btn:hover{background:var(--ana-koyu);color:#fff;box-shadow:0 2px 8px rgba(26,86,219,.35);transform:translateY(-1px)}
.apy-btn-primary{background:linear-gradient(135deg,var(--ana),var(--ana-koyu));color:#fff;padding:13px 28px;font-size:15px;border-radius:var(--r);box-shadow:0 2px 8px rgba(26,86,219,.3)}
.apy-btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(26,86,219,.4);color:#fff}
.apy-btn-sm{background:var(--ana);color:#fff;padding:6px 12px;font-size:12px;border-radius:var(--r-sm)}
.apy-btn-sm:hover{background:var(--ana-koyu);color:#fff}
.apy-btn-accent{background:var(--cam);color:#fff;padding:10px 18px;font-size:14px}
.apy-btn-accent:hover{background:#0e7490;color:#fff}
.apy-btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:transparent;border:1.5px solid var(--ana);color:var(--ana);padding:9px 18px;font-size:14px;font-weight:600;border-radius:var(--r-sm);cursor:pointer;transition:var(--gecis);text-decoration:none;font-family:var(--font-g)}
.apy-btn-outline:hover{background:var(--ana);color:#fff}
.apy-btn-icon{width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--kenar);background:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;transition:var(--gecis);color:var(--metin-2)}
.apy-btn-icon:hover{border-color:var(--ana);color:var(--ana);background:var(--ana-acik)}
.apy-btn-yesil,.apy-btn-yesil:hover{background:var(--yesil)!important;color:#fff!important}
.apy-btn-tehlike,.apy-btn-tehlike:hover{background:var(--kirmizi)!important;color:#fff!important;box-shadow:none!important;transform:none!important}
.apy-btn-sari,.apy-btn-turuncu{background:var(--turuncu)!important;color:#fff!important}
.apy-btn-mor{background:var(--mor)!important;color:#fff!important}

/* ── FORMLAR ── */
.apy-input,.apy-select,.apy-select-mini{width:100%;border:1.5px solid var(--kenar);border-radius:var(--r-sm);padding:10px 14px;font-size:14px;font-family:var(--font-g);color:var(--metin);background:#fff;transition:var(--gecis);outline:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;box-sizing:border-box;display:block;background-clip:padding-box;-webkit-tap-highlight-color:transparent}
.apy-input:focus,.apy-select:focus{border-color:var(--ana);box-shadow:0 0 0 3px rgba(26,86,219,.12);background:#fff}
.apy-input::placeholder{color:var(--metin-3)}
.apy-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:36px;cursor:pointer}
.apy-select-mini{width:auto;padding:5px 28px 5px 10px;font-size:12px}
textarea.apy-input{resize:vertical;min-height:90px;line-height:1.6}
.apy-input-ic{border:1.5px solid var(--kenar);border-radius:var(--r-sm);padding:7px 10px;font-size:13px;font-family:var(--font-g);color:var(--metin);background:#fff;transition:var(--gecis);outline:none;width:100%}
.apy-input-ic:focus{border-color:var(--ana);box-shadow:0 0 0 3px rgba(26,86,219,.1)}
.apy-input-full{width:100%}
.apy-form-group{display:flex;flex-direction:column;gap:6px}
.apy-form-group label{font-size:13px;font-weight:600;color:var(--metin-2)}
.apy-form-row{display:flex;flex-wrap:wrap;gap:14px}
.apy-form-row .apy-form-group{flex:1;min-width:140px}
.apy-form-grid{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-start;margin-bottom:16px}
.apy-form-grid .apy-form-group{flex:1;min-width:140px}
.apy-form-satir{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.apy-inline-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.apy-form-section{background:var(--arkaplan);border:1px solid var(--kenar);border-radius:var(--r);padding:18px 20px;margin-bottom:16px}
.apy-checkbox-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:13px;line-height:1.5}
.apy-checkbox-label input[type=checkbox]{width:16px;height:16px;margin-top:2px;accent-color:var(--ana);flex-shrink:0}

/* ── PANEL ── */
.apy-panel{background:var(--kart);border-radius:var(--r-lg);box-shadow:var(--golge);padding:28px;margin-bottom:20px;border:1px solid rgba(226,232,240,.6)}
.apy-panel-baslik{font-family:var(--font-b);font-size:20px;font-weight:700;color:var(--metin);margin-bottom:22px;padding-bottom:16px;border-bottom:1px solid var(--kenar);display:flex;align-items:center;gap:10px}
.apy-panel-baslik .apy-baslik-ikon{width:38px;height:38px;border-radius:var(--r-sm);background:var(--ana-acik);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;border:1px solid var(--ana-kenar)}
.apy-section-baslik{font-family:var(--font-b);font-size:14px;font-weight:600;color:var(--metin);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.apy-sticky-actions{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px;padding:10px 14px;background:var(--arkaplan);border-radius:var(--r-sm);border:1px solid var(--kenar)}

/* ── KARTLAR ── */
.apy-kart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:16px}
.apy-kart{background:var(--kart);border:1px solid var(--kenar);border-radius:var(--r);padding:20px;transition:var(--gecis);position:relative;overflow:hidden}
.apy-kart:hover{box-shadow:var(--golge-lg);border-color:var(--ana-kenar);transform:translateY(-2px)}
.apy-kart::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--ana),var(--cam))}
.apy-kart-ust{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.apy-kart-ikon{width:44px;height:44px;border-radius:var(--r);background:var(--ana-acik);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.apy-kart-bilgi{flex:1;min-width:0}
.apy-kart-bilgi strong{display:block;font-weight:600;font-size:15px;color:var(--metin);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apy-kart-bilgi small{font-size:12px;color:var(--metin-3)}
.apy-kart-meta{font-size:13px;color:var(--metin-2);padding:10px 0;border-top:1px solid var(--kenar);border-bottom:1px solid var(--kenar);margin:12px 0;display:flex;flex-wrap:wrap;gap:8px}
.apy-kart-aksiyonlar{display:flex;gap:8px;flex-wrap:wrap}

.apy-daire-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:12px;margin-top:16px}
.apy-daire-kart{background:var(--kart);border:1.5px solid var(--kenar);border-radius:var(--r);padding:16px;transition:var(--gecis);display:flex;flex-direction:column;gap:8px;position:relative}
.apy-daire-kart:hover{border-color:var(--ana);box-shadow:0 4px 12px rgba(26,86,219,.12);transform:translateY(-2px)}
.apy-daire-no{font-family:var(--font-b);font-size:16px;font-weight:600;color:var(--metin)}
.apy-daire-sakin{font-size:12px;color:var(--metin-2)}
.apy-daire-sakin.apy-pasif{color:var(--metin-3);font-style:italic}
.apy-daire-bakiye{font-size:13px;font-weight:600}
.apy-daire-aksiyonlar{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.apy-daire-durum-dot{position:absolute;top:12px;right:12px;width:8px;height:8px;border-radius:50%}

/* ── TABLO ── */
.apy-tablo-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--kenar)}
.apy-tablo{width:100%;border-collapse:collapse;font-size:14px}
.apy-tablo thead th{background:var(--arkaplan);color:var(--metin-2);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;text-align:left;border-bottom:1px solid var(--kenar);white-space:nowrap}
.apy-tablo thead th input[type=checkbox]{accent-color:var(--ana)}
.apy-tablo tbody td{padding:13px 16px;border-bottom:1px solid var(--kenar);background:#fff;vertical-align:middle}
.apy-tablo tbody tr:last-child td{border-bottom:none}
.apy-tablo tbody tr:hover td{background:var(--arkaplan)}
.apy-tablo.apy-tablo-ic{font-size:13px}
.apy-tablo.apy-tablo-ic th,.apy-tablo.apy-tablo-ic td{padding:9px 12px}
.apy-tablo.apy-tablo-ic thead th{background:#f8fafc;font-size:11px}
.apy-td-kisalt{max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── BADGE ── */
.apy-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--r-full);font-size:11.5px;font-weight:600;background:var(--arkaplan);color:var(--metin-2);border:1px solid var(--kenar);white-space:nowrap}
.apy-badge-mavi{background:var(--ana-acik);color:var(--ana);border-color:var(--ana-kenar)}
.apy-badge-yesil{background:var(--yesil-acik);color:var(--yesil);border-color:#6ee7b7}
.apy-badge-kirmizi{background:var(--kirmizi-acik);color:var(--kirmizi);border-color:#fca5a5}
.apy-badge-sari{background:var(--turuncu-acik);color:var(--turuncu);border-color:#fcd34d}
.apy-badge-mor{background:var(--mor-acik);color:var(--mor);border-color:#c4b5fd}
.apy-badge-cam{background:var(--cam-acik);color:var(--cam);border-color:#67e8f9}
.apy-badge-turuncu{background:var(--turuncu-acik);color:var(--turuncu);border-color:#fcd34d}

/* ── ALERTLER ── */
.apy-alert-hata,.apy-alert-basari{padding:13px 16px;border-radius:var(--r-sm);font-size:14px;font-weight:500;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px}
.apy-alert-hata{background:var(--kirmizi-acik);color:var(--kirmizi);border:1px solid #fca5a5}
.apy-alert-basari{background:var(--yesil-acik);color:var(--yesil);border:1px solid #6ee7b7}

/* ── AUTH ── */
.apy-auth-wrap{min-height:calc(100vh - var(--hh) - 100px);display:flex;align-items:center;justify-content:center;padding:40px 20px}
.apy-auth-container{width:100%;max-width:480px}
.apy-auth-box{background:var(--kart);border-radius:var(--r-lg);box-shadow:var(--golge-lg);padding:40px 36px;border:1px solid var(--kenar)}
.apy-auth-header{text-align:center;margin-bottom:32px}
.apy-auth-header .apy-auth-ikon-wrap{width:60px;height:60px;background:var(--ana-acik);border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 16px;border:1px solid var(--ana-kenar)}
.apy-auth-header h1{font-size:22px;font-weight:700;color:var(--metin);margin-bottom:6px}
.apy-auth-header p{font-size:14px;color:var(--metin-2)}
.apy-auth-form .apy-form-group{margin-bottom:16px}
.apy-auth-form label{font-size:13px;font-weight:600;color:var(--metin);display:block;margin-bottom:6px}
.apy-auth-form .apy-input{padding:12px 14px;font-size:15px}
.apy-auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--metin-3);font-size:12px}
.apy-auth-divider::before,.apy-auth-divider::after{content:'';flex:1;height:1px;background:var(--kenar)}
.apy-auth-footer{text-align:center;margin-top:22px;font-size:13px;color:var(--metin-2)}
.apy-auth-footer a{color:var(--ana);font-weight:600}
.apy-captcha-wrap{background:var(--arkaplan);border:1px solid var(--kenar);border-radius:var(--r-sm);padding:14px 16px;margin-bottom:16px}
.apy-captcha-wrap label{font-size:13px;font-weight:600;display:block;margin-bottom:8px;color:var(--metin)}
.apy-captcha-wrap .apy-input{max-width:110px}
.apy-sifre-wrapper{position:relative}
.apy-sifre-goster-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:18px;color:var(--metin-3);cursor:pointer;padding:4px;transition:color .15s}
.apy-sifre-goster-btn:hover{color:var(--metin)}
.apy-login-alt-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px 18px;background:var(--arkaplan);border:1.5px solid var(--kenar);border-radius:var(--r-sm);font-size:14px;font-weight:500;color:var(--metin);cursor:pointer;transition:var(--gecis);text-decoration:none;font-family:var(--font-g)}
.apy-login-alt-btn:hover{border-color:var(--ana);color:var(--ana);background:var(--ana-acik)}

/* ── ÖZET KARTLAR ── */
.apy-ozet-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:22px}
.apy-ozet-kart{display:flex;align-items:center;gap:16px;padding:20px;border-radius:var(--r);border:1px solid var(--kenar);background:var(--kart);box-shadow:var(--golge);transition:var(--gecis)}
.apy-ozet-kart:hover{transform:translateY(-1px);box-shadow:var(--golge-lg)}
.apy-ozet-kart .apy-ozet-ikon{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.apy-ozet-bilgi{flex:1;min-width:0}
.apy-ozet-etiket{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--metin-3);display:block;margin-bottom:4px}
.apy-ozet-rakam{font-family:var(--font-b);font-size:20px;font-weight:700;color:var(--metin);display:block}
.apy-ozet-gelir .apy-ozet-ikon{background:var(--yesil-acik)}
.apy-ozet-gider .apy-ozet-ikon{background:var(--kirmizi-acik)}
.apy-ozet-kalan-pos .apy-ozet-ikon{background:var(--ana-acik)}
.apy-ozet-kalan-neg .apy-ozet-ikon{background:var(--turuncu-acik)}
.apy-ozet-mor .apy-ozet-ikon{background:var(--mor-acik)}

/* ── PANEL MENÜSÜ ── */
.apy-panel-menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:12px}
.apy-menu-kart{display:flex;flex-direction:column;align-items:center;gap:10px;padding:22px 16px;background:var(--kart);border:1.5px solid var(--kenar);border-radius:var(--r);color:var(--metin);text-decoration:none;transition:var(--gecis);text-align:center}
.apy-menu-kart:hover{border-color:var(--ana);background:var(--ana-acik);color:var(--ana);transform:translateY(-3px);box-shadow:0 6px 20px rgba(26,86,219,.12)}
.apy-menu-ikon{width:48px;height:48px;border-radius:var(--r);background:var(--arkaplan);display:flex;align-items:center;justify-content:center;font-size:22px;transition:var(--gecis)}
.apy-menu-kart:hover .apy-menu-ikon{background:rgba(26,86,219,.1)}
.apy-menu-ad{font-size:13px;font-weight:600;line-height:1.3}

/* ── KULLANICI PANELİ ── */
.apy-kullanici-panel{max-width:860px}
.apy-kp-header{background:linear-gradient(135deg,var(--ana),var(--ana-koyu));border-radius:var(--r);padding:20px 24px;display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;box-shadow:0 4px 16px rgba(26,86,219,.2)}
.apy-kp-hosgeldin{display:flex;align-items:center;gap:12px}
.apy-kp-hosgeldin .apy-kp-avatar{width:44px;height:44px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;color:#fff}
.apy-kp-hosgeldin strong{color:#fff;font-size:16px;display:block}
.apy-kp-hosgeldin small{color:rgba(255,255,255,.75);font-size:12px}
.apy-kp-daire-baslik{font-family:var(--font-b);font-size:17px;font-weight:600;color:var(--metin);padding:14px 0;margin-bottom:16px;border-bottom:2px solid var(--kenar);display:flex;align-items:center;gap:8px}
.apy-kp-ozet-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.apy-kp-ozet-kart{display:flex;align-items:center;gap:12px;padding:16px;border-radius:var(--r);border:1px solid var(--kenar);background:var(--kart);box-shadow:var(--golge)}
.apy-kp-tamam{border-color:#6ee7b7;background:linear-gradient(135deg,#f0fdf4,#d1fae5)}
.apy-kp-borclu{border-color:#fca5a5;background:linear-gradient(135deg,#fff5f5,#fee2e2)}
.apy-kp-ozet-ikon{font-size:26px}
.apy-kp-ozet-etiket{font-size:11px;color:var(--metin-2);font-weight:600;display:block;text-transform:uppercase;letter-spacing:.4px}
.apy-kp-ozet-deger{font-family:var(--font-b);font-size:17px;font-weight:700;color:var(--metin);display:block}

.apy-kp-tab-header{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:16px;border-bottom:2px solid var(--kenar);padding-bottom:0}
.apy-kp-tab-btn{background:none;border:none;padding:10px 16px;font-size:13px;font-weight:600;color:var(--metin-2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;border-radius:var(--r-sm) var(--r-sm) 0 0;transition:var(--gecis);font-family:var(--font-g)}
.apy-kp-tab-btn.active,.apy-kp-tab-btn:hover{color:var(--ana);border-bottom-color:var(--ana);background:var(--ana-acik)}
.apy-kp-tab-icerik{display:none}
.apy-kp-tab-icerik.active{display:block}

/* ── DUYURULAR ── */
.apy-duyuru-liste{display:flex;flex-direction:column;gap:12px}
.apy-duyuru-form{background:var(--arkaplan);border:1px solid var(--kenar);border-radius:var(--r);padding:20px;margin-bottom:20px}
.apy-duyuru-kart{background:var(--kart);border:1px solid var(--kenar);border-left:4px solid var(--ana);border-radius:0 var(--r) var(--r) 0;padding:18px 20px;transition:var(--gecis)}
.apy-duyuru-kart:hover{box-shadow:var(--golge)}
.apy-duyuru-ust{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}
.apy-duyuru-tarih{font-size:12px;color:var(--metin-3)}
.apy-duyuru-baslik{font-family:var(--font-b);font-size:15px;margin-bottom:6px;color:var(--metin)}
.apy-duyuru-icerik{font-size:14px;color:var(--metin-2);line-height:1.65;white-space:pre-line}
.apy-duyuru-sil-form{margin-top:12px}

/* ── HESABIM ── */
.apy-hesap-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.apy-hesap-bolum{background:var(--arkaplan);border:1px solid var(--kenar);border-radius:var(--r);padding:20px}
.apy-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}
.apy-info-kart{padding:14px 16px;border-radius:var(--r-sm);background:var(--kart);border:1px solid var(--kenar);display:flex;flex-direction:column;gap:4px}
.apy-info-etiket{font-size:11px;color:var(--metin-3);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.apy-info-deger{font-family:var(--font-b);font-size:16px;font-weight:700;color:var(--metin)}

/* ── TOPLU ── */
.apy-toplu-wrap{background:var(--arkaplan);border:1px solid var(--kenar);border-radius:var(--r);padding:20px;margin-top:16px}
.apy-toplu-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.apy-toplu-kart{background:var(--kart);border:1px solid var(--kenar);border-radius:var(--r-sm);padding:16px}
.apy-toplu-kart strong{display:block;margin-bottom:10px;font-size:13px;color:var(--metin)}

/* ── RAPOR ── */
.apy-rapor-bolum{margin-bottom:24px}
.apy-rapor-baslik-satir{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.apy-progress-wrap{position:relative;background:var(--kenar);border-radius:var(--r-full);height:20px;min-width:80px;overflow:hidden;display:flex;align-items:center}
.apy-progress-bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--ana),var(--cam));border-radius:var(--r-full);transition:width .5s ease}
.apy-progress-wrap span{position:relative;z-index:1;font-size:11px;font-weight:700;color:var(--metin);padding:0 8px}

/* ── ACCORDION ── */
.apy-daire-satir{cursor:pointer}
.apy-daire-satir:hover td{background:var(--ana-acik)!important}
.apy-daire-satir.acik td{background:var(--ana-acik)!important}
.apy-expand-ipucu{font-size:10px;color:var(--metin-3);margin-left:4px;transition:transform .2s;display:inline-block}
.apy-daire-satir.acik .apy-expand-ipucu{transform:rotate(180deg)}
.apy-hareket-satir>td{padding:0!important}
.apy-hareket-detay{padding:16px;background:#f8fafc;border-top:1px solid var(--kenar)}
.apy-hareket-islemler{display:flex;gap:6px;flex-wrap:wrap;align-items:flex-start}
.apy-duzelt-form{background:var(--arkaplan);border:1px solid var(--kenar);border-radius:var(--r-sm);padding:12px;margin-top:8px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}

/* ── HERO ── */
.apy-hero{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:60px 0}
.apy-chip{display:inline-flex;align-items:center;gap:6px;background:var(--ana-acik);color:var(--ana);border:1px solid var(--ana-kenar);border-radius:var(--r-full);padding:5px 12px;font-size:12px;font-weight:600;margin-bottom:16px}
.apy-hero h1{font-family:var(--font-b);font-size:38px;font-weight:700;line-height:1.2;color:var(--metin);margin-bottom:18px}
.apy-hero h1 span{color:var(--ana)}
.apy-hero p{font-size:16px;color:var(--metin-2);line-height:1.75;margin-bottom:28px;max-width:480px}
.apy-hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.apy-hero-badges{display:flex;flex-wrap:wrap;gap:8px}
.apy-hero-badges span{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--metin-2);font-weight:500}
.apy-hero-badges span::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--yesil);flex-shrink:0}
.apy-hero-mini-stats{display:flex;gap:20px;flex-wrap:wrap;margin-top:28px}
.apy-hero-mini-stats div{display:flex;flex-direction:column;gap:2px}
.apy-hero-mini-stats strong{font-family:var(--font-b);font-size:18px;color:var(--ana)}
.apy-hero-mini-stats span{font-size:12px;color:var(--metin-3)}
.apy-glass-card,.apy-showcase-card{background:var(--kart);border:1px solid var(--kenar);border-radius:var(--r-lg);padding:28px;box-shadow:var(--golge-lg)}
.apy-glass-card h3{font-size:16px;margin-bottom:16px;color:var(--metin)}
.apy-hero-list{list-style:none;counter-reset:h;display:flex;flex-direction:column;gap:12px}
.apy-hero-list li{counter-increment:h;display:flex;align-items:center;gap:12px;font-size:14px;color:var(--metin-2);font-weight:500}
.apy-hero-list li::before{content:counter(h);width:26px;height:26px;background:var(--ana);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;font-family:var(--font-b);flex-shrink:0}
.apy-showcase-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--kenar);gap:12px}
.apy-showcase-row:last-child{border-bottom:none}
.apy-showcase-row strong{font-size:14px;font-weight:600;color:var(--metin)}
.apy-showcase-row span{font-size:13px;color:var(--metin-2);text-align:right}
.apy-home-section{padding:40px 0}
.apy-home-section-tight{padding:20px 0}
.apy-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:24px}
.apy-feature-kart{background:var(--kart);border:1px solid var(--kenar);border-radius:var(--r);padding:24px 20px;text-align:center;box-shadow:var(--golge);transition:var(--gecis)}
.apy-feature-kart:hover{transform:translateY(-3px);box-shadow:var(--golge-lg);border-color:var(--ana-kenar)}
.apy-feature-kart .apy-feature-ikon{font-size:32px;margin-bottom:12px}
.apy-feature-kart h3{font-size:15px;font-weight:600;margin-bottom:8px;color:var(--metin)}
.apy-feature-kart p{font-size:13px;color:var(--metin-2);line-height:1.6}

/* ── FOOTER ── */
.apy-footer-ad-wrap{background:var(--arkaplan);border-top:1px solid var(--kenar);padding:20px 0}
.apy-footer-ad-label{font-size:11px;color:var(--metin-3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-weight:600}
.apy-footer{background:var(--metin);padding:40px 0 0;margin-top:40px}
.apy-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;padding-bottom:32px}
.apy-footer-brand strong{color:#fff;font-family:var(--font-b);font-size:16px;display:block;margin-bottom:8px}
.apy-footer-brand p{font-size:13px;color:rgba(255,255,255,.5);line-height:1.7;max-width:280px}
.apy-footer h4{color:rgba(255,255,255,.7);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;margin-bottom:14px}
.apy-footer-links{display:flex;flex-direction:column;gap:8px}
.apy-footer-links a{color:rgba(255,255,255,.55);font-size:13px;transition:var(--gecis)}
.apy-footer-links a:hover{color:#fff}
.apy-footer-list{list-style:none;display:flex;flex-direction:column;gap:6px}
.apy-footer-list li{color:rgba(255,255,255,.55);font-size:13px;display:flex;align-items:center;gap:6px}
.apy-footer-list li::before{content:'';width:4px;height:4px;background:rgba(255,255,255,.3);border-radius:50%}
.apy-footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:16px 0}
.apy-footer-bottom-inner{display:flex;justify-content:space-between;align-items:center}
.apy-footer-bottom span{font-size:13px;color:rgba(255,255,255,.4)}
.apy-footer-bottom a{font-size:13px;color:rgba(255,255,255,.5)}
.apy-footer-bottom a:hover{color:#fff}

/* ── YARDIMCILAR ── */
.apy-yesil{color:var(--yesil)!important}
.apy-kirmizi{color:var(--kirmizi)!important}
.apy-link{color:var(--ana);text-decoration:underline;text-underline-offset:3px}
.apy-ayrac{border:none;border-top:1px solid var(--kenar);margin:20px 0}
.apy-bos-yazi{text-align:center;color:var(--metin-3);padding:24px!important;font-style:italic;font-size:13px}
.apy-bos-durum{text-align:center;padding:40px 20px}
.apy-bos-durum .apy-bos-ikon{font-size:48px;display:block;margin-bottom:12px;opacity:.5}
.apy-bos-durum p{font-size:15px;color:var(--metin-2);margin:0}
.apy-wa-link{display:inline-flex;align-items:center;vertical-align:middle}
.apy-admin-hizli-erisim{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}

/* ── MOBİL ── */
@media(max-width:992px){
  .apy-nav{display:none;position:fixed;top:var(--hh);left:0;right:0;bottom:0;background:var(--kart);flex-direction:column;align-items:stretch;justify-content:flex-start;padding:16px;z-index:999;overflow-y:auto;gap:4px;border-top:1px solid var(--kenar);box-shadow:0 8px 40px rgba(0,0,0,.15)}
  .apy-nav.acik{display:flex}
  .apy-nav a{padding:13px 16px;font-size:15px;border-radius:var(--r);border:1px solid transparent}
  .apy-nav a:hover,.apy-nav a.aktif{background:var(--ana-acik);border-color:var(--ana-kenar)}
  .apy-hamburger{display:flex}
  .apy-header-kullanici-ad{display:none}
  body.apy-menu-open{overflow:hidden}
  .apy-hero{grid-template-columns:1fr;text-align:center;gap:30px;padding:40px 0}
  .apy-hero h1{font-size:28px}
  .apy-hero p{max-width:100%}
  .apy-hero-actions{justify-content:center}
  .apy-hero-badges{justify-content:center}
  .apy-hero-mini-stats{justify-content:center}
  .apy-hero-side{display:none}
  .apy-kp-ozet-grid{grid-template-columns:1fr}
  .apy-hesap-grid{grid-template-columns:1fr}
  .apy-toplu-grid{grid-template-columns:1fr}
  .apy-kart-grid{grid-template-columns:1fr}
  .apy-footer-grid{grid-template-columns:1fr}
  .apy-ozet-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .apy-panel{padding:18px 16px;border-radius:var(--r)}
  .apy-panel-baslik{font-size:17px}
  .apy-daire-grid{grid-template-columns:repeat(2,1fr)}
  .apy-form-satir{flex-direction:column;align-items:stretch}
  .apy-form-satir .apy-btn,.apy-form-satir .apy-btn-sm{width:100%;justify-content:center}
  .apy-auth-box{padding:24px 18px;border-radius:var(--r)}
  .apy-ozet-grid{grid-template-columns:1fr 1fr}
  .apy-kp-tab-btn{padding:8px 10px;font-size:12px}
  .apy-panel-menu-grid{grid-template-columns:repeat(2,1fr)}
  .apy-ozet-rakam{font-size:17px}
  .apy-site-icerik{padding-bottom:80px}
}
@media(max-width:400px){
  .apy-daire-grid{grid-template-columns:1fr}
  .apy-ozet-grid{grid-template-columns:1fr}
  .apy-kp-ozet-grid{grid-template-columns:1fr}
}

/* ── MOBİL BOTTOM NAV ── */
.apy-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--kart);border-top:1px solid var(--kenar);z-index:998;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -4px 20px rgba(0,0,0,.08)}
.apy-bottom-nav-inner{display:flex;align-items:center;height:100%;gap:4px}
.apy-bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:6px 4px;border-radius:var(--r-sm);text-decoration:none;color:var(--metin-3);font-size:10px;font-weight:600;transition:var(--gecis);border:none;background:none;cursor:pointer;font-family:var(--font-g)}
.apy-bottom-nav-item .apy-bnav-ikon{font-size:20px}
.apy-bottom-nav-item.aktif{color:var(--ana);background:var(--ana-acik)}
.apy-bottom-nav-item:hover{color:var(--ana)}
@media(max-width:640px){.apy-bottom-nav{display:flex}}

@media print{
  .apy-header,.apy-footer,.apy-bottom-nav,.apy-btn,.apy-btn-sm,form{display:none!important}
  .apy-panel{box-shadow:none;border:1px solid #ddd;break-inside:avoid}
  body{background:#fff;font-size:13px}
}

/* ── UYUMLULUK EKLERİ (v3.7 modülleri için) ── */
.apy-auth-logo { text-align:center; margin-bottom:28px; }
.apy-auth-logo .apy-auth-ikon { font-size:48px; display:block; margin-bottom:12px; line-height:1; }
.apy-auth-logo h1,.apy-auth-logo h2 { font-family:var(--font-b); font-size:22px; font-weight:700; color:var(--metin); margin-bottom:6px; }
.apy-auth-logo p { font-size:14px; color:var(--metin-2); margin:0; }
.apy-input-full { width:100%; display:block; }
.apy-form-row { display:flex; flex-wrap:wrap; gap:14px; }
.apy-form-row .apy-form-group { flex:1; min-width:140px; }
.apy-captcha-group{background:var(--arkaplan);border:1px solid var(--kenar);border-radius:var(--r-sm);padding:14px 16px;margin-bottom:16px}
.apy-captcha-group label{font-size:13px;font-weight:600;display:block;margin-bottom:8px;color:var(--metin)}
.apy-kvkk-group{margin-bottom:20px}
.apy-content{line-height:1.8;color:var(--metin-2)}
.apy-content p{margin-bottom:12px}
.apy-kp-tabs{margin-top:16px}
.apy-kp-ikon{font-size:26px;flex-shrink:0}
.apy-mobile-stack{display:flex;flex-wrap:wrap;gap:10px}
@media(max-width:640px){.apy-mobile-stack{flex-direction:column}}

/* ── LANDING PAGE ── */
.apy-landing-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;padding:48px 0 40px}
.apy-landing-left h1{font-family:var(--font-b);font-size:34px;font-weight:700;line-height:1.2;color:var(--metin);margin:12px 0 14px}
.apy-landing-left h1 span{color:var(--ana)}
.apy-landing-left p{font-size:15px;color:var(--metin-2);line-height:1.75;margin-bottom:22px}
.apy-landing-ozellik-list{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.apy-ozellik-satir{display:flex;align-items:flex-start;gap:12px}
.apy-ozellik-ikon{width:34px;height:34px;background:var(--ana-acik);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;border:1px solid var(--ana-kenar)}
.apy-ozellik-satir strong{display:block;font-size:13.5px;font-weight:600;color:var(--metin);margin-bottom:1px}
.apy-ozellik-satir span{font-size:12.5px;color:var(--metin-2)}
.apy-landing-badges{display:flex;flex-wrap:wrap;gap:7px}
.apy-landing-badges span{font-size:12px;color:var(--metin-2);font-weight:500;background:var(--arkaplan);border:1px solid var(--kenar);padding:4px 10px;border-radius:var(--r-full)}
.apy-landing-right{}
.apy-landing-auth-box{background:var(--kart);border-radius:var(--r-lg);box-shadow:var(--golge-lg);border:1px solid var(--kenar);overflow:hidden}
.apy-landing-auth-tabs{display:flex;border-bottom:2px solid var(--kenar)}
.apy-landing-tab{flex:1;padding:14px;font-size:14px;font-weight:600;font-family:var(--font-g);background:var(--arkaplan);border:none;cursor:pointer;color:var(--metin-2);transition:var(--gecis);border-bottom:2px solid transparent;margin-bottom:-2px}
.apy-landing-tab.aktif{background:var(--kart);color:var(--ana);border-bottom-color:var(--ana)}
.apy-landing-tab-content{display:none;padding:24px}
.apy-landing-tab-content.aktif{display:block}
.apy-landing-form .apy-form-group{margin-bottom:13px}
.apy-landing-form label{font-size:13px;font-weight:600;color:var(--metin);display:block;margin-bottom:5px}
.apy-landing-guven{display:flex;gap:10px;margin-top:12px}
.apy-landing-guven div{flex:1;display:flex;align-items:center;gap:7px;background:var(--kart);border:1px solid var(--kenar);border-radius:var(--r-sm);padding:9px 12px;font-size:12px;color:var(--metin-2);font-weight:500}
.apy-landing-guven div span:first-child{font-size:16px}
@media(max-width:900px){.apy-landing-wrap{grid-template-columns:1fr;padding:28px 0}.apy-landing-left h1{font-size:26px}}

/* ── İLETİŞİM & ATAMA ── */
.apy-contact-islem-wrap summary{padding:6px 0}

/* ── İLETİŞİM MERKEZİ (contact.php içinde de var ama global olsun) ── */
.apy-contact-liste{display:flex;flex-direction:column;gap:12px}
.apy-contact-kart{background:var(--kart);border:1px solid var(--kenar);border-left:4px solid var(--ana);border-radius:0 var(--r) var(--r) 0;padding:18px 20px;transition:var(--gecis)}
.apy-contact-kart:hover{box-shadow:var(--golge)}
.apy-contact-kart-ust{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.apy-contact-konu{font-family:var(--font-b);font-size:15px;color:var(--metin);margin-bottom:8px}
.apy-contact-mesaj{font-size:14px;color:var(--metin-2);line-height:1.65;white-space:pre-line}
.apy-contact-yanit{background:var(--yesil-acik);border:1px solid #6ee7b7;border-radius:var(--r-sm);padding:12px 16px;margin-top:12px;font-size:13px}
.apy-contact-yanit strong{display:block;color:var(--yesil);margin-bottom:4px}
.apy-contact-yanit p{color:var(--metin-2);margin:0}

/* ── FOOTER AD ── */
.apy-footer-ad-content{color:var(--metin);font-size:14px;line-height:1.6}

/* ── HERO MAIN (giriş yapılmışsa) ── */
.apy-hero-main{display:flex;flex-direction:column}

/* ── HEADER DROPDOWN (global) ── */
.apy-nav-diger{position:relative}
.apy-nav-diger-btn{display:flex;align-items:center;gap:4px;color:var(--metin-2);padding:6px 12px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;background:none;border:none;cursor:pointer;font-family:var(--font-g);transition:var(--gecis)}
.apy-nav-diger-btn:hover,.apy-nav-diger-btn.aktif{color:var(--ana);background:var(--ana-acik)}
.apy-nav-diger-btn svg{transition:transform .2s}
.apy-nav-diger.open .apy-nav-diger-btn svg{transform:rotate(180deg)}
.apy-nav-diger.open .apy-nav-diger-btn{color:var(--ana);background:var(--ana-acik)}
.apy-nav-dropdown{display:none;position:absolute;top:calc(100% + 6px);right:0;background:var(--kart);border:1px solid var(--kenar);border-radius:var(--r);box-shadow:var(--golge-lg);min-width:210px;z-index:2000;overflow:hidden}
.apy-nav-diger.open .apy-nav-dropdown{display:block}
.apy-nav-dropdown a{display:flex;align-items:center;gap:10px;padding:11px 16px;font-size:13.5px;color:var(--metin-2);transition:var(--gecis);border-bottom:1px solid var(--kenar);text-decoration:none}
.apy-nav-dropdown a:last-child{border-bottom:none}
.apy-nav-dropdown a:hover{background:var(--ana-acik);color:var(--ana)}
.apy-nav-dropdown .diger-ikon{font-size:16px;width:24px;text-align:center;flex-shrink:0}

/* Mobil'de dropdown full width */
@media(max-width:992px){
  .apy-nav-dropdown{position:static;box-shadow:none;border:none;border-radius:0;border-top:1px solid var(--kenar)}
  .apy-nav-diger{border-top:1px solid var(--kenar)}
  .apy-nav-diger-btn{width:100%;border-radius:var(--r);border:1px solid transparent;padding:13px 16px;font-size:15px;justify-content:space-between}
  .apy-nav-dropdown a{padding:10px 20px;font-size:14px}
}

/* ── SAFARİ & GENEL TARAYICI UYUMLULUK ── */

/* Tüm input/select/textarea Safari'de düzgün görünsün */
.apy-input,
.apy-select,
input.apy-input,
select.apy-select,
textarea.apy-input {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 8px;         /* Safari varsayılanı sıfırla */
    background-clip: padding-box;
    -webkit-tap-highlight-color: transparent;
}

/* Select'de custom ok - Safari dahil */
select.apy-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2394a3b8' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 16px;
    padding-right: 36px;
}

/* Number input spin buttons kaldır */
input[type="number"].apy-input::-webkit-outer-spin-button,
input[type="number"].apy-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
input[type="number"].apy-input { -moz-appearance: textfield; }

/* Auth kutusu label stili */
.apy-auth-form .apy-form-group label,
.apy-auth-form label {
    font-size: 13px;
    font-weight: 600;
    color: #374151;
    display: block;
    margin-bottom: 6px;
}
.apy-auth-form .apy-input {
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
    border: 1.5px solid #d1d5db;
    border-radius: 8px;
    padding: 12px 14px;
    font-size: 15px;
    background: #fff;
    color: #111827;
    transition: border-color .15s, box-shadow .15s;
    outline: none;
    box-sizing: border-box;
    display: block;
}
.apy-auth-form .apy-input:focus {
    border-color: #1a56db;
    box-shadow: 0 0 0 3px rgba(26,86,219,.12);
}
.apy-auth-form .apy-input::placeholder { color: #9ca3af; }

/* Auth box daha dar/odaklı */
.apy-auth-box { max-width: 460px; }
.apy-auth-wrap { align-items: flex-start; padding-top: 48px; }

/* Login form buton */
.apy-auth-form .apy-btn-primary {
    width: 100%;
    justify-content: center;
    padding: 14px 24px;
    font-size: 16px;
    border-radius: 10px;
    -webkit-appearance: none;
}

/* Checkbox Safari düzelt */
.apy-checkbox-label input[type="checkbox"] {
    -webkit-appearance: checkbox;
    appearance: checkbox;
    width: 16px;
    height: 16px;
    flex-shrink: 0;
}

/* Auth divider */
.apy-auth-divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 18px 0;
    color: #9ca3af;
    font-size: 12px;
}
.apy-auth-divider::before,
.apy-auth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: #e5e7eb;
}

/* Auth footer linkler */
.apy-auth-footer {
    text-align: center;
    margin-top: 18px;
    font-size: 13px;
    color: #6b7280;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.apy-auth-footer a { color: #1a56db; font-weight: 600; }

/* Landing login kutusu içi input'lar */
.apy-landing-form .apy-input {
    -webkit-appearance: none;
    appearance: none;
    border: 1.5px solid #d1d5db;
    border-radius: 8px;
    padding: 11px 14px;
    font-size: 15px;
    width: 100%;
    background: #fff;
    color: #111827;
    transition: border-color .15s, box-shadow .15s;
    outline: none;
    box-sizing: border-box;
    display: block;
}
.apy-landing-form .apy-input:focus {
    border-color: #1a56db;
    box-shadow: 0 0 0 3px rgba(26,86,219,.12);
}
.apy-landing-form .apy-input::placeholder { color: #9ca3af; }

/* apy-login-alt-btn Safari */
.apy-login-alt-btn { -webkit-appearance: none; }

/* Genel: tüm butonlar Safari'de düzgün */
button.apy-btn,
button.apy-btn-sm,
button.apy-btn-primary,
input[type="submit"].apy-btn {
    -webkit-appearance: none;
    appearance: none;
}

/* ══════════════════════════════════════════════════════════
   APY DASHBOARD AKORDIYON SİSTEMİ
   ═══════════════════════════════════════════════════════════ */

/* Genel sarmalayıcı */
.apy-dash-wrap { max-width: 1100px; }

.apy-dash-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}
.apy-dash-baslik {
    font-family: var(--font-b);
    font-size: 22px;
    font-weight: 700;
    color: var(--metin);
    margin: 0 0 4px;
}
.apy-dash-alt { font-size: 13px; color: var(--metin-2); margin: 0; }
.apy-dash-admin-links { display: flex; flex-wrap: wrap; gap: 6px; }

/* Yeni apartman ekleme alanı (eski — geriye uyumluluk) */
.apy-dash-yeni-ap {
    background: var(--arkaplan);
    border: 1.5px dashed var(--kenar);
    border-radius: var(--r);
    padding: 14px 18px;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.apy-dash-yeni-ap::before {
    content: '🏢';
    font-size: 20px;
    flex-shrink: 0;
}

/* ── Genel Akordeon Toggle (Apartman Ekle + Sakin Ekle) ── */
.apy-acc-wrap {
    margin-bottom: 16px;
}
.apy-acc-wrap--sakin {
    margin-bottom: 12px;
}
.apy-acc-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 11px 16px;
    background: var(--arkaplan);
    border: 1.5px dashed var(--kenar);
    border-radius: var(--r);
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: var(--metin);
    transition: background .18s, border-color .18s;
    text-align: left;
}
.apy-acc-toggle:hover,
.apy-acc-toggle--open {
    background: var(--vurgu-soluk, rgba(59,130,246,.07));
    border-color: var(--vurgu, #3b82f6);
    color: var(--vurgu, #3b82f6);
}
.apy-acc-toggle--sakin {
    font-size: 13px;
    font-weight: 600;
    padding: 9px 14px;
    border-style: solid;
    border-width: 1px;
    background: var(--kart, #fff);
}
.apy-acc-ok {
    font-size: 18px;
    line-height: 1;
    transition: transform .2s;
    flex-shrink: 0;
}
.apy-acc-toggle--open .apy-acc-ok {
    transform: rotate(45deg);
}
.apy-acc-ikon {
    margin-right: 4px;
}
.apy-acc-body {
    border: 1px solid var(--kenar);
    border-top: none;
    border-radius: 0 0 var(--r) var(--r);
    padding: 16px;
    background: var(--kart, #fff);
    animation: apyAccSlide .18s ease;
}
@keyframes apyAccSlide {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Akordiyon liste ── */
.apy-ak-liste {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* ── Akordiyon item ── */
.apy-ak-item {
    background: var(--kart);
    border: 1.5px solid var(--kenar);
    border-radius: var(--r);
    overflow: hidden;
    transition: box-shadow .2s, border-color .2s;
}
.apy-ak-item:hover {
    border-color: var(--ana-kenar);
    box-shadow: var(--golge);
}
.apy-ak-item.apy-ak-acik {
    border-color: var(--ana);
    box-shadow: 0 0 0 3px rgba(26,86,219,.08), var(--golge);
}
.apy-ak-item.apy-ak-acik::before {
    /* Üst accent çizgisi */
    display: block;
}

/* ── Akordiyon başlık (tıklanabilir) ── */
.apy-ak-baslik {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    cursor: pointer;
    user-select: none;
    transition: background .15s;
    gap: 12px;
}
.apy-ak-baslik:hover { background: var(--arkaplan); }
.apy-ak-item.apy-ak-acik .apy-ak-baslik {
    background: var(--ana-acik);
    border-bottom: 1px solid var(--ana-kenar);
}

.apy-ak-baslik-sol {
    display: flex;
    align-items: center;
    gap: 14px;
    min-width: 0;
    flex: 1;
}
.apy-ak-ikon {
    font-size: 24px;
    width: 42px;
    height: 42px;
    background: var(--ana-acik);
    border-radius: var(--r-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border: 1px solid var(--ana-kenar);
}
.apy-ak-item.apy-ak-acik .apy-ak-ikon { background: var(--ana); }
.apy-ak-baslik-metin { min-width: 0; }
.apy-ak-baslik-metin strong {
    display: block;
    font-size: 15px;
    font-weight: 600;
    color: var(--metin);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.apy-ak-baslik-metin span {
    font-size: 12.5px;
    color: var(--metin-2);
    display: block;
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.apy-ak-baslik-sag { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.apy-ak-sil-btn {
    background: none;
    border: 1px solid var(--kenar);
    border-radius: var(--r-sm);
    padding: 4px 8px;
    font-size: 13px;
    cursor: pointer;
    color: var(--metin-3);
    transition: var(--gecis);
}
.apy-ak-sil-btn:hover { background: var(--kirmizi-acik); border-color: var(--kirmizi); color: var(--kirmizi); }
.apy-ak-ok {
    font-size: 13px;
    color: var(--metin-2);
    transition: transform .2s;
    min-width: 20px;
    text-align: center;
}
.apy-ak-item.apy-ak-acik .apy-ak-ok { color: var(--ana); }

/* ── Akordiyon içerik ── */
.apy-ak-icerik {
    animation: apy-ak-ac .2s ease;
}
@keyframes apy-ak-ac {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── İç wrap ── */
.apy-ak-ic-wrap {
    padding: 20px 24px 24px;
    display: flex;
    flex-direction: column;
    gap: 0;
}

/* ── Adım kutuları ── */
.apy-ak-adim {
    border: 1px solid var(--kenar);
    border-radius: var(--r);
    overflow: hidden;
    background: var(--kart);
}
.apy-ak-adim-baslik {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 18px;
    background: var(--arkaplan);
    border-bottom: 1px solid var(--kenar);
    font-size: 14px;
    font-weight: 600;
    color: var(--metin);
    flex-wrap: wrap;
}
.apy-ak-adim-no {
    width: 26px; height: 26px;
    background: var(--ana);
    color: #fff;
    border-radius: 50%;
    font-size: 13px;
    font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-b);
    flex-shrink: 0;
}
.apy-ak-adim-icerik { padding: 16px 18px; }

/* Ok aşağı bağlayıcı */
.apy-ak-ok-asagi {
    text-align: center;
    color: var(--metin-3);
    font-size: 18px;
    padding: 8px 0;
    line-height: 1;
}

/* Form satırı */
.apy-ak-form-satir {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: flex-end;
    margin-bottom: 14px;
}

/* İpucu metni */
.apy-ak-ipucu {
    font-size: 12.5px;
    color: var(--metin-3);
    background: var(--arkaplan);
    border: 1px solid var(--kenar);
    border-radius: var(--r-sm);
    padding: 9px 13px;
    margin: 4px 0 0;
    line-height: 1.55;
}

/* ── Blok tab'ları ── */
.apy-ak-blok-tablar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
}
.apy-ak-blok-tab-wrap {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--arkaplan);
    border: 1px solid var(--kenar);
    border-radius: var(--r-full);
    overflow: hidden;
}
.apy-ak-blok-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    font-size: 13px;
    font-weight: 500;
    color: var(--metin-2);
    text-decoration: none;
    border-radius: var(--r-full);
    transition: var(--gecis);
    border: 1.5px solid var(--kenar);
    background: var(--arkaplan);
}
.apy-ak-blok-tab:hover { border-color: var(--ana); color: var(--ana); background: var(--ana-acik); }
.apy-ak-blok-tab.aktif {
    background: var(--ana);
    color: #fff;
    border-color: var(--ana);
    font-weight: 600;
}
.apy-ak-blok-tab.aktif .apy-badge { background: rgba(255,255,255,.25); color: #fff; border-color: transparent; }
.apy-ak-blok-tab-wrap .apy-ak-blok-tab { border-radius: var(--r-full) 0 0 var(--r-full); border-right: none; }
.apy-ak-blok-sil {
    background: none;
    border: none;
    padding: 0 10px;
    font-size: 16px;
    color: var(--metin-3);
    cursor: pointer;
    height: 100%;
    transition: color .15s, background .15s;
    border-radius: 0 var(--r-full) var(--r-full) 0;
    line-height: 1;
}
.apy-ak-blok-sil:hover { color: var(--kirmizi); background: var(--kirmizi-acik); }

/* ── Daire Grid ── */
.apy-ak-daire-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 10px;
    margin-top: 4px;
}

/* ── Daire Kartı ── */
.apy-ak-daire-kart {
    background: var(--kart);
    border: 1.5px solid var(--kenar);
    border-radius: var(--r);
    padding: 14px 16px;
    transition: var(--gecis);
    display: flex;
    flex-direction: column;
    gap: 6px;
    position: relative;
}
.apy-ak-daire-kart:hover { border-color: var(--ana-kenar); box-shadow: var(--golge); }
.apy-ak-daire-kart.apy-ak-daire-acik {
    border-color: var(--ana);
    grid-column: 1 / -1;       /* açıkken tam genişlik */
    background: #fafcff;
    box-shadow: 0 0 0 3px rgba(26,86,219,.08);
}
.apy-ak-daire-ust { display: flex; align-items: center; justify-content: space-between; gap: 6px; }
.apy-ak-daire-no { font-family: var(--font-b); font-size: 16px; font-weight: 700; color: var(--metin); }
.apy-ak-daire-sakin { font-size: 12px; color: var(--metin-2); }
.apy-ak-daire-bakiye { font-size: 12.5px; font-weight: 600; }
.apy-ak-daire-aksiyonlar { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 4px; }

/* Blok değiştir select */
.apy-ak-blok-degis-form { margin: 2px 0; }

/* ── Sakin Panel (daire içi) ── */
.apy-ak-sakin-icerik {
    border-top: 1px solid var(--ana-kenar);
    margin-top: 12px;
    padding-top: 14px;
    animation: apy-ak-ac .2s ease;
}
.apy-ak-sakin-wrap { }
.apy-ak-sakin-form { margin-bottom: 8px; }
.apy-ak-sakin-form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 10px;
    align-items: end;
}

/* ── Mobil ── */
@media (max-width: 768px) {
    .apy-ak-ic-wrap { padding: 14px 14px 18px; }
    .apy-ak-daire-grid { grid-template-columns: repeat(2, 1fr); }
    .apy-ak-daire-kart.apy-ak-daire-acik { grid-column: 1 / -1; }
    .apy-ak-baslik { padding: 13px 16px; }
    .apy-dash-header { flex-direction: column; }
    .apy-ak-sakin-form-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
    .apy-ak-daire-grid { grid-template-columns: 1fr; }
    .apy-ak-sakin-form-grid { grid-template-columns: 1fr; }
    .apy-ak-blok-tablar { flex-direction: column; align-items: flex-start; }
}
