/* ==================================================
   PERCEPTRON CONSULTORIA
   Cores logo: #1C4456 (petróleo) · #2E84AF (azul médio) · #9EDFFF (céu)
   Acento:     #2A7BA8 · fundo #F5F8FA · dark #021A1B
   ================================================== */

@import url('https://fonts.googleapis.com/css2?family=Sofia+Sans:wght@400;600;700;800;900&family=Montserrat:wght@400;500;600;700&family=Ubuntu+Sans:wght@300;400;500;600&display=swap');

:root {
    --bg:       #ffffff;
    --dark:     #021A1B;
    --primary:  #1C4456;
    --blue:     #2E84AF;
    --sky:      #9EDFFF;
    --accent:   #2A7BA8;
    --yellow:   #FFC85B;

    --text:         #0d2b35;
    --text-secondary: #1C4456;
    --text-muted:   #3a5f72;
    --border:       rgba(28,68,86,0.12);
    --card-bg:      #ffffff;
    --cream:        #f0f5f8;

    --font-title: 'Sofia Sans', sans-serif;
    --font-aux:   'Montserrat', sans-serif;
    --font-body:  'Ubuntu Sans', sans-serif;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family: var(--font-body); background: var(--bg); color: var(--text); overflow-x: hidden; width: 100%; }
img{max-width:100%; height:auto;}

h1, h2, h3, h4 { font-family: var(--font-title); }
.hidden { display: none !important; }
.page  { min-height: 100vh; }

@keyframes fadeUp  { from { opacity:0; transform:translateY(28px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn  { from { opacity:0; } to { opacity:1; } }
@keyframes pulse   { 0%,100%{opacity:.35;} 50%{opacity:1;} }

.anim-up { animation: fadeUp 0.65s ease both; }
.anim-d1 { animation-delay:.1s; }
.anim-d2 { animation-delay:.22s; }
.anim-d3 { animation-delay:.36s; }
.anim-d4 { animation-delay:.5s; }

/* ── HEADER ─────────────────────────────────────── */
.header {
    position: fixed; top:0; left:0; right:0;
    z-index: 100; height: 68px;
    display: flex; align-items: center;
    background: #eaf2f6;
    border-bottom: 1px solid rgba(28,68,86,.1);
    transition: background .35s, box-shadow .35s;
}
.header.scrolled {
    background: rgba(234,242,246,.98);
    backdrop-filter: blur(16px);
    box-shadow: 0 1px 20px rgba(28,68,86,.09);
}
.header.page-mode {
    background: rgba(234,242,246,.98);
    backdrop-filter: blur(16px);
    box-shadow: 0 1px 14px rgba(28,68,86,.08);
}

.header-inner {
    width:100%; max-width:1400px; margin:0 auto; padding:0 2.5rem;
    display:flex; align-items:center; justify-content:space-between;
    gap: 2rem;
}

/* Logo */
.logo-wrap { display:flex; align-items:center; gap:.75rem; cursor:pointer; flex-shrink:0; }
.logo-img  { height:38px; width:auto; max-width:220px; object-fit:contain; transition:opacity .2s; }
.logo-wrap:hover .logo-img { opacity:.85; }
.logo-text { display:flex; flex-direction:column; }
.logo-name {
    font-family: var(--font-title); font-size:1.35rem; font-weight:800;
    color:var(--primary); letter-spacing:.03em; line-height:1;
    text-transform: uppercase;
}
.logo-tagline {
    font-family: var(--font-aux); font-size:.52rem; font-weight:600;
    letter-spacing:.2em; text-transform:uppercase; color:var(--blue);
    margin-top:2px;
}

/* Nav links */
.nav-links { display:flex; align-items:center; gap:.2rem; }

.nav-link {
    background:none; border:none;
    font-family:var(--font-aux); font-size:.68rem; font-weight:600;
    letter-spacing:.08em; text-transform:uppercase;
    color:var(--primary); cursor:pointer;
    padding:.44rem .8rem; border-radius:6px;
    position:relative; transition:all .18s;
}
.nav-link::after { display:none; }
.nav-link:hover  { color:var(--primary); background:rgba(28,68,86,.08); }
.nav-link.active { color:var(--primary); background:rgba(28,68,86,.1); font-weight:700; }

.nav-divider { width:1px; height:16px; background:rgba(28,68,86,.1); margin:0 .5rem; flex-shrink:0; }

.nav-cta {
    display:inline-flex; align-items:center;
    background: var(--primary);
    border:none;
    padding:.46rem 1.1rem; border-radius:6px;
    font-family:var(--font-aux); font-size:.68rem; font-weight:700;
    letter-spacing:.08em; text-transform:uppercase;
    color:white; cursor:pointer; transition:all .2s;
}
.nav-cta:hover { background: var(--blue); transform:translateY(-1px); box-shadow:0 4px 14px rgba(28,68,86,.2); }

/* Theme toggle */
.theme-toggle {
    display:inline-flex; align-items:center; justify-content:center;
    width:34px; height:34px; border-radius:8px;
    border:1px solid rgba(28,68,86,.1);
    background:transparent; cursor:pointer; color:var(--text-muted);
    transition:all .2s; margin-left:.25rem;
}
.theme-toggle:hover { background:rgba(28,68,86,.05); color:var(--primary); border-color:rgba(28,68,86,.2); }
.theme-icon { display:none; }
:root:not(.dark) .theme-icon-moon { display:flex; }
:root.dark .theme-icon-sun { display:flex; }

/* Hamburger button */
.nav-toggle {
    display: none;
    width: 38px; height: 38px;
    border: 1px solid rgba(28,68,86,.15);
    background: transparent;
    border-radius: 8px;
    cursor: pointer;
    align-items: center; justify-content: center;
    transition: all .2s;
    flex-shrink: 0;
}
.nav-toggle:hover { background:rgba(28,68,86,.06); border-color:rgba(28,68,86,.3); }
.nav-toggle:active { transform:scale(.95); }

.burger-icon { display:block; transition: opacity .15s; }
.burger-open rect { fill: var(--primary); }
.burger-close line { stroke: var(--primary); }
.burger-close { display:none; }
.header.mobile-open .burger-open  { display:none; }
.header.mobile-open .burger-close { display:block; }

.nav-toggle-lines { display:none; }
.nav-burger       { display:none; }

/* Mobile overlay */
.mobile-menu-overlay {
    display:none; position:fixed; inset:0; z-index:95;
    background:rgba(10,25,35,.35); backdrop-filter:blur(3px);
}
.header.mobile-open .mobile-menu-overlay { display:block; }

/* Mobile menu panel */
.mobile-menu {
    position:fixed; top:68px; left:0; right:0; z-index:120;
    background:#eaf2f6;
    border-top:2px solid var(--primary);
    box-shadow:0 12px 40px rgba(28,68,86,.12);
    transform:translateY(-6px);
    opacity:0; pointer-events:none;
    transition:transform .22s ease, opacity .22s ease;
}
.header.mobile-open .mobile-menu { transform:translateY(0); opacity:1; pointer-events:auto; }

.mobile-menu-inner {
    max-width:1400px; margin:0 auto;
    padding:.85rem 1.25rem 1.1rem;
    display:flex; flex-direction:column; gap:.15rem;
}

.mobile-link {
    width:100%; text-align:left; background:none; border:none;
    padding:.8rem .9rem; border-radius:7px;
    font-family:var(--font-aux); font-size:.76rem; font-weight:600;
    letter-spacing:.08em; text-transform:uppercase;
    color:var(--text-muted); cursor:pointer; transition:all .18s;
}
.mobile-link:hover  { color:var(--primary); background:rgba(28,68,86,.05); }
.mobile-link.active { color:var(--primary); background:rgba(28,68,86,.07); font-weight:700; }

.mobile-cta {
    margin-top:.45rem;
    background: var(--primary);
    color:white; border-radius:7px; padding:.85rem 1rem;
    text-align:center; font-weight:700;
}
.mobile-cta:hover { background: var(--blue); color:white; }

/* Theme toggle mobile */
.theme-toggle-mobile {
    display:flex; align-items:center; gap:.6rem;
    width:100%; background:none; border:none;
    padding:.8rem .9rem; border-radius:7px;
    font-family:var(--font-aux); font-size:.72rem; font-weight:600;
    letter-spacing:.08em; text-transform:uppercase;
    color:var(--text-muted); cursor:pointer; transition:all .18s;
    margin-top:.2rem;
}
.theme-toggle-mobile:hover { color:var(--primary); background:rgba(28,68,86,.05); }

/* Unused legacy */
.mobile-nav-overlay { display:none; }
.mobile-nav         { display:none; }

/* Dark: header */
:root.dark .header,
:root.dark .header.scrolled,
:root.dark .header.page-mode {
    background: rgba(22,45,58,.98);
    border-bottom-color: rgba(91,175,214,.15);
    box-shadow: 0 2px 20px rgba(0,0,0,.25);
}
:root.dark .nav-link        { color: rgba(226,238,244,.9); }
:root.dark .nav-link:hover  { color: white; background: rgba(91,175,214,.12); }
:root.dark .nav-link.active { color: white; background: rgba(91,175,214,.15); }
:root.dark .nav-divider     { background: rgba(91,175,214,.12); }
:root.dark .nav-cta         { background: var(--blue); }
:root.dark .nav-cta:hover   { background: #9EDFFF; color: #0f1e24; }
:root.dark .theme-toggle    { border-color: rgba(91,175,214,.2); color: rgba(226,238,244,.5); }
:root.dark .theme-toggle:hover { background: rgba(91,175,214,.08); color: var(--blue); }
:root.dark .nav-toggle      { border-color: rgba(91,175,214,.2); }
:root.dark .nav-toggle:hover { background: rgba(91,175,214,.08); }
:root.dark .burger-open rect { fill: var(--blue); }
:root.dark .burger-close line { stroke: var(--blue); }
:root.dark .mobile-menu     { background: rgba(22,45,58,.99); border-top-color: var(--blue); }
:root.dark .mobile-link     { color: rgba(226,238,244,.8); }
:root.dark .mobile-link:hover  { color: white; background: rgba(91,175,214,.12); }
:root.dark .mobile-link.active { color: white; background: rgba(91,175,214,.15); }
:root.dark .mobile-cta      { background: var(--blue); color: #0f1e24; }
:root.dark .theme-toggle-mobile { color: rgba(226,238,244,.45); }

/* ── HERO ────────────────────────────────────────── */
.hero {
    min-height:100vh; position:relative;
    display:flex; align-items:center; overflow:hidden;
    background: var(--dark);
}
.hero-bg {
    position:absolute; inset:0;
    background:
        radial-gradient(ellipse 80% 60% at 70% 50%, rgba(46,132,175,.14) 0%, transparent 60%),
        radial-gradient(ellipse 50% 70% at 20% 80%, rgba(255,200,91,.07) 0%, transparent 50%),
        linear-gradient(155deg, #011010 0%, #021A1B 45%, #031e1e 100%);
}
.hero-grid {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
    background-size:80px 80px;
    mask-image:radial-gradient(ellipse 80% 60% at 50% 50%, black 30%, transparent 100%);
}
.hero-inner {
    position:relative; z-index:2;
    max-width:1400px; margin:0 auto;
    padding:0 1.5rem; padding-top:72px;
    width:100%; display:grid;
    grid-template-columns:1fr 1fr;
    gap:4rem; align-items:center; min-height:100vh;
    box-sizing: border-box;
}

.hero-eyebrow { display:flex; align-items:center; gap:1rem; margin-bottom:1.75rem; }
.hero-eyebrow-line { width:36px; height:1px; background:var(--yellow); }
.hero-eyebrow-text {
    font-family:var(--font-aux); font-size:.65rem; font-weight:600;
    letter-spacing:.22em; text-transform:uppercase; color:var(--yellow);
}

.hero-title {
    font-family:var(--font-title);
    font-size:clamp(2rem,5.2vw,5.2rem);
    font-weight:800; line-height:1.05; color:white; margin-bottom:1.5rem;
    text-transform:uppercase;
    word-break: break-word;
    overflow-wrap: break-word;
}
.hero-title em    { font-style:italic; font-weight:400; color:rgba(255,255,255,.4); text-transform:none; display:block; font-size:.7em; margin-bottom:.2em; }
.hero-title strong{ font-weight:900; display:block; }

.hero-desc {
    font-family:var(--font-body); font-size:.98rem; line-height:1.85;
    color:rgba(255,255,255,.42); max-width:440px; margin-bottom:2.5rem;
}

.hero-actions { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }

.btn-primary {
    display:inline-flex; align-items:center; gap:.55rem;
    padding:.82rem 1.9rem; background:var(--yellow); color:var(--dark);
    border:none; border-radius:2px;
    font-family:var(--font-aux); font-size:.72rem; font-weight:700;
    letter-spacing:.1em; text-transform:uppercase; cursor:pointer;
    transition:all .28s;
}
.btn-primary:hover { filter:brightness(1.08); transform:translateY(-2px); box-shadow:0 8px 24px rgba(255,200,91,.3); }

.btn-outline {
    display:inline-flex; align-items:center; gap:.55rem;
    padding:.82rem 1.9rem; background:transparent;
    color:rgba(255,255,255,.65); border:1px solid rgba(255,255,255,.18);
    border-radius:2px; font-family:var(--font-aux); font-size:.72rem;
    font-weight:600; letter-spacing:.1em; text-transform:uppercase;
    cursor:pointer; transition:all .28s;
}
.btn-outline:hover { border-color:rgba(255,255,255,.45); color:white; }

.hero-badges { display:flex; align-items:center; gap:1.1rem; margin-top:2rem; flex-wrap:wrap; }
.hero-badge {
    display:flex; align-items:center; gap:.4rem;
    font-family:var(--font-aux); font-size:.6rem; font-weight:600;
    letter-spacing:.12em; text-transform:uppercase; color:rgba(255,255,255,.3);
}
.hero-badge svg { color:var(--yellow); opacity:.7; flex-shrink:0; }

/* Hero cards */
.hero-visual { display:flex; justify-content:center; align-items:center; position:relative; }
.hero-card-stack { position:relative; width:360px; height:400px; }
.hero-card { position:absolute; border-radius:4px; backdrop-filter:blur(8px); padding:2rem; border:1px solid rgba(255,255,255,.07); }
.hero-card-1 {
    top:0; left:0; right:40px; bottom:40px;
    background:linear-gradient(135deg,rgba(28,68,86,.65),rgba(2,26,27,.88));
    border-color:rgba(46,132,175,.22);
}
.hero-card-2 {
    top:40px; left:40px; right:0; bottom:0;
    background:rgba(28,68,86,.18);
    border-color:rgba(46,132,175,.12);
}
.hero-stat-num  { font-family:var(--font-title); font-size:2.8rem; font-weight:700; color:white; line-height:1; }
.hero-stat-label{ font-family:var(--font-aux); font-size:.6rem; font-weight:500; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.32); margin-top:4px; }
.hero-divider   { width:100%; height:1px; background:rgba(255,255,255,.07); margin:1.1rem 0; }
.hero-tag {
    display:inline-flex; align-items:center; gap:.4rem;
    padding:.28rem .75rem; border:1px solid rgba(255,200,91,.28); border-radius:2px;
    font-family:var(--font-aux); font-size:.6rem; font-weight:600;
    letter-spacing:.14em; text-transform:uppercase; color:var(--yellow); margin-top:.4rem;
}

.hero-scroll {
    position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
    display:flex; flex-direction:column; align-items:center; gap:.45rem;
    cursor:pointer; z-index:2;
}
.hero-scroll-text { font-family:var(--font-aux); font-size:.6rem; font-weight:500; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.22); }
.hero-scroll-line { width:1px; height:38px; background:linear-gradient(to bottom,rgba(255,200,91,.5),transparent); animation:pulse 2s ease infinite; }

/* ── ÁREAS ────────────────────────────────────────── */
.areas-section { background:var(--bg); padding:8rem 0; position:relative; }
.areas-section::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--border),transparent); }

.section-container { max-width:1400px; margin:0 auto; padding:0 2.5rem; }
.section-header-row { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:4.5rem; gap:2rem; }

.section-label { display:flex; align-items:center; gap:.7rem; margin-bottom:1rem; }
.section-label-line { width:30px; height:1px; background:var(--yellow); }
.section-label-text { font-family:var(--font-aux); font-size:.6rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--yellow); }

.section-title-serif { font-family:var(--font-title); font-size:clamp(2rem,3.8vw,3.2rem); font-weight:800; color:var(--primary); line-height:1.12; text-transform:uppercase; }
.section-title-serif em { font-style:italic; font-weight:400; color:var(--text-muted); text-transform:none; }
.section-desc { font-family:var(--font-body); font-size:.87rem; line-height:1.8; color:var(--text-muted); max-width:310px; text-align:right; }

.areas-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5px; background:var(--border); border:1px solid var(--border); }
@media(max-width:1024px){ .areas-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px) { .areas-grid{ grid-template-columns:1fr; } }

.area-card { background:var(--bg); padding:2.5rem 2rem; transition:background .28s; position:relative; overflow:hidden; }
.area-card::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--yellow); transition:width .38s ease; }
.area-card:hover { background:white; }
.area-card:hover::after { width:100%; }
.area-num   { font-family:var(--font-aux); font-size:.6rem; font-weight:600; letter-spacing:.2em; color:var(--yellow); margin-bottom:1.5rem; }
.area-icon  { width:38px; height:38px; margin-bottom:1.2rem; color:var(--primary); opacity:.75; }
.area-title { font-family:var(--font-title); font-size:1.2rem; font-weight:700; color:var(--primary); margin-bottom:.7rem; line-height:1.2; text-transform:uppercase; }
.area-desc  { font-family:var(--font-body); font-size:.8rem; line-height:1.72; color:var(--text-muted); }

/* Citação */
.areas-quote-block { margin-top:5rem; padding:3rem 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); display:flex; flex-direction:column; align-items:center; text-align:center; gap:.9rem; }
.areas-quote-line  { width:36px; height:1px; background:var(--yellow); }
.areas-quote       { font-family:var(--font-title); font-size:clamp(1.05rem,1.8vw,1.4rem); font-style:italic; font-weight:400; color:var(--primary); max-width:680px; line-height:1.65; quotes:none; }
.areas-quote-author{ font-family:var(--font-aux); font-size:.62rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--yellow); }

.areas-numbers-bar {
    display:flex; justify-content:space-between; align-items:center;
    margin-top:5rem; padding:3rem 2.5rem; border-top:1px solid var(--border);
    gap:0; flex-wrap:wrap;
    background: linear-gradient(135deg, rgba(28,68,86,.03) 0%, rgba(46,132,175,.03) 100%);
    border:1px solid var(--border);
    border-radius:4px;
}
.number-stat {
    text-align:center; flex:1; min-width:120px;
    padding: 1rem 1.5rem;
    position: relative;
}
.number-stat + .number-stat::before {
    content:''; position:absolute; left:0; top:20%; bottom:20%;
    width:1px; background: var(--border);
}
.number-stat-value {
    font-family:var(--font-title); font-size:clamp(2.4rem,4vw,3.5rem);
    font-weight:900; color:var(--primary); line-height:1;
    background: linear-gradient(135deg, var(--primary), var(--blue));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
}
.number-stat-label {
    font-family:var(--font-aux); font-size:.62rem; font-weight:600;
    letter-spacing:.14em; text-transform:uppercase;
    color:var(--text-muted); margin-top:.5rem; line-height:1.4;
}

/* ── PAGE HERO ───────────────────────────────────── */
.page-hero { background:var(--dark); padding:10rem 2.5rem 6rem; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(46,132,175,.1) 0%,transparent 60%); }
.page-hero-inner { position:relative; z-index:1; max-width:1400px; margin:0 auto; }
.page-hero-label { display:flex; align-items:center; gap:.7rem; margin-bottom:1.4rem; }
.page-hero-label-line { width:30px; height:1px; background:var(--yellow); }
.page-hero-label-text { font-family:var(--font-aux); font-size:.6rem; font-weight:600; letter-spacing:.24em; text-transform:uppercase; color:var(--yellow); }
.page-hero-title { font-family:var(--font-title); font-size:clamp(2.8rem,5.5vw,5.5rem); font-weight:800; color:white; line-height:1.05; max-width:800px; text-transform:uppercase; }
.page-hero-title em { font-style:italic; font-weight:400; color:rgba(255,255,255,.38); text-transform:none; display:block; }
.page-hero-sub { margin-top:1.4rem; font-family:var(--font-body); font-size:.95rem; font-style:italic; color:rgba(255,255,255,.28); max-width:580px; line-height:1.65; }

/* ── SOBRE ───────────────────────────────────────── */
.sobre-content { max-width:1400px; margin:0 auto; padding:6rem 2.5rem; }
.sobre-grid { display:grid; grid-template-columns:1fr 1fr; gap:5.5rem; align-items:start; margin-bottom:6rem; }
@media(max-width:900px){ .sobre-grid{ grid-template-columns:1fr; gap:3rem; } }

.sobre-text-big   { font-family:var(--font-title); font-size:clamp(1.3rem,2.2vw,1.85rem); font-weight:700; line-height:1.45; color:var(--primary); margin-bottom:1.75rem; }
.sobre-text-big strong { font-weight:900; }
.sobre-text-body  { font-family:var(--font-body); font-size:.88rem; line-height:1.9; color:var(--text-muted); margin-bottom:1.4rem; }

.sobre-values { display:flex; flex-direction:column; border:1px solid var(--border); }
.sobre-value-item { display:flex; align-items:flex-start; gap:1.4rem; padding:1.4rem 1.6rem; border-bottom:1px solid var(--border); transition:background .25s; }
.sobre-value-item:last-child { border-bottom:none; }
.sobre-value-item:hover { background:rgba(28,68,86,.03); }
.sobre-value-num   { font-family:var(--font-aux); font-size:.6rem; font-weight:600; color:var(--yellow); padding-top:3px; flex-shrink:0; letter-spacing:.1em; }
.sobre-value-title { font-family:var(--font-title); font-size:1.05rem; font-weight:700; color:var(--primary); margin-bottom:.28rem; }
.sobre-value-desc  { font-family:var(--font-body); font-size:.8rem; color:var(--text-muted); line-height:1.62; }

/* Timeline */
.sobre-timeline { padding:4rem 0; border-top:1px solid var(--border); margin-bottom:4rem; }
.timeline-grid  { display:grid; grid-template-columns:repeat(5,1fr); gap:0; position:relative; }
.timeline-grid::before { content:''; position:absolute; top:17px; left:0; right:0; height:1px; background:linear-gradient(90deg,var(--yellow),var(--border)); }
@media(max-width:900px){ .timeline-grid{ grid-template-columns:1fr 1fr; gap:2rem; } .timeline-grid::before{display:none;} }
@media(max-width:480px){ .timeline-grid{ grid-template-columns:1fr; } }
.timeline-item { padding-top:2.4rem; padding-right:1.4rem; position:relative; }
.timeline-item::before { content:''; position:absolute; top:11px; left:0; width:12px; height:12px; border-radius:50%; background:var(--yellow); border:3px solid var(--bg); box-shadow:0 0 0 1px var(--yellow); }
.timeline-year { font-family:var(--font-aux); font-size:1rem; font-weight:700; color:var(--primary); margin-bottom:.5rem; letter-spacing:.04em; }
.timeline-desc { font-family:var(--font-body); font-size:.76rem; color:var(--text-muted); line-height:1.6; }

/* Equipe */
.equipe-section { border-top:1px solid var(--border); padding-top:4.5rem; }
.equipe-grid    { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-top:2.5rem; }
@media(max-width:1100px){ .equipe-grid{ grid-template-columns:1fr 1fr; } }
@media(max-width:580px) { .equipe-grid{ grid-template-columns:1fr; } }

.equipe-card { border:1px solid var(--border); background:var(--card-bg); overflow:hidden; transition:all .28s; position:relative; display:flex; flex-direction:column; }
.equipe-card.admin-border { border:2px dashed var(--yellow); }
.equipe-card:hover { box-shadow:0 16px 48px rgba(28,68,86,.15); transform:translateY(-5px); border-color:rgba(46,132,175,.35); }

/* Card photo area — taller, full-width */
.equipe-card-top { height:280px; background:linear-gradient(160deg,var(--primary) 0%,var(--blue) 100%); display:flex; align-items:flex-end; justify-content:center; position:relative; overflow:hidden; }
.equipe-card-top::after { content:''; position:absolute; bottom:0; left:0; right:0; height:70px; background:linear-gradient(to top, var(--card-bg), transparent); z-index:1; }

.equipe-avatar-wrap { position:relative; width:100%; height:100%; }
.equipe-avatar { width:100%; height:100%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.3); }
.equipe-avatar svg { width:72px; height:72px; }
.equipe-avatar-img { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }

.equipe-avatar-upload-overlay { position:absolute; inset:0; background:rgba(0,0,0,.55); display:none; align-items:center; justify-content:center; cursor:pointer; z-index:5; }
.equipe-avatar-wrap:hover .equipe-avatar-upload-overlay { display:flex; }
.equipe-avatar-upload-overlay .upload-label { display:flex; flex-direction:column; align-items:center; gap:.4rem; cursor:pointer; color:white; font-family:var(--font-aux); font-size:.6rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; padding:.75rem; text-align:center; }
.equipe-avatar-upload-overlay .upload-input { display:none; }

.equipe-card-body { padding:1.5rem 1.6rem 1.75rem; flex:1; display:flex; flex-direction:column; position:relative; z-index:2; }
.equipe-role    { font-family:var(--font-aux); font-size:.58rem; font-weight:700; letter-spacing:.2em; text-transform:uppercase; color:var(--blue); margin-bottom:.3rem; }
.equipe-name    { font-family:var(--font-title); font-size:1.25rem; font-weight:800; color:var(--primary); margin-bottom:.6rem; line-height:1.2; }
.equipe-bio     { font-family:var(--font-body); font-size:.8rem; color:var(--text-muted); line-height:1.7; margin-bottom:1rem; border-bottom:1px solid var(--border); padding-bottom:.9rem; flex:1; }
.equipe-specialty{ font-family:var(--font-aux); font-size:.6rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--primary); opacity:.65; }

.card-admin-actions { display:none; position:absolute; top:.7rem; right:.7rem; gap:.35rem; }
.card-admin-actions.active { display:flex; }
.action-btn  { width:28px; height:28px; display:flex; align-items:center; justify-content:center; border-radius:3px; border:none; cursor:pointer; transition:all .2s; }
.delete-btn  { background:rgba(220,38,38,.12); color:#dc2626; }
.delete-btn:hover { background:rgba(220,38,38,.22); }
.edit-btn    { background:rgba(46,132,175,.12); color:var(--blue); }
.edit-btn:hover { background:rgba(46,132,175,.22); }

.add-member-card { border:2px dashed var(--border); background:transparent; min-height:200px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.7rem; cursor:pointer; transition:all .28s; color:var(--text-muted); }
.add-member-card:hover { border-color:var(--yellow); color:var(--yellow); }

/* ── NOTÍCIAS ─────────────────────────────────────── */
.noticias-content { max-width:1400px; margin:0 auto; padding:6rem 2.5rem; }
.noticias-toolbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:2.5rem; padding-bottom:1.75rem; border-bottom:1px solid var(--border); flex-wrap:wrap; gap:1rem; }
.noticias-filters { display:flex; gap:.45rem; flex-wrap:wrap; }
.filter-btn { padding:.38rem .95rem; border:1px solid var(--border); background:none; border-radius:2px; font-family:var(--font-aux); font-size:.65rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); cursor:pointer; transition:all .22s; }
.filter-btn:hover, .filter-btn.active { background:var(--primary); border-color:var(--primary); color:white; }

.add-news-btn { display:none; align-items:center; gap:.45rem; padding:.58rem 1.35rem; background:var(--primary); color:white; border:none; border-radius:2px; font-family:var(--font-aux); font-size:.68rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; transition:all .28s; }
.add-news-btn.active { display:flex; }
.add-news-btn:hover  { background:var(--blue); }

.noticias-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
@media(max-width:1024px){ .noticias-grid{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:640px) { .noticias-grid{ grid-template-columns:1fr; } }

.noticia-card.featured { grid-column:span 3; display:grid; grid-template-columns:1fr 1fr; }
@media(max-width:1024px){ .noticia-card.featured{ grid-column:span 2; } }
@media(max-width:640px) { .noticia-card.featured{ grid-column:span 1; grid-template-columns:1fr; } }

.noticia-card { background:var(--card-bg); border:1px solid var(--border); overflow:hidden; transition:all .32s; position:relative; cursor:pointer; display:flex; flex-direction:column; }
.noticia-card.admin-border { border:2px dashed var(--yellow); }
.noticia-card:hover { box-shadow:0 16px 48px rgba(28,68,86,.11); transform:translateY(-4px); }

.noticia-img-wrap { overflow:hidden; background:linear-gradient(135deg,var(--primary),var(--blue)); position:relative; }
.noticia-card:not(.featured) .noticia-img-wrap { height:200px; }
.noticia-card.featured .noticia-img-wrap { min-height:360px; }
.noticia-img { width:100%; height:100%; object-fit:cover; transition:transform .55s ease; display:block; }
.noticia-card:hover .noticia-img { transform:scale(1.04); }

.noticia-img-placeholder { width:100%; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.7rem; color:rgba(255,255,255,.25); font-family:var(--font-aux); font-size:.65rem; letter-spacing:.15em; text-transform:uppercase; position:absolute; inset:0; }
.noticia-tag-float { position:absolute; top:.9rem; left:.9rem; padding:.22rem .7rem; background:rgba(2,26,27,.75); backdrop-filter:blur(4px); border-radius:2px; font-family:var(--font-aux); font-size:.58rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--yellow); }

.noticia-body { padding:1.65rem; flex:1; display:flex; flex-direction:column; }
.noticia-card.featured .noticia-body { padding:2.4rem; justify-content:center; }

.noticia-meta { display:flex; align-items:center; gap:.9rem; margin-bottom:.9rem; font-family:var(--font-aux); font-size:.6rem; font-weight:500; letter-spacing:.09em; color:var(--text-muted); }
.noticia-meta-dot { width:3px; height:3px; border-radius:50%; background:var(--border); }

.noticia-title { font-family:var(--font-title); font-size:1.35rem; font-weight:700; color:var(--primary); line-height:1.28; margin-bottom:.7rem; transition:color .25s; }
.noticia-card.featured .noticia-title { font-size:1.85rem; }
.noticia-card:hover .noticia-title { color:var(--blue); }
.noticia-summary { font-family:var(--font-body); font-size:.83rem; line-height:1.72; color:var(--text-muted); flex:1; margin-bottom:1.4rem; }
.noticia-read-more { display:flex; align-items:center; gap:.45rem; font-family:var(--font-aux); font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--primary); transition:all .25s; margin-top:auto; }
.noticia-card:hover .noticia-read-more { gap:.75rem; color:var(--blue); }

.noticia-admin-actions { display:none; position:absolute; top:.7rem; right:.7rem; gap:.35rem; z-index:5; }
.noticia-admin-actions.active { display:flex; }
.noticia-img-upload-overlay { position:absolute; inset:0; display:none; align-items:center; justify-content:center; background:rgba(2,26,27,.55); z-index:3; cursor:pointer; }
.noticia-card.admin-border .noticia-img-wrap:hover .noticia-img-upload-overlay { display:flex; }
.upload-label { display:flex; flex-direction:column; align-items:center; gap:.45rem; color:white; font-family:var(--font-aux); font-size:.65rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; }
.upload-input { display:none; }

/* ── CONTATO ─────────────────────────────────────── */
.contato-content { max-width:1400px; margin:0 auto; padding:6rem 2.5rem; display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:start; }
@media(max-width:900px){ .contato-content{ grid-template-columns:1fr; gap:3rem; } }

.contato-info-desc { font-family:var(--font-body); font-size:.88rem; line-height:1.82; color:var(--text-muted); margin-bottom:2.5rem; max-width:380px; }
.contato-info-list { display:flex; flex-direction:column; }
.contato-info-item { display:flex; align-items:flex-start; gap:1.1rem; padding:1.2rem 0; border-bottom:1px solid var(--border); }
.contato-info-item:last-child { border-bottom:none; }
.contato-info-icon { width:34px; height:34px; border:1px solid var(--border); border-radius:3px; display:flex; align-items:center; justify-content:center; color:var(--yellow); flex-shrink:0; }
.contato-info-label { font-family:var(--font-aux); font-size:.6rem; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--yellow); margin-bottom:.22rem; }
.contato-info-value { font-family:var(--font-body); font-size:.86rem; color:var(--text); line-height:1.55; }

.contato-form { background:var(--card-bg); border:1px solid var(--border); padding:2.4rem; }
.contato-form-title { font-family:var(--font-title); font-size:1.55rem; font-weight:700; color:var(--primary); margin-bottom:.45rem; }
.contato-form-sub { font-family:var(--font-body); font-size:.8rem; color:var(--text-muted); margin-bottom:1.75rem; padding-bottom:1.4rem; border-bottom:1px solid var(--border); }
.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media(max-width:500px){ .form-row{ grid-template-columns:1fr; } }
.form-group { display:flex; flex-direction:column; gap:.35rem; margin-bottom:1.1rem; }
.form-label { font-family:var(--font-aux); font-size:.62rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--text-muted); }
.form-input, .form-select, .form-textarea { padding:.72rem .95rem; background:var(--bg); border:1px solid var(--border); border-radius:2px; font-family:var(--font-body); font-size:.86rem; color:var(--text); transition:border-color .25s; outline:none; }
.form-input:focus, .form-select:focus, .form-textarea:focus { border-color:var(--blue); background:white; }
.form-textarea { resize:vertical; min-height:115px; }
.form-submit { width:100%; padding:.88rem; background:var(--primary); color:white; border:none; border-radius:2px; font-family:var(--font-aux); font-size:.72rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; cursor:pointer; transition:all .28s; margin-top:.65rem; }
.form-submit:hover { background:var(--blue); transform:translateY(-1px); }
.form-success { display:none; align-items:center; gap:.7rem; padding:.9rem 1.1rem; background:rgba(22,163,74,.07); border:1px solid rgba(22,163,74,.18); border-radius:2px; font-family:var(--font-body); font-size:.8rem; color:#166534; margin-top:.9rem; }
.form-success.show { display:flex; }

/* ── MODAL LOGIN ─────────────────────────────────── */
.modal-overlay { position:fixed; inset:0; z-index:300; background:rgba(2,26,27,.72); backdrop-filter:blur(6px); display:none; align-items:center; justify-content:center; padding:1rem; }
.modal-overlay.active { display:flex; }
.modal-box { background:var(--card-bg); width:100%; max-width:420px; border-radius:4px; padding:2.4rem; position:relative; box-shadow:0 32px 80px rgba(0,0,0,.22); }
.modal-x { position:absolute; top:1.2rem; right:1.2rem; background:none; border:none; font-size:1.4rem; color:var(--text-muted); cursor:pointer; line-height:1; }
.modal-icon-wrap { width:46px; height:46px; background:var(--bg); border:1px solid var(--border); border-radius:3px; display:flex; align-items:center; justify-content:center; margin-bottom:1.1rem; color:var(--primary); }
.modal-title { font-family:var(--font-title); font-size:1.55rem; font-weight:700; color:var(--primary); margin-bottom:.3rem; }
.modal-sub { font-family:var(--font-body); font-size:.8rem; color:var(--text-muted); margin-bottom:1.75rem; padding-bottom:1.4rem; border-bottom:1px solid var(--border); }
.modal-field { position:relative; margin-bottom:.9rem; }
.modal-input { width:100%; padding:.82rem 2.8rem .82rem .95rem; background:var(--bg); border:1px solid var(--border); border-radius:2px; font-family:var(--font-body); font-size:.88rem; outline:none; transition:border-color .25s; }
.modal-input:focus { border-color:var(--blue); background:white; }
.modal-input.error { border-color:#dc2626; background:#fef2f2; }
.modal-eye { position:absolute; right:.82rem; top:50%; transform:translateY(-50%); background:none; border:none; color:var(--text-muted); cursor:pointer; }
.modal-error { font-family:var(--font-aux); font-size:.72rem; font-weight:600; color:#dc2626; text-align:center; margin-bottom:.7rem; display:none; }
.modal-error.show { display:block; }
.modal-submit { width:100%; padding:.88rem; background:var(--primary); color:white; border:none; border-radius:2px; font-family:var(--font-aux); font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; transition:all .28s; }
.modal-submit:hover { background:var(--blue); }
.modal-hint { text-align:center; font-family:var(--font-aux); font-size:.58rem; font-weight:500; color:#b0b0b0; letter-spacing:.1em; margin-top:.9rem; text-transform:uppercase; }

/* ── ADMIN FLOATING ──────────────────────────────── */
.admin-floating { position:fixed; bottom:1.25rem; right:1.25rem; z-index:200; display:flex; flex-direction:column; align-items:flex-end; gap:.5rem; }
.admin-btn { display:flex; align-items:center; gap:.55rem; padding:.65rem 1rem; border-radius:3px; border:none; font-family:var(--font-aux); font-size:.65rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; cursor:pointer; box-shadow:0 8px 24px rgba(0,0,0,.18); transition:all .28s; max-width:calc(100vw - 2.5rem); }
.admin-btn:hover { transform:translateY(-2px); }
.admin-btn-login  { background:var(--primary); color:white; }
.admin-btn-logout { background:#dc2626; color:white; }

.admin-banner { display:none; position:fixed; top:72px; left:0; right:0; z-index:90; background:rgba(255,200,91,.96); color:var(--dark); padding:.55rem 2.5rem; font-family:var(--font-aux); font-size:.68rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; align-items:center; gap:.7rem; }
.admin-banner.active { display:flex; }

/* ── FOOTER ──────────────────────────────────────── */
.footer { background:var(--dark); color:white; padding:5rem 0 2.5rem; position:relative; }
.footer::before { content:''; position:absolute; top:0; left:2.5rem; right:2.5rem; height:1px; background:linear-gradient(90deg,transparent,rgba(255,200,91,.25),transparent); }
.footer-inner { max-width:1400px; margin:0 auto; padding:0 2.5rem; display:grid; grid-template-columns:2fr 1fr 1fr 1.5fr; gap:3.5rem; margin-bottom:3.5rem; }
@media(max-width:900px){ .footer-inner{ grid-template-columns:1fr 1fr; gap:2.5rem; } }
@media(max-width:600px){ .footer-inner{ grid-template-columns:1fr; } }

.footer-logo-wrap { display:flex; align-items:center; gap:.75rem; margin-bottom:1.2rem; }
.footer-logo-img { height:34px; width:auto; max-width:220px; object-fit:contain; }
.footer-logo-name { font-family:var(--font-title); font-size:1.25rem; font-weight:800; color:white; text-transform:uppercase; }
.footer-desc { font-family:var(--font-body); font-size:.8rem; line-height:1.8; color:rgba(255,255,255,.65); max-width:250px; margin-bottom:1.4rem; }
.footer-social { display:flex; gap:.7rem; }
.footer-social-btn { width:32px; height:32px; border:1px solid rgba(255,255,255,.1); border-radius:3px; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.6); cursor:pointer; transition:all .25s; }
.footer-social-btn:hover { border-color:var(--yellow); color:var(--yellow); }
.footer-col-title { font-family:var(--font-aux); font-size:.58rem; font-weight:700; letter-spacing:.24em; text-transform:uppercase; color:var(--yellow); margin-bottom:1.1rem; }
.footer-links { display:flex; flex-direction:column; gap:.55rem; }
.footer-link { font-family:var(--font-body); font-size:.8rem; color:rgba(255,255,255,.72); cursor:pointer; background:none; border:none; text-align:left; transition:color .25s; padding:0; }
.footer-link:hover { color:white; }
.footer-contact-list { display:flex; flex-direction:column; gap:.7rem; }
.footer-contact-item { display:flex; align-items:flex-start; gap:.7rem; font-family:var(--font-body); font-size:.78rem; color:rgba(255,255,255,.72); line-height:1.5; }
.footer-contact-item svg { flex-shrink:0; margin-top:2px; color:var(--yellow); opacity:.55; }
.footer-bottom { max-width:1400px; margin:0 auto; padding:1.75rem 2.5rem 0; border-top:1px solid rgba(255,255,255,.05); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-copy { font-family:var(--font-aux); font-size:.62rem; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.45); }

/* ── RESPONSIVE ──────────────────────────────────── */
@media(max-width:1024px){
    .hero-inner{ grid-template-columns:1fr; padding-top:110px; padding-bottom:80px; min-height:auto; }
    .hero-visual{ display:none; }
}
.admin-btn-icon-only {
    padding:.55rem .7rem !important;
    min-width:unset !important;
    border-radius:50% !important;
    width:40px; height:40px;
    justify-content:center;
}


@media(max-width:768px){
    .nav-links{ display:none; }
    .nav-toggle{
        display:flex !important;
        align-items:center !important;
        justify-content:center !important;
        border-radius:10px !important;
        width:40px !important;
        height:40px !important;
    }
    .logo-text{ display:none; }
    .logo-img{ height:34px; max-width:190px; }
    .section-header-row{ flex-direction:column; align-items:flex-start; }
    .section-desc{ text-align:left; }
    .noticias-toolbar{ flex-direction:column; align-items:flex-start; }
    .contato-content,.sobre-content,.noticias-content{ padding:4rem 1.25rem; }
    .section-container{ padding:0 1.25rem; }
    .areas-section{ padding:5rem 0; }
    .page-hero{ padding:8rem 1.25rem 4rem; }
    .footer-inner,.footer-bottom{ padding-left:1.25rem; padding-right:1.25rem; }
    .equipe-card-top{ height:240px; }
    .sobre-grid{ gap:2.5rem; }
    .areas-numbers-bar{ gap:0; flex-wrap:wrap; padding:1.5rem 1rem; }
    .number-stat{ min-width:45%; }
    .number-stat + .number-stat::before{ display:none; }
    /* Hero mobile */
    .hero-inner{ padding-left:1.25rem; padding-right:1.25rem; }
    .hero-title{ font-size:clamp(1.8rem,8vw,3rem); }
    .hero-desc{ font-size:.9rem; max-width:100%; }
    .hero-actions{ flex-direction:column; align-items:stretch; gap:.75rem; }
    .btn-primary,.btn-outline{ justify-content:center; width:100%; }
    .hero-badges{ gap:.75rem; }
    /* Admin btn */
    .admin-floating{ bottom:1rem; right:1rem; }
    .admin-btn{ font-size:.6rem; padding:.6rem .85rem; }
}

@media(max-width:580px){
    .equipe-card-top{ height:300px; }
    .sobre-content{ padding:3rem 1.25rem; }
    .hero-title{ font-size:clamp(1.6rem,7.5vw,2.4rem); }
    .hero-eyebrow-text{ font-size:.58rem; letter-spacing:.15em; }
    .areas-numbers-bar{ padding:1.25rem .75rem; }
    .number-stat{ min-width:48%; padding:.75rem; }
    .number-stat-value{ font-size:clamp(2rem,10vw,2.8rem); }
}

@media(max-width:420px){
    .header-inner{ padding:0 1rem; }
    .logo-img{ max-width:150px; }
    .equipe-card-top{ height:260px; }
    .hero-title{ font-size:clamp(1.5rem,7vw,2rem); }
    .hero-inner{ padding-top:90px; padding-left:1rem; padding-right:1rem; }
    .contato-content,.sobre-content,.noticias-content{ padding:3rem 1rem; }
    .page-hero{ padding:7rem 1rem 3rem; }
    .admin-btn span:not(:first-child){ display:none; }
}

/* ── THEME TOGGLE BUTTON ────────────────────────── */
.theme-toggle {
    display: flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border: 1px solid rgba(28,68,86,.2);
    border-radius: 50%;
    background: transparent;
    cursor: pointer;
    color: var(--primary);
    transition: all .25s;
    position: relative;
    flex-shrink: 0;
}
.theme-toggle:hover { background: rgba(28,68,86,.07); border-color: var(--blue); color: var(--blue); }
.theme-icon { display: flex; align-items: center; justify-content: center; position: absolute; transition: opacity .2s, transform .2s; }
.theme-icon-moon { opacity: 1; transform: rotate(0deg); }
.theme-icon-sun  { opacity: 0; transform: rotate(90deg); }
.dark .theme-icon-moon { opacity: 0; transform: rotate(-90deg); }
.dark .theme-icon-sun  { opacity: 1; transform: rotate(0deg); }

.theme-toggle-mobile {
    width: auto; height: auto; border-radius: 3px;
    padding: .9rem .25rem; border: none; border-bottom: 1px solid rgba(28,68,86,.07);
    justify-content: flex-start; gap: .65rem; border-radius: 0;
    font-family: var(--font-aux); font-size: .78rem; font-weight: 700;
    letter-spacing: .12em; text-transform: uppercase; color: var(--text-muted);
}
.theme-toggle-mobile:hover { background: transparent; color: var(--primary); }
.theme-toggle-mobile .theme-icon { position: relative; }
.theme-toggle-label { font-family: var(--font-aux); font-size: .78rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }

/* ── DARK MODE ──────────────────────────────────── */
:root.dark {
    --bg:           #0f1e24;
    --dark:         #060e11;
    --primary:      #5bafd6;
    --blue:         #7ec8e8;
    --sky:          #9EDFFF;
    --text:         #e2eef4;
    --text-secondary: #9bbfce;
    --text-muted:   #6b9db0;
    --border:       rgba(91,175,214,0.14);
    --card-bg:      #162028;
    --cream:        #1a2b35;
}

/* Dark: header */
:root.dark .header,
:root.dark .header.scrolled,
:root.dark .header.page-mode {
    background: rgba(12,24,30,.98);
    border-bottom-color: rgba(91,175,214,.1);
    box-shadow: 0 2px 28px rgba(0,0,0,.35);
}
:root.dark .nav-link        { color: rgba(226,238,244,.45); }
:root.dark .nav-link:hover  { color: var(--text); background: rgba(91,175,214,.08); }
:root.dark .nav-link.active { color: var(--text); background: rgba(91,175,214,.1); }
:root.dark .nav-divider     { background: rgba(91,175,214,.15); }
:root.dark .theme-toggle    { border-color: rgba(91,175,214,.25); color: var(--blue); }
:root.dark .theme-toggle:hover { background: rgba(91,175,214,.1); }

/* Dark: mobile menu */
:root.dark .mobile-menu {
    background: #0f1e26;
    border-image: linear-gradient(90deg, var(--blue), #9EDFFF) 1;
    box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
:root.dark .mobile-link        { color: rgba(226,238,244,.5); }
:root.dark .mobile-link:hover  { color: var(--text); background: rgba(91,175,214,.08); }
:root.dark .mobile-link.active { color: var(--text); background: rgba(91,175,214,.1); }
:root.dark .theme-toggle-mobile { color: rgba(226,238,244,.5); }

/* Dark: hero */


:root.dark .hero-grid {
    background-image:
        linear-gradient(rgba(28,68,86,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(28,68,86,.04) 1px, transparent 1px);
}
:root.dark .hero-eyebrow-line { background: var(--primary); opacity:.5; }
:root.dark .hero-eyebrow-text { color: var(--primary); opacity:.7; }
:root.dark .hero-title        { color: var(--primary); }
:root.dark .hero-title em     { color: var(--blue); opacity:.7; }
:root.dark .hero-title strong { color: var(--primary); }
:root.dark .hero-desc         { color: var(--text-muted); }
:root.dark .hero-scroll-text  { color: rgba(28,68,86,.35); }
:root.dark .hero-scroll-line  { background: linear-gradient(to bottom, rgba(28,68,86,.4), transparent); }
:root.dark .hero-stat-num   { color: var(--primary); }
:root.dark .hero-stat-label { color: rgba(28,68,86,.5); }
:root.dark .hero-divider    { background: rgba(28,68,86,.1); }
:root.dark .hero-tag { border-color: rgba(46,132,175,.3); color: var(--blue); background: rgba(46,132,175,.06); }
:root.dark .btn-primary { background: var(--primary); color: white; border-color: var(--primary); box-shadow: 0 4px 16px rgba(28,68,86,.2); }
:root.dark .btn-primary:hover { background: var(--blue); border-color: var(--blue); filter:none; }
:root.dark .btn-outline { border-color: rgba(28,68,86,.3); color: var(--primary); }
:root.dark .btn-outline:hover { border-color: var(--primary); background: rgba(28,68,86,.05); }
/* ── HERO: MODO CLARO ────────────────────────────── */
:root:not(.dark) .hero {
    background: #f4f6f8;
}
:root:not(.dark) .hero-bg {
    background:
        radial-gradient(ellipse 70% 60% at 75% 40%, rgba(28,68,86,.07) 0%, transparent 65%),
        radial-gradient(ellipse 50% 60% at 15% 80%, rgba(46,132,175,.05) 0%, transparent 55%),
        linear-gradient(155deg, #e8eef2 0%, #f0f4f7 45%, #f5f7f9 100%);
}
:root:not(.dark) .hero-grid {
    background-image:
        linear-gradient(rgba(28,68,86,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(28,68,86,.04) 1px, transparent 1px);
}
:root:not(.dark) .hero-eyebrow-line { background: var(--primary); opacity:.5; }
:root:not(.dark) .hero-eyebrow-text { color: var(--primary); opacity:.7; }
:root:not(.dark) .hero-title        { color: var(--primary); }
:root:not(.dark) .hero-title em     { color: var(--blue); -webkit-text-stroke: 0; opacity:.7; }
:root:not(.dark) .hero-title strong { color: var(--primary); }
:root:not(.dark) .hero-desc         { color: var(--text-muted); }
:root:not(.dark) .hero-badge        { border-color: rgba(28,68,86,.15); color: var(--text-muted); }
:root:not(.dark) .hero-scroll-text  { color: rgba(28,68,86,.35); }
:root:not(.dark) .hero-scroll-line  { background: linear-gradient(to bottom, rgba(28,68,86,.4), transparent); }

/* Cards hero no modo claro */
:root:not(.dark) .hero-card-1 {
    background: white;
    border-color: rgba(28,68,86,.14);
    backdrop-filter: none;
    box-shadow: 0 8px 32px rgba(28,68,86,.12);
    z-index: 2;
}
:root:not(.dark) .hero-card-2 {
    background: rgba(228,238,244,.5);
    border-color: rgba(28,68,86,.07);
    z-index: 1;
}
:root:not(.dark) .hero-stat-num   { color: var(--primary); }
:root:not(.dark) .hero-stat-label { color: rgba(28,68,86,.5); }
:root:not(.dark) .hero-divider    { background: rgba(28,68,86,.1); }
:root:not(.dark) .hero-tag {
    border-color: rgba(46,132,175,.3);
    color: var(--blue);
    background: rgba(46,132,175,.06);
}

/* Botões hero no modo claro */
:root:not(.dark) .btn-primary {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
    box-shadow: 0 4px 16px rgba(28,68,86,.2);
}
:root:not(.dark) .btn-primary:hover { background: var(--blue); border-color: var(--blue); filter:none; }
:root:not(.dark) .btn-outline {
    border-color: rgba(28,68,86,.3);
    color: var(--primary);
}
:root:not(.dark) .btn-outline:hover { border-color: var(--primary); color: var(--primary); background: rgba(28,68,86,.05); }


/* Dark: sections & cards */
:root.dark .areas-section { background: var(--bg); }
:root.dark .area-card      { background: var(--card-bg); border-color: var(--border); }
:root.dark .area-card:hover { background: #1c2f3a; }
:root.dark .equipe-card    { background: var(--card-bg); border-color: var(--border); }
:root.dark .equipe-card-top::after { background: linear-gradient(to top, var(--card-bg), transparent); }
:root.dark .noticia-card   { background: var(--card-bg); border-color: var(--border); }
:root.dark .sobre-values   { border-color: var(--border); }
:root.dark .sobre-value-item { border-bottom-color: var(--border); }
:root.dark .sobre-value-item:hover { background: rgba(91,175,214,.04); }
:root.dark .timeline-item::before { border-color: var(--bg); }

/* Dark: forms */
:root.dark .contato-form   { background: var(--card-bg); border-color: var(--border); }
:root.dark .form-input,
:root.dark .form-select,
:root.dark .form-textarea  { background: #1a2b35; border-color: var(--border); color: var(--text); }
:root.dark .form-input:focus,
:root.dark .form-select:focus,
:root.dark .form-textarea:focus { background: #1e3040; border-color: var(--blue); }

/* Dark: modal */
:root.dark .modal-overlay  { background: rgba(0,0,0,.75); }
:root.dark .modal-box      { background: var(--card-bg); }
:root.dark .modal-input    { background: #1a2b35; border-color: var(--border); color: var(--text); }
:root.dark .modal-input:focus { background: #1e3040; }

/* Dark: page hero */
:root.dark .page-hero { background: var(--dark); }

/* Dark: footer already dark — lighten slightly */
:root.dark .footer { background: #060e11; }
:root.dark .footer::before { background: linear-gradient(90deg,transparent,rgba(91,175,214,.15),transparent); }

/* Dark: numbers bar */
:root.dark .number-stat-value { color: var(--blue); }

/* Dark: nav burger lines */
:root.dark .nav-burger span { background: var(--text); }

/* Dark: numbers bar */
:root.dark .areas-numbers-bar {
    background: linear-gradient(135deg, rgba(91,175,214,.05) 0%, rgba(91,175,214,.02) 100%);
}
:root.dark .number-stat-value {
    background: linear-gradient(135deg, var(--blue), #9EDFFF);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
}
:root.dark .number-stat + .number-stat::before { background: var(--border); }
@media(max-width:580px){
    .number-stat + .number-stat::before { display:none; }
    .areas-numbers-bar { gap:1rem; padding:1.5rem 1rem; }
    .number-stat { padding:.75rem 1rem; }
}

/* ── CURRÍCULO MODAL ─────────────────────────────── */
.curriculo-modal { position:relative; }
.curriculo-header {
    display:flex; align-items:flex-start; gap:1.5rem;
    padding:2rem 2rem 1.25rem;
    background:linear-gradient(135deg, var(--primary) 0%, var(--blue) 100%);
    color:white;
}
.curriculo-foto {
    width:90px; height:110px; object-fit:cover; object-position:top center;
    border-radius:8px; flex-shrink:0;
    box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.curriculo-foto-placeholder {
    width:90px; height:110px; border-radius:8px; flex-shrink:0;
    background:rgba(255,255,255,.15); display:flex;
    align-items:center; justify-content:center; color:rgba(255,255,255,.7);
}
.curriculo-header-info { flex:1; min-width:0; }
.curriculo-role {
    font-family:var(--font-aux); font-size:.62rem; font-weight:700;
    letter-spacing:.14em; text-transform:uppercase;
    color:rgba(255,255,255,.75); margin-bottom:.35rem;
}
.curriculo-name {
    font-family:var(--font-title); font-size:1.35rem; font-weight:800;
    color:white; line-height:1.2; margin:0;
}
.curriculo-body { padding:1.5rem 2rem 2rem; }
.curriculo-section-label {
    font-family:var(--font-aux); font-size:.62rem; font-weight:700;
    letter-spacing:.14em; text-transform:uppercase;
    color:var(--blue); margin-bottom:.5rem;
}
.curriculo-bio {
    font-family:var(--font-body); font-size:.88rem;
    color:var(--text-muted); line-height:1.75; margin:0;
}

/* Ver currículo link */
.equipe-ver-mais {
    font-family:var(--font-aux); font-size:.62rem; font-weight:700;
    letter-spacing:.1em; text-transform:uppercase;
    color:var(--blue); margin-top:.75rem;
    transition:color .2s;
}
.equipe-card:hover .equipe-ver-mais { color:var(--primary); }

/* Dark curriculo */
:root.dark .curriculo-body { background:var(--card-bg); }
:root.dark .curriculo-bio  { color:rgba(226,238,244,.6); }

/* ── PARCEIROS ───────────────────────────────────── */
.parceiros-grid {
    padding: 1.5rem 0 .5rem;
    display: flex; gap: 1.5rem; flex-wrap: wrap;
}
.parceiro-card {
    display: flex; flex-direction: column; align-items: flex-start;
    text-decoration: none;
    padding: 1.75rem 2rem;
    background: white;
    border: 1px solid rgba(28,68,86,.1);
    border-radius: 14px;
    box-shadow: 0 2px 12px rgba(28,68,86,.07);
    transition: all .25s;
    max-width: 320px;
}
.parceiro-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(28,68,86,.13);
    border-color: rgba(28,68,86,.18);
}
.parceiro-badge {
    font-family: var(--font-aux); font-size: .58rem; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    color: white; background: var(--blue);
    padding: .25rem .65rem; border-radius: 99px;
    margin-bottom: 1.1rem;
}
.parceiro-logo {
    height: auto; width: 100%; max-width: 200px;
    object-fit: contain; object-position: left center;
    margin-bottom: 1.1rem;
}
.parceiro-divider {
    width: 100%; height: 1px;
    background: rgba(28,68,86,.08);
    margin-bottom: 1rem;
}
.parceiro-name {
    font-family: var(--font-title); font-size: .88rem; font-weight: 700;
    color: var(--primary); line-height: 1.3; margin-bottom: .35rem;
}
.parceiro-desc {
    font-family: var(--font-aux); font-size: .6rem; font-weight: 600;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--text-muted);
}

/* Dark parceiro */
:root.dark .parceiro-card {
    background: var(--card-bg);
    border-color: rgba(91,175,214,.1);
}
:root.dark .parceiro-logo {
    filter: brightness(1) saturate(0) invert(0);
}

/* ── EQUIPE ADMIN BAR ────────────────────────────── */
.equipe-admin-bar {
    display: flex;
    border-top: 1px solid var(--border);
    margin-top: auto;
}
.equipe-admin-edit,
.equipe-admin-delete {
    flex: 1;
    display: flex; align-items: center; justify-content: center; gap: .4rem;
    padding: .75rem;
    border: none; background: none; cursor: pointer;
    font-family: var(--font-aux); font-size: .68rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    transition: all .18s;
}
.equipe-admin-edit {
    color: var(--blue);
    border-right: 1px solid var(--border);
}
.equipe-admin-edit:hover { background: rgba(46,132,175,.08); }
.equipe-admin-delete {
    color: #e05555;
}
.equipe-admin-delete:hover { background: rgba(224,85,85,.08); }
:root.dark .equipe-admin-bar { border-top-color: var(--border); }
:root.dark .equipe-admin-edit { border-right-color: var(--border); }

/* ── PÁGINA DE ARTIGO ────────────────────────────── */
.artigo-page {
    min-height: 100vh;
    background: var(--bg);
    padding-top: 68px;
}
.artigo-back {
    display: inline-flex; align-items: center; gap: .5rem;
    margin: 2rem 2.5rem;
    font-family: var(--font-aux); font-size: .68rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--blue); cursor: pointer; transition: gap .2s;
}
.artigo-back:hover { gap: .8rem; }
.artigo-container {
    max-width: 760px; margin: 0 auto;
    padding: 0 2rem 5rem;
}
.artigo-header { margin-bottom: 2.5rem; }
.artigo-tag {
    display: inline-block;
    font-family: var(--font-aux); font-size: .6rem; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    color: white; background: var(--blue);
    padding: .28rem .75rem; border-radius: 99px;
    margin-bottom: 1rem;
}
.artigo-meta {
    font-family: var(--font-aux); font-size: .68rem;
    color: var(--text-muted); margin-bottom: .75rem;
}
.artigo-titulo {
    font-family: var(--font-title); font-size: clamp(1.8rem, 4vw, 2.8rem);
    font-weight: 800; color: var(--primary);
    line-height: 1.15; margin-bottom: 1.25rem;
    text-transform: uppercase;
}
.artigo-resumo {
    font-family: var(--font-body); font-size: 1.05rem;
    color: var(--text-muted); line-height: 1.7;
    border-left: 3px solid var(--blue);
    padding-left: 1.25rem;
    font-style: italic;
}
.artigo-img-wrap {
    margin: 2rem 0;
    border-radius: 8px; overflow: hidden;
}
.artigo-img {
    width: 100%; height: auto; max-height: 420px;
    object-fit: cover; display: block;
}
.artigo-content { margin-top: 2rem; }
.artigo-paragrafo {
    font-family: var(--font-body); font-size: 1rem;
    color: var(--text); line-height: 1.85;
    margin-bottom: 1.5rem;
}

/* Dark */
:root.dark .artigo-page { background: var(--bg); }
:root.dark .artigo-titulo { color: var(--text); }
:root.dark .artigo-paragrafo { color: rgba(226,238,244,.75); }

/* ── EDITOR DE ARTIGO ────────────────────────────── */
.editor-overlay { background: rgba(0,0,0,.7) !important; }
.editor-box {
    width: 100%; min-height: 100vh;
    background: var(--bg);
    display: flex; flex-direction: column;
}
.editor-toolbar {
    position: sticky; top: 0; z-index: 10;
    display: flex; align-items: center; justify-content: space-between;
    padding: .85rem 2rem;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 2px 12px rgba(28,68,86,.07);
}
.editor-title-bar {
    display: flex; align-items: center; gap: .5rem;
    font-family: var(--font-aux); font-size: .72rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase; color: var(--primary);
}
.editor-actions { display: flex; gap: .75rem; }
.editor-btn-cancel {
    padding: .48rem 1.1rem; border-radius: 6px;
    border: 1px solid var(--border); background: none;
    font-family: var(--font-aux); font-size: .68rem; font-weight: 600;
    letter-spacing: .08em; text-transform: uppercase;
    color: var(--text-muted); cursor: pointer; transition: all .18s;
}
.editor-btn-cancel:hover { background: rgba(28,68,86,.05); }
.editor-btn-save {
    padding: .48rem 1.3rem; border-radius: 6px;
    border: none; background: var(--primary);
    font-family: var(--font-aux); font-size: .68rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    color: white; cursor: pointer; transition: all .18s;
}
.editor-btn-save:hover { background: var(--blue); transform: translateY(-1px); }

.editor-meta-row {
    display: flex; gap: 1rem; padding: 1.25rem 2rem;
    border-bottom: 1px solid var(--border);
    flex-wrap: wrap;
}
.editor-content-wrap { flex: 1; display: flex; flex-direction: column; }
.editor-format-bar {
    display: flex; align-items: center; gap: .35rem;
    padding: .6rem 2rem;
    background: rgba(28,68,86,.03);
    border-bottom: 1px solid var(--border);
    flex-wrap: wrap;
}
.efmt-btn {
    padding: .3rem .65rem; border-radius: 4px;
    border: 1px solid var(--border); background: var(--bg);
    font-family: var(--font-aux); font-size: .68rem; font-weight: 700;
    color: var(--primary); cursor: pointer; transition: all .15s;
}
.efmt-btn:hover { background: var(--primary); color: white; border-color: var(--primary); }
.efmt-italic { font-style: italic; }
.efmt-sep { width: 1px; height: 18px; background: var(--border); margin: 0 .2rem; }
.efmt-hint {
    font-family: var(--font-aux); font-size: .6rem;
    color: var(--text-muted); margin-left: auto;
}
.editor-textarea {
    flex: 1; min-height: 320px;
    padding: 1.5rem 2rem;
    border: none; outline: none; resize: none;
    background: var(--bg); color: var(--text);
    font-family: 'Courier New', monospace; font-size: .9rem; line-height: 1.8;
}
.editor-preview-wrap {
    border-top: 2px solid var(--border);
    padding: 1.5rem 2rem 3rem;
    background: rgba(28,68,86,.02);
}
.editor-preview-label {
    font-family: var(--font-aux); font-size: .62rem; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--blue); margin-bottom: 1.5rem;
}
.editor-preview { max-width: 700px; }

/* Artigo page */
.artigo-sem-conteudo {
    text-align: center; padding: 3rem 0;
    color: var(--text-muted);
    font-family: var(--font-body); font-size: .9rem;
    display: flex; flex-direction: column; align-items: center;
}
.btn-escrever-artigo {
    margin-top: 1rem; padding: .6rem 1.5rem; border-radius: 6px;
    border: none; background: var(--primary); color: white;
    font-family: var(--font-aux); font-size: .68rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    cursor: pointer; transition: all .2s;
}
.btn-escrever-artigo:hover { background: var(--blue); transform: translateY(-1px); }
.artigo-h2 {
    font-family: var(--font-title); font-size: 1.4rem; font-weight: 800;
    color: var(--primary); margin: 2.5rem 0 1rem; text-transform: uppercase;
}
.artigo-h3 {
    font-family: var(--font-title); font-size: 1.1rem; font-weight: 700;
    color: var(--primary); margin: 2rem 0 .75rem;
}
.artigo-list {
    font-family: var(--font-body); font-size: 1rem; line-height: 1.8;
    color: var(--text); margin: 1rem 0 1.5rem 1.5rem;
}
.artigo-list li { margin-bottom: .35rem; }

/* Dark editor */
:root.dark .editor-box      { background: var(--bg); }
:root.dark .editor-toolbar  { background: var(--bg); }
:root.dark .editor-textarea { background: var(--bg); color: var(--text); }
:root.dark .editor-preview-wrap { background: rgba(91,175,214,.03); }
:root.dark .artigo-h2, :root.dark .artigo-h3 { color: var(--text); }

/* ── EDITOR SPLIT ────────────────────────────────── */
.editor-split {
    display: grid;
    grid-template-columns: 1fr 1fr;
    flex: 1;
    min-height: 400px;
    border-top: 1px solid var(--border);
}
.editor-split .editor-textarea {
    border-right: 1px solid var(--border);
    min-height: 400px;
}
.editor-split-preview {
    padding: 1.5rem 2rem;
    overflow-y: auto;
    background: rgba(28,68,86,.02);
}
@media (max-width: 768px) {
    .editor-split { grid-template-columns: 1fr; }
    .editor-split .editor-textarea { border-right: none; border-bottom: 1px solid var(--border); }
}
:root.dark .editor-split-preview { background: rgba(91,175,214,.02); }

/* ── ARTIGO EDIT FAB ─────────────────────────────── */
.artigo-edit-fab {
    position: fixed; bottom: 2rem; right: 2rem; z-index: 50;
    display: flex; align-items: center; gap: .5rem;
    padding: .65rem 1.25rem; border-radius: 99px;
    border: none; background: var(--primary); color: white;
    font-family: var(--font-aux); font-size: .68rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    cursor: pointer; transition: all .2s;
    box-shadow: 0 4px 20px rgba(28,68,86,.3);
}
.artigo-edit-fab:hover { background: var(--blue); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(28,68,86,.35); }

/* Trocar imagem artigo */
.artigo-img-wrap { position: relative; }
.artigo-img-trocar {
    position: absolute; bottom: .75rem; right: .75rem;
    display: inline-flex; align-items: center; gap: .4rem;
    padding: .4rem .85rem; border-radius: 6px;
    background: rgba(0,0,0,.55); color: white;
    font-family: var(--font-aux); font-size: .62rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    cursor: pointer; transition: background .2s;
    backdrop-filter: blur(4px);
}
.artigo-img-trocar:hover { background: rgba(0,0,0,.75); }
.artigo-img-add {
    margin: 1.5rem 0;
    display: flex; justify-content: center;
}
.artigo-img-add .artigo-img-trocar {
    position: static;
    background: rgba(28,68,86,.08); color: var(--primary);
    border: 1px dashed rgba(28,68,86,.2); padding: .75rem 1.5rem;
    border-radius: 8px;
}
.artigo-img-add .artigo-img-trocar:hover { background: rgba(28,68,86,.12); }

/* Upload button in editor */
.editor-btn-upload {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 6px;
    border: 1px solid var(--border); background: var(--bg);
    color: var(--text-muted); cursor: pointer; transition: all .18s;
    flex-shrink: 0;
}
.editor-btn-upload:hover { border-color: var(--primary); color: var(--primary); background: rgba(28,68,86,.05); }



/* ── DARK HERO IGUAL AO CLARO ───────────────────── */
:root.dark .hero-grid {
    background-image:
        linear-gradient(rgba(28,68,86,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(28,68,86,.04) 1px, transparent 1px);
}
:root.dark .hero-eyebrow-line { background: var(--primary) !important; opacity:.5; }
:root.dark .hero-eyebrow-text { color: var(--primary) !important; opacity:.7; }
:root.dark .hero-title        { color: var(--primary) !important; }
:root.dark .hero-title em     { color: var(--blue) !important; -webkit-text-stroke:0; opacity:.7; }
:root.dark .hero-title strong { color: var(--primary) !important; }
:root.dark .hero-desc, :root.dark .hero-desc *  { color: var(--text-muted) !important; }
:root.dark .hero-scroll-text  { color: rgba(28,68,86,.35) !important; }
:root.dark .hero-scroll-line  { background: linear-gradient(to bottom, rgba(28,68,86,.4), transparent) !important; }
:root.dark .hero-stat-num   { color: var(--primary) !important; }
:root.dark .hero-stat-label { color: rgba(28,68,86,.5) !important; }
:root.dark .hero-divider    { background: rgba(28,68,86,.1) !important; }
:root.dark .hero-tag { border-color: rgba(46,132,175,.3) !important; color: var(--blue) !important; background: rgba(46,132,175,.06) !important; }
:root.dark .btn-primary { background: var(--primary) !important; color: white !important; border-color: var(--primary) !important; }
:root.dark .btn-primary:hover { background: var(--blue) !important; }
:root.dark .btn-outline { border-color: rgba(28,68,86,.3) !important; color: var(--primary) !important; }
:root.dark .hero-badge { border-color: rgba(28,68,86,.15) !important; color: var(--text-muted) !important; }
:root.dark .hero-badge svg { color: var(--primary) !important; }



/* ── DARK MODE HERO = MODO CLARO ─────────────────── */


:root.dark .hero-grid {
    background-image:
        linear-gradient(rgba(28,68,86,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(28,68,86,.04) 1px, transparent 1px);
}
:root.dark .hero-eyebrow-line { background: var(--primary) !important; opacity:.5; }
:root.dark .hero-eyebrow-text { color: var(--primary) !important; opacity:.7; }
:root.dark .hero-title        { color: var(--primary) !important; }
:root.dark .hero-title em     { color: var(--blue) !important; opacity:.7; -webkit-text-stroke:0; }
:root.dark .hero-title strong { color: var(--primary) !important; }
:root.dark .hero-desc         { color: var(--text-muted) !important; }
:root.dark .hero-badge        { border-color: rgba(28,68,86,.15) !important; color: var(--text-muted) !important; }
:root.dark .hero-scroll-text  { color: rgba(28,68,86,.35) !important; }
:root.dark .hero-scroll-line  { background: linear-gradient(to bottom, rgba(28,68,86,.4), transparent) !important; }
:root.dark .hero-stat-num   { color: var(--primary) !important; }
:root.dark .hero-stat-label { color: rgba(28,68,86,.5) !important; }
:root.dark .hero-divider    { background: rgba(28,68,86,.1) !important; }
:root.dark .hero-tag { border-color: rgba(46,132,175,.3) !important; color: var(--blue) !important; background: rgba(46,132,175,.06) !important; }
:root.dark .btn-primary { background: var(--primary) !important; color: white !important; border-color: var(--primary) !important; }
:root.dark .btn-primary:hover { background: var(--blue) !important; }
:root.dark .btn-outline { border-color: rgba(28,68,86,.3) !important; color: var(--primary) !important; }
:root.dark .btn-outline:hover { border-color: var(--primary) !important; background: rgba(28,68,86,.05) !important; }

/* ── DARK MODE HERO = LIGHT MODE ─────────────────── */
:root.dark .hero { background: var(--dark); }
:root.dark .hero-bg {
    background:
        radial-gradient(ellipse 80% 60% at 70% 50%, rgba(91,175,214,.18) 0%, transparent 60%),
        radial-gradient(ellipse 50% 70% at 20% 80%, rgba(91,175,214,.06) 0%, transparent 50%),
        linear-gradient(155deg, #060e11 0%, #0f1e24 45%, #0d1a22 100%);
}
:root.dark .hero-grid {
    background-image:
        linear-gradient(rgba(28,68,86,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(28,68,86,.04) 1px, transparent 1px);
}
:root.dark .hero-eyebrow-line { background: var(--yellow); opacity:.6; }
:root.dark .hero-eyebrow-text { color: var(--yellow); opacity:.85; }
:root.dark .hero-title        { color: white; }
:root.dark .hero-title em     { color: rgba(255,255,255,.4); -webkit-text-stroke: 0; }
:root.dark .hero-title strong { color: white; }
:root.dark .hero-desc         { color: rgba(255,255,255,.55); }
:root.dark .hero-badge        { border-color: rgba(28,68,86,.15); color: var(--text-muted); }
:root.dark .hero-scroll-text  { color: rgba(28,68,86,.35); }
:root.dark .hero-scroll-line  { background: linear-gradient(to bottom, rgba(28,68,86,.4), transparent); }
:root.dark .hero-stat-num   { color: var(--blue); }
:root.dark .hero-stat-label { color: rgba(226,238,244,.5); }
:root.dark .hero-divider    { background: rgba(91,175,214,.12); }
:root.dark .hero-tag { border-color: rgba(255,200,91,.28); color: var(--yellow); background: transparent; }
:root.dark .btn-primary { background: var(--primary); color: white; border-color: var(--primary); box-shadow: 0 4px 16px rgba(28,68,86,.2); filter: none; }
:root.dark .btn-primary:hover { background: var(--blue); border-color: var(--blue); }
:root.dark .btn-outline { border-color: rgba(28,68,86,.3); color: var(--primary); }
:root.dark .btn-outline:hover { border-color: var(--primary); background: rgba(28,68,86,.05); color: var(--primary); }

/* Remove card-2 completely in dark mode */

/* ── TEXTO JUSTIFICADO ───────────────────────────── */
.sobre-text-big, .sobre-text-body, .artigo-paragrafo,
.noticia-summary, .area-desc, .hero-desc,
.equipe-bio, .curriculo-bio, .artigo-resumo,
.timeline-desc { text-align: justify; }

/* ── FOOTER LEGAL ────────────────────────────────── */
.footer-legal {
    max-width: 1400px; margin: 0 auto;
    padding: 1.5rem 2.5rem 0;
    border-top: 1px solid rgba(255,255,255,.08);
    margin-top: 2rem;
}
.footer-legal-text {
    font-family: var(--font-aux); font-size: .6rem;
    color: rgba(255,255,255,.45); letter-spacing: .08em;
    line-height: 1.8; margin: 0;
}

/* ── HERO CARD DARK MODE (glass) ─────────────────── */
:root.dark .hero-card-1 {
    background: rgba(255,255,255,.06) !important;
    border-color: rgba(91,175,214,.25) !important;
    backdrop-filter: blur(16px) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,.3), inset 0 1px 0 rgba(255,255,255,.08) !important;
}
:root.dark .hero-card-2 { display: none !important; }
:root.dark .hero-stat-num   { color: var(--blue) !important; }
:root.dark .hero-stat-label { color: rgba(226,238,244,.55) !important; }
:root.dark .hero-divider    { background: rgba(91,175,214,.15) !important; }

/* ── NOVO EDITOR DE NOTÍCIAS (NED) ───────────────── */
.ned-wrap {
    display: flex; min-height: 100vh; width: 100%;
    background: var(--bg);
}

/* Sidebar */
.ned-sidebar {
    width: 280px; flex-shrink: 0;
    border-right: 1px solid var(--border);
    background: var(--bg);
    display: flex; flex-direction: column; gap: 0;
    padding: 1.5rem 1.25rem;
    overflow-y: auto;
    position: sticky; top: 0; max-height: 100vh;
}
.ned-logo {
    display: flex; align-items: center; gap: .5rem;
    font-family: var(--font-aux); font-size: .72rem; font-weight: 700;
    letter-spacing: .1em; text-transform: uppercase;
    color: var(--primary); margin-bottom: 1.75rem;
}
.ned-field { margin-bottom: 1.4rem; }
.ned-label {
    display: block; font-family: var(--font-aux); font-size: .6rem;
    font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
    color: var(--text-muted); margin-bottom: .5rem;
}
.ned-tags-grid {
    display: flex; flex-wrap: wrap; gap: .35rem;
}
.ned-tag-btn {
    padding: .28rem .65rem; border-radius: 99px;
    border: 1px solid var(--border); background: none;
    font-family: var(--font-aux); font-size: .62rem; font-weight: 600;
    letter-spacing: .06em; color: var(--text-muted);
    cursor: pointer; transition: all .15s;
}
.ned-tag-btn:hover  { border-color: var(--blue); color: var(--blue); }
.ned-tag-btn.active { border-color: var(--primary); background: var(--primary); color: white; }
.ned-img-area {
    border-radius: 8px; overflow: hidden;
    border: 1px solid var(--border); background: var(--card-bg);
    min-height: 100px;
}
.ned-img-preview { width: 100%; height: 130px; object-fit: cover; display: block; }
.ned-img-placeholder {
    height: 100px; display: flex; flex-direction: column;
    align-items: center; justify-content: center; gap: .4rem;
    color: var(--text-muted); font-family: var(--font-aux);
    font-size: .65rem;
}
.ned-input {
    width: 100%; padding: .5rem .7rem; border-radius: 6px;
    border: 1px solid var(--border); background: var(--card-bg);
    font-family: var(--font-body); font-size: .8rem; color: var(--text);
    box-sizing: border-box; outline: none; transition: border .15s;
}
.ned-input:focus { border-color: var(--blue); }
.ned-textarea {
    width: 100%; padding: .6rem .7rem; border-radius: 6px;
    border: 1px solid var(--border); background: var(--card-bg);
    font-family: var(--font-body); font-size: .8rem; color: var(--text);
    box-sizing: border-box; outline: none; resize: none; min-height: 80px;
    line-height: 1.6; transition: border .15s;
}
.ned-textarea:focus { border-color: var(--blue); }
.ned-upload-btn {
    display: inline-flex; align-items: center; gap: .35rem;
    padding: .3rem .7rem; border-radius: 6px;
    border: 1px solid var(--border); background: none;
    font-family: var(--font-aux); font-size: .62rem; font-weight: 600;
    letter-spacing: .06em; color: var(--text-muted); cursor: pointer;
    transition: all .15s;
}
.ned-upload-btn:hover { border-color: var(--primary); color: var(--primary); }
.ned-sidebar-actions {
    margin-top: auto; padding-top: 1.25rem;
    border-top: 1px solid var(--border);
    display: flex; gap: .6rem;
}
.ned-btn-cancel {
    flex: 1; padding: .55rem; border-radius: 7px;
    border: 1px solid var(--border); background: none;
    font-family: var(--font-aux); font-size: .68rem; font-weight: 600;
    letter-spacing: .06em; color: var(--text-muted); cursor: pointer;
    transition: all .15s;
}
.ned-btn-cancel:hover { background: var(--card-bg); }
.ned-btn-publish {
    flex: 2; padding: .55rem; border-radius: 7px;
    border: none; background: var(--primary);
    font-family: var(--font-aux); font-size: .68rem; font-weight: 700;
    letter-spacing: .06em; color: white; cursor: pointer;
    display: flex; align-items: center; justify-content: center; gap: .4rem;
    transition: all .2s;
}
.ned-btn-publish:hover { background: var(--blue); transform: translateY(-1px); }

/* Editor area */
.ned-editor-area {
    flex: 1; display: flex; flex-direction: column;
    min-height: 100vh; overflow: hidden;
}
.ned-title-input {
    width: 100%; padding: 2rem 2.5rem 0;
    border: none; outline: none; background: transparent;
    font-family: var(--font-title); font-size: 2rem; font-weight: 800;
    color: var(--primary); text-transform: uppercase;
    box-sizing: border-box; letter-spacing: .02em;
}
.ned-title-input::placeholder { color: rgba(28,68,86,.2); }

/* Toolbar */
.ned-toolbar {
    display: flex; align-items: center; gap: .25rem;
    padding: 1rem 2.5rem;
    border-bottom: 1px solid var(--border);
    flex-wrap: wrap;
}
.ned-tb-btn {
    padding: .28rem .55rem; border-radius: 5px;
    border: 1px solid transparent; background: none;
    font-family: var(--font-aux); font-size: .72rem; font-weight: 700;
    color: var(--text-muted); cursor: pointer; transition: all .12s;
    display: flex; align-items: center; justify-content: center;
}
.ned-tb-btn:hover { border-color: var(--border); background: var(--card-bg); color: var(--primary); }
.ned-tb-bold em, .ned-tb-italic strong { pointer-events: none; }
.ned-tb-sep { width: 1px; height: 16px; background: var(--border); margin: 0 .2rem; flex-shrink: 0; }
.ned-tb-hint {
    font-family: var(--font-aux); font-size: .6rem; color: var(--text-muted);
    margin-left: auto; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ned-preview-toggle {
    display: flex; align-items: center; gap: .35rem;
    padding: .28rem .7rem; border-radius: 5px;
    border: 1px solid var(--border); background: none;
    font-family: var(--font-aux); font-size: .62rem; font-weight: 600;
    color: var(--text-muted); cursor: pointer; transition: all .15s;
    margin-left: .5rem; white-space: nowrap;
}
.ned-preview-toggle:hover, .ned-preview-toggle.active {
    border-color: var(--primary); color: var(--primary); background: rgba(28,68,86,.04);
}
.ned-content-area { flex: 1; display: flex; min-height: 0; }
.ned-content {
    flex: 1; padding: 1.75rem 2.5rem;
    border: none; outline: none; resize: none; background: transparent;
    font-family: var(--font-body); font-size: .95rem; color: var(--text);
    line-height: 1.9; box-sizing: border-box;
}
.ned-preview {
    flex: 1; padding: 1.75rem 2.5rem;
    overflow-y: auto; box-sizing: border-box;
}

@media (max-width: 768px) {
    .ned-wrap { flex-direction: column; }
    .ned-sidebar { width: 100%; max-height: none; position: static; border-right: none; border-bottom: 1px solid var(--border); }
    .ned-title-input { padding: 1.25rem 1.25rem 0; font-size: 1.4rem; }
    .ned-toolbar { padding: .75rem 1.25rem; }
    .ned-content { padding: 1.25rem; }
    .ned-tb-hint { display: none; }
}

/* Dark ned */
:root.dark .ned-sidebar { background: var(--bg); }
:root.dark .ned-editor-area { background: var(--bg); }
:root.dark .ned-input, :root.dark .ned-textarea { background: var(--card-bg); color: var(--text); }
