/* ══════════════════════════════════════════════
   Naalli · Portal do Aluno — Stylesheet
   ══════════════════════════════════════════════ */
:root {
  --terra:#B8706A; --terra-deep:#9A5B56; --terra-soft:#D9A5A0; --terra-wash:rgba(184,112,106,.08);
  --bone:#F8F3ED; --cream:#EFE6D8; --parchment:#FAF6EF; --sand:#DED0BC;
  --earth:#3D2E26; --coffee:#5A453B; --smoke:#8A7A6F;
  --sage:#8FA383; --sage-deep:#6B8560; --gold:#C99A52;
  --danger:#C75B5B; --blue:#7A96B8;
  --serif:'Fraunces',Georgia,serif; --sans:'Inter Tight',-apple-system,sans-serif;
  --r:14px; --r-lg:20px; --r-xl:28px;
  --shadow:0 4px 24px rgba(61,46,38,.07);
  --shadow-md:0 8px 32px rgba(61,46,38,.12);
  --shadow-lg:0 16px 48px rgba(61,46,38,.16);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bone);color:var(--earth);font-size:14px;line-height:1.6;min-height:100vh}
body.modal-open{overflow:hidden}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:14px}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── LOGIN ─────────────────────────────────── */
.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(160deg,var(--cream) 0%,var(--parchment) 60%,#E8DDD4 100%)}
.login-card{background:var(--bone);border-radius:24px;padding:44px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-md);border:1px solid rgba(61,46,38,.06)}
.login-logo{display:flex;justify-content:center;margin-bottom:28px}
.login-logo img{height:52px;border-radius:10px;object-fit:cover}
.login-logo-fallback{height:52px;width:52px;border-radius:10px;background:var(--terra);display:flex;align-items:center;justify-content:center}
.login-logo-fallback span{font-family:var(--serif);font-size:22px;color:#fff;font-weight:500}
.login-title{font-family:var(--serif);font-size:26px;font-weight:400;text-align:center;margin-bottom:6px}
.login-sub{font-size:13px;color:var(--smoke);text-align:center;margin-bottom:28px}
.field{margin-bottom:16px}
.field label{display:block;font-size:11px;font-weight:600;color:var(--smoke);letter-spacing:.1em;text-transform:uppercase;margin-bottom:7px}
.field input{width:100%;padding:13px 16px;border-radius:var(--r);border:1px solid rgba(61,46,38,.12);background:var(--parchment);outline:none;transition:border-color .2s;color:var(--earth)}
.field input:focus{border-color:var(--terra)}
.btn-login{width:100%;padding:14px;background:var(--terra);color:var(--bone);border-radius:100px;font-size:14px;font-weight:600;transition:background .2s;margin-top:6px}
.btn-login:hover{background:var(--terra-deep)}
.login-err{color:#C04545;font-size:12px;display:none;margin-bottom:12px;text-align:center;background:rgba(192,69,69,.06);padding:10px;border-radius:10px}

/* ── APP LAYOUT ─────────────────────────────── */
.app{display:none;min-height:100vh;flex-direction:column}
.app.show{display:flex}

/* TOPBAR */
.topbar{background:var(--earth);padding:0 28px;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 20px rgba(0,0,0,.2)}
.topbar-brand{display:flex;align-items:center;gap:12px}
.topbar-logo{width:34px;height:34px;border-radius:8px;object-fit:cover}
.topbar-name{font-family:var(--serif);font-size:18px;color:var(--terra-soft);font-weight:500}
.topbar-right{display:flex;align-items:center;gap:12px}
.topbar-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.2);cursor:pointer}
.topbar-avatar-fallback{width:36px;height:36px;border-radius:50%;background:var(--terra);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:15px;color:#fff;border:2px solid rgba(255,255,255,.2);cursor:pointer}
.topbar-user{font-size:13px;color:rgba(248,243,237,.6)}
.btn-logout{font-size:12px;color:rgba(248,243,237,.45);padding:6px 14px;border-radius:20px;border:1px solid rgba(248,243,237,.15);transition:all .2s}
.btn-logout:hover{color:rgba(248,243,237,.8);border-color:rgba(248,243,237,.35)}

/* CONTENT */
.content{flex:1;padding:32px 28px;max-width:960px;margin:0 auto;width:100%}

/* ── SAUDAÇÃO ──────────────────────────────── */
.greeting{margin-bottom:24px}
.greeting-tag{font-size:11px;font-weight:600;color:var(--terra);letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px}
.greeting-name{font-family:var(--serif);font-size:34px;font-weight:400;letter-spacing:-.02em;line-height:1.1}
.greeting-sub{font-size:13px;color:var(--smoke);margin-top:4px}

/* ── ABAS ───────────────────────────────────── */
.abas{display:flex;gap:6px;margin-bottom:24px;background:var(--parchment);padding:6px;border-radius:16px;border:1px solid rgba(61,46,38,.06);overflow-x:auto;scrollbar-width:none}
.abas::-webkit-scrollbar{display:none}
.aba-btn{flex:1;min-width:80px;padding:9px 12px;border-radius:12px;font-size:13px;font-weight:600;border:none;cursor:pointer;background:transparent;color:var(--smoke);transition:all .2s;font-family:var(--sans);white-space:nowrap;text-align:center}
.aba-ativa{background:var(--bone);color:var(--earth);box-shadow:var(--shadow)}

/* ── CARDS ──────────────────────────────────── */
.card{background:var(--parchment);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow);border:1px solid rgba(61,46,38,.05);margin-bottom:18px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.card-title{font-family:var(--serif);font-size:19px;font-weight:500}

/* ── FRASE DO DIA ───────────────────────────── */
.frase-card{background:var(--terra);border-radius:var(--r-lg);padding:24px;margin-bottom:18px;position:relative;overflow:hidden}
.frase-card::before{content:'"';position:absolute;top:-20px;left:16px;font-family:var(--serif);font-size:120px;color:rgba(255,255,255,.1);line-height:1}
.frase-texto{font-family:var(--serif);font-size:17px;font-weight:400;font-style:italic;color:var(--bone);line-height:1.5;position:relative;z-index:1}
.frase-autor{font-size:12px;color:rgba(248,243,237,.5);margin-top:10px;position:relative;z-index:1}

/* ── STATS ROW ──────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.stat-card{background:var(--parchment);border-radius:14px;padding:16px;box-shadow:var(--shadow);border:1px solid rgba(61,46,38,.05);text-align:center}
.stat-emoji{font-size:22px;margin-bottom:6px}
.stat-val{font-family:var(--serif);font-size:26px;font-weight:500;color:var(--earth);line-height:1}
.stat-lbl{font-size:11px;color:var(--smoke);margin-top:4px}

/* ── CONTRATO ───────────────────────────────── */
.contrato-hero{background:var(--earth);border-radius:16px;padding:28px;color:var(--bone);position:relative;overflow:hidden;margin-bottom:18px}
.contrato-hero::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:rgba(184,112,106,.15)}
.contrato-hero::after{content:'';position:absolute;bottom:-60px;right:40px;width:120px;height:120px;border-radius:50%;background:rgba(184,112,106,.08)}
.contrato-status-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;position:relative;z-index:1}
.contrato-status-dot{width:8px;height:8px;border-radius:50%}
.contrato-status-txt{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.contrato-plano{font-family:var(--serif);font-size:26px;font-weight:400;line-height:1.1;position:relative;z-index:1;margin-bottom:4px}
.contrato-plano span{font-style:italic;color:var(--terra-soft)}
.contrato-sub{font-size:12px;color:rgba(248,243,237,.45);position:relative;z-index:1;margin-bottom:20px}
.contrato-meta{display:flex;gap:24px;flex-wrap:wrap;position:relative;z-index:1}
.contrato-meta-item label{font-size:9px;font-weight:600;color:rgba(248,243,237,.35);letter-spacing:.12em;text-transform:uppercase;display:block;margin-bottom:3px}
.contrato-meta-item span{font-size:13px;font-weight:500;color:var(--bone)}
.contrato-actions{margin-top:20px;position:relative;z-index:1;display:flex;gap:8px}

/* ── KPIs ───────────────────────────────────── */
.kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.kpi-mini{background:var(--parchment);border-radius:14px;padding:16px;box-shadow:var(--shadow);border:1px solid rgba(61,46,38,.05);text-align:center}
.kpi-mini-val{font-family:var(--serif);font-size:26px;font-weight:500;color:var(--earth);line-height:1}
.kpi-mini-lbl{font-size:11px;color:var(--smoke);margin-top:4px}

/* ── PRÓXIMOS TREINOS ───────────────────────── */
.booking-card{display:flex;align-items:center;gap:14px;background:var(--bone);border-radius:12px;padding:14px 16px;border:1px solid rgba(61,46,38,.07);margin-bottom:10px;transition:border-color .2s}
.booking-card:hover{border-color:rgba(61,46,38,.14)}
.booking-emoji{width:42px;height:42px;border-radius:12px;background:var(--parchment);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.booking-info{flex:1}
.booking-date{font-weight:600;font-size:14px}
.booking-detail{font-size:12px;color:var(--smoke);margin-top:2px}
.booking-pill{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600}

/* ── BADGES ─────────────────────────────────── */
.badges-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
.badge-item{background:var(--bone);border-radius:14px;padding:14px 10px;text-align:center;border:1px solid rgba(61,46,38,.06);transition:all .2s}
.badge-item:hover{border-color:var(--terra);transform:translateY(-2px)}
.badge-item.locked{opacity:.4}
.badge-emoji{font-size:26px;margin-bottom:6px}
.badge-name{font-size:11px;color:var(--earth);font-weight:600}
.progress-bar{height:6px;background:rgba(61,46,38,.08);border-radius:3px;overflow:hidden;margin-top:8px}
.progress-fill{height:100%;background:var(--terra);border-radius:3px;transition:width .5s}

/* ── AGENDAMENTO ─────────────────────────────── */
.semana-scroller{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px;margin-bottom:16px}
.semana-scroller::-webkit-scrollbar{display:none}
.dia-btn{display:flex;flex-direction:column;align-items:center;padding:10px 14px;border-radius:14px;background:var(--bone);border:1.5px solid rgba(61,46,38,.08);cursor:pointer;min-width:58px;transition:all .2s;position:relative}
.dia-btn:hover{border-color:var(--terra)}
.dia-btn.selected{background:var(--terra);border-color:var(--terra)}
.dia-btn.disabled{opacity:.35;cursor:not-allowed}
.dia-btn.has-reserva{border-color:var(--sage-deep)}
.dia-nome{font-size:11px;font-weight:600;color:var(--smoke);margin-bottom:4px}
.dia-btn.selected .dia-nome{color:rgba(248,243,237,.7)}
.dia-num{font-size:18px;font-weight:700;color:var(--earth)}
.dia-btn.selected .dia-num{color:var(--bone)}
.dia-dot{width:6px;height:6px;border-radius:50%;background:var(--sage-deep);margin-top:5px}
.dia-btn.selected .dia-dot{background:rgba(255,255,255,.7)}

.horarios-scroller{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;margin-bottom:16px}
.horarios-scroller::-webkit-scrollbar{display:none}
.horario-btn{padding:8px 14px;border-radius:10px;background:var(--bone);border:1.5px solid rgba(61,46,38,.08);cursor:pointer;min-width:72px;text-align:center;transition:all .2s;font-family:var(--sans)}
.horario-btn.selected{border-color:var(--terra);background:var(--terra-wash)}
.horario-btn.has-reserva{border-color:var(--sage-deep);background:rgba(107,133,96,.06)}
.horario-hora{font-size:15px;font-weight:700;color:var(--earth)}
.horario-btn.selected .horario-hora{color:var(--terra)}
.horario-btn.has-reserva .horario-hora{color:var(--sage-deep)}
.horario-vagas{font-size:10px;color:var(--smoke)}
.bar-bg{width:44px;height:3px;background:rgba(61,46,38,.08);border-radius:2px;overflow:hidden;margin:4px auto}
.bar-fill{height:100%;border-radius:2px}

.slots-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.slot-card{border-radius:12px;padding:12px;border-left:4px solid;cursor:pointer;transition:all .2s;position:relative;min-height:90px;display:flex;flex-direction:column;justify-content:space-between}
.slot-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.slot-card.ocupado{cursor:not-allowed}
.slot-card.ocupado:hover{transform:none}
.slot-badge{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;background:rgba(44,35,32,.4)}
.slot-badge.proprio{background:var(--blue)}
.slot-nome{font-size:13px;font-weight:600;margin-top:6px}
.slot-action{font-size:10px;font-weight:500;margin-top:3px}
.slot-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid var(--blue)}
.slot-avatar-fallback{width:32px;height:32px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff}

/* ── MENSALIDADES ────────────────────────────── */
.mens-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-radius:12px;background:var(--bone);border:1px solid rgba(61,46,38,.06);margin-bottom:8px;transition:border-color .2s}
.mens-item:hover{border-color:rgba(61,46,38,.12)}
.mens-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.mens-ref{font-weight:600;font-size:14px}
.mens-date{font-size:12px;color:var(--smoke);margin-top:2px}
.mens-val{font-weight:700;font-size:15px;text-align:right}
.badge-status{display:inline-flex;align-items:center;padding:3px 10px;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase;margin-top:3px}
.mens-empty{text-align:center;padding:32px;color:var(--smoke);font-size:13px}

/* ── COMUNIDADE ─────────────────────────────── */
.membro-card{display:flex;align-items:flex-start;gap:14px;background:var(--bone);border-radius:14px;padding:16px;border:1px solid rgba(61,46,38,.06);margin-bottom:10px;transition:border-color .2s}
.membro-card:hover{border-color:rgba(61,46,38,.12)}
.membro-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--sand)}
.membro-avatar-fallback{width:52px;height:52px;border-radius:50%;background:var(--terra);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:22px;color:#fff;flex-shrink:0}
.membro-nome{font-weight:600;font-size:15px}
.membro-bio{font-size:13px;color:var(--coffee);margin-top:4px;line-height:1.5}
.membro-tempo{font-size:11px;color:var(--smoke);margin-top:6px}
.badge-conquista{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:8px;font-size:10px;font-weight:600;margin-right:4px;margin-top:4px}
.badge-novo{background:rgba(107,133,96,.12);color:var(--sage-deep);padding:3px 8px;border-radius:8px;font-size:10px;font-weight:700}

/* ── CONTEÚDOS / BIBLIOTECA ─────────────────── */
.biblio-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.biblio-card{background:var(--bone);border-radius:14px;overflow:hidden;border:1px solid rgba(61,46,38,.06);cursor:pointer;transition:all .2s}
.biblio-card:hover{border-color:var(--terra);transform:translateY(-2px);box-shadow:var(--shadow)}
.biblio-thumb{width:100%;height:100px;object-fit:cover;display:block}
.biblio-thumb-placeholder{width:100%;height:100px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.biblio-body{padding:12px}
.biblio-tag{display:inline-block;font-size:10px;font-weight:600;color:var(--terra);background:var(--terra-wash);padding:3px 10px;border-radius:20px;margin-bottom:6px}
.biblio-title{font-weight:600;font-size:13px;color:var(--earth);line-height:1.4;margin-bottom:4px}
.biblio-cat{font-size:11px;color:var(--smoke);display:flex;align-items:center;gap:4px}

/* ── AVISOS ─────────────────────────────────── */
.aviso-card{background:var(--bone);border-radius:12px;padding:16px;border:1px solid rgba(61,46,38,.06);border-left:3px solid;margin-bottom:10px;cursor:pointer;transition:all .2s}
.aviso-card:hover{border-color:rgba(61,46,38,.14)}
.aviso-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.aviso-titulo{font-weight:600;font-size:14px;margin-bottom:4px}
.aviso-msg{font-size:13px;color:var(--coffee);line-height:1.5}

/* ── AVALIAR ─────────────────────────────────── */
.estrela{font-size:28px;color:var(--sand);background:none;border:none;cursor:pointer;transition:color .15s;padding:0 2px}
.estrela.ativa{color:var(--gold)}
.field-lbl{display:block;font-size:11px;font-weight:600;color:var(--smoke);letter-spacing:.1em;text-transform:uppercase;margin-bottom:8px}
.aval-aula-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;background:var(--bone);border:1.5px solid rgba(61,46,38,.08);cursor:pointer;margin-bottom:8px;transition:all .2s}
.aval-aula-item.selected{border-color:var(--terra);background:var(--terra-wash)}
.aval-aula-item:hover{border-color:var(--terra)}

/* ── PERFIL ─────────────────────────────────── */
.foto-wrap{position:relative;width:96px;height:96px;margin:0 auto 20px}
.foto-wrap img,.foto-avatar-fallback{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--bone);display:block}
.foto-avatar-fallback{background:var(--terra);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:36px;color:#fff}
.foto-edit-btn{position:absolute;bottom:2px;right:2px;width:30px;height:30px;border-radius:50%;background:var(--terra);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border:2px solid var(--bone);font-size:14px;transition:background .2s}
.foto-edit-btn:hover{background:var(--terra-deep)}
.perfil-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.perfil-field{background:var(--bone);border-radius:12px;padding:14px 16px;border:1px solid rgba(61,46,38,.06)}
.perfil-field label{font-size:10px;font-weight:600;color:var(--smoke);letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:5px}
.perfil-field span,.perfil-field input{font-size:14px;color:var(--earth);font-weight:500}
.perfil-field.edit input{width:100%;background:transparent;border:none;outline:none;font-family:inherit}

/* ── BOTÕES ─────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:100px;font-size:13px;font-weight:600;transition:all .2s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:var(--terra);color:var(--bone)}.btn-primary:hover{background:var(--terra-deep)}
.btn-ghost{background:transparent;color:var(--earth);border-color:rgba(61,46,38,.14)}.btn-ghost:hover{background:var(--cream)}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-dark{background:rgba(248,243,237,.1);color:var(--bone);border-color:rgba(248,243,237,.2)}.btn-dark:hover{background:rgba(248,243,237,.18)}

/* ── MODAIS ─────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(61,46,38,.65);backdrop-filter:blur(8px);z-index:999;display:none;align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex}
.modal-box{background:var(--parchment);border-radius:24px;max-width:520px;width:100%;padding:32px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto}
.modal-title{font-family:var(--serif);font-size:22px;font-weight:500;margin-bottom:6px}
.modal-sub{font-size:13px;color:var(--smoke);margin-bottom:24px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
.modal-close{width:36px;height:36px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--coffee)}
.modal-close:hover{background:var(--sand)}

/* ── PLANO OPTIONS ───────────────────────────── */
.plano-option{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-radius:14px;border:1.5px solid rgba(61,46,38,.1);cursor:pointer;transition:all .2s;background:var(--bone);margin-bottom:10px}
.plano-option:hover,.plano-option.selected{border-color:var(--terra);background:var(--terra-wash)}
.plano-option-name{font-weight:600;font-size:14px}
.plano-option-desc{font-size:12px;color:var(--smoke);margin-top:2px}
.plano-option-val{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--terra)}
.plano-option-per{font-size:11px;color:var(--smoke)}

/* ── LOADER ─────────────────────────────────── */
.loader{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--smoke);font-size:13px;gap:10px}
.spin{width:18px;height:18px;border:2px solid rgba(184,112,106,.2);border-top-color:var(--terra);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── TOAST ──────────────────────────────────── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--earth);color:var(--bone);padding:14px 20px;border-radius:12px;box-shadow:var(--shadow-md);z-index:1001;font-size:13px;transform:translateY(100px);opacity:0;transition:all .3s}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{background:var(--sage-deep)}.toast.error{background:#C04545}

/* ── BUSCA ──────────────────────────────────── */
.search-row{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.search-input{flex:1;min-width:160px;padding:10px 14px;border-radius:var(--r);border:1px solid rgba(61,46,38,.1);background:var(--bone);outline:none;transition:border-color .2s;color:var(--earth)}
.search-input:focus{border-color:var(--terra)}
.count-badge{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:12px;background:var(--terra-wash);color:var(--terra);font-weight:700;font-size:13px}

/* ── FILTROS ─────────────────────────────────── */
.filtros-row{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;margin-bottom:14px;padding-bottom:2px}
.filtros-row::-webkit-scrollbar{display:none}
.filtro-chip{padding:6px 14px;border-radius:20px;background:var(--bone);border:1px solid rgba(61,46,38,.1);cursor:pointer;font-size:12px;font-weight:600;color:var(--smoke);white-space:nowrap;transition:all .2s}
.filtro-chip:hover{border-color:var(--terra);color:var(--terra)}
.filtro-chip.active{background:var(--earth);color:var(--bone);border-color:var(--earth)}

/* ── AVISO NO TOPO ───────────────────────────── */
.aviso-wrap-item{border-left:3px solid;border-radius:12px;padding:14px 16px;margin-bottom:10px}
.aviso-wrap-cat{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.aviso-wrap-titulo{font-weight:600;font-size:14px;margin-bottom:2px}
.aviso-wrap-msg{font-size:13px;color:var(--coffee)}

/* ── RESPONSIVO ─────────────────────────────── */
@media(max-width:700px){
  .content{padding:20px 16px}
  .kpi-row,.stats-row{grid-template-columns:1fr 1fr}
  .perfil-grid{grid-template-columns:1fr}
  .slots-grid{grid-template-columns:1fr 1fr}
  .badges-grid{grid-template-columns:repeat(4,1fr)}
  .biblio-grid{grid-template-columns:1fr}
  .contrato-meta{gap:16px}
  .greeting-name{font-size:26px}
  .topbar{padding:0 16px}
  .abas{border-radius:12px}
}
@media(max-width:420px){
  .badges-grid{grid-template-columns:repeat(4,1fr)}
  .slots-grid{grid-template-columns:1fr 1fr}
}