/* ===== Pangara · Portal de Procurement — Design System (base V5 Minimal) ===== */
:root{
  --coral:#EF4232; --coral-d:#C9301F; --ink:#111111; --muted:#8a8a8a;
  --line:#e6e6e6; --paper:#ffffff; --soft:#FAF7F3; --soft2:#F4F1ED;
  --ok:#2E8B6F; --warn:#C8881C; --info:#2D6CDF; --bad:#C9402B;
  --sidebar:#141215;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Archivo',sans-serif;color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
h1,h2,h3{letter-spacing:-.03em;line-height:1.02;font-weight:700}
.wrap{max-width:1320px;margin:0 auto;padding:0 48px}
.coral{color:var(--coral)}
.muted{color:var(--muted)}
small{font-size:12px}

/* ===== Buttons ===== */
.btn,.btn-o,.btn-coral{display:inline-flex;align-items:center;gap:8px;padding:15px 30px;font-weight:600;font-size:14px;transition:.2s;cursor:pointer;border:1px solid var(--ink);font-family:inherit}
.btn{background:var(--ink);color:#fff}
.btn:hover{background:var(--coral);border-color:var(--coral)}
.btn-o{background:none;color:var(--ink)}
.btn-o:hover{background:var(--ink);color:#fff}
.btn-coral{background:var(--coral);color:#fff;border-color:var(--coral)}
.btn-coral:hover{background:var(--ink);border-color:var(--ink)}
.btn-sm{padding:9px 16px;font-size:13px}
.btn-block{width:100%;justify-content:center}

/* ===== Public header ===== */
header.site{border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(255,255,255,.93);backdrop-filter:blur(10px);z-index:100}
.nav{display:flex;align-items:center;justify-content:space-between;height:104px;gap:30px}
.nav .logo{display:flex;align-items:center;gap:12px}
.nav .logo img{height:64px}
.nav .logo .tag{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border-left:1px solid var(--line);padding-left:11px;font-weight:600;line-height:1.2}
.nav nav{display:flex;gap:24px;align-items:center}
.nav nav a{font-size:13px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--ink);white-space:nowrap}
.nav nav a:hover,.nav nav a.active{color:var(--coral)}
.nav nav a.back-site{color:var(--muted);padding-right:18px;border-right:1px solid var(--line)}
.nav nav a.back-site:hover{color:var(--coral)}
.nav .actions{display:flex;gap:12px;align-items:center}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer}
.burger span{width:24px;height:2px;background:var(--ink)}

/* ===== Generic sections ===== */
.section{padding:80px 0;border-bottom:1px solid var(--line)}
.section.nb{border-bottom:0}
.lab{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);font-weight:700}
.sec-title{font-size:clamp(28px,4vw,48px);font-weight:800;letter-spacing:-.03em;margin-top:12px}
.sec-head{margin-bottom:44px;max-width:60ch}
.sec-head p{color:var(--muted);font-size:17px;margin-top:14px}

/* ===== Portal hero ===== */
.phero{border-bottom:1px solid var(--line);padding:80px 0 0}
.phero .meta{display:flex;gap:18px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:28px}
.phero h1{font-size:clamp(40px,6.5vw,86px);font-weight:800;letter-spacing:-.04em;line-height:.94;max-width:18ch}
.phero .lead{font-size:19px;color:#444;max-width:56ch;margin:26px 0 34px}
.phero .cta-row{display:flex;gap:14px;flex-wrap:wrap;padding-bottom:60px}

/* page hero (inner) */
.page-hero{border-bottom:1px solid var(--line);padding:64px 0 56px}
.page-hero .crumb{display:flex;gap:12px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:22px}
.page-hero .crumb a:hover{color:var(--coral)}
.page-hero h1{font-size:clamp(34px,5vw,64px);font-weight:800;letter-spacing:-.03em}
.page-hero p{font-size:18px;color:#444;max-width:60ch;margin-top:18px}

/* ===== Steps / how it works ===== */
.steps4{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}
.steps4 .st{padding:34px 26px 38px;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.steps4 .st:nth-child(4n){border-right:0}
.steps4 .st .n{font-size:13px;font-weight:700;color:var(--coral);letter-spacing:.08em}
.steps4 .st h4{font-size:19px;margin:14px 0 8px}
.steps4 .st p{font-size:14px;color:var(--muted)}

/* ===== Cards grid (categories / features) ===== */
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{border:1px solid var(--line);background:#fff;transition:.25s}
.card:hover{box-shadow:0 24px 50px -30px rgba(0,0,0,.35);transform:translateY(-3px)}
.cat-card{padding:30px 26px 34px;display:block}
.cat-card .em{font-size:30px;margin-bottom:18px}
.cat-card h4{font-size:20px;margin-bottom:8px}
.cat-card p{font-size:14px;color:var(--muted);margin-bottom:14px}
.cat-card .more{font-size:13px;font-weight:700;color:var(--coral)}
.cat-card:hover h4{color:var(--coral)}

/* product card */
.prod-card{display:block}
.prod-card .ph{aspect-ratio:4/3;overflow:hidden;border-bottom:1px solid var(--line);background:var(--soft)}
.prod-card .ph img{width:100%;height:100%;object-fit:cover;transition:.5s}
.prod-card:hover .ph img{transform:scale(1.05)}
.prod-card .bd{padding:20px 20px 24px}
.prod-card .ct{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.prod-card h4{font-size:17px;margin:8px 0 10px;letter-spacing:-.01em}
.prod-card .pr{font-size:13px;color:#444}
.prod-card .pr b{color:var(--ink)}

/* ===== Catalog layout ===== */
.cat-layout{display:grid;grid-template-columns:260px 1fr;gap:40px}
.filters{border:1px solid var(--line);padding:24px;height:fit-content;position:sticky;top:96px}
.filters h5{font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin:20px 0 12px}
.filters h5:first-child{margin-top:0}
.filters label{display:flex;gap:9px;align-items:center;font-size:14px;color:#444;padding:5px 0;cursor:pointer}
.searchbar{display:flex;border:1px solid var(--line);margin-bottom:24px}
.searchbar input{flex:1;border:0;padding:14px 16px;font-family:inherit;font-size:15px;outline:none}
.searchbar button{border:0;background:var(--ink);color:#fff;padding:0 22px;cursor:pointer;font-weight:600}

/* ===== Product detail ===== */
.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px}
.pd-media img{width:100%;height:440px;object-fit:cover;border:1px solid var(--line)}
.pd-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:10px}
.pd-thumbs img{height:74px;object-fit:cover;border:1px solid var(--line);cursor:pointer}
.pd-info .ct{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.pd-info h1{font-size:36px;margin:10px 0 14px;letter-spacing:-.02em}
.pd-info .desc{color:#555;font-size:16px;margin-bottom:20px}
.specs{list-style:none;border-top:1px solid var(--line);margin:14px 0 24px}
.specs li{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.specs li span{color:var(--muted)}

/* price simulator */
.simulator{border:1px solid var(--line);padding:26px;background:var(--soft)}
.simulator .row{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.simulator select,.simulator input{border:1px solid var(--line);padding:12px 14px;font-family:inherit;font-size:14px;background:#fff}
.price-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:6px 0 18px}
.tier{border:1px solid var(--line);background:#fff;padding:18px;cursor:pointer;transition:.2s;position:relative}
.tier:hover{border-color:var(--ink)}
.tier.sel{border-color:var(--coral);box-shadow:inset 0 0 0 1px var(--coral)}
.tier .t{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.tier .v{font-size:24px;font-weight:800;letter-spacing:-.02em;margin:8px 0 4px}
.tier .x{font-size:12px;color:var(--muted)}
.tier .pick{position:absolute;top:12px;right:12px;width:16px;height:16px;border:1px solid var(--line);border-radius:50%}
.tier.sel .pick{border-color:var(--coral);background:var(--coral);box-shadow:inset 0 0 0 3px #fff}
.addon-toggle{display:flex;gap:10px;align-items:center;font-size:14px;padding:12px 0;border-top:1px solid var(--line)}

/* ===== Wizard ===== */
.wz-progress{display:flex;gap:0;border:1px solid var(--line);margin-bottom:40px;overflow:hidden}
.wz-progress .s{flex:1;padding:16px 14px;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);border-right:1px solid var(--line);display:flex;gap:10px;align-items:center;background:#fff}
.wz-progress .s:last-child{border-right:0}
.wz-progress .s .num{width:22px;height:22px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:12px;flex:none}
.wz-progress .s.active{color:var(--ink);background:var(--soft)}
.wz-progress .s.active .num{background:var(--coral);color:#fff;border-color:var(--coral)}
.wz-progress .s.done .num{background:var(--ink);color:#fff;border-color:var(--ink)}
.wz-step{display:none}
.wz-step.show{display:block}
.wz-step h2{font-size:30px;letter-spacing:-.02em;margin-bottom:6px}
.wz-step .sub{color:var(--muted);margin-bottom:28px}
.opt-grid{display:grid;gap:14px}
.opt{border:1px solid var(--line);padding:22px 24px;cursor:pointer;display:flex;gap:16px;align-items:flex-start;transition:.2s;background:#fff}
.opt:hover{border-color:var(--ink)}
.opt.sel{border-color:var(--coral);box-shadow:inset 0 0 0 1px var(--coral)}
.opt .ic{font-size:24px;flex:none}
.opt h4{font-size:18px;margin-bottom:4px}
.opt p{font-size:14px;color:var(--muted)}
.opt .pick{margin-left:auto;width:18px;height:18px;border:1px solid var(--line);border-radius:50%;flex:none}
.opt.sel .pick{border-color:var(--coral);background:var(--coral);box-shadow:inset 0 0 0 4px #fff}
.wz-nav{display:flex;justify-content:space-between;margin-top:36px;padding-top:24px;border-top:1px solid var(--line)}
.cond{display:none;margin-top:20px;padding-left:20px;border-left:2px solid var(--coral)}
.cond.show{display:block}

/* ===== Forms ===== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column}
.field.full{grid-column:1/-1}
.field label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-bottom:8px}
.field input,.field select,.field textarea{border:1px solid var(--line);padding:13px 15px;font-family:inherit;font-size:15px;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--coral)}
.checkrow{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--muted)}

/* ===== Badges / status ===== */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:5px 11px;border:1px solid var(--line);border-radius:100px}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--muted)}
.badge.new{color:var(--info);border-color:#bcd0f5}.badge.new::before{background:var(--info)}
.badge.analise{color:var(--warn);border-color:#ecd8ad}.badge.analise::before{background:var(--warn)}
.badge.cotado{color:var(--coral);border-color:#f3c5bd}.badge.cotado::before{background:var(--coral)}
.badge.ok{color:var(--ok);border-color:#b6dcd0}.badge.ok::before{background:var(--ok)}
.badge.bad{color:var(--bad);border-color:#e7bdb4}.badge.bad::before{background:var(--bad)}

/* ===== Stat cards ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line)}
.stats .st{padding:26px 24px;border-right:1px solid var(--line)}
.stats .st:last-child{border-right:0}
.stats .st .k{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:600}
.stats .st .v{font-size:38px;font-weight:800;letter-spacing:-.03em;margin-top:8px}
.stats .st .v small{font-size:14px;color:var(--coral);font-weight:700}

/* ===== Tables ===== */
.table{width:100%;border-collapse:collapse;border:1px solid var(--line);background:#fff}
.table th{text-align:left;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:14px 16px;border-bottom:1px solid var(--line);background:var(--soft)}
.table td{padding:15px 16px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
.table tr:last-child td{border-bottom:0}
.table tr:hover td{background:#fafafa}
.table .id{font-weight:700;color:var(--coral)}
.table .actions{text-align:right}

/* panels */
.panel{border:1px solid var(--line);background:#fff}
.panel .ph{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.panel .ph h3{font-size:18px}
.panel .pb{padding:24px}

/* ===== App shell (cliente / investidor / profissional / admin) ===== */
.shell{display:grid;grid-template-columns:264px 1fr;min-height:100vh}
.aside{background:var(--sidebar);color:#cfcad2;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.aside .brand{display:flex;align-items:center;gap:10px;padding:22px 24px;border-bottom:1px solid rgba(255,255,255,.08)}
.aside .brand img{height:30px}
.aside .brand b{color:#fff;font-size:15px;font-weight:700}
.aside .role{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:#7d7785;padding:18px 24px 8px}
.aside nav{display:flex;flex-direction:column;padding:0 12px;gap:2px}
.aside nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;font-size:14px;color:#cfcad2;border-radius:8px}
.aside nav a .ic{width:18px;text-align:center;opacity:.8}
.aside nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.aside nav a.active{background:var(--coral);color:#fff}
.aside .foot{margin-top:auto;padding:18px 24px;border-top:1px solid rgba(255,255,255,.08);font-size:13px}
.aside .foot a{color:#9b95a2}
.aside .foot a:hover{color:#fff}
.main{display:flex;flex-direction:column;min-width:0;background:var(--soft)}
.topbar{height:70px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 36px;position:sticky;top:0;z-index:20}
.topbar h1{font-size:20px;font-weight:700;letter-spacing:-.01em}
.topbar .right{display:flex;align-items:center;gap:18px}
.topbar .who{display:flex;align-items:center;gap:10px;font-size:14px}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--coral);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.content{padding:36px;max-width:1200px;width:100%}
.content .row-head{display:flex;justify-content:space-between;align-items:center;margin:0 0 22px}
.content .row-head h2{font-size:22px;letter-spacing:-.01em}
.mb{margin-bottom:24px}

/* locked / gated */
.locked{position:relative;border:1px dashed var(--line);background:var(--soft);padding:40px;text-align:center}
.locked .lk{font-size:30px;margin-bottom:12px}
.locked h4{font-size:20px;margin-bottom:8px}
.locked p{color:var(--muted);font-size:15px;max-width:46ch;margin:0 auto 18px}

/* project / package cards */
.proj-card{border:1px solid var(--line);background:#fff;padding:0;overflow:hidden}
.proj-card .ph{height:180px;overflow:hidden;border-bottom:1px solid var(--line)}
.proj-card .ph img{width:100%;height:100%;object-fit:cover}
.proj-card .bd{padding:22px 24px 26px}
.proj-card .ct{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.proj-card h4{font-size:20px;margin:8px 0 10px}
.proj-card p{font-size:14px;color:#555;margin-bottom:16px}
.proj-meta{display:flex;gap:24px;border-top:1px solid var(--line);padding-top:14px}
.proj-meta div .k{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600}
.proj-meta div .v{font-size:16px;font-weight:700}
.pkg{border:1px solid var(--line);padding:32px 28px;background:#fff;display:flex;flex-direction:column}
.pkg.hl{border-color:var(--coral);box-shadow:0 24px 50px -30px rgba(239,66,50,.5)}
.pkg .nm{font-size:13px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--coral)}
.pkg .pr{font-size:40px;font-weight:800;letter-spacing:-.03em;margin:14px 0 4px}
.pkg .pr small{font-size:14px;color:var(--muted);font-weight:600}
.pkg ul{list-style:none;margin:20px 0;flex:1}
.pkg li{font-size:14px;color:#444;padding:8px 0 8px 22px;position:relative;border-bottom:1px solid var(--line)}
.pkg li::before{content:"";position:absolute;left:0;top:15px;width:10px;height:2px;background:var(--coral)}

/* directory (professionals) */
.dir-card{border:1px solid var(--line);background:#fff;padding:24px}
.dir-card .top{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.dir-card .av{width:48px;height:48px;border-radius:50%;background:var(--soft2);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--coral)}
.dir-card h4{font-size:17px}
.dir-card .sp{font-size:13px;color:var(--muted)}
.dir-card .meta{font-size:13px;color:#555;margin:4px 0}

/* ===== Footer ===== */
footer.site{border-top:1px solid var(--line);padding:54px 0 34px;background:#fff}
.fg{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px}
footer.site .flogo{height:36px;margin-bottom:14px}
footer.site p{color:var(--muted);font-size:14px}
footer.site h5{font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
footer.site ul{list-style:none}
footer.site li{margin-bottom:9px}
footer.site ul a{color:var(--muted);font-size:14px}
footer.site ul a:hover{color:var(--coral)}
.fb{margin-top:44px;padding-top:20px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}

/* auth */
.auth{min-height:calc(100vh - 74px);display:grid;grid-template-columns:1fr 1fr}
.auth .vis{background:var(--sidebar);color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:space-between}
.auth .vis h2{font-size:38px;letter-spacing:-.03em;line-height:1.05}
.auth .vis p{color:#b7b1bd;margin-top:16px;max-width:40ch}
.auth .form{padding:60px;display:flex;flex-direction:column;justify-content:center;max-width:560px}
.auth .form h1{font-size:32px;margin-bottom:8px}
.auth .form .sub{color:var(--muted);margin-bottom:30px}
.role-pick{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:18px}
.role-pick .r{border:1px solid var(--line);padding:14px 12px;text-align:center;cursor:pointer;font-size:13px;font-weight:600}
.role-pick .r.sel{border-color:var(--coral);color:var(--coral);box-shadow:inset 0 0 0 1px var(--coral)}

/* helpers */
.split{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.split-3{display:grid;grid-template-columns:2fr 1fr;gap:36px}
.note{background:var(--soft);border:1px solid var(--line);padding:16px 18px;font-size:13.5px;color:#555;display:flex;gap:10px}
.note .i{color:var(--coral)}

/* ===== Responsive ===== */
@media(max-width:1000px){
  .wrap{padding:0 22px}
  .nav nav{display:none}
  .burger{display:flex}
  .cat-layout,.pd-grid,.split,.split-3,.auth{grid-template-columns:1fr}
  .g4,.g3,.g2,.price-tiers,.steps4,.stats,.form-grid,.fg,.role-pick{grid-template-columns:1fr 1fr}
  .shell{grid-template-columns:1fr}
  .aside{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center}
  .aside nav{flex-direction:row;flex-wrap:wrap}
  .wz-progress{display:none}
}
@media(max-width:640px){.g4,.g3,.g2,.price-tiers,.steps4,.stats,.form-grid,.fg,.role-pick{grid-template-columns:1fr}}

/* Categorias com scroll independente (mostra ~2 linhas) */
.cat-scroll{max-height:600px;overflow-y:auto;padding:2px 10px 2px 2px}
.cat-scroll::-webkit-scrollbar{width:8px}
.cat-scroll::-webkit-scrollbar-track{background:#f1f1f1;border-radius:8px}
.cat-scroll::-webkit-scrollbar-thumb{background:#d6d6d6;border-radius:8px}
.cat-scroll::-webkit-scrollbar-thumb:hover{background:#c0c0c0}
@media(max-width:1000px){.cat-scroll{max-height:none;overflow:visible;padding:0}}
