@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,700;9..144,900&family=Manrope:wght@500;600;700&display=swap');

:root{
  --bg:#f5f1ea; --bg-soft:#ede7da; --paper:#fdfbf6;
  --ink:#1a1814; --ink-soft:#5c574d; --ink-faint:#9a948a;
  --line:#d8d2c4; --line-soft:#e7e1d3;
  --primary:#1f4d3f; --primary-pale:#dde9e3;
  --accent:#c84a1f; --accent-pale:#f5dcd0;
  --present:#2d7a4a; --present-pale:#d4e8d8;
  --absent:#b8341a; --absent-pale:#f3d6cf;
  --late:#c87a1f; --late-pale:#f5e2cc;
  --excused:#3a6ea5; --excused-pale:#d6e2f0;
  --shadow-sm:0 1px 2px rgba(26,24,20,.06);
  --shadow:0 8px 24px rgba(26,24,20,.12);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;min-height:100%;background:var(--bg)}
body{font-family:'Manrope',-apple-system,sans-serif;color:var(--ink);font-size:15px;line-height:1.5;font-weight:500;-webkit-font-smoothing:antialiased}
.serif{font-family:'Fraunces',Georgia,serif;font-weight:700;letter-spacing:-.01em}
input,textarea,select,button{font-family:inherit;font-size:inherit}
button{cursor:pointer}

/* Layout for app-style screens */
#app{display:flex;flex-direction:column;min-height:100dvh;max-width:520px;margin:0 auto;background:var(--bg);position:relative}
@media (min-width: 740px){ #app{max-width:720px;box-shadow:0 0 0 1px var(--line-soft);min-height:100dvh} }
@media (min-width: 1100px){ #app{max-width:960px} }

/* Auth/login/setup centered layout */
.auth{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100dvh;padding:30px;text-align:center;background:var(--bg)}
.auth-logo{width:84px;height:84px;border-radius:24px;background:var(--primary);color:var(--paper);display:flex;align-items:center;justify-content:center;margin-bottom:24px;font-family:'Fraunces',serif;font-size:42px;font-weight:900;letter-spacing:-.04em;box-shadow:0 12px 32px rgba(31,77,63,.3)}
.auth h1{font-family:'Fraunces',serif;margin:0 0 4px;font-size:38px;font-weight:900;letter-spacing:-.03em;line-height:1}
.auth h1 .dot{color:var(--accent)}
.auth .tag{color:var(--ink-soft);margin-bottom:32px;font-size:14px;font-weight:500}
.auth-form{width:100%;max-width:380px;text-align:left}

/* Cards / sections */
.card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:10px;box-shadow:var(--shadow-sm)}
.card.tap:active{transform:scale(.99)}
.row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.muted{color:var(--ink-soft);font-size:13px}
.faint{color:var(--ink-faint);font-size:12px;font-weight:500}
.divider{height:1px;background:var(--line-soft);margin:14px 0}

/* Buttons */
.btn{background:var(--primary);color:var(--paper);border:none;padding:13px 20px;border-radius:12px;font-size:15px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}
.btn:active{transform:scale(.98)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.full{width:100%}
.btn.ghost{background:var(--paper);color:var(--ink);border:1px solid var(--line)}
.btn.danger{background:var(--absent);color:#fff}
.btn.success{background:var(--present);color:#fff}
.btn.sm{padding:8px 14px;font-size:13px;border-radius:9px}
.btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Form fields */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.field input,.field select,.field textarea{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:13px 14px;color:var(--ink);font-size:15px;font-weight:500;width:100%;appearance:none;-webkit-appearance:none}
/* Native checkbox / radio — override .field reset so the tick shows on mobile */
.field input[type="checkbox"],.field input[type="radio"],
input[type="checkbox"],input[type="radio"]{
  appearance:auto;-webkit-appearance:auto;
  width:20px;height:20px;min-width:20px;
  padding:0;background:transparent;border:none;border-radius:0;
  accent-color:var(--primary);cursor:pointer;flex-shrink:0;
}
.field textarea{resize:vertical;min-height:80px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-pale)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.field .hint{font-size:11px;color:var(--ink-faint);font-weight:500;text-transform:none;letter-spacing:0}

/* Pills */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.pill.present{background:var(--present-pale);color:var(--present)}
.pill.absent{background:var(--absent-pale);color:var(--absent)}
.pill.late{background:var(--late-pale);color:var(--late)}
.pill.primary{background:var(--primary-pale);color:var(--primary)}
.pill.accent{background:var(--accent-pale);color:var(--accent)}
.pill.muted{background:var(--bg-soft);color:var(--ink-soft)}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--paper);border-radius:12px;padding:10px 18px;z-index:200;box-shadow:var(--shadow);animation:fadein .2s;font-size:13px;font-weight:600}
.toast.error{background:var(--absent)}
.toast.success{background:var(--present)}
@keyframes fadein{from{opacity:0}to{opacity:1}}

/* Empty state */
.empty{text-align:center;padding:40px 20px;color:var(--ink-faint)}
.empty .ico-big{width:64px;height:64px;border-radius:50%;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;color:var(--ink-faint)}
.empty .title{font-weight:700;color:var(--ink);font-family:'Fraunces',serif;font-size:18px;margin-bottom:4px}

/* =============================================================
   SETUP WIZARD specific
   ============================================================= */
.wizard{display:flex;flex-direction:column;min-height:100dvh;background:var(--bg);padding:24px 16px 40px}
.wizard-inner{max-width:560px;width:100%;margin:0 auto}
.wizard-head{text-align:center;margin-bottom:24px}
.wizard-logo{width:64px;height:64px;border-radius:20px;background:var(--primary);color:var(--paper);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-family:'Fraunces',serif;font-size:32px;font-weight:900;letter-spacing:-.04em;box-shadow:0 8px 20px rgba(31,77,63,.25)}
.wizard h1{font-family:'Fraunces',serif;margin:0 0 4px;font-size:28px;font-weight:900;letter-spacing:-.02em;line-height:1.1}
.wizard h1 .dot{color:var(--accent)}
.wizard .tag{color:var(--ink-soft);font-size:14px;margin-top:4px}

.steps{display:flex;justify-content:center;gap:8px;margin:18px 0 22px}
.step-dot{width:30px;height:6px;border-radius:3px;background:var(--bg-soft)}
.step-dot.done{background:var(--primary)}
.step-dot.active{background:var(--accent)}

.wizard-step{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow-sm)}
.wizard-step h2{font-family:'Fraunces',serif;font-size:20px;margin:0 0 4px;font-weight:800;letter-spacing:-.01em}
.wizard-step .step-sub{color:var(--ink-soft);margin-bottom:18px;font-size:13px}

.check-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.check-item{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border-radius:10px;background:var(--bg-soft)}
.check-item.ok{background:var(--present-pale)}
.check-item.fail{background:var(--absent-pale)}
.check-item.warn{background:var(--late-pale)}
.check-item .ico{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;line-height:1}
.check-item.ok .ico{background:var(--present)}
.check-item.fail .ico{background:var(--absent)}
.check-item.warn .ico{background:var(--late)}
.check-item .info{flex:1;min-width:0}
.check-item .info .name{font-weight:700;font-size:13px}
.check-item .info .detail{font-size:12px;color:var(--ink-soft);margin-top:1px}
.check-item .info .fix{font-size:12px;color:var(--absent);margin-top:3px}

.btn-row{display:flex;gap:10px;margin-top:18px}
.btn-row .btn{flex:1}
.btn-row .btn.ghost{flex:0 0 auto;min-width:100px}

.alert{padding:12px 14px;border-radius:10px;font-size:13px;margin-bottom:12px;font-weight:500}
.alert.ok{background:var(--present-pale);color:var(--present);border:1px solid var(--present)}
.alert.error{background:var(--absent-pale);color:var(--absent);border:1px solid var(--absent)}
.alert.warn{background:var(--late-pale);color:var(--late);border:1px solid var(--late)}
.alert.info{background:var(--primary-pale);color:var(--primary);border:1px solid var(--primary)}

.progress-list{display:flex;flex-direction:column;gap:4px;margin-bottom:14px;font-family:'Fraunces',serif;font-size:14px;font-weight:700;letter-spacing:-.005em}
.progress-list .item{padding:8px 12px;background:var(--bg-soft);border-radius:8px;display:flex;align-items:center;gap:10px;font-size:13px;font-family:'Manrope',sans-serif;font-weight:600}
.progress-list .item .check{color:var(--present);font-weight:900}
.progress-list .item.skip{color:var(--ink-faint)}
.progress-list .item.fail{background:var(--absent-pale);color:var(--absent)}

details.tech{margin-top:10px;font-size:12px;color:var(--ink-soft)}
details.tech summary{cursor:pointer;font-weight:600;padding:6px 0}
details.tech pre{background:var(--bg-soft);padding:10px;border-radius:8px;overflow:auto;font-size:11px;white-space:pre-wrap;word-break:break-word}

.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--paper);border-top-color:transparent;border-radius:50%;animation:spin 1s linear infinite;vertical-align:middle;margin-right:6px}
.spinner.dark{border-color:var(--ink);border-top-color:transparent}
@keyframes spin{to{transform:rotate(360deg)}}

.success-card{text-align:center;padding:8px 0 4px}
.success-card .check-big{width:72px;height:72px;border-radius:50%;background:var(--present);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:38px;font-weight:900;box-shadow:0 8px 24px rgba(45,122,74,.3)}
.success-card h2{font-size:24px;margin-bottom:8px}
.success-card .creds{background:var(--bg-soft);border-radius:10px;padding:14px;margin:14px 0;text-align:left;font-size:13px;line-height:1.7}
.success-card .creds b{color:var(--ink);font-family:'Fraunces',serif;font-size:14px}
.success-card .next-steps{text-align:left;font-size:13px;color:var(--ink-soft);margin-top:14px;padding:12px;background:var(--primary-pale);border-radius:10px}
.success-card .next-steps b{color:var(--primary);display:block;margin-bottom:6px}
.success-card .next-steps ol{margin:0;padding-left:18px}

/* Strength meter */
.strength{height:4px;border-radius:2px;background:var(--bg-soft);overflow:hidden;margin-top:6px}
.strength .bar{height:100%;background:var(--absent);width:0;transition:width .2s,background .2s}
.strength.lvl-2 .bar{background:var(--late);width:50%}
.strength.lvl-3 .bar{background:var(--present);width:75%}
.strength.lvl-4 .bar{background:var(--primary);width:100%}
.strength.lvl-1 .bar{width:25%}

/* =============================================================
   ADMIN PANEL
   ============================================================= */
.admin-app{display:flex;flex-direction:column;min-height:100dvh;max-width:1100px;margin:0 auto;background:var(--bg)}
.admin-top{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;background:var(--bg);border-bottom:1px solid var(--line-soft);position:sticky;top:0;z-index:10;flex-wrap:wrap;gap:10px}
.admin-top h1{font-family:'Fraunces',serif;margin:0;font-size:22px;font-weight:900;letter-spacing:-.02em;line-height:1}
.admin-top h1 .dot{color:var(--accent)}
.admin-top .sub{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;font-weight:600;margin-top:2px}
.admin-top .right{display:flex;align-items:center;gap:10px}
.admin-top .who{font-size:13px;color:var(--ink-soft)}
.admin-top .who b{color:var(--ink)}

.admin-tabs{display:flex;gap:4px;padding:8px 16px 0;background:var(--bg);border-bottom:1px solid var(--line);overflow-x:auto;-webkit-overflow-scrolling:touch}
.admin-tabs button{background:none;border:none;padding:10px 14px;font-size:13px;font-weight:700;color:var(--ink-soft);border-bottom:2px solid transparent;white-space:nowrap}
.admin-tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}
.admin-tabs button:hover{color:var(--ink)}

.admin-main{flex:1;padding:18px 16px 60px;overflow-x:hidden}

/* Stat grid for admin pregled */
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.stat{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px}
.stat .label{font-size:10px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em;font-weight:700}
.stat .value{font-family:'Fraunces',serif;font-size:32px;font-weight:900;color:var(--ink);letter-spacing:-.04em;line-height:1;margin-top:4px}
.stat .value.green{color:var(--primary)}
.stat .value.red{color:var(--absent)}
.stat .value.amber{color:var(--late)}
.stat .sub{font-size:11px;color:var(--ink-faint);margin-top:4px;font-weight:500}
@media (min-width: 640px){ .stat-grid{grid-template-columns:repeat(4,1fr)} }

/* Tables */
.data-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}
.data-table th,.data-table td{padding:12px 14px;text-align:left;font-size:13px;border-bottom:1px solid var(--line-soft)}
.data-table th{background:var(--bg-soft);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--ink-soft);white-space:nowrap}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:var(--bg-soft)}
.data-table .actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}
.data-table .actions .btn{padding:6px 10px;font-size:12px;border-radius:8px}
.data-table .inactive{opacity:.55}
.data-table .nowrap{white-space:nowrap}

.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-wrap .data-table{min-width:680px}

.toolbar{display:flex;gap:8px;align-items:center;margin-bottom:14px;flex-wrap:wrap}
.toolbar .search{flex:1;min-width:200px}
.toolbar .btn{flex-shrink:0}

.search{width:100%;padding:12px 14px;background:var(--paper);border:1px solid var(--line);border-radius:12px;color:var(--ink);font-size:14px;font-weight:500}
.search:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-pale)}

.section-title{font-size:11px;font-weight:700;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.12em;margin:18px 0 10px}

/* Modal (admin) */
.modal-bg{position:fixed;inset:0;background:rgba(26,24,20,.55);z-index:100;display:flex;align-items:center;justify-content:center;animation:fadein .2s;backdrop-filter:blur(2px);padding:16px}
.modal{background:var(--bg);width:100%;max-width:560px;max-height:90dvh;overflow-y:auto;border-radius:20px;padding:22px;animation:slideup .28s cubic-bezier(.2,.8,.2,1);position:relative;box-shadow:var(--shadow)}
.modal h2{font-family:'Fraunces',serif;margin:0 0 6px;font-size:22px;font-weight:800;letter-spacing:-.02em}
.modal .sub{color:var(--ink-soft);margin-bottom:18px;font-size:13px}
.modal .close{position:absolute;top:14px;right:14px;background:var(--paper);border:1px solid var(--line);color:var(--ink);width:32px;height:32px;border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;line-height:1;cursor:pointer}
@keyframes slideup{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Multi-select for clubs / trainers */
.multi-select{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;padding:8px;background:var(--bg-soft);border-radius:10px;border:1px solid var(--line-soft)}
.multi-select label{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--ink)}
.multi-select label:hover{background:var(--paper)}
.multi-select input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);margin:0}
.multi-select .empty{padding:14px;text-align:center;color:var(--ink-faint);font-size:13px}

/* Matrix grid for dodjele */
.matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:8px;box-shadow:var(--shadow-sm)}
.matrix{border-collapse:separate;border-spacing:0;min-width:100%}
.matrix th,.matrix td{padding:6px;text-align:center;border:1px solid var(--line-soft)}
.matrix .corner{background:var(--bg-soft);min-width:160px;text-align:left;padding:10px 12px;position:sticky;left:0;z-index:2}
.matrix th.col{background:var(--bg-soft);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);white-space:nowrap;padding:10px 8px;min-width:90px}
.matrix th.row{background:var(--paper);font-weight:600;text-align:left;padding:10px 12px;font-size:13px;position:sticky;left:0;z-index:1;min-width:200px}
.matrix th.row .email{font-size:11px;color:var(--ink-faint);font-weight:500;margin-top:2px}
.matrix td .cell-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid var(--line);background:var(--bg);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-weight:900;color:var(--ink-faint);transition:all .12s;font-size:18px}
.matrix td .cell-btn:hover{border-color:var(--primary)}
.matrix td .cell-btn.on{background:var(--primary);border-color:var(--primary);color:#fff}
.matrix td .cell-btn:active{transform:scale(.92)}

/* Generic .row for inline meta */
.row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.muted{color:var(--ink-soft);font-size:13px}
.faint{color:var(--ink-faint);font-size:12px;font-weight:500}
.divider{height:1px;background:var(--line-soft);margin:14px 0}

/* Avatar (admin reuses from app) */
.avatar{width:42px;height:42px;border-radius:50%;background:var(--primary);color:var(--paper);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0;letter-spacing:-.02em}
.avatar.sm{width:34px;height:34px;font-size:12px}
.avatar.warm{background:var(--accent)}
.avatar.muted{background:var(--ink-faint)}

/* Inline list rows in modals */
.list-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--paper);border:1px solid var(--line);border-radius:10px;margin-bottom:6px}
.list-row .info{flex:1;min-width:0}
.list-row .name{font-weight:700;font-size:14px}
.list-row .meta{font-size:12px;color:var(--ink-soft);margin-top:1px}

/* Hide on narrow screens (e.g., admin table columns) */
@media (max-width: 720px){
  .hide-mobile{display:none}
}

/* Form field tweak for admin (sometimes 3-col) */
.field-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
@media (max-width: 540px){ .field-3{grid-template-columns:1fr} }

/* =============================================================
   MAIN APP (app.html)
   ============================================================= */
header.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;background:var(--bg);position:sticky;top:0;z-index:10;border-bottom:1px solid var(--line-soft)}
header.topbar .left{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
header.topbar h1{font-family:'Fraunces',serif;margin:0;font-size:22px;font-weight:900;letter-spacing:-.02em;line-height:1}
header.topbar h1 .dot{color:var(--accent)}
header.topbar .club{font-size:12px;color:var(--ink-soft);margin-top:3px;text-transform:uppercase;letter-spacing:.08em;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
header.topbar .right{display:flex;align-items:center;gap:8px}
.topbtn{background:var(--paper);border:1px solid var(--line);color:var(--ink);padding:8px 12px;border-radius:10px;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px}
.topbtn svg{width:16px;height:16px}

/* Sync indicator */
.sync-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--bg-soft);color:var(--ink-soft)}
.sync-pill .dot{width:8px;height:8px;border-radius:50%;background:var(--ink-faint)}
.sync-pill.online{background:var(--present-pale);color:var(--present)}
.sync-pill.online .dot{background:var(--present)}
.sync-pill.offline{background:var(--bg-soft);color:var(--ink-soft)}
.sync-pill.offline .dot{background:var(--ink-faint)}
.sync-pill.syncing{background:var(--late-pale);color:var(--late)}
.sync-pill.syncing .dot{background:var(--late);animation:pulse 1s infinite}
.sync-pill.error{background:var(--absent-pale);color:var(--absent)}
.sync-pill.error .dot{background:var(--absent)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

#app main{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:90px;-webkit-overflow-scrolling:touch;width:100%}

nav.tabs{position:fixed;bottom:0;left:0;right:0;max-width:520px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);background:var(--paper);border-top:1px solid var(--line);padding:8px 0 calc(8px + env(safe-area-inset-bottom));z-index:20}
@media (min-width: 740px){ nav.tabs{max-width:720px} }
@media (min-width: 1100px){ nav.tabs{max-width:960px} }
nav.tabs button{background:none;border:none;color:var(--ink-faint);display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;font-size:10px;font-weight:600;cursor:pointer}
nav.tabs button svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
nav.tabs button.active{color:var(--primary)}
nav.tabs button.active svg{stroke-width:2.2}

.section{padding:18px 16px 6px}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin:0 0 8px}
.section-head .t{font-size:11px;font-weight:700;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.12em}
.section-head a{font-size:12px;color:var(--primary);text-decoration:none;font-weight:600}

.btn-fab{position:fixed;bottom:96px;right:18px;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 16px rgba(200,74,31,.35);z-index:15;cursor:pointer}
/* Anchor FAB to app container right edge on wider screens */
@media (min-width: 740px){ .btn-fab{right:max(18px, calc(50vw - 720px/2 + 18px))} }
@media (min-width: 1100px){ .btn-fab{right:max(18px, calc(50vw - 960px/2 + 18px))} }
.btn-fab svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round}
.btn-fab:active{transform:scale(.95)}

/* App modal (bottom sheet on mobile) */
.app-modal-bg{position:fixed;inset:0;background:rgba(26,24,20,.55);z-index:100;display:flex;align-items:flex-end;justify-content:center;animation:fadein .2s;backdrop-filter:blur(2px)}
.app-modal-wrap{position:relative;width:100%;max-width:520px}
.app-modal{background:var(--bg);width:100%;max-height:94dvh;overflow-y:auto;border-radius:20px 20px 0 0;padding:8px 16px 24px;animation:slideUpSheet .28s cubic-bezier(.2,.8,.2,1)}
.app-modal-handle{width:40px;height:4px;background:var(--line);border-radius:2px;margin:8px auto 16px}
.app-modal h2{font-family:'Fraunces',serif;margin:0 0 16px;font-size:24px;font-weight:700;letter-spacing:-.02em}
.app-modal .close{position:absolute;top:18px;right:18px;background:var(--paper);border:1px solid var(--line);color:var(--ink);width:32px;height:32px;border-radius:50%;font-size:18px;display:flex;align-items:center;justify-content:center;line-height:1;z-index:5;cursor:pointer}
@keyframes slideUpSheet{from{transform:translateY(100%)}to{transform:translateY(0)}}

.action-list{display:flex;flex-direction:column;gap:6px}
.action-list button{background:var(--paper);border:1px solid var(--line);color:var(--ink);padding:14px;border-radius:12px;text-align:left;font-size:14px;font-weight:600;display:flex;align-items:center;gap:14px;width:100%;cursor:pointer}
.action-list button:active{background:var(--bg-soft)}
.action-list .ico-circle{width:38px;height:38px;border-radius:10px;background:var(--primary-pale);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}
.action-list .ico-circle svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.action-list .ico-circle.warm{background:var(--accent-pale);color:var(--accent)}
.action-list .ico-circle.danger{background:var(--absent-pale);color:var(--absent)}
.action-list .meta{display:flex;flex-direction:column;flex:1;min-width:0}
.action-list .meta .name{font-weight:700;font-size:14px}
.action-list .meta .sub{font-size:12px;color:var(--ink-soft);font-weight:500}
.action-list .arrow{color:var(--ink-faint);font-size:18px}

/* Update prompt for new SW version */
.update-banner{position:fixed;bottom:96px;left:16px;right:16px;max-width:488px;margin:0 auto;background:var(--primary);color:#fff;padding:12px 14px;border-radius:12px;display:flex;align-items:center;gap:10px;z-index:25;box-shadow:var(--shadow);font-size:13px;font-weight:600}
.update-banner button{background:#fff;color:var(--primary);border:none;padding:6px 12px;border-radius:8px;font-weight:700;font-size:12px;cursor:pointer;margin-left:auto}

/* Install banner (A2HS) */
.install-banner{position:fixed;bottom:96px;left:16px;right:16px;max-width:488px;margin:0 auto;background:var(--accent);color:#fff;padding:12px 14px;border-radius:12px;display:flex;align-items:center;gap:10px;z-index:25;box-shadow:var(--shadow);font-size:13px;font-weight:600}
.install-banner button{background:#fff;color:var(--accent);border:none;padding:6px 12px;border-radius:8px;font-weight:700;font-size:12px;cursor:pointer}
.install-banner .dismiss{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}

/* =============================================================
   IGRAČI / GRUPE
   ============================================================= */
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;padding-bottom:2px}
.chip{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:7px 13px;font-size:12px;font-weight:600;color:var(--ink-soft);white-space:nowrap;cursor:pointer;display:inline-flex;align-items:center;gap:5px}
.chip.active{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.chip .ct{opacity:.55;font-weight:700}
.chip.add{border-style:dashed;color:var(--primary);border-color:var(--primary)}

.avatar.lg{width:64px;height:64px;font-size:22px;border-radius:50%}

.player-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--paper);border:1px solid var(--line);border-radius:12px;margin-bottom:8px;text-align:left;width:100%;cursor:pointer}
.player-row:active{background:var(--bg-soft)}
.player-info{flex:1;min-width:0}
.player-name{font-weight:700;font-size:15px;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.player-meta{font-size:12px;color:var(--ink-soft);margin-top:1px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.player-row .chev{color:var(--ink-faint);font-size:18px;margin-left:auto;flex-shrink:0}

.group-head{display:flex;align-items:baseline;justify-content:space-between;margin:18px 0 8px}
.group-head:first-child{margin-top:6px}
.group-head .g-name{font-family:'Fraunces',serif;font-size:18px;font-weight:800;letter-spacing:-.01em}
.group-head .g-meta{font-size:12px;color:var(--ink-faint);font-weight:600}
.group-head .g-act{display:flex;gap:4px}
.group-head .g-act button{background:none;border:none;color:var(--ink-faint);padding:4px 6px;border-radius:6px;cursor:pointer}
.group-head .g-act button:hover{color:var(--primary)}
.group-head .g-act svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round}

.pill.danger{background:var(--absent-pale);color:var(--absent)}

.detail-head{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line-soft)}
.detail-head .info{flex:1;min-width:0}
.detail-head .h-name{font-family:'Fraunces',serif;font-size:22px;font-weight:800;letter-spacing:-.02em;line-height:1.1}
.detail-head .h-meta{font-size:13px;color:var(--ink-soft);margin-top:3px}

.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:14px;font-size:13px}
.detail-grid .lbl{color:var(--ink-faint);font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:700;margin-bottom:1px}
.detail-grid .val{color:var(--ink);font-weight:600;word-break:break-word}
.detail-grid .val.empty{color:var(--ink-faint);font-weight:500}
.detail-grid .full{grid-column:1 / -1}

.btn-group-row{display:flex;gap:8px;margin-top:8px}
.btn-group-row .btn{flex:1}

/* =============================================================
   TRENINZI — calendar + list
   ============================================================= */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.cal-head .month{font-family:'Fraunces',serif;font-size:20px;font-weight:700;text-transform:capitalize}
.cal-head button{background:var(--paper);border:1px solid var(--line);color:var(--ink);width:36px;height:36px;border-radius:10px;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:14px}
.cal-day-name{text-align:center;font-size:10px;color:var(--ink-faint);padding:6px 0;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.cal-day{aspect-ratio:1;background:var(--bg-soft);border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:13px;font-weight:600;position:relative;color:var(--ink);cursor:pointer;border:none}
.cal-day.out{background:transparent;color:var(--ink-faint);cursor:default}
.cal-day.has{background:var(--primary);color:#fff}
.cal-day.has.match{background:var(--accent)}
.cal-day.today{box-shadow:0 0 0 2px var(--accent) inset;font-weight:800}
.cal-day .badge{position:absolute;top:2px;right:3px;background:rgba(255,255,255,.3);font-size:9px;padding:0 4px;border-radius:6px;font-weight:700}
.cal-day:not(.out):hover{outline:1px solid var(--primary)}

.training-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--paper);border:1px solid var(--line);border-radius:14px;margin-bottom:8px;cursor:pointer;width:100%;text-align:left}
.training-card:active{background:var(--bg-soft)}
.training-card .date-bubble{width:52px;flex-shrink:0;text-align:center;padding:6px 0;border-radius:10px;background:var(--bg-soft);color:var(--ink)}
.training-card .date-bubble .d{font-family:'Fraunces',serif;font-size:20px;font-weight:900;line-height:1}
.training-card .date-bubble .m{font-size:10px;text-transform:uppercase;color:var(--ink-soft);letter-spacing:.05em;margin-top:2px;font-weight:700}
.training-card.match .date-bubble{background:var(--accent-pale);color:var(--accent)}
.training-card.match .date-bubble .m{color:var(--accent)}
.training-card .body{flex:1;min-width:0}
.training-card .ttl{font-weight:700;font-size:15px;letter-spacing:-.01em;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.training-card .meta{font-size:12px;color:var(--ink-soft);margin-top:2px}
.training-card.done{opacity:.7}
.training-card.done .ttl::after{content:'završen';font-size:10px;background:var(--present-pale);color:var(--present);padding:2px 6px;border-radius:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;margin-left:4px}
.training-card .chev{color:var(--ink-faint);font-size:18px}
.training-card .att-frac{font-size:11px;color:var(--ink-faint);font-weight:700;margin-left:auto;background:var(--bg-soft);padding:4px 8px;border-radius:8px}
.training-card.match .att-frac{background:var(--accent-pale);color:var(--accent)}

/* =============================================================
   BIG ATTENDANCE MODAL
   ============================================================= */
.att-sheet-head{position:sticky;top:-8px;background:var(--bg);padding:6px 0 12px;z-index:5;margin:-8px 0 8px;border-bottom:1px solid var(--line-soft)}
.att-sheet-head .ttl{font-family:'Fraunces',serif;font-size:18px;font-weight:800;letter-spacing:-.01em}
.att-sheet-head .sub{font-size:12px;color:var(--ink-soft);margin-top:2px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.att-counter{display:flex;align-items:center;gap:6px;margin-top:10px;font-weight:700;font-size:13px;color:var(--present)}
.att-counter svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:3}

.att-quick{display:flex;gap:6px;margin-top:8px}
.att-quick button{flex:1;padding:9px 6px;font-size:11px;font-weight:700;border-radius:9px;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;cursor:pointer}
.att-quick button:active{transform:scale(.97)}
.att-quick button.active{background:var(--primary);border-color:var(--primary);color:#fff}

.score-bar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;margin:10px 0;padding:10px;background:var(--paper);border:1px solid var(--line);border-radius:12px}
.score-bar .team{font-size:11px;color:var(--ink-soft);text-align:center;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.score-bar input{width:100%;text-align:center;font-family:'Fraunces',serif;font-size:34px;font-weight:900;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:4px;color:var(--ink);letter-spacing:-.02em}
.score-bar input:focus{outline:none;border-color:var(--accent);background:var(--paper)}
.score-bar .colon{font-family:'Fraunces',serif;font-size:36px;font-weight:900;color:var(--ink-faint);padding:0 4px}

.att-card-grid{display:grid;grid-template-columns:1fr;gap:8px}
@media (min-width: 540px){ .att-card-grid{grid-template-columns:1fr 1fr} }

.att-card{background:var(--paper);border:1.5px solid var(--line);border-radius:14px;padding:12px;transition:background .15s,border-color .15s}
.att-card.present{background:var(--present-pale);border-color:var(--present)}
.att-card.absent{background:var(--absent-pale);border-color:var(--absent)}
.att-card.late{background:var(--late-pale);border-color:var(--late)}
.att-card.excused{background:var(--excused-pale);border-color:var(--excused)}
.att-card .head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.att-card .name{font-weight:800;font-size:15px;letter-spacing:-.01em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.att-card .pos{font-size:11px;color:var(--ink-soft);font-weight:600}
.att-simple-btns{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.att-simple-btns button{padding:11px 6px;border:1.5px solid var(--line);background:var(--paper);border-radius:10px;font-weight:800;font-size:13px;color:var(--ink-soft);cursor:pointer;letter-spacing:.04em;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:5px}
.att-simple-btns button svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5}
.att-simple-btns button:active{transform:scale(.97)}
.att-card.present .att-simple-btns button.yes{background:var(--present);border-color:var(--present);color:#fff}
.att-card.absent  .att-simple-btns button.no {background:var(--absent);border-color:var(--absent);color:#fff}

/* Detailed mode: 4 status buttons */
.att-detail-btns{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}
.att-detail-btns button{height:44px;border:1.5px solid var(--line);background:var(--paper);border-radius:10px;font-weight:800;font-size:14px;color:var(--ink-soft);cursor:pointer}
.att-detail-btns button:active{transform:scale(.95)}
.att-card.present .att-detail-btns button.s-P{background:var(--present);border-color:var(--present);color:#fff}
.att-card.absent  .att-detail-btns button.s-O{background:var(--absent);border-color:var(--absent);color:#fff}
.att-card.late    .att-detail-btns button.s-K{background:var(--late);border-color:var(--late);color:#fff}
.att-card.excused .att-detail-btns button.s-I{background:var(--excused);border-color:var(--excused);color:#fff}
.att-card .rate-row-inline{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.05);flex-wrap:wrap}
.att-card .rate-row-inline .label{font-size:10px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-weight:700;margin-right:auto}
.rate-dot{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line);background:var(--paper);display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink-faint);cursor:pointer}
.rate-dot.on{background:var(--accent);border-color:var(--accent);color:#fff}
.att-card .starter-toggle{display:flex;align-items:center;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.05)}
.att-card .starter-toggle label{font-size:11px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em;cursor:pointer;display:flex;align-items:center;gap:6px}
.att-card .starter-toggle input{accent-color:var(--accent)}

.att-foot{position:sticky;bottom:-24px;background:var(--bg);margin:10px -16px -24px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--line-soft);display:flex;gap:8px;z-index:5}
.att-foot .btn{flex:1}

.big-rate{display:flex;justify-content:space-between;gap:6px;margin-top:6px}
.big-rate button{flex:1;padding:14px 6px;border-radius:12px;border:1.5px solid var(--line);background:var(--paper);font-size:18px;font-weight:800;color:var(--ink-soft);font-family:'Fraunces',serif;cursor:pointer}
.big-rate button.on{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 12px rgba(200,74,31,.25)}
.big-rate-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-faint);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:6px;padding:0 4px}

.scorer-row{display:grid;grid-template-columns:1fr 1fr 64px auto;gap:6px;align-items:center;padding:8px;background:var(--paper);border:1px solid var(--line);border-radius:10px;margin-bottom:6px}
.scorer-row select,.scorer-row input{padding:8px;font-size:13px;border:1px solid var(--line);border-radius:8px;background:var(--paper);color:var(--ink);width:100%;font-weight:500}
.scorer-row .rm{background:var(--absent-pale);color:var(--absent);border:none;width:32px;height:32px;border-radius:8px;font-weight:900;font-size:16px;cursor:pointer}

/* Trening / Utakmica toggle */
.kind-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.kind-toggle button{padding:14px 8px;border:1.5px solid var(--line);background:var(--paper);border-radius:12px;font-weight:800;font-size:14px;color:var(--ink-soft);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.kind-toggle button svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2}
.kind-toggle button.on.trening{background:var(--primary);border-color:var(--primary);color:#fff}
.kind-toggle button.on.utakmica{background:var(--accent);border-color:var(--accent);color:#fff}

/* =============================================================
   ČLANARINE
   ============================================================= */
.pay-card{background:var(--paper);border:1.5px solid var(--line);border-radius:14px;padding:12px;margin-bottom:8px;transition:background .15s,border-color .15s}
.pay-card.paid{background:var(--present-pale);border-color:var(--present)}
.pay-card.unpaid{background:var(--absent-pale);border-color:var(--absent)}
.pay-card.due{background:var(--late-pale);border-color:var(--late)}
.pay-card .top{display:flex;align-items:center;gap:10px;margin-bottom:10px;cursor:pointer}
.pay-card .meta{flex:1;min-width:0}
.pay-card .name{font-weight:800;font-size:15px;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pay-card .sub{font-size:12px;color:var(--ink-soft);margin-top:1px}
.pay-card .amount{font-family:'Fraunces',serif;font-weight:900;font-size:18px;letter-spacing:-.02em;text-align:right;flex-shrink:0}
.pay-card .amount .km{font-size:11px;font-weight:600;color:var(--ink-soft);margin-left:2px}
.pay-btns{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.pay-btns button{padding:11px 6px;border:1.5px solid var(--line);background:var(--paper);border-radius:10px;font-weight:800;font-size:13px;color:var(--ink-soft);cursor:pointer;text-transform:uppercase;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;gap:5px}
.pay-btns button svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.5}
.pay-btns button:active{transform:scale(.97)}
.pay-card.paid .pay-btns button.y{background:var(--present);border-color:var(--present);color:#fff}
.pay-card.unpaid .pay-btns button.n,
.pay-card.due    .pay-btns button.n{background:var(--absent);border-color:var(--absent);color:#fff}

.pay-toolbar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.pay-toolbar .btn{flex:0 0 auto;padding:8px 12px;font-size:12px;border-radius:9px}

/* Year calendar grid (per player detail) */
.year-block{margin-top:14px}
.year-block .yr-label{font-family:'Fraunces',serif;font-weight:800;font-size:16px;margin-bottom:8px;color:var(--ink-soft)}
.year-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:5px}
@media (max-width:380px){ .year-grid{grid-template-columns:repeat(4,1fr)} }
.year-cell{aspect-ratio:1;background:var(--bg-soft);border-radius:9px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink-faint);cursor:pointer;border:1.5px solid transparent;position:relative}
.year-cell.paid{background:var(--present);color:#fff;border-color:var(--present)}
.year-cell.unpaid{background:var(--absent);color:#fff;border-color:var(--absent)}
.year-cell.due{background:var(--late);color:#fff;border-color:var(--late)}
.year-cell.future{opacity:.4;cursor:not-allowed}
.year-cell .mlbl{font-family:'Fraunces',serif;font-size:13px;font-weight:900;text-transform:uppercase}
.year-cell .sm{font-size:9px;opacity:.85;margin-top:1px;font-weight:600}
.year-cell:not(.future):hover{outline:1px solid var(--primary)}

/* =============================================================
   DESKTOP-ONLY: 2-column lists where it helps
   ============================================================= */
@media (min-width: 740px){
  .section{display:block}
  /* Player and training/pay rows: 2 columns at >= 740, 3 columns at >= 1100 */
  .player-row, .training-card, .pay-card {
    width:100%;
  }
  /* Mark sections that should use a 2-col grid for rows */
  .grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
  .grid-2 > * { margin-bottom: 0 !important; }
}
@media (min-width: 1100px){
  .grid-2 { grid-template-columns:1fr 1fr 1fr; }
  .att-card-grid{ grid-template-columns:1fr 1fr 1fr; }
  .year-grid{ grid-template-columns:repeat(12,1fr); }
}

/* =============================================================
   DARK MODE
   ============================================================= */
@media (prefers-color-scheme: dark) {
  body[data-theme="auto"] {
    --bg:#1a1814; --bg-soft:#252320; --paper:#2a2825;
    --ink:#f5f1ea; --ink-soft:#bdb6a8; --ink-faint:#867e72;
    --line:#3a3631; --line-soft:#322e29;
    --primary:#4ea886; --primary-pale:#1f3a32;
    --accent:#e88159; --accent-pale:#3a2a20;
    --present:#5ab97c; --present-pale:#1f3a2a;
    --absent:#e66a4f; --absent-pale:#3a221c;
    --late:#e6a64f; --late-pale:#3a2e1c;
    --excused:#6ea0c8; --excused-pale:#1c2a3a;
    --shadow-sm:0 1px 2px rgba(0,0,0,.3);
    --shadow:0 8px 24px rgba(0,0,0,.45);
  }
}
body[data-theme="tamna"] {
  --bg:#1a1814; --bg-soft:#252320; --paper:#2a2825;
  --ink:#f5f1ea; --ink-soft:#bdb6a8; --ink-faint:#867e72;
  --line:#3a3631; --line-soft:#322e29;
  --primary:#4ea886; --primary-pale:#1f3a32;
  --accent:#e88159; --accent-pale:#3a2a20;
  --present:#5ab97c; --present-pale:#1f3a2a;
  --absent:#e66a4f; --absent-pale:#3a221c;
  --late:#e6a64f; --late-pale:#3a2e1c;
  --excused:#6ea0c8; --excused-pale:#1c2a3a;
  --shadow-sm:0 1px 2px rgba(0,0,0,.3);
  --shadow:0 8px 24px rgba(0,0,0,.45);
}

/* =============================================================
   BULK IMPORT (igrači)
   ============================================================= */
.bulk-import-form{display:flex;flex-direction:column;gap:14px}
.bulk-import-form textarea{min-height:160px;font-family:'JetBrains Mono','Menlo',monospace;font-size:13px;line-height:1.6}
.bulk-preview{background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:10px;padding:10px 14px;max-height:240px;overflow-y:auto;font-size:13px}
.bulk-preview .row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--line-soft)}
.bulk-preview .row:last-child{border-bottom:none}
.bulk-preview .row.bad{color:var(--absent)}
.bulk-preview .row .num{font-family:'Fraunces',serif;font-weight:800;color:var(--ink-faint);min-width:24px;text-align:right;font-size:12px}
.bulk-preview .row .name{flex:1;font-weight:600}
.bulk-preview .row .year{color:var(--ink-soft);font-size:12px;font-weight:600}
.bulk-preview .row .err{color:var(--absent);font-size:11px;font-weight:700}
.bulk-summary{display:flex;gap:14px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft)}
.bulk-summary .ok{color:var(--present)}
.bulk-summary .err{color:var(--absent)}
.bulk-undo{position:fixed;bottom:104px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--paper);border-radius:12px;padding:10px 18px;z-index:200;box-shadow:var(--shadow);font-size:13px;font-weight:600;display:flex;align-items:center;gap:12px}
.bulk-undo button{background:transparent;color:var(--accent);border:none;font-weight:800;font-size:13px;cursor:pointer;padding:0}

/* =============================================================
   STATS DELTA INDICATORS
   ============================================================= */
.stat .delta{display:inline-flex;align-items:center;gap:2px;font-size:10px;font-weight:800;padding:2px 5px;border-radius:6px;margin-left:6px;vertical-align:middle}
.stat .delta.up{background:var(--present-pale);color:var(--present)}
.stat .delta.down{background:var(--absent-pale);color:var(--absent)}
.stat .delta.flat{background:var(--bg-soft);color:var(--ink-faint)}
.stat .context{font-size:10px;color:var(--ink-faint);margin-top:3px;font-weight:600;line-height:1.3}
.stat .context b{color:var(--ink-soft);font-weight:700}

/* =============================================================
   HOMEPAGE GROUP CHIPS
   ============================================================= */
.home-chips{display:flex;gap:6px;overflow-x:auto;padding:0 16px 12px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.home-chips::-webkit-scrollbar{display:none}
.home-chips .chip{flex-shrink:0}

.group-mini-card{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin-bottom:8px;cursor:pointer;display:flex;align-items:center;gap:12px;width:100%;text-align:left}
.group-mini-card:active{background:var(--bg-soft)}
.group-mini-card .gico{width:40px;height:40px;border-radius:11px;background:var(--primary-pale);color:var(--primary);display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:900;font-size:14px;flex-shrink:0;letter-spacing:-.02em}
.group-mini-card .gico.accent{background:var(--accent-pale);color:var(--accent)}
.group-mini-card .body{flex:1;min-width:0}
.group-mini-card .ttl{font-weight:700;font-size:15px;letter-spacing:-.01em}
.group-mini-card .quick{display:flex;gap:10px;font-size:11px;color:var(--ink-soft);margin-top:3px;flex-wrap:wrap}
.group-mini-card .quick b{color:var(--ink);font-weight:800}
.group-mini-card .badge{background:var(--accent);color:#fff;font-size:10px;padding:2px 6px;border-radius:6px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;margin-left:auto;flex-shrink:0}

/* Active training banner (auto-detected) */
.active-banner{margin:8px 16px 0;padding:14px 16px;border-radius:14px;background:linear-gradient(135deg, var(--accent), #d65b3a);color:#fff;display:flex;align-items:center;gap:12px;box-shadow:0 6px 18px rgba(200,74,31,.3);cursor:pointer;border:none;width:calc(100% - 32px);text-align:left}
.active-banner:active{transform:scale(.98)}
.active-banner .ab-ico{width:38px;height:38px;border-radius:11px;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.active-banner .ab-ico svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.4}
.active-banner .ab-body{flex:1;min-width:0}
.active-banner .ab-ttl{font-family:'Fraunces',serif;font-size:16px;font-weight:800}
.active-banner .ab-sub{font-size:12px;opacity:.9;margin-top:2px}
.active-banner .ab-go{font-size:20px;font-weight:900}

/* =============================================================
   PARENT PUBLIC PAGE (dijete.html)
   ============================================================= */
.dijete-shell{max-width:520px;margin:0 auto;padding:24px 16px 40px;min-height:100dvh;background:var(--bg)}
.dijete-head{text-align:center;margin-bottom:18px}
.dijete-head h1{font-family:'Fraunces',serif;margin:0;font-size:32px;font-weight:900;letter-spacing:-.03em}
.dijete-head h1 .dot{color:var(--accent)}
.dijete-head .muted{font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:700;color:var(--ink-soft);margin-top:4px}
.dijete-player{padding:18px;margin-bottom:14px;background:var(--paper)}
.dijete-year{margin:10px 0 16px}
.dijete-year .yr-label{font-family:'Fraunces',serif;font-weight:800;font-size:16px;margin-bottom:8px;color:var(--ink-soft)}
.dijete-foot{text-align:center;margin-top:24px;font-size:11px;padding:12px}
.error-card{text-align:center;padding:30px 18px;border:1px solid var(--absent-pale);background:var(--paper)}
.loading{text-align:center;padding:40px 20px;color:var(--ink-faint);font-size:13px}
.km{font-size:11px;font-weight:600;color:var(--ink-soft);margin-left:2px}

/* =============================================================
   BULK PLAĆANJA PO GRUPI (modal)
   ============================================================= */
.bulk-pay-list{max-height:50vh;overflow-y:auto;border:1px solid var(--line-soft);border-radius:10px;background:var(--paper)}
.bulk-pay-row{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line-soft);transition:background .12s}
.bulk-pay-row:last-child{border-bottom:none}
.bulk-pay-row.paid{background:var(--present-pale)}
.bulk-pay-row input[type="checkbox"]{width:22px;height:22px;accent-color:var(--present);flex-shrink:0}
.bulk-pay-row .name{flex:1;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bulk-pay-row input.amt{width:84px;padding:6px 10px;font-size:13px;text-align:right;font-weight:700;border:1px solid var(--line);border-radius:8px;background:var(--bg);color:var(--ink)}
.bulk-pay-totals{display:flex;justify-content:space-between;padding:10px 14px;background:var(--bg-soft);border-radius:10px;margin-top:10px;font-weight:800;font-size:14px}
.bulk-pay-totals .lbl{color:var(--ink-soft);font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;align-self:center}

/* =============================================================
   CHARTS (player progress)
   ============================================================= */
.chart-wrap{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:10px}
.chart-wrap canvas{max-width:100%}
.chart-toolbar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.chart-toolbar .chip{cursor:pointer}
.chart-empty{text-align:center;padding:30px 12px;color:var(--ink-faint);font-size:13px}

/* =============================================================
   PARENT LINK (modal helper)
   ============================================================= */
.parent-link-box{background:var(--bg-soft);border:1px dashed var(--primary);border-radius:10px;padding:12px 14px;margin:10px 0;font-family:'JetBrains Mono','Menlo',monospace;font-size:12px;word-break:break-all;color:var(--ink);line-height:1.5}
.parent-link-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.parent-link-actions .btn{padding:7px 12px;font-size:12px;border-radius:8px}

/* =============================================================
   THEME PICKER (postavke)
   ============================================================= */
.theme-pick{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:8px 0 14px}
.theme-pick button{padding:14px 6px;border:1.5px solid var(--line);background:var(--paper);border-radius:12px;color:var(--ink);font-weight:700;font-size:13px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:6px}
.theme-pick button .swatch{width:36px;height:36px;border-radius:8px;border:1px solid var(--line)}
.theme-pick button .swatch.light{background:#f5f1ea}
.theme-pick button .swatch.dark{background:#1a1814}
.theme-pick button .swatch.auto{background:linear-gradient(135deg, #f5f1ea 50%, #1a1814 50%)}
.theme-pick button.on{border-color:var(--primary);background:var(--primary-pale);color:var(--primary)}

/* =============================================================
   iOS INSTALL INSTRUCTIONS (Add to Home Screen)
   ============================================================= */
.install-banner.ios{background:linear-gradient(135deg, #1f4d3f, #2d6e5a)}
.install-banner.ios button{background:#fff;color:#1f4d3f}
.install-banner.ios .dismiss{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.ios-step{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line-soft)}
.ios-step:last-of-type{border-bottom:none}
.ios-step-num{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:900;font-size:16px;flex-shrink:0;letter-spacing:-.02em}
.ios-step-body{flex:1;min-width:0}
.ios-step-ttl{font-weight:700;font-size:14px;margin-bottom:3px}
.ios-step-sub{font-size:13px;color:var(--ink-soft);line-height:1.45}
.ios-step-sub b{color:var(--ink);font-weight:700}

/* Vidljiva instalacijska kartica na login stranici */
.install-card{margin-top:18px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:var(--shadow-sm);text-align:left}
.install-card-head{display:flex;align-items:center;gap:8px;font-family:'Fraunces',serif;font-weight:800;font-size:15px;color:var(--primary);margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--line-soft)}
.install-card .ios-step{padding:10px 0}
.install-lead{font-size:12px;color:var(--ink-soft);font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.install-note{font-size:12px;margin-top:12px;padding:11px 13px;background:var(--bg-soft);border-radius:10px;line-height:1.5;color:var(--ink-soft)}
.install-warn{font-size:13px;margin:8px 0 12px;padding:12px 14px;background:var(--late-pale);color:var(--late);border-radius:10px;font-weight:600;line-height:1.5}
.install-warn b{color:var(--late)}

/* =============================================================
   RODITELJSKI PORTAL (/roditelj/)
   ============================================================= */
.rod-app{display:flex;flex-direction:column;min-height:100dvh;max-width:560px;margin:0 auto;background:var(--bg)}
.rod-top{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--bg);position:sticky;top:0;z-index:10;border-bottom:1px solid var(--line-soft)}
.rod-top .logo{font-family:'Fraunces',serif;font-size:22px;font-weight:900;letter-spacing:-.02em}
.rod-top .logo .dot{color:var(--accent)}
.rod-top .right{display:flex;align-items:center;gap:6px}
.rod-top .right a,.rod-top .right button{background:var(--paper);border:1px solid var(--line);color:var(--ink);padding:7px 11px;border-radius:9px;font-weight:600;font-size:12px;text-decoration:none;display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.rod-main{flex:1;padding:18px 16px 40px}
.rod-greeting{font-size:13px;color:var(--ink-soft);margin-bottom:2px}
.rod-h1{font-family:'Fraunces',serif;font-size:24px;font-weight:900;letter-spacing:-.02em;margin:0 0 14px}

.rod-back{display:inline-flex;align-items:center;gap:6px;color:var(--primary);text-decoration:none;font-weight:700;font-size:13px;margin-bottom:12px}

/* Dijete kartica na dashboard-u */
.dijete-card{display:flex;align-items:center;gap:14px;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:10px;text-decoration:none;color:var(--ink);box-shadow:var(--shadow-sm)}
.dijete-card:active{background:var(--bg-soft)}
.dijete-card .avatar{width:54px;height:54px;border-radius:50%;font-size:19px}
.dijete-card .dc-info{flex:1;min-width:0}
.dijete-card .dc-name{font-family:'Fraunces',serif;font-size:18px;font-weight:800;letter-spacing:-.01em}
.dijete-card .dc-sub{font-size:12px;color:var(--ink-soft);margin-top:2px}
.dijete-card .dc-stats{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}
.stat-pill{font-size:11px;font-weight:700;padding:3px 9px;border-radius:20px;white-space:nowrap}
.stat-pill.green{background:var(--present-pale);color:var(--present)}
.stat-pill.amber{background:var(--late-pale);color:var(--late)}
.stat-pill.red{background:var(--absent-pale);color:var(--absent)}
.dijete-card .dc-chev{font-size:22px;color:var(--ink-faint)}

/* Dijete header */
.dijete-title{font-family:'Fraunces',serif;font-size:26px;font-weight:900;letter-spacing:-.02em;margin:0}
.dijete-meta{font-size:13px;color:var(--ink-soft);margin-top:3px}

/* Tabovi */
.rod-tabs{display:flex;gap:4px;margin:14px 0;border-bottom:1px solid var(--line);overflow-x:auto;-webkit-overflow-scrolling:touch}
.rod-tabs button{background:none;border:none;padding:10px 14px;font-size:13px;font-weight:700;color:var(--ink-soft);border-bottom:2px solid transparent;white-space:nowrap;cursor:pointer}
.rod-tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}

/* Info kartice */
.info-card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:13px 15px;margin-bottom:8px}
.info-card .ic-label{font-size:11px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.info-card .ic-value{font-family:'Fraunces',serif;font-size:20px;font-weight:800;margin-top:3px;letter-spacing:-.01em}
.info-card .ic-value.green{color:var(--primary)}
.info-card .ic-value.red{color:var(--absent)}
.info-card .ic-sub{font-size:12px;color:var(--ink-soft);margin-top:2px}

/* Status kartica (članarine) */
.status-card{border-radius:14px;padding:16px;margin-bottom:14px;border:1px solid}
.status-card.green{background:var(--present-pale);border-color:var(--present);color:var(--present)}
.status-card.red{background:var(--absent-pale);border-color:var(--absent);color:var(--absent)}
.status-card h3{font-family:'Fraunces',serif;margin:0 0 4px;font-size:18px}
.status-card p{margin:0;font-size:13px;font-weight:600}

/* Trening lista (raspored + zadnji) */
.trening-row{display:flex;align-items:center;gap:10px;padding:11px 13px;background:var(--paper);border:1px solid var(--line);border-radius:12px;margin-bottom:7px}
.trening-row .tr-status{font-size:11px;font-weight:800;padding:3px 8px;border-radius:8px;white-space:nowrap}
.trening-row .tr-status.P{background:var(--present-pale);color:var(--present)}
.trening-row .tr-status.O{background:var(--absent-pale);color:var(--absent)}
.trening-row .tr-status.K{background:var(--late-pale);color:var(--late)}
.trening-row .tr-status.I{background:var(--excused-pale);color:var(--excused)}
.trening-row .tr-info{flex:1;min-width:0}
.trening-row .tr-tip{font-weight:700;font-size:14px}
.trening-row .tr-datum{font-size:12px;color:var(--ink-soft);margin-top:1px}
.trening-row .tr-ocjena{font-size:12px;font-weight:700;color:var(--accent)}

/* Raspored — datum box */
.raspored-item{display:flex;gap:12px;padding:12px 13px;background:var(--paper);border:1px solid var(--line);border-radius:12px;margin-bottom:8px}
.raspored-item.utakmica{border-color:var(--accent);background:var(--accent-pale)}
.raspored-item .datum-box{width:54px;flex-shrink:0;text-align:center;background:var(--bg-soft);border-radius:10px;padding:6px 0}
.raspored-item.utakmica .datum-box{background:var(--paper)}
.raspored-item .datum-box .dan{font-family:'Fraunces',serif;font-size:22px;font-weight:900;line-height:1}
.raspored-item .datum-box .mj{font-size:10px;text-transform:uppercase;font-weight:700;color:var(--ink-soft);margin-top:2px}
.raspored-item .ri-info{flex:1;min-width:0}
.raspored-item .ri-tip{font-weight:700;font-size:15px}
.raspored-item .ri-sub{font-size:12px;color:var(--ink-soft);margin-top:2px}
.raspored-item.otkazan{opacity:.55}
.raspored-item.otkazan .ri-tip::after{content:' · OTKAZAN';color:var(--absent);font-size:11px}

/* Uplate tabela */
.uplate-table{width:100%;border-collapse:collapse;background:var(--paper);border:1px solid var(--line);border-radius:12px;overflow:hidden;font-size:13px}
.uplate-table th{background:var(--bg-soft);padding:9px 11px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-weight:700}
.uplate-table td{padding:10px 11px;border-top:1px solid var(--line-soft)}
.uplate-table tr.unpaid td{background:var(--absent-pale)}

/* Graf kartica */
.graf-card{background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:10px}
.graf-card h3{font-family:'Fraunces',serif;font-size:15px;margin:0 0 8px;font-weight:800}
/* Fiksna visina kontejnera — sprječava Chart.js resize petlju (canvas koji raste) */
.graf-cv{position:relative;height:210px;width:100%}
.graf-cv canvas{position:absolute;inset:0}
.graf-card .napredak{font-size:12px;font-weight:700;margin-top:8px}
.graf-card .napredak.up{color:var(--present)}
.graf-card .napredak.down{color:var(--absent)}

/* Info banner (registracija) */
.info-banner{background:var(--primary-pale);border:1px solid var(--primary);border-radius:12px;padding:14px 16px;margin-bottom:18px;text-align:center}
.info-banner p{margin:0;font-size:12px;color:var(--primary);font-weight:600}
.info-banner h2{font-family:'Fraunces',serif;margin:4px 0;font-size:22px;font-weight:900;color:var(--ink)}

/* =============================================================
   VJEŽBE — čista kartica (pun naziv, meta kao pilule)
   ============================================================= */
.vjezba-card{display:flex;gap:12px;align-items:flex-start;width:100%;text-align:left;cursor:pointer;
  background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:13px 14px;margin-bottom:8px;box-shadow:var(--shadow-sm)}
.vjezba-card:active{background:var(--bg-soft)}
.vj-ico{width:40px;height:40px;border-radius:11px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  background:var(--primary-pale);color:var(--primary)}
.vj-ico svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.vj-ico.int-hi{background:var(--absent-pale);color:var(--absent)}
.vj-ico.int-mid{background:var(--late-pale);color:var(--late)}
.vj-ico.int-lo{background:var(--present-pale);color:var(--present)}
.vj-body{flex:1;min-width:0}
.vj-name{font-weight:700;font-size:15px;line-height:1.3;letter-spacing:-.01em;word-break:break-word}
.vj-pills{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.vj-pills .vp{font-size:11px;font-weight:700;padding:3px 8px;border-radius:8px;background:var(--bg-soft);color:var(--ink-soft);white-space:nowrap}
.vj-pills .vp.int-hi{background:var(--absent-pale);color:var(--absent);text-transform:capitalize}
.vj-pills .vp.int-mid{background:var(--late-pale);color:var(--late);text-transform:capitalize}
.vj-pills .vp.int-lo{background:var(--present-pale);color:var(--present);text-transform:capitalize}
.vj-pills .vp-opr{background:var(--primary-pale);color:var(--primary)}
.vj-desc{font-size:12px;color:var(--ink-soft);margin-top:6px;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* =============================================================
   3-FAZNI TRENING (dolasci modal)
   ============================================================= */
.phase-steps{display:flex;gap:6px;margin-top:10px}
.phase-steps .ps{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;
  background:var(--bg-soft);border:1px solid var(--line-soft);border-radius:10px;padding:7px 4px;
  font-size:11px;font-weight:700;color:var(--ink-faint);cursor:pointer}
.phase-steps .ps .ps-num{width:18px;height:18px;border-radius:50%;background:var(--line);color:var(--paper);
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.phase-steps .ps.active{background:var(--primary-pale);border-color:var(--primary);color:var(--primary)}
.phase-steps .ps.active .ps-num{background:var(--primary)}
.phase-steps .ps.done{color:var(--present)}
.phase-steps .ps.done .ps-num{background:var(--present)}
@media (max-width:380px){ .phase-steps .ps-lbl{display:none} }

.vj-faza-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;cursor:pointer;
  background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:7px}
.vj-faza-row .vjf-num{width:28px;height:28px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;
  justify-content:center;font-family:'Fraunces',serif;font-weight:900;font-size:14px;background:var(--bg-soft);color:var(--ink-soft)}
.vj-faza-row .vjf-body{flex:1;min-width:0}
.vj-faza-row .vjf-name{font-weight:700;font-size:14px;word-break:break-word}
.vj-faza-row .vjf-meta{font-size:12px;color:var(--ink-soft);margin-top:2px}
.vj-faza-row .vjf-status{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  padding:4px 8px;border-radius:8px;white-space:nowrap;background:var(--bg-soft);color:var(--ink-faint)}
.vj-faza-row.st-now{border-color:var(--late);background:var(--late-pale)}
.vj-faza-row.st-now .vjf-num{background:var(--late);color:#fff}
.vj-faza-row.st-now .vjf-status{background:var(--late);color:#fff}
.vj-faza-row.st-done{border-color:var(--present);background:var(--present-pale)}
.vj-faza-row.st-done .vjf-num{background:var(--present);color:#fff}
.vj-faza-row.st-done .vjf-status{background:var(--present);color:#fff}
.vj-faza-row.st-done .vjf-name{text-decoration:line-through;opacity:.7}

/* =============================================================
   COLLAPSE / ACCORDION (detalji igrača: mjerenja, povrede, dolasci...)
   ============================================================= */
.acc{border:1px solid var(--line);border-radius:12px;margin-top:10px;background:var(--paper);overflow:hidden}
.acc-sum{display:flex;align-items:center;gap:8px;padding:12px 14px;cursor:pointer;list-style:none;user-select:none}
.acc-sum::-webkit-details-marker{display:none}
.acc-sum::marker{content:''}
.acc-chev{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;
  color:var(--ink-faint);font-size:18px;font-weight:700;transition:transform .15s;line-height:1}
.acc[open] .acc-chev{transform:rotate(90deg)}
.acc-t{font-family:'Fraunces',serif;font-size:15px;font-weight:800;letter-spacing:-.01em}
.acc-ct{font-size:11px;font-weight:800;color:var(--ink-soft);background:var(--bg-soft);
  padding:2px 8px;border-radius:20px}
.acc-add{margin-left:auto;font-size:12px;font-weight:700;color:var(--primary);
  padding:4px 8px;border-radius:8px;background:var(--primary-pale);white-space:nowrap;cursor:pointer}
.acc-add:active{transform:scale(.96)}
.acc-body{padding:2px 14px 12px}
.acc:active{}
.acc-sum:hover{background:var(--bg-soft)}

/* Klikabilne statistike na početnoj */
.stat.tappable{cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent;transition:transform .08s ease}
.stat.tappable:active{transform:scale(.97)}
.stat.tappable::after{content:"\203a";position:absolute;top:8px;right:10px;color:var(--ink-faint);font-size:16px;font-weight:800;line-height:1}
.stat.tappable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* Matrica plaćanja */
.matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:12px;background:var(--paper)}
table.matrix{border-collapse:separate;border-spacing:0;width:100%;font-size:12px}
table.matrix th,table.matrix td{padding:7px 4px;text-align:center;border-bottom:1px solid var(--line);border-right:1px solid var(--line);white-space:nowrap;font-weight:700}
table.matrix th{background:var(--bg-soft);color:var(--ink-soft);font-size:10px;text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0;z-index:2}
table.matrix th.mx-m{min-width:42px}
table.matrix th.mx-m small{display:block;font-weight:600;color:var(--ink-faint);font-size:9px}
table.matrix tbody tr:last-child td{border-bottom:none}
table.matrix td:last-child,table.matrix th:last-child{border-right:none}
.mx-row-h{position:sticky;left:0;z-index:1;background:var(--paper);text-align:left !important;min-width:118px;max-width:150px;overflow:hidden;text-overflow:ellipsis;color:var(--ink)}
thead .mx-row-h{z-index:3;background:var(--bg-soft)}
.mx-cnt{display:inline-block;background:var(--bg-soft);color:var(--ink-faint);border-radius:8px;padding:1px 6px;font-size:10px;margin-left:3px;font-weight:700}
.mx-link{background:none;border:none;padding:0;font:inherit;color:var(--accent);font-weight:800;cursor:pointer;text-align:left}
.mx-link:active{opacity:.6}
.mx-ok{background:var(--present-pale);color:var(--present)}
.mx-mid{background:var(--late-pale);color:var(--late)}
.mx-bad{background:var(--absent-pale);color:var(--absent)}
.mx-na{color:var(--ink-faint)}
table.matrix tr.mx-total td{background:var(--ink);color:var(--paper);border-bottom:none;font-weight:800}
table.matrix tr.mx-total .mx-row-h{background:var(--ink);color:var(--paper)}
table.matrix tr.mx-total .mx-cnt{background:rgba(255,255,255,.18);color:var(--paper)}
.matrix-ig td{font-size:13px}
.mx-debt{font-weight:800}
.mx-legend{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:11px;color:var(--ink-soft);font-weight:600}
.mx-legend span{display:inline-flex;align-items:center;gap:5px}
.mx-sw{width:12px;height:12px;border-radius:4px;display:inline-block}

/* Zadnjih 5 statusa prisutnosti u listi igrača */
.att-dots{display:flex;gap:3px;margin-top:5px}
.att-dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:var(--ink-faint);flex:none}
.att-dot.att-P{background:var(--present)}
.att-dot.att-K{background:var(--late)}
.att-dot.att-O{background:var(--absent)}
.att-dot.att-I{background:var(--ink-faint)}

/* Klikabilne statistike na pocetnoj */
.stat.tappable{cursor:pointer;position:relative;-webkit-tap-highlight-color:transparent;transition:transform .08s,box-shadow .12s}
.stat.tappable:active{transform:scale(.97)}
.stat.tappable::after{content:"�a";position:absolute;top:8px;right:10px;color:var(--ink-faint);font-size:16px;font-weight:800;line-height:1}
.stat.tappable:focus-visible{outline:2px solid var(--accent);outline-offset:2px}

/* Matrica placanja */
.matrix-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:12px;background:var(--paper)}
table.matrix{border-collapse:separate;border-spacing:0;width:100