/* ============================================================
   Portal de TI IFTO — Design System v5.0 "Open World 2026"
   Bento Grid · Glassmorphism · Gamification · Dark Premium
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;0,14..32,900&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ─────────────────────────────────────────────────────────────
   DESIGN TOKENS
───────────────────────────────────────────────────────────── */
html, body { 
  overflow-x: hidden; 
  width: 100%;
  position: relative;
  margin: 0;
  padding: 0;
}
:root {
  /* Backgrounds (Soften/Dimmed Dark Mode) */
  --bg:       #11141D;
  --bg-2:     #171B26;
  --bg-3:     #1E2331;
  --surface:  #1D2331;
  --surface-2:#242C3E;
  --surface-3:#2C364B;

  /* Green (Vibrant Emerald / IFTO Premium) */
  --green:         #00C853;
  --green-bright:  #69F0AE;
  --green-dim:     #00A444;
  --green-glow:    rgba(0,200,83,0.18);
  --green-glow-lg: rgba(0,200,83,0.10);
  --green-subtle:  rgba(0,200,83,0.06);
  --green-border:  rgba(0,200,83,0.25);

  /* Blue (Slate Blue) */
  --blue:        #6B8BAE;
  --blue-dim:    #4D6682;
  --blue-glow:   rgba(107,139,174,0.10);
  --blue-subtle: rgba(107,139,174,0.04);

  /* Purple (Dusty Purple) */
  --purple:        #8B80A5;
  --purple-dim:    #6A6182;
  --purple-glow:   rgba(139,128,165,0.10);
  --purple-subtle: rgba(139,128,165,0.04);

  /* Amber (Muted Gold) */
  --amber:        #B59052;
  --amber-subtle: rgba(181,144,82,0.04);

  /* Red (Muted Terracotta) */
  --red:        #B26A6A;
  --red-dim:    #8E5151;
  --red-glow:   rgba(178,106,106,0.10);
  --red-subtle: rgba(178,106,106,0.04);

  /* Text */
  --tx-1: #E8EDF5;
  --tx-2: #8899B2;
  --tx-3: #7E8DAA; /* Aumentado contraste de #3D5070 para melhor leitura */

  /* Borders */
  --br:   rgba(255,255,255,0.06);
  --br-2: rgba(255,255,255,0.10);
  --br-3: rgba(255,255,255,0.15);

  /* Typography */
  --font:  'Inter', system-ui, -apple-system, sans-serif;
  --mono:  'JetBrains Mono', 'Fira Code', monospace;

  /* Radius */
  --r-xs:  4px;
  --r-sm:  8px;
  --r:     12px;
  --r-md:  16px;
  --r-lg:  20px;
  --r-xl:  24px;
  --r-2xl: 32px;
  --r-full:9999px;

  /* Spacing */
  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem; --s5:1.25rem;
  --s6:1.5rem; --s8:2rem;  --s10:2.5rem; --s12:3rem; --s16:4rem;

  /* Transitions */
  --ease:     cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,0,.2,1);
  --t1: 120ms; --t2: 200ms; --t3: 320ms;

  /* Layout */
  --nav-h: 64px;
  --container: 1340px;
  --sidebar-w: 260px;
}

/* Light Mode */
:root[data-theme="light"] {
  --bg: #F5F7FA; --bg-2: #EAEFF6; --bg-3: #FFFFFF;
  --surface: #FFFFFF; --surface-2: #F5F7FA; --surface-3: #EEF2F8;
  --br: rgba(0,0,0,0.07); --br-2: rgba(0,0,0,0.11); --br-3: rgba(0,0,0,0.16);
  --tx-1: #0D1117; --tx-2: #374151; --tx-3: #6B7280;
  --green-glow: rgba(34,197,94,0.10);
  --green-subtle: rgba(34,197,94,0.05);
}

/* ─────────────────────────────────────────────────────────────
   RESET
───────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font);background:var(--bg);color:var(--tx-1);line-height:1.6;min-height:100vh;transition:background var(--t3) var(--ease),color var(--t3) var(--ease)}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit;font-size:inherit}

/* Scrollbar */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--br-2);border-radius:var(--r-full)}
::-webkit-scrollbar-thumb:hover{background:var(--tx-3)}

/* Utilities */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--s6)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

/* ─────────────────────────────────────────────────────────────
   ANIMATIONS
───────────────────────────────────────────────────────────── */
@keyframes up   {from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade {from{opacity:0}to{opacity:1}}
@keyframes spin {from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes pulse-green {0%,100%{box-shadow:0 0 0 0 var(--green-glow)}50%{box-shadow:0 0 0 8px var(--green-glow)}}
@keyframes shimmer {0%{background-position:-600px 0}100%{background-position:600px 0}}
@keyframes spotlight-in {from{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}
@keyframes xp-fill {from{width:0}to{width:var(--xp-pct)}}
@keyframes slide-in {from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes slide-out{to{transform:translateX(100%);opacity:0}}
@keyframes bounce-in{0%{transform:scale(.7);opacity:0}60%{transform:scale(1.08)}100%{transform:scale(1);opacity:1}}

/* ═══════════════════════════════════════════════════════════
   NAVBAR
═══════════════════════════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:300;
  height:var(--nav-h);
  background:rgba(17,20,29,0.92);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--br);
}
:root[data-theme="light"] .navbar{background:rgba(245,247,250,0.9)}

.navbar .container{display:flex;align-items:center;justify-content:space-between;height:100%;gap:var(--s4)}

.navbar-brand{display:flex;align-items:center;gap:var(--s3);flex-shrink:0}
.nav-logo{
  width:36px;height:36px;
  background:linear-gradient(135deg,var(--green),var(--green-dim));
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:.78rem;color:#000;letter-spacing:-.5px;
  box-shadow:0 0 20px var(--green-glow);
}
.nav-title{font-weight:800;font-size:.95rem;line-height:1.1;color:var(--tx-1)}
.nav-sub{font-size:.65rem;color:var(--tx-3);font-weight:500}

/* XP Bar na navbar */
.nav-xp{
  display:flex;align-items:center;gap:var(--s3);
  padding:var(--s2) var(--s4);
  background:var(--purple-subtle);
  border:1px solid rgba(167,139,250,0.15);
  border-radius:var(--r-full);
  cursor:pointer;
  transition:all var(--t2) var(--ease);
}
.nav-xp:hover{background:rgba(167,139,250,0.14);border-color:rgba(167,139,250,0.3)}
.nav-xp-icon{font-size:1rem}
.nav-xp-info{line-height:1.1}
.nav-xp-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--purple);margin-bottom:2px}
.nav-xp-bar-wrap{width:72px;height:4px;background:var(--br-2);border-radius:var(--r-full);overflow:hidden}
.nav-xp-bar-fill{height:100%;background:linear-gradient(90deg,var(--purple-dim),var(--purple));border-radius:var(--r-full);transition:width .6s var(--ease)}

/* Spotlight trigger */
.nav-spotlight-btn{
  display:flex;align-items:center;gap:var(--s2);
  padding:var(--s2) var(--s4);
  background:var(--surface-2);
  border:1px solid var(--br-2);
  border-radius:var(--r-full);
  font-size:.8rem;color:var(--tx-2);
  transition:all var(--t2) var(--ease);
  cursor:pointer;
}
.nav-spotlight-btn:hover{border-color:var(--green-border);color:var(--tx-1)}
.nav-spotlight-kbd{
  display:inline-flex;align-items:center;justify-content:center;
  padding:1px 6px;
  background:var(--br);border:1px solid var(--br-2);
  border-radius:4px;font-size:.65rem;font-family:var(--mono);color:var(--tx-3);
}

.navbar-right{display:flex;align-items:center;gap:var(--s3)}
.btn-theme{
  width:34px;height:34px;border-radius:var(--r-full);
  background:var(--surface-2);border:1px solid var(--br);
  color:var(--tx-2);display:flex;align-items:center;justify-content:center;
  font-size:.85rem;transition:all var(--t2) var(--ease);
}
.btn-theme:hover{background:var(--green-subtle);border-color:var(--green-border);color:var(--green)}
.btn-admin-nav{
  display:flex;align-items:center;gap:var(--s2);
  padding:6px 14px;
  background:var(--green-subtle);
  border:1px solid var(--green-border);
  border-radius:var(--r-full);
  font-size:.78rem;font-weight:700;color:var(--green);
  transition:all var(--t2) var(--ease);
}
.btn-admin-nav:hover{background:var(--green);color:#000;box-shadow:0 0 20px var(--green-glow)}

/* ═══════════════════════════════════════════════════════════
   SPOTLIGHT / COMMAND+K
═══════════════════════════════════════════════════════════ */
.spotlight-overlay{
  position:fixed;inset:0;z-index:900;
  background:rgba(0,0,0,0.75);
  backdrop-filter:blur(8px);
  display:flex;align-items:flex-start;justify-content:center;
  padding-top:12vh;
  opacity:0;visibility:hidden;
  transition:opacity var(--t2) var(--ease),visibility var(--t2) var(--ease);
}
.spotlight-overlay.open{opacity:1;visibility:visible}

.spotlight-box{
  width:100%;max-width:640px;
  background:var(--surface-2);
  border:1px solid var(--br-2);
  border-radius:var(--r-xl);
  box-shadow:0 40px 100px rgba(0,0,0,.7), 0 0 0 1px var(--green-glow);
  overflow:hidden;
  animation:spotlight-in var(--t3) var(--ease-out) both;
}
.spotlight-input-wrap{
  display:flex;align-items:center;gap:var(--s3);
  padding:var(--s4) var(--s5);
  border-bottom:1px solid var(--br);
}
.spotlight-icon{color:var(--green);font-size:1.1rem;flex-shrink:0}
.spotlight-input{
  flex:1;background:none;border:none;outline:none;
  font:600 1.05rem/1 var(--font);color:var(--tx-1);
}
.spotlight-input::placeholder{color:var(--tx-3);font-weight:400}
.spotlight-esc{font-size:.65rem;color:var(--tx-3);font-family:var(--mono);flex-shrink:0}

.spotlight-results{max-height:400px;overflow-y:auto}
.spotlight-group-label{
  padding:var(--s3) var(--s5) var(--s2);
  font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:var(--tx-3);
}
.spotlight-item{
  display:flex;align-items:center;gap:var(--s3);
  padding:var(--s3) var(--s5);
  cursor:pointer;transition:background var(--t1) var(--ease);
  border-radius:0;
}
.spotlight-item:hover,.spotlight-item.focused{background:var(--surface-3)}
.spotlight-item-icon{
  width:32px;height:32px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:.9rem;flex-shrink:0;
}
.spotlight-item-icon.green{background:var(--green-subtle)}
.spotlight-item-icon.blue {background:var(--blue-subtle)}
.spotlight-item-icon.purple{background:var(--purple-subtle)}
.spotlight-item-body{flex:1;min-width:0}
.spotlight-item-name{font-size:.88rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.spotlight-item-sub{font-size:.72rem;color:var(--tx-2)}
.spotlight-item-badge{
  padding:2px 8px;border-radius:var(--r-full);
  font-size:.62rem;font-weight:700;flex-shrink:0;
}
.spotlight-empty{
  padding:var(--s10) var(--s5);
  text-align:center;color:var(--tx-3);font-size:.88rem;
}
.spotlight-footer{
  display:flex;align-items:center;gap:var(--s4);
  padding:var(--s3) var(--s5);
  border-top:1px solid var(--br);
  font-size:.68rem;color:var(--tx-3);
}
.spotlight-footer kbd{
  padding:1px 6px;background:var(--br);border:1px solid var(--br-2);
  border-radius:4px;font-family:var(--mono);
}

/* ═══════════════════════════════════════════════════════════
   HERO + SEARCH
═══════════════════════════════════════════════════════════ */
.hero{
  padding-top:calc(var(--nav-h) + 4.5rem);
  padding-bottom:3.5rem;
  position:relative;overflow:hidden;text-align:center;
}
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 55% at 50% -5%, rgba(34,197,94,.13) 0%, transparent 60%),
    radial-gradient(ellipse 55% 40% at 90% 90%, rgba(96,165,250,.06) 0%, transparent 55%);
}
.hero-grid-bg{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:28px 28px;
  mask-image:radial-gradient(ellipse 65% 65% at 50% 50%,black 20%,transparent 100%);
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:var(--s2);
  padding:4px 14px;
  background:var(--green-subtle);border:1px solid var(--green-border);
  color:var(--green-bright);border-radius:var(--r-full);
  font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:var(--s5);
  animation:up .6s var(--ease-out) both;
}
.hero-title{
  font-size:clamp(2.5rem,5.5vw,4.2rem);
  font-weight:900;line-height:1.1;letter-spacing:-.04em;
  margin-bottom:var(--s4);
  animation:up .65s .08s var(--ease-out) both;
}
.hero-title em{
  font-style:normal;
  background:linear-gradient(135deg,var(--green),var(--green-bright) 60%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-sub{
  font-size:1.05rem;color:var(--tx-2);max-width:540px;margin:0 auto var(--s6);
  animation:up .7s .14s var(--ease-out) both;
}

/* Search Bar */
.hero-search-wrap{
  max-width:580px;margin:0 auto var(--s6);
  position:relative;
  animation:up .72s .18s var(--ease-out) both;
}
.hero-search-inner{
  display:flex;align-items:center;gap:var(--s3);
  padding:var(--s4) var(--s5);
  background:var(--surface-2);
  border:1px solid var(--br-2);
  border-radius:var(--r-xl);
  cursor:text;transition:all var(--t2) var(--ease);
  box-shadow:0 8px 40px rgba(0,0,0,.3);
}
.hero-search-inner:hover{border-color:var(--green-border)}
.hero-search-inner.focused{border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow),0 8px 40px rgba(0,0,0,.3)}
.hero-search-icon{color:var(--green);flex-shrink:0}
.hero-search-input{
  flex:1;background:none;border:none;outline:none;
  font:500 .95rem/1 var(--font);color:var(--tx-1);
}
.hero-search-input::placeholder{color:var(--tx-3)}
.hero-search-kbd{
  display:flex;align-items:center;gap:4px;
  font-size:.65rem;color:var(--tx-3);font-family:var(--mono);flex-shrink:0;
}
.hero-search-kbd kbd{
  padding:2px 6px;background:var(--br);
  border:1px solid var(--br-2);border-radius:4px;
}

/* Hero Stats Strip */
.hero-stats{
  display:inline-flex;align-items:center;
  background:var(--surface-2);border:1px solid var(--br);
  border-radius:var(--r-full);overflow:hidden;
  animation:up .75s .22s var(--ease-out) both;
}
.hero-stat{
  display:flex;align-items:center;gap:var(--s2);
  padding:var(--s2) var(--s5);
  border-right:1px solid var(--br);font-size:.8rem;color:var(--tx-2);
}
.hero-stat:last-child{border-right:none}
.hero-stat strong{color:var(--tx-1);font-weight:800;font-size:.9rem}

/* ═══════════════════════════════════════════════════════════
   BENTO GRID SECTIONS
═══════════════════════════════════════════════════════════ */
.section{padding:var(--s10) 0}
.section-label{
  display:flex;align-items:center;gap:var(--s3);
  margin-bottom:var(--s6);
}
.section-label-icon{
  width:32px;height:32px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;font-size:.9rem;
}
.ico-green{background:var(--green-subtle)}
.ico-blue{background:var(--blue-subtle)}
.ico-purple{background:var(--purple-subtle)}
.section-label-title{
  font-size:1.15rem;font-weight:800;letter-spacing:-.02em;
}
.section-label-count{
  margin-left:var(--s2);display:inline-flex;align-items:center;
  padding:2px 10px;background:var(--surface-2);border:1px solid var(--br);
  border-radius:var(--r-full);font-size:.68rem;font-weight:600;color:var(--tx-3);
}

/* ═══════════════════════════════════════════════════════════
   MISSIONS SECTION (Bento Grid)
═══════════════════════════════════════════════════════════ */
.missions-bento{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:var(--s5);
}

/* Mission Card */
.mission-card{
  position:relative;
  background:var(--surface);
  border:1px solid var(--br);
  border-radius:var(--r-lg);
  padding:var(--s5);
  cursor:pointer;
  transition:transform var(--t2) var(--ease),border-color var(--t2) var(--ease),box-shadow var(--t2) var(--ease);
  overflow:hidden;
}
.mission-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,var(--green-glow-lg) 0%,transparent 60%);
  opacity:0;transition:opacity var(--t2) var(--ease);pointer-events:none;
}
.mission-card:hover{
  transform:translateY(-4px);
  border-color:var(--green-border);
  box-shadow:0 16px 48px rgba(0,0,0,.4),0 0 0 1px var(--green-glow);
}
.mission-card:hover::before{opacity:1}
.mission-card.completed{border-color:var(--green-border);background:var(--surface-2)}
.mission-card.completed::after{
  content:'✓';position:absolute;top:var(--s4);right:var(--s4);
  width:28px;height:28px;background:var(--green);border-radius:var(--r-full);
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:800;color:#000;
  animation:bounce-in .4s var(--ease-out) both;
}

.mission-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--s4)}
.mission-icon{
  width:44px;height:44px;border-radius:var(--r-md);font-size:1.35rem;
  display:flex;align-items:center;justify-content:center;
  background:var(--green-subtle);border:1px solid var(--green-border);flex-shrink:0;
}
.mission-top-right{display:flex;align-items:center;gap:var(--s2)}
.btn-mission-share{
  width:24px;height:24px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--tx-3);transition:all var(--t1) var(--ease);
}
.btn-mission-share:hover{background:var(--surface-2);color:var(--green)}
.mission-xp{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:var(--r-full);
  background:var(--purple-subtle);border:1px solid rgba(148,134,194,.2);
  font-size:.7rem;font-weight:800;color:var(--purple);font-family:var(--mono);
}

.mission-title{font-size:1.05rem;font-weight:800;margin-bottom:var(--s2);line-height:1.25;letter-spacing:-.02em}
.mission-desc{font-size:.82rem;color:var(--tx-2);line-height:1.55;margin-bottom:var(--s4)}

.mission-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--s3)}
.mission-badges{display:flex;align-items:center;gap:var(--s2)}
.badge-dif, .badge-time{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:var(--r-full);font-size:.65rem;font-weight:700;
}
.badge-dif.facil    {background:var(--green-subtle);color:var(--green-bright);border:1px solid var(--green-border)}
.badge-dif.medio    {background:var(--amber-subtle);color:var(--amber);border:1px solid rgba(251,191,36,.2)}
.badge-dif.avancado {background:var(--red-subtle);color:var(--red);border:1px solid var(--red-glow)}
.badge-time{background:var(--surface-2);color:var(--tx-2);border:1px solid var(--br)}
.mission-progress{
  display:flex;align-items:center;gap:var(--s2);font-size:.72rem;color:var(--tx-3);
}
.mission-progress .dots{display:flex;gap:4px}
.mission-progress .dot{
  width:8px;height:8px;border-radius:var(--r-full);
  background:var(--br-2);transition:background var(--t2) var(--ease);
}
.mission-progress .dot.done{background:var(--green)}

/* ═══════════════════════════════════════════════════════════
   STEPPER MODAL (Missão interativa)
═══════════════════════════════════════════════════════════ */
.stepper-overlay{
  position:fixed;inset:0;z-index:800;
  background:rgba(0,0,0,.82);backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;padding:var(--s4);
  opacity:0;visibility:hidden;transition:opacity var(--t3) var(--ease),visibility var(--t3) var(--ease);
}
.stepper-overlay.open{opacity:1;visibility:visible}

.stepper-modal{
  width:100%;max-width:700px;max-height:90vh;
  background:var(--surface);border:1px solid var(--br-2);border-radius:var(--r-xl);
  display:flex;flex-direction:column;overflow:hidden;
  box-shadow:0 48px 120px rgba(0,0,0,.7);
  transform:scale(.93) translateY(16px);
  transition:transform var(--t3) var(--ease-out);
}
.stepper-overlay.open .stepper-modal{transform:scale(1) translateY(0)}

/* Stepper Header */
.stepper-header{
  padding:var(--s5) var(--s6);border-bottom:1px solid var(--br);flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;gap:var(--s4);
}
.stepper-header-left{flex:1}
.stepper-mission-label{
  font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--green);margin-bottom:4px;
}
.stepper-title{font-size:1.1rem;font-weight:800;letter-spacing:-.02em}
.stepper-xp-badge{
  display:inline-flex;align-items:center;gap:var(--s2);
  padding:var(--s2) var(--s4);
  background:var(--purple-subtle);border:1px solid rgba(167,139,250,.2);
  border-radius:var(--r-full);font-size:.75rem;font-weight:800;color:var(--purple);
  flex-shrink:0;
}
.stepper-close{
  width:32px;height:32px;border-radius:var(--r-sm);color:var(--tx-2);
  display:flex;align-items:center;justify-content:center;
  transition:all var(--t1) var(--ease);flex-shrink:0;
}
.stepper-close:hover{background:var(--surface-3);color:var(--tx-1)}

/* Step progress bar */
.stepper-progress-bar{
  height:3px;background:var(--br);flex-shrink:0;
}
.stepper-progress-fill{
  height:100%;background:linear-gradient(90deg,var(--green-dim),var(--green));
  transition:width .5s var(--ease);
}

/* Stepper body */
.stepper-body{flex:1;overflow-y:auto;padding:var(--s8) var(--s6)}

/* Step dots navigation */
.stepper-dots{
  display:flex;align-items:center;justify-content:center;gap:var(--s3);
  margin-bottom:var(--s8);
}
.stepper-dot{
  display:flex;flex-direction:column;align-items:center;gap:var(--s2);cursor:pointer;
}
.stepper-dot-circle{
  width:34px;height:34px;border-radius:var(--r-full);border:2px solid var(--br-2);
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:800;color:var(--tx-3);
  transition:all var(--t2) var(--ease);font-family:var(--mono);
}
.stepper-dot.active  .stepper-dot-circle{border-color:var(--green);color:var(--green);background:var(--green-subtle);box-shadow:0 0 12px var(--green-glow)}
.stepper-dot.done    .stepper-dot-circle{border-color:var(--green);background:var(--green);color:#000}
.stepper-dot-label{font-size:.6rem;font-weight:600;color:var(--tx-3);text-align:center;max-width:64px;line-height:1.2}
.stepper-dot.active .stepper-dot-label{color:var(--green)}
.stepper-dot.done   .stepper-dot-label{color:var(--tx-2)}
.stepper-dot-line{width:40px;height:1px;background:var(--br-2);margin-bottom:20px;transition:background var(--t2) var(--ease)}
.stepper-dot-line.done{background:var(--green)}

/* Current step content */
.step-content{}
.step-number{
  font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
  color:var(--tx-3);margin-bottom:var(--s3);font-family:var(--mono);
}
.step-title{
  font-size:1.5rem;font-weight:900;letter-spacing:-.03em;margin-bottom:var(--s4);
  background:linear-gradient(135deg,var(--tx-1),var(--tx-2));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.step-img{
  width:100%;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--br);margin-bottom:var(--s5);
  background:var(--surface-2);min-height:140px;
  display:flex;align-items:center;justify-content:center;
}
.step-img img{width:100%;height:auto;display:block}
.step-img-placeholder{
  display:flex;flex-direction:column;align-items:center;gap:var(--s3);
  padding:var(--s10);color:var(--tx-3);
}
.step-img-placeholder svg{opacity:.4}
.step-resumo{
  font-size:.95rem;line-height:1.75;color:var(--tx-2);margin-bottom:var(--s4);
}
.step-dica{
  display:flex;align-items:flex-start;gap:var(--s3);
  padding:var(--s4);border-radius:var(--r-md);
  background:rgba(251,191,36,.06);border:1px solid rgba(251,191,36,.15);
  font-size:.82rem;color:var(--tx-2);line-height:1.55;
}
.step-dica-icon{font-size:1rem;flex-shrink:0;margin-top:1px}

/* Stepper Footer */
.stepper-footer{
  padding:var(--s4) var(--s6);border-top:1px solid var(--br);flex-shrink:0;
  display:flex;align-items:center;justify-content:space-between;gap:var(--s3);
  background:var(--surface-2);
}
.stepper-nav-btns{display:flex;gap:var(--s3)}
.btn-step-prev,.btn-step-next{
  display:inline-flex;align-items:center;gap:var(--s2);
  padding:var(--s2) var(--s5);border-radius:var(--r-full);
  font-size:.85rem;font-weight:700;transition:all var(--t2) var(--ease);
}
.btn-step-prev{
  background:var(--surface-3);border:1px solid var(--br-2);color:var(--tx-2);
}
.btn-step-prev:hover:not(:disabled){border-color:var(--br-3);color:var(--tx-1)}
.btn-step-next{
  background:var(--green);color:#000;border:1px solid transparent;
}
.btn-step-next:hover{background:var(--green-bright);box-shadow:0 0 20px var(--green-glow)}
.btn-step-next:disabled{opacity:.4;cursor:not-allowed}
.btn-step-prev:disabled{opacity:.3;cursor:not-allowed}
.btn-step-complete{
  background:linear-gradient(135deg,var(--green-dim),var(--green));
  color:#000;border:none;
  padding:var(--s2) var(--s6);border-radius:var(--r-full);
  font-size:.9rem;font-weight:800;
  display:inline-flex;align-items:center;gap:var(--s2);
  transition:all var(--t2) var(--ease);
}
.btn-step-complete:hover{box-shadow:0 0 28px var(--green-glow);transform:translateY(-1px)}

/* XP Popup */
.xp-popup{
  position:fixed;bottom:var(--s8);right:var(--s6);z-index:1000;
  background:linear-gradient(135deg,var(--purple-dim),var(--purple));
  color:#fff;border-radius:var(--r-lg);padding:var(--s4) var(--s5);
  box-shadow:0 16px 48px rgba(167,139,250,.35);
  display:flex;align-items:center;gap:var(--s3);
  animation:slide-in .4s var(--ease-out) both;
  min-width:220px;
}
.xp-popup.hide{animation:slide-out .35s var(--ease) forwards}
.xp-popup-icon{font-size:1.8rem}
.xp-popup-text strong{display:block;font-size:1rem;font-weight:900;letter-spacing:-.02em}
.xp-popup-text span{font-size:.78rem;opacity:.85}

/* ═══════════════════════════════════════════════════════════
   SERVIÇOS RÁPIDOS
═══════════════════════════════════════════════════════════ */
.quick-service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--s4);
}
.quick-service-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--s5) var(--s4);
  background: var(--surface);
  border: 1px solid var(--br-2);
  border-radius: var(--r-md);
  text-decoration: none;
  color: var(--tx-1);
  transition: all var(--t2) var(--ease);
  position: relative;
  overflow: hidden;
  min-height: 120px;
}
.quick-service-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 4px;
  background: var(--service-color, var(--green));
  opacity: 0.8;
  transition: all var(--t2) var(--ease);
}
.quick-service-card:hover {
  transform: translateY(-4px);
  border-color: var(--green-border);
  box-shadow: 0 12px 32px rgba(0,0,0,0.4), 0 0 0 1px var(--green-glow);
  background: var(--surface-2);
}
.quick-service-card:hover::before {
  height: 6px;
  opacity: 1;
}
.quick-service-icon {
  font-size: 2rem;
  margin-bottom: var(--s3);
  transition: transform var(--t2) var(--ease);
}
.quick-service-card:hover .quick-service-icon {
  transform: scale(1.1);
}
.quick-service-title {
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.25;
  transition: color var(--t2) var(--ease);
}
.quick-service-card:hover .quick-service-title {
  color: var(--green-bright);
}
.quick-service-desc {
  margin-top: var(--s2);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--tx-3);
  line-height: 1.4;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  transition: all var(--t3) var(--ease);
  transform: translateY(8px);
}
.quick-service-card:hover .quick-service-desc {
  opacity: 1;
  max-height: 80px;
  transform: translateY(0);
}

/* ═══════════════════════════════════════════════════════════
   LAB CARDS
═══════════════════════════════════════════════════════════ */
.labs-grid-wrap{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--s5);
}
.lab-card{
  background:var(--surface);border:1px solid var(--br);
  border-radius:var(--r-lg);overflow:hidden;cursor:pointer;
  transition:transform var(--t2) var(--ease),border-color var(--t2) var(--ease),box-shadow var(--t2) var(--ease);
}
.lab-card:hover{transform:translateY(-4px);border-color:var(--green-border);box-shadow:0 16px 48px rgba(0,0,0,.4),0 0 0 1px var(--green-glow)}
.lab-card-img{height:165px;background:var(--surface-2);overflow:hidden;position:relative}
.lab-card-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--t3) var(--ease)}
.lab-card:hover .lab-card-img img{transform:scale(1.06)}
.img-fallback{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s2);opacity:.5}
.img-fallback .fi{font-size:2.5rem}
.img-fallback .fl{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--tx-3)}
.lab-pc-badge{
  position:absolute;bottom:var(--s3);right:var(--s3);
  background:#3B82F6;border:none;border-radius:var(--r-sm);
  padding:4px 10px;font-size:.7rem;font-weight:900;color:#FFFFFF;
  box-shadow:0 8px 24px rgba(0,0,0,.6);font-family:var(--mono);
}
.lab-dual-badge{
  position:absolute;top:var(--s3);right:var(--s3);
  background:rgba(0,0,0,0.75);backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,0.2);border-radius:var(--r-sm);
  padding:5px 12px;font-size:.7rem;font-weight:800;color:#FFFFFF;
  box-shadow:0 4px 12px rgba(0,0,0,0.5);
  letter-spacing:0.02em;
}
.lab-card-body{padding:var(--s4) var(--s5)}
.lab-card-name{font-size:1rem;font-weight:800;margin-bottom:var(--s3);line-height:1.25;letter-spacing:-.02em}
.lab-specs-row{display:flex;flex-direction:column;gap:6px}
.spec-line{display:flex;align-items:center;gap:var(--s2);font-size:.76rem;color:var(--tx-2)}
.spec-line svg{color:var(--tx-3);flex-shrink:0;width:13px;height:13px}
.lab-card-foot{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--s3) var(--s5);border-top:1px solid var(--br);background:var(--surface-2);
}
.lab-os{font-size:.68rem;color:var(--tx-3);font-weight:500}
.btn-lab-view{font-size:.72rem;font-weight:700;color:var(--green);display:flex;align-items:center;gap:4px}
.btn-lab-view span{transition:transform var(--t2) var(--ease)}
.lab-card:hover .btn-lab-view span{transform:translateX(4px)}
.btn-reservar{display:block;text-align:center;padding:6px;background:var(--surface-3);border:1px solid var(--br-2);border-radius:var(--r-sm);font-size:.75rem;font-weight:700;color:var(--tx-2);transition:all var(--t2) var(--ease);text-decoration:none}
.btn-reservar:hover{background:var(--green-subtle);color:var(--green);border-color:var(--green-border)}

/* Lab Modal */
.modal-overlay{
  position:fixed;inset:0;z-index:800;
  background:rgba(0,0,0,.78);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:center;padding:var(--s4);
  opacity:0;visibility:hidden;transition:opacity var(--t3) var(--ease),visibility var(--t3) var(--ease);
}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{
  background:var(--surface);border:1px solid var(--br-2);border-radius:var(--r-xl);
  width:100%;max-width:560px;max-height:88vh;overflow:hidden;display:flex;flex-direction:column;
  transform:scale(.92) translateY(18px);transition:transform var(--t3) var(--ease-out);
  box-shadow:0 40px 100px rgba(0,0,0,.65);
}
.modal-overlay.active .modal{transform:scale(1) translateY(0)}
.modal-header{
  display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s4);
  padding:var(--s5) var(--s6);border-bottom:1px solid var(--br);flex-shrink:0;
}
.modal-title{font-size:1.15rem;font-weight:800;letter-spacing:-.02em}
.modal-meta{font-size:.72rem;color:var(--tx-2);margin-top:4px}
.modal-close{
  width:30px;height:30px;border-radius:var(--r-sm);color:var(--tx-2);
  display:flex;align-items:center;justify-content:center;transition:all var(--t1) var(--ease);flex-shrink:0;
}
.modal-close:hover{background:var(--surface-3);color:var(--tx-1)}
.modal-img{overflow:hidden}
.modal-img img{width:100%;max-height:200px;object-fit:cover}
.modal-body{flex:1;overflow-y:auto;padding:var(--s5) var(--s6)}
.modal-sect{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--tx-3);margin:var(--s5) 0 var(--s3)}
.modal-sect:first-child{margin-top:0}
.specs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s3)}
.spec-card{background:var(--surface-2);border:1px solid var(--br);border-radius:var(--r);padding:var(--s3) var(--s4)}
.spec-card .lbl{font-size:.6rem;color:var(--tx-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.spec-card .val{font-size:.85rem;font-weight:700}
.sw-list{display:flex;flex-wrap:wrap;gap:var(--s2)}
.sw-tag{padding:4px 11px;background:rgba(59, 130, 246, 0.1);border:1px solid rgba(59, 130, 246, 0.4);color:#60A5FA;border-radius:var(--r-full);font-size:.7rem;font-weight:700}
.dual-tag-mini{
  display:inline-block;margin-left:6px;
  background:var(--green);color:#000;border-radius:var(--r-xs);
  padding:1px 6px;font-size:.62rem;font-weight:900;text-transform:uppercase;
  vertical-align:middle;
}
.cred-list{display:flex;flex-direction:column;gap:var(--s3)}
.cred-item{
  display:flex;align-items:center;justify-content:space-between;gap:var(--s3);
  padding:var(--s3) var(--s4);background:var(--surface-2);border:1px solid var(--br);border-radius:var(--r);
}
.cred-desc{font-size:.82rem;font-weight:700}
.cred-user{font-size:.68rem;color:var(--tx-2);margin-top:2px}
.cred-copy{padding:4px 12px;background:var(--green-subtle);border:1px solid var(--green-border);border-radius:var(--r-full);font-size:.7rem;font-weight:700;color:var(--green);transition:all var(--t2) var(--ease);cursor:pointer}
.cred-copy:hover{background:var(--green);color:#000}

/* ═══════════════════════════════════════════════════════════
   NOTICIAS
═══════════════════════════════════════════════════════════ */
.noticias-list{display:flex;flex-direction:column;gap:var(--s3)}
.noticia-item{
  display:flex;align-items:flex-start;gap:var(--s4);
  padding:var(--s4) var(--s5);
  background:var(--surface);border:1px solid var(--br);border-radius:var(--r-lg);
  cursor:pointer;transition:all var(--t2) var(--ease);
  border-left:3px solid transparent;
}
.noticia-item:hover{border-color:var(--br-2);border-left-color:var(--green);background:var(--surface-2);transform:translateX(3px)}
.noticia-date{
  display:flex;flex-direction:column;align-items:center;min-width:40px;text-align:center;
}
.noticia-date .day{font-size:1.5rem;font-weight:900;line-height:1;color:var(--green);font-family:var(--mono)}
.noticia-date .mon{font-size:.6rem;font-weight:700;text-transform:uppercase;color:var(--tx-3);letter-spacing:.06em}
.noticia-body{flex:1;min-width:0}
.noticia-title{font-size:.9rem;font-weight:700;margin-bottom:4px;line-height:1.35}
.noticia-excerpt{font-size:.78rem;color:var(--tx-2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.badge-pdf{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.25);color:var(--red);border-radius:var(--r-full);font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}

/* ═══════════════════════════════════════════════════════════
   CONTATOS (DIRETÓRIO COMPACTO)
═══════════════════════════════════════════════════════════ */
.contato-directory{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--s5);align-items:start}
.contato-grupo{background:var(--surface);border:1px solid var(--br);border-radius:var(--r-lg);overflow:hidden}
.contato-grupo-title{padding:var(--s3) var(--s4);background:var(--surface-2);color:var(--green);font-size:.75rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;border-bottom:1px solid var(--br)}
.contato-grupo-list{display:flex;flex-direction:column}
.contato-card{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--s3) var(--s4);border-bottom:1px solid var(--br);
  transition:all var(--t2) var(--ease);
}
.contato-card:last-child{border-bottom:none}
.contato-card:hover{background:var(--surface-2)}

.contato-main{display:flex;align-items:center;gap:var(--s4);flex:1;min-width:0}

.contato-number-wrap{
  min-width:44px;padding:var(--s1) var(--s2);
  background:var(--surface-3);border:1px solid var(--br);border-radius:var(--r-md);
  cursor:pointer;transition:all var(--t2) var(--ease);text-align:center;
}
.contato-number-wrap:hover{background:var(--green-subtle);border-color:var(--green-border)}
.contato-number{font-size:.85rem;font-weight:900;color:var(--tx-1);font-family:var(--mono);line-height:1}
.contato-number-wrap:hover .contato-number{color:var(--green)}

.contato-person{min-width:0;}
.contato-nome{font-size:.85rem;font-weight:700;line-height:1.2;color:var(--tx-1);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.contato-meta{font-size:.65rem;color:var(--tx-3);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.contato-actions{margin-left:var(--s3)}
.btn-wa{
  width:32px;height:32px;border-radius:var(--r-full);
  display:flex;align-items:center;justify-content:center;
  background:rgba(37,211,102,0.08);color:#25D366;
  transition:all var(--t2) var(--ease);
}
.btn-wa:hover{background:#25D366;color:#fff;transform:scale(1.05)}
.btn-wa svg{width:16px;height:16px}


/* ═══════════════════════════════════════════════════════════
   TOAST
═══════════════════════════════════════════════════════════ */
.toast-container{position:fixed;top:calc(var(--nav-h) + 12px);right:var(--s5);z-index:900;display:flex;flex-direction:column;gap:var(--s2)}
.toast{
  display:flex;align-items:center;gap:var(--s3);
  padding:var(--s3) var(--s5);
  background:var(--surface-2);border:1px solid var(--br-2);border-radius:var(--r);
  box-shadow:0 8px 32px rgba(0,0,0,.4);
  animation:slide-in .3s var(--ease-out) both;
  min-width:220px;max-width:340px;font-size:.85rem;
  border-left:3px solid var(--tx-3);
}
.toast.success{border-left-color:var(--green)}
.toast.error  {border-left-color:var(--red)}
.toast.fade-out{animation:slide-out .3s var(--ease) forwards}

/* ═══════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════ */
.footer{
  padding:var(--s8) 0;background:var(--surface);border-top:1px solid var(--br);
  text-align:center;color:var(--tx-3);font-size:.78rem;
}
.footer strong{color:var(--tx-2)}

/* ═══════════════════════════════════════════════════════════
   EMPTY STATE / LOADING
═══════════════════════════════════════════════════════════ */
.empty-state{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:var(--s16) var(--s6);text-align:center;color:var(--tx-3);gap:var(--s3);
}
.loading-spinner{display:inline-block;animation:spin 1s linear infinite}
.skeleton{
  background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);
  background-size:800px 100%;animation:shimmer 1.6s infinite;border-radius:var(--r);
}

/* ═══════════════════════════════════════════════════════════
   SHARED BUTTONS
═══════════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:var(--s2);padding:var(--s2) var(--s4);font-size:.85rem;font-weight:700;border-radius:var(--r-sm);transition:all var(--t2) var(--ease);cursor:pointer;white-space:nowrap}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn-primary{background:var(--green);color:#000}
.btn-primary:hover:not(:disabled){background:var(--green-bright);box-shadow:0 0 20px var(--green-glow)}
.btn-secondary{background:var(--surface-2);color:var(--tx-1);border:1px solid var(--br-2)}
.btn-secondary:hover:not(:disabled){border-color:var(--green-border);color:var(--green)}
.btn-danger{background:var(--red-subtle);color:var(--red);border:1px solid var(--red-glow)}
.btn-danger:hover:not(:disabled){background:var(--red-dim);color:#fff}
.btn-sm{padding:5px var(--s3);font-size:.75rem}
.btn-icon{padding:6px;width:32px;height:32px}

/* ═══════════════════════════════════════════════════════════
   ADMIN PANEL (unchanged functional styles)
═══════════════════════════════════════════════════════════ */
.admin-layout{display:flex;min-height:100vh;background:var(--bg)}
.admin-sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--br);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:transform var(--t3) var(--ease)}
.admin-sidebar-brand{padding:var(--s6);background:linear-gradient(135deg,var(--green-dim) 0%,#1a5c35 100%);color:#fff}
.admin-sidebar-brand .logo{font-size:1rem;font-weight:800;display:flex;align-items:center;gap:var(--s2)}
.admin-sidebar-user{font-size:.78rem;opacity:.85;margin-top:var(--s2)}
.admin-nav{padding:var(--s4) 0;flex:1;overflow-y:auto}
.admin-nav-item{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) var(--s6);font-size:.875rem;font-weight:500;color:var(--tx-2);cursor:pointer;transition:var(--t2);border-left:3px solid transparent}
.admin-nav-item:hover{background:var(--surface-2);color:var(--tx-1)}
.admin-nav-item.active{background:var(--green-subtle);color:var(--green);border-left-color:var(--green)}
.admin-nav-item svg{width:18px;height:18px;flex-shrink:0}
.admin-sidebar-footer{padding:var(--s4) var(--s6);border-top:1px solid var(--br)}
.admin-content{flex:1;margin-left:var(--sidebar-w);padding:var(--s8);min-height:100vh}
.admin-page-title{font-size:1.6rem;font-weight:900;margin-bottom:var(--s2);letter-spacing:-.03em}
.admin-page-subtitle{font-size:.9rem;color:var(--tx-2);margin-bottom:var(--s6)}
.admin-tab-panel{display:none}
.admin-tab-panel.active{display:block;animation:fade .3s var(--ease) both}
.admin-breadcrumbs{display:flex;align-items:center;gap:var(--s2);font-size:.78rem;margin-bottom:var(--s6);color:var(--tx-3)}
.admin-breadcrumbs a{color:var(--green)}
.admin-breadcrumbs .sep{color:var(--tx-3)}
.admin-card{background:var(--surface);border:1px solid var(--br);border-radius:var(--r-lg);padding:var(--s6);margin-bottom:var(--s5)}
.admin-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s4)}
.admin-card-title{font-size:1rem;font-weight:800;color:var(--tx-1)}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{text-align:left;padding:var(--s3) var(--s4);font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--tx-3);border-bottom:2px solid var(--br)}
.admin-table td{padding:var(--s4);border-bottom:1px solid var(--br);font-size:.85rem;color:var(--tx-1)}
.admin-table tr:hover td{background:var(--surface-2)}
.admin-table .td-main{font-weight:700}
.admin-table th[onclick]:hover { background: var(--surface-3); color: var(--green); }

.badge-green{background:var(--green-subtle);color:var(--green);border-radius:var(--r-full);padding:3px 10px;font-size:.68rem;font-weight:700}
.badge-gray{background:var(--surface-2);color:var(--tx-3);border-radius:var(--r-full);padding:3px 10px;font-size:.68rem;font-weight:600}
.badge-purple{background:var(--purple-subtle);color:var(--purple);border-radius:var(--r-full);padding:3px 10px;font-size:.68rem;font-weight:700}
.lab-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--s5)}
.lab-admin-card{background:var(--surface);border:1px solid var(--br);border-radius:var(--r-lg);overflow:hidden;transition:all var(--t2) var(--ease)}
.lab-admin-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.3)}
.lab-admin-card-img{height:170px;background:var(--surface-2);display:flex;align-items:center;justify-content:center}
.lab-admin-card-img img{width:100%;height:100%;object-fit:cover}
.lab-admin-card-img .no-photo{display:flex;flex-direction:column;align-items:center;gap:var(--s2);color:var(--tx-3)}
.lab-admin-card-body{padding:var(--s4)}
.lab-admin-card-name{font-size:1rem;font-weight:800;margin-bottom:var(--s3)}
.lab-admin-actions{display:flex;flex-wrap:wrap;gap:var(--s2)}
.toggle{appearance:none;width:42px;height:22px;background:var(--br-2);border-radius:var(--r-full);position:relative;cursor:pointer;transition:all var(--t2) var(--ease)}
.toggle::before{content:'';position:absolute;width:18px;height:18px;background:#fff;border-radius:50%;top:2px;left:2px;transition:all var(--t2) var(--ease);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.toggle:checked{background:var(--green)}
.toggle:checked::before{transform:translateX(20px)}
.toggle-wrap{display:flex;align-items:center}
.soft-list{display:flex;flex-direction:column;gap:var(--s2);max-height:380px;overflow-y:auto}
.soft-item{display:flex;align-items:center;justify-content:space-between;padding:var(--s3);background:var(--surface-2);border-radius:var(--r-sm);font-size:.82rem}
.soft-item-readonly{background:var(--green-subtle)}
.cred-item-admin{display:flex;align-items:center;gap:var(--s2);margin-bottom:var(--s2)}
.cred-item-admin input{flex:1;padding:var(--s2);font-size:.82rem;background:var(--surface-2);border:1px solid var(--br);border-radius:var(--r-xs);color:var(--tx-1);outline:none}
.cred-item-admin input:focus{border-color:var(--green)}
.inline-form{display:flex;gap:var(--s2);align-items:center}
.inline-form input{flex:1;padding:var(--s2) var(--s3);background:var(--surface-2);border:1px solid var(--br);border-radius:var(--r-sm);color:var(--tx-1);font-size:.82rem;outline:none}
.inline-form input:focus{border-color:var(--green)}
.software-search{width:100%;padding:var(--s2) var(--s3);background:var(--surface-2);border:1px solid var(--br);border-radius:var(--r);color:var(--tx-1);font-size:.82rem;outline:none;margin-bottom:var(--s3)}
.software-search:focus{border-color:var(--green)}
.upload-zone{border:2px dashed var(--br-2);border-radius:var(--r-lg);padding:var(--s8);text-align:center;cursor:pointer;transition:all var(--t2) var(--ease);background:var(--surface-2)}
.upload-zone:hover{border-color:var(--green);background:var(--green-subtle)}
.upload-zone input[type="file"]{display:none}
.upload-icon{font-size:2rem;margin-bottom:var(--s2)}
.upload-text{font-size:.82rem;color:var(--tx-2)}
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:99}
.overlay.show{display:block}
.admin-mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:58px;background:var(--surface);border-bottom:1px solid var(--br);z-index:101;padding:0 var(--s4);align-items:center;justify-content:space-between}
.mobile-menu-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;color:var(--tx-1)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}
.form-group{margin-bottom:var(--s4)}
.form-label{display:block;font-size:.7rem;font-weight:700;color:var(--tx-3);margin-bottom:var(--s2);text-transform:uppercase;letter-spacing:.05em}
.form-control{width:100%;padding:var(--s3) var(--s4);background:var(--surface-2);border:1px solid var(--br-2);border-radius:var(--r);color:var(--tx-1);font-size:.88rem;outline:none;transition:all var(--t2) var(--ease)}
.form-control:focus{border-color:var(--green);box-shadow:0 0 0 3px var(--green-glow)}
.form-control::placeholder{color:var(--tx-3)}
.form-control:disabled{opacity:.5;cursor:not-allowed}
textarea.form-control{min-height:100px;resize:vertical}
select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234B5A72'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:14px;padding-right:2.5rem}
.modal-check-list{display:flex;flex-direction:column;gap:var(--s2);max-height:320px;overflow-y:auto}
.modal-check-item{display:flex;align-items:center;gap:var(--s3);padding:var(--s3) var(--s4);background:var(--surface-2);border:1px solid var(--br);border-radius:var(--r);cursor:pointer;transition:all var(--t2) var(--ease)}
.modal-check-item:hover{border-color:var(--green-border);background:var(--green-subtle)}
.modal-check-item input[type="checkbox"]{width:16px;height:16px;accent-color:var(--green);cursor:pointer;flex-shrink:0}
.lab-info{display:flex;flex-direction:column}
.lab-name{font-size:.85rem;font-weight:700}
.lab-group{font-size:.68rem;color:var(--tx-3)}
.btn-outline{background:transparent;border:1px solid var(--br-2);color:var(--tx-2);border-radius:var(--r-sm)}
.btn-outline:hover{border-color:var(--green-border);color:var(--green)}
.ql-toolbar.ql-snow{border-color:var(--br-2) !important;border-radius:var(--r) var(--r) 0 0 !important;background:var(--surface-2)}
.ql-container.ql-snow{border-color:var(--br-2) !important;border-radius:0 0 var(--r) var(--r) !important;font-family:var(--font) !important}
.ql-editor{min-height:180px;color:var(--tx-1)}
.ql-snow .ql-stroke{stroke:var(--tx-2) !important}
.ql-snow .ql-fill{fill:var(--tx-2) !important}
.ql-snow .ql-picker{color:var(--tx-2) !important}
/* Link visível dentro do editor Quill (admin) */
.ql-editor a { color: #4da6ff !important; text-decoration: underline; font-weight: 600; }
[data-theme="light"] .ql-editor a { color: #0057cc !important; }


/* ═══════════════════════════════════════════════════════════
   ESTATÍSTICAS / DASHBOARD FINAL
═══════════════════════════════════════════════════════════ */
.stats-section {
  padding: 5rem 0;
  position: relative;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 200, 83, 0.03) 100%);
  border-top: 1px solid var(--br);
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--s6);
}
.stat-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--s8) var(--s6);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--br-2);
  border-radius: var(--r-xl);
  backdrop-filter: blur(12px);
  transition: all 0.4s var(--ease);
}
.stat-card:hover {
  transform: translateY(-5px);
  background: rgba(0, 200, 83, 0.05);
  border-color: var(--green-border);
  box-shadow: 0 16px 40px rgba(0, 200, 83, 0.1);
}
.stat-icon {
  font-size: 2.5rem;
  margin-bottom: var(--s3);
  filter: drop-shadow(0 4px 10px rgba(0,0,0,0.4));
}
.stat-valor {
  font-size: 3.5rem;
  font-weight: 900;
  color: var(--tx-1); /* Fallback */
  font-family: var(--mono);
  line-height: 1;
  margin-bottom: var(--s2);
  letter-spacing: -0.04em;
  background: linear-gradient(135deg, #fff 0%, var(--green-bright) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
:root[data-theme="light"] .stat-valor {
  background: linear-gradient(135deg, var(--tx-1) 0%, var(--green-dim) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.stat-label {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--tx-2);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

/* ═══════════════════════════════════════════════════════════
   FLOATING NAV (SCROLLSPY)
═══════════════════════════════════════════════════════════ */
.floating-nav {
  position: fixed;
  top: 50%;
  right: 1.5rem;
  transform: translateY(-50%) translateX(20px);
  z-index: 900;
  opacity: 0;
  pointer-events: none;
  transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}
.floating-nav.show {
  opacity: 1;
  pointer-events: all;
  transform: translateY(-50%) translateX(0);
}
.floating-nav-inner {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  background: rgba(18, 18, 18, 0.4);
  backdrop-filter: blur(12px);
  padding: 0.75rem 0.5rem;
  border-radius: 3rem;
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.5);
}
.float-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.03);
  color: var(--text-muted);
  text-decoration: none;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  border: 1px solid transparent;
}
.float-icon {
  font-size: 1.1rem;
  z-index: 2;
}
.float-label {
  position: absolute;
  right: 15px;
  background: var(--surface);
  color: var(--text-primary);
  padding: 0.4rem 1rem;
  border-radius: 2rem;
  font-size: 0.75rem;
  font-weight: 700;
  white-space: nowrap;
  opacity: 0;
  visibility: hidden;
  border: 1px solid var(--border);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  transform: translateX(-10px);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  z-index: 1;
}
.float-btn:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
}
.float-btn:hover .float-label {
  opacity: 1;
  visibility: visible;
  transform: translateX(-35px);
}
.float-btn.active {
  background: var(--green);
  color: #000;
  box-shadow: 0 0 15px rgba(50, 160, 65, 0.4);
  border-color: rgba(255,255,255,0.2);
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .admin-sidebar{transform:translateX(-100%)}
  .admin-sidebar.open{transform:translateX(0)}
  .admin-content{margin-left:0;padding:var(--s6);padding-top:calc(58px + var(--s6))}
  .admin-mobile-header{display:flex}
}
@media(max-width:768px){
  .hero-title{font-size:clamp(2rem,8vw,3rem)}
  .hero-stats{flex-direction:column;border-radius:var(--r-lg)}
  .hero-stat{border-right:none;border-bottom:1px solid var(--br);width:100%;justify-content:center}
  .hero-stat:last-child{border-bottom:none}
  .missions-bento,.labs-grid-wrap,.contatos-grid,.specs-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr !important}
  .lab-admin-grid{grid-template-columns:1fr}
  .nav-xp{display:none}
  .nav-spotlight-btn span:not(.nav-spotlight-kbd){display:none}
  .floating-nav{display:none !important}
}
@media(max-width:480px){
  .container{padding:0 var(--s4)}
  .hero{padding-top:calc(var(--nav-h) + 2.5rem);padding-bottom:2.5rem}
  .section{padding:var(--s8) 0}
  .spotlight-box{border-radius:var(--r-lg)}
  .stepper-modal{border-radius:var(--r-xl)}
  .toast-container{left:var(--s3);right:var(--s3)}
  .toast{max-width:100%;min-width:unset}
}

/* ── Labs Controls (Home Pública) ───────────────────── */
.labs-controls {
  display: flex;
  gap: 0.5rem;
  padding: 0.4rem;
  background: rgba(255, 255, 255, 0.03);
  border-radius: var(--r-lg);
  border: 1px solid var(--br);
  backdrop-filter: blur(8px);
}

@media(max-width: 768px) {
  .labs-controls {
    width: 100%;
    flex-direction: column;
    padding: var(--s3);
    gap: var(--s2);
  }
  .labs-controls input, 
  .labs-controls select {
    width: 100% !important;
  }
}

/* ═══════════════════════════════════════════════════════════
   TUTORIAIS & CHIPS
═══════════════════════════════════════════════════════════ */
@media(max-width: 768px) {
  .category-filters {
    overflow-x: auto;
    width: auto;
    max-width: 100vw;
    padding-bottom: 5px;
    -webkit-overflow-scrolling: touch;
    margin-left: calc(-1 * var(--s4));
    margin-right: calc(-1 * var(--s4));
    padding-left: var(--s4);
    padding-right: var(--s4);
  }
  .category-filters::-webkit-scrollbar { display: none; }
  .section-label { gap: 0.5rem !important; }
}
.category-filters {
  display: flex !important;
  gap: var(--s2);
  margin-top: 5px;
}
.chip {
  padding: 6px 14px;
  background: var(--surface-2);
  border: 1px solid var(--br-2);
  border-radius: var(--r-full);
  color: var(--tx-2);
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--t1) var(--ease);
  white-space: nowrap;
}
.chip:hover {
  background: var(--surface-3);
  color: var(--tx-1);
}
.chip.active {
  background: var(--green-dim);
  color: var(--green);
  border-color: var(--green);
  box-shadow: 0 0 12px var(--green-glow);
}

.tutorial-card {
  border-left-width: 3px !important;
  border-left-color: var(--purple) !important;
}
.tutorial-card:hover { border-color: var(--purple-glow) !important; }

.tutorial-hero-img {
  width: 100%;
  max-height: 300px;
  object-fit: cover;
  border-radius: var(--r);
  margin-bottom: var(--s6);
  border: 1px solid var(--br);
}

.tutorial-content-wrap { color: var(--tx-2); line-height: 1.7; }
.tutorial-body-html { font-size: 0.95rem; }
.tutorial-body-html h1, .tutorial-body-html h2 { color: var(--tx-1); margin: 1.5rem 0 0.8rem; letter-spacing: -0.02em; }
.tutorial-body-html p { margin-bottom: 1rem; }
.tutorial-body-html img { 
  max-width: 100%; height: auto; border-radius: var(--r); margin: 1.5rem 0; 
  border: 1px solid var(--br); box-shadow: 0 10px 40px rgba(0,0,0,0.3);
}
.tutorial-body-html ul, .tutorial-body-html ol { margin-left: 1.5rem; margin-bottom: 1rem; }
.tutorial-body-html li { margin-bottom: 0.5rem; }
/* Links dentro do conteúdo de tutoriais e stepper */
.tutorial-body-html a,
.step-content a,
.step-resumo a,
.ql-editor a {
  color: #4da6ff;
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
  font-weight: 600;
  transition: color 0.2s, opacity 0.2s;
}
.tutorial-body-html a:hover,
.step-content a:hover,
.step-resumo a:hover,
.ql-editor a:hover {
  color: #80c4ff;
  opacity: 0.9;
}
[data-theme="light"] .tutorial-body-html a,
[data-theme="light"] .step-content a,
[data-theme="light"] .step-resumo a,
[data-theme="light"] .ql-editor a {
  color: #0057cc;
}
[data-theme="light"] .tutorial-body-html a:hover,
[data-theme="light"] .step-content a:hover,
[data-theme="light"] .step-resumo a:hover,
[data-theme="light"] .ql-editor a:hover {
  color: #0044a8;
}

/* ═══════════════════════════════════════════════════════════
   SUAP GUIDE BANNER + BOTÃO
═══════════════════════════════════════════════════════════ */
.btn-guia-suap {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 1.1rem;
  border-radius: var(--r-full);
  background: rgba(100,149,237,.12);
  border: 1.5px solid rgba(100,149,237,.3);
  color: #90b4f5;
  font-size: 0.8rem;
  font-weight: 700;
  text-decoration: none;
  transition: all var(--t2) var(--ease);
  white-space: nowrap;
}
.btn-guia-suap:hover {
  background: rgba(100,149,237,.2);
  border-color: #90b4f5;
  box-shadow: 0 0 20px rgba(100,149,237,.2);
}

.suap-guide-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.25rem 1.75rem;
  background: linear-gradient(135deg, rgba(25,40,80,.6) 0%, rgba(18,30,60,.8) 100%);
  border: 1px solid rgba(100,149,237,.25);
  border-radius: var(--r-lg);
  margin-bottom: 1.5rem;
  position: relative;
  overflow: hidden;
}
.suap-guide-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 95% 50%, rgba(100,149,237,.08) 0%, transparent 70%);
  pointer-events: none;
}
.suap-guide-banner-left {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.suap-guide-icon {
  font-size: 2.5rem;
  flex-shrink: 0;
  filter: drop-shadow(0 0 12px rgba(100,149,237,.4));
}
.suap-guide-label {
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #90b4f5;
  margin-bottom: 0.25rem;
}
.suap-guide-title {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--tx-1);
  margin-bottom: 0.3rem;
  letter-spacing: -.02em;
}
.suap-guide-desc {
  font-size: 0.8rem;
  color: var(--tx-2);
  line-height: 1.5;
  max-width: 480px;
}
.btn-guia-open {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  padding: 0.65rem 1.5rem;
  border-radius: var(--r-full);
  background: linear-gradient(135deg, #3a6fd8, #1e4db7);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 700;
  text-decoration: none;
  border: 1px solid rgba(100,149,237,.3);
  transition: all var(--t2) var(--ease);
  box-shadow: 0 4px 16px rgba(30,77,183,.4);
  white-space: nowrap;
}
.btn-guia-open:hover {
  background: linear-gradient(135deg, #4a7fe8, #2e5dc7);
  box-shadow: 0 8px 28px rgba(30,77,183,.5);
  transform: translateY(-2px);
}

@media (max-width: 640px) {
  .suap-guide-banner {
    flex-direction: column;
    align-items: flex-start;
  }
  .btn-guia-open { width: 100%; justify-content: center; }
}

/* ═══════════════════════════════════════════════════════════
   PÁGINAS ADICIONAIS (Laboratórios & Ramais)
   ═══════════════════════════════════════════════════════════ */
.labs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--s6);
  margin-top: var(--s6);
}

.table-container {
  overflow-x: auto;
  border-radius: var(--r-lg);
  border: 1px solid var(--br);
  background: var(--surface);
  box-shadow: 0 12px 40px rgba(0,0,0,0.2);
}

.ramais-table th {
  background: var(--surface-2);
  color: var(--tx-3);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ramais-table tr {
  transition: background var(--t1) var(--ease);
}

.ramais-table tr:hover {
  background: rgba(255,255,255,0.02);
}

.btn-wa-mini {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #25D366;
  color: #fff;
  padding: 6px 14px;
  border-radius: var(--r-full);
  font-size: 0.75rem;
  font-weight: 700;
  transition: all var(--t2) var(--ease);
  box-shadow: 0 4px 12px rgba(37, 211, 102, 0.2);
}

.btn-wa-mini:hover {
  background: #20BA56;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(37, 211, 102, 0.3);
}

.search-bar-wrap input {
  width: 100%;
  border-radius: var(--r-lg);
  background: var(--surface-2);
  border: 1px solid var(--br-2);
  padding: 12px 20px;
  color: var(--tx-1);
  font-weight: 500;
  transition: all var(--t2) var(--ease);
}

.search-bar-wrap input:focus {
  outline: none;
  border-color: var(--green);
  box-shadow: 0 0 0 4px var(--green-glow);
}

/* ═══════════════════════════════════════════════════════════════
   TRILHA DE APRENDIZADO — Swiper Carousel + Cards + Modais
   v6.0
═══════════════════════════════════════════════════════════════ */

/* ── Swiper Container ────────────────────────────────────────── */
.trilha-swiper {
  padding: 0.5rem 0 3rem;
  width: 100%;
}

.trilha-swiper .swiper-wrapper {
  align-items: stretch;
}

/* Navegação customizada */
.trilha-btn-prev,
.trilha-btn-next {
  color: var(--green) !important;
  background: var(--surface-2);
  width: 40px !important;
  height: 40px !important;
  border-radius: 50%;
  box-shadow: 0 2px 12px rgba(0,0,0,.3);
  transition: background 0.2s;
  --swiper-navigation-size: 18px;
}
.trilha-btn-prev:hover,
.trilha-btn-next:hover {
  background: var(--green-subtle);
}
.trilha-btn-prev::after,
.trilha-btn-next::after {
  font-size: 16px !important;
  font-weight: 900;
}

@media(max-width: 768px) {
  .trilha-btn-prev, .trilha-btn-next { display: none !important; }
}

/* Paginação */
.trilha-pagination .swiper-pagination-bullet {
  background: var(--border);
  opacity: 1;
  transition: background 0.2s, transform 0.2s;
}
.trilha-pagination .swiper-pagination-bullet-active {
  background: var(--green);
  transform: scaleX(2.2);
  border-radius: 4px;
}

/* ── Trilha Card ─────────────────────────────────────────────── */
.trilha-card {
  display: flex;
  flex-direction: column;
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  cursor: pointer;
  height: 100%;
  min-height: 340px;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s;
}
.trilha-card:hover,
.trilha-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,.35);
  border-color: var(--green);
  outline: none;
}

/* Capa */
.trilha-card-capa {
  position: relative;
  height: 160px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--surface-2) 0%, rgba(50,160,65,.12) 100%);
  flex-shrink: 0;
}
.trilha-card-capa img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.trilha-card:hover .trilha-card-capa img {
  transform: scale(1.06);
}
.trilha-card-capa-fallback {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  color: var(--green);
  opacity: .5;
}

/* Badge de tipo (canto superior direito) */
.trilha-card-tipo-badge {
  position: absolute;
  top: 10px;
  right: 10px;
  font-size: 0.62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 3px 8px;
  border-radius: 20px;
  backdrop-filter: blur(6px);
}
.tipo-simples {
  background: rgba(50,160,65,.85);
  color: #fff;
}
.tipo-interativo {
  background: rgba(100,60,200,.85);
  color: #fff;
}

/* Corpo do card */
.trilha-card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1rem 1rem 0.85rem;
  gap: 0.4rem;
}
.trilha-card-cat {
  font-size: 0.62rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--green);
}
.trilha-card-titulo {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.35;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.trilha-card-resumo {
  font-size: 0.78rem;
  color: var(--text-secondary);
  line-height: 1.5;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0;
}
.trilha-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.75rem;
  gap: 0.5rem;
}
.trilha-passos-badge {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--text-muted);
}
.btn-trilha-start {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 6px 14px;
  background: linear-gradient(135deg, var(--green) 0%, #27ae60 100%);
  color: #fff;
  border: none;
  border-radius: 20px;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity 0.2s, transform 0.15s;
}
.btn-trilha-start:hover {
  opacity: .9;
  transform: scale(1.03);
}

/* ── Modal Card Simples ──────────────────────────────────────── */
.trilha-simples-modal {
  max-width: 720px;
  width: 95vw;
}

.trilha-simples-modal .modal-body {
  max-height: 70vh;
  overflow-y: auto;
  padding: 1.5rem;
}

.trilha-simples-badge {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--green);
  background: var(--green-subtle);
  padding: 2px 8px;
  border-radius: 20px;
  margin-bottom: 0.35rem;
}

/* Rich text dentro do modal */
.trilha-simples-body h1,
.trilha-simples-body h2,
.trilha-simples-body h3 {
  color: var(--text-primary);
  margin: 1rem 0 0.5rem;
  font-weight: 700;
  line-height: 1.3;
}
.trilha-simples-body p { margin: 0.5rem 0; line-height: 1.7; }
.trilha-simples-body ul,
.trilha-simples-body ol { padding-left: 1.4rem; margin: 0.5rem 0; }
.trilha-simples-body li { margin: 0.3rem 0; line-height: 1.6; }
.trilha-simples-body img {
  max-width: 100%;
  height: auto;
  border-radius: var(--r);
  margin: 0.75rem 0;
}

/* Alinhamento de Imagens e Textos (Quill) */
.trilha-simples-body .ql-align-center { text-align: center; }
.trilha-simples-body .ql-align-right { text-align: right; }
.trilha-simples-body .ql-align-left { text-align: left; }
.trilha-simples-body .ql-align-justify { text-align: justify; }

.trilha-simples-body img.ql-align-center { display: block; margin-left: auto; margin-right: auto; }
.trilha-simples-body img.ql-align-right { float: right; margin-left: 1rem; margin-bottom: 0.5rem; }
.trilha-simples-body img.ql-align-left { float: left; margin-right: 1rem; margin-bottom: 0.5rem; }
.trilha-simples-body a {
  color: var(--green);
  text-decoration: underline;
}
.trilha-simples-body strong { font-weight: 700; }
.trilha-simples-body em { font-style: italic; }
.trilha-simples-body code {
  background: var(--surface-2);
  padding: 1px 5px;
  border-radius: 4px;
  font-family: var(--mono);
  font-size: 0.85em;
}
.trilha-simples-body pre {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 1rem;
  overflow-x: auto;
  margin: 0.75rem 0;
}

/* ══════════════════════════════════════════════════════════════
   LIGHTBOX (Expansão de Imagens)
══════════════════════════════════════════════════════════════ */
.lightbox-overlay {
  position: fixed;
  top: 0; left: 0; width: 100vw; height: 100vh;
  background: rgba(0, 0, 0, 0.9);
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity 0.3s ease;
  backdrop-filter: blur(5px);
  cursor: zoom-out;
}
.lightbox-overlay.active {
  opacity: 1;
}
.lightbox-img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.5);
  transform: scale(0.95);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  cursor: default;
}
.lightbox-overlay.active .lightbox-img {
  transform: scale(1);
}
.lightbox-close {
  position: absolute;
  top: 20px;
  right: 30px;
  color: white;
  font-size: 2rem;
  cursor: pointer;
  z-index: 100000;
  transition: transform 0.2s;
}
.lightbox-close:hover {
  transform: scale(1.1);
  color: var(--green);
}

/* Badges de Notícias */
.badge-source {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.4rem;
}
.badge-source-ifto {
    background: rgba(50, 160, 65, 0.15);
    color: #32a041;
    border: 1px solid rgba(50, 160, 65, 0.3);
}
.badge-source-paraiso {
    background: rgba(50, 160, 65, 0.25);
    color: #32a041;
    border: 1px solid #32a041;
}
.badge-source-ti {
    background: rgba(30, 144, 255, 0.15);
    color: #1e90ff;
    border: 1px solid rgba(30, 144, 255, 0.3);
}
.badge-source-urgente {
    background: rgba(255, 69, 0, 0.15);
    color: #ff4500;
    border: 1px solid #ff4500;
    animation: pulse-urgent 2s infinite;
}

@keyframes pulse-urgent {
    0% { box-shadow: 0 0 0 0 rgba(255, 69, 0, 0.4); }
    70% { box-shadow: 0 0 0 6px rgba(255, 69, 0, 0); }
    100% { box-shadow: 0 0 0 0 rgba(255, 69, 0, 0); }
}

.badge-orange { background: #ff4500; color: white; padding: 2px 6px; border-radius: 4px; font-size: 0.7rem; }
.badge-blue { background: #1e90ff; color: white; padding: 2px 6px; border-radius: 4px; font-size: 0.7rem; }

/* Lab Card Hover Overlay */
.lab-card-img {
    overflow: hidden;
    position: relative;
}
.lab-card-img img {
    transition: transform 0.3s ease;
}
.lab-card-img:hover img {
    transform: scale(1.05);
}
.lab-card-img::after {
    content: "Clique para ver softwares";
    position: absolute;
    top: 0; left: 0; width: 100%; height: 100%;
    background: rgba(0,0,0,0.5);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: bold;
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
    z-index: 5;
}
.lab-card-img:hover::after {
    opacity: 1;
}

.btn-detalhes:hover {
    background: rgba(255,255,255,0.1) !important;
    border-color: var(--tx-1) !important;
}
