/* Portal Grupo PluralMed — design system (identidade oficial + motion)
   Paleta: teal #5BB8C8 · petróleo #2F7185 · azul #006B8F · verde-limão #A4D65E */
:root{
  --teal:#5BB8C8; --teal-l:#7CCAD7; --petrol:#2F7185; --petrol-d:#1d4a56; --blue:#006B8F; --blue-d:#00536f;
  --lime:#A4D65E; --lime-d:#7Cae34; --navy:#10384a;
  --ink:#13323e; --muted:#5f7884; --faint:#8aa0a8; --line:#e4ecee; --bg:#eef3f4; --card:#ffffff;
  --danger:#c0392b; --ok:#1f9d6b; --gold:#C9A24B;
  --grad:linear-gradient(135deg,#5BB8C8 0%,#2F7185 52%,#006B8F 120%);
  --grad-soft:linear-gradient(135deg,#5BB8C8,#2F7185);
  --grad-blue:linear-gradient(135deg,#2F7185,#006B8F);
  --shadow:0 2px 14px rgba(16,56,74,.07); --shadow-md:0 8px 26px rgba(16,56,74,.12); --shadow-lg:0 20px 50px rgba(16,56,74,.22);
  --radius:18px; --radius-sm:12px;
  --ease:cubic-bezier(.22,.7,.2,1);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);background:var(--bg);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:none}
button{font-family:inherit;cursor:pointer}
img{max-width:100%;display:block}
.hidden{display:none!important}
::selection{background:var(--teal);color:#fff}

/* motion utilities */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.06s}.reveal.d2{transition-delay:.12s}.reveal.d3{transition-delay:.18s}.reveal.d4{transition-delay:.24s}.reveal.d5{transition-delay:.3s}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}

/* buttons */
.btn{background:var(--blue);color:#fff;border:none;padding:11px 20px;border-radius:11px;font-weight:700;font-size:14px;transition:.18s var(--ease);box-shadow:0 4px 14px rgba(0,107,143,.25)}
.btn:hover{background:var(--blue-d);transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,107,143,.32)}
.btn:active{transform:translateY(0)}
.btn.block{width:100%}
.btn.ghost{background:#fff;color:var(--petrol);border:1px solid var(--line);box-shadow:none}
.btn.ghost:hover{background:#f0f6f6;border-color:var(--teal)}
.btn.lime{background:var(--lime-d);box-shadow:0 4px 14px rgba(124,174,52,.3)}
.btn.lime:hover{background:var(--lime)}
.btn.gold{background:var(--gold);box-shadow:none}
.btn.sm{padding:8px 14px;font-size:13px;border-radius:9px;box-shadow:none}
.btn.lg{padding:14px 26px;font-size:15px}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* ---------- LOGIN ---------- */
#login{position:fixed;inset:0;display:flex;align-items:stretch}
.login-hero{flex:1;position:relative;display:none;overflow:hidden}
.login-hero .bg{position:absolute;inset:0;background:linear-gradient(135deg,rgba(29,74,86,.82),rgba(0,107,143,.66)),url('/static/assets/img/hero.jpg') center/cover;animation:slowzoom 18s ease-in-out infinite alternate}
@keyframes slowzoom{to{transform:scale(1.08)}}
.login-hero .ring{position:absolute;border:2px solid rgba(255,255,255,.18);border-radius:50%}
.login-hero .ring.r1{width:340px;height:340px;right:-90px;top:60px}
.login-hero .ring.r2{width:220px;height:220px;right:120px;bottom:-60px;border-color:rgba(164,214,94,.4)}
.login-hero .hero-txt{position:absolute;bottom:60px;left:56px;right:56px;color:#fff;z-index:2}
.login-hero .hero-txt h2{font-size:38px;line-height:1.1;margin:0 0 12px;font-weight:800;letter-spacing:-.5px}
.login-hero .hero-txt h2 b{color:var(--lime)}
.login-hero .hero-txt p{font-size:15.5px;color:#e7f5f4;max-width:520px}
.login-right{width:470px;max-width:100vw;display:flex;align-items:center;justify-content:center;background:#fff}
.login-card{padding:42px 46px;width:100%;max-width:400px}
.login-card img.logo{height:48px;margin-bottom:26px}
.login-card h1{font-size:22px;margin:0 0 2px;color:var(--navy)}
.login-card p.sub{color:var(--muted);margin:0 0 26px;font-size:13.5px}
.field{margin-bottom:15px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--petrol);margin-bottom:6px}
.field input{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:11px;font-size:14px;background:#f7fafa;transition:.15s}
.field input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(91,184,200,.22);background:#fff}
.err{color:var(--danger);font-size:13px;margin-top:8px;min-height:18px}
.hint{background:#eef5f5;border-radius:11px;padding:11px 13px;font-size:12px;color:var(--muted);margin-top:20px;line-height:1.7}

/* ---------- APP SHELL ---------- */
#app{display:grid;grid-template-columns:262px 1fr;grid-template-rows:64px 1fr;height:100vh}
header.topbar{grid-column:1/3;display:flex;align-items:center;gap:18px;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);padding:0 22px;z-index:30;position:sticky;top:0}
.topbar img.logo{height:34px}
.searchbar{flex:1;max-width:560px;position:relative}
.searchbar input{width:100%;padding:10px 14px 10px 40px;border:1px solid var(--line);border-radius:999px;font-size:14px;background:#f3f8f8;transition:.15s}
.searchbar input:focus{outline:none;border-color:var(--teal);background:#fff;box-shadow:0 0 0 3px rgba(91,184,200,.18)}
.searchbar svg{position:absolute;left:14px;top:10px;color:var(--faint)}
.usermenu{display:flex;align-items:center;gap:11px;margin-left:auto}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--grad-soft);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.usermenu .uinfo{text-align:right;line-height:1.2}
.usermenu .uinfo b{font-size:13px;color:var(--navy)}
.usermenu .uinfo small{color:var(--blue);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}

aside.nav{background:#fff;border-right:1px solid var(--line);padding:14px 12px;overflow-y:auto}
.nav .group{font-size:10.5px;text-transform:uppercase;letter-spacing:1.2px;color:var(--faint);margin:18px 12px 6px;font-weight:800}
.nav a.item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;color:var(--ink);font-size:14px;font-weight:500;margin-bottom:2px;transition:.15s var(--ease);position:relative}
.nav a.item:hover{background:#eef5f5}
.nav a.item.active{background:var(--grad-soft);color:#fff;box-shadow:var(--shadow)}
.nav a.item .ic{width:20px;text-align:center;font-size:15px}
.nav .badge{margin-left:auto;background:#eef2f3;color:var(--muted);border-radius:999px;font-size:11px;padding:1px 8px;font-weight:700}
.nav a.item.active .badge{background:rgba(255,255,255,.22);color:#fff}

main.content{overflow-y:auto;scroll-behavior:smooth}
#view{padding:30px 40px 80px;max-width:1240px;margin:0 auto;transition:opacity .25s var(--ease)}
#view.fading{opacity:0}
.page-head{margin-bottom:22px}
.page-head .eyebrow{font-size:11.5px;font-weight:800;text-transform:uppercase;letter-spacing:1.4px;color:var(--blue)}
.page-head h1{margin:4px 0 6px;font-size:30px;color:var(--navy);letter-spacing:-.4px;line-height:1.1}
.page-head .desc{color:var(--muted);max-width:760px;font-size:15px}
.crumb{font-size:13px;color:var(--muted);margin-bottom:14px;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.crumb a{color:var(--blue)}.crumb span.sep{color:#bcc8cb}
.section-title{font-size:12px;text-transform:uppercase;letter-spacing:1.4px;color:var(--faint);font-weight:800;margin:34px 0 14px;display:flex;align-items:center;gap:12px}
.section-title::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---------- HERO ---------- */
.hero{position:relative;border-radius:24px;overflow:hidden;margin-bottom:8px;min-height:340px;display:flex;align-items:center;box-shadow:var(--shadow-lg)}
.hero .bg{position:absolute;inset:0;background:linear-gradient(105deg,rgba(16,56,74,.92) 0%,rgba(0,107,143,.6) 48%,rgba(91,184,200,.15) 100%),url('/static/assets/img/hero.jpg') center 28%/cover}
.hero .ring{position:absolute;border:2px solid rgba(255,255,255,.13);border-radius:50%;pointer-events:none}
.hero .ring.r1{width:380px;height:380px;right:-80px;top:-90px}
.hero .ring.r2{width:260px;height:260px;right:140px;bottom:-120px;border-color:rgba(164,214,94,.35)}
.hero .inner{position:relative;padding:44px 48px;color:#fff;max-width:760px}
.hero .eyebrow{color:var(--lime);font-weight:800;letter-spacing:1.6px;text-transform:uppercase;font-size:12px}
.hero h1{margin:10px 0 14px;font-size:42px;font-weight:800;line-height:1.08;letter-spacing:-1px}
.hero h1 b{color:var(--lime)}
.hero p{margin:0 0 20px;color:#e7f5f4;max-width:600px;font-size:16px}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}
.hero .slogan{display:inline-block;margin-top:16px;background:rgba(255,255,255,.14);border-radius:999px;padding:6px 18px;font-size:13px;backdrop-filter:blur(6px)}

/* page hero (business) */
.phero{position:relative;border-radius:22px;overflow:hidden;min-height:280px;display:flex;align-items:flex-end;box-shadow:var(--shadow-lg);margin-bottom:8px}
.phero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.phero .ov{position:absolute;inset:0}
.phero .inner{position:relative;padding:30px 36px;color:#fff}
.phero .num{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:13px;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);font-weight:800;font-size:20px;margin-bottom:12px}
.phero h1{margin:0 0 8px;font-size:30px;font-weight:800;letter-spacing:-.4px;max-width:760px;line-height:1.1}
.phero .tagline{font-size:16px;color:#eafffb;max-width:620px}

/* ---------- GRIDS / CARDS ---------- */
.grid{display:grid;gap:20px}
.cols-2{grid-template-columns:repeat(auto-fill,minmax(360px,1fr))}
.cols-3{grid-template-columns:repeat(auto-fill,minmax(290px,1fr))}
.cols-4{grid-template-columns:repeat(auto-fill,minmax(215px,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);transition:.22s var(--ease);color:inherit}
a.card,.card.link{cursor:pointer;text-decoration:none}
a.card:hover,.card.link:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#d2e2e5}
.card .tag{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.7px;color:var(--blue)}
.card h3{margin:7px 0;font-size:17px;color:var(--navy)}
.card p{margin:0;color:var(--muted);font-size:13.5px}
.pill{display:inline-block;background:#eef5f5;color:var(--petrol);border-radius:999px;padding:3px 11px;font-size:11.5px;font-weight:600}
.pill.lime{background:#f0f8e4;color:var(--lime-d)}

/* business card (image) */
.bizcard{padding:0;overflow:hidden;cursor:pointer;display:flex;flex-direction:column}
.bizcard .img{height:168px;background-size:cover;background-position:center;position:relative;transition:.4s var(--ease)}
.bizcard:hover .img{transform:scale(1.05)}
.bizcard .imgwrap{overflow:hidden;position:relative}
.bizcard .imgwrap::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(16,56,74,0) 45%,rgba(16,56,74,.62))}
.bizcard .num{position:absolute;top:12px;left:14px;width:32px;height:32px;border-radius:10px;background:rgba(255,255,255,.92);color:var(--blue);font-weight:800;display:flex;align-items:center;justify-content:center;font-size:14px;z-index:3}
.bizcard .ic{position:absolute;bottom:12px;right:14px;font-size:26px;z-index:3}
.bizcard .body{padding:16px 18px;flex:1;display:flex;flex-direction:column}
.bizcard .body h3{margin:5px 0 6px;font-size:16px}
.bizcard .body .tline{font-size:13px;color:var(--muted);flex:1}
.bizcard .body .more{margin-top:12px;font-size:12.5px;font-weight:700;color:var(--blue);display:flex;align-items:center;gap:5px}
.bizcard:hover .body .more{gap:9px}

/* KPI / stat */
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi .num{font-size:38px;font-weight:800;color:var(--navy);line-height:1;letter-spacing:-1px}
.kpi .lbl{color:var(--muted);font-size:13px;margin-top:8px}
.kpi.accent{background:var(--grad);color:#fff;border:none}
.kpi.accent .num,.kpi.accent .lbl{color:#fff}
.kpi.accent .lbl{color:#dff4f0}
.statcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow)}
.statcard .big{font-size:26px;font-weight:800;margin:4px 0;color:var(--navy)}
.statcard .tag{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:var(--blue)}
.statcard.accent{background:var(--grad-soft);color:#fff;border:none}
.statcard.accent .big,.statcard.accent .tag{color:#fff}

/* pilares / feature */
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:.2s var(--ease)}
.feat:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.feat .fic{font-size:28px}
.feat h3{margin:12px 0 6px;font-size:16px;color:var(--navy)}
.feat p{margin:0;color:var(--muted);font-size:13.5px}

/* manifesto band */
.band{background:var(--grad);border-radius:22px;padding:40px 44px;color:#fff;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}
.band::after{content:"";position:absolute;right:-90px;top:-90px;width:300px;height:300px;border:2px solid rgba(255,255,255,.13);border-radius:50%}
.band .eyebrow{color:var(--lime);font-weight:800;letter-spacing:1.4px;text-transform:uppercase;font-size:12px}
.band p{font-size:19px;line-height:1.55;max-width:820px;margin:12px 0 0;font-weight:500}

/* tabs */
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin:24px 0 20px;overflow-x:auto}
.tabs button{background:none;border:none;padding:11px 16px;font-size:14px;font-weight:600;color:var(--muted);border-bottom:2.5px solid transparent;white-space:nowrap;transition:.15s}
.tabs button:hover{color:var(--petrol)}
.tabs button.active{color:var(--blue);border-bottom-color:var(--blue)}
.tabpane{animation:fadein .35s var(--ease)}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* checklist / value props */
.vlist{list-style:none;padding:0;margin:0}
.vlist li{display:flex;gap:11px;padding:9px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
.vlist li:last-child{border-bottom:none}
.vlist li::before{content:"✓";color:var(--lime-d);font-weight:800;flex-shrink:0;width:20px;height:20px;background:#f0f8e4;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}

/* gallery (thumbs) */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.gallery .gthumb{position:relative;border-radius:14px;overflow:hidden;cursor:pointer;aspect-ratio:16/10;box-shadow:var(--shadow)}
.gallery .gthumb img{width:100%;height:100%;object-fit:cover;transition:.45s var(--ease)}
.gallery .gthumb:hover img{transform:scale(1.08)}
.gallery .gthumb::after{content:"⤢";position:absolute;right:10px;bottom:8px;color:#fff;font-size:16px;opacity:0;transition:.2s;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.gallery .gthumb:hover::after{opacity:1}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;background:rgba(8,30,38,.92);z-index:120;display:flex;align-items:center;justify-content:center;flex-direction:column;animation:fadein .25s}
.lightbox .stage{position:relative;max-width:88vw;max-height:78vh;display:flex;align-items:center;justify-content:center}
.lightbox img{max-width:88vw;max-height:78vh;border-radius:14px;box-shadow:0 30px 80px rgba(0,0,0,.5);animation:lbin .45s var(--ease)}
@keyframes lbin{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
.lightbox .nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;border:none;font-size:24px;display:flex;align-items:center;justify-content:center;transition:.15s;backdrop-filter:blur(6px)}
.lightbox .nav:hover{background:rgba(255,255,255,.28)}
.lightbox>.nav{position:fixed}
.lightbox .nav.prev{left:20px}.lightbox .nav.next{right:20px}
@media(min-width:1100px){.lightbox .nav.prev{left:40px}.lightbox .nav.next{right:40px}}
.lightbox .close{position:absolute;top:22px;right:26px;background:rgba(255,255,255,.14);color:#fff;border:none;width:44px;height:44px;border-radius:50%;font-size:20px;backdrop-filter:blur(6px)}
.lightbox .close:hover{background:rgba(255,255,255,.28)}
.lightbox .caption{color:#fff;margin-top:16px;font-size:14px;opacity:.9}
.lightbox .dots{display:flex;gap:8px;margin-top:14px}
.lightbox .dots i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.35);cursor:pointer;transition:.2s}
.lightbox .dots i.on{background:var(--lime);width:24px;border-radius:5px}

/* timeline (journey) */
.timeline{position:relative}
.tstep{display:grid;grid-template-columns:64px 1fr;gap:18px;padding-bottom:6px;position:relative}
.tstep-line{position:absolute;left:31px;top:8px;bottom:-18px;width:2px;background:linear-gradient(var(--teal),var(--line))}
.tstep:last-child .tstep-line{display:none}
.tnode{width:64px;height:64px;border-radius:18px;background:var(--grad-soft);color:#fff;display:flex;align-items:center;justify-content:center;font-size:26px;box-shadow:var(--shadow-md);z-index:2;position:relative}
.tbody{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px 20px;box-shadow:var(--shadow);margin-bottom:18px;flex:1;transition:.2s var(--ease)}
.tbody:hover{transform:translateX(4px);box-shadow:var(--shadow-md)}
.tbody .tnum{font-size:11px;font-weight:800;color:var(--blue);letter-spacing:1px;text-transform:uppercase}
.tbody h3{margin:4px 0 6px;font-size:17px;color:var(--navy)}
.tbody .obj{color:var(--petrol);font-weight:600;font-size:13.5px;margin-bottom:6px}
.tbody p{margin:0;color:var(--muted);font-size:13.5px}
.tbody .who{margin-top:10px;font-size:12px;color:var(--lime-d);font-weight:700}

/* carrossel (acervo) */
.carousel{position:relative;border-radius:20px;overflow:hidden;margin:18px 0 4px;box-shadow:var(--shadow-lg);aspect-ratio:21/8;background:#10384a}
.car-track{position:absolute;inset:0}
.car-slide{position:absolute;inset:0;background-size:cover;background-position:center 28%;opacity:0;transition:opacity 1s var(--ease);transform:scale(1.03)}
.car-slide.on{opacity:1;transform:scale(1);transition:opacity 1s var(--ease),transform 6s linear}
.carousel::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,56,74,.55),rgba(16,56,74,0) 55%)}
.car-cap{position:absolute;left:30px;bottom:26px;color:#fff;z-index:3;max-width:60%}
.car-cap b{display:block;font-size:24px;font-weight:800;letter-spacing:-.3px;text-shadow:0 2px 12px rgba(0,0,0,.4)}
.car-cap span{font-size:14px;color:#eafffb;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.car-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;border:none;font-size:22px;z-index:4;backdrop-filter:blur(6px);transition:.15s}
.car-nav:hover{background:rgba(255,255,255,.34)}
.car-nav.prev{left:16px}.car-nav.next{right:16px}
.car-dots{position:absolute;bottom:20px;right:26px;display:flex;gap:7px;z-index:4}
.car-dots i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.4);cursor:pointer;transition:.2s}
.car-dots i.on{background:var(--lime);width:26px;border-radius:5px}

.car-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;background:rgba(255,255,255,.92);color:var(--blue);border:none;border-radius:999px;padding:12px 22px;font-size:15px;font-weight:800;box-shadow:var(--shadow-lg);transition:.18s var(--ease)}
.car-play:hover{transform:translate(-50%,-50%) scale(1.06);background:#fff}
.car-play.hidden{display:none}

/* video card (acervo) */
.videocard{display:grid;grid-template-columns:300px 1fr;gap:0;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:22px}
.vc-poster{position:relative;background-size:cover;background-position:center;min-height:170px;cursor:pointer}
.vc-poster::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,107,143,.5),rgba(16,56,74,.5))}
.vc-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:62px;height:62px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:24px;padding-left:4px;transition:.18s var(--ease);box-shadow:var(--shadow-lg)}
.vc-poster:hover .vc-play{transform:translate(-50%,-50%) scale(1.1)}
.vc-body{padding:20px 24px;align-self:center}
.vc-body h3{margin:6px 0;color:var(--navy);font-size:18px}
.vc-body p{margin:0;color:var(--muted);font-size:14px}

/* founder block */
.founder{display:grid;grid-template-columns:340px 1fr;gap:24px;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);margin-bottom:20px}
.founder-img{background-size:cover;background-position:center;min-height:280px}
.founder-body{padding:26px 30px 26px 4px}
.founder-body .eyebrow{color:var(--blue);font-weight:800;letter-spacing:1.2px;text-transform:uppercase;font-size:11.5px}
.founder-body h2{font-size:26px;color:var(--navy);margin:8px 0 14px;letter-spacing:-.4px}
.founder-body p{color:var(--muted);font-size:14.5px;margin:0 0 10px}
.founder-body .tese{color:var(--petrol);font-weight:600;border-left:3px solid var(--teal);padding-left:12px}
.chap .chap-n{display:flex;align-items:center;justify-content:space-between;font-size:26px}
.chap .chap-n span{font-size:13px;font-weight:800;color:#cdd9dc;background:#eef5f5;width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.chap h3{font-size:15px}

/* sequência lógica */
.seqline{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 20px;box-shadow:var(--shadow);margin-bottom:18px}
.seqstep{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--navy);font-size:14px}
.seqdot{width:26px;height:26px;border-radius:50%;background:var(--grad-soft);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.seqarrow{color:var(--teal);font-weight:800}

/* sub-abas dos negócios */
.subtabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.subtab{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 16px 8px 8px;font-size:13.5px;font-weight:600;color:var(--navy);box-shadow:var(--shadow);transition:.16s var(--ease)}
.subtab:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--teal);text-decoration:none}
.subtab .st-n{width:26px;height:26px;border-radius:50%;background:var(--grad-soft);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.subtab .st-ic{font-size:16px}
.cols-5{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}

/* journey drill-down */
.jbar{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.depthdots{display:inline-flex;gap:6px;margin-left:auto;align-items:center}
.depthdots i{width:9px;height:9px;border-radius:50%;background:#d3e0e3;transition:.2s}
.depthdots i.on{background:var(--blue);box-shadow:0 0 0 3px rgba(0,107,143,.12)}
.jlink{cursor:pointer;text-decoration:none}
.more{margin-top:12px;font-size:12.5px;font-weight:800;color:var(--blue);display:flex;align-items:center;gap:5px}
.jlink:hover .more,.drill:hover .more{gap:10px}
.stage-hero{display:flex;gap:22px;align-items:center;border-radius:22px;padding:30px 34px;color:#fff;box-shadow:var(--shadow-lg);margin-bottom:18px;position:relative;overflow:hidden}
.stage-hero::after{content:"";position:absolute;right:-70px;top:-70px;width:240px;height:240px;border:2px solid rgba(255,255,255,.14);border-radius:50%}
.stage-hero .shic{font-size:48px;flex-shrink:0;width:84px;height:84px;border-radius:22px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.stage-hero .eyebrow{color:rgba(255,255,255,.82);font-weight:800;letter-spacing:1.3px;text-transform:uppercase;font-size:11.5px}
.stage-hero h1{margin:4px 0 6px;font-size:27px;color:#fff;letter-spacing:-.4px;line-height:1.1}
.stage-hero p{margin:0;color:#eafffb;font-size:15px;max-width:640px}
.drill .dic{font-size:32px;margin-bottom:4px}
.accordion{display:flex;flex-direction:column;gap:10px;max-width:900px}
.acc-item{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;transition:.2s}
.acc-item.open{border-color:#cfe0e4;box-shadow:var(--shadow-md)}
.acc-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;background:none;border:none;padding:16px 20px;font-size:15px;font-weight:700;color:var(--navy);text-align:left}
.acc-head:hover{color:var(--blue)}
.acc-ar{color:var(--blue);transition:transform .25s var(--ease);font-size:13px}
.acc-item.open .acc-ar{transform:rotate(180deg)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.acc-item.open .acc-body{max-height:400px}
.acc-inner{padding:0 20px 18px;color:var(--muted);font-size:14.5px;line-height:1.65}

/* cadeia sistêmica (entradas → transformação → saídas) */
.sistemic{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:stretch;margin-bottom:6px}
.sis-io{border-radius:18px;padding:20px;color:#fff;box-shadow:var(--shadow-md);text-decoration:none;display:flex;flex-direction:column;transition:.18s var(--ease)}
.sis-io:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);text-decoration:none}
.sis-io.entradas{background:linear-gradient(135deg,#2F7185,#1d4a56)}
.sis-io.saidas{background:linear-gradient(135deg,#86BC3C,#5f8f28)}
.sis-io .io-ic{font-size:28px}
.sis-io .io-t{font-size:20px;font-weight:800;margin-top:6px}
.sis-io .io-s{font-size:13px;opacity:.92;flex:1;margin-top:4px}
.sis-io .more{color:#fff;opacity:.95}
.sis-mid{display:flex;align-items:center;gap:10px}
.sis-arrow{color:var(--teal);font-size:26px;font-weight:800}
.sis-core{background:#fff;border:2px dashed var(--teal);border-radius:16px;padding:18px 16px;display:flex;align-items:center;text-align:center;box-shadow:var(--shadow);min-width:150px}
.sis-core-t{font-size:13px;font-weight:700;color:var(--petrol);line-height:1.35}
.phase-block{margin-bottom:14px}
.phase-head{display:flex;align-items:center;gap:12px;background:#eef5f5;border-radius:12px;padding:10px 14px;margin-bottom:8px;color:var(--navy);text-decoration:none}
.phase-head:hover{background:#e3eff0;text-decoration:none}
.phase-head .phase-ic{font-size:22px}
.phase-head b{font-size:14px;color:var(--navy)}
.phase-head small{display:block;color:var(--muted);font-size:12px}
.phase-head .more{margin-left:auto;color:var(--blue);font-weight:800}
@media(max-width:760px){.sistemic{grid-template-columns:1fr}.sis-mid{flex-direction:column}.sis-arrow{transform:rotate(90deg)}}

/* value chain */
.chain{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.chain .lbl{font-size:11px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:var(--blue);margin-bottom:12px}
.flow{display:flex;flex-wrap:wrap;gap:9px}
.proc{flex:1;min-width:120px;background:var(--grad-soft);color:#fff;border-radius:13px;padding:13px 14px;transition:.18s var(--ease);cursor:default}
.proc:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);filter:brightness(1.06)}
.proc .pic{font-size:18px}
.proc .sig{font-weight:800;font-size:13px;margin-top:4px}
.proc .nm{font-size:10.5px;opacity:.95;line-height:1.3;display:block;margin-top:2px;color:#eafffb}
.support-band{margin-top:18px;background:#f4faea;border:1px dashed var(--lime-d);border-radius:14px;padding:16px}
.support-band .lbl{color:var(--lime-d)}
.support-band .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid #cfe6a8;color:#5f7e2c;border-radius:999px;padding:6px 13px;font-size:12.5px;font-weight:600}

/* charts */
.chart-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}

/* document / markdown (Acervo) */
.doc{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px 34px;box-shadow:var(--shadow);max-width:900px}
.doc h1,.doc h2,.doc h3{color:var(--navy);line-height:1.25}
.doc h1{font-size:21px;border-bottom:1px solid var(--line);padding-bottom:8px}
.doc h2{font-size:17px;margin-top:24px}.doc h3{font-size:15px;margin-top:18px}
.doc p{margin:10px 0}.doc ul,.doc ol{padding-left:22px}
.doc table{border-collapse:collapse;width:100%;margin:14px 0;font-size:13px}
.doc th,.doc td{border:1px solid var(--line);padding:7px 10px;text-align:left}.doc th{background:#eef5f5;color:var(--navy)}
.doc code{background:#eef5f5;padding:1px 5px;border-radius:5px;font-size:13px}
.doclist{display:flex;flex-direction:column;gap:9px}
.docitem{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 15px;transition:.15s}
.docitem:hover{border-color:#d2e2e5;box-shadow:var(--shadow)}
.docitem .ext{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;color:#fff;text-transform:uppercase;flex-shrink:0}
.ext.md{background:var(--blue)}.ext.docx{background:#2b579a}.ext.pdf{background:#c0392b}.ext.pptx{background:#d24726}
.ext.png,.ext.jpg,.ext.jpeg{background:var(--teal)}.ext.mp4{background:#8e44ad}.ext.zip,.ext.txt{background:#7f8c8d}
.docitem .info{flex:1;min-width:0}.docitem .info b{font-size:13.5px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--navy)}
.docitem .info small{color:var(--muted);font-size:12px}

/* tables */
table.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
table.tbl th{background:var(--petrol);color:#fff;text-align:left;padding:12px 15px;font-size:12.5px}
table.tbl td{padding:11px 15px;border-top:1px solid var(--line);font-size:13.5px}
table.tbl tr:hover td{background:#f5fafa}

/* metapanel / kv */
.metapanel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);margin-bottom:18px}
.metapanel h3{margin:0 0 14px;color:var(--navy);font-size:17px;display:flex;align-items:center;gap:8px}
.kv{display:grid;grid-template-columns:180px 1fr;gap:9px 18px;font-size:14px}
.kv dt{color:var(--muted);font-weight:600}.kv dd{margin:0}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(10,40,46,.55);display:flex;align-items:center;justify-content:center;z-index:90;backdrop-filter:blur(3px);animation:fadein .2s}
.modal{background:#fff;border-radius:20px;padding:28px;width:540px;max-width:94vw;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg);animation:lbin .3s var(--ease)}
.modal h2{margin:0 0 14px;color:var(--navy);font-size:19px}
.modal .field textarea{width:100%;padding:10px;border:1px solid var(--line);border-radius:11px;font-family:inherit;font-size:14px;min-height:70px}
.modal .field select{width:100%;padding:10px;border:1px solid var(--line);border-radius:11px;font-size:14px}
.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:18px}
.stars{display:flex;gap:6px;font-size:28px;color:#d8e0e2}.stars span{cursor:pointer;transition:.1s}.stars span:hover{transform:scale(1.15)}.stars span.on{color:var(--gold)}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:13px 22px;border-radius:12px;box-shadow:var(--shadow-lg);z-index:140;font-size:14px;animation:lbin .3s var(--ease)}
.empty{color:var(--muted);text-align:center;padding:56px 20px}
.spinner{margin:70px auto;width:38px;height:38px;border:3px solid #d3e6e8;border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}
.lock{display:inline-block;background:#fbeaea;color:var(--danger);border-radius:999px;padding:2px 9px;font-size:11px;font-weight:700;margin-left:6px}
.live-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--lime-d);margin-right:7px;animation:pulse 1.6s infinite}

@media(min-width:1024px){.login-hero{display:block}}
@media(max-width:860px){#app{grid-template-columns:1fr}aside.nav{display:none}.login-right{width:100%}.hero h1{font-size:30px}#view{padding:22px}}
