:root{
    --bg:#f4f6f8;
    --panel:#ffffff;
    --text:#18212f;
    --muted:#64748b;
    --line:#e2e8f0;
    --primary:#0f172a;
    --primary-2:#111827;
    --accent:#facc15;
    --danger:#dc2626;
    --green:#16a34a;
    --blue:#2563eb;
    --orange:#ea580c;
    --purple:#7c3aed;
    --shadow:0 12px 30px rgba(15,23,42,.08);
    --radius:18px;
}

*{box-sizing:border-box}
body{
    margin:0;
    font-family:Inter,Arial,Helvetica,sans-serif;
    background:var(--bg);
    color:var(--text);
}

a{color:inherit;text-decoration:none}
.topbar{
    position:sticky;
    top:0;
    z-index:10;
    background:#0b1220;
    color:white;
    min-height:74px;
    padding:14px 28px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    box-shadow:0 8px 30px rgba(0,0,0,.18);
}

.brand{
    display:flex;
    gap:12px;
    align-items:center;
}

.brand-logo{
    height:46px;
    width:auto;
    max-width:230px;
    object-fit:contain;
    display:block;
}

.brand-mark{
    width:42px;
    height:42px;
    border-radius:12px;
    display:grid;
    place-items:center;
    background:var(--accent);
    color:#0b1220;
    font-weight:900;
}

.brand small{
    display:block;
    color:#cbd5e1;
    margin-top:2px;
}

.topnav{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
    align-items:center;
    justify-content:flex-end;
}

.topnav a{
    color:#dbeafe;
    padding:10px 12px;
    border-radius:12px;
    font-size:14px;
}

.topnav a.active,
.topnav a:hover{background:rgba(255,255,255,.12);color:white}

.container{
    width:min(1180px, calc(100% - 32px));
    margin:26px auto 60px;
}

.hero,.page-title{
    background:linear-gradient(135deg,#0f172a,#1e293b);
    color:white;
    border-radius:24px;
    padding:30px;
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:20px;
    margin-bottom:20px;
    box-shadow:var(--shadow);
}

.hero h1,.page-title h1{margin:4px 0 10px;font-size:34px}
.hero p,.page-title p{margin:0;color:#cbd5e1}
.eyebrow{
    text-transform:uppercase;
    letter-spacing:.12em;
    font-weight:800;
    color:var(--accent)!important;
    font-size:12px;
}

.button{
    border:0;
    border-radius:12px;
    background:var(--accent);
    color:#111827;
    padding:12px 16px;
    font-weight:800;
    cursor:pointer;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:8px;
    white-space:nowrap;
}

.button:hover{filter:brightness(.97)}
.button.secondary{
    background:#e5e7eb;
    color:#111827;
}
.button.small{
    padding:9px 12px;
    font-size:13px;
}
.button.full{width:100%}
.panel,.search-card,.login-card,.kpi,.order-card{
    background:var(--panel);
    border:1px solid var(--line);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}

.panel,.search-card{padding:22px;margin-bottom:20px}
.panel-heading{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    margin-bottom:14px;
}
.panel-heading h2{margin:0;font-size:21px}
.panel-heading span,.panel-heading a{color:var(--muted);font-weight:700}

.search-card label,.login-card label,.form-grid label{
    display:flex;
    flex-direction:column;
    gap:8px;
    font-weight:800;
    color:#334155;
}

.search-row{
    display:flex;
    gap:12px;
    margin-top:10px;
}

input,select,textarea{
    border:1px solid #cbd5e1;
    border-radius:12px;
    padding:12px 13px;
    font:inherit;
    width:100%;
    background:white;
    color:var(--text);
}

input:focus,select:focus,textarea:focus{
    outline:3px solid rgba(250,204,21,.25);
    border-color:#eab308;
}

.cards-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:16px;
}
.order-card{padding:18px}
.order-card-top{
    display:flex;
    justify-content:space-between;
    gap:8px;
    align-items:center;
}
.order-card h3{margin:16px 0 10px}
.order-card p{margin:8px 0;color:#475569}
.badge{
    display:inline-flex;
    border-radius:999px;
    padding:6px 10px;
    font-size:12px;
    font-weight:900;
    white-space:nowrap;
}
.status-pendente{background:#f1f5f9;color:#334155}
.status-producao{background:#dbeafe;color:#1d4ed8}
.status-impresso{background:#ede9fe;color:#6d28d9}
.status-retirada{background:#ffedd5;color:#c2410c}
.status-entregue{background:#dcfce7;color:#15803d}
.status-cancelado{background:#fee2e2;color:#b91c1c}

.login-wrap{
    min-height:calc(100vh - 180px);
    display:grid;
    place-items:center;
}
.login-card{
    width:min(420px,100%);
    padding:28px;
}
.login-card h1{margin:0 0 8px}
.login-card p{color:var(--muted)}
.login-card label{margin-top:16px}
.alert,.flash{
    padding:14px 16px;
    border-radius:14px;
    margin-bottom:16px;
    font-weight:700;
}
.alert{background:#fee2e2;color:#991b1b}
.flash{background:#dcfce7;color:#166534}

.kpis{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(190px,1fr));
    gap:16px;
    margin-bottom:20px;
}
.kpi{
    padding:20px;
}
.kpi span{
    color:var(--muted);
    font-weight:800;
}
.kpi strong{
    display:block;
    font-size:34px;
    margin:8px 0;
}
.kpi small{color:var(--muted)}

.grid-two{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:20px;
}
.table-scroll{overflow:auto}
table{
    width:100%;
    border-collapse:collapse;
    min-width:720px;
}
th,td{
    padding:13px 12px;
    border-bottom:1px solid var(--line);
    text-align:left;
    vertical-align:middle;
}
th{
    background:#f8fafc;
    color:#334155;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.04em;
}
td small{
    display:block;
    margin-top:4px;
}
.muted{color:var(--muted)}
.filters{
    display:grid;
    grid-template-columns:2fr minmax(160px, .7fr) minmax(190px, .9fr) auto auto;
    gap:12px;
    align-items:center;
}
.actions{
    display:flex;
    gap:12px;
    align-items:center;
}
.actions form{margin:0}
.link-danger{
    border:0;
    background:transparent;
    color:var(--danger);
    cursor:pointer;
    font:inherit;
    font-weight:800;
    padding:0;
}
.form-grid{
    display:grid;
    grid-template-columns:repeat(2,1fr);
    gap:18px;
}
.span-2{grid-column:span 2}
.form-actions{
    display:flex;
    gap:10px;
}
.inline-status{
    display:flex;
    gap:8px;
    align-items:center;
    min-width:460px;
}
.inline-status input{min-width:120px}
.timeline{
    display:grid;
    gap:14px;
}
.timeline div{
    border-left:4px solid var(--accent);
    padding-left:12px;
}
.timeline strong,.timeline span,.timeline small{display:block}
.timeline span{color:#334155;margin:4px 0}
.timeline small{color:var(--muted)}
.page-actions{display:flex;gap:10px}
.only-print{display:none}

@media(max-width:900px){
    .topbar,.hero,.page-title{align-items:flex-start;flex-direction:column}
    .topnav{justify-content:flex-start}
    .grid-two{grid-template-columns:1fr}
    .filters{grid-template-columns:1fr}
    .form-grid{grid-template-columns:1fr}
    .span-2{grid-column:span 1}
    .search-row{flex-direction:column}
    .inline-status{min-width:360px}
}

@media print{
    body{background:white}
    .topbar,.no-print,.button,.filters{display:none!important}
    .container{width:100%;margin:0}
    .panel,.kpi{box-shadow:none;border:1px solid #ddd}
    .only-print{display:block}
    .grid-two{grid-template-columns:1fr 1fr}
    table{min-width:0}
}

.payment-paid{background:#dcfce7;color:#15803d}
.payment-partial{background:#fef3c7;color:#92400e}
.payment-pending{background:#fee2e2;color:#b91c1c}
.payment-empty{background:#f1f5f9;color:#475569}
.finance-summary{
    display:grid;
    gap:5px;
    min-width:190px;
}
.finance-summary span,
.finance-summary strong{
    white-space:nowrap;
}
.inline-payment{
    display:grid;
    grid-template-columns:1fr 1fr auto;
    gap:8px;
    align-items:center;
    margin-top:10px;
    min-width:380px;
}
.inline-payment input{min-width:90px}
.finance-preview{
    background:#f8fafc;
    border:1px solid var(--line);
    border-radius:14px;
    padding:14px;
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    align-items:center;
}
.finance-preview span{color:#334155;font-weight:700}

@media(max-width:900px){
    .inline-payment{grid-template-columns:1fr;min-width:260px}
}

.image-cell{min-width:120px}
.thumb-link{
    display:inline-flex;
    align-items:center;
    gap:8px;
    font-weight:800;
    color:#0f172a;
}
.order-thumb{
    width:74px;
    height:54px;
    object-fit:cover;
    border:1px solid var(--line);
    border-radius:10px;
    background:#f8fafc;
}
.image-upload-box{
    background:#f8fafc;
    border:1px solid var(--line);
    border-radius:14px;
    padding:14px;
    display:grid;
    gap:10px;
}
.current-image{
    display:flex;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
    padding-top:8px;
}
.current-image .order-thumb{
    width:120px;
    height:84px;
}
.checkline{
    display:flex!important;
    flex-direction:row!important;
    align-items:center;
    gap:8px!important;
    font-weight:700!important;
    margin-top:8px;
}
.checkline input{
    width:auto;
}

@media(max-width:480px){
    .brand-logo{height:38px;max-width:190px}
}

/* Melhorias da tela de produção: evita página cortada e deixa status/valores mais fáceis de achar */
.production-title{
    align-items:flex-start;
}
.production-filters{
    grid-template-columns:2fr minmax(150px,.8fr) minmax(150px,.8fr) minmax(190px,.9fr) auto auto;
}
.empty-state{
    background:#f8fafc;
    border:1px dashed #cbd5e1;
    border-radius:16px;
    padding:24px;
    text-align:center;
}
.empty-state h3{margin:0 0 8px}
.empty-state p{color:var(--muted);margin:0 0 16px}
.production-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(360px,1fr));
    gap:16px;
}
.production-card{
    border:1px solid var(--line);
    border-radius:18px;
    background:#fff;
    box-shadow:0 8px 20px rgba(15,23,42,.06);
    padding:16px;
    display:grid;
    gap:14px;
}
.production-card-head{
    display:flex;
    justify-content:space-between;
    gap:10px;
    align-items:flex-start;
    border-bottom:1px solid var(--line);
    padding-bottom:12px;
}
.order-code{
    display:block;
    font-size:18px;
    color:#0f172a;
}
.production-main{
    display:grid;
    grid-template-columns:110px 1fr;
    gap:14px;
    align-items:start;
}
.production-image .order-thumb{
    width:100px;
    height:76px;
}
.production-info h3{
    margin:0 0 8px;
    font-size:18px;
}
.production-info p{
    margin:5px 0;
    color:#475569;
}
.production-finance{
    background:#f8fafc;
    border:1px solid var(--line);
    border-radius:14px;
    padding:14px;
}
.card-payment{
    min-width:0;
    grid-template-columns:1fr 1fr auto;
}
.production-status-form{
    display:grid;
    grid-template-columns:minmax(180px,.9fr) 1fr auto;
    gap:10px;
    align-items:end;
}
.production-status-form label{
    display:flex;
    flex-direction:column;
    gap:7px;
    font-weight:800;
    color:#334155;
}
@media(max-width:900px){
    .production-filters{grid-template-columns:1fr}
    .production-grid{grid-template-columns:1fr}
    .production-status-form{grid-template-columns:1fr}
    .card-payment{grid-template-columns:1fr}
}
@media(max-width:480px){
    .production-main{grid-template-columns:1fr}
    .production-image .order-thumb{width:100%;height:140px}
}

/* Pedidos atrasados */
.status-atrasado{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.is-late{border-color:#fecaca!important;background:#fff5f5!important}
tr.is-late td{background:#fff5f5!important}
.production-card.is-late{box-shadow:0 10px 24px rgba(185,28,28,.12)}
.late-text{display:inline-flex;margin-left:6px;padding:3px 8px;border-radius:999px;background:#fee2e2;color:#991b1b;font-size:11px;font-weight:900;text-transform:uppercase}
.late-kpi{border-color:#fecaca!important;background:#fff5f5!important}
.late-kpi strong{color:#b91c1c}

/* Produção em formato de lista/tabela */
.production-table-scroll{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
}
.production-list-table{
    min-width:1320px;
}
.production-list-table th,
.production-list-table td{
    vertical-align:top;
}
.production-list-table .finance-cell{
    min-width:260px;
}
.production-list-table .inline-status{
    min-width:430px;
}
.production-list-table .inline-payment{
    min-width:320px;
}
.production-list-table tr.is-late td{
    background:#fff5f5!important;
}

/* Usuários e auditoria */
.status-note{
    margin-top:8px;
    line-height:1.35;
}
.users-list{
    display:grid;
    gap:14px;
}
.user-card{
    border:1px solid var(--line);
    border-radius:16px;
    padding:16px;
    background:#fff;
}
.user-edit-form{
    display:grid;
    grid-template-columns:repeat(4, minmax(150px, 1fr)) minmax(170px, .8fr) auto;
    gap:12px;
    align-items:end;
}
.user-edit-form label,
.user-create-form label{
    display:flex;
    flex-direction:column;
    gap:8px;
    font-weight:800;
    color:#334155;
}
.user-meta{
    display:grid;
    gap:4px;
    color:#334155;
}
.user-meta small{color:var(--muted)}
.delete-user-form{
    margin-top:10px;
}
.muted-panel p{
    margin:8px 0 0;
    color:#475569;
}
@media(max-width:1100px){
    .user-edit-form{grid-template-columns:repeat(2, 1fr)}
}
@media(max-width:700px){
    .user-edit-form{grid-template-columns:1fr}
}
