/* BJS Automação — style.css */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

:root {
    --navy:       #0a1628;
    --card:       #0d1f3c;
    --black:      #111111;
    --yellow:     #f5c400;
    --yellow-bg:  rgba(245,196,0,0.12);
    --gray:       #8a9bbf;
    --muted:      #4f617e;
    --border:     rgba(255,255,255,0.07);
    --white:      #f0f4ff;
    --success:    #22c55e;
    --danger:     #ef4444;
    --info:       #3b82f6;
    --warning:    #f59e0b;
    --radius:     12px;
    --radius-sm:  8px;
    --sidebar-w:  255px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--navy);color:var(--white);font-size:14px;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;display:block}
button,input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:var(--navy)}
::-webkit-scrollbar-thumb{background:var(--card);border-radius:3px}

/* ── SIDEBAR ── */
.sidebar{
    position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;
    background:var(--black);border-right:1px solid var(--border);
    display:flex;flex-direction:column;z-index:200;
    transition:transform .3s ease;overflow-y:auto;
}
.sidebar-header{padding:20px 18px 16px;border-bottom:1px solid var(--border)}
.sidebar-brand{font-size:22px;font-weight:800;letter-spacing:-.5px}
.sidebar-brand span{color:var(--yellow)}
.sidebar-tagline{font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.sidebar-user{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.sidebar-user .av{width:36px;height:36px;border-radius:50%;background:var(--yellow);color:var(--black);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;flex-shrink:0}
.sidebar-user .name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}
.sidebar-user .role{font-size:11px;color:var(--muted)}
.sidebar-nav{flex:1;padding:10px}
.nav-section{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;padding:10px 8px 4px}
.nav-item a{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-sm);color:var(--gray);font-size:13px;font-weight:500;transition:.15s}
.nav-item a svg{width:16px;height:16px;flex-shrink:0}
.nav-item a:hover{background:rgba(255,255,255,0.05);color:var(--white)}
.nav-item.active a{background:var(--yellow-bg);color:var(--yellow);border:1px solid rgba(245,196,0,.15)}
.nav-badge{margin-left:auto;background:var(--yellow);color:var(--black);font-size:10px;font-weight:700;padding:1px 6px;border-radius:20px}
.sidebar-footer{padding:10px;border-top:1px solid var(--border)}
.sidebar-footer a{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-sm);color:var(--muted);font-size:13px;transition:.15s}
.sidebar-footer a:hover{color:var(--danger);background:rgba(239,68,68,.06)}
.sidebar-footer a svg{width:16px;height:16px}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:199}
.sidebar-overlay.open{display:block}

/* ── LAYOUT ── */
.app-layout{display:flex;min-height:100vh}
.main-wrap{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}

/* ── TOPBAR ── */
.topbar{height:58px;background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:100}
.topbar-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.topbar-titles{min-width:0}
.topbar-title{font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-sub{font-size:11px;color:var(--gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--white);padding:6px;border-radius:6px}
.hamburger svg{width:20px;height:20px;display:block}
.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* ── PAGE ── */
.page{padding:20px;flex:1}

/* ── FOOTER ── */
.app-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:11px;color:var(--muted);flex-wrap:wrap;gap:6px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:.15s;white-space:nowrap;text-decoration:none}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn-primary{background:var(--yellow);color:var(--black)}
.btn-primary:hover{background:#d4a900;transform:translateY(-1px)}
.btn-secondary{background:rgba(255,255,255,.05);color:var(--white);border:1px solid var(--border)}
.btn-secondary:hover{background:rgba(255,255,255,.09)}
.btn-danger{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.2)}
.btn-danger:hover{background:rgba(239,68,68,.18)}
.btn-success{background:rgba(34,197,94,.1);color:var(--success);border:1px solid rgba(34,197,94,.2)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-lg{padding:12px 22px;font-size:15px}
.btn-block{width:100%}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none !important}

/* ── CARDS ── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.card-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.card-title{font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}
.card-title svg{width:16px;height:16px;color:var(--yellow);flex-shrink:0}
.card-body{padding:18px}

/* ── STATS ── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:12px}
.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-icon svg{width:20px;height:20px}
.stat-icon.y{background:rgba(245,196,0,.1);color:var(--yellow)}
.stat-icon.g{background:rgba(34,197,94,.1);color:var(--success)}
.stat-icon.b{background:rgba(59,130,246,.1);color:var(--info)}
.stat-icon.r{background:rgba(239,68,68,.1);color:var(--danger)}
.stat-val{font-size:22px;font-weight:800;line-height:1.1}
.stat-lbl{font-size:12px;color:var(--gray);margin-top:2px}

/* ── FORMS ── */
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:11px;font-weight:700;color:var(--gray);margin-bottom:6px;text-transform:uppercase;letter-spacing:.7px}
.form-control{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--white);font-size:14px;outline:none;transition:.15s}
.form-control:focus{border-color:var(--yellow);background:rgba(245,196,0,.03);box-shadow:0 0 0 3px rgba(245,196,0,.1)}
.form-control::placeholder{color:var(--muted)}
.form-control option{background:var(--card)}
textarea.form-control{resize:vertical;min-height:80px}
.inp-wrap{position:relative}
.inp-wrap .form-control{padding-left:40px}
.inp-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);width:16px;height:16px;pointer-events:none}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse}
thead th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border);background:rgba(0,0,0,.15);white-space:nowrap}
tbody td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.04);font-size:13px}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:rgba(255,255,255,.02)}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600}
.badge-rascunho{background:rgba(148,163,184,.12);color:#94a3b8}
.badge-pendente{background:rgba(245,158,11,.12);color:var(--warning)}
.badge-aprovado{background:rgba(34,197,94,.12);color:var(--success)}
.badge-reprovado{background:rgba(239,68,68,.12);color:var(--danger)}
.badge-cancelado{background:rgba(107,114,128,.12);color:#6b7280}

/* ── ALERTS ── */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px;display:flex;align-items:flex-start;gap:9px}
.alert svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}
.alert-danger{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:#fca5a5}
.alert-success{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);color:#86efac}
.alert-info{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.2);color:#93c5fd}
.alert-warning{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.2);color:#fcd34d}

/* ── BREADCRUMB ── */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);margin-bottom:16px;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--yellow)}
.breadcrumb .cur{color:var(--white);font-weight:500}

/* ── PAGINATION ── */
.pagination{display:flex;align-items:center;gap:4px;justify-content:center;margin-top:20px;flex-wrap:wrap}
.page-btn{min-width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--gray);font-size:13px;font-weight:500;cursor:pointer;transition:.15s;text-decoration:none}
.page-btn:hover{border-color:var(--yellow);color:var(--yellow)}
.page-btn.active{background:var(--yellow);border-color:var(--yellow);color:var(--black);font-weight:700}
.page-btn.disabled{opacity:.3;pointer-events:none}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:48px 20px;color:var(--gray)}
.empty svg{width:48px;height:48px;color:var(--muted);margin:0 auto 14px}
.empty h3{font-size:16px;font-weight:600;color:var(--white);margin-bottom:6px}
.empty p{font-size:13px;color:var(--gray);margin-bottom:18px}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;visibility:hidden;transition:.2s}
.modal-overlay.active{opacity:1;visibility:visible}
.modal{background:var(--card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 48px rgba(0,0,0,.6)}
.modal-header{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:15px;font-weight:700}
.modal-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px}
.modal-close:hover{color:var(--white);background:rgba(255,255,255,.06)}
.modal-close svg{width:18px;height:18px;display:block}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}

/* ── LOGIN ── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--navy)}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:36px 32px;width:100%;max-width:400px;box-shadow:0 8px 48px rgba(0,0,0,.5)}
.login-brand{text-align:center;margin-bottom:28px}
.login-brand .logo{font-size:30px;font-weight:800;letter-spacing:-.5px}
.login-brand .logo span{color:var(--yellow)}
.login-brand .sub{font-size:11px;color:var(--muted);letter-spacing:1.2px;text-transform:uppercase;margin-top:3px}
.login-title{font-size:19px;font-weight:700;margin-bottom:4px}
.login-desc{font-size:13px;color:var(--gray);margin-bottom:22px}

/* ── ITEMS TABLE (orcamento) ── */
.items-tbl{width:100%;border-collapse:collapse}
.items-tbl th{background:rgba(0,0,0,.2);padding:9px 10px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;text-align:left;border-bottom:1px solid var(--border)}
.items-tbl td{padding:8px 10px;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}
.items-tbl .form-control{padding:7px 9px;font-size:13px}
.btn-rm{background:none;border:none;cursor:pointer;color:var(--muted);padding:5px;border-radius:6px;transition:.15s}
.btn-rm:hover{color:var(--danger);background:rgba(239,68,68,.1)}
.btn-rm svg{width:15px;height:15px;display:block}

/* ── TOTAL BOX ── */
.total-box{background:var(--yellow-bg);border:1px solid rgba(245,196,0,.15);border-radius:var(--radius-sm);padding:14px 16px;margin-top:14px;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.total-row{display:flex;gap:20px;align-items:center;font-size:13px;color:var(--gray);width:100%;justify-content:flex-end}
.total-row .v{font-weight:600;color:var(--white);min-width:90px;text-align:right}
.total-row.grand{font-size:17px;font-weight:800;color:var(--yellow);border-top:1px solid rgba(245,196,0,.15);padding-top:8px;margin-top:4px}
.total-row.grand .v{color:var(--yellow)}

/* ── FILTERS ── */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.search-box{position:relative;flex:1;min-width:180px}
.search-box svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);width:15px;height:15px;pointer-events:none}
.search-box input{width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px 9px 34px;color:var(--white);font-size:13px;outline:none;transition:.15s}
.search-box input:focus{border-color:var(--yellow)}
.search-box input::placeholder{color:var(--muted)}

/* ── PRINT ── */
@media print{
    .sidebar,.topbar,.btn,.filters,.pagination,.hamburger,.sidebar-overlay,.app-footer{display:none !important}
    .main-wrap{margin-left:0 !important}
    .page{padding:0 !important}
    body{background:#fff;color:#000}
    .card{border:1px solid #ccc;box-shadow:none}
}

/* ── RESPONSIVE ── */
@media (max-width:900px){
    .sidebar{transform:translateX(-100%)}
    .sidebar.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.6)}
    .main-wrap{margin-left:0}
    .hamburger{display:flex}
    .stats-grid{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:600px){
    .page{padding:12px}
    .topbar{padding:0 12px;height:52px}
    .topbar-sub{display:none}
    .app-footer{padding:10px 12px}
    .stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}
    .stat-card{padding:12px;gap:10px}
    .stat-icon{width:36px;height:36px}
    .stat-val{font-size:18px}
    .stat-lbl{font-size:11px}
    .card-header{padding:12px 14px}
    .card-body{padding:14px}
    .card-title{font-size:13px}
    thead th{font-size:10px;padding:8px 10px}
    tbody td{font-size:12px;padding:9px 10px}
    .filters{flex-direction:column;gap:8px}
    .filters form{flex-direction:column;width:100%;gap:8px}
    .search-box{min-width:unset;width:100%}
    .filters select.form-control{width:100%}
    .btn-lg{padding:11px 18px;font-size:14px}
    .login-card{padding:28px 20px}
    .modal-overlay{padding:0;align-items:flex-end}
    .modal{border-radius:16px 16px 0 0;max-width:100%}
    .breadcrumb{font-size:11px}
}

@media (max-width:400px){
    .stats-grid{grid-template-columns:1fr}
    .page{padding:10px}
}
