/* ============================================================
   CONCURSIA — Aplicação de cliente (app.concursia.eu)
   Ported from the Claude-design "V2" prototype (app.css).
   Brand tokens; tema claro, B2B, âmbar como sinal.
   ============================================================ */

:root {
  --ink: #1A1A1A;
  --grey: #808080;
  --amber: #EBB323;
  --amber-deep: #C8920A;
  --amber-soft: #FFF6E0;
  --white: #FFFFFF;

  --bg: #F4F3EF;            /* app canvas — warm light neutral */
  --panel: #FFFFFF;
  --bg-dark: #1A1A1A;
  --line: #E6E4DD;
  --line-strong: #D6D3C9;
  --line-dark: #2E2E2E;
  --ink-70: #3A3A3A;
  --ink-55: #5A5A5A;
  --muted: #7A776F;
  --muted-dark: #9A968C;
  --ok: #207A5B;
  --warn: #C8920A;
  --danger: #B5483B;

  --font-display: "Schibsted Grotesk", system-ui, sans-serif;
  --font-body: "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, monospace;

  --radius: 13px;
  --radius-sm: 9px;
  --radius-lg: 18px;
  --shadow-sm: 0 1px 2px rgba(26,26,26,.04), 0 1px 3px rgba(26,26,26,.06);
  --shadow-md: 0 4px 14px rgba(26,26,26,.07), 0 14px 36px rgba(26,26,26,.08);
  --shadow-pop: 0 12px 30px rgba(26,26,26,.12), 0 40px 80px rgba(26,26,26,.16);

  --sidebar-w: 248px;
  --topbar-h: 66px;
}

* , *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body.concursia-app {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; }
.concursia-app a { color: inherit; text-decoration: none; }
.concursia-app button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
.concursia-app input, .concursia-app select, .concursia-app textarea { font-family: inherit; font-size: inherit; color: inherit; }
.concursia-app h1, .concursia-app h2, .concursia-app h3, .concursia-app h4 { font-family: var(--font-display); margin: 0; letter-spacing: -0.02em; font-weight: 700; line-height: 1.1; }
.concursia-app p { margin: 0; }
.concursia-app ::selection { background: var(--amber); color: var(--ink); }
.mono { font-family: var(--font-mono); }

.concursia-app :focus-visible { outline: 2.5px solid var(--amber); outline-offset: 2px; border-radius: 6px; }

/* ---------- buttons ---------- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-weight: 600; font-size: 14px; letter-spacing: -0.01em; padding: 10px 16px; border-radius: 9px; border: 1.5px solid transparent; transition: background .16s, border-color .16s, transform .12s, box-shadow .16s, color .16s; white-space: nowrap; }
.btn:active { transform: translateY(1px); }
.btn-amber { background: var(--amber); color: var(--ink); box-shadow: 0 1px 0 rgba(0,0,0,.03), 0 5px 14px rgba(235,179,35,.28); }
.btn-amber:hover { background: #f5be2e; box-shadow: 0 1px 0 rgba(0,0,0,.03), 0 8px 20px rgba(235,179,35,.4); }
.btn-dark { background: var(--ink); color: #fff; }
.btn-dark:hover { background: #000; }
.btn-ghost { border-color: var(--line-strong); color: var(--ink-70); background: #fff; }
.btn-ghost:hover { border-color: var(--ink); color: var(--ink); }
.btn-quiet { color: var(--ink-70); padding: 8px 12px; }
.btn-quiet:hover { background: rgba(26,26,26,.05); }
.btn-sm { padding: 7px 12px; font-size: 13px; border-radius: 8px; }
.btn-block { width: 100%; }
.btn .arr { transition: transform .18s; }
.btn:hover .arr { transform: translateX(2px); }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* ---------- chips / badges ---------- */
.chip { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .02em; padding: 3px 9px; border-radius: 20px; border: 1px solid var(--line); color: var(--muted); background: #fff; white-space: nowrap; }
.chip.cae { color: var(--ink-70); }
.badge { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .05em; text-transform: uppercase; padding: 4px 9px; border-radius: 6px; font-weight: 500; }
.badge.new { background: var(--amber); color: var(--ink); }
.badge.soft { background: var(--amber-soft); color: var(--amber-deep); }
.badge.grey { background: #ECEAE3; color: var(--muted); }
.badge.ok { background: #E4F0EA; color: var(--ok); }
.badge.warn { background: #FBEFD3; color: var(--warn); }
.badge.danger { background: #F6E3E0; color: var(--danger); }
.badge.dot::before { content:""; width:6px;height:6px;border-radius:50%;background:currentColor; }

/* ============================================================
   LOGIN
   ============================================================ */
.login-wrap { min-height: 100%; display: grid; grid-template-columns: 1.05fr 1fr; }
.login-aside { background: var(--ink); color: #ECEAE3; position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: space-between; padding: 44px; }
.login-aside .brand-row { display: flex; align-items: center; gap: 11px; position: relative; z-index: 2; }
.login-aside .brand-row .wm { font-family: var(--font-display); font-weight: 700; font-size: 20px; letter-spacing: .02em; color: #fff; }
.login-aside .pitch { position: relative; z-index: 2; max-width: 420px; }
.login-aside .pitch .eyebrow { font-family: var(--font-mono); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--amber); display: inline-flex; align-items:center; gap: 8px; }
.login-aside .pitch h2 { font-size: 34px; color: #fff; margin-top: 16px; line-height: 1.08; }
.login-aside .pitch p { color: var(--muted-dark); margin-top: 16px; font-size: 15.5px; max-width: 380px; }
.login-aside .foot { position: relative; z-index: 2; font-size: 12.5px; color: var(--muted-dark); font-family: var(--font-mono); }
.login-radar { position: absolute; right: -120px; top: 50%; transform: translateY(-50%); width: 560px; height: 560px; z-index: 1; opacity: .9; }
.login-radar .ring { fill: none; stroke: #2c2c2c; }
.login-sweep { transform-origin: 280px 280px; animation: appsweep 7s linear infinite; }
@keyframes appsweep { to { transform: rotate(360deg); } }

.login-main { display: flex; align-items: center; justify-content: center; padding: 40px; background: var(--panel); }
.login-card { width: 100%; max-width: 380px; }
.login-card h1 { font-size: 28px; }
.login-card .sub { color: var(--muted); margin-top: 8px; font-size: 14.5px; }
.field { margin-top: 18px; }
.field label { display: block; font-size: 13px; font-weight: 600; color: var(--ink-70); margin-bottom: 7px; }
.field .ctrl { position: relative; display: flex; align-items: center; }
.field input { width: 100%; padding: 12px 14px; border: 1.5px solid var(--line-strong); border-radius: 10px; background: #fff; transition: border-color .15s, box-shadow .15s; }
.field input:focus { outline: none; border-color: var(--ink); box-shadow: 0 0 0 3px rgba(26,26,26,.06); }
.field input.has-icon { padding-left: 42px; }
.field .ic-lead { position: absolute; left: 13px; color: var(--grey); pointer-events: none; }
.field .toggle-pw { position: absolute; right: 10px; color: var(--grey); padding: 6px; border-radius: 6px; }
.field .toggle-pw:hover { color: var(--ink); background: rgba(26,26,26,.05); }
.field .err { color: var(--danger); font-size: 12.5px; margin-top: 6px; }
.login-row { display: flex; align-items: center; justify-content: space-between; margin-top: 14px; font-size: 13.5px; }
.login-row label { display: flex; align-items: center; gap: 8px; color: var(--ink-70); cursor: pointer; }
.login-row a { color: var(--amber-deep); font-weight: 600; }
.checkbox { width: 17px; height: 17px; border: 1.5px solid var(--line-strong); border-radius: 5px; display: inline-flex; align-items: center; justify-content: center; background: #fff; transition: background .15s, border-color .15s; flex: none; }
.checkbox.on { background: var(--amber); border-color: var(--amber); color: var(--ink); }
.checkbox:not(.on) svg { display: none; }
.login-row .rm { cursor: pointer; }
.login-divider { display: flex; align-items: center; gap: 14px; margin: 22px 0; color: var(--muted); font-size: 12.5px; }
.login-divider::before, .login-divider::after { content: ""; height: 1px; background: var(--line); flex: 1; }
.sso { display: flex; flex-direction: column; gap: 10px; }
.login-foot { margin-top: 24px; font-size: 13.5px; color: var(--muted); text-align: center; }
.login-foot a { color: var(--amber-deep); font-weight: 600; }

/* ============================================================
   APP SHELL
   ============================================================ */
.app { display: grid; grid-template-columns: var(--sidebar-w) 1fr; height: 100%; }

.sidebar { background: var(--panel); border-right: 1px solid var(--line); display: flex; flex-direction: column; height: 100%; }
.sidebar .s-brand { display: flex; align-items: center; gap: 10px; padding: 18px 18px 16px; }
.sidebar .s-brand .wm { display: flex; flex-direction: column; line-height: 1; }
.sidebar .s-brand .wm b { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: .02em; }
.sidebar .s-brand .wm span { font-family: var(--font-mono); font-size: 8.5px; letter-spacing: .07em; text-transform: uppercase; color: var(--grey); margin-top: 3px; }
.s-nav { padding: 8px 12px; display: flex; flex-direction: column; gap: 2px; flex: 1; }
.s-section { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--grey); padding: 14px 12px 6px; }
.s-item { display: flex; align-items: center; gap: 11px; padding: 9px 12px; border-radius: 9px; font-size: 14.5px; font-weight: 500; color: var(--ink-70); transition: background .14s, color .14s; position: relative; }
.s-item:hover { background: rgba(26,26,26,.045); color: var(--ink); }
.s-item.active { background: var(--ink); color: #fff; }
.s-item.active .s-ic { color: var(--amber); }
.s-item .s-ic { color: var(--grey); display: flex; }
.s-item:hover .s-ic { color: var(--ink-70); }
.s-item .count { margin-left: auto; font-family: var(--font-mono); font-size: 11px; background: var(--amber); color: var(--ink); padding: 1px 7px; border-radius: 10px; font-weight: 600; }
.s-item.active .count { background: var(--amber); }
.s-account { border-top: 1px solid var(--line); padding: 12px; }
.s-account .card { display: flex; align-items: center; gap: 10px; padding: 9px; border-radius: 10px; transition: background .14s; cursor: pointer; width: 100%; text-align: left; }
.s-account .card:hover { background: rgba(26,26,26,.045); }
.s-account .avatar { width: 36px; height: 36px; border-radius: 9px; background: var(--ink); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 14px; flex: none; }
.s-account .meta { min-width: 0; flex: 1; }
.s-account .meta b { display: block; font-size: 13.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.s-account .meta span { display: block; font-size: 11.5px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.s-plan { display: flex; align-items: center; gap: 7px; margin-top: 10px; padding: 8px 11px; border-radius: 9px; background: var(--amber-soft); }
.s-plan .t { font-size: 12px; color: var(--amber-deep); font-weight: 600; }
.s-plan .t b { font-family: var(--font-mono); }

/* main column */
.main { display: flex; flex-direction: column; height: 100%; min-width: 0; overflow: hidden; }
.topbar { height: var(--topbar-h); border-bottom: 1px solid var(--line); background: var(--panel); display: flex; align-items: center; gap: 16px; padding: 0 22px; flex: none; }
.topbar .tb-title { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -.01em; }
.topbar .search { margin-left: 6px; flex: 1; max-width: 460px; position: relative; display: flex; align-items: center; }
.topbar .search input { width: 100%; padding: 9px 12px 9px 38px; border: 1.5px solid var(--line); border-radius: 9px; background: var(--bg); transition: border-color .15s, background .15s; }
.topbar .search input:focus { outline: none; border-color: var(--line-strong); background: #fff; }
.topbar .search .ic { position: absolute; left: 12px; color: var(--grey); }
.topbar .tb-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.icon-btn { width: 38px; height: 38px; border-radius: 9px; display: flex; align-items: center; justify-content: center; color: var(--ink-70); position: relative; transition: background .14s; }
.icon-btn:hover { background: rgba(26,26,26,.05); }
.icon-btn .dot { position: absolute; top: 8px; right: 9px; width: 7px; height: 7px; border-radius: 50%; background: var(--amber); border: 2px solid var(--panel); }
.live-pill { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 11px; color: var(--ink-70); padding: 6px 11px; border: 1px solid var(--line); border-radius: 20px; }
.live-pill i { width: 7px; height: 7px; border-radius: 50%; background: var(--amber); box-shadow: 0 0 0 0 rgba(235,179,35,.5); animation: livedot 2.4s ease-out infinite; }
@keyframes livedot { 0% { box-shadow: 0 0 0 0 rgba(235,179,35,.5);} 70%{ box-shadow: 0 0 0 8px rgba(235,179,35,0);} 100%{ box-shadow: 0 0 0 0 rgba(235,179,35,0);} }

.scroll { overflow-y: auto; flex: 1; }
.page { padding: 26px 28px 60px; max-width: 1180px; margin: 0 auto; width: 100%; }

/* ============================================================
   CONCURSOS FEED
   ============================================================ */
.page-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 20px; flex-wrap: wrap; }
.page-head h1 { font-size: 26px; }
.page-head .ph-sub { color: var(--muted); font-size: 14px; margin-top: 5px; }

.stat-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 22px; }
.stat { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; }
.stat .k { font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; text-transform: uppercase; color: var(--muted); display: flex; align-items: center; gap: 7px; }
.stat .v { font-family: var(--font-display); font-weight: 700; font-size: 30px; letter-spacing: -.02em; margin-top: 8px; }
.stat .v em { font-style: normal; color: var(--amber-deep); }
.stat.accent { background: var(--ink); border-color: var(--ink); color: #fff; }
.stat.accent .k { color: var(--muted-dark); }
.stat.accent .v em { color: var(--amber); }

.toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; flex-wrap: wrap; }
.filters { display: flex; gap: 8px; flex-wrap: wrap; }
.fbtn { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 500; color: var(--ink-70); padding: 8px 13px; border: 1.5px solid var(--line); border-radius: 9px; background: #fff; transition: border-color .14s, background .14s; }
.fbtn:hover { border-color: var(--line-strong); }
.fbtn.on { border-color: var(--ink); background: var(--ink); color: #fff; }
.fbtn.on .fc { color: var(--amber); }
.fbtn .fc { color: var(--grey); }
.fbtn .cnt { font-family: var(--font-mono); font-size: 11px; opacity: .7; }
.sort { margin-left: auto; display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--muted); }
.sort select { border: 1.5px solid var(--line); border-radius: 9px; padding: 8px 10px; background: #fff; font-weight: 500; color: var(--ink-70); cursor: pointer; }

.feed-list { display: flex; flex-direction: column; gap: 10px; }
.crow { display: grid; grid-template-columns: 64px 1fr auto; gap: 16px; align-items: center; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; cursor: pointer; transition: border-color .16s, box-shadow .16s, transform .16s; position: relative; }
.crow:hover { border-color: var(--line-strong); box-shadow: var(--shadow-md); transform: translateY(-1px); }
.crow.high { border-left: 3px solid var(--amber); }
.crow.ignored { opacity: .55; }

.ring { position: relative; width: 56px; height: 56px; flex: none; }
.ring svg { transform: rotate(-90deg); }
.ring .rtxt { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.ring .rtxt b { font-family: var(--font-display); font-weight: 700; font-size: 16px; letter-spacing: -.03em; line-height: 1; }
.ring .rtxt span { font-family: var(--font-mono); font-size: 7.5px; color: var(--muted); letter-spacing: .03em; margin-top: 1px; }

.cmain { min-width: 0; }
.cmain .ctop { display: flex; align-items: center; gap: 9px; margin-bottom: 5px; flex-wrap: wrap; }
.cmain .title { font-family: var(--font-display); font-weight: 600; font-size: 16.5px; letter-spacing: -.01em; color: var(--ink); line-height: 1.25; }
.cmain .cmeta { display: flex; align-items: center; gap: 8px; margin-top: 8px; font-size: 12.5px; color: var(--muted); flex-wrap: wrap; }
.cmain .cmeta .mi { display: inline-flex; align-items: center; gap: 5px; }
.cmain .cmeta .mi svg { color: var(--grey); }
.cmain .cmeta .src { font-family: var(--font-mono); color: var(--ink-70); }
.cmain .cmeta .sep { width: 3px; height: 3px; border-radius: 50%; background: var(--line-strong); }
.cmain .tags { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }

.cright { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; flex: none; text-align: right; }
.cright .value { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -.02em; white-space: nowrap; }
.cright .value span { font-size: 11px; color: var(--muted); font-weight: 500; font-family: var(--font-body); }
.deadline { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 12px; padding: 4px 9px; border-radius: 7px; background: var(--bg); color: var(--ink-70); }
.deadline.urgent { background: #F6E3E0; color: var(--danger); }
.deadline.soon { background: #FBEFD3; color: var(--warn); }

.empty { text-align: center; padding: 70px 20px; color: var(--muted); }
.empty .ic { width: 56px; height: 56px; margin: 0 auto 16px; color: var(--line-strong); }
.empty h3 { font-family: var(--font-body); font-weight: 700; font-size: 17px; color: var(--ink-70); }
.empty p { margin-top: 6px; font-size: 14px; }

/* ============================================================
   CONCURSO DETAIL
   ============================================================ */
.detail-back { display: inline-flex; align-items: center; gap: 8px; font-size: 13.5px; font-weight: 600; color: var(--ink-70); margin-bottom: 18px; padding: 7px 12px 7px 9px; border-radius: 9px; }
.detail-back:hover { background: rgba(26,26,26,.05); }
.detail-grid { display: grid; grid-template-columns: 1fr 320px; gap: 22px; align-items: start; }
.dcard { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 22px 24px; }
.dcard + .dcard { margin-top: 16px; }
.dhead .dtop { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-bottom: 12px; }
.dhead h1 { font-size: 25px; line-height: 1.15; }
.dhead .dmeta { display: flex; align-items: center; gap: 10px; margin-top: 14px; font-size: 13.5px; color: var(--muted); flex-wrap: wrap; }
.dhead .dmeta .mi { display: inline-flex; align-items: center; gap: 6px; }
.dhead .dmeta .src { font-family: var(--font-mono); color: var(--ink-70); }
.dhead .tags { display: flex; gap: 7px; margin-top: 16px; flex-wrap: wrap; }

.ai-head { display: flex; align-items: center; gap: 10px; margin-bottom: 4px; }
.ai-head .spark { width: 28px; height: 28px; border-radius: 8px; background: var(--amber-soft); color: var(--amber-deep); display: flex; align-items: center; justify-content: center; }
.ai-head h3 { font-family: var(--font-body); font-weight: 700; font-size: 16px; }
.ai-head .tag { margin-left: auto; font-family: var(--font-mono); font-size: 10px; letter-spacing: .05em; text-transform: uppercase; color: var(--muted); }
.ai-summary { font-size: 14.5px; color: var(--ink-70); line-height: 1.6; margin-top: 12px; }
.ai-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 18px; }
.ai-fact { border: 1px solid var(--line); border-radius: 10px; padding: 13px 14px; background: var(--bg); }
.ai-fact .k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .05em; text-transform: uppercase; color: var(--muted); }
.ai-fact .v { font-weight: 600; font-size: 14.5px; margin-top: 5px; color: var(--ink); }
.req-list { list-style: none; padding: 0; margin: 16px 0 0; display: flex; flex-direction: column; gap: 10px; }
.req-list li { display: flex; gap: 10px; font-size: 14px; color: var(--ink-70); align-items: flex-start; }
.req-list li .ck { color: var(--amber-deep); flex: none; margin-top: 2px; }

.docs { display: flex; flex-direction: column; gap: 8px; margin-top: 14px; }
.doc { display: flex; align-items: center; gap: 12px; padding: 11px 14px; border: 1px solid var(--line); border-radius: 10px; transition: border-color .14s, background .14s; cursor: pointer; }
.doc:hover { border-color: var(--line-strong); background: var(--bg); }
.doc .fi { width: 34px; height: 34px; border-radius: 8px; background: var(--bg); display: flex; align-items: center; justify-content: center; color: var(--ink-70); flex: none; border: 1px solid var(--line); }
.doc .dn { flex: 1; min-width: 0; }
.doc .dn b { display: block; font-size: 13.5px; font-weight: 600; }
.doc .dn span { font-family: var(--font-mono); font-size: 11px; color: var(--muted); }
.doc .dl { color: var(--grey); }
.doc:hover .dl { color: var(--ink); }

/* aside */
.aside-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px; }
.aside-card + .aside-card { margin-top: 16px; }
.score-big { display: flex; align-items: center; gap: 16px; }
.score-big .ring { width: 76px; height: 76px; }
.score-big .ring .rtxt b { font-size: 22px; }
.score-big .sb-txt b { font-family: var(--font-display); font-size: 15px; display: block; }
.score-big .sb-txt span { font-size: 12.5px; color: var(--muted); }
.reasons { list-style: none; padding: 0; margin: 18px 0 0; display: flex; flex-direction: column; gap: 12px; }
.reasons li { display: flex; gap: 10px; align-items: flex-start; font-size: 13px; color: var(--ink-70); }
.reasons li .ri { width: 18px; height: 18px; flex: none; margin-top: 1px; }
.reasons li.pos .ri { color: var(--ok); }
.reasons li.neu .ri { color: var(--grey); }
.aside-actions { display: flex; flex-direction: column; gap: 9px; }
.kv { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid var(--line); font-size: 13.5px; }
.kv:last-child { border-bottom: none; }
.kv .k { color: var(--muted); }
.kv .v { font-weight: 600; }
.kv .v.mono { font-family: var(--font-mono); font-weight: 500; }

/* ============================================================
   CONTA / DEFINIÇÕES
   ============================================================ */
.tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin-bottom: 24px; flex-wrap: wrap; }
.tab { padding: 11px 14px; font-size: 14px; font-weight: 600; color: var(--muted); border-bottom: 2px solid transparent; margin-bottom: -1px; transition: color .14s, border-color .14s; }
.tab:hover { color: var(--ink-70); }
.tab.on { color: var(--ink); border-bottom-color: var(--amber); }

.set-grid { display: grid; grid-template-columns: 220px 1fr; gap: 30px; align-items: start; }
.set-side h4 { font-family: var(--font-body); font-weight: 700; font-size: 15px; }
.set-side p { font-size: 13px; color: var(--muted); margin-top: 6px; }
.set-card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 24px; }
.set-card + .set-card { margin-top: 18px; }
.frow { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.frow.one { grid-template-columns: 1fr; }
.fld label { display: block; font-size: 13px; font-weight: 600; color: var(--ink-70); margin-bottom: 7px; }
.fld input, .fld select, .fld textarea { width: 100%; padding: 10px 13px; border: 1.5px solid var(--line-strong); border-radius: 9px; background: #fff; transition: border-color .15s, box-shadow .15s; }
.fld input:focus, .fld select:focus, .fld textarea:focus { outline: none; border-color: var(--ink); box-shadow: 0 0 0 3px rgba(26,26,26,.06); }
.fld .hint { font-size: 12px; color: var(--muted); margin-top: 6px; }
.fld + .fld { margin-top: 16px; }
.cae-tags { display: flex; gap: 8px; flex-wrap: wrap; padding: 8px; border: 1.5px solid var(--line-strong); border-radius: 9px; background: #fff; min-height: 46px; align-items: center; }
.cae-tag { display: inline-flex; align-items: center; gap: 7px; background: var(--ink); color: #fff; font-family: var(--font-mono); font-size: 12px; padding: 5px 8px 5px 11px; border-radius: 7px; }
.cae-tag b { font-weight: 500; }
.cae-tag .x { color: var(--muted-dark); display: flex; }
.cae-tag .x:hover { color: #fff; }
.cae-tags .add { font-size: 12.5px; color: var(--amber-deep); font-weight: 600; padding: 5px 8px; }

.toggle { width: 42px; height: 24px; border-radius: 20px; background: var(--line-strong); position: relative; transition: background .18s; flex: none; cursor: pointer; }
.toggle.on { background: var(--amber); }
.toggle::after { content: ""; position: absolute; top: 3px; left: 3px; width: 18px; height: 18px; border-radius: 50%; background: #fff; transition: transform .18s; box-shadow: 0 1px 3px rgba(0,0,0,.2); }
.toggle.on::after { transform: translateX(18px); }
.optrow { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 16px 0; border-bottom: 1px solid var(--line); }
.optrow:last-child { border-bottom: none; }
.optrow .ot b { display: block; font-size: 14.5px; font-weight: 600; }
.optrow .ot span { display: block; font-size: 13px; color: var(--muted); margin-top: 3px; }

.seg { display: inline-flex; background: var(--bg); border: 1px solid var(--line); border-radius: 9px; padding: 3px; gap: 2px; }
.seg button { padding: 6px 13px; font-size: 13px; font-weight: 600; color: var(--muted); border-radius: 7px; transition: background .14s, color .14s; }
.seg button.on { background: #fff; color: var(--ink); box-shadow: var(--shadow-sm); }

/* subscription */
.plan-banner { display: flex; align-items: center; gap: 18px; background: var(--ink); color: #fff; border-radius: var(--radius); padding: 22px 24px; }
.plan-banner .pb-ic { width: 48px; height: 48px; border-radius: 11px; background: rgba(235,179,35,.16); color: var(--amber); display: flex; align-items: center; justify-content: center; flex: none; }
.plan-banner .pb-txt { flex: 1; }
.plan-banner .pb-txt b { font-family: var(--font-display); font-size: 18px; }
.plan-banner .pb-txt .row { display: flex; align-items: center; gap: 10px; }
.plan-banner .pb-txt span { color: var(--muted-dark); font-size: 13.5px; }
.plan-banner .price { text-align: right; }
.plan-banner .price b { font-family: var(--font-display); font-size: 26px; }
.plan-banner .price span { color: var(--muted-dark); font-size: 12.5px; display: block; }
.usage { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 16px; }
.usage .u { border: 1px solid var(--line); border-radius: 11px; padding: 15px 16px; }
.usage .u .k { font-size: 12.5px; color: var(--muted); }
.usage .u .v { font-family: var(--font-display); font-weight: 700; font-size: 22px; margin-top: 6px; }
.bar { height: 6px; border-radius: 4px; background: var(--line); margin-top: 10px; overflow: hidden; }
.bar i { display: block; height: 100%; background: var(--amber); border-radius: 4px; }

.save-bar { display: flex; align-items: center; justify-content: flex-end; gap: 10px; margin-top: 22px; }
.saved-flash { font-size: 13px; color: var(--ok); display: inline-flex; align-items: center; gap: 7px; font-weight: 600; }

/* toast */
.toast { position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--ink); color: #fff; padding: 12px 18px; border-radius: 11px; font-size: 13.5px; font-weight: 500; display: flex; align-items: center; gap: 10px; box-shadow: var(--shadow-pop); opacity: 0; pointer-events: none; transition: opacity .25s, transform .25s; z-index: 200; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast .ti { color: var(--amber); display: flex; }

/* responsive */
@media (max-width: 1080px) {
  .stat-row { grid-template-columns: repeat(2,1fr); }
  .detail-grid { grid-template-columns: 1fr; }
  .ai-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 860px) {
  :root { --sidebar-w: 0px; }
  .sidebar { display: none; }
  .app { grid-template-columns: 1fr; }
  .login-wrap { grid-template-columns: 1fr; }
  .login-aside { display: none; }
  .set-grid { grid-template-columns: 1fr; gap: 14px; }
  .crow { grid-template-columns: 52px 1fr; }
  .cright { grid-column: 2; align-items: flex-start; text-align: left; flex-direction: row; gap: 12px; margin-top: 4px; }
  .frow { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .stat-row { grid-template-columns: 1fr 1fr; }
  .ai-grid, .usage { grid-template-columns: 1fr; }
  .page { padding: 18px 16px 50px; }
}

/* scrollbar */
.scroll::-webkit-scrollbar { width: 11px; }
.scroll::-webkit-scrollbar-thumb { background: #d8d5cc; border-radius: 8px; border: 3px solid var(--bg); }
.scroll::-webkit-scrollbar-thumb:hover { background: #c4c0b5; }
