
:root{
  --bg:#000;
  --panel:rgba(20,20,20,.94);
  --panel2:rgba(32,32,32,.96);
  --line:rgba(255,255,255,.08);
  --line2:rgba(255,255,255,.16);
  --text:#f5f5f5;
  --muted:#bbbbbb;
  --soft:#9a9a9a;
  --hover:#3a3a3a;
  --shadow:0 12px 30px rgba(0,0,0,.28);
  --ok:#59d38c;
  --warn:#ffb347;
  --danger:#ff7070;
  --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;position:relative}
body::before{content:"";position:fixed;inset:0;background:url('logo.png') center center / contain no-repeat;opacity:.10;pointer-events:none;z-index:0}
header,main,.modal-backdrop,.toast-wrap{position:relative;z-index:2}
header{position:sticky;top:0;z-index:80;background:rgba(10,10,10,.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:10px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.left-head{display:flex;align-items:center;gap:10px;min-width:220px}
.logo-link{display:flex;align-items:center;text-decoration:none;color:inherit}
.logo{width:46px;height:46px;border-radius:12px;object-fit:contain;background:rgba(255,255,255,.03);padding:4px;border:1px solid var(--line)}
.brand{display:flex;flex-direction:column;gap:2px}.brand strong{font-size:16px}.brand span{font-size:11px;color:var(--muted)}
.header-actions{display:flex;align-items:center;gap:8px;flex:1;justify-content:flex-end;flex-wrap:wrap}
.search-wrap{position:relative;width:min(420px,100%);flex:1;min-width:240px}
.search{width:100%;height:40px;border-radius:999px;border:1px solid var(--line2);background:#ededed;color:#111;padding:0 42px 0 14px;font-size:14px;outline:none}
.search-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#444;font-size:15px;pointer-events:none}
.top-btn,.btn{height:40px;border:none;border-radius:12px;padding:0 14px;background:#2c2c2c;color:#fff;border:1px solid var(--line2);cursor:pointer;font-weight:700}
.top-btn:hover,.btn:hover{background:#3a3a3a}
.btn.small{height:32px;padding:0 10px;font-size:12px}
.btn.icon{width:36px;padding:0;font-size:18px}
.btn.ok,.top-btn.ok{background:#244431}.btn.ok:hover,.top-btn.ok:hover{background:#2d5940}
.btn.warn,.top-btn.warn{background:#4a3721}.btn.warn:hover,.top-btn.warn:hover{background:#5a4428}
.btn.danger,.top-btn.danger{background:#3a2020}.btn.danger:hover,.top-btn.danger:hover{background:#4a2626}
.btn.ghost,.top-btn.ghost{background:#1f1f1f}
.btn[disabled],.top-btn[disabled]{opacity:.5;cursor:not-allowed}
.menu-wrap{position:relative}
.menu-btn{width:40px;height:40px;border:none;border-radius:12px;cursor:pointer;background:var(--panel2);color:#fff;font-size:20px;line-height:1;border:1px solid var(--line2)}
.menu-btn:hover{background:var(--hover)}
.menu-panel{position:absolute;right:0;top:44px;min-width:240px;background:#111;border:1px solid var(--line2);border-radius:16px;box-shadow:var(--shadow);padding:8px;display:none;z-index:200}
.menu-wrap:hover .menu-panel,.menu-wrap.open .menu-panel{display:block}
.menu-item{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fff;padding:11px 12px;border-radius:12px;font-size:14px;border:1px solid transparent}
.menu-item:hover{background:#1e1e1e;border-color:var(--line)}
.menu-sep{height:1px;background:var(--line);margin:6px 2px}
main{max-width:1400px;margin:16px auto;padding:0 14px 28px}
.topbar{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:14px}
.title h1{margin:0;font-size:22px}.title p{margin:4px 0 0;color:var(--muted);font-size:12px}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px}
.card,.panel,.group-card{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:14px;box-shadow:var(--shadow);backdrop-filter:blur(8px);display:grid;gap:12px}
.panel .ph{padding:0 0 12px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.panel .pb{padding-top:12px}
.card-head,.group-head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;flex-wrap:wrap}
.card-title,.group-title{display:grid;gap:4px}
.card-title h3,.group-title h3{margin:0;font-size:18px;line-height:1.2}
.subline{font-size:12px;color:var(--muted)}
.badge,.count-badge,.pill{padding:6px 10px;border-radius:999px;font-size:11px;font-weight:800;background:#2a2a2a;border:1px solid var(--line);color:#f2f2f2;white-space:nowrap}
.badge.ok,.pill.ok{background:rgba(89,211,140,.14);color:#86e6ab;border-color:rgba(89,211,140,.28)}
.badge.warn,.pill.warn{background:rgba(255,179,71,.14);color:#ffd28d;border-color:rgba(255,179,71,.28)}
.badge.danger,.pill.danger{background:rgba(255,112,112,.14);color:#ffb3b3;border-color:rgba(255,112,112,.28)}
.meta{display:grid;gap:8px}
.row{display:flex;gap:10px;align-items:flex-start;justify-content:space-between}
.row span{font-size:11px;color:var(--soft);min-width:96px}
.row strong{font-size:13px;color:#fff;text-align:right;word-break:break-word}
.actions,.group-actions,.catalog-actions{display:flex;gap:8px;flex-wrap:wrap}
.empty{background:var(--panel);border:1px dashed var(--line2);padding:28px;border-radius:22px;color:var(--muted);text-align:center}
.vehicle-list,.list-cards,.stack{display:grid;gap:10px}
.item,.vehicle-item,.mini-card{border:1px solid var(--line);border-radius:16px;padding:12px;background:rgba(255,255,255,.03);display:grid;gap:8px}
.mini-card{cursor:pointer}.mini-card:hover{background:rgba(255,255,255,.06)}
.field{display:grid;gap:6px}
.field label{font-size:12px;color:#cfcfcf;font-weight:700}
.field input,.field textarea,.field select{width:100%;min-height:42px;border-radius:12px;border:1px solid var(--line2);background:#f3f3f3;color:#111;padding:10px 12px;font:inherit;outline:none}
.field textarea{min-height:92px;resize:vertical}
.field.readonly input{background:#dcdcdc;color:#111;font-weight:700}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.span-2{grid-column:1/-1}
.helper,.notice,.note{font-size:12px;color:#cfcfcf;line-height:1.5;background:rgba(255,255,255,.03);border:1px solid var(--line);padding:12px;border-radius:14px}
.notice.warn,.helper.warn{color:#ffd28d;border-color:rgba(255,179,71,.25);background:rgba(255,179,71,.08)}
.notice.ok,.helper.ok{color:#86e6ab;border-color:rgba(89,211,140,.25);background:rgba(89,211,140,.08)}
.layout{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(320px,.85fr);gap:14px;align-items:start}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px}
table{width:100%;border-collapse:collapse;min-width:920px;background:rgba(255,255,255,.02)}
th,td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
th{font-size:12px;color:#d6d6d6;text-align:left;background:rgba(255,255,255,.03)}
td input,td select{width:100%;min-height:36px;border-radius:10px;border:1px solid var(--line2);background:#f3f3f3;color:#111;padding:8px 10px;font:inherit;outline:none}
.row-total{background:#e2e2e2 !important;font-weight:700}
.summary{display:grid;gap:10px}
.sum-row{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.03)}
.sum-row span{font-size:12px;color:var(--muted)} .sum-row strong{font-size:16px}
.sum-row.main strong{font-size:22px}
.kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:14px;display:grid;gap:6px}
.kpi span{font-size:12px;color:var(--muted)} .kpi strong{font-size:24px}
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.62);display:none;align-items:center;justify-content:center;padding:16px;z-index:100}
.modal{width:min(900px,100%);background:#111;border:1px solid var(--line2);border-radius:22px;box-shadow:var(--shadow);overflow:hidden}
.modal header{position:static;background:#121212;border-bottom:1px solid var(--line);padding:14px 16px}
.modal .body{padding:16px;display:grid;gap:14px}
.modal .foot{padding:0 16px 16px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}
.toast-wrap{position:fixed;right:14px;bottom:14px;display:grid;gap:8px;z-index:999}
.toast{background:#111;border:1px solid var(--line2);color:#fff;padding:12px 14px;border-radius:14px;box-shadow:var(--shadow);min-width:240px}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.chip{min-height:38px;padding:8px 12px;border:none;border-radius:999px;background:#2c2c2c;color:#fff;border:1px solid var(--line);cursor:pointer;font-weight:700;line-height:1.1}
.chip:hover{background:#3a3a3a}.chip.active{background:#f0f0f0;color:#111}
@media (max-width:1100px){.layout{grid-template-columns:1fr}.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:820px){.form-grid{grid-template-columns:1fr}.kpis{grid-template-columns:1fr}}
@media (max-width:640px){.grid{grid-template-columns:1fr}.title h1{font-size:18px}.search-wrap{min-width:100%}}


/* =========================================================
   WS Oficina Auto - Mobile refinado + PWA base
   ---------------------------------------------------------
   Camada global para melhorar uso em telemóvel sem alterar
   regras de negócio, sincronização ou cálculos.
   ========================================================= */
:root{
  --mobile-safe-bottom: env(safe-area-inset-bottom, 0px);
  --mobile-safe-top: env(safe-area-inset-top, 0px);
}

html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

body{
  overscroll-behavior-y:contain;
}

input, select, textarea, button{
  font-size:16px;
}

button, .btn, .top-btn, .chip, .menu-btn{
  touch-action:manipulation;
}

a.btn, a.top-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}

@media (max-width:760px){
  body{
    padding-bottom:calc(8px + var(--mobile-safe-bottom));
  }

  header{
    position:sticky;
    top:0;
    padding:8px 10px;
    gap:8px;
  }

  .left-head{
    min-width:0;
    flex:1 1 auto;
  }

  .logo{
    width:40px;
    height:40px;
    border-radius:11px;
  }

  .brand strong{
    font-size:14px;
    line-height:1.1;
  }

  .brand span{
    font-size:10px;
  }

  .header-actions{
    width:100%;
    justify-content:flex-start;
    gap:7px;
  }

  .search-wrap{
    order:2;
    width:100%;
    flex:1 1 100%;
    min-width:0;
  }

  .search{
    height:44px;
    border-radius:14px;
  }

  .top-btn,.btn{
    min-height:42px;
    height:auto;
    padding:10px 12px;
    border-radius:12px;
    font-size:14px;
    line-height:1.1;
  }

  .btn.small{
    min-height:38px;
    height:auto;
    padding:9px 10px;
    font-size:12px;
  }

  .menu-btn{
    width:42px;
    height:42px;
    border-radius:12px;
  }

  .menu-panel{
    position:fixed;
    top:62px;
    left:10px;
    right:10px;
    min-width:0;
    max-height:calc(100vh - 82px);
    border-radius:18px;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
  }

  .menu-item{
    min-height:44px;
    font-size:14px;
    padding:12px 12px;
  }

  main{
    margin:12px auto;
    padding:0 10px calc(22px + var(--mobile-safe-bottom));
  }

  .topbar{
    align-items:flex-start;
    margin-bottom:10px;
  }

  .title h1{
    font-size:19px;
  }

  .title p{
    font-size:12px;
  }

  .grid{
    grid-template-columns:1fr !important;
    gap:10px;
  }

  .card,.panel,.group-card{
    border-radius:18px;
    padding:12px;
    gap:10px;
  }

  .panel .ph{
    padding-bottom:10px;
    gap:8px;
  }

  .panel .pb{
    padding-top:10px;
  }

  .card-head,.group-head{
    gap:8px;
  }

  .card-title h3,.group-title h3{
    font-size:16px;
  }

  .actions,.group-actions,.catalog-actions,.inline-actions,.hero-actions{
    width:100%;
    gap:7px;
  }

  .actions .btn,
  .group-actions .btn,
  .inline-actions .btn,
  .hero-actions .top-btn{
    flex:1 1 auto;
  }

  .form-grid,.modal-grid,.payment-grid{
    grid-template-columns:1fr !important;
  }

  .span-2{
    grid-column:auto;
  }

  .field input,
  .field textarea,
  .field select{
    min-height:46px;
    border-radius:13px;
    padding:11px 12px;
  }

  .field textarea{
    min-height:98px;
  }

  .modal-backdrop{
    align-items:flex-end;
    padding:10px;
  }

  .modal{
    width:100%;
    max-height:calc(100vh - 20px);
    border-radius:20px;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
  }

  .modal header{
    padding:13px 14px;
  }

  .modal .body{
    padding:14px;
    gap:12px;
  }

  .modal .foot{
    padding:0 14px calc(14px + var(--mobile-safe-bottom));
    justify-content:stretch;
  }

  .modal .foot .btn,
  .modal .foot .top-btn{
    flex:1 1 auto;
  }

  .table-wrap{
    border-radius:16px;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
  }

  table{
    min-width:780px;
  }

  .kpis{
    grid-template-columns:1fr 1fr !important;
    gap:8px;
  }

  .kpi{
    border-radius:16px;
    padding:12px;
  }

  .kpi strong{
    font-size:20px;
  }

  .toast-wrap{
    left:10px;
    right:10px;
    bottom:calc(10px + var(--mobile-safe-bottom));
  }

  .toast{
    min-width:0;
    width:100%;
  }
}

@media (max-width:430px){
  .kpis{
    grid-template-columns:1fr !important;
  }

  .top-btn,.btn{
    width:auto;
  }

  .actions .btn,
  .group-actions .btn,
  .inline-actions .btn{
    flex:1 1 100%;
  }
}

