/* ===========================================================
   LIGA PAUPER · COUNTER GAMING HOUSE — "Standings Oficial"
   Sistema visual: documento de torneio impresso sobre a mesa
   =========================================================== */
:root{
  --sheet:#e9e3d2; --sheet2:#e2dbc6; --ink:#211d15; --ink2:#544d3c; --faint:#8d8470;
  --line:#211d15; --hair:rgba(33,29,21,.4); --red:#b42318; --redink:#a51f15;
  --hl:#f3e8b0; --green:#1d6a32; --desk:#272019;
  --W:#e7d98f; --U:#2f6fb0; --B:#473f54; --R:#b42318; --G:#3f8a52; --C:#9a9286;
  --pad:64px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:"Spline Sans Mono",monospace;color:var(--ink);
  background:
    radial-gradient(120% 90% at 50% -10%, #342c22, transparent 60%),
    repeating-linear-gradient(91deg, rgba(0,0,0,.10) 0 2px, transparent 2px 7px),
    var(--desk);}
.cond{font-family:"Saira Condensed",sans-serif}
.hand{font-family:"Caveat",cursive}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
input,select{font:inherit;color:inherit}

/* ---- SHEET / SHELL ---- */
.app{width:min(1240px,100%);margin:0 auto;min-height:100vh;position:relative;
  background:linear-gradient(180deg,#ece6d6,#e3dcc8);
  box-shadow:0 0 0 1px rgba(0,0,0,.15),0 40px 90px rgba(0,0,0,.45);}
.app::after{content:"";position:absolute;inset:0;pointer-events:none;mix-blend-mode:multiply;opacity:.5;z-index:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E")}
.feed{position:absolute;top:0;bottom:0;width:30px;display:flex;flex-direction:column;justify-content:space-around;padding:18px 0;z-index:1}
.feed.l{left:12px}.feed.r{right:12px}
.feed b{width:13px;height:13px;border-radius:50%;background:#d6ccb2;box-shadow:inset 0 1px 2px rgba(0,0,0,.45);margin:0 auto;border:1px solid rgba(0,0,0,.12)}
.inner{position:relative;z-index:2;padding:0 var(--pad)}

/* ---- TOP BAR / NAV ---- */
.topbar{position:sticky;top:0;z-index:30;background:var(--ink);color:var(--sheet);
  display:flex;align-items:stretch;justify-content:space-between;gap:16px;padding:0 var(--pad);
  box-shadow:0 3px 0 var(--red),0 8px 18px rgba(0,0,0,.4)}
.brand{display:flex;align-items:center;gap:12px;padding:11px 0}
.brand .mk{width:34px;height:34px;border:2px solid var(--sheet);border-radius:50%;display:grid;place-items:center;
  font-family:"Saira Condensed";font-weight:900;font-size:19px;flex:none}
.brand .bt{line-height:1}
.brand .bt .a{font-family:"Saira Condensed";font-weight:900;font-size:19px;letter-spacing:.02em;text-transform:uppercase}
.brand .bt .b{font-size:10px;letter-spacing:.18em;color:#b7ad96;text-transform:uppercase;margin-top:2px}
.nav{display:flex;align-items:stretch}
.nav button{padding:0 20px;font-family:"Saira Condensed";font-weight:700;font-size:16px;letter-spacing:.04em;text-transform:uppercase;
  color:#b7ad96;border-bottom:4px solid transparent;transition:color .12s,border-color .12s;white-space:nowrap}
.nav button:hover{color:var(--sheet)}
.nav button.on{color:#fff;border-bottom-color:var(--red)}
.nav button.admin{color:#ffb4ac}
.nav button.admin.on{color:#fff;border-bottom-color:var(--red)}
.menu-btn{display:none}

/* ---- DOC MASTHEAD (per screen) ---- */
.mast{padding:32px 0 14px;border-bottom:3px solid var(--ink);position:relative}
.doctop{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;font-size:12px;letter-spacing:.04em;color:var(--ink2);
  text-transform:uppercase;border-bottom:1px dashed var(--ink);padding-bottom:8px;margin-bottom:14px}
.doctop b{color:var(--ink)}
.title-row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap}
h1.doc{font-family:"Saira Condensed";font-weight:900;font-size:clamp(48px,8vw,82px);line-height:.82;letter-spacing:-.01em;text-transform:uppercase}
h1.doc small{display:block;font-size:clamp(15px,2.4vw,21px);font-weight:700;letter-spacing:.34em;color:var(--ink2);margin-bottom:6px}
.stamp{font-family:"Saira Condensed";font-weight:900;text-transform:uppercase;color:var(--red);
  border:3px solid var(--red);border-radius:6px;padding:6px 14px 4px;line-height:.95;text-align:center;
  box-shadow:inset 0 0 0 2px rgba(180,35,24,.25);transform:rotate(-7deg);opacity:.96;flex:none;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='r'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.12' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 2.2 -0.35'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23r)'/%3E%3C/svg%3E");-webkit-mask-size:90px;mask-size:90px}
.stamp .big{font-size:32px}.stamp .sm{font-size:13px;letter-spacing:.2em}
.metarow{display:flex;flex-wrap:wrap;margin-top:18px;border:2px solid var(--ink)}
.metarow .cell{flex:1;min-width:120px;padding:9px 14px;border-right:1px solid var(--ink)}
.metarow .cell:last-child{border-right:none}
.metarow .k{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink2)}
.metarow .v{font-family:"Saira Condensed";font-weight:800;font-size:23px;line-height:1.05;margin-top:2px}
.metarow .v.red{color:var(--red)}
.scrawl{font-family:"Caveat";color:var(--redink);font-weight:700;transform:rotate(-6deg)}

/* ---- ID PHOTO (image-slot wrapper) ---- */
.idphoto{position:relative;display:block;background:#cabf9f;border:1px solid var(--ink);
  box-shadow:0 2px 5px rgba(0,0,0,.3);transform:rotate(var(--tilt,-1.5deg))}
.idphoto::before{content:"";position:absolute;top:-4px;left:50%;transform:translateX(-50%) rotate(8deg);
  width:18px;height:7px;background:linear-gradient(180deg,#b8b2a4,#7d776a);border:1px solid #5a554a;border-radius:1px;z-index:3;
  box-shadow:0 1px 2px rgba(0,0,0,.4)}
.idphoto image-slot{display:block;width:100%;height:100%}

/* ====================== STANDINGS ====================== */
.section-h{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px;margin:24px 0 0}
.section-h h2{font-family:"Saira Condensed";font-weight:900;font-size:24px;text-transform:uppercase;letter-spacing:.02em}
.section-h .leg{font-size:11px;color:var(--ink2);letter-spacing:.03em}

/* podium strip on standings */
.podio{display:grid;grid-template-columns:repeat(3,1fr);margin:14px 0 8px;border:2px solid var(--ink)}
.pp{padding:14px 16px;border-right:2px solid var(--ink);position:relative;display:flex;gap:14px;align-items:flex-start;min-height:118px}
.pp>div{padding-right:46px}
.pp:last-child{border-right:none}
.pp.one{background:repeating-linear-gradient(45deg,rgba(180,35,24,.07) 0 10px,transparent 10px 20px)}
.pp .ph{width:72px;height:72px;flex:none}
.pp .medal{position:absolute;top:12px;right:14px;width:40px;height:40px;border-radius:50%;border:3px solid var(--ink);
  display:grid;place-items:center;font-family:"Saira Condensed";font-weight:900;font-size:20px;background:var(--sheet)}
.pp.one .medal{border-color:var(--red);color:var(--red)}
.pp .ttl{font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink2)}
.pp .nm{font-family:"Saira Condensed";font-weight:900;font-size:22px;line-height:.95;margin-top:3px;text-transform:uppercase;overflow-wrap:anywhere}
.pp.one .nm{color:var(--red)}
.pp .meta{font-size:11px;color:var(--ink2);margin-top:5px}
.pp .rec{font-family:"Saira Condensed";font-weight:800;font-size:17px;margin-top:6px}
.pp .rec .pts{color:var(--red)}

.grid-h,.st-row{display:grid;grid-template-columns:50px 48px 1fr 116px 96px 78px 64px;align-items:center;gap:12px}
.grid-h{padding:8px 10px;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);margin-top:10px;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--ink2)}
.grid-h .c{text-align:center}.grid-h .rt{text-align:right}
.st-row{padding:8px 10px;border-bottom:1px dashed var(--hair);position:relative;cursor:pointer;transition:background .1s}
.st-row:nth-child(even){background:rgba(33,29,21,.035)}
.st-row:hover{background:rgba(33,29,21,.07)}
.st-row.lead{background:repeating-linear-gradient(45deg,rgba(180,35,24,.08) 0 12px,transparent 12px 24px);border-top:2px solid var(--red);border-bottom:2px solid var(--red)}
.st-row.me{background:var(--hl);box-shadow:inset 4px 0 0 var(--ink)}
.st-row .pos{font-family:"Saira Condensed";font-weight:900;font-size:28px;text-align:center;line-height:.9}
.st-row.lead .pos{color:var(--red)}
.st-row .ph{width:48px;height:48px}
.plr{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}
.plr .h{font-family:"Saira Condensed";font-weight:800;font-size:22px;text-transform:uppercase;line-height:.95}
.plr .real{font-size:11px;color:var(--ink2)}
.plr .dk{font-size:10px;letter-spacing:.04em;color:var(--ink);border:1px solid var(--ink);padding:1px 6px;text-transform:uppercase;white-space:nowrap}
.ci{display:inline-flex;gap:3px;align-items:center;vertical-align:middle}
.mana{display:inline-block;vertical-align:middle;filter:drop-shadow(0 1px 0 rgba(0,0,0,.18))}
.rec{font-family:"Saira Condensed";font-weight:800;font-size:20px;text-align:center;letter-spacing:.02em}
.rec .v{color:var(--green)}.rec .d{color:var(--red)}.rec s{opacity:.4;text-decoration:none}
.apr{display:flex;align-items:center;gap:8px}
.apr .bar{flex:1;height:9px;border:1px solid var(--ink);position:relative;min-width:40px}
.apr .bar i{position:absolute;inset:0;background:repeating-linear-gradient(90deg,var(--ink) 0 2px,transparent 2px 4px)}
.apr .v{font-weight:700;font-size:13px;width:34px;text-align:right}
.seq{font-size:14px;font-weight:700;text-align:center}
.seq .w{color:var(--green)}.seq .l{color:var(--red)}
.pts{font-family:"Saira Condensed";font-weight:900;font-size:28px;text-align:right;line-height:.9}
.st-row .lblk{display:none;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2)}

/* ---- footer ---- */
.foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin:26px 0 36px;padding-top:16px;border-top:3px solid var(--ink)}
.sign{font-size:12px;color:var(--ink2)}
.sign .line{width:min(240px,60vw);border-bottom:1px solid var(--ink);margin-bottom:5px;height:34px;position:relative}
.sign .line .sg{position:absolute;left:14px;bottom:2px;font-family:"Caveat";font-size:30px;color:var(--ink);transform:rotate(-3deg)}
.barcode{display:flex;gap:2px;align-items:flex-end;height:42px}
.barcode b{width:3px;background:var(--ink)}
.docno{text-align:right;font-size:11px;color:var(--ink2);line-height:1.7}
.docno b{font-family:"Saira Condensed";font-weight:800;font-size:18px;color:var(--ink)}

/* ====================== PÓDIO ====================== */
.podium-screen{padding-top:8px}
.pod-grid{display:grid;grid-template-columns:1fr 1.25fr 1fr;align-items:end;gap:22px;margin:30px 0 10px}
.pod-card{border:2px solid var(--ink);background:var(--sheet);position:relative;padding:18px;text-align:center}
.pod-card.c1{border-color:var(--red);border-width:3px;background:repeating-linear-gradient(45deg,rgba(180,35,24,.06) 0 14px,transparent 14px 28px)}
.pod-card .place{font-family:"Saira Condensed";font-weight:900;font-size:18px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2)}
.pod-card.c1 .place{color:var(--red)}
.pod-photo{width:100%;aspect-ratio:1/1;margin:12px auto;max-width:300px}
.pod-card.c1 .pod-photo{max-width:360px}
.pod-card .ttl{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink2)}
.pod-card .nm{font-family:"Saira Condensed";font-weight:900;font-size:clamp(26px,3vw,40px);line-height:.92;text-transform:uppercase;margin-top:4px}
.pod-card.c1 .nm{color:var(--red)}
.pod-card .real{font-size:13px;color:var(--ink2);margin-top:4px}
.pod-card .deck{display:inline-block;font-size:11px;border:1px solid var(--ink);padding:2px 9px;text-transform:uppercase;margin-top:9px}
.pod-stats{display:flex;justify-content:center;gap:18px;margin-top:14px;padding-top:12px;border-top:1px solid var(--hair)}
.pod-stats div b{display:block;font-family:"Saira Condensed";font-weight:900;font-size:26px;line-height:1}
.pod-stats div.v b{color:var(--green)}.pod-stats div.d b{color:var(--red)}.pod-stats div.p b{color:var(--ink)}
.pod-stats div small{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2)}
.crown-stamp{position:absolute;top:-18px;left:50%;transform:translateX(-50%) rotate(-4deg);
  font-family:"Saira Condensed";font-weight:900;font-size:14px;letter-spacing:.1em;color:#fff;background:var(--red);padding:4px 14px;text-transform:uppercase;z-index:4;box-shadow:0 4px 10px rgba(0,0,0,.35)}
.honor{margin:26px 0 36px}
.honor-row{display:flex;gap:16px;align-items:center;padding:12px 14px;border-bottom:1px dashed var(--hair);flex-wrap:wrap}
.honor-row .ph{width:56px;height:56px;flex:none}
.honor-row .lbl{font-family:"Saira Condensed";font-weight:800;font-size:16px;text-transform:uppercase;min-width:150px}
.honor-row .desc{font-size:13px;color:var(--ink2);flex:1;min-width:160px}
.honor-row .val{font-family:"Saira Condensed";font-weight:900;font-size:22px}

/* ====================== ADMIN ====================== */
.admin-grid{display:grid;grid-template-columns:1fr;gap:24px;margin:22px 0 36px}
.panel{border:2px solid var(--ink);background:rgba(255,255,255,.35);padding:0}
.panel .ph2{background:var(--ink);color:var(--sheet);font-family:"Saira Condensed";font-weight:800;font-size:17px;
  text-transform:uppercase;letter-spacing:.04em;padding:9px 16px;display:flex;justify-content:space-between;align-items:center}
.panel .pb{padding:16px}
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.field label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);font-weight:600}
.field input,.field select{border:2px solid var(--ink);background:var(--sheet);padding:9px 11px;font-family:"Spline Sans Mono";font-size:14px}
.field input:focus,.field select:focus{outline:2px solid var(--red);outline-offset:-1px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.entry{display:grid;grid-template-columns:42px 1fr repeat(3,64px) 70px 30px;align-items:center;gap:10px;padding:7px 8px;border-bottom:1px dashed var(--hair)}
.entry .ph{width:40px;height:40px}
.entry .nm{font-family:"Saira Condensed";font-weight:800;font-size:17px;text-transform:uppercase;line-height:1}
.entry .nm small{display:block;font-family:"Spline Sans Mono";font-weight:400;font-size:10px;color:var(--ink2);text-transform:none;letter-spacing:0}
.step{display:flex;align-items:center;border:2px solid var(--ink);background:var(--sheet)}
.step button{width:26px;height:32px;font-family:"Saira Condensed";font-weight:900;font-size:18px;line-height:1}
.step button:hover{background:var(--ink);color:var(--sheet)}
.step input{width:34px;text-align:center;border:none;border-left:2px solid var(--ink);border-right:2px solid var(--ink);background:transparent;height:32px;font-weight:700;font-size:15px}
.step.v{border-color:var(--green)}.step.v input{border-color:var(--green)}
.step.d{border-color:var(--red)}.step.d input{border-color:var(--red)}
.entry .ept{font-family:"Saira Condensed";font-weight:900;font-size:22px;text-align:center;color:var(--red)}
.entry .clr{color:var(--faint)}
.btn{font-family:"Saira Condensed";font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.05em;
  background:var(--ink);color:var(--sheet);padding:11px 22px;border:2px solid var(--ink);transition:background .12s}
.btn:hover{background:var(--red);border-color:var(--red)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--sheet)}
.btn.red{background:var(--red);border-color:var(--red)}
.admin-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:8px}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:60;background:var(--ink);color:var(--sheet);
  padding:14px 22px;font-family:"Saira Condensed";font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:.04em;
  box-shadow:0 10px 30px rgba(0,0,0,.5);border-left:5px solid var(--red);animation:tin .3s ease}
@keyframes tin{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}
.hint{font-size:12px;color:var(--ink2);line-height:1.5}
.hint b{color:var(--ink)}

/* ====================== HISTÓRICO ====================== */
.hist{margin:24px 0 36px}
.cert{display:grid;grid-template-columns:54px 1fr auto;gap:18px;align-items:center;border:2px solid var(--ink);background:var(--sheet);
  padding:16px 18px;margin-bottom:14px;position:relative;transition:transform .12s}
.cert:hover{transform:translateX(4px)}
.cert .seal{width:54px;height:54px;border-radius:50%;border:3px solid var(--ink);display:grid;place-items:center;
  font-family:"Saira Condensed";font-weight:900;font-size:18px;line-height:.9;text-align:center}
.cert.latest{border-color:var(--red)}
.cert.latest .seal{border-color:var(--red);color:var(--red)}
.cert .when{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2)}
.cert .champ{font-family:"Saira Condensed";font-weight:900;font-size:28px;text-transform:uppercase;line-height:.95;margin-top:2px}
.cert .sub{font-size:12px;color:var(--ink2);margin-top:4px}
.cert .right{text-align:right}
.cert .right .pts{font-family:"Saira Condensed";font-weight:900;font-size:30px;line-height:.9}
.cert .right small{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2)}

/* detail drawer */
.drawer-bg{position:fixed;inset:0;background:rgba(20,16,10,.55);z-index:50;display:flex;justify-content:flex-end;animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.drawer{width:min(440px,100%);height:100%;background:linear-gradient(180deg,#ece6d6,#e3dcc8);box-shadow:-20px 0 60px rgba(0,0,0,.5);
  overflow:auto;padding:26px;position:relative;animation:slidein .25s ease}
@keyframes slidein{from{transform:translateX(40px);opacity:.5}to{transform:translateX(0);opacity:1}}
.drawer .x{position:absolute;top:18px;right:18px;font-family:"Saira Condensed";font-weight:900;font-size:22px;width:34px;height:34px;border:2px solid var(--ink)}
.drawer .x:hover{background:var(--ink);color:var(--sheet)}
.drawer .dphoto{width:150px;height:150px;margin-bottom:14px}
.drawer .dh{font-family:"Saira Condensed";font-weight:900;font-size:34px;text-transform:uppercase;line-height:.95}
.drawer .dr{font-size:13px;color:var(--ink2);margin-top:4px}
.bigstat{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin:18px 0;border:2px solid var(--ink)}
.bigstat .s{padding:12px 6px;text-align:center;border-right:1px solid var(--ink)}
.bigstat .s:last-child{border-right:none}
.bigstat .s b{display:block;font-family:"Saira Condensed";font-weight:900;font-size:30px;line-height:1}
.bigstat .s.v b{color:var(--green)}.bigstat .s.d b{color:var(--red)}
.bigstat .s small{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink2)}

/* ====================== RESPONSIVE ====================== */
@media (max-width:880px){
  :root{--pad:20px}
  .feed{display:none}
  .nav{display:none;position:absolute;top:100%;right:0;left:0;flex-direction:column;background:var(--ink);box-shadow:0 18px 30px rgba(0,0,0,.5)}
  .nav.open{display:flex}
  .nav button{padding:14px 22px;border-bottom:1px solid rgba(255,255,255,.12);text-align:left}
  .nav button.on{border-bottom-color:rgba(255,255,255,.12);border-left:4px solid var(--red)}
  .menu-btn{display:grid;place-items:center;font-family:"Saira Condensed";font-weight:800;font-size:15px;color:var(--sheet);padding:0 4px;text-transform:uppercase}
  .pod-grid{grid-template-columns:1fr;gap:16px}
  .pod-card{order:2}.pod-card.c1{order:1}
  .pod-photo,.pod-card.c1 .pod-photo{max-width:240px}
  .podio{grid-template-columns:1fr}
  .pp{border-right:none;border-bottom:2px solid var(--ink)}.pp:last-child{border-bottom:none}
  /* standings → stacked cards */
  .grid-h{display:none}
  .st-row{grid-template-columns:44px 46px 1fr auto;grid-template-areas:"pos ph plr pts" "pos ph rec rec" "pos ph apr apr";row-gap:6px;padding:12px 8px}
  .st-row .pos{grid-area:pos}.st-row .ph{grid-area:ph}.plr{grid-area:plr}
  .st-row .rec{grid-area:rec;text-align:left}.st-row .apr{grid-area:apr}
  .st-row .pts{grid-area:pts}.st-row .seq{display:none}
  .st-row .lblk{display:inline}
  .row2{grid-template-columns:1fr}
  .entry{grid-template-columns:34px 1fr;grid-template-areas:"ph nm" "we we" "pt pt";row-gap:8px;border-bottom:2px solid var(--hair);padding:10px 6px}
  .entry .ph{grid-area:ph}.entry .nm{grid-area:nm}
}

/* ===========================================================
   ADIÇÕES DO SISTEMA REAL (auth, foto real, conta) — CGH
   =========================================================== */
.loading{display:grid;place-items:center;min-height:70vh;color:var(--sheet);
  font-family:"Saira Condensed";font-weight:800;font-size:22px;text-transform:uppercase;letter-spacing:.06em}

/* foto real dentro do quadro grampeado (substitui o web-component) */
.idphoto img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1;user-select:none}
.idphoto .photo-edit{position:absolute;left:0;right:0;bottom:0;z-index:4;text-align:center;
  font-family:"Saira Condensed";font-weight:800;font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:#fff;background:rgba(33,29,21,.78);padding:2px 0;opacity:0;transition:opacity .12s}
.idphoto:hover .photo-edit{opacity:1}

/* barra de conta no topbar */
.authbar{display:flex;align-items:center;gap:10px;padding:0 14px}
.authbar .who{font-size:12px;color:#b7ad96;letter-spacing:.02em;white-space:nowrap}
.authbar .link{color:#b7ad96;font-family:"Saira Condensed";font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.04em}
.authbar .link:hover{color:#fff}
.authbar .join{font-family:"Saira Condensed";font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.04em;
  color:#fff;background:var(--red);padding:7px 12px;border:1px solid var(--red);white-space:nowrap}
.authbar .join:hover{filter:brightness(1.12)}

/* modal de autenticação (reusa .drawer-bg) */
.auth-card{position:relative;width:min(460px,94vw);max-height:92vh;overflow:auto;
  background:linear-gradient(180deg,#ece6d6,#e3dcc8);border:3px solid var(--ink);
  box-shadow:0 30px 80px rgba(0,0,0,.55);animation:slidein .22s ease}
.auth-card .x{position:absolute;top:12px;right:12px;font-family:"Saira Condensed";font-weight:900;font-size:20px;
  width:32px;height:32px;border:2px solid var(--ink);z-index:2}
.auth-card .x:hover{background:var(--ink);color:var(--sheet)}
.auth-tabs{display:flex;border-bottom:2px solid var(--ink)}
.auth-tabs button{flex:1;padding:16px 0;font-family:"Saira Condensed";font-weight:900;font-size:18px;text-transform:uppercase;
  letter-spacing:.04em;color:var(--ink2);border-bottom:4px solid transparent}
.auth-tabs button.on{color:var(--ink);border-bottom-color:var(--red);background:rgba(180,35,24,.06)}
.auth-err{background:rgba(180,35,24,.12);border-left:4px solid var(--red);color:var(--redink);
  font-size:13px;padding:9px 12px;margin-bottom:12px}
/* o conteúdo do formulário (login/cadastro) precisa de respiro — antes ficava sem margem */
.auth-card .pb{padding:22px 24px 26px}
.auth-card .auth-tabs+.pb{padding-top:20px}
.auth-card .field{margin-bottom:16px}

/* ====================== SELETOR DE CORES (identidade) ===================== */
.colorpick{display:flex;flex-wrap:nowrap;gap:6px;margin-top:2px}
.cpick{flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;gap:5px;padding:9px 2px 7px;
  border:2px solid var(--hair);background:var(--sheet);cursor:pointer;transition:border-color .12s,background .12s,transform .08s}
.cpick .mana{opacity:.4;filter:grayscale(1) drop-shadow(0 1px 0 rgba(0,0,0,.15));transition:opacity .12s,filter .12s}
.cpick span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  font-size:9.5px;letter-spacing:.02em;text-transform:uppercase;color:var(--ink2);font-weight:600}
.cpick:hover{border-color:var(--ink)}
.cpick.on{border-color:var(--ink);background:#fff;box-shadow:inset 0 0 0 1px var(--ink),0 2px 0 rgba(0,0,0,.12)}
.cpick.on .mana{opacity:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}
.cpick.on span{color:var(--ink)}
.adm-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink2);
  border:2px solid var(--ink);background:var(--sheet);padding:9px 11px;cursor:pointer}
.adm-check input{width:16px;height:16px;accent-color:var(--red)}

/* ====================== GESTÃO DE JOGADORES (admin) ====================== */
.userlist{border:1px solid var(--hair)}
.urow{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:12px;
  padding:9px 10px;border-bottom:1px dashed var(--hair)}
.urow:last-child{border-bottom:none}
.urow.is-pending{background:rgba(180,35,24,.07);box-shadow:inset 4px 0 0 var(--red)}
.urow.is-blocked{opacity:.62}
.urow .ph{width:42px;height:42px}
.uinfo{min-width:0}
.uhead{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.uhead b{font-family:"Saira Condensed";font-weight:800;font-size:17px;text-transform:uppercase;line-height:1}
.uinfo small{display:block;font-size:11px;color:var(--ink2);margin-top:2px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ubadge{font-size:10px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;
  padding:1px 7px;border:1px solid var(--ink);line-height:1.5}
.ubadge.pend{color:var(--red);border-color:var(--red);background:rgba(180,35,24,.1)}
.ubadge.act{color:var(--green);border-color:var(--green)}
.ubadge.blk{color:var(--ink2)}
.ubadge.adm{color:#fff;background:var(--ink);border-color:var(--ink)}
.uacts{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.ubtn{font-family:"Saira Condensed";font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.04em;
  padding:6px 11px;border:2px solid var(--ink);background:var(--sheet);cursor:pointer;transition:background .12s,color .12s}
.ubtn:hover{background:var(--ink);color:var(--sheet)}
.ubtn.ok{border-color:var(--green);color:var(--green)}
.ubtn.ok:hover{background:var(--green);color:#fff}
.ubtn.danger{border-color:var(--red);color:var(--red)}
.ubtn.danger:hover{background:var(--red);color:#fff}
.ubtn:disabled{opacity:.45;cursor:default}
.ubtn:disabled:hover{background:var(--sheet);color:var(--ink)}

/* aviso de conta pendente */
.pending-note{border:2px solid var(--red);background:rgba(180,35,24,.08);color:var(--ink);
  padding:13px 16px;margin:18px 0 4px;font-size:13px;line-height:1.5}
.pending-note b{color:var(--redink)}

@media (max-width:680px){
  .urow{grid-template-columns:38px 1fr;grid-template-areas:"ph info" "acts acts";row-gap:8px}
  .urow .ph{grid-area:ph}.uinfo{grid-area:info}.uacts{grid-area:acts;justify-content:flex-start}
}

@media (max-width:880px){
  .authbar{flex-wrap:wrap;padding:12px 22px;gap:12px;border-top:1px solid rgba(255,255,255,.12)}
  .authbar .join{padding:10px 14px}
}

/* ====================== CROPPER 1:1 (upload de foto) ====================== */
.crop-bg{position:fixed;inset:0;z-index:120;background:rgba(20,17,12,.72);
  display:grid;place-items:center;padding:20px;animation:fade .16s ease}
.crop-box{width:min(360px,94vw);background:linear-gradient(180deg,#ece6d6,#e3dcc8);
  border:3px solid var(--ink);box-shadow:0 30px 80px rgba(0,0,0,.55);padding:18px;animation:slidein .2s ease}
.crop-title{font-family:"Saira Condensed";font-weight:900;font-size:18px;text-transform:uppercase;
  letter-spacing:.04em;color:var(--ink);margin-bottom:12px}
.crop-view{position:relative;margin:0 auto;overflow:hidden;background:#2b2620;border:2px solid var(--ink);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.08);cursor:grab;touch-action:none;user-select:none}
.crop-view:active{cursor:grabbing}
.crop-view img{pointer-events:none}
/* grade-guia 3x3 (regra dos terços) por cima do recorte */
.crop-grid{position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.28),rgba(255,255,255,.28)) 33.33% 0/1px 100% no-repeat,
    linear-gradient(rgba(255,255,255,.28),rgba(255,255,255,.28)) 66.66% 0/1px 100% no-repeat,
    linear-gradient(rgba(255,255,255,.28),rgba(255,255,255,.28)) 0 33.33%/100% 1px no-repeat,
    linear-gradient(rgba(255,255,255,.28),rgba(255,255,255,.28)) 0 66.66%/100% 1px no-repeat;
  box-shadow:inset 0 0 0 9999px rgba(0,0,0,0)}
.crop-zoom{display:flex;align-items:center;gap:10px;margin:14px 2px 4px;
  font-family:"Saira Condensed";font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink2)}
.crop-zoom input[type=range]{flex:1;accent-color:var(--red)}
.crop-actions{display:flex;justify-content:flex-end;align-items:center;gap:14px;margin-top:8px}
.crop-actions .link{color:var(--ink2);font-family:"Saira Condensed";font-weight:700;font-size:14px;
  text-transform:uppercase;letter-spacing:.04em}
.crop-actions .link:hover{color:var(--ink)}
.crop-actions .join{font-family:"Saira Condensed";font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.04em;
  color:#fff;background:var(--red);padding:8px 16px;border:1px solid var(--red)}
.crop-actions .join:hover{filter:brightness(1.12)}
.crop-actions button:disabled{opacity:.5;cursor:default}
.crop-hint{margin-top:10px;font-size:11px;color:var(--ink2);font-family:"Spline Sans Mono";line-height:1.4}
