/* ===== FEIFER — zákaznická administrace (navazuje na hala.css) ===== */
/* Sticky footer: stránka roztažená na výšku viewportu, obsah (.acc) vyplní zbytek,
   footer tak sedí vždy dole (admin.css se načítá jen na /ucet). */
.A { min-height:100vh; display:flex; flex-direction:column; }
/* width:100% je nutné: .wrap má margin:0 auto a auto cross-margin ve flexu
   vypíná stretch → bez toho se obsah smršťoval na šířku obsahu. */
.A > .acc { flex:1; width:100%; }
.acc { display:grid; grid-template-columns:260px 1fr; gap:0; min-height:70vh; }
.acc__side { border-right:1px solid var(--line); background:var(--char-2); padding:22px 0; }
body.light .acc__side { background:#fff; }
.acc__who { padding:0 22px 20px; border-bottom:1px solid var(--line); margin-bottom:14px; }
.acc__who .ico { width:46px; height:46px; background:var(--red); color:#fff; display:grid; place-items:center; font-family:var(--exo); font-weight:800; font-size:18px; border-radius:var(--rad-md); }
.acc__who .nm { font-weight:800; font-size:16px; margin-top:12px; }
.acc__who .sub { font-family:var(--mono); font-size:11px; color:var(--faint); margin-top:3px; }
.acc__nav { display:flex; flex-direction:column; }
.acc__nav a { display:flex; align-items:center; gap:12px; margin:2px 12px; padding:11px 12px; font-size:14.5px; font-weight:600; color:var(--mut); border-left:2px solid transparent; border-radius:var(--rad-sm); cursor:pointer; transition:.12s; }
.acc__nav a svg { width:18px; height:18px; flex-shrink:0; }
.acc__nav a:hover { color:#fff; background:var(--char-3); }
body.light .acc__nav a:hover { color:var(--ink); background:var(--char-2); }
.acc__nav a.on { color:var(--red); border-left-color:var(--red); background:var(--char-3); }
body.light .acc__nav a.on { background:var(--char-2); }
.acc__nav a .cnt { margin-left:auto; font-family:var(--mono); font-size:11px; background:var(--char); color:var(--faint); padding:2px 8px; border-radius:999px; }
body.light .acc__nav a .cnt { background:var(--char-2); }
.acc__nav .sep { font-family:var(--mono); font-size:10px; letter-spacing:.08em; color:var(--faint); text-transform:uppercase; padding:18px 22px 8px; }
.acc__main { padding:30px 34px 50px; min-width:0; }
.acc__logout { margin:14px 22px 0; }

/* page header */
.accp__head { display:flex; align-items:flex-end; justify-content:space-between; gap:18px; margin-bottom:24px; flex-wrap:wrap; }
.accp__eyebrow { font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--red); text-transform:uppercase; }
.accp__head h1 { font-size:30px; font-weight:800; text-transform:uppercase; margin-top:7px; }
.accp__head p { color:var(--mut); font-size:14px; margin-top:6px; }

.acc__sec { display:none; }
.acc__sec.on { display:block; animation:accIn .2s ease; }
@keyframes accIn { from{opacity:0;transform:translateY(6px);} to{opacity:1;transform:none;} }

/* stat cards */
.acc__stats { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
/* points hero */
.pts__hero { position:relative; overflow:hidden; display:grid; grid-template-columns:auto 1.3fr 1fr; gap:30px; align-items:center; background:#0f1014; border:1px solid var(--line); padding:28px 30px; border-radius:var(--rad-lg); }
body.light .pts__hero { background:#1d1f25; }
.pts__hero__bp { position:absolute; inset:0; background:none; }
.pts__hero > *:not(.pts__hero__bp) { position:relative; }
.pts__hero .pts__ring { background:conic-gradient(var(--red) calc(var(--p,62)*1%), rgba(255,255,255,.14) 0); }
.pts__hero .pts__ring::before, body.light .pts__hero .pts__ring::before { background:#16171c; }
.pts__hero .pts__ring b, .pts__hero .pts__ring span { color:#fff; }
.pts__lvl__tag { display:inline-flex; font-family:var(--mono); font-size:10.5px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:#fff; background:var(--red); padding:5px 10px; border-radius:var(--rad-xs); }
.pts__hero__main h3 { color:#fff; font-size:24px; font-weight:900; text-transform:uppercase; margin-top:12px; }
.pts__hero__main p { color:#c7cbd2; font-size:14px; line-height:1.6; margin-top:8px; }
.pts__hero__main p b { color:#fff; }
.pts__ladder { margin-top:18px; }
.pts__ladder__bar { height:7px; background:rgba(255,255,255,.14); overflow:hidden; border-radius:999px; }
.pts__ladder__bar i { display:block; height:100%; background:linear-gradient(90deg,var(--red),#ff5a45); }
.pts__ladder__steps { display:flex; justify-content:space-between; margin-top:10px; }
.pts__ladder__steps .step b { display:block; font-size:12px; font-weight:700; text-transform:uppercase; color:#7a808a; }
.pts__ladder__steps .step span { font-family:var(--mono); font-size:10.5px; color:#7a808a; }
.pts__ladder__steps .step.done b, .pts__ladder__steps .step.act b { color:#fff; }
.pts__ladder__steps .step.act b { color:var(--red); }
.pts__perks { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); padding:18px 20px; border-radius:var(--rad-md); }
.pts__perks__lab { font-family:var(--mono); font-size:10.5px; letter-spacing:.05em; text-transform:uppercase; color:#9aa1ad; margin-bottom:12px; }
.pts__perks .perk { display:flex; align-items:flex-start; gap:9px; color:#dfe3e8; font-size:13px; line-height:1.45; margin-top:8px; }
.pts__perks .perk:first-of-type { margin-top:0; }
.pts__perks .perk svg { color:var(--red); flex-shrink:0; margin-top:2px; }
.reward .r-ic { width:42px; height:42px; margin:0 auto 10px; border:1px solid var(--red); color:var(--red); display:grid; place-items:center; border-radius:var(--rad-sm); }
.reward.is-locked { opacity:.85; }
.reward .r-prog { height:5px; background:var(--char-3); margin:0 0 10px; overflow:hidden; border-radius:999px; }
body.light .reward .r-prog { background:#e3e4e8; }
.reward .r-prog i { display:block; height:100%; background:var(--red); }
@media (max-width:980px){ .pts__hero { grid-template-columns:1fr; } .pts__ring { margin:0 auto; } }

/* dashboard hero */
.acc__hero { position:relative; overflow:hidden; display:grid; grid-template-columns:1.5fr 1fr; gap:24px; background:#0f1014; border:1px solid var(--line); padding:30px 32px; margin-bottom:16px; border-radius:var(--rad-lg); }
body.light .acc__hero { background:#1d1f25; }
.acc__hero__bp { position:absolute; inset:0; background:none; }
.acc__hero__bp::after { content:""; position:absolute; inset:0; background-image:none; background-size:30px 30px; mask-image:radial-gradient(120% 100% at 80% 20%,#000 30%,transparent 80%); }
.acc__hero__l { position:relative; z-index:1; }
.acc__hero__eyebrow { display:inline-flex; font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:#fff; background:var(--red); padding:6px 12px; border-radius:var(--rad-xs); }
.acc__hero__l h1 { color:#fff; font-size:32px; font-weight:900; text-transform:uppercase; letter-spacing:-.01em; margin:14px 0 0; }
.acc__hero__l p { color:#c7cbd2; font-size:14.5px; line-height:1.6; margin:10px 0 0; max-width:46ch; }
.acc__hero__l p b { color:#fff; }
.acc__hero__cta { display:flex; gap:12px; margin-top:20px; flex-wrap:wrap; }
.acc__btn--ghost { border:1px solid rgba(255,255,255,.3); color:#fff; background:transparent; }
.acc__btn--ghost:hover { background:rgba(255,255,255,.1); }
.acc__hero__credit { position:relative; z-index:1; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); padding:22px; display:flex; flex-direction:column; justify-content:center; border-radius:var(--rad-md); }
.acc__hero__credit__lab { font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:#e5e8ec; }
.acc__hero__credit__val { font-size:34px; font-weight:900; font-style:italic; color:#27b169; line-height:1; margin-top:8px; }
.acc__credit__bar { height:7px; background:rgba(255,255,255,.12); margin:14px 0 8px; overflow:hidden; border-radius:999px; }
.acc__credit__bar i { display:block; height:100%; background:linear-gradient(90deg,#27b169,#34c878); }
.acc__hero__credit__sub { font-family:var(--mono); font-size:11px; color:#cfd3da; }
/* delivery tracker */
.acc__track { display:flex; align-items:center; gap:20px; border:1px solid var(--line); border-left:3px solid var(--red); background:var(--char-2); padding:18px 22px; margin-top:16px; margin-bottom:16px; border-radius:var(--rad-md); }
body.light .acc__track { background:#fff; }
.acc__track__ic { width:40px; height:40px; flex-shrink:0; background:var(--red); color:#fff; display:grid; place-items:center; border-radius:var(--rad-sm); }
.acc__track__ic svg { width:20px; height:20px; }
.acc__track__info { flex:1; min-width:0; }
.acc__track__lab { font-size:13px; color:var(--mut); margin-bottom:12px; }
.acc__track__lab b { color:var(--ink); font-family:var(--mono); }
body:not(.light) .acc__track__lab b { color:#fff; }
.acc__track__steps { display:flex; align-items:center; gap:0; flex-wrap:wrap; }
.acc__track__steps .st { font-family:var(--mono); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.03em; color:var(--faint); padding:5px 10px; border:1px solid var(--line); white-space:nowrap; border-radius:999px; }
.acc__track__steps .st.done { color:#27b169; border-color:rgba(39,177,105,.4); background:rgba(39,177,105,.08); }
.acc__track__steps .st.act { color:#fff; background:var(--red); border-color:var(--red); }
.acc__track__steps .ln { flex:1; min-width:14px; height:2px; background:var(--line); }
.acc__track__steps .ln.done { background:#27b169; }
.acc__track__meta { text-align:right; flex-shrink:0; }
.acc__track__eta { font-family:var(--mono); font-size:13px; font-weight:700; color:var(--ink); }
body:not(.light) .acc__track__eta { color:#fff; }
.acc__track__lnk { font-size:12.5px; font-weight:700; color:var(--red); }
/* current month chart highlight */
.chart .bar.now { background:linear-gradient(var(--red),var(--red-600)); box-shadow:0 0 0 1px rgba(219,10,10,.3); }
@media (max-width:760px){
  .acc__hero { grid-template-columns:1fr; gap:18px; padding:24px; }
  .acc__hero__l h1 { font-size:26px; }
  .acc__track { flex-wrap:wrap; gap:14px; }
  .acc__track__meta { text-align:left; }
}
.acc__stat { border:1px solid var(--line); border-top:2px solid var(--line); background:var(--char-2); padding:20px; position:relative; overflow:hidden; transition:.18s; border-radius:var(--rad-md); }
.acc__stat:hover { border-top-color:var(--red); transform:translateY(-2px); }
body.light .acc__stat { background:#fff; }
.acc__stat .lab { font-family:var(--mono); font-size:11px; letter-spacing:.04em; text-transform:uppercase; color:var(--faint); }
.acc__stat .val { font-size:30px; font-weight:800; margin-top:10px; line-height:1; }
.acc__stat .val i { color:var(--red); font-style:normal; font-size:18px; }
.acc__stat .dlt { font-size:12px; margin-top:8px; font-weight:600; }
.acc__stat .dlt.up { color:var(--ok); }
.acc__stat .dlt.red { color:var(--red); }
.acc__stat .ic { position:absolute; top:16px; right:16px; color:var(--line); }
.acc__stat .ic svg { width:30px; height:30px; }

/* widgets row */
.acc__row { display:grid; grid-template-columns:1.5fr 1fr; gap:16px; margin-top:16px; }
.acc__card { border:1px solid var(--line); background:var(--char-2); padding:22px; border-radius:var(--rad-lg); }
body.light .acc__card { background:#fff; }
.acc__card h3 { font-size:16px; font-weight:800; text-transform:uppercase; margin-bottom:4px; }
.acc__card .h-sub { font-size:12.5px; color:var(--faint); margin-bottom:18px; font-family:var(--mono); }
.acc__card__head { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.acc__card__head a { font-size:13px; font-weight:700; color:var(--red); }

/* bar chart */
.chart { display:flex; align-items:flex-end; gap:10px; height:170px; padding-top:10px; }
.chart .col { flex:1; display:flex; flex-direction:column; align-items:center; gap:8px; height:100%; justify-content:flex-end; }
.chart .bar { width:100%; max-width:34px; background:linear-gradient(var(--red),var(--red-600)); transition:height .6s cubic-bezier(.2,.8,.2,1); position:relative; border-radius:4px 4px 0 0; }
.chart .bar.muted { background:var(--char-3); }
body.light .chart .bar.muted { background:#dfe2e7; }
.chart .col .m { font-family:var(--mono); font-size:10px; color:var(--faint); }
.chart .col .v { font-family:var(--mono); font-size:10px; color:var(--mut); }

/* points panel */
.pts { display:grid; grid-template-columns:auto 1fr; gap:28px; align-items:center; }
.pts__ring { width:150px; height:150px; border-radius:50%; display:grid; place-items:center; position:relative; flex-shrink:0;
  background:conic-gradient(var(--red) calc(var(--p,62)*1%), var(--char-3) 0); }
body.light .pts__ring { background:conic-gradient(var(--red) calc(var(--p,62)*1%), #e3e4e8 0); }
.pts__ring::before { content:""; position:absolute; inset:14px; border-radius:50%; background:var(--char-2); }
body.light .pts__ring::before { background:#fff; }
.pts__ring b { position:relative; font-size:34px; font-weight:800; }
.pts__ring span { position:relative; font-family:var(--mono); font-size:10px; color:var(--faint); text-transform:uppercase; }
.pts__info h3 { font-size:20px; font-weight:800; text-transform:uppercase; }
.pts__info p { color:var(--mut); font-size:14px; margin-top:8px; line-height:1.55; }
.pts__bar { height:8px; background:var(--char-3); margin-top:16px; position:relative; border-radius:999px; overflow:hidden; }
body.light .pts__bar { background:#e3e4e8; }
.pts__bar i { position:absolute; left:0; top:0; bottom:0; background:var(--red); }
.pts__bar + .lbl { display:flex; justify-content:space-between; font-family:var(--mono); font-size:11px; color:var(--faint); margin-top:7px; }
.rewards { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:18px; }
.reward { border:1px solid var(--line); padding:16px; text-align:center; border-radius:var(--rad-md); }
.reward .r-pts { font-family:var(--mono); font-size:12px; color:var(--red); font-weight:600; }
.reward .r-nm { font-size:14px; font-weight:700; margin:8px 0 12px; }
.reward button { width:100%; height:36px; border:1px solid var(--line); color:var(--mut); font-weight:700; font-size:12.5px; text-transform:uppercase; transition:.15s; border-radius:var(--rad-sm); }
.reward button.ok { background:var(--red); border-color:var(--red); color:#fff; }
.reward button.ok:hover { background:var(--red-600); }

/* tables */
.atable { width:100%; border-collapse:collapse; border:1px solid var(--line); font-size:14px; }
.atable thead th { text-align:left; font-family:var(--mono); font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.04em; color:var(--faint); padding:13px 16px; border-bottom:1px solid var(--line); background:var(--char-2); }
body.light .atable thead th { background:#f7f8fa; }
.atable tbody tr { border-bottom:1px solid var(--line); transition:background .12s; }
.atable tbody tr:hover { background:var(--char-2); }
body.light .atable tbody tr:hover { background:#f7f8fa; }
.atable td { padding:14px 16px; color:#fff; }
body.light .atable td { color:var(--ink); }
.atable td.mono { font-family:var(--mono); font-size:13px; color:var(--mut); }
.atable td .lnk { color:var(--red); font-weight:700; cursor:pointer; }
.atable td.right { text-align:right; font-weight:700; }
.atable td.amt { font-family:var(--mono); font-weight:700; }
.badge2 { display:inline-flex; align-items:center; gap:6px; font-family:var(--mono); font-size:11px; font-weight:600; padding:4px 10px; text-transform:uppercase; letter-spacing:.03em; border-radius:999px; }
.badge2 .d { width:6px; height:6px; border-radius:50%; background:currentColor; }
.b-paid { color:var(--ok); background:rgba(39,177,105,.12); }
.b-unpaid { color:#ff7a5c; background:rgba(255,122,92,.12); }
.b-ship { color:#4ea1ff; background:rgba(78,161,255,.12); }
.b-prep { color:#f5a623; background:rgba(245,166,35,.12); }
.b-done { color:var(--mut); background:var(--char-3); }
body.light .b-done { background:#eceef1; }

/* projects / carts cards */
.acc__grid2 { display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.pcardx { border:1px solid var(--line); background:var(--char-2); padding:20px; border-radius:var(--rad-md); }
body.light .pcardx { background:#fff; }
.pcardx .top { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.pcardx h4 { font-size:16px; font-weight:800; }
.pcardx .meta { font-family:var(--mono); font-size:11px; color:var(--faint); }
.pcardx .desc { color:var(--mut); font-size:13.5px; line-height:1.5; margin-bottom:14px; }
.pcardx .foot { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid var(--line); }
.pcardx .foot .amt { font-weight:800; font-size:16px; }
.pcardx .foot .amt small { font-family:var(--exo); font-weight:400; font-size:11px; color:var(--faint); display:block; }
.miniprog { height:6px; background:var(--char-3); margin:10px 0 14px; position:relative; border-radius:999px; overflow:hidden; }
body.light .miniprog { background:#e3e4e8; }
.miniprog i { position:absolute; left:0; top:0; bottom:0; background:var(--red); }

.acc__btn-sm { display:inline-flex; align-items:center; gap:7px; height:36px; padding:0 14px; font-weight:700; font-size:12.5px; text-transform:uppercase; }

@media (max-width:980px){
  .acc { grid-template-columns:1fr; }
  .acc__side { border-right:none; border-bottom:1px solid var(--line); }
  .acc__stats { grid-template-columns:1fr 1fr; }
  .acc__row { grid-template-columns:1fr; }
  .pts { grid-template-columns:1fr; }
  .acc__grid2 { grid-template-columns:1fr; }
  .atable { display:block; overflow-x:auto; white-space:nowrap; }
}
