/* ============================================
   ISentença — Design System (inspirado no exemplo)
   Regra do projeto: sem subpastas -> CSS na raiz
   ============================================ */

/* Reset */
*{ margin:0; padding:0; box-sizing:border-box; }

/* Anchor scrolling (evita o header sticky cobrindo o destino) */
html{
  scroll-behavior:smooth;
  scroll-padding-top:92px;
}

/* Fallback extra por elemento-alvo (funciona bem com âncoras #id) */
:target{
  scroll-margin-top:92px;
}

:root{
  --primary:#5A60FF;
  --primary-dark:#4A50E6;
  --primary-light:#6B70FF;
  --secondary:#9E44FF;
  --gradient-primary:linear-gradient(135deg,#5A60FF 0%,#9E44FF 100%);

  --neutral-900:#1A1A1A;
  --neutral-800:#2D2D2D;
  --neutral-700:#4A4A4A;
  --neutral-600:#777777;
  --neutral-400:#B0B0B0;
  --neutral-200:#E5E5E5;
  --neutral-100:#F5F5F5;
  --neutral-50:#FAFAFA;
  --white:#FFFFFF;

  --success:#35C66A;
  --warning:#FFB347;
  --error:#FF5B5B;

  --font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-size-xs:12px;
  --font-size-sm:14px;
  --font-size-base:16px;
  --font-size-lg:18px;
  --font-size-xl:20px;
  --font-size-2xl:24px;
  --font-size-3xl:30px;
  --font-size-4xl:36px;
  --font-size-5xl:48px;

  --spacing-xs:8px;
  --spacing-sm:12px;
  --spacing-md:16px;
  --spacing-lg:24px;
  --spacing-xl:32px;
  --spacing-2xl:48px;
  --spacing-3xl:64px;

  --radius-sm:6px;
  --radius-md:10px;
  --radius-lg:16px;
  --radius-xl:24px;
  --radius-full:9999px;

  --shadow-sm:0 2px 4px rgba(0,0,0,0.05);
  --shadow-md:0 4px 12px rgba(0,0,0,0.08);
  --shadow-lg:0 8px 24px rgba(0,0,0,0.12);
  --shadow-xl:0 16px 48px rgba(0,0,0,0.15);
}

body{
  font-family:var(--font-family);
  font-size:var(--font-size-base);
  line-height:1.6;
  color:var(--neutral-900);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 var(--spacing-lg);
}

/* Landing theme (Apple-ish, inspirado no exemplo) */
.page-landing{
  --primary:#0071E3;
  --primary-dark:#0060C3;
  --primary-light:#3A8BEA;
  --secondary:#0A84FF;
  --gradient-primary:linear-gradient(180deg,#0A84FF 0%,#0071E3 100%);

  --neutral-900:#0B0B0F;
  --neutral-800:#1C1C22;
  --neutral-700:#2C2C33;
  --neutral-600:#555763;
  --neutral-400:#A7A8B3;
  --neutral-200:#E6E6EB;
  --neutral-100:#F5F5F7;
  --neutral-50:#FAFAFC;
  --white:#FFFFFF;

  --shadow-sm:0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 10px 30px rgba(0,0,0,0.08);
  --shadow-lg:0 18px 60px rgba(0,0,0,0.10);
  --shadow-xl:0 30px 90px rgba(0,0,0,0.12);
}

/* Navbar */
.navbar{
  position:sticky;
  top:0;
  z-index:1000;
  padding:var(--spacing-md) 0;
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(0,0,0,0.06);
}
.nav-content{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:var(--spacing-md);
  flex-wrap:wrap;
}
.logo{
  display:flex;
  align-items:center;
  gap:var(--spacing-sm);
}
.logo-icon{
  width:40px;
  height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--primary);
  border-radius:12px;
  border:1px solid rgba(0,0,0,0.08);
  background:rgba(255,255,255,0.75);
  box-shadow:var(--shadow-sm);
}
.logo-icon svg{ width:24px; height:24px; }
.logo-text{
  font-size:var(--font-size-2xl);
  font-weight:800;
  color:var(--neutral-900);
  letter-spacing:-0.5px;
}
.logo-accent{
  color:var(--success);
}
.nav-links{
  display:flex;
  align-items:center;
  gap:var(--spacing-lg);
  flex-wrap:wrap;
  row-gap:var(--spacing-sm);
}
.nav-link{
  color:var(--neutral-700);
  text-decoration:none;
  font-weight:600;
  font-size:var(--font-size-sm);
  transition:color .2s ease, transform .2s ease, background .2s ease, border-color .2s ease;
}
.nav-link:hover{ color:var(--primary); }
.btn-ghost{
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(239,68,68,0.45);
  color:#dc2626;
  background:rgba(239,68,68,0.06);
}
.btn-ghost:hover{
  border-color:rgba(239,68,68,0.70);
  color:#b91c1c;
  background:rgba(239,68,68,0.12);
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:var(--spacing-md) var(--spacing-xl);
  border:none;
  border-radius:14px;
  cursor:pointer;
  text-decoration:none;
  font-weight:700;
  font-size:var(--font-size-base);
  white-space:nowrap;
  transition:transform .25s ease, box-shadow .25s ease, filter .2s ease;
}
.btn-primary{
  background:var(--primary);
  color:#fff;
  box-shadow:0 10px 26px rgba(0,113,227,0.22);
}
.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 44px rgba(0,113,227,0.26);
}
.btn-large{
  padding:var(--spacing-lg) var(--spacing-2xl);
  font-size:var(--font-size-lg);
}
.btn-small{
  padding:var(--spacing-sm) var(--spacing-lg);
  font-size:var(--font-size-sm);
  border-radius:12px;
}

/* Hero */
.hero{
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(10,132,255,0.08) 0%, rgba(10,132,255,0.00) 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(0,113,227,0.06) 0%, rgba(0,113,227,0.00) 55%),
    linear-gradient(180deg, var(--neutral-50) 0%, var(--white) 55%);
  padding:56px 0 36px;
}
.hero-content{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:var(--spacing-3xl);
  align-items:center;
}
.hero-title{
  font-size:var(--font-size-5xl);
  font-weight:800;
  line-height:1.12;
  letter-spacing:-1.2px;
  margin-bottom:var(--spacing-lg);
}
.hero-subtitle{
  font-size:var(--font-size-xl);
  color:var(--neutral-600);
  margin-bottom:var(--spacing-2xl);
  max-width:46ch;
}
.hero-subtitle-note{
  display:block;
  margin-top:10px;
  font-size:14px;
  color:var(--neutral-600);
}
.hero-highlight-pill{
  color:var(--primary);
  font-weight:800;
  padding:2px 8px;
  border-radius:999px;
  background:rgba(10,132,255,0.10);
  border:1px solid rgba(10,132,255,0.18);
  box-shadow:0 1px 0 rgba(255,255,255,0.6) inset;
  white-space:nowrap;
}
.hero-image{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:460px;
}
.hero-illustration{
  position:relative;
  width:100%;
  height:100%;
}
.illustration-circle{
  position:absolute;
  border-radius:50%;
  opacity:.10;
}
.circle-1{
  width:300px; height:300px;
  background:var(--gradient-primary);
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  animation:pulse 3s ease-in-out infinite;
}
.circle-2{
  width:200px; height:200px;
  background:var(--secondary);
  top:30%; right:20%;
  animation:pulse 3s ease-in-out infinite .5s;
}
.circle-3{
  width:150px; height:150px;
  background:var(--primary);
  bottom:20%; left:10%;
  animation:pulse 3s ease-in-out infinite 1s;
}
@keyframes pulse{
  0%,100%{ transform:scale(1); opacity:.10; }
  50%{ transform:scale(1.1); opacity:.15; }
}

/* Hero card (lado direito) */
.clinic-cta-card{
  position:absolute;
  right:0;
  top:0;
  margin:var(--spacing-xl);
  width:min(380px,42vw);
  background:rgba(255,255,255,0.72);
  border:1px solid rgba(0,0,0,0.08);
  backdrop-filter:blur(16px);
  border-radius:18px;
  padding:var(--spacing-xl);
  box-shadow:var(--shadow-md);
}
.clinic-cta-title{
  font-size:var(--font-size-xl);
  font-weight:800;
  letter-spacing:-0.4px;
  margin:0 0 var(--spacing-sm);
}
.clinic-cta-sub{
  color:var(--neutral-600);
  margin:0 0 var(--spacing-md);
  line-height:1.5;
}
.clinic-cta-bullets{
  list-style:none;
  padding:0;
  margin:0 0 var(--spacing-md);
  color:var(--neutral-700);
  font-size:var(--font-size-sm);
}
.clinic-cta-bullets li{
  display:flex;
  align-items:flex-start;
  gap:.55rem;
  margin:.4rem 0;
}
.clinic-cta-bullets li::before{
  content:"";
  width:18px; height:18px;
  margin-top:2px;
  border-radius:6px;
  background:rgba(0,113,227,0.12);
  border:1px solid rgba(0,113,227,0.22);
  box-shadow:0 1px 0 rgba(255,255,255,0.6) inset;
  flex:0 0 auto;
}
.clinic-cta-actions{ display:flex; gap:var(--spacing-sm); flex-wrap:wrap; }

/* Sections */
.section-title{
  font-size:var(--font-size-4xl);
  font-weight:800;
  text-align:center;
  letter-spacing:-0.5px;
  margin-bottom:32px;
}
.section-subtitle{
  text-align:center;
  color:var(--neutral-600);
  font-size:var(--font-size-lg);
  max-width:760px;
  margin:0 auto var(--spacing-2xl);
}

/* How works */
.how-works{ padding:44px 0; background:var(--white); }
.steps-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}
.step-card{
  text-align:left;
  padding:26px 26px 24px;
  border-radius:20px;
  background:linear-gradient(180deg, rgba(255,255,255,0.98) 0%, rgba(245,245,247,0.85) 100%);
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:var(--shadow-md);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.step-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-lg);
  border-color:rgba(0,113,227,0.22);
}
.step-number{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,113,227,0.10);
  color:var(--primary);
  font-weight:800;
  font-size:13px;
  margin-bottom:14px;
}
.step-icon{
  width:56px;
  height:56px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:16px;
  margin:4px 0 14px;
  background:rgba(0,113,227,0.08);
  border:1px solid rgba(0,113,227,0.16);
  font-size:26px;
}
.step-title{
  font-size:18px;
  font-weight:800;
  letter-spacing:-0.2px;
  margin-bottom:10px;
}
.step-description{
  font-size:14px;
  color:var(--neutral-600);
}

/* Benefits */
.benefits{ padding:44px 0; background:var(--white); }
.benefits-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:var(--spacing-xl);
}
.benefit-item{ text-align:center; padding:var(--spacing-xl); }
.benefit-icon{ font-size:40px; margin-bottom:var(--spacing-md); }
.benefit-title{ font-size:var(--font-size-lg); font-weight:800; margin-bottom:var(--spacing-sm); }
.benefit-text{ color:var(--neutral-600); font-size:var(--font-size-sm); line-height:1.6; }

/* “Partners” blocks (reaproveitado como seções Advogados/Cidadãos) */
.partners{
  padding:52px 0;
  background:linear-gradient(180deg, var(--white) 0%, var(--neutral-50) 100%);
}
.partners.trainer{
  background:linear-gradient(180deg, var(--neutral-50) 0%, var(--white) 100%);
}
.partners-header{ text-align:center; margin-bottom:var(--spacing-2xl); }
.partners-report-card{
  background:rgba(255,255,255,0.75);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:22px;
  padding:22px;
  box-shadow:var(--shadow-md);
  backdrop-filter:blur(14px);
}
.partners-report-title{
  font-weight:800;
  letter-spacing:-0.3px;
  font-size:18px;
  margin-bottom:14px;
}
.partners-report-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.partners-report-item{
  background:rgba(245,245,247,0.7);
  border:1px solid rgba(0,0,0,0.06);
  border-radius:16px;
  padding:14px;
}
.partners-report-kicker{
  font-size:12px;
  font-weight:800;
  color:var(--neutral-700);
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:6px;
}
.partners-report-text{
  font-size:14px;
  color:var(--neutral-600);
  line-height:1.5;
}

/* CTA */
.cta-section{ padding:44px 0; background:var(--white); }
.cta-box{
  background:rgba(245,245,247,0.88);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:var(--radius-xl);
  text-align:center;
  color:var(--neutral-900);
  box-shadow:var(--shadow-lg);
  backdrop-filter:blur(16px);
  padding:var(--spacing-3xl);
}
.cta-title{
  font-size:var(--font-size-4xl);
  font-weight:800;
  margin-bottom:var(--spacing-md);
  letter-spacing:-0.5px;
}
.cta-subtitle{
  font-size:var(--font-size-xl);
  margin-bottom:var(--spacing-2xl);
  color:var(--neutral-600);
}

/* Footer */
.footer{
  background:var(--neutral-100);
  color:var(--neutral-700);
  border-top:1px solid rgba(0,0,0,0.06);
  padding:var(--spacing-2xl) 0 var(--spacing-lg);
}
.footer-content{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:var(--spacing-lg);
  margin-bottom:var(--spacing-xl);
  flex-wrap:wrap;
}
.footer-slogan{ color:var(--neutral-600); font-size:var(--font-size-sm); }
.footer-links{ display:flex; gap:var(--spacing-xl); flex-wrap:wrap; }
.footer-link{ color:var(--neutral-700); text-decoration:none; font-size:var(--font-size-sm); }
.footer-link:hover{ color:var(--neutral-900); }
.footer-bottom{
  border-top:1px solid rgba(0,0,0,0.08);
  padding-top:var(--spacing-lg);
  text-align:center;
  color:var(--neutral-600);
  font-size:var(--font-size-sm);
}

/* Forms (usado nas telas internas) */
.form-input{
  width:100%;
  padding:var(--spacing-sm) var(--spacing-md);
  font-size:var(--font-size-base);
  font-family:var(--font-family);
  color:var(--neutral-900);
  background:var(--white);
  border:1px solid var(--neutral-200);
  border-radius:14px;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.form-input:focus{
  outline:none;
  border-color:rgba(0,113,227,0.45);
  box-shadow:0 0 0 4px rgba(10,132,255,0.14);
}
.form-input::placeholder{ color:var(--neutral-400); }

.form-textarea{
  width:100%;
  min-height:160px;
  resize:vertical;
  padding:var(--spacing-sm) var(--spacing-md);
  font-size:var(--font-size-base);
  font-family:var(--font-family);
  line-height:1.4;
  color:var(--neutral-900);
  background:var(--white);
  border:1px solid var(--neutral-200);
  border-radius:14px;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.form-textarea:focus{
  outline:none;
  border-color:rgba(0,113,227,0.45);
  box-shadow:0 0 0 4px rgba(10,132,255,0.14);
}
.form-textarea::placeholder{ color:var(--neutral-400); }

.form-hint{
  display:block;
  margin-top:6px;
  font-size:12px;
  color:var(--neutral-600);
}

/* ============================================
   IA Debug Console + Modal Progress (global)
   ============================================ */

/* Status: servidores IA (card de status no topo do caso) */
.ai-server-status{
  background:linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(245,245,247,0.78) 100%);
  border:1px solid rgba(53,198,106,0.22);
}

.ai-server-status-inner{
  display:flex;
  align-items:center;
  gap:14px;
}

.ai-server-icon{
  width:64px;
  height:64px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--success);
  background:rgba(53,198,106,0.10);
  border:1px solid rgba(53,198,106,0.22);
  box-shadow:0 10px 26px rgba(53,198,106,0.10);
  flex:0 0 auto;
}

.ai-server-icon svg{
  width:34px;
  height:34px;
}

.ai-server-status-title{
  font-weight:900;
  letter-spacing:-0.3px;
  color:var(--neutral-900);
  margin-bottom:2px;
}

.ai-server-status-line{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  color:var(--neutral-700);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:12px;
}

.ai-status-dot{
  width:12px;
  height:12px;
  border-radius:999px;
  background:var(--success);
  box-shadow:0 0 0 6px rgba(53,198,106,0.16);
  animation:aiStatusPulse 1.6s ease-in-out infinite;
}

@keyframes aiStatusPulse{
  0%,100%{ transform:scale(1); box-shadow:0 0 0 6px rgba(53,198,106,0.16); }
  50%{ transform:scale(1.05); box-shadow:0 0 0 10px rgba(53,198,106,0.10); }
}

.ai-debug-toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:6px 0 12px;
}

.ai-debug-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}

.ai-debug-pane{
  background:rgba(255,255,255,0.72);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:16px;
  padding:12px;
  box-shadow:var(--shadow-sm);
}

.ai-debug-pane-title{
  font-size:12px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--neutral-700);
  margin-bottom:8px;
}

.ai-debug-pre{
  background:rgba(11,11,15,0.92);
  color:#EDEDED;
  border-radius:14px;
  border:1px solid rgba(255,255,255,0.10);
  padding:12px;
  font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size:12px;
  line-height:1.45;
  white-space:pre-wrap;
  overflow:auto;
  max-height:42vh;
}

.ai-debug-pre-compact{
  max-height:18vh;
}

.ai-debug-history{
  margin-top:14px;
}

@media (max-width: 968px){
  .ai-debug-grid{ grid-template-columns:1fr; }
  .ai-debug-pre{ max-height:38vh; }
}

/* Modal full-screen travando a UI */
.ai-modal-overlay{
  position:fixed;
  inset:0;
  z-index:9999;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:rgba(0,0,0,0.55);
  backdrop-filter:blur(6px);
}

.ai-modal-overlay.is-open{ display:flex; }

.ai-modal{
  width:min(860px, 96vw);
  background:rgba(255,255,255,0.92);
  border:1px solid rgba(0,0,0,0.10);
  border-radius:22px;
  box-shadow:var(--shadow-xl);
  padding:22px;
}

.ai-modal-title{
  font-weight:900;
  letter-spacing:-0.3px;
  font-size:18px;
  margin:0 0 10px;
  color:var(--neutral-900);
}

.ai-modal-sub{
  margin:0 0 14px;
  color:var(--neutral-600);
  font-size:14px;
}

.ai-progress-wrap{
  background:rgba(0,0,0,0.06);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:999px;
  height:18px;
  overflow:hidden;
}

.ai-progress-bar{
  height:100%;
  width:10%;
  border-radius:999px;
  background:var(--gradient-primary);
  transition:width .25s ease;
}

.ai-modal-note{
  margin-top:12px;
  color:var(--neutral-700);
  font-size:13px;
}

.ai-modal-note strong{
  font-weight:900;
}

.ai-body-locked{
  overflow:hidden !important;
}

/* Responsive */
@media (max-width: 968px){
  .hero-content{ grid-template-columns:1fr; text-align:center; }
  .hero-title{ font-size:var(--font-size-4xl); }
  .hero-subtitle{ margin-left:auto; margin-right:auto; }
  .steps-grid{ grid-template-columns:1fr; gap:14px; }
  .benefits-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .partners-report-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
  .clinic-cta-card{ position:static; width:100%; margin:var(--spacing-lg) 0 0; }
}
@media (max-width: 640px){
  .container{ padding:0 var(--spacing-md); }
  .hero-title{ font-size:var(--font-size-3xl); }
  .hero-subtitle{ font-size:var(--font-size-lg); }
  .benefits-grid{ grid-template-columns:1fr; }
  .partners-report-grid{ grid-template-columns:1fr; }
  .cta-box{ padding:var(--spacing-2xl); }
  .nav-link{ white-space:normal; overflow-wrap:anywhere; }
}


