*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --p:#1B3A5C;--pl:#2E6B9E;--pd:#0F2440;
  --a:#0A6E5C;--al:#0D8A72;--gold:#D4A03C;
  --d:#0C1929;--c:#F8FAFE;--c2:#EDF2F8;--c3:#DDE5EF;
  --ink:#1A1A1A;--ink2:#4A5568;--ink3:#7A8A9E;
  --ok:#00a86b;--warn:#c97d00;--err:#c93030;
}
html,body{height:100%;overflow:hidden;background:var(--c);color:var(--ink);font-family:'DM Sans',sans-serif;font-size:14px;-webkit-font-smoothing:antialiased;}
body{display:flex;}
.serif{font-family:'DM Serif Display',serif;font-weight:400;letter-spacing:-.02em;}
.mono{font-family:'JetBrains Mono',monospace;}
a{text-decoration:none;color:inherit;}
button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit;}
::-webkit-scrollbar{width:8px;height:8px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:rgba(27,58,92,.2);border-radius:4px;}
::-webkit-scrollbar-thumb:hover{background:rgba(27,58,92,.4);}

/* ========== SIDEBAR ========== */
.sidebar{width:272px;min-width:272px;height:100vh;background:linear-gradient(180deg,#162B45 0%,var(--d) 100%);color:#e8e4dc;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.06);position:relative;overflow:hidden;}
.sidebar::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;opacity:.5;}
.sb-head{padding:1.25rem 1.25rem .9rem;position:relative;z-index:1;}
.sb-logo{display:flex;align-items:center;gap:.6rem;cursor:pointer;}
.sb-logo-mark{width:32px;height:32px;background:#fff;border-radius:7px;padding:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sb-logo-mark svg{width:100%;height:100%;}
.sb-logo-text{font-family:'DM Serif Display',serif;font-size:1.35rem;color:#fff;letter-spacing:-.02em;line-height:1;}
.sb-logo-text em{color:#7FB9A3;font-style:italic;font-weight:400;}
.sb-tagline{font-size:.62rem;color:#7a9cbf;letter-spacing:.1em;text-transform:uppercase;margin-top:.55rem;font-weight:500;}

.sb-scroll{flex:1;overflow-y:auto;padding:.5rem .85rem 1rem;position:relative;z-index:1;}
.sb-group-label{font-size:.62rem;color:#4a6278;text-transform:uppercase;letter-spacing:.12em;font-weight:600;padding:.9rem .5rem .4rem;}
.sb-item{display:flex;align-items:center;gap:.7rem;padding:.55rem .65rem;border-radius:7px;font-size:.82rem;color:#b8c5d6;cursor:pointer;margin-bottom:2px;position:relative;transition:background .15s,color .15s;}
.sb-item:hover{background:rgba(255,255,255,.05);color:#fff;}
.sb-item.active{background:rgba(46,107,158,.22);color:#fff;font-weight:600;}
.sb-item.active::before{content:'';position:absolute;left:-.85rem;top:.45rem;bottom:.45rem;width:3px;background:var(--gold);border-radius:0 2px 2px 0;}
.sb-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.85;}
.sb-item.active .sb-icon{opacity:1;}
.sb-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}
.sb-label{flex:1;}
.sb-badge-free{font-size:.55rem;background:var(--gold);color:var(--d);padding:.12rem .4rem;border-radius:3px;font-weight:800;letter-spacing:.05em;}

/* Eye-catcher comprar créditos */
.sb-promo{margin:.75rem .35rem 0;padding:.85rem .9rem;border-radius:10px;background:linear-gradient(135deg,rgba(212,160,60,.18),rgba(212,160,60,.05));border:1px solid rgba(212,160,60,.35);position:relative;overflow:hidden;cursor:pointer;}
.sb-promo::before{content:'';position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);animation:promo-shine 4s ease-in-out infinite;transform:skewX(-20deg);}
@keyframes promo-shine{0%,65%{left:-100%;}85%,100%{left:160%;}}
.sb-promo-label{font-size:.58rem;color:var(--gold);font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.3rem;display:flex;align-items:center;gap:.3rem;}
.sb-promo-pulse{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse-dot 1.6s ease-in-out infinite;}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.7);}}
.sb-promo-title{font-family:'DM Serif Display',serif;font-size:1rem;color:#fff;line-height:1.15;margin-bottom:.3rem;letter-spacing:-.01em;}
.sb-promo-title em{font-style:italic;color:var(--gold);}
.sb-promo-sub{font-size:.68rem;color:#c8d6e5;line-height:1.4;margin-bottom:.55rem;}
.sb-promo-btn{display:flex;align-items:center;justify-content:center;gap:.35rem;width:100%;background:var(--gold);color:var(--d);padding:.45rem;border-radius:6px;font-size:.72rem;font-weight:800;letter-spacing:.02em;transition:transform .15s;}
.sb-promo-btn:hover{transform:translateY(-1px);}

.sb-foot{padding:.9rem 1.1rem 1rem;border-top:1px solid rgba(255,255,255,.07);position:relative;z-index:1;background:rgba(0,0,0,.15);}
.sb-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:8px;padding:.7rem .8rem;margin-bottom:.55rem;}
.sb-card-label{font-size:.58rem;color:#7a9cbf;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:.35rem;}
.sb-proj-name{font-size:.82rem;font-weight:600;color:#fff;line-height:1.25;margin-bottom:.25rem;}
.sb-proj-meta{font-size:.68rem;color:#9ab0c8;margin-bottom:.45rem;}
.sb-bar{height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;}
.sb-bar-fill{height:100%;background:linear-gradient(90deg,var(--pl),var(--al));border-radius:2px;transition:width .4s;}

.sb-plan-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;}
.sb-plan-badge{font-size:.95rem;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:5px;background:rgba(212,160,60,.18);}
.sb-plan-name{font-size:.85rem;font-weight:700;color:#fff;}
.sb-plan-tag{font-size:.55rem;background:var(--gold);color:var(--d);padding:.1rem .35rem;border-radius:3px;font-weight:800;margin-left:auto;letter-spacing:.04em;}
.sb-saldos{font-size:.7rem;color:#c8d6e5;line-height:1.7;}
.sb-saldos .num{color:#fff;font-weight:700;}

.sb-user{display:flex;align-items:center;gap:.55rem;padding:.45rem .15rem;}
.sb-user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--pl),var(--al));display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0;}
.sb-user-info{flex:1;min-width:0;}
.sb-user-email{font-size:.7rem;color:#c8d6e5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-user-exit{font-size:.65rem;color:#7a9cbf;cursor:pointer;padding:.2rem .4rem;border-radius:4px;}
.sb-user-exit:hover{color:#fff;background:rgba(255,255,255,.06);}

.sb-version{font-size:.58rem;color:#3a526c;text-align:center;margin-top:.5rem;letter-spacing:.06em;}

/* ========== MAIN ========== */
.main{flex:1;height:100vh;overflow-y:auto;position:relative;}
.topbar{position:sticky;top:0;z-index:20;background:rgba(248,250,254,.88);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(27,58,92,.08);padding:.85rem 2rem;display:flex;align-items:center;gap:1rem;}
.breadcrumb{font-size:.78rem;color:var(--ink3);display:flex;align-items:center;gap:.5rem;}
.breadcrumb .sep{opacity:.4;}
.breadcrumb .current{color:var(--p);font-weight:600;}
.topbar-spacer{flex:1;}
.topbar-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:6px;font-size:.75rem;color:var(--ink2);background:rgba(27,58,92,.05);font-weight:500;cursor:pointer;transition:background .15s;}
.topbar-btn:hover{background:rgba(27,58,92,.1);}
.topbar-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.8;}

.page{padding:2rem 2.5rem 4rem;max-width:1280px;margin:0 auto;position:relative;}

/* Watermark */
.wm{position:absolute;font-family:'DM Serif Display',serif;font-style:italic;font-weight:400;font-size:clamp(3rem,9vw,7rem);color:transparent;-webkit-text-stroke:1.5px rgba(27,58,92,.06);pointer-events:none;user-select:none;letter-spacing:-.03em;line-height:1;z-index:0;top:1rem;right:1.5rem;}

.page-head{position:relative;z-index:1;margin-bottom:1.75rem;}
.page-eyebrow{font-size:.7rem;color:var(--pl);letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:.5rem;}
.page-title{font-family:'DM Serif Display',serif;font-size:clamp(1.75rem,3.2vw,2.4rem);color:var(--d);line-height:1.1;letter-spacing:-.02em;margin-bottom:.5rem;}
.page-title em{font-style:italic;color:var(--p);}
.page-sub{font-size:.92rem;color:var(--ink2);max-width:620px;line-height:1.5;}

/* Card 3D */
.card{background:#fff;border-radius:12px;border:2px solid var(--d);box-shadow:0 4px 0 var(--d),0 8px 18px rgba(0,0,0,.06);position:relative;z-index:1;}
.card-soft{background:#fff;border-radius:12px;border:1px solid #e8e4dc;box-shadow:0 1px 3px rgba(0,0,0,.04);position:relative;z-index:1;}
.card-dark{background:linear-gradient(145deg,#162B45,var(--d));color:#fff;border-radius:12px;border:2px solid rgba(27,58,92,.4);box-shadow:0 4px 0 rgba(0,0,0,.3),0 8px 18px rgba(0,0,0,.2);position:relative;z-index:1;overflow:hidden;}
.card-dark::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;opacity:.6;pointer-events:none;}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1.15rem;border-radius:8px;font-size:.83rem;font-weight:600;transition:transform .15s,box-shadow .15s;cursor:pointer;white-space:nowrap;}
.btn-primary{background:var(--p);color:#fff;border:2px solid var(--d);box-shadow:0 3px 0 var(--d);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 0 var(--d);}
.btn-primary:active{transform:translateY(1px);box-shadow:0 2px 0 var(--d);}
.btn-accent{background:var(--a);color:#fff;border:2px solid var(--d);box-shadow:0 3px 0 var(--d);}
.btn-accent:hover{transform:translateY(-1px);box-shadow:0 4px 0 var(--d);}
.btn-gold{background:var(--gold);color:var(--d);border:2px solid var(--d);box-shadow:0 3px 0 var(--d);font-weight:700;}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 4px 0 var(--d);}
.btn-outline{background:transparent;color:var(--p);border:2px solid var(--p);box-shadow:0 3px 0 var(--p);}
.btn-outline:hover{transform:translateY(-1px);box-shadow:0 4px 0 var(--p);}
.btn-ghost{background:rgba(27,58,92,.06);color:var(--p);}
.btn-ghost:hover{background:rgba(27,58,92,.12);}
.btn-xl{padding:.95rem 1.8rem;font-size:.95rem;}
.btn-full{width:100%;}
.btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:999px;font-size:.68rem;font-weight:600;}
.badge-ok{background:#e6f7f0;color:var(--ok);}
.badge-warn{background:#fff8e6;color:var(--warn);}
.badge-err{background:#ffe9e9;color:var(--err);}
.badge-info{background:#e8f0fb;color:var(--p);}
.badge-neutral{background:#f0f0f0;color:#666;}

/* Grids */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}

/* Guarda defensiva: atributo `hidden` sempre vence qualquer `display`
   utilitário (grid, flex, block). Previne recidiva do Bug A detectado
   em 23/04 (conflito .grid-2 display:grid × hidden no /novo). */
[hidden]{display:none !important;}

/* ========== DASHBOARD HOME ========== */
.hero-banner{position:relative;background:linear-gradient(135deg,#162B45 0%,var(--d) 65%,#0a1729 100%);color:#fff;border-radius:16px;padding:2.5rem 2.5rem 2.25rem;overflow:hidden;margin-bottom:1.5rem;border:2px solid var(--d);box-shadow:0 6px 0 var(--d),0 16px 40px rgba(12,25,41,.2);}
.hero-banner::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:36px 36px;opacity:.5;pointer-events:none;}
.hero-aurora{position:absolute;border-radius:50%;pointer-events:none;filter:blur(80px);opacity:.4;}
.hero-aurora.a1{width:280px;height:280px;background:var(--pl);top:-80px;right:-40px;animation:aurora-a 18s ease-in-out infinite;}
.hero-aurora.a2{width:240px;height:240px;background:var(--al);bottom:-80px;left:30%;animation:aurora-b 22s ease-in-out infinite;}
@keyframes aurora-a{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(-40px,30px) scale(1.15);}}
@keyframes aurora-b{0%,100%{transform:translate(0,0) scale(1);}50%{transform:translate(60px,-20px) scale(1.1);}}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.3fr 1fr;gap:2rem;align-items:center;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:.9rem;}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--gold);}
.hero-title{font-family:'DM Serif Display',serif;font-size:clamp(1.9rem,3.3vw,2.6rem);line-height:1.1;letter-spacing:-.025em;margin-bottom:.85rem;text-wrap:balance;}
.hero-title em{font-style:italic;color:#9FD4C0;}
.hero-sub{font-size:.95rem;line-height:1.55;color:#c8d6e5;margin-bottom:1.4rem;max-width:480px;}
.hero-actions{display:flex;gap:.7rem;flex-wrap:wrap;}
.hero-stat-stack{display:flex;flex-direction:column;gap:.75rem;}
.hero-stat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.85rem 1.1rem;display:flex;align-items:center;gap:.9rem;}
.hero-stat-icon{width:36px;height:36px;border-radius:8px;background:rgba(212,160,60,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.hero-stat-icon svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:2;}
.hero-stat-val{font-family:'DM Serif Display',serif;font-size:1.4rem;color:#fff;line-height:1;}
.hero-stat-lbl{font-size:.7rem;color:#9ab0c8;letter-spacing:.04em;margin-top:.2rem;}

/* Announcement / banner strip */
.ann-strip{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e8e4dc;border-left:4px solid var(--gold);border-radius:10px;padding:.85rem 1.1rem;margin-bottom:1.5rem;box-shadow:0 1px 3px rgba(0,0,0,.04);}
.ann-icon{width:34px;height:34px;border-radius:8px;background:rgba(212,160,60,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1rem;}
.ann-body{flex:1;}
.ann-title{font-weight:700;font-size:.85rem;color:var(--d);margin-bottom:.15rem;}
.ann-text{font-size:.78rem;color:var(--ink2);line-height:1.4;}
.ann-cta{font-size:.75rem;color:var(--p);font-weight:700;white-space:nowrap;cursor:pointer;}
.ann-cta:hover{text-decoration:underline;}

/* Update / news cards row */
.news-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem;}
.news-card{background:#fff;border:1px solid #e8e4dc;border-radius:10px;padding:1.1rem 1.2rem;position:relative;transition:transform .15s,box-shadow .15s;cursor:pointer;}
.news-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.07);}
.news-tag{display:inline-block;font-size:.6rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:.15rem .45rem;border-radius:3px;margin-bottom:.6rem;}
.news-tag.atu{background:rgba(10,110,92,.12);color:var(--a);}
.news-tag.evt{background:rgba(212,160,60,.18);color:#8a6520;}
.news-tag.tip{background:rgba(46,107,158,.15);color:var(--p);}
.news-title{font-family:'DM Serif Display',serif;font-size:1.05rem;line-height:1.2;color:var(--d);margin-bottom:.45rem;letter-spacing:-.01em;}
.news-text{font-size:.77rem;color:var(--ink2);line-height:1.5;}
.news-date{font-size:.67rem;color:var(--ink3);margin-top:.55rem;font-family:'JetBrains Mono',monospace;}

/* Partner / sponsor strip */
.sponsor-band{background:#fff;border:1px dashed rgba(27,58,92,.2);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.5rem;}
.sponsor-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem;}
.sponsor-label{font-size:.62rem;color:var(--ink3);letter-spacing:.14em;text-transform:uppercase;font-weight:700;}
.sponsor-tag{font-size:.62rem;color:var(--ink3);font-style:italic;}
.sponsor-row{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;}
.sponsor-slot{aspect-ratio:3.2/1;border-radius:7px;background:linear-gradient(135deg,#f3f6fb,#e8eef5);border:1px solid rgba(27,58,92,.08);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--ink3);font-weight:600;letter-spacing:.05em;}

/* Shortcut actions grid */
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem;margin-bottom:1.5rem;}
.quick-card{background:#fff;border:1px solid #e8e4dc;border-radius:12px;padding:1.1rem 1rem;cursor:pointer;transition:all .15s;position:relative;}
.quick-card:hover{border-color:var(--p);transform:translateY(-2px);box-shadow:0 4px 14px rgba(16,76,139,.1);}
.quick-card .qc-icon{width:38px;height:38px;border-radius:8px;background:rgba(27,58,92,.08);display:flex;align-items:center;justify-content:center;margin-bottom:.7rem;}
.quick-card .qc-icon svg{width:20px;height:20px;stroke:var(--p);fill:none;stroke-width:1.8;}
.quick-card .qc-title{font-weight:700;font-size:.85rem;color:var(--d);margin-bottom:.2rem;}
.quick-card .qc-sub{font-size:.72rem;color:var(--ink3);line-height:1.4;}

/* Side column widgets */
.home-cols{display:grid;grid-template-columns:1.6fr 1fr;gap:1.25rem;margin-bottom:1.5rem;}
.widget{background:#fff;border:1px solid #e8e4dc;border-radius:12px;padding:1.15rem 1.25rem;}
.widget-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem;padding-bottom:.7rem;border-bottom:1px solid #edf0f5;}
.widget-title{font-family:'DM Serif Display',serif;font-size:1.15rem;color:var(--d);letter-spacing:-.01em;}
.widget-link{font-size:.72rem;color:var(--p);font-weight:600;cursor:pointer;}
.widget-link:hover{text-decoration:underline;}

.proj-row{display:flex;align-items:center;gap:.8rem;padding:.65rem 0;border-bottom:1px solid #f2f4f8;}
.proj-row:last-child{border-bottom:none;}
.proj-ico{width:32px;height:32px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.95rem;}
.proj-info{flex:1;min-width:0;}
.proj-title{font-size:.83rem;font-weight:600;color:var(--d);margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.proj-meta{font-size:.7rem;color:var(--ink3);display:flex;align-items:center;gap:.5rem;}
.proj-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink3);opacity:.5;}
.proj-status{font-size:.65rem;padding:.15rem .5rem;border-radius:999px;font-weight:700;}

.credit-widget{background:linear-gradient(145deg,#162B45,var(--d));color:#fff;border-radius:12px;padding:1.25rem 1.3rem;position:relative;overflow:hidden;border:2px solid var(--d);box-shadow:0 4px 0 var(--d);}
.credit-widget::before{content:'';position:absolute;top:-40px;right:-40px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(212,160,60,.25),transparent 70%);}
.cw-label{font-size:.62rem;color:var(--gold);letter-spacing:.14em;text-transform:uppercase;font-weight:700;margin-bottom:.55rem;position:relative;}
.cw-title{font-family:'DM Serif Display',serif;font-size:1.2rem;line-height:1.15;margin-bottom:.3rem;position:relative;}
.cw-title em{font-style:italic;color:#9FD4C0;}
.cw-sub{font-size:.75rem;color:#c8d6e5;margin-bottom:1rem;line-height:1.5;position:relative;}
.cw-saldos{display:flex;flex-direction:column;gap:.45rem;margin-bottom:1rem;position:relative;}
.cw-saldo{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#c8d6e5;}
.cw-saldo .num{font-family:'DM Serif Display',serif;font-size:1.1rem;color:#fff;min-width:28px;text-align:center;}

/* =========================================================
   TIPOS DE PROJETO (5 cards como no .py)
   ========================================================= */
.tipo-section-label{font-family:'DM Serif Display',serif;font-size:1.25rem;color:var(--d);margin-bottom:.85rem;letter-spacing:-.01em;}
.tipos-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem;}
.tipos-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:.75rem;}
.tipo-card{background:#fff;border:2px solid #e8e4dc;border-radius:14px;padding:1.3rem 1.1rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;text-align:center;min-height:200px;justify-content:center;}
.tipo-card:hover{border-color:var(--p);box-shadow:0 4px 20px rgba(16,76,139,.1);transform:translateY(-2px);}
.tipo-card .ti-emoji{font-size:2.1rem;margin-bottom:.55rem;}
.tipo-card .ti-title{font-weight:700;font-size:.95rem;color:var(--d);margin-bottom:.35rem;letter-spacing:-.01em;}
.tipo-card .ti-desc{font-size:.73rem;color:var(--ink3);line-height:1.5;}
.tipo-card .ti-tags{font-size:.65rem;color:var(--pl);margin-top:.35rem;font-weight:600;}
.tipo-card.active{border-color:var(--p);box-shadow:0 6px 22px rgba(16,76,139,.18);background:linear-gradient(180deg,#fff 0%,#f5f9ff 100%);}
.tipo-card.active::after{content:"✓ selecionado";position:absolute;top:.55rem;right:.6rem;background:var(--p);color:#fff;font-size:.58rem;font-weight:800;letter-spacing:.08em;padding:.15rem .45rem;border-radius:10px;}
.tipo-card{position:relative;}

/* Bônus explicação */
.bonus-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-top:1rem;}
.bonus-card{background:linear-gradient(135deg,#fff8ed,#fff);border:1.5px solid rgba(212,160,60,.4);border-radius:12px;padding:1rem 1.1rem;position:relative;}
.bonus-card .bn-tag{font-size:.6rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.45rem;}
.bonus-card .bn-title{font-family:'DM Serif Display',serif;font-size:1.1rem;color:var(--d);margin-bottom:.5rem;line-height:1.2;}
.bonus-card .bn-title em{color:var(--gold);font-style:italic;}
.bonus-row{display:flex;justify-content:space-between;font-size:.78rem;padding:.28rem 0;border-bottom:1px dashed #e8d9b3;color:var(--ink2);}
.bonus-row:last-child{border-bottom:none;font-weight:700;color:var(--d);padding-top:.45rem;}
.bonus-row .bn-val{font-family:'JetBrains Mono',monospace;color:var(--gold);font-weight:700;}

/* Plan savings badge */
.plan-save{margin:.6rem 0 .9rem;padding:.45rem .65rem;border-radius:8px;background:#f0f8f3;color:#0b6846;font-size:.72rem;font-weight:600;text-align:center;border:1px solid #c8e5d3;}
.plan-save strong{font-weight:800;}
.plan-save.dark{background:rgba(159,212,192,.12);color:#9FD4C0;border-color:rgba(159,212,192,.3);}
.plan-save.subtle{background:#f7f4ec;color:var(--ink3);border-color:#e8e0cf;font-weight:500;}

/* Books (bônus) */
.bonus-section-head{text-align:left;padding:1.1rem 1.2rem;background:linear-gradient(135deg,#fff8ed 0%,#fffaf0 100%);border:1.5px solid rgba(212,160,60,.35);border-radius:14px;margin-top:1.4rem;}
.bonus-ribbon{display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:var(--gold);padding:.35rem .7rem;border-radius:999px;}
.books-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;margin-bottom:1.5rem;}
.book-card{background:#fff;border:2px solid #e8e4dc;border-radius:14px;padding:1.2rem;display:flex;gap:1.1rem;align-items:flex-start;transition:all .2s;}
.book-card:hover{border-color:var(--gold);box-shadow:0 8px 26px rgba(212,160,60,.18);transform:translateY(-2px);}
.book-cover{width:104px;height:138px;flex-shrink:0;border-radius:4px 6px 6px 4px;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.22),0 2px 4px rgba(0,0,0,.12);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;padding:.9rem .7rem;color:#fff;text-align:center;}
.book-cover::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:linear-gradient(90deg,rgba(0,0,0,.28),rgba(0,0,0,0));pointer-events:none;}
.book-cover::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 30% 10%,rgba(255,255,255,.14),transparent 60%);pointer-events:none;}
.book-cover img{width:100%;height:100%;object-fit:cover;display:block;}

/* Capa 1 – Planner 90 Dias (azul marinho editorial) */
.book-cover-planner{background:linear-gradient(155deg,#0E2C4E 0%,#1B4676 55%,#0A2340 100%);}
.book-cover-planner .bc-top{font-family:'DM Serif Display',serif;font-style:italic;font-size:.78rem;letter-spacing:.02em;color:#E8C878;margin-bottom:.15rem;}
.book-cover-planner .bc-num{font-family:'DM Serif Display',serif;font-size:2.6rem;line-height:1;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.3);}
.book-cover-planner .bc-bot{font-family:'DM Serif Display',serif;font-style:italic;font-size:.95rem;color:#E8C878;margin-top:.1rem;letter-spacing:.04em;}

/* Capa 2 – Resposta aos Revisores (verde esmeralda) */
.book-cover-revisores{background:linear-gradient(155deg,#084C3F 0%,#0D7A63 55%,#063D32 100%);}
.book-cover-revisores .bc-eyebrow{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:#F5D89A;margin-bottom:.35rem;font-weight:700;}
.book-cover-revisores .bc-main{font-family:'DM Serif Display',serif;font-size:1rem;line-height:1.1;color:#fff;}
.book-cover-revisores .bc-main em{color:#F5D89A;font-style:italic;font-size:1.15rem;display:block;margin-top:.1rem;}
.book-cover-revisores .bc-ink{position:absolute;bottom:.45rem;right:.55rem;font-size:1.15rem;color:rgba(245,216,154,.55);transform:rotate(-8deg);}

/* Capa 3 – Lattes Blindado (grafite / preto premium) */
.book-cover-lattes{background:linear-gradient(155deg,#1A1A1A 0%,#2E2E2E 55%,#0F0F0F 100%);}
.book-cover-lattes .bc-shield{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#D4A03C,#E8C878);color:#1A1A1A;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1rem;margin-bottom:.35rem;box-shadow:0 2px 6px rgba(0,0,0,.35);}
.book-cover-lattes .bc-title-l{font-family:'DM Serif Display',serif;font-size:1.25rem;color:#E8C878;line-height:1;}
.book-cover-lattes .bc-title-l em{font-style:italic;}
.book-cover-lattes .bc-title-l2{font-family:'DM Serif Display',serif;font-size:.88rem;color:#fff;letter-spacing:.14em;text-transform:uppercase;margin-top:.25rem;}
.book-body{flex:1;min-width:0;}
.book-tag{font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:.3rem;}
.book-title{font-family:'DM Serif Display',serif;font-size:1.12rem;color:var(--d);line-height:1.15;margin-bottom:.18rem;}
.book-sub{font-size:.73rem;font-style:italic;color:var(--ink2);margin-bottom:.5rem;}
.book-desc{font-size:.77rem;color:var(--ink2);line-height:1.55;}
@media(max-width:900px){.books-grid{grid-template-columns:1fr;}}

/* =========================================================
   PIPELINE
   ========================================================= */
.pipe-banner{background:linear-gradient(135deg,#0F1B2D 0%,#1A3A5C 100%);color:#fff;border-radius:14px;padding:1.4rem 1.8rem;margin-bottom:1.5rem;position:relative;overflow:hidden;}
.pipe-banner::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--ok),var(--pl),var(--ok),transparent);background-size:200% 100%;animation:shimmer 2.5s ease-in-out infinite;}
@keyframes shimmer{0%{background-position:-200% 0;}100%{background-position:200% 0;}}
.pipe-etapa-row{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;margin-bottom:.4rem;}
.pulse{width:10px;height:10px;border-radius:50%;background:#00e68a;animation:pulse 1.2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}
.pipe-sub{font-size:.82rem;color:#9ab0c8;margin-bottom:.85rem;}
.pipe-bar-out{background:rgba(255,255,255,.1);border-radius:6px;height:10px;overflow:hidden;margin-bottom:.65rem;}
.pipe-bar-in{height:100%;background:linear-gradient(90deg,var(--pl),var(--ok));border-radius:6px;position:relative;overflow:hidden;}
.pipe-bar-in::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);background-size:200% 100%;animation:shimmer 1.8s linear infinite;}
.pipe-chips{display:flex;gap:.4rem;flex-wrap:wrap;}
.chip{font-size:.7rem;padding:.22rem .6rem;border-radius:12px;font-weight:500;}
.chip-done{background:rgba(0,168,107,.2);color:#00e68a;}
.chip-run{background:rgba(46,107,158,.4);color:#9ECAFF;border:1px solid rgba(158,202,255,.4);}
.chip-pend{background:rgba(255,255,255,.06);color:#5a7a96;}
.pipe-timer{position:absolute;top:1.4rem;right:1.8rem;font-family:'JetBrains Mono',monospace;font-size:.78rem;color:#7a9cbf;}

.step-row{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;border-radius:10px;margin-bottom:.45rem;font-size:.88rem;border:1px solid transparent;}
.step-done{background:#e6f7f0;color:#0b6846;border-color:rgba(0,168,107,.2);}
.step-run{background:#fff8e6;color:#8a6520;border-color:rgba(212,160,60,.3);box-shadow:0 3px 0 rgba(212,160,60,.25);font-weight:600;}
.step-pend{background:#f7f7f9;color:#7a8a9e;}
.step-ico{font-size:1rem;width:1.5rem;text-align:center;flex-shrink:0;}
.step-label{flex:1;}
.step-status{font-size:.75rem;font-weight:600;}
.spin{display:inline-block;animation:spin 1.2s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

/* Expanders */
.expander{background:#fff;border:1px solid #e8e4dc;border-radius:10px;margin-bottom:.75rem;overflow:hidden;}
.expander-head{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.1rem;cursor:pointer;font-weight:600;font-size:.87rem;color:var(--d);user-select:none;}
.expander-head .chev{margin-left:auto;transition:transform .2s;opacity:.5;}
.expander.open .chev{transform:rotate(90deg);}
.expander-body{padding:0 1.1rem 1.1rem;display:none;}
.expander.open .expander-body{display:block;}

/* Tables */
.tbl{width:100%;border-collapse:collapse;font-size:.78rem;}
.tbl thead th{background:#f1f5f9;color:#475569;padding:.55rem .7rem;text-align:left;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;}
.tbl tbody td{padding:.55rem .7rem;border-bottom:1px solid #f2f4f8;}
.tbl tbody tr:hover{background:#fafbfd;}

/* Info boxes */
.alert{padding:.8rem 1.1rem;border-radius:8px;font-size:.82rem;line-height:1.5;margin-bottom:.85rem;}
.alert-info{background:#f0f7ff;border-left:3px solid var(--p);color:#164977;}
.alert-warn{background:#fff4e6;border-left:3px solid var(--warn);color:#5a3a00;}
.alert-ok{background:#e6f7f0;border-left:3px solid var(--ok);color:#0b6846;}
.alert strong{font-weight:700;}

/* Checkbox */
.chk{display:flex;align-items:flex-start;gap:.55rem;padding:.45rem 0;font-size:.82rem;color:var(--ink);cursor:pointer;}
.chk input{margin-top:.2rem;width:16px;height:16px;accent-color:var(--ok);cursor:pointer;flex-shrink:0;}
.chk strong{font-weight:700;}

/* Toggle */
.toggle{position:relative;display:inline-block;width:40px;height:22px;}
.toggle input{opacity:0;width:0;height:0;}
.toggle-slider{position:absolute;inset:0;background:#cbd5e1;border-radius:22px;transition:.2s;cursor:pointer;}
.toggle-slider::before{content:'';position:absolute;left:2px;top:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.toggle input:checked + .toggle-slider{background:var(--ok);}
.toggle input:checked + .toggle-slider::before{transform:translateX(18px);}

/* Inputs */
.input,.textarea,.select{width:100%;padding:.6rem .8rem;border:1.5px solid #ddd9d2;border-radius:8px;background:#fafaf8;font-family:inherit;font-size:.83rem;color:var(--ink);transition:border-color .15s;}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--p);background:#fff;}
.textarea{resize:vertical;min-height:70px;}
.label{display:block;font-size:.75rem;font-weight:600;color:var(--ink2);margin-bottom:.35rem;letter-spacing:.01em;}
.label .req{color:var(--err);}
.field{margin-bottom:.9rem;}

/* Upload zone */
.uploader{border:2px dashed #cbd5e1;border-radius:10px;padding:1.5rem;text-align:center;background:#fafbfd;cursor:pointer;transition:all .15s;}
.uploader:hover{border-color:var(--p);background:#f0f7ff;}
.uploader-ico{font-size:1.8rem;margin-bottom:.4rem;}
.uploader-text{font-size:.82rem;color:var(--ink2);}
.uploader-hint{font-size:.7rem;color:var(--ink3);margin-top:.25rem;}

/* =========================================================
   COMPRAR CRÉDITOS
   ========================================================= */
.plans-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:1.2rem;}
.plan{background:#fff;border:2px solid #e8e4dc;border-radius:14px;padding:1.5rem 1.4rem;position:relative;display:flex;flex-direction:column;}
.plan.featured{border-color:var(--p);box-shadow:0 8px 28px rgba(16,76,139,.14);transform:translateY(-4px);}
.plan.dark{background:linear-gradient(145deg,#162B45,var(--d));color:#fff;border-color:var(--d);}
.plan-ribbon{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--gold);color:var(--d);font-size:.62rem;font-weight:800;padding:.28rem .85rem;border-radius:999px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;}
.plan-emoji{font-size:1.6rem;margin-bottom:.4rem;}
.plan-name{font-family:'DM Serif Display',serif;font-size:1.45rem;margin-bottom:.25rem;}
.plan-desc{font-size:.75rem;color:var(--ink3);margin-bottom:1rem;line-height:1.4;min-height:2.1em;}
.plan.dark .plan-desc{color:#9ab0c8;}
.plan-price{display:flex;align-items:baseline;gap:.35rem;margin-bottom:.3rem;}
.plan-price .cur{font-size:.85rem;color:var(--ink2);font-weight:600;}
.plan-price .amt{font-family:'DM Serif Display',serif;font-size:2.4rem;line-height:1;color:var(--d);}
.plan.dark .plan-price .cur,.plan.dark .plan-price .amt{color:#fff;}
.plan.dark .plan-price .cur{color:#c8d6e5;}
.plan-parcelas{font-size:.72rem;color:var(--ink3);margin-bottom:1rem;}
.plan.dark .plan-parcelas{color:#9ab0c8;}
.plan-feat{list-style:none;font-size:.8rem;color:var(--ink2);display:flex;flex-direction:column;gap:.45rem;margin-bottom:1.2rem;}
.plan.dark .plan-feat{color:#c8d6e5;}
.plan-feat li{display:flex;align-items:flex-start;gap:.5rem;line-height:1.4;}
.plan-feat .chk{color:var(--ok);flex-shrink:0;padding:0;font-weight:700;}
.plan .btn{margin-top:auto;}

/* Avulsos compact row */
.avulso-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem;}
.avulso{background:#fff;border:1px solid #e8e4dc;border-radius:10px;padding:1.1rem 1.2rem;display:flex;align-items:center;gap:1rem;}
.avulso-emoji{font-size:1.5rem;}
.avulso-body{flex:1;}
.avulso-name{font-weight:700;font-size:.9rem;color:var(--d);margin-bottom:.15rem;}
.avulso-desc{font-size:.72rem;color:var(--ink3);}
.avulso-price{font-family:'DM Serif Display',serif;font-size:1.4rem;color:var(--p);}

/* =========================================================
   HISTÓRICO
   ========================================================= */
.hist-row{display:grid;grid-template-columns:40px 2fr 1fr 1fr 120px 100px;gap:.85rem;align-items:center;padding:.85rem 1rem;border-bottom:1px solid #f2f4f8;font-size:.82rem;}
.hist-row:hover{background:#fafbfd;}
.hist-row.head{background:#f1f5f9;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#475569;}
.hist-ico{width:32px;height:32px;border-radius:7px;background:rgba(27,58,92,.06);display:flex;align-items:center;justify-content:center;font-size:.95rem;}

/* =========================================================
   RECOMENDADOR
   ========================================================= */
.journal-card{display:grid;grid-template-columns:1fr 110px 100px 140px;gap:1rem;align-items:center;padding:1rem 1.2rem;border-bottom:1px solid #edf0f5;}
.journal-card:last-child{border-bottom:none;}
.journal-name{font-family:'DM Serif Display',serif;font-size:1.05rem;color:var(--d);margin-bottom:.2rem;}
.journal-meta{font-size:.72rem;color:var(--ink3);}
.journal-score{font-family:'DM Serif Display',serif;font-size:1.4rem;color:var(--a);text-align:center;}
.journal-score-lbl{font-size:.62rem;color:var(--ink3);text-align:center;text-transform:uppercase;letter-spacing:.05em;}

/* =========================================================
   RESULTADO
   ========================================================= */
.result-hero{background:linear-gradient(145deg,#162B45,var(--d));color:#fff;border-radius:14px;padding:2rem 2.25rem;margin-bottom:1.5rem;position:relative;overflow:hidden;border:2px solid var(--d);box-shadow:0 4px 0 var(--d);}
.result-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:32px 32px;pointer-events:none;opacity:.5;}
.result-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;position:relative;z-index:1;}
.result-stats{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}
.result-stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.85rem 1rem;}
.result-stat-val{font-family:'DM Serif Display',serif;font-size:1.6rem;color:var(--gold);line-height:1;}
.result-stat-lbl{font-size:.7rem;color:#9ab0c8;margin-top:.2rem;}

/* =========================================================
   PREVIA
   ========================================================= */
.previa-hero{background:#fff;border:2px solid var(--d);border-radius:14px;padding:2rem;box-shadow:0 4px 0 var(--d);margin-bottom:1.5rem;}
.previa-badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--gold);color:var(--d);font-size:.65rem;font-weight:800;padding:.3rem .7rem;border-radius:4px;letter-spacing:.08em;margin-bottom:.75rem;}

/* =========================================================
   LOGIN OVERLAY
   ========================================================= */
.login-overlay{position:fixed;inset:0;background:rgba(12,25,41,.82);backdrop-filter:blur(10px);z-index:100;display:none;align-items:center;justify-content:center;padding:2rem;}
.login-overlay.show{display:flex;}
.login-box{background:#fff;border-radius:16px;display:grid;grid-template-columns:1fr 1fr;max-width:920px;width:100%;overflow:hidden;border:2px solid var(--d);box-shadow:0 10px 0 var(--d),0 30px 80px rgba(0,0,0,.4);}
.login-left{padding:2.5rem 2.25rem;}
.login-right{background:linear-gradient(145deg,#162B45,var(--d));color:#fff;padding:2.5rem 2.25rem;position:relative;overflow:hidden;}
.login-right::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:26px 26px;opacity:.5;pointer-events:none;}
.login-close{position:absolute;top:1rem;right:1rem;width:28px;height:28px;border-radius:6px;background:rgba(255,255,255,.08);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;font-size:1rem;}

/* =========================================================
   LOGIN PAGE (dedicated, in-app)
   ========================================================= */
body.is-login .sidebar{display:none;}
body.is-login .main{background:linear-gradient(155deg,#0B1E33 0%,#162B45 45%,#0F2740 100%);}
.login-page{padding:0;max-width:none;margin:0;min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;background:transparent;}
.login-form-side{background:#fff;padding:3.2rem 3.6rem;display:flex;flex-direction:column;justify-content:center;position:relative;}
.login-form-wrap{max-width:420px;margin:0 auto;width:100%;}
.login-brand{display:flex;align-items:center;gap:.7rem;margin-bottom:2.4rem;position:absolute;top:2.2rem;left:3.6rem;font-size:27.5px;font-weight:600;}
.login-brand .logo-mark{width:44px;height:44px;background:#fff;border:1.5px solid #e8e4dc;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(11,30,51,.06);}
.login-brand .logo-mark svg{width:32px;height:32px;display:block;}
.login-brand .brand-word{font-family:'DM Serif Display',serif;font-size:1.5rem;color:var(--d);letter-spacing:-.01em;line-height:1;}
.login-brand .brand-word em{color:var(--a);font-style:italic;}
.login-eyebrow{font-size:.68rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:.7rem;}
.login-title{font-family:'DM Serif Display',serif;font-size:2.4rem;line-height:1.05;color:var(--d);letter-spacing:-.02em;margin-bottom:.6rem;}
.login-title em{color:var(--a);font-style:italic;}
.login-sub{font-size:.95rem;color:var(--ink2);line-height:1.5;margin-bottom:2rem;max-width:380px;}
.login-field{margin-bottom:1rem;}
.login-field .label{display:block;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink3);margin-bottom:.4rem;}
.login-field .input{width:100%;padding:.95rem 1rem;border:1.5px solid #e0dcd2;border-radius:8px;font-size:.95rem;font-family:inherit;color:var(--d);background:#fafaf7;transition:all .15s;}
.login-field .input:focus{outline:none;border-color:var(--a);background:#fff;box-shadow:0 0 0 3px rgba(46,157,127,.12);}
.login-row{display:flex;align-items:center;justify-content:space-between;margin:.3rem 0 1.3rem;}
.login-check{display:flex;align-items:center;gap:.45rem;font-size:.8rem;color:var(--ink2);cursor:pointer;}
.login-check input{width:15px;height:15px;accent-color:var(--a);}
.login-link{font-size:.8rem;color:var(--a);text-decoration:none;font-weight:600;cursor:pointer;}
.login-link:hover{text-decoration:underline;}
.login-submit{width:100%;padding:1.05rem;background:var(--a);color:#fff;border:none;border-radius:8px;font-weight:700;font-size:.95rem;font-family:inherit;cursor:pointer;letter-spacing:.02em;transition:all .15s;box-shadow:0 6px 0 #206956;}
.login-submit:hover{transform:translateY(-1px);box-shadow:0 7px 0 #206956;}
.login-submit:active{transform:translateY(3px);box-shadow:0 3px 0 #206956;}
.login-divider{display:flex;align-items:center;gap:.8rem;margin:1.5rem 0;font-size:.7rem;color:var(--ink3);letter-spacing:.1em;text-transform:uppercase;}
.login-divider::before,.login-divider::after{content:"";flex:1;height:1px;background:#e8e4dc;}
.login-social{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;}
.login-social-btn{padding:.85rem;background:#fff;border:1.5px solid #e0dcd2;border-radius:8px;font-weight:600;font-size:.85rem;color:var(--d);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;font-family:inherit;transition:all .15s;}
.login-social-btn:hover{border-color:var(--d);background:#f8f6f0;}
.login-foot{text-align:center;margin-top:2rem;font-size:.8rem;color:var(--ink2);}
.login-foot a{color:var(--a);font-weight:700;text-decoration:none;}

/* Lado editorial */
.login-editorial{background:linear-gradient(155deg,#0B1E33 0%,#162B45 45%,#0F2740 100%);color:#fff;padding:3.6rem;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;}
.login-editorial::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:44px 44px;pointer-events:none;}
.login-editorial::after{content:"";position:absolute;top:-200px;right:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(46,157,127,.35),transparent 65%);pointer-events:none;}
.login-editorial-inner{position:relative;z-index:2;}
.login-quote-eyebrow{font-size:.65rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.3rem;}
.login-quote{font-family:'DM Serif Display',serif;font-size:1.75rem;line-height:1.15;color:#fff;margin-bottom:1.6rem;letter-spacing:-.015em;}
.login-quote em{color:#9FD4C0;font-style:italic;}
.login-cite{display:flex;align-items:center;gap:.8rem;}
.login-cite-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#B8860B);display:flex;align-items:center;justify-content:center;font-weight:800;color:#1A1A1A;font-size:.9rem;}
.login-cite-name{font-size:.88rem;color:#fff;font-weight:700;}
.login-cite-role{font-size:.72rem;color:#9ab0c8;margin-top:.1rem;}

/* Benefícios (substitui depoimento) */
.login-benefits{display:flex;flex-direction:column;gap:1.1rem;margin-bottom:1.8rem;}
.lb-row{display:flex;gap:.9rem;align-items:flex-start;}
.lb-ico{width:36px;height:36px;border-radius:8px;background:rgba(46,157,127,.15);color:#9FD4C0;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(46,157,127,.25);}
.lb-name{font-weight:700;color:#fff;font-size:.92rem;margin-bottom:.18rem;letter-spacing:-.005em;}
.lb-desc{font-size:.78rem;color:#9ab0c8;line-height:1.5;}

.login-stats{position:relative;z-index:2;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding-top:1.8rem;border-top:1px solid rgba(255,255,255,.12);}
.login-stat .num{font-family:'DM Serif Display',serif;font-size:1.9rem;color:#9FD4C0;line-height:1;font-style:italic;}
.login-stat .lab{font-size:.7rem;color:#9ab0c8;margin-top:.4rem;letter-spacing:.04em;}

.login-preview{position:relative;z-index:2;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:1.1rem 1.25rem;margin-top:1.8rem;}
.login-preview-head{font-size:.62rem;color:var(--gold);letter-spacing:.14em;font-weight:800;text-transform:uppercase;margin-bottom:.6rem;}
.login-preview-title{font-size:.92rem;color:#fff;margin-bottom:.6rem;font-weight:700;}
.login-preview-bar{height:6px;background:rgba(255,255,255,.12);border-radius:3px;overflow:hidden;margin-bottom:.6rem;}
.login-preview-bar>div{height:100%;width:57%;background:linear-gradient(90deg,var(--a),#9FD4C0);border-radius:3px;}
.login-preview-chips{display:flex;gap:.3rem;flex-wrap:wrap;}
.login-preview-chips span{font-size:.65rem;padding:.2rem .55rem;border-radius:999px;background:rgba(255,255,255,.08);color:#9FD4C0;font-weight:600;}
.login-preview-chips span.run{background:rgba(212,160,60,.2);color:var(--gold);}

@media(max-width:1100px){.login-page{grid-template-columns:1fr;}.login-editorial{display:none;}.login-brand{position:static;margin-bottom:2rem;}.login-form-side{padding:2rem 1.5rem;}}

/* =========================================================
   PERFIL DO USUÁRIO
   ========================================================= */
.perfil-hero{background:linear-gradient(155deg,#0B1E33 0%,#162B45 55%,#0F2740 100%);color:#fff;border-radius:16px;padding:2.2rem 2.4rem;margin-bottom:1.8rem;position:relative;overflow:hidden;}
.perfil-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:40px 40px;}
.perfil-hero::after{content:"";position:absolute;top:-160px;right:-120px;width:420px;height:420px;background:radial-gradient(circle,rgba(46,157,127,.3),transparent 65%);}
.perfil-hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:auto 1fr auto;gap:1.8rem;align-items:center;}
.perfil-avatar{width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--a),#0B6846);display:flex;align-items:center;justify-content:center;font-family:'DM Serif Display',serif;font-size:2.2rem;color:#fff;letter-spacing:-.02em;box-shadow:0 8px 24px rgba(0,0,0,.35),inset 0 0 0 3px rgba(255,255,255,.15);position:relative;}
.perfil-avatar-edit{position:absolute;bottom:-2px;right:-2px;width:28px;height:28px;border-radius:50%;background:var(--gold);color:#1A1A1A;display:flex;align-items:center;justify-content:center;font-size:.75rem;cursor:pointer;border:3px solid #162B45;}
.perfil-name{font-family:'DM Serif Display',serif;font-size:1.85rem;color:#fff;letter-spacing:-.02em;margin-bottom:.25rem;}
.perfil-name em{color:#9FD4C0;font-style:italic;}
.perfil-role{font-size:.85rem;color:#9ab0c8;margin-bottom:.8rem;}
.perfil-badges{display:flex;gap:.4rem;flex-wrap:wrap;}
.perfil-badge{padding:.32rem .65rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:999px;font-size:.7rem;color:#fff;font-weight:600;display:flex;align-items:center;gap:.35rem;}
.perfil-badge.gold{background:rgba(212,160,60,.2);border-color:rgba(212,160,60,.4);color:var(--gold);}
.perfil-cta{display:flex;flex-direction:column;gap:.5rem;}
.perfil-cta .btn-gold-line{padding:.65rem 1.1rem;background:rgba(212,160,60,.2);border:1.5px solid var(--gold);color:#fff;border-radius:8px;font-weight:700;font-size:.8rem;cursor:pointer;font-family:inherit;}
.perfil-cta .btn-ghost-w{padding:.6rem 1.1rem;background:transparent;border:1px solid rgba(255,255,255,.25);color:#fff;border-radius:8px;font-weight:600;font-size:.78rem;cursor:pointer;font-family:inherit;}

.perfil-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:1.3rem;margin-bottom:1.3rem;}
.perfil-card{background:#fff;border:1px solid #e8e4dc;border-radius:14px;padding:1.4rem 1.5rem;}
.perfil-card h3{font-family:'DM Serif Display',serif;font-size:1.15rem;color:var(--d);margin-bottom:.4rem;letter-spacing:-.01em;}
.perfil-card .sub{font-size:.78rem;color:var(--ink3);margin-bottom:1.2rem;}

.perfil-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.1rem;}
.perfil-form-grid .field{display:flex;flex-direction:column;gap:.3rem;}
.perfil-form-grid .field.full{grid-column:1/-1;}
.perfil-form-grid label{font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink3);}
.perfil-form-grid .input,.perfil-form-grid select{padding:.7rem .85rem;border:1.5px solid #e0dcd2;border-radius:8px;font-size:.87rem;font-family:inherit;color:var(--d);background:#fafaf7;}
.perfil-form-grid .input:focus{outline:none;border-color:var(--a);background:#fff;}
.perfil-form-grid .input[readonly]{background:#f4f1ea;color:var(--ink2);}

.plano-pill{display:flex;align-items:center;gap:.7rem;padding:.7rem .9rem;background:#fff8ed;border:1.5px solid rgba(212,160,60,.3);border-radius:10px;margin-bottom:1rem;}
.plano-pill-emoji{font-size:1.3rem;}
.plano-pill-name{font-weight:800;color:var(--d);font-size:.95rem;}
.plano-pill-meta{font-size:.72rem;color:var(--ink3);}
.plano-pill-tag{margin-left:auto;padding:.22rem .55rem;background:var(--ok);color:#fff;border-radius:999px;font-size:.65rem;font-weight:800;letter-spacing:.05em;}

.saldo-list{display:flex;flex-direction:column;gap:.55rem;margin-bottom:1rem;}
.saldo-row{display:flex;align-items:center;gap:.7rem;padding:.55rem .7rem;background:#f8f6f0;border-radius:8px;}
.saldo-row .emoji{font-size:1.05rem;}
.saldo-row .name{flex:1;font-size:.82rem;color:var(--d);font-weight:600;}
.saldo-row .num{font-family:'DM Serif Display',serif;font-size:1.3rem;color:var(--a);font-style:italic;line-height:1;}
.saldo-validade{font-size:.72rem;color:var(--ink3);padding:.5rem .7rem;background:#f4f1ea;border-radius:8px;display:flex;align-items:center;gap:.4rem;}

.perfil-section{margin-top:1.3rem;}
.perfil-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.8rem;}
.perfil-section-head h3{font-family:'DM Serif Display',serif;font-size:1.2rem;color:var(--d);letter-spacing:-.01em;}

.purch-table{width:100%;background:#fff;border:1px solid #e8e4dc;border-radius:12px;overflow:hidden;}
.purch-table th{text-align:left;padding:.85rem 1.1rem;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);border-bottom:1px solid #e8e4dc;background:#faf9f5;}
.purch-table td{padding:.95rem 1.1rem;font-size:.85rem;color:var(--d);border-bottom:1px solid #f0ede5;vertical-align:middle;}
.purch-table tr:last-child td{border-bottom:none;}
.purch-table .purch-date{font-family:'JetBrains Mono',monospace;font-size:.76rem;color:var(--ink3);}
.purch-table .purch-amount{font-weight:700;color:var(--d);font-family:'DM Serif Display',serif;font-style:italic;font-size:1rem;}
.purch-status{display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .55rem;border-radius:999px;font-size:.68rem;font-weight:700;}
.purch-status.ok{background:#e8f5ed;color:#0b6846;}
.purch-status.pending{background:#fff4dc;color:#8a6410;}

.integ-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem;}
.integ-card{background:#fff;border:1.5px solid #e8e4dc;border-radius:12px;padding:1.1rem 1.2rem;display:flex;flex-direction:column;gap:.5rem;}
.integ-head{display:flex;align-items:center;gap:.65rem;}
.integ-logo{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.8rem;color:#fff;flex-shrink:0;}
.integ-logo.orcid{background:#A6CE39;color:#fff;}
.integ-logo.lattes{background:#0E2C4E;}
.integ-logo.gscholar{background:#4285F4;}
.integ-name{font-weight:700;color:var(--d);font-size:.9rem;}
.integ-state{font-size:.7rem;color:var(--ink3);}
.integ-state.connected{color:var(--ok);font-weight:700;}
.integ-btn{margin-top:.3rem;padding:.55rem;background:#f8f6f0;border:1.5px solid #e0dcd2;border-radius:7px;font-size:.75rem;font-weight:700;color:var(--d);cursor:pointer;font-family:inherit;}
.integ-btn.connected{background:#e8f5ed;border-color:#9FD4C0;color:var(--a);}

.pref-list{display:flex;flex-direction:column;gap:0;}
.pref-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid #f0ede5;gap:1rem;}
.pref-row:last-child{border-bottom:none;}
.pref-row .pref-body{flex:1;}
.pref-row .pref-name{font-weight:700;color:var(--d);font-size:.9rem;margin-bottom:.15rem;}
.pref-row .pref-desc{font-size:.77rem;color:var(--ink3);line-height:1.45;}
.pref-toggle{width:44px;height:24px;background:#d9d5c9;border-radius:999px;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0;}
.pref-toggle::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:left .2s;}
.pref-toggle.on{background:var(--a);}
.pref-toggle.on::after{left:22px;}

.danger-zone{background:#fef7f4;border:1.5px solid #f4d5c8;border-radius:12px;padding:1.3rem 1.5rem;margin-top:1.3rem;}
.danger-zone h3{font-family:'DM Serif Display',serif;font-size:1.05rem;color:#a03a1a;margin-bottom:.3rem;}
.danger-zone .sub{font-size:.78rem;color:#6b3a22;margin-bottom:1rem;}
.danger-actions{display:flex;gap:.7rem;flex-wrap:wrap;}
.btn-danger-out{padding:.6rem 1rem;background:#fff;border:1.5px solid #d4896a;color:#a03a1a;border-radius:8px;font-weight:700;font-size:.78rem;cursor:pointer;font-family:inherit;}
.btn-danger-out:hover{background:#fdecdf;}

@media(max-width:900px){.perfil-grid{grid-template-columns:1fr;}.integ-grid{grid-template-columns:1fr;}.perfil-hero-grid{grid-template-columns:1fr;text-align:center;}.perfil-cta{align-items:center;}}

.hidden{display:none !important;}
.flex{display:flex;}.items-center{align-items:center;}.justify-between{justify-content:space-between;}.gap-2{gap:.5rem;}.gap-3{gap:.75rem;}.gap-4{gap:1rem;}
.mt-1{margin-top:.5rem;}.mt-2{margin-top:1rem;}.mt-3{margin-top:1.5rem;}.mb-1{margin-bottom:.5rem;}.mb-2{margin-bottom:1rem;}.mb-3{margin-bottom:1.5rem;}
.text-muted{color:var(--ink3);}.text-sm{font-size:.78rem;}.text-xs{font-size:.7rem;}
.fw-700{font-weight:700;}

</style>
