/* ─────────────────────────────────────
   LOBBER — Estilos globais
   ───────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
  --green-950: #042018;
  --green-900: #083a2a;
  --green-800: #0a5038;
  --green-700: #0d6647;
  --green-600: #1D9E75;
  --green-500: #2bbf8e;
  --green-400: #5DCAA5;
  --green-200: #9FE1CB;
  --green-100: #C8F0E3;
  --green-50:  #E1F5EE;
  --amber:     #EF9F27;
  --amber-50:  #FDF3E3;
  --red:       #E24B4A;
  --red-50:    #FDEEEE;
  --white:     #FAFAF8;
  --gray-100:  #F4F3F0;
  --gray-200:  #E8E6E1;
  --gray-400:  #B0ADA6;
  --gray-600:  #6B6860;
  --gray-800:  #2C2B28;
  --gray-900:  #1A1918;
  --serif:     'DM Serif Display', Georgia, serif;
  --sans:      'DM Sans', system-ui, sans-serif;
  --radius:    12px;
  --radius-sm: 8px;
  --sidebar:   240px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--gray-100);
  color: var(--gray-900);
  -webkit-font-smoothing: antialiased;
}

/* ── SIDEBAR ── */
.sidebar {
  width: var(--sidebar); background: var(--green-950);
  display: flex; flex-direction: column; flex-shrink: 0;
  height: 100vh; position: fixed; left: 0; top: 0; z-index: 50;
}
.sidebar-logo { display: flex; align-items: center; gap: 9px; padding: 20px 20px 0; text-decoration: none; margin-bottom: 32px; }
.sidebar-logo-mark { width: 28px; height: 28px; background: var(--green-600); border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.sidebar-logo-mark svg { width: 16px; height: 16px; }
.sidebar-logo-text { font-family: var(--serif); font-size: 20px; color: var(--white); }
.sidebar-section-label { font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: rgba(159,225,203,.35); padding: 0 20px; margin-bottom: 6px; }
.sidebar-nav { display: flex; flex-direction: column; gap: 2px; padding: 0 10px; margin-bottom: 24px; }
.sidebar-link { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: var(--radius-sm); font-size: 14px; color: rgba(159,225,203,.6); text-decoration: none; transition: background .15s, color .15s; cursor: pointer; }
.sidebar-link:hover { background: rgba(255,255,255,.05); color: var(--green-200); }
.sidebar-link.active { background: rgba(29,158,117,.18); color: var(--green-400); }
.sidebar-link svg { width: 16px; height: 16px; flex-shrink: 0; }
.sidebar-link .badge { margin-left: auto; background: var(--green-600); color: var(--white); font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: 10px; }
.sidebar-divider { height: 1px; background: rgba(255,255,255,.06); margin: 8px 20px 16px; }
.sidebar-bottom { margin-top: auto; padding: 16px 10px; border-top: 1px solid rgba(255,255,255,.06); }
.sidebar-user { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: var(--radius-sm); cursor: pointer; transition: background .15s; }
.sidebar-user:hover { background: rgba(255,255,255,.05); }
.sidebar-avatar { width: 30px; height: 30px; border-radius: 50%; background: var(--green-700); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; color: var(--white); flex-shrink: 0; }
.sidebar-user-name { font-size: 13px; color: var(--green-200); font-weight: 500; }
.sidebar-user-plan { font-size: 11px; color: rgba(159,225,203,.4); }

/* ── LAYOUT COM SIDEBAR ── */
.app-layout { display: flex; height: 100vh; overflow: hidden; }
.main { margin-left: var(--sidebar); flex: 1; display: flex; flex-direction: column; height: 100vh; overflow: hidden; }

/* ── TOPBAR ── */
.topbar { background: var(--white); border-bottom: 1px solid var(--gray-200); padding: 0 32px; height: 60px; display: flex; align-items: center; gap: 16px; flex-shrink: 0; }
.topbar-title { font-size: 15px; font-weight: 600; color: var(--gray-900); }
.topbar-right { display: flex; align-items: center; gap: 12px; margin-left: auto; }
.topbar-btn { width: 36px; height: 36px; border-radius: var(--radius-sm); background: transparent; border: 1px solid var(--gray-200); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--gray-600); transition: background .15s; }
.topbar-btn:hover { background: var(--gray-100); }
.topbar-plan { display: flex; align-items: center; gap: 6px; background: var(--green-50); border: 1px solid var(--green-100); padding: 6px 12px; border-radius: var(--radius-sm); font-size: 12px; font-weight: 600; color: var(--green-700); cursor: pointer; }

/* ── CONTENT ── */
.content { flex: 1; overflow-y: auto; padding: 28px 32px; }

/* ── BOTÕES ── */
.btn-primary { display: inline-flex; align-items: center; gap: 7px; background: var(--green-600); color: var(--white); border: none; padding: 9px 18px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 600; font-family: var(--sans); cursor: pointer; transition: background .15s; text-decoration: none; }
.btn-primary:hover { background: var(--green-700); }
.btn-secondary { display: inline-flex; align-items: center; gap: 7px; background: var(--white); color: var(--gray-700); border: 1px solid var(--gray-200); padding: 8px 14px; border-radius: var(--radius-sm); font-size: 13px; font-weight: 500; font-family: var(--sans); cursor: pointer; transition: background .15s; text-decoration: none; }
.btn-secondary:hover { background: var(--gray-100); }

/* ── CARDS ── */
.card { background: var(--white); border: 1px solid var(--gray-200); border-radius: var(--radius); overflow: hidden; }
.card-header { padding: 18px 22px; border-bottom: 1px solid var(--gray-100); display: flex; align-items: center; justify-content: space-between; }
.card-title { font-size: 15px; font-weight: 600; color: var(--gray-900); }
.card-body { padding: 22px; }

/* ── FORMULÁRIOS ── */
.form-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.form-label { font-size: 12px; font-weight: 600; color: var(--gray-700); text-transform: uppercase; letter-spacing: .05em; }
.form-input { height: 42px; border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 0 14px; font-size: 14px; font-family: var(--sans); color: var(--gray-900); background: var(--white); outline: none; transition: border-color .2s, box-shadow .2s; }
.form-input:focus { border-color: var(--green-600); box-shadow: 0 0 0 3px rgba(29,158,117,.1); }
.form-input::placeholder { color: var(--gray-400); }
.form-select { height: 42px; border: 1.5px solid var(--gray-200); border-radius: var(--radius-sm); padding: 0 14px; font-size: 14px; font-family: var(--sans); color: var(--gray-900); background: var(--white); outline: none; appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23B0ADA6' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; transition: border-color .2s; }
.form-select:focus { border-color: var(--green-600); }

/* ── UTILITÁRIOS ── */
.text-green { color: var(--green-600); }
.text-amber { color: var(--amber); }
.text-red   { color: var(--red); }
.text-gray  { color: var(--gray-600); }

/* ── TOAST ── */
.toast {
  position: fixed; bottom: 24px; right: 24px; z-index: 999;
  background: var(--gray-900); color: var(--white);
  padding: 12px 18px; border-radius: var(--radius-sm);
  font-size: 13px; font-weight: 500;
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
  transform: translateY(80px); opacity: 0;
  transition: all .3s cubic-bezier(.4,0,.2,1);
  display: flex; align-items: center; gap: 10px;
}
.toast.show { transform: translateY(0); opacity: 1; }
.toast.success { background: var(--green-700); }
.toast.error   { background: var(--red); }

/* ── LOADING ── */
.loading-overlay {
  position: fixed; inset: 0; background: rgba(255,255,255,.7);
  display: flex; align-items: center; justify-content: center;
  z-index: 998; opacity: 0; pointer-events: none; transition: opacity .2s;
}
.loading-overlay.show { opacity: 1; pointer-events: all; }
.spinner { width: 32px; height: 32px; border: 3px solid var(--gray-200); border-top-color: var(--green-600); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.fade-up { animation: fadeUp .4s ease both; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--gray-200); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--gray-400); }
