/* =========================================================
   BROTAS CLUBE — APP (admin + associado)
   ========================================================= */

:root{
  --bc-army-900:#0f1a14;
  --bc-army-800:#15241b;
  --bc-army-700:#1c3024;
  --bc-army-600:#243d2d;
  --bc-army-500:#2f5038;
  --bc-army-400:#3d6648;
  --bc-army-300:#5a8060;
  --bc-army-200:#a4c4ad;
  --bc-lime-500:#c4e36d;
  --bc-lime-400:#dcf28e;
  --bc-mustard:#d6a847;
  --bc-cream:#f4f1e6;
  --bc-bone:#ece7d4;
  --bc-ink:#0c1410;
  --bc-success:#8fc56a;
  --bc-danger:#c45a3a;
  --bc-info:#5b94c5;
  --bc-warn:#d6a847;

  --font-display:"Bricolage Grotesque","Inter",system-ui,sans-serif;
  --font-body:"Inter",sans-serif;
  --font-mono:"JetBrains Mono",monospace;

  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px; --r-pill:999px;
  --shadow:0 12px 30px -18px rgba(15,26,20,.25);
  --shadow-lg:0 30px 60px -28px rgba(15,26,20,.42);
  --ease-spring:cubic-bezier(.22,1.4,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--font-body);background:var(--bc-cream);color:var(--bc-ink);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:0;border:0}
img,svg{display:block;max-width:100%}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;transition-duration:.001ms !important}
}

/* ----- Splash ----- */
.splash{
  position:fixed;inset:0;background:var(--bc-army-900);
  display:grid;place-items:center;color:var(--bc-cream);z-index:200;
  transition:opacity .4s ease;
}
.splash p{margin-top:1rem;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bc-army-200)}
.splash-mark{
  width:84px;height:84px;border-radius:22px;
  background:linear-gradient(135deg,var(--bc-army-700),var(--bc-army-500));
  display:grid;place-items:center;color:var(--bc-lime-500);
  font-family:var(--font-display);font-weight:800;font-size:2rem;
  box-shadow:0 0 0 0 rgba(196,227,109,.6);
  animation:splashPulse 1.6s var(--ease-spring) infinite;
}
@keyframes splashPulse{
  0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(196,227,109,.4)}
  50%{transform:scale(.96);box-shadow:0 0 0 18px rgba(196,227,109,0)}
}
.splash.hide{opacity:0;pointer-events:none}

/* ----- Common ----- */
.muted{color:var(--bc-army-500)}
.small{font-size:.85rem}
.glass{
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(20px) saturate(140%);
  border:1px solid rgba(15,26,20,.06);
}
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.7rem 1.1rem;border-radius:var(--r-pill);font-weight:600;font-size:.92rem;
  transition:transform .25s var(--ease-spring),background .25s,color .25s,box-shadow .3s;
  white-space:nowrap;
}
.btn:active{transform:scale(.97)}
.btn.big{padding:1rem 1.4rem;font-size:1rem;justify-content:center}
.btn.small{padding:.4rem .8rem;font-size:.82rem}
.btn-primary{background:var(--bc-army-700);color:var(--bc-cream);box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--bc-army-500)}
.btn-ghost{background:rgba(15,26,20,.04);color:var(--bc-army-700);border:1px solid rgba(15,26,20,.08)}
.btn-ghost:hover{background:rgba(15,26,20,.08)}
.btn-pop{background:var(--bc-lime-500);color:var(--bc-army-900)}
.btn-pop:hover{background:var(--bc-lime-400)}
.btn-danger{background:rgba(196,90,58,.12);color:var(--bc-danger)}
.btn-danger:hover{background:var(--bc-danger);color:#fff}

input,select,textarea{
  width:100%;font:inherit;color:var(--bc-ink);
  background:#fff;border:1.5px solid rgba(15,26,20,.1);
  border-radius:14px;padding:.85rem 1rem;
  transition:border-color .25s,box-shadow .25s;
}
input:focus,select:focus,textarea:focus{
  outline:0;border-color:var(--bc-army-500);
  box-shadow:0 0 0 4px rgba(60,102,72,.12);
}
label{display:block;font-size:.85rem;color:var(--bc-army-700);margin-bottom:.5rem;font-weight:500}
label > input,label > select,label > textarea{margin-top:.4rem}

/* ===========================================================
   AUTH (login/register)
   =========================================================== */
.auth-wrap{
  min-height:100vh;display:grid;grid-template-columns:1.05fr 1fr;
  background:
    radial-gradient(800px 500px at 100% 0%,rgba(196,227,109,.4),transparent 60%),
    radial-gradient(700px 500px at -10% 100%,rgba(60,102,72,.15),transparent 60%),
    var(--bc-cream);
}
.auth-card{
  margin:auto;padding:3rem;border-radius:28px;width:min(440px,92vw);
  box-shadow:var(--shadow-lg);
  position:relative;
  animation:authIn .9s var(--ease-spring);
}
@keyframes authIn{from{opacity:0;transform:translateY(20px)}}
.auth-card .brand{display:flex;align-items:center;gap:.55rem;margin-bottom:1.4rem;color:var(--bc-army-800);font-family:var(--font-display);font-weight:700}
.auth-card .brand .mark{
  width:36px;height:36px;border-radius:11px;
  background:linear-gradient(135deg,var(--bc-army-700),var(--bc-army-500));
  color:var(--bc-lime-500);display:grid;place-items:center;font-weight:800
}
.auth-card h1{font-family:var(--font-display);font-size:2rem;letter-spacing:-.02em;color:var(--bc-army-900);margin-bottom:.4rem}
.auth-card .muted{margin-bottom:1.5rem}
.auth-card .form{display:flex;flex-direction:column;gap:.8rem}
.auth-card .alt{position:relative;text-align:center;color:var(--bc-army-300);margin:.4rem 0}
.auth-card .alt::before,.auth-card .alt::after{content:"";position:absolute;top:50%;width:38%;height:1px;background:rgba(15,26,20,.1)}
.auth-card .alt::before{left:0}.auth-card .alt::after{right:0}
.auth-card .alt span{padding:0 .8rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}
.auth-card .row-between{display:flex;justify-content:space-between;align-items:center}
.auth-card .check{display:flex;gap:.4rem;align-items:center;cursor:pointer}
.auth-card .check input{width:auto}
.auth-card .hint{font-size:.85rem;min-height:1em;text-align:center}
.auth-card .hint.error{color:var(--bc-danger)}
.auth-card .hint.success{color:var(--bc-success)}
.auth-card .back-link{position:absolute;top:1.2rem;left:1.4rem;color:var(--bc-army-500);font-size:.85rem}
.auth-card .auth-footer{margin-top:1.5rem;text-align:center;line-height:1.6}
.auth-card .auth-footer code{background:rgba(15,26,20,.06);padding:.05rem .4rem;border-radius:6px;font-size:.78rem}

.tabs{display:flex;gap:.4rem;background:rgba(15,26,20,.05);padding:.3rem;border-radius:var(--r-pill);margin-bottom:1rem}
.tab{flex:1;padding:.6rem 1rem;border-radius:var(--r-pill);font-size:.88rem;color:var(--bc-army-500);transition:all .3s var(--ease-spring)}
.tab.is-active{background:var(--bc-army-700);color:var(--bc-cream);box-shadow:var(--shadow)}

/* Auth side panel */
.auth-side{
  position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--bc-army-700),var(--bc-army-900) 70%);
  color:var(--bc-cream);padding:3rem;
  display:flex;flex-direction:column;justify-content:space-between;gap:2rem;
}
.auth-side .quote h2{font-family:var(--font-display);font-size:2rem;line-height:1.1;letter-spacing:-.02em;max-width:340px}
.auth-side .quote p{margin-top:.6rem;color:var(--bc-army-200)}
.auth-side .big-card{
  position:relative;background:linear-gradient(140deg,var(--bc-army-800),var(--bc-army-500));
  border-radius:24px;padding:1.6rem;border:1px solid rgba(196,227,109,.25);
  box-shadow:var(--shadow-lg);
}
.auth-side .big-card .chip{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(196,227,109,.18);color:var(--bc-lime-400);
  padding:.3rem .7rem;border-radius:var(--r-pill);
  font-family:var(--font-mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.12em
}
.auth-side .card-meta{display:flex;justify-content:space-between;margin-top:2rem}
.auth-side .num{font-family:var(--font-mono);font-size:.85rem;color:var(--bc-lime-400)}
.auth-side .name{font-family:var(--font-display);font-size:1.4rem;line-height:1.1}
.bubbles{position:absolute;inset:0;pointer-events:none}
.bubbles .b{position:absolute;border-radius:50%;filter:blur(0);opacity:.18}
.bubbles .b1{width:200px;height:200px;background:var(--bc-lime-500);top:-40px;right:-40px;animation:floatA 9s ease-in-out infinite}
.bubbles .b2{width:80px;height:80px;background:var(--bc-mustard);top:50%;right:20%;animation:floatA 7s ease-in-out -2s infinite}
.bubbles .b3{width:280px;height:280px;background:var(--bc-army-300);bottom:-100px;left:-60px;opacity:.1;animation:floatA 11s ease-in-out -3s infinite}
@keyframes floatA{50%{transform:translate(20px,-30px)}}

@media (max-width:880px){
  .auth-wrap{grid-template-columns:1fr}
  .auth-side{display:none}
  .auth-card{padding:2rem;margin:1.5rem auto}
}

/* Anim helper */
[data-anim="fade-up"]{opacity:0;transform:translateY(12px);animation:fadeUp .8s var(--ease-spring) forwards}
[data-anim="fade-up"][data-delay="1"]{animation-delay:.08s}
[data-anim="fade-up"][data-delay="2"]{animation-delay:.16s}
[data-anim="fade-up"][data-delay="3"]{animation-delay:.24s}
@keyframes fadeUp{to{opacity:1;transform:none}}

/* ===========================================================
   SHELL (sidebar + main)
   =========================================================== */
.shell{
  display:grid;grid-template-columns:260px 1fr;min-height:100vh;
}
.sidebar{
  background:var(--bc-army-900);color:var(--bc-army-200);
  padding:1.4rem 1rem;display:flex;flex-direction:column;gap:1.4rem;
  position:sticky;top:0;height:100vh;
}
.sidebar .brand{display:flex;align-items:center;gap:.6rem;padding:.4rem .6rem;color:var(--bc-cream);font-family:var(--font-display);font-weight:700}
.sidebar .brand .mark{
  width:36px;height:36px;border-radius:11px;
  background:linear-gradient(135deg,var(--bc-army-700),var(--bc-army-500));
  color:var(--bc-lime-500);display:grid;place-items:center;font-weight:800
}
.sidebar nav{display:flex;flex-direction:column;gap:.2rem;flex:1;overflow:auto}
.sidebar nav a,.sidebar nav button{
  display:flex;align-items:center;gap:.7rem;padding:.7rem .9rem;
  color:var(--bc-army-200);border-radius:12px;font-size:.92rem;
  transition:background .25s,color .25s,transform .25s var(--ease-spring);
}
.sidebar nav a svg{flex-shrink:0;color:var(--bc-army-300)}
.sidebar nav a:hover{background:rgba(196,227,109,.07);color:var(--bc-cream)}
.sidebar nav a.is-active{background:var(--bc-army-700);color:var(--bc-cream);box-shadow:inset 0 0 0 1px rgba(196,227,109,.2)}
.sidebar nav a.is-active svg{color:var(--bc-lime-500)}
.sidebar nav .group{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;color:var(--bc-army-400);text-transform:uppercase;padding:1rem .9rem .4rem}
.side-foot{padding:.5rem;border-top:1px solid var(--bc-army-700);display:flex;flex-direction:column;gap:.8rem}
.user-mini{display:flex;align-items:center;gap:.7rem;padding:.4rem}
.user-mini .avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--bc-army-500),var(--bc-army-300));
  color:var(--bc-army-900);display:grid;place-items:center;font-weight:700;font-family:var(--font-display)
}
.user-mini strong{display:block;color:var(--bc-cream);font-size:.9rem}
.user-mini small{color:var(--bc-army-300);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}

.main{display:flex;flex-direction:column;background:var(--bc-cream);min-height:100vh;min-width:0}
.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
  padding:1rem 2rem;border-bottom:1px solid rgba(15,26,20,.06);
  position:sticky;top:0;background:rgba(244,241,230,.85);backdrop-filter:blur(14px);z-index:10;
}
.search{position:relative;flex:1;max-width:420px}
.search svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--bc-army-500)}
.search input{padding-left:2.6rem;border-radius:var(--r-pill);background:#fff}
.topbar-right{display:flex;gap:.6rem;align-items:center}
.ico-btn{position:relative;width:42px;height:42px;border-radius:14px;background:rgba(15,26,20,.05);display:grid;place-items:center;color:var(--bc-army-700);transition:background .25s}
.ico-btn:hover{background:rgba(15,26,20,.1)}
.ico-btn .dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--bc-lime-500);box-shadow:0 0 0 3px var(--bc-cream)}
.user-chip{padding:.5rem .9rem;border-radius:var(--r-pill);background:rgba(15,26,20,.05);font-size:.85rem;color:var(--bc-army-700)}

.content{padding:2rem;display:flex;flex-direction:column;gap:1.4rem}

/* Breadcrumb / heading */
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;flex-wrap:wrap}
.page-head h1{font-family:var(--font-display);font-size:1.9rem;letter-spacing:-.02em;color:var(--bc-army-900)}
.page-head .breadcrumb{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--bc-army-500)}

/* ===========================================================
   Cards & widgets
   =========================================================== */
.grid{display:grid;gap:1rem}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:1fr 1fr}
@media (max-width:1100px){.grid.cols-4{grid-template-columns:1fr 1fr}.grid.cols-3{grid-template-columns:1fr 1fr}}
@media (max-width:680px){.grid.cols-4,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr}}

.card{
  background:#fff;border-radius:var(--r-lg);padding:1.4rem;
  border:1px solid rgba(15,26,20,.05);
  box-shadow:var(--shadow);
  transition:transform .35s var(--ease-spring),box-shadow .3s;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.card .label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bc-army-500)}
.card .value{font-family:var(--font-display);font-size:2.2rem;color:var(--bc-army-900);letter-spacing:-.02em;margin-top:.4rem}
.card .delta{font-size:.85rem;margin-top:.3rem}
.card .delta.up{color:var(--bc-success)}
.card .delta.down{color:var(--bc-danger)}

.card.dark{background:linear-gradient(160deg,var(--bc-army-700),var(--bc-army-500));color:var(--bc-cream)}
.card.dark .label{color:var(--bc-army-200)}
.card.dark .value{color:var(--bc-cream)}

.chart{
  height:140px;display:flex;align-items:flex-end;gap:6px;
  padding-top:1rem;border-top:1px dashed rgba(15,26,20,.08);
  margin-top:.8rem
}
.chart .bar{flex:1;background:linear-gradient(180deg,var(--bc-lime-500),var(--bc-army-400));border-radius:4px 4px 0 0;transition:transform .4s var(--ease-spring)}
.chart .bar:hover{transform:scaleY(1.05)}

/* Tabela */
.table{width:100%;border-collapse:collapse;font-size:.92rem}
.table th{
  text-align:left;font-family:var(--font-mono);font-size:.72rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--bc-army-500);
  padding:.8rem .8rem;border-bottom:1px solid rgba(15,26,20,.06);
}
.table td{padding:.85rem .8rem;border-bottom:1px solid rgba(15,26,20,.04);vertical-align:middle}
.table tr:hover td{background:rgba(196,227,109,.08)}
.tag{display:inline-flex;padding:.2rem .55rem;border-radius:var(--r-pill);font-size:.72rem;font-weight:600;font-family:var(--font-mono);letter-spacing:.05em}
.tag.green{background:rgba(60,102,72,.12);color:var(--bc-army-700)}
.tag.lime{background:rgba(196,227,109,.4);color:var(--bc-army-900)}
.tag.gray{background:rgba(15,26,20,.06);color:var(--bc-army-500)}
.tag.danger{background:rgba(196,90,58,.12);color:var(--bc-danger)}
.tag.warn{background:rgba(214,168,71,.18);color:#8a6516}

.empty{text-align:center;padding:3rem 1rem;color:var(--bc-army-500)}
.empty h3{font-family:var(--font-display);color:var(--bc-army-700);margin-bottom:.4rem}

/* Carteira do associado */
.wallet{
  border-radius:24px;padding:2rem;color:var(--bc-cream);
  background:
    radial-gradient(700px 300px at 100% -20%,rgba(196,227,109,.45),transparent 60%),
    linear-gradient(160deg,var(--bc-army-700),var(--bc-army-900));
  position:relative;overflow:hidden;min-height:240px;
  box-shadow:var(--shadow-lg);
}
.wallet::after{
  content:"";position:absolute;inset:auto -10% -50% auto;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle,rgba(196,227,109,.25),transparent 60%);
}
.wallet .chip{
  display:inline-flex;align-items:center;gap:.4rem;
  background:rgba(196,227,109,.18);color:var(--bc-lime-400);
  padding:.3rem .8rem;border-radius:var(--r-pill);
  font-family:var(--font-mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.12em
}
.wallet .digits{font-family:var(--font-mono);font-size:1.6rem;letter-spacing:.2em;margin-top:1.4rem}
.wallet .name{font-family:var(--font-display);font-size:1.6rem;margin-top:.3rem}
.wallet .meta{display:flex;justify-content:space-between;align-items:flex-end;margin-top:1.4rem;gap:1rem;flex-wrap:wrap}
.wallet .qr{
  width:140px;aspect-ratio:1;background:#fff;border-radius:14px;
  display:grid;place-items:center;color:var(--bc-army-900);
  font-family:var(--font-mono);font-size:.7rem;padding:.4rem;
  border:6px solid var(--bc-cream);
}
.wallet .countdown{font-family:var(--font-mono);font-size:.85rem;color:var(--bc-lime-400);margin-top:.4rem}

/* Cards de parceiros */
.partner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.partner{
  background:#fff;border-radius:var(--r-lg);padding:1.2rem;
  border:1px solid rgba(15,26,20,.05);position:relative;overflow:hidden;
  transition:transform .3s var(--ease-spring),box-shadow .3s
}
.partner:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.partner .ico{
  width:44px;height:44px;border-radius:12px;
  background:var(--bc-army-700);color:var(--bc-lime-500);
  display:grid;place-items:center;font-size:1.2rem;margin-bottom:.8rem;
}
.partner h4{font-family:var(--font-display);color:var(--bc-army-900);margin-bottom:.2rem}
.partner small{color:var(--bc-army-500)}
.partner .discount{margin-top:.7rem;font-weight:600;color:var(--bc-army-700)}
.partner .badge{position:absolute;top:.8rem;right:.8rem;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.06em;background:var(--bc-lime-500);color:var(--bc-army-900);padding:.2rem .55rem;border-radius:var(--r-pill)}

/* Filtros / chips */
.chips{display:flex;flex-wrap:wrap;gap:.5rem}
.chip-btn{
  padding:.5rem 1rem;border-radius:var(--r-pill);
  background:rgba(15,26,20,.05);font-size:.82rem;color:var(--bc-army-700);
  transition:all .25s;border:1.5px solid transparent;
}
.chip-btn:hover{background:rgba(15,26,20,.1)}
.chip-btn.is-active{background:var(--bc-army-700);color:var(--bc-cream);border-color:var(--bc-army-700)}

/* Toast */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  background:var(--bc-army-900);color:var(--bc-cream);
  padding:.9rem 1.4rem;border-radius:var(--r-pill);
  font-size:.9rem;box-shadow:var(--shadow-lg);z-index:1000;
  opacity:0;pointer-events:none;transition:opacity .3s,transform .3s var(--ease-spring)
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-6px);pointer-events:auto}
.toast.success{background:var(--bc-success);color:#0a1f0a}
.toast.error{background:var(--bc-danger)}

/* Modal */
.modal-back{position:fixed;inset:0;background:rgba(15,26,20,.5);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:300;animation:fadeIn .25s}
.modal{background:#fff;border-radius:var(--r-xl);padding:2rem;max-width:520px;width:92vw;animation:popIn .35s var(--ease-spring)}
.modal h3{font-family:var(--font-display);font-size:1.4rem;color:var(--bc-army-900);margin-bottom:.6rem}
.modal .actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1.2rem}
@keyframes fadeIn{from{opacity:0}}
@keyframes popIn{from{opacity:0;transform:scale(.95)}}

.skeleton{position:relative;overflow:hidden;background:rgba(15,26,20,.05);border-radius:.5rem;color:transparent!important}
.skeleton::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:shimmer 1.4s infinite}
@keyframes shimmer{from{transform:translateX(-100%)}to{transform:translateX(100%)}}
.skel-row{height:1.4rem;margin:.4rem 0}
.skel-grid{display:grid;gap:.5rem}

/* ===========================================================
   Mobile
   =========================================================== */
@media (max-width:880px){
  .shell{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-280px;top:0;width:260px;z-index:50;transition:left .35s var(--ease-spring)}
  .sidebar.open{left:0}
  .topbar{padding:.8rem 1rem}
  .content{padding:1.2rem}
  .menu-toggle{display:inline-grid !important}
}
.menu-toggle{display:none;width:42px;height:42px;border-radius:14px;background:rgba(15,26,20,.05);place-items:center}
