/* ══════════════════════════════════════════
   SPOR KULÜBÜ YÖNETİM (Multi-tenant)
   Renkler clubs.json'dan inline style ile override edilir.
══════════════════════════════════════════ */
:root {
  --shadow-rgb: 204,0,0;       /* clubs.json içinden override edilir */
  --teal:    #CC0000;
  --teal2:   #9B0000;
  --teal3:   #E53935;
  --teal-s:  #FFEBEE;
  --teal-m:  #FFCDD2;
  --dark:    #1A1A1A;
  --orange:  #D84315;
  --orange-s:#FBE9E7;
  --green:   #2E7D32;
  --green-s: #E8F5E9;
  --red:     #C62828;
  --red-s:   #FFEBEE;
  --yellow:  #E65100;
  --yellow-s:#FFF3E0;
  --bg:      #F5F5F5;
  --card:    #FFFFFF;
  --border:  #E0D5D5;
  --txt:     #1A1A1A;
  --txt2:    #4A4040;
  --txt3:    #C4A8A8;
  --r:       14px;
  --rs:      9px;
  --sh:      0 2px 12px rgba(var(--shadow-rgb), .09);
  --sh2:     0 6px 24px rgba(var(--shadow-rgb), .15);
}

/* ── BASE ── */
*, *::before, *::after { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
html { font-size:16px; height:100%; background:var(--bg); overscroll-behavior:none; }
body { font-family:'Outfit',sans-serif; background:var(--bg); color:var(--txt); min-height:100%; -webkit-font-smoothing:antialiased; overflow-x:hidden; overscroll-behavior:none; }
button { font-family:inherit; cursor:pointer; border:none; outline:none; transition:all .18s; }
input, textarea, select { font-family:inherit; outline:none; }
img { display:block; }

/* ── UTIL ── */
.hidden { display:none !important; }
.flex { display:flex; align-items:center; }
.gap4{gap:4px} .gap8{gap:8px} .gap12{gap:12px}
.txt-teal  { color:var(--teal); }
.txt-red   { color:var(--red); }
.txt-yellow{ color:var(--yellow); }
.txt-green { color:var(--green); }

/* ── TOAST ── */
#toast {
  position:fixed; bottom:32px; left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--dark); color:#fff;
  padding:11px 22px; border-radius:30px;
  font-size:13px; font-weight:600;
  z-index:9999; opacity:0;
  transition:all .3s; white-space:nowrap; pointer-events:none;
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
#toast.show { transform:translateX(-50%) translateY(0); opacity:1; }

/* ── LOADING ── */
#loading-screen {
  position:fixed; inset:0;
  background:linear-gradient(150deg,var(--teal2),var(--teal),var(--teal3));
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  z-index:1000; gap:18px;
}
#loading-screen .logo-img {
  width:96px; height:96px; object-fit:contain;
  border-radius:50%; background:#fff; padding:4px;
  box-shadow:0 8px 32px rgba(0,0,0,.25);
  animation:pulse 2s ease-in-out infinite;
}
#loading-screen .app-name {
  font-size:16px; font-weight:700; color:#fff;
  text-align:center; opacity:.9; letter-spacing:.4px;
}
@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.05)} }

/* ── İmza ── */
.signature {
  font-size:9px; font-weight:300; letter-spacing:1.2px;
  color:rgba(255,255,255,.16); text-transform:uppercase;
  text-align:center; margin-top:24px;
  font-feature-settings:"liga","kern";
}
.signature b { font-weight:500; color:rgba(255,255,255,.28); letter-spacing:1.4px; }
.signature-light { color:rgba(0,0,0,.18); margin-top:26px; }
.signature-light b { color:rgba(0,0,0,.32); font-weight:500; }
.spinner {
  width:32px; height:32px;
  border:3px solid rgba(255,255,255,.3);
  border-top-color:#fff; border-radius:50%;
  animation:spin .8s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }

/* ══════════════════════════════
   LOGIN
══════════════════════════════ */
#view-login {
  min-height:100vh; display:flex; flex-direction:column;
  background:linear-gradient(150deg,var(--teal2),var(--teal) 60%,var(--teal3));
}
.login-top {
  flex:1; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  padding:52px 24px 28px; gap:10px;
}
.login-logo {
  width:96px; height:96px; object-fit:contain;
  border-radius:50%; background:#fff; padding:4px;
  box-shadow:0 8px 32px rgba(0,0,0,.2);
  margin-bottom:4px;
}
.login-club {
  font-size:12px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; color:rgba(255,255,255,.75); text-align:center;
}
.login-title {
  font-size:26px; font-weight:800; color:#fff;
  letter-spacing:-.5px; text-align:center;
}
.login-form {
  background:#fff; border-radius:28px 28px 0 0;
  padding:32px 22px 48px;
  box-shadow:0 -6px 32px rgba(0,0,0,.15);
}
.login-form label {
  font-size:11px; font-weight:700; color:var(--txt2);
  display:block; margin-bottom:6px; margin-top:18px;
  text-transform:uppercase; letter-spacing:.7px;
}
.login-form label:first-of-type { margin-top:0; }
.field {
  width:100%; border:1.5px solid var(--border); border-radius:var(--rs);
  padding:13px 15px; font-size:15px; color:var(--txt); background:var(--bg);
  transition:border-color .2s, box-shadow .2s;
}
.field:focus { border-color:var(--teal); box-shadow:0 0 0 3px rgba(var(--shadow-rgb), .12); }
.err-msg { color:var(--red); font-size:13px; margin-top:8px; min-height:18px; }
.btn-primary {
  width:100%;
  background:linear-gradient(135deg,var(--teal),var(--teal2));
  color:#fff; border-radius:var(--r);
  padding:15px; font-size:16px; font-weight:700; margin-top:24px;
  box-shadow:0 4px 16px rgba(var(--shadow-rgb), .35);
}
.btn-primary:active { opacity:.88; transform:scale(.98); }
.btn-primary:disabled { opacity:.5; cursor:not-allowed; transform:none; }

/* ══════════════════════════════
   APP SHELL + TOPBAR
══════════════════════════════ */
#app { display:flex; flex-direction:column; min-height:100vh; }

.topbar {
  background:linear-gradient(135deg,var(--teal2),var(--teal));
  color:#fff;
  padding:50px 16px 13px;
  display:flex; align-items:center; justify-content:space-between;
  position:sticky; top:0; z-index:100;
  box-shadow:0 2px 16px rgba(153,0,0,.28);
}
.topbar.compact { padding-top:13px; }

/* Logo wrap — beyaz daire içinde logo */
.topbar-logo-wrap {
  width:40px; height:40px; border-radius:50%;
  background:#fff; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
  overflow:hidden;
  margin-right:2px;
}
.topbar-logo-img {
  width:38px; height:38px; object-fit:contain;
  border-radius:50%;
}

.topbar-title { font-size:17px; font-weight:700; flex:1; letter-spacing:-.2px; }
.role-chip {
  display:inline-flex; align-items:center;
  padding:2px 9px; border-radius:20px; font-size:11px; font-weight:700;
  background:rgba(255,255,255,.22); color:#fff; margin-top:2px; letter-spacing:.2px;
}
.topbar-back {
  background:rgba(255,255,255,.2); color:#fff; font-size:18px;
  width:40px; height:40px; border-radius:10px; margin-right:8px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  transition:all .2s;
}
.topbar-back:active { background:rgba(255,255,255,.35); transform:scale(0.94); }

.btn-logout {
  background:rgba(255,255,255,.2); color:#fff; font-size:18px;
  width:40px; height:40px; border-radius:10px;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  transition:all .2s;
}
.btn-logout:active { background:rgba(255,255,255,.35); transform:scale(0.94); }

/* ── CONTENT ── */
.content { padding:14px 14px 36px; }

/* ══════════════════════════════
   STATS
══════════════════════════════ */
.stats-row { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:16px; }
.stat-box {
  background:var(--card); border-radius:var(--r); padding:13px 8px;
  text-align:center; box-shadow:var(--sh); border:1px solid var(--border);
}
.stat-num { font-size:20px; font-weight:800; color:var(--teal); line-height:1.1; }
.stat-lbl { font-size:10px; color:var(--txt2); margin-top:3px; font-weight:500; }

/* ══════════════════════════════
   SECTION TITLE
══════════════════════════════ */
.section-title {
  font-size:12px; font-weight:700; color:var(--txt2);
  margin-bottom:10px; text-transform:uppercase; letter-spacing:.7px;
  display:flex; align-items:center; justify-content:space-between;
}

/* ══════════════════════════════
   CARDS
══════════════════════════════ */
.card-list { display:flex; flex-direction:column; gap:9px; }
.card {
  background:var(--card); border-radius:var(--r); padding:14px;
  box-shadow:var(--sh); border:1px solid var(--border);
  cursor:pointer;
  transition:transform .12s, box-shadow .12s;
}
.card:active { transform:scale(.98); box-shadow:none; }
.card-head { display:flex; align-items:center; justify-content:space-between; gap:8px; }
.card-title { font-size:15px; font-weight:700; color:var(--txt); }
.card-sub { font-size:12px; color:var(--txt2); margin-top:3px; line-height:1.45; }
.card-right { text-align:right; flex-shrink:0; }
.card-big { font-size:26px; font-weight:800; color:var(--teal); line-height:1; }
.card-small { font-size:10px; color:var(--txt2); }

/* ── AVATAR ── */
.avatar {
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--teal-s),var(--teal-m));
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:800; color:var(--teal2); flex-shrink:0;
  border:2px solid var(--teal-m);
}

/* ══════════════════════════════
   FAB
══════════════════════════════ */
.fab {
  position:fixed; bottom:24px; right:18px;
  width:58px; height:58px; border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--teal2));
  color:#fff; font-size:30px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(var(--shadow-rgb), .45); z-index:50;
}
.fab:active { transform:scale(.92); }

/* ══════════════════════════════
   CLASS BANNER
══════════════════════════════ */
.class-banner {
  background:linear-gradient(135deg,var(--teal2),var(--teal));
  padding:10px 14px 12px; display:flex; flex-wrap:wrap; gap:7px;
}
.banner-chip {
  display:flex; align-items:center; gap:5px;
  background:rgba(255,255,255,.18); border-radius:20px;
  padding:5px 11px; font-size:12px; color:rgba(255,255,255,.95); font-weight:500;
}

/* ══════════════════════════════
   TABS
══════════════════════════════ */
.tab-bar {
  display:flex; background:var(--card);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:90;
  box-shadow:0 1px 4px rgba(0,0,0,.05);
  overflow-x:auto; scrollbar-width:none;
}
.tab-bar::-webkit-scrollbar { display:none; }
.tab-btn {
  flex:1; min-width:80px; padding:12px 4px; font-size:12px; font-weight:600; color:var(--txt2);
  background:none; border-bottom:2.5px solid transparent;
  display:flex; align-items:center; justify-content:center; gap:4px;
  transition:color .18s;
  white-space:nowrap;
}
.tab-btn.active { color:var(--teal); border-bottom-color:var(--teal); }
.tab-content { display:none; }
.tab-content.active { display:block; }

/* ══════════════════════════════
   STUDENT ROW
══════════════════════════════ */
.student-row {
  background:var(--card); border-radius:var(--r); padding:13px 14px;
  display:flex; align-items:center; gap:12px;
  box-shadow:var(--sh); border:1px solid var(--border); margin-bottom:9px;
}

/* ── ICON BUTTON ── */
.icon-btn {
  background:none; font-size:17px;
  padding:6px 8px; border-radius:8px; flex-shrink:0;
  transition:background .15s; line-height:1;
}
.icon-btn:active { background:var(--teal-s); }
.icon-btn.danger:active { background:var(--red-s); }
.student-name { font-size:14px; font-weight:700; color:var(--txt); }
.student-meta { font-size:12px; color:var(--txt2); margin-top:2px; line-height:1.4; }

/* ══════════════════════════════
   ATTENDANCE
══════════════════════════════ */
.att-summary {
  display:flex; background:var(--card);
  border-bottom:1px solid var(--border);
}
.att-sum-item { flex:1; padding:12px 4px; text-align:center; }
.att-sum-num { font-size:22px; font-weight:800; line-height:1; }
.att-sum-lbl { font-size:10px; color:var(--txt2); margin-top:3px; font-weight:500; white-space:nowrap; }
.att-hint {
  background:var(--teal-s); padding:8px 14px;
  font-size:12px; color:var(--teal2); text-align:center; font-weight:500;
  border-bottom:1px solid var(--teal-m);
}
.att-row {
  background:var(--card); border-radius:var(--r); padding:13px 14px;
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:9px; box-shadow:var(--sh); border:1px solid var(--border);
  border-left:4px solid var(--border); cursor:pointer;
}
.att-row:active { transform:scale(.98); }
.att-row.present { border-left-color:var(--teal3); }
.att-row.absent  { border-left-color:var(--red); }
.att-row.excused { border-left-color:var(--yellow); }
.att-icon {
  width:38px; height:38px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:17px; flex-shrink:0;
}
.att-icon.present { background:var(--teal-s); }
.att-icon.absent  { background:var(--red-s); }
.att-icon.excused { background:var(--yellow-s); }
.status-badge { padding:4px 11px; border-radius:20px; font-size:12px; font-weight:700; }
.status-badge.present { background:var(--teal-s); color:var(--teal); }
.status-badge.absent  { background:var(--red-s);  color:var(--red); }
.status-badge.excused { background:var(--yellow-s);color:var(--yellow); }

/* ══════════════════════════════
   PAYMENT
══════════════════════════════ */
.month-bar {
  background:linear-gradient(135deg,var(--teal2),var(--teal));
  padding:9px 14px; display:flex; align-items:center; justify-content:space-between;
}
.month-bar span { font-size:15px; font-weight:700; color:#fff; }
.month-nav {
  background:rgba(255,255,255,.22); color:#fff;
  font-size:20px; padding:4px 12px; border-radius:9px; line-height:1;
}
.month-nav:active { background:rgba(255,255,255,.38); }
.pay-row {
  background:var(--card); border-radius:var(--r); padding:13px 14px;
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:9px; box-shadow:var(--sh); border:1px solid var(--border);
  gap:8px;
}
.pay-badge {
  padding:4px 10px; border-radius:20px; font-size:11px; font-weight:700;
  display:flex; align-items:center; gap:4px; white-space:nowrap;
}
.pay-badge.paid    { background:var(--teal-s);  color:var(--teal2); }
.pay-badge.pending { background:var(--yellow-s); color:var(--yellow); }
.pay-badge.overdue { background:var(--red-s);    color:var(--red); }
.pay-badge.partial { background:var(--orange-s); color:var(--orange); }
.btn-collect {
  background:linear-gradient(135deg,var(--teal),var(--teal2));
  color:#fff; border-radius:var(--rs);
  padding:7px 16px; font-size:12px; font-weight:700; margin-top:5px;
  display:block; width:100%; text-align:center;
}
.btn-collect:active { opacity:.85; }

/* ══════════════════════════════
   PAYMENT HISTORY MODAL
══════════════════════════════ */
.modal-box-tall { max-height:90vh; }
.pay-hist-stats {
  display:flex; gap:8px; margin:0 0 16px;
}
.pay-hist-stat {
  flex:1; text-align:center;
  background:var(--bg); padding:10px 4px; border-radius:12px;
  border:1px solid var(--border);
}
.pay-hist-num { font-size:16px; font-weight:800; color:var(--dark); }
.pay-hist-lbl { font-size:10px; color:var(--txt2); margin-top:2px; font-weight:500; }
.pay-hist-list {
  max-height:40vh; overflow-y:auto;
  margin:0 -4px 8px; padding:0 4px;
}
.pay-hist-month { margin-bottom:14px; }
.pay-hist-month-hdr {
  display:flex; align-items:center; justify-content:space-between;
  padding:5px 0; border-bottom:1.5px solid var(--teal-m); margin-bottom:6px;
}
.pay-hist-month-label { font-size:13px; font-weight:700; color:var(--dark); }
.pay-hist-item {
  display:flex; align-items:center; gap:8px;
  padding:9px 2px; border-bottom:1px solid var(--border);
}
.pay-hist-item:last-child { border-bottom:none; }

/* ══════════════════════════════
   STICKY FOOTER
══════════════════════════════ */
.sticky-footer {
  position:fixed; bottom:0; left:0; right:0;
  background:rgba(245,245,245,.94);
  backdrop-filter:blur(12px);
  border-top:1px solid var(--border);
  padding:12px 14px max(30px, env(safe-area-inset-bottom));
}
.btn-save, .btn-wa, .btn-add-full, .btn-primary-full {
  width:100%; border-radius:var(--r);
  padding:15px; font-size:15px; font-weight:700;
  display:flex; align-items:center; justify-content:center; gap:9px;
}
.btn-save {
  background:linear-gradient(135deg,var(--teal),var(--teal2)); color:#fff;
  box-shadow:0 4px 16px rgba(var(--shadow-rgb), .3);
}
.btn-wa {
  background:linear-gradient(135deg,#25D366,#128C7E); color:#fff;
  box-shadow:0 4px 16px rgba(37,211,102,.3);
}
.btn-save:active, .btn-wa:active { transform:scale(.98); opacity:.9; }
.btn-add-full {
  background:linear-gradient(135deg,var(--teal),var(--teal2)); color:#fff;
  margin-top:10px; box-shadow:0 3px 12px rgba(var(--shadow-rgb), .25);
}
.btn-add-full:active { transform:scale(.98); opacity:.9; }

/* ══════════════════════════════
   MODAL
══════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0;
  background:rgba(20,20,20,.52); z-index:200;
  display:flex; align-items:flex-end;
  backdrop-filter:blur(4px);
}
.modal-box {
  background:#fff; border-radius:26px 26px 0 0; width:100%;
  padding:26px 20px max(44px, env(safe-area-inset-bottom)); max-height:93vh; overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  box-shadow:0 -8px 40px rgba(0,0,0,.18);
}
.modal-title {
  font-size:18px; font-weight:800; color:var(--txt);
  margin-bottom:16px;
}
.modal-box label {
  font-size:11px; font-weight:700; color:var(--txt2);
  display:block; margin-bottom:6px; margin-top:15px;
  text-transform:uppercase; letter-spacing:.6px;
}
.modal-box label:first-of-type { margin-top:0; }
.modal-box .field + label { margin-top:13px; }
.modal-btns { display:flex; gap:10px; margin-top:20px; }
.btn-cancel {
  flex:1; border:1.5px solid var(--border); border-radius:var(--r);
  padding:13px; font-size:14px; font-weight:600; color:var(--txt2); background:#fff;
}
.btn-cancel:active { background:var(--bg); }
.btn-ok {
  flex:2; background:linear-gradient(135deg,var(--teal),var(--teal2));
  color:#fff; border-radius:var(--r);
  padding:13px; font-size:14px; font-weight:700;
  display:flex; align-items:center; justify-content:center; gap:6px;
  box-shadow:0 3px 12px rgba(var(--shadow-rgb), .28);
}
.btn-ok:active { opacity:.88; transform:scale(.98); }
.btn-ok:disabled { opacity:.5; cursor:not-allowed; transform:none; }

/* ══════════════════════════════
   INFO BOX
══════════════════════════════ */
.info-box {
  background:var(--teal-s); border-radius:var(--r); padding:13px 14px;
  display:flex; gap:11px; align-items:flex-start; margin-bottom:14px;
  border:1px solid var(--teal-m);
}
.info-box .icon { font-size:19px; flex-shrink:0; margin-top:1px; }
.info-box p { font-size:13px; color:var(--teal2); line-height:1.6; }

/* ── EXCEL BUTTONS ── */
.btn-excel-full {
  width:100%; background:linear-gradient(135deg,#217346,#1a5c38);
  color:#fff; border-radius:var(--r); padding:14px;
  font-size:14px; font-weight:700; margin-top:10px;
  display:flex; align-items:center; justify-content:center; gap:8px;
  box-shadow:0 4px 16px rgba(33,115,70,.35);
}
.btn-excel-full:active { opacity:.88; transform:scale(.98); }
.btn-excel-range {
  width:100%; background:var(--card); color:var(--green);
  border:1.5px solid #217346; border-radius:var(--r); padding:11px;
  font-size:13px; font-weight:700; margin-top:7px;
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.btn-excel-range:active { background:#f0faf3; }

/* ── TEXTAREA ── */
textarea.field { resize:vertical; min-height:120px; line-height:1.6; }

/* ── EMPTY STATE ── */
.empty-state {
  display:flex; flex-direction:column; align-items:center;
  padding:52px 20px; gap:10px;
}
.empty-state .empty-icon { font-size:50px; opacity:.3; }
.empty-state p { font-size:14px; color:var(--txt2); text-align:center; line-height:1.6; }

/* ── ROLE SELECT ── */
select.field { cursor:pointer; }

/* ══════════════════════════════
   GLOBAL SEARCH
══════════════════════════════ */
.search-bar-wrap {
  background:var(--card);
  padding:10px 14px 12px;
  border-bottom:1px solid var(--border);
  position:sticky; top:63px; z-index:80;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.search-input {
  width:100%; border:1.5px solid var(--border); border-radius:30px;
  padding:11px 18px; font-size:14px; color:var(--txt); background:var(--bg);
  font-family:inherit; outline:none;
  transition:border-color .2s, box-shadow .2s;
}
.search-input:focus {
  border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(var(--shadow-rgb), .12);
}
.search-result-card {
  background:var(--card); border-radius:var(--r); padding:13px 14px;
  box-shadow:var(--sh); border:1px solid var(--border);
  cursor:pointer; transition:transform .12s, box-shadow .12s;
  display:flex; align-items:center; gap:12px;
}
.search-result-card:active { transform:scale(.98); box-shadow:none; }

/* ── EVRAK SECTION ── */
.evrak-section {
  margin-top: 18px;
  border-top: 1px solid var(--border);
  padding-top: 14px;
}
.evrak-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.evrak-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--txt);
}
.btn-evrak-upload {
  font-size: 13px;
  font-weight: 600;
  color: var(--teal);
  background: var(--teal-s);
  border: 1.5px solid var(--teal-m);
  border-radius: 8px;
  padding: 6px 12px;
  cursor: pointer;
  transition: background .15s;
  display: inline-block;
}
.btn-evrak-upload:active { background: var(--teal-m); }

.evrak-progress {
  font-size: 13px;
  color: var(--txt2);
  background: var(--teal-s);
  border-radius: 8px;
  padding: 8px 12px;
  margin-bottom: 8px;
}
.evrak-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.evrak-item {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 9px 12px;
}
.evrak-item-icon { font-size: 22px; flex-shrink: 0; }
.evrak-item-info { flex: 1; min-width: 0; }
.evrak-item-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--txt);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.evrak-item-meta { font-size: 11px; color: var(--txt3); margin-top: 2px; }
.evrak-item-actions { display: flex; gap: 6px; flex-shrink: 0; }
.btn-evrak-view, .btn-evrak-del {
  font-size: 12px;
  font-weight: 600;
  border-radius: 7px;
  padding: 5px 10px;
  cursor: pointer;
  border: none;
}
.btn-evrak-view {
  background: var(--green-s);
  color: var(--green);
}
.btn-evrak-del {
  background: var(--red-s);
  color: var(--red);
}
.evrak-empty {
  font-size: 13px;
  color: var(--txt3);
  text-align: center;
  padding: 10px 0;
}

/* ══════════════════════════════
   VELİ PANELİ
══════════════════════════════ */
.parent-children-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.parent-children-grid .card {
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
.parent-children-grid .card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(var(--shadow-rgb), .10);
}
.parent-children-grid .card:active {
  transform: translateY(0);
}
.parent-tab-btn {
  transition: background .15s ease, color .15s ease;
}
.parent-stat-card {
  background: var(--teal-s);
  border: 1.5px solid var(--teal-m);
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 10px;
}
.parent-info-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 0;
  font-size: 13px;
  border-top: 1px solid var(--border);
}
.parent-info-row:first-child { border-top: none; }

/* ══════════════════════════════
   DESKTOP (≥ 540px)
══════════════════════════════ */
@media (min-width:540px) {
  .parent-children-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
}
@media (min-width:900px) {
  .parent-children-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width:540px) {
  .login-form { border-radius:28px; max-width:420px; margin:0 auto 32px; }
  #view-login { align-items:center; justify-content:center; }
  .login-top  { flex:none; padding-bottom:20px; }

  .topbar { padding-left:20px; padding-right:20px; }
  .content { max-width:620px; margin:0 auto; padding:16px 16px 40px; }

  .modal-overlay  { align-items:center; }
  .modal-box {
    border-radius:26px; max-width:480px;
    margin:auto; margin-bottom:32px;
  }
  .sticky-footer { display:flex; justify-content:center; }
  .sticky-footer > * { max-width:592px; width:100%; }

  .fab { right:calc(50% - 296px); }
  .stat-num { font-size:22px; }
  .stats-row { gap:10px; }
}

/* ── Home Hub (Ana ekran 2 sütun kare kartlar) ─────────────── */
.home-grid {
  display:grid;
  grid-template-columns: repeat(2, 1fr);   /* Her zaman 2 sütun */
  gap:12px;
  margin-top:6px;
}
.home-card {
  background:#fff;
  border:1px solid var(--border);
  border-top:4px solid var(--teal);
  border-radius:18px;
  padding:18px 12px 16px;
  cursor:pointer;
  font-family:inherit;
  color:var(--txt);
  text-align:center;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:10px;
  aspect-ratio: 1 / 1;       /* Eşit büyüklük: kare */
  box-shadow:0 1px 3px rgba(0,0,0,.04);
  transition:transform .12s ease, box-shadow .15s ease, border-color .12s ease;
  -webkit-tap-highlight-color: transparent;
}
.home-card:hover, .home-card:focus-visible {
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(var(--shadow-rgb), .18);
  outline:none;
}
.home-card:active { transform:translateY(0); box-shadow:0 2px 6px rgba(var(--shadow-rgb), .14); }
.home-card-icon {
  width:60px; height:60px;
  border-radius:16px;
  background:var(--teal-s);
  color:var(--teal2);
  display:flex; align-items:center; justify-content:center;
  font-size:30px; line-height:1;
}
.home-card-title {
  font-weight:800; color:var(--txt);
  font-size:15px;
  letter-spacing:-.01em;
  line-height:1.2;
}
.home-card-sub {
  font-size:11.5px; color:var(--txt2);
  line-height:1.3;
  padding:0 4px;
  max-width:100%;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
/* Tablet+: kareler büyümesin diye max boyut sınırlayalım, grid ortalansın */
@media (min-width:600px) {
  .home-grid { gap:16px; max-width:520px; margin-left:auto; margin-right:auto; }
  .home-card-icon { width:64px; height:64px; font-size:32px; }
  .home-card-title { font-size:16px; }
}

/* ── Admin Hub (Yönetim Paneli ana ekran kart grid) ──────────── */
.admin-hub-grid {
  display:grid;
  grid-template-columns: 1fr;   /* Mobil: tek sütun, full genişlik büyük kartlar */
  gap:14px;
  margin-top:8px;
}
.admin-hub-card {
  width:100%;
  background:#fff;
  border:1px solid var(--border);
  border-left:5px solid var(--teal);
  border-radius:18px;
  padding:22px 20px;
  cursor:pointer;
  font-family:inherit;
  color:var(--txt);
  text-align:left;
  display:flex; flex-direction:row; align-items:center; gap:18px;
  min-height:96px;
  box-shadow:0 1px 3px rgba(0,0,0,.04);
  transition:transform .12s ease, box-shadow .15s ease, border-color .12s ease;
  -webkit-tap-highlight-color: transparent;
}
.admin-hub-card:hover, .admin-hub-card:focus-visible {
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(var(--shadow-rgb), .18);
  outline:none;
}
.admin-hub-card:active { transform:translateY(0); box-shadow:0 2px 6px rgba(var(--shadow-rgb), .14); }
.admin-hub-icon {
  flex:0 0 56px;
  width:56px; height:56px;
  border-radius:14px;
  background:var(--teal-s);
  color:var(--teal2);
  display:flex; align-items:center; justify-content:center;
  font-size:28px; line-height:1;
}
.admin-hub-body {
  flex:1; min-width:0;
  display:flex; flex-direction:column; gap:3px;
}
.admin-hub-title {
  font-weight:800; color:var(--txt); font-size:17px;
  letter-spacing:-.01em;
}
.admin-hub-sub {
  font-size:13px; color:var(--txt2); line-height:1.35;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.admin-hub-arrow {
  flex:0 0 auto; color:var(--txt2); font-size:20px; opacity:.5;
}
/* Tablet ve üstü: 2 sütun */
@media (min-width:600px) {
  .admin-hub-grid { grid-template-columns: repeat(2, 1fr); gap:16px; }
}
/* Geniş ekran: 3 sütun */
@media (min-width:900px) {
  .admin-hub-grid { grid-template-columns: repeat(3, 1fr); }
}

/* ── CMS Modül Kapalı (Satış) Banner ───────────────────────────── */
.cms-disabled-banner {
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:32px 22px 24px;
  text-align:center;
  box-shadow:0 4px 16px rgba(var(--shadow-rgb), .08);
}
.cms-disabled-banner.hidden { display:none; }
.cms-disabled-icon { font-size:54px; line-height:1; margin-bottom:10px; }
.cms-disabled-title {
  font-size:20px; font-weight:800;
  color:var(--teal2);
  margin-bottom:14px;
}
.cms-disabled-text {
  font-size:13.5px;
  color:var(--txt2);
  line-height:1.7;
  text-align:left;
  background:var(--teal-s);
  padding:14px 16px;
  border-radius:12px;
  margin-bottom:18px;
}
.cms-disabled-cta {
  display:inline-block;
  padding:12px 22px;
  background:var(--teal);
  color:#fff !important;
  border-radius:24px;
  font-weight:800; font-size:13.5px;
  text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease;
}
.cms-disabled-cta:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 22px rgba(var(--shadow-rgb), .25);
}
.cms-disabled-contact {
  margin-top:18px;
  padding-top:16px;
  border-top:1px solid var(--border);
  font-size:12.5px;
  color:var(--txt2);
}
.cms-disabled-contact a { color:var(--teal); font-weight:700; }

/* ── CMS (Web Sitem) Panel ─────────────────────────────────────── */
.cms-section {
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  margin-bottom:14px;
}
.cms-section-title {
  font-weight:800; font-size:14px;
  color:var(--teal2);
  margin-bottom:10px;
  padding-bottom:8px;
  border-bottom:2px solid var(--teal-s);
}
.cms-section label {
  display:block;
  font-size:12px; font-weight:700;
  color:var(--txt2);
  margin:10px 0 4px;
}
.cms-hero-row {
  display:flex; gap:12px; align-items:stretch;
  margin-top:6px;
}
.cms-image-preview {
  flex:1; min-height:100px; max-width:60%;
  background:var(--bg);
  background-size:cover; background-position:center;
  border:2px dashed var(--border);
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  color:var(--txt2); font-size:12px;
}
.cms-image-preview:empty::before { content:'Görsel yok'; }
.cms-image-actions {
  flex:0 0 140px;
  display:flex; flex-direction:column;
}
.cms-sponsors-list {
  display:flex; flex-direction:column; gap:8px;
}
.cms-sponsor-row {
  display:flex; gap:8px; align-items:center;
  padding:8px;
  background:var(--bg);
  border:1px solid var(--border);
  border-radius:10px;
}
.cms-sponsor-logo {
  width:48px; height:48px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:8px;
  background-size:contain; background-position:center; background-repeat:no-repeat;
  flex-shrink:0;
}
.cms-sponsor-row input { flex:1; min-width:0; }
.cms-sponsor-del {
  background:transparent;
  border:1px solid var(--red);
  color:var(--red);
  padding:4px 10px; border-radius:8px;
  cursor:pointer; font-size:11px; font-weight:700;
}

/* ── Audit Log Panel ───────────────────────────────────────────── */
.audit-filters {
  display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px;
}
.audit-filters .field { flex:1 1 140px; min-width:0; padding:8px 10px; font-size:13px; }
.audit-filters #btn-audit-refresh { font-size:13px; }

.audit-stats {
  display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px;
  font-size:12px; color:var(--txt2);
}
.audit-stats .audit-stat-chip {
  background:var(--teal-s); color:var(--teal2);
  padding:5px 10px; border-radius:12px; font-weight:600;
}

.audit-row {
  background:#fff; border:1px solid var(--border); border-radius:12px;
  padding:10px 12px; margin-bottom:8px; cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease;
  display:flex; gap:10px; align-items:flex-start;
}
.audit-row:hover {
  transform:translateY(-1px);
  box-shadow:0 3px 10px rgba(var(--shadow-rgb), .12);
}
.audit-row .audit-icon {
  flex:0 0 36px; height:36px; border-radius:50%;
  background:var(--teal-s); color:var(--teal2);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; font-weight:700;
}
.audit-row .audit-body { flex:1; min-width:0; }
.audit-row .audit-action {
  font-weight:700; color:var(--txt); font-size:13.5px; line-height:1.3;
}
.audit-row .audit-target {
  color:var(--txt2); font-size:12.5px; margin-top:2px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.audit-row .audit-meta {
  color:var(--txt2); font-size:11.5px; margin-top:4px;
  display:flex; gap:8px; flex-wrap:wrap;
}
.audit-row .audit-user-chip {
  background:#F5F5F5; padding:2px 7px; border-radius:8px;
  font-weight:600; color:var(--txt);
}
.audit-row .audit-role-chip {
  padding:2px 7px; border-radius:8px; font-weight:600; font-size:10.5px;
}
.audit-row .audit-role-superadmin { background:#FFF3E0; color:#E65100; }
.audit-row .audit-role-coach_finance { background:#E3F2FD; color:#1565C0; }
.audit-row .audit-role-coach_standard { background:#E8F5E9; color:#2E7D32; }
.audit-row .audit-role-parent { background:#F3E5F5; color:#6A1B9A; }
.audit-row .audit-time {
  color:var(--txt2); font-size:11.5px; flex-shrink:0;
}

#audit-detail-content pre {
  background:var(--bg); padding:10px; border-radius:8px;
  font-size:11.5px; white-space:pre-wrap; word-break:break-all;
  border:1px solid var(--border);
}
#audit-detail-content .audit-kv {
  display:flex; gap:10px; padding:6px 0; border-bottom:1px solid var(--border);
}
#audit-detail-content .audit-kv:last-child { border-bottom:none; }
#audit-detail-content .audit-k { font-weight:600; color:var(--txt2); flex:0 0 110px; }
#audit-detail-content .audit-v { flex:1; word-break:break-word; color:var(--txt); }

/* ══════════════════════════════════════════
   SPORCU KARTI (Player Card) — premium polish
   FIFA Ultimate Team mantığı + tier renkleri + animasyon
══════════════════════════════════════════ */
.player-card {
  position: relative;
  width: 100%;
  aspect-ratio: 9 / 14;
  max-width: 320px;
  margin: 0 auto;
  border-radius: 22px;
  overflow: hidden;
  /* Düz lineer gradient — beyaz overlay yok, koyu tema gerçek koyu kalır */
  background: linear-gradient(160deg, var(--teal) 0%, var(--teal2) 55%, var(--teal3) 100%);
  color: #fff;
  box-shadow:
    0 24px 64px rgba(var(--shadow-rgb), .45),
    0 8px 24px rgba(0,0,0,.3),
    inset 0 0 0 1px rgba(255,255,255,.12),
    inset 0 -3px 12px rgba(0,0,0,.4);
  font-family: 'Outfit', sans-serif;
  padding: 18px 16px 14px;
  display: flex;
  flex-direction: column;
  isolation: isolate;
  transition: transform .25s ease;
}
.player-card:active { transform: scale(.98); }

/* Vignette + ince hologram desen — beyaz YIKANMASIN, sadece doku */
.player-card::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,.35) 100%),
    repeating-linear-gradient(115deg,
      transparent 0px, transparent 18px,
      rgba(255,255,255,.018) 18px, rgba(255,255,255,.018) 36px);
  pointer-events: none;
  z-index: 1;
}

/* Tier'a göre dramatik dış glow halkası — kartın "premium" hissi */
.player-card.tier-rookie {
  box-shadow:
    0 24px 64px rgba(0,0,0,.45),
    0 0 28px rgba(220,230,240,.20),
    inset 0 0 0 1px rgba(255,255,255,.12),
    inset 0 -3px 12px rgba(0,0,0,.4);
}
.player-card.tier-bronze {
  box-shadow:
    0 24px 64px rgba(0,0,0,.45),
    0 0 32px rgba(255,160,80,.40),
    inset 0 0 0 1px rgba(255,180,100,.22),
    inset 0 -3px 12px rgba(0,0,0,.4);
}
.player-card.tier-silver {
  box-shadow:
    0 24px 64px rgba(0,0,0,.45),
    0 0 36px rgba(220,230,240,.42),
    inset 0 0 0 1px rgba(240,245,250,.28),
    inset 0 -3px 12px rgba(0,0,0,.4);
}
.player-card.tier-gold {
  box-shadow:
    0 24px 64px rgba(0,0,0,.45),
    0 0 44px rgba(255,200,60,.55),
    inset 0 0 0 1px rgba(255,225,120,.35),
    inset 0 -3px 12px rgba(0,0,0,.4);
}
.player-card.tier-elite {
  box-shadow:
    0 24px 64px rgba(0,0,0,.45),
    0 0 52px rgba(110,240,255,.65),
    inset 0 0 0 1px rgba(140,250,255,.38),
    inset 0 -3px 12px rgba(0,0,0,.4);
}

.player-card::after {
  content: '';
  position: absolute;
  top: 0; left: -50%;
  width: 50%; height: 100%;
  background: linear-gradient(100deg,
    transparent 0%,
    rgba(255,255,255,0) 30%,
    rgba(255,255,255,.14) 50%,
    rgba(255,255,255,0) 70%,
    transparent 100%);
  transform: skewX(-15deg);
  animation: pc-sweep 7s ease-in-out infinite;
  pointer-events: none;
  z-index: 1;
}
@keyframes pc-sweep {
  0%   { left: -50%; opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { left: 150%; opacity: 0; }
}

.player-card > * { position: relative; z-index: 2; }

.pc-top {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 8px;
  margin-bottom: 2px;
}
.pc-ovr-block {
  display: flex; flex-direction: column; align-items: flex-start; line-height: 1;
}
.pc-ovr {
  font-size: 46px; font-weight: 900;
  letter-spacing: -.05em;
  line-height: .95;
  text-shadow:
    0 2px 8px rgba(0,0,0,.35),
    0 0 24px rgba(255,255,255,.18);
}
.pc-ovr-label {
  font-size: 10px; font-weight: 800;
  letter-spacing: .2em;
  opacity: .9;
  margin-top: 2px;
}

.pc-tier {
  display: inline-block;
  margin-top: 5px;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .14em;
  background: rgba(0,0,0,.32);
  border: 1px solid rgba(255,255,255,.25);
  text-shadow: 0 1px 2px rgba(0,0,0,.4);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.15);
}
.pc-tier.tier-bronze { color: #FFB97A; border-color: rgba(255,160,80,.55); box-shadow: inset 0 1px 0 rgba(255,200,150,.25), 0 0 8px rgba(255,140,60,.25); }
.pc-tier.tier-silver { color: #E8F0F5; border-color: rgba(220,230,240,.55); box-shadow: inset 0 1px 0 rgba(255,255,255,.35), 0 0 10px rgba(220,230,240,.3); }
.pc-tier.tier-gold   { color: #FFE066; border-color: rgba(255,210,80,.65); box-shadow: inset 0 1px 0 rgba(255,235,150,.4),  0 0 14px rgba(255,200,60,.4); }
.pc-tier.tier-elite  { color: #6EF0FF; border-color: rgba(110,240,255,.65); box-shadow: inset 0 1px 0 rgba(180,250,255,.4), 0 0 18px rgba(110,240,255,.5); }

.pc-ovr.tier-bronze { color: #FFCBA0; text-shadow: 0 2px 10px rgba(255,150,60,.4),  0 0 18px rgba(255,150,60,.25); }
.pc-ovr.tier-silver { color: #F4FAFE; text-shadow: 0 2px 10px rgba(220,235,250,.4), 0 0 18px rgba(220,235,250,.3); }
.pc-ovr.tier-gold   { color: #FFEC80; text-shadow: 0 2px 12px rgba(255,210,70,.55), 0 0 22px rgba(255,210,70,.4); }
.pc-ovr.tier-elite  { color: #A8F4FF; text-shadow: 0 2px 14px rgba(100,230,255,.6), 0 0 24px rgba(100,230,255,.45); }

.pc-branch-emoji {
  font-size: 30px; line-height: 1;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.4));
  margin-top: 4px;
}
.pc-logo {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: rgba(255,255,255,.96);
  padding: 5px;
  object-fit: contain;
  box-shadow:
    0 4px 14px rgba(0,0,0,.3),
    0 0 0 2px rgba(255,255,255,.4),
    inset 0 -1px 2px rgba(0,0,0,.1);
}

.pc-avatar-wrap {
  display: flex; justify-content: center; margin: 4px 0 6px;
  position: relative;
}
.pc-avatar {
  position: relative;
  width: 96px; height: 96px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.4), rgba(255,255,255,.1) 50%, rgba(0,0,0,.18) 100%);
  border: 3px solid rgba(255,255,255,.55);
  display: flex; align-items: center; justify-content: center;
  font-size: 50px; font-weight: 900;
  color: #fff;
  text-shadow: 0 2px 10px rgba(0,0,0,.4), 0 0 20px rgba(255,255,255,.25);
  box-shadow:
    0 6px 22px rgba(0,0,0,.32),
    inset 0 2px 6px rgba(255,255,255,.32),
    inset 0 -3px 6px rgba(0,0,0,.18);
  z-index: 1;
}
.pc-avatar::before {
  content: '';
  position: absolute;
  inset: -14px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.28), rgba(255,255,255,.05) 50%, transparent 75%);
  z-index: -1;
  animation: pc-halo 4s ease-in-out infinite;
}
@keyframes pc-halo {
  0%, 100% { transform: scale(1); opacity: .8; }
  50%      { transform: scale(1.08); opacity: 1; }
}

.pc-name {
  font-size: 20px; font-weight: 900;
  text-align: center;
  letter-spacing: .01em;
  text-transform: uppercase;
  margin-bottom: 2px;
  text-shadow: 0 1px 4px rgba(0,0,0,.4);
  line-height: 1.1;
}
.pc-subtitle {
  font-size: 12px; font-weight: 600;
  text-align: center;
  opacity: .9;
  margin-bottom: 8px;
  letter-spacing: .02em;
}

.pc-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);
  margin: 4px 0 10px;
}

.pc-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 7px 8px;
  flex: 1;
  align-content: center;
}
.pc-stat {
  display: flex; flex-direction: column; align-items: center;
  gap: 2px;
  background: linear-gradient(180deg, rgba(0,0,0,.42) 0%, rgba(0,0,0,.62) 100%);
  border: 1.5px solid rgba(255,255,255,.18);
  border-radius: 11px;
  padding: 8px 4px 7px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -2px 0 rgba(0,0,0,.3),
    0 3px 8px rgba(0,0,0,.3);
}
.pc-stat-val {
  font-size: 22px; font-weight: 900;
  line-height: 1;
  letter-spacing: -.02em;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,.55);
}
.pc-stat-label {
  font-size: 10px; font-weight: 800;
  letter-spacing: .14em;
  opacity: .85;
  text-transform: uppercase;
}
.pc-stat.empty .pc-stat-val { opacity: .35; }
.pc-stat.hi    .pc-stat-val { color: #FFE066; text-shadow: 0 1px 8px rgba(255,210,70,.7), 0 0 16px rgba(255,210,70,.35); }
.pc-stat.elite .pc-stat-val { color: #A8F4FF; text-shadow: 0 1px 10px rgba(100,230,255,.8), 0 0 18px rgba(100,230,255,.45); }

.pc-footer {
  display: flex; align-items: center; justify-content: center;
  gap: 6px;
  margin-top: 8px;
  padding-top: 7px;
  border-top: 1px solid rgba(255,255,255,.22);
  font-size: 10.5px; font-weight: 800;
  letter-spacing: .14em;
  opacity: .9;
  text-align: center;
  text-transform: uppercase;
  text-shadow: 0 1px 2px rgba(0,0,0,.3);
}

.pc-no-data {
  background: rgba(0,0,0,.28);
  border: 1px dashed rgba(255,255,255,.4);
  border-radius: 12px;
  padding: 16px 12px;
  text-align: center;
  font-size: 12.5px;
  line-height: 1.55;
  margin: 8px 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.1);
}

@media (max-width: 360px) {
  .player-card { padding: 14px 12px 10px; border-radius: 18px; }
  .pc-ovr { font-size: 40px; }
  .pc-avatar { width: 84px; height: 84px; font-size: 44px; }
  .pc-name { font-size: 18px; }
  .pc-stat-val { font-size: 18px; }
  .pc-logo { width: 46px; height: 46px; }
}

/* Avatar — fotoğraflı versiyonu */
.pc-avatar.has-photo {
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.2), rgba(0,0,0,.15) 75%);
  overflow: hidden;
  padding: 0;
}
.pc-avatar.has-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

/* ══════════════════════════════════════════
   PROFİL FOTOĞRAFI UPLOAD (Öğrenci modal)
══════════════════════════════════════════ */
.photo-upload-wrap {
  display: flex; flex-direction: column; align-items: center;
  gap: 10px;
  padding: 12px 0 16px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 12px;
}
.photo-preview {
  width: 100px; height: 100px;
  border-radius: 50%;
  background: var(--bg);
  border: 2px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  position: relative;
  box-shadow: 0 4px 14px rgba(var(--shadow-rgb), .12);
}
.photo-preview img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.photo-initial {
  font-size: 44px; font-weight: 900;
  color: var(--txt3);
  text-transform: uppercase;
}
.photo-actions {
  display: flex; gap: 8px; flex-wrap: wrap; justify-content: center;
}
.btn-photo-pick {
  background: var(--teal);
  color: #fff;
  padding: 9px 16px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  border: none;
  transition: opacity .15s;
}
.btn-photo-pick:hover, .btn-photo-pick:active { opacity: .85; }
.btn-photo-del {
  background: transparent;
  color: var(--red);
  padding: 9px 14px;
  border: 1.5px solid var(--red);
  border-radius: 10px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
}
.photo-progress {
  font-size: 12px; color: var(--txt2); font-weight: 600;
  background: var(--teal-s);
  padding: 6px 12px;
  border-radius: 8px;
}
.photo-progress.hidden { display: none; }

/* ══════════════════════════════════════════
   RADAR GRAFİĞİ (Sporcu Kartı altında — yetenek görselleştirme)
══════════════════════════════════════════ */
.radar-wrap {
  margin-top: 16px;
  background: #fff;
  border-radius: 16px;
  padding: 16px 14px 12px;
  box-shadow: 0 4px 18px rgba(var(--shadow-rgb), .08);
  border: 1px solid var(--border);
}
.radar-title {
  font-size: 13px;
  font-weight: 800;
  color: var(--teal);
  text-align: center;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.radar-sub {
  font-size: 11px;
  color: var(--txt2);
  text-align: center;
  margin-bottom: 10px;
}
.radar-svg {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  max-width: 280px;
}
.radar-grid    { stroke: var(--border); stroke-width: 1; fill: none; }
.radar-axis    { stroke: var(--border); stroke-width: 1; }
.radar-area    { fill: var(--teal); fill-opacity: .25; stroke: var(--teal); stroke-width: 2; stroke-linejoin: round; }
.radar-point   { fill: var(--teal); }
.radar-label   {
  fill: var(--txt2);
  font-size: 11px;
  font-weight: 700;
  font-family: 'Outfit', sans-serif;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.radar-label-val { fill: var(--teal); font-weight: 900; }
.radar-empty {
  text-align: center;
  color: var(--txt2);
  font-size: 12px;
  padding: 20px 10px;
  line-height: 1.6;
}
