:root{
  --black:#0a0a0a;--surface-1:#111111;--surface-2:#181818;--surface-3:#1f1f1f;--surface-0:#0d0d0d;
  --border-subtle:#1a1a1a;--border:#222222;--border-mid:#2e2e2e;
  --gold:#c9a84c;--gold-light:#e8c97a;--gold-dim:rgba(201,168,76,.12);--gold-glow:rgba(201,168,76,.18);
  --white:#f0ece4;--text-secondary:#a0998f;--text-muted:#6a6460;--placeholder:#545048;
  --green:#4caf82;--red:#e05555;--blue:#5b9cf6;--orange:#f0974a;--purple:#a78bfa;
  --shadow-sm:0 1px 3px rgba(0,0,0,.4),0 1px 2px rgba(0,0,0,.3);
  --shadow-md:0 4px 12px rgba(0,0,0,.5),0 2px 4px rgba(0,0,0,.3);
  --shadow-lg:0 8px 24px rgba(0,0,0,.6),0 4px 8px rgba(0,0,0,.4);
  --shadow-gold:0 6px 22px rgba(201,168,76,.28);--shadow-gold-lg:0 10px 36px rgba(201,168,76,.35);
  --ease-out:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --dur-fast:120ms;--dur-normal:220ms;--dur-slow:380ms;
  --radius-sm:3px;--radius-md:6px;--radius-lg:10px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{background:var(--black);color:var(--white);font-family:'DM Sans',sans-serif;min-height:100vh;}

/* Login */
#loginScreen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;}
#loginScreen::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 50% 30%,rgba(201,168,76,.06),transparent 60%);pointer-events:none;}
.login-box{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px 40px;width:360px;max-width:100%;z-index:1;animation:fadeUp .5s var(--ease-out) both;box-shadow:var(--shadow-lg),0 0 0 1px rgba(201,168,76,.04);}
.login-logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:4px;margin-bottom:4px;}
.login-logo span{color:var(--gold);}
.login-sub{font-size:12px;color:var(--text-secondary);letter-spacing:1px;margin-bottom:28px;text-align:center;}
.login-label{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:7px;display:block;}
.login-sel,.login-inp{width:100%;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--white);font-family:'DM Sans',sans-serif;font-size:15px;padding:12px 14px;outline:none;transition:border-color var(--dur-normal) var(--ease-out),box-shadow var(--dur-normal) var(--ease-out);appearance:none;margin-bottom:14px;}
.login-sel{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23c9a84c' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer;}
.login-sel option{background:#161616;}
.login-sel:focus,.login-inp:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,168,76,.1);}
.login-inp::placeholder{color:var(--placeholder);}
.btn-login{width:100%;padding:14px;background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--black);border:none;border-radius:var(--radius-md);font-family:'Bebas Neue',sans-serif;font-size:16px;letter-spacing:3px;cursor:pointer;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-normal) var(--ease-out);margin-top:4px;box-shadow:0 2px 8px rgba(201,168,76,.2);}
.btn-login:hover{transform:translateY(-2px);box-shadow:var(--shadow-gold);}
.btn-login:active{transform:scale(.99);}
.login-err{color:var(--red);font-size:12px;margin-top:8px;display:none;}

#app{display:none;}

nav{background:linear-gradient(180deg,var(--surface-2) 0%,var(--surface-1) 100%);border-bottom:1px solid var(--border);padding:0 28px;display:flex;align-items:center;justify-content:space-between;height:58px;position:sticky;top:0;z-index:100;backdrop-filter:blur(8px);}
.nav-brand{font-family:'Bebas Neue',sans-serif;font-size:18px;letter-spacing:4px;display:flex;align-items:center;gap:12px;}
.nav-dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px var(--gold);}
.nav-right{display:flex;align-items:center;gap:10px;}
.user-chip{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border-mid);padding:6px 13px;border-radius:var(--radius-sm);font-size:13px;}
.user-av{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--black);}
.btn-logout{background:none;border:1px solid var(--border);color:var(--text-secondary);padding:6px 12px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:border-color var(--dur-normal) var(--ease-out),color var(--dur-normal) var(--ease-out),background var(--dur-normal) var(--ease-out);}
.btn-logout:hover{border-color:rgba(224,85,85,.4);color:var(--red);background:rgba(224,85,85,.06);}

.view-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 28px;background:var(--surface-1);}
.tab{padding:13px 22px;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color var(--dur-normal) var(--ease-out),border-color var(--dur-normal) var(--ease-out);font-family:'Bebas Neue',sans-serif;}
.tab:hover{color:var(--text-secondary);}
.tab.active{color:var(--gold);border-bottom-color:var(--gold);}

.content{padding:24px;width:100%;}

/* KPIs */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:22px;}
.kpi{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px 16px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--dur-normal) var(--ease-out),border-color var(--dur-normal) var(--ease-out),transform var(--dur-normal) var(--ease-out);}
.kpi:hover{box-shadow:var(--shadow-md);border-color:var(--border-mid);transform:translateY(-1px);}
.kpi.c-gold:hover{box-shadow:0 4px 16px rgba(201,168,76,.15),var(--shadow-md);}
.kpi::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;border-radius:0 var(--radius-sm) var(--radius-sm) 0;}
.kpi.c-gold::before{background:var(--gold);}
.kpi.c-green::before{background:var(--green);}
.kpi.c-blue::before{background:var(--blue);}
.kpi.c-orange::before{background:var(--orange);}
.kpi.c-red::before{background:var(--red);}
.kpi.c-purple::before{background:var(--purple);}
.kpi-lbl{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:7px;}
.kpi-val{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:1px;line-height:1;margin-bottom:3px;}
.kpi.c-gold .kpi-val{color:var(--gold);}
.kpi.c-green .kpi-val{color:var(--green);}
.kpi.c-blue .kpi-val{color:var(--blue);}
.kpi.c-orange .kpi-val{color:var(--orange);}
.kpi.c-red .kpi-val{color:var(--red);}
.kpi.c-purple .kpi-val{color:var(--purple);}
.kpi-sub{font-size:10px;color:var(--text-muted);}

/* Charts */
.charts-grid{display:grid;grid-template-columns:3fr 2fr;gap:12px;margin-bottom:22px;}
@media(max-width:800px){.charts-grid{grid-template-columns:1fr;}}
.chart-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;box-shadow:var(--shadow-sm);}
.chart-title{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px;}
.bar-chart{display:flex;align-items:flex-end;gap:7px;height:100px;}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;}
.bar{width:100%;border-radius:2px 2px 0 0;min-height:3px;transition:opacity var(--dur-normal);cursor:pointer;}
.bar:hover{opacity:.75;}
.bar-lbl{font-size:9px;color:var(--text-muted);}
.bar-v{font-size:9px;color:var(--text-secondary);}

/* Payment breakdown chart */
.pay-breakdown{display:flex;flex-direction:column;gap:12px;}
.pb-item{display:flex;align-items:center;gap:10px;}
.pb-label{width:140px;font-size:12px;display:flex;align-items:center;gap:6px;flex-shrink:0;}
.pb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.pb-bar-wrap{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.pb-bar{height:100%;border-radius:3px;transition:width .6s ease;}
.pb-count{font-size:12px;font-weight:600;width:24px;text-align:right;flex-shrink:0;}
.pb-val{font-size:11px;color:var(--text-secondary);width:80px;text-align:right;flex-shrink:0;}

/* Table */
.tbl-card{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);}
.tbl-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);}
.tbl-hdr h3{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-secondary);}
.filter-row{display:flex;gap:7px;flex-wrap:wrap;padding:12px 18px;border-bottom:1px solid var(--border);background:var(--surface-0);}
.filter-row input,.filter-row select{background:var(--surface-2);border:1px solid var(--border);color:var(--white);padding:7px 11px;border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:12px;outline:none;transition:border-color var(--dur-normal) var(--ease-out),box-shadow var(--dur-normal) var(--ease-out);appearance:none;}
.filter-row input:focus,.filter-row select:focus{border-color:var(--gold);box-shadow:0 0 0 2px rgba(201,168,76,.1);}
.filter-row input::placeholder{color:var(--placeholder);}
.filter-row input{width:170px;}
.filter-row select{padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath d='M1 1l3 3 3-3' stroke='%23888' stroke-width='1.2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;}
.filter-row select option{background:#111;}
.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
thead tr{background:var(--surface-0);border-bottom:1px solid var(--border);}
th{text-align:left;padding:10px 16px;font-size:9px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--text-muted);white-space:nowrap;}
td{padding:12px 16px;font-size:13px;border-bottom:1px solid var(--border-subtle);vertical-align:middle;}
tbody tr{transition:background var(--dur-fast) var(--ease-out);}
tbody tr:hover{background:rgba(255,255,255,.022);}
tbody tr:last-child td{border:none;}
.td-id{color:var(--text-secondary);font-family:monospace;font-size:11px;}
.td-name{font-weight:500;}
.td-val{color:var(--gold);font-weight:600;}
.td-val-red{color:var(--red);font-weight:600;}
.vtag{display:inline-flex;align-items:center;gap:5px;font-size:12px;}
.vtag .dot{width:7px;height:7px;border-radius:50%;}

/* Status badges — pedido */
.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;border:1px solid transparent;}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.8;}
.badge-aguardando{background:rgba(240,151,74,.1);color:var(--orange);border-color:rgba(240,151,74,.2);}
.badge-fabricando{background:rgba(167,139,250,.1);color:var(--purple);border-color:rgba(167,139,250,.2);}
.badge-pronto{background:rgba(91,156,246,.1);color:var(--blue);border-color:rgba(91,156,246,.2);}
.badge-enviado{background:rgba(76,175,130,.1);color:var(--green);border-color:rgba(76,175,130,.2);}
.badge-cancelado{background:rgba(224,85,85,.1);color:var(--red);border-color:rgba(224,85,85,.2);}
.badge-aguardando-pagamento{background:rgba(201,168,76,.1);color:var(--gold);border-color:rgba(201,168,76,.2);}
.badge-aguardando-coleta{background:rgba(61,207,207,.1);color:#3dcfcf;border-color:rgba(61,207,207,.2);}
.badge-aguardando-retirada{background:rgba(244,114,182,.1);color:#f472b6;border-color:rgba(244,114,182,.2);}

/* Payment status badges */
.pay-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-sm);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;border:1px solid transparent;}
.pay-badge-pago{background:rgba(76,175,130,.1);color:var(--green);border-color:rgba(76,175,130,.2);}
.pay-badge-sinal{background:rgba(240,151,74,.1);color:var(--orange);border-color:rgba(240,151,74,.2);}
.pay-badge-retirada{background:rgba(91,156,246,.1);color:var(--blue);border-color:rgba(91,156,246,.2);}

/* Action buttons */
.act-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);width:27px;height:27px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),background var(--dur-fast) var(--ease-out);margin-right:3px;font-size:13px;}
.act-btn:hover{border-color:rgba(201,168,76,.4);color:var(--gold);background:var(--gold-dim);}
.act-btn svg{width:12px;height:12px;}
.act-btn-danger:hover{border-color:rgba(224,85,85,.4);color:var(--red);background:rgba(224,85,85,.08);}
.search-wrap{position:relative;display:inline-flex;align-items:center;}
.search-wrap .bi-search{position:absolute;left:10px;color:var(--placeholder);font-size:12px;pointer-events:none;}
.search-wrap input{padding-left:28px !important;}

.pagination{display:flex;align-items:center;justify-content:space-between;padding:11px 18px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted);}
.pg-btns{display:flex;gap:4px;}
.pg-btn{width:27px;height:27px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out);display:flex;align-items:center;justify-content:center;}
.pg-btn:hover,.pg-btn.active{background:var(--gold-dim);border-color:rgba(201,168,76,.3);color:var(--gold);}
.empty{text-align:center;padding:44px 20px;color:var(--text-muted);}
.empty svg{opacity:.2;margin-bottom:10px;}

/* Vendor ranking */
.vendor-rank{display:flex;flex-direction:column;gap:10px;}
.vr-item{display:flex;align-items:center;gap:10px;}
.vr-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--black);flex-shrink:0;}
.vr-info{flex:1;}
.vr-name{font-size:12px;font-weight:500;}
.vr-bar-wrap{height:4px;background:var(--border-mid);border-radius:2px;margin-top:3px;}
.vr-bar{height:100%;border-radius:2px;transition:width .6s ease;}
.vr-val{font-size:13px;font-weight:600;white-space:nowrap;}

/* Modal */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:200;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.overlay.open{display:flex;}
.modal{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-md);width:540px;max-width:94vw;max-height:90vh;overflow-y:auto;padding:26px;animation:scaleIn .22s var(--ease-spring) both;}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:19px;letter-spacing:3px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;}
.close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:20px;line-height:1;transition:color var(--dur-fast);}
.close-btn:hover{color:var(--white);}
.det-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.det-item label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-muted);display:block;margin-bottom:3px;}
.det-item p{font-size:13px;color:var(--white);}

/* Modal sections */
.modal-section{background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-top:14px;}
.modal-section h4{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}

/* Status selects */
.status-sel{background:var(--surface-2);border:1px solid var(--border);color:var(--white);padding:10px 12px;border-radius:var(--radius-sm);font-family:'DM Sans',sans-serif;font-size:13px;width:100%;outline:none;cursor:pointer;appearance:none;transition:border-color var(--dur-normal) var(--ease-out);}
.status-sel:focus{border-color:var(--gold);}
.modal-row{display:flex;gap:10px;margin-bottom:10px;align-items:flex-end;}
.modal-row .f{flex:1;}
.modal-row label{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-secondary);display:block;margin-bottom:5px;}
.modal-row input{width:100%;background:var(--surface-0);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--white);font-family:'DM Sans',sans-serif;font-size:13px;padding:9px 12px;outline:none;transition:border-color var(--dur-normal) var(--ease-out);}
.modal-row input:focus{border-color:var(--gold);}
.pfx-sm{position:relative;}
.pfx-sm span{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--gold);font-size:12px;font-weight:600;pointer-events:none;}
.pfx-sm input{padding-left:28px;}
.btn-save{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--black);border:none;padding:12px 22px;border-radius:var(--radius-md);font-family:'Bebas Neue',sans-serif;font-size:14px;letter-spacing:2.5px;cursor:pointer;margin-top:16px;width:100%;transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-normal) var(--ease-out);}
.btn-save:hover{transform:translateY(-1px);box-shadow:var(--shadow-gold);}
.btn-save:active{transform:scale(.99);}

.btn-export{background:var(--surface-2);border:1px solid var(--border);color:var(--text-secondary);padding:5px 11px;border-radius:var(--radius-sm);font-size:11px;cursor:pointer;transition:color var(--dur-normal) var(--ease-out);}
.btn-export:hover{color:var(--gold);}

/* Payment highlight in table */
.resta-chip{display:inline-block;font-size:10px;color:var(--red);font-weight:700;margin-top:2px;}
.retirada-chip{display:inline-block;font-size:10px;color:var(--blue);font-weight:600;margin-top:2px;}

.fin-check-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:18px;width:36px;height:36px;cursor:pointer;transition:all var(--dur-normal) var(--ease-out);display:flex;align-items:center;justify-content:center;}
.fin-check-btn:hover{border-color:var(--green);transform:scale(1.1);}
.fin-check-btn.checked{background:rgba(76,175,130,.1);border-color:var(--green);}

@media(max-width:640px){
  /* Nav */
  nav{padding:0 14px;height:52px;}
  .nav-brand span{display:none;}          /* esconde "/ PAINEL" */
  .nav-right{gap:6px;}
  #navName{display:none;}                 /* esconde nome, mantém avatar */
  .user-chip{padding:5px 8px;}
  #btnNovoPedido{font-size:0!important;padding:6px 10px;}  /* esconde texto, mantém ícone */
  #btnNovoPedido i{font-size:15px;}

  /* Tabs */
  .view-tabs{padding:0 14px;}
  .tab{padding:10px 12px;font-size:10px;letter-spacing:1.5px;}

  /* KPIs */
  .kpi-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
  .kpi{padding:14px 12px;}
  .kpi-val{font-size:22px;}

  /* Layout */
  .content{padding:14px;}
  .charts-grid{grid-template-columns:1fr;}

  /* Tabela */
  .tbl-wrap{-webkit-overflow-scrolling:touch;}
  .filter-row{flex-direction:column;}
  .filter-row input,.filter-row select{width:100%;}

  /* Filtro de período (select + datepicker) */
  .filter-date-inputs{flex-wrap:wrap;}
  .filter-date-inputs input[type=date]{flex:1;min-width:120px;width:auto!important;}

  /* Modal */
  .modal{padding:18px 14px;-webkit-overflow-scrolling:touch;}
  .modal-row{flex-direction:column;}
  .modal-row .f{width:100%;}

  /* Login */
  .login-box{padding:30px 20px;}
}

/* Toast */
.toast{position:fixed;bottom:24px;right:24px;padding:13px 18px;border-radius:var(--radius-md);font-size:13px;font-weight:600;z-index:9999;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);transform:translateY(80px);opacity:0;transition:all .3s var(--ease-out);pointer-events:none;max-width:320px;}
.toast.show{transform:translateY(0);opacity:1;}
.toast.success{background:#0d2b1a;border:1px solid var(--green);color:var(--green);}
.toast.error{background:#2b0d0d;border:1px solid var(--red);color:var(--red);}
.toast.loading{background:#0d1a2b;border:1px solid var(--blue);color:var(--blue);}

@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes goldPulse{0%,100%{box-shadow:0 0 0 0 rgba(201,168,76,.4)}50%{box-shadow:0 0 0 6px rgba(201,168,76,0)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}

/* ── Fotos do Pedido ── */
.foto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;margin-top:8px;}
.foto-item{position:relative;border-radius:4px;overflow:hidden;background:var(--surface-0);border:1px solid var(--border);aspect-ratio:1/1;cursor:pointer;}
.foto-item img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity var(--dur-fast);}
.foto-item:hover img{opacity:.8;}
.foto-del-btn{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.65);border:none;color:#fff;width:22px;height:22px;border-radius:50%;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--dur-fast);z-index:1;}
.foto-del-btn:hover{background:var(--red);}
.foto-meta{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.75));padding:14px 5px 4px;font-size:9px;color:rgba(255,255,255,.6);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;}
.btn-foto-upload{display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px dashed var(--border-mid);color:var(--text-secondary);padding:7px 14px;border-radius:var(--radius-sm);font-size:12px;cursor:pointer;transition:border-color var(--dur-normal),color var(--dur-normal);margin-top:8px;font-family:'DM Sans',sans-serif;}
.btn-foto-upload:hover{border-color:var(--gold);color:var(--gold);}

/* Scrollbars dark theme — Chrome/Edge/Safari */
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:var(--surface-0);}
::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:#3a3a3a;}
::-webkit-scrollbar-corner{background:var(--surface-0);}

/* Firefox */
*{scrollbar-width:thin;scrollbar-color:var(--border-mid) var(--surface-0);}
